{"id":16410017,"url":"https://github.com/juliandavidmr/onboard","last_synced_at":"2025-07-29T23:14:51.294Z","repository":{"id":70333142,"uuid":"309011540","full_name":"juliandavidmr/onboard","owner":"juliandavidmr","description":"Onboard is an extensible framework for visual programming. Onboard allows you to create a node editor from the browser. You can define nodes and events that allow you to create instructions to process data in your editor.","archived":false,"fork":false,"pushed_at":"2020-11-28T03:17:24.000Z","size":435,"stargazers_count":12,"open_issues_count":0,"forks_count":0,"subscribers_count":4,"default_branch":"main","last_synced_at":"2025-04-07T23:11:23.063Z","etag":null,"topics":["d3","node-editor","visual-programming"],"latest_commit_sha":null,"homepage":"","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/juliandavidmr.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2020-11-01T02:49:20.000Z","updated_at":"2024-03-06T10:43:47.000Z","dependencies_parsed_at":null,"dependency_job_id":"fc0b1398-1301-47c5-9475-938e3b080f66","html_url":"https://github.com/juliandavidmr/onboard","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/juliandavidmr/onboard","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/juliandavidmr%2Fonboard","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/juliandavidmr%2Fonboard/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/juliandavidmr%2Fonboard/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/juliandavidmr%2Fonboard/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/juliandavidmr","download_url":"https://codeload.github.com/juliandavidmr/onboard/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/juliandavidmr%2Fonboard/sbom","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":267779064,"owners_count":24143176,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","status":"online","status_checked_at":"2025-07-29T02:00:12.549Z","response_time":2574,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["d3","node-editor","visual-programming"],"created_at":"2024-10-11T06:22:37.814Z","updated_at":"2025-07-29T23:14:51.287Z","avatar_url":"https://github.com/juliandavidmr.png","language":"TypeScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"![](./demo.png)\n\n# **Onboard**\n\nOnboard is an extensible framework for visual programming. Onboard allows you to create a node editor from the browser. You can define nodes and events that allow you to create instructions to process data in your editor.\n\nOnboard is based on [d3.js](https://d3js.org/).\n\n## How it works?\n\n- [x] No canvas.\n- [x] Based on [d3.js](https://d3js.org/).\n\n## Extensions\n\n- [x] Connectors.\n- [ ] Autopositioning.\n- [ ] minimap.\n\n## TODO\n\n- [ ] Export/Import JSON.\n- [x] Events.\n- [x] Node Connector.\n- [ ] Pin protection.\n- [ ] Control: Input\n- [ ] Control: Label.\n- [ ] Avoid cyclic connections.\n- [ ] Demo website.\n\n## Example\n\n```ts\nimport { Editor, NodeComponent, Pin } from \"./Onboard\";\nimport * as Connector from \"./Onboard/extensions/connectors.ext\";\n\nconst root = \"#root\";\n\nconst Node1 = new NodeComponent({ title: \"Node1\" });\nconst Node2 = new NodeComponent({ title: \"Node2\" });\nconst Node3 = new NodeComponent({ title: \"Node3\" });\n\nconst editor = new Editor({\n    name: \"schema1\",\n    root,\n    nodes: [Node1, Node2, Node3]\n});\n\nNode1.addInput(new Pin(\"out1\", \"Output 1\"));\n\nNode2.addInput(new Pin(\"in1\", \"Input 1\"));\nNode2.addInput(new Pin(\"in2\", \"Input 2\"));\nNode2.addOutput(new Pin(\"out1\", \"Output 1\"));\n\nNode3.addInput(new Pin(\"in1\", \"Input 1\"));\nNode3.addOutput(new Pin(\"out1\", \"Output 1\"));\nNode3.addOutput(new Pin(\"out2\", \"Output 2\"));\nNode3.addOutput(new Pin(\"out3\", \"Output 3\"));\n\neditor.install(Connector);\n```\n\n## Development\n\n1. Clone\n2. `npm install`\n3. `npm run start`\n4. Open http://localhost:1234\n\n**License**\n\n[MIT](./LICENSE)\n\n**You are free to contribute to this project. :)**","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fjuliandavidmr%2Fonboard","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fjuliandavidmr%2Fonboard","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fjuliandavidmr%2Fonboard/lists"}