[{"data":1,"prerenderedAt":-1},["ShallowReactive",2],{"project-8933":3},{"id":4,"name":5,"fullName":6,"owner":7,"repo":5,"description":8,"homepage":9,"htmlUrl":10,"language":11,"languages":10,"totalLinesOfCode":10,"stars":12,"forks":13,"watchers":14,"openIssues":15,"contributorsCount":16,"subscribersCount":16,"size":16,"stars1d":16,"stars7d":16,"stars30d":17,"stars90d":16,"forks30d":16,"starsTrendScore":16,"compositeScore":18,"rankGlobal":10,"rankLanguage":10,"license":19,"archived":20,"fork":21,"defaultBranch":22,"hasWiki":20,"hasPages":20,"topics":23,"createdAt":10,"pushedAt":10,"updatedAt":44,"readmeContent":45,"aiSummary":46,"trendingCount":16,"starSnapshotCount":16,"syncStatus":47,"lastSyncTime":48,"discoverSource":49},8933,"gantt-elastic","neuronetio\u002Fgantt-elastic","neuronetio","Gantt Chart  [ javascript gantt chart, gantt component, vue gantt, vue gantt chart,  responsive gantt, project manager , vue projects ]","https:\u002F\u002Fneuronet.io\u002Fgantt-elastic\u002F",null,"Vue",1367,324,1,4,0,3,55.84,"MIT License",true,false,"master",[24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43],"gantt","gantt-chart","gantt-component","gantt-javascript","javascript","javascript-gantt","jquery","jquery-gantt","project","project-gantt","project-management","responsive","svg","task","task-manager","vue","vue-gantt","vue-gantt-chart","vue-gantt-component","vuejs","2026-06-12 04:00:42","\u003Ch1>Gantt-elastic - Javascript Gantt Chart (editable, responsive)\u003C\u002Fh1>\n\u003Ch2>Javascript Gantt Chart for vue, jquery, vanilla js and other frameworks\u003C\u002Fh2>\n\n\u003Cbr>\n\u003Ch3>Project moved as next major version to \u003Ca href=\"https:\u002F\u002Fgithub.com\u002Fneuronetio\u002Fgantt-schedule-timeline-calendar\">gantt-schedule-timeline-calendar\u003C\u002Fa>\u003C\u002Fh3>\u003Cbr>\u003Cbr>\n\u003Cbr>\n\n\u003Cstrong>This project is not suitable for use in a production environment as it runs very slowly even in standard medium projects. This project has been completely rewritten and built with super performance in mind and is available in the new repository as a \u003Ca href=\"https:\u002F\u002Fgithub.com\u002Fneuronetio\u002Fgantt-schedule-timeline-calendar\">gantt-schedule-timeline-calendar\u003C\u002Fa>.\u003C\u002Fstrong>\n\n\n\u003Ch2>\u003Ca href=\"https:\u002F\u002Fneuronet.io\u002Fgantt-elastic\u002F\" target=\"_blank\">Gantt-elastic demo here\u003C\u002Fa>\u003C\u002Fh2>\n\n![preview img](https:\u002F\u002Fgithub.com\u002Fneuronetio\u002Fgantt-elastic\u002Fraw\u002Fmaster\u002Fgantt-elastic.jpg)\n![preview gif](https:\u002F\u002Fgithub.com\u002Fneuronetio\u002Fgantt-elastic\u002Fraw\u002Fmaster\u002Fgantt-elastic.gif)\n![preview gif](https:\u002F\u002Fgithub.com\u002Fneuronetio\u002Fgantt-elastic\u002Fraw\u002Fmaster\u002Fgrab-scroll.gif)\n\n## Gantt-elastic\n\nis a vue component but it could be used in other frameworks or even with jQuery (vue is kind of elastic and lightweight framework).\n\n[WIKI](https:\u002F\u002Fgithub.com\u002Fneuronetio\u002Fgantt-elastic\u002Fwiki)\n\n[Vue Example](https:\u002F\u002Fgithub.com\u002Fneuronetio\u002Fvue-gantt-elastic)\n\n### Installation\n\n`npm install --save gantt-elastic` or download zip from github \u002F clone repo\n\nand if you want default header\n\n`npm install --save gantt-elastic-header`\n\n### Usage\n\n```html\n\u003C!DOCTYPE html>\n\u003Chtml charset=\"utf-8\">\n  \u003Chead>\n    \u003Cmeta charset=\"utf-8\" \u002F>\n    \u003Cmeta name=\"viewport\" content=\"width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0\" \u002F>\n    \u003Ctitle>GanttElastic editor demo\u003C\u002Ftitle>\n    \u003Cscript src=\"https:\u002F\u002Fcdn.jsdelivr.net\u002Fnpm\u002Fvue\u002Fdist\u002Fvue.js\">\u003C\u002Fscript>\n    \u003Cscript src=\"https:\u002F\u002Fcdn.jsdelivr.net\u002Fnpm\u002Fdayjs\">\u003C\u002Fscript>\n\n    \u003Cscript src=\"https:\u002F\u002Funpkg.com\u002Fgantt-elastic\u002Fdist\u002FGanttElastic.umd.js\">\u003C\u002Fscript>\n    \u003Cscript src=\"https:\u002F\u002Funpkg.com\u002Fgantt-elastic-header\u002Fdist\u002FHeader.umd.js\">\u003C\u002Fscript>\n  \u003C\u002Fhead>\n\n  \u003Cbody>\n    \u003Cdiv style=\"width:100%;height:100%\">\n      \u003Cdiv id=\"app\" v-if=\"!destroy\">\n        \u003Cgantt-elastic :tasks=\"tasks\" :options=\"options\" :dynamic-style=\"dynamicStyle\">\n          \u003Cgantt-header slot=\"header\">\u003C\u002Fgantt-header>\n          \u003Cgantt-footer slot=\"footer\">\u003C\u002Fgantt-footer>\n        \u003C\u002Fgantt-elastic>\n      \u003C\u002Fdiv>\n    \u003C\u002Fdiv>\n\n    \u003Cscript>\n      \u002F\u002F just helper to get current dates\n      function getDate(hours) {\n        const currentDate = new Date();\n        const currentYear = currentDate.getFullYear();\n        const currentMonth = currentDate.getMonth();\n        const currentDay = currentDate.getDate();\n        const timeStamp = new Date(currentYear, currentMonth, currentDay, 0, 0, 0).getTime();\n        return new Date(timeStamp + hours * 60 * 60 * 1000).getTime();\n      }\n\n      let tasks = [\n        {\n          id: 1,\n          label: 'Make some noise',\n          user:\n            '\u003Ca href=\"https:\u002F\u002Fwww.google.com\u002Fsearch?q=John+Doe\" target=\"_blank\" style=\"color:#0077c0;\">John Doe\u003C\u002Fa>',\n          start: getDate(-24 * 5),\n          duration: 15 * 24 * 60 * 60 * 1000,\n          progress: 85,\n          type: 'project',\n          \u002F\u002Fcollapsed: true,\n        },\n        {\n          id: 2,\n          label: 'With great power comes great responsibility',\n          user:\n            '\u003Ca href=\"https:\u002F\u002Fwww.google.com\u002Fsearch?q=Peter+Parker\" target=\"_blank\" style=\"color:#0077c0;\">Peter Parker\u003C\u002Fa>',\n          parentId: 1,\n          start: getDate(-24 * 4),\n          duration: 4 * 24 * 60 * 60 * 1000,\n          progress: 50,\n          type: 'milestone',\n          collapsed: true,\n          style: {\n            base: {\n              fill: '#1EBC61',\n              stroke: '#0EAC51',\n            },\n            \u002F*'tree-row-bar': {\n              fill: '#1EBC61',\n              stroke: '#0EAC51'\n            },\n            'tree-row-bar-polygon': {\n              stroke: '#0EAC51'\n            }*\u002F\n          },\n        },\n        {\n          id: 3,\n          label: 'Courage is being scared to death, but saddling up anyway.',\n          user:\n            '\u003Ca href=\"https:\u002F\u002Fwww.google.com\u002Fsearch?q=John+Wayne\" target=\"_blank\" style=\"color:#0077c0;\">John Wayne\u003C\u002Fa>',\n          parentId: 2,\n          start: getDate(-24 * 3),\n          duration: 2 * 24 * 60 * 60 * 1000,\n          progress: 100,\n          type: 'task',\n        },\n        {\n          id: 4,\n          label: 'Put that toy AWAY!',\n          user:\n            '\u003Ca href=\"https:\u002F\u002Fwww.google.com\u002Fsearch?q=Clark+Kent\" target=\"_blank\" style=\"color:#0077c0;\">Clark Kent\u003C\u002Fa>',\n          start: getDate(-24 * 2),\n          duration: 2 * 24 * 60 * 60 * 1000,\n          progress: 50,\n          type: 'task',\n          dependentOn: [3],\n        },\n      ];\n\n      let options = {\n        maxRows: 100,\n        maxHeight: 300,\n        title: {\n          label: 'Your project title as html (link or whatever...)',\n          html: false,\n        },\n        row: {\n          height: 24,\n        },\n        calendar: {\n          hour: {\n            display: false,\n          },\n        },\n        chart: {\n          progress: {\n            bar: false,\n          },\n          expander: {\n            display: true,\n          },\n        },\n        taskList: {\n          expander: {\n            straight: false,\n          },\n          columns: [\n            {\n              id: 1,\n              label: 'ID',\n              value: 'id',\n              width: 40,\n            },\n            {\n              id: 2,\n              label: 'Description',\n              value: 'label',\n              width: 200,\n              expander: true,\n              html: true,\n              events: {\n                click({ data, column }) {\n                  alert('description clicked!\\n' + data.label);\n                },\n              },\n            },\n            {\n              id: 3,\n              label: 'Assigned to',\n              value: 'user',\n              width: 130,\n              html: true,\n            },\n            {\n              id: 3,\n              label: 'Start',\n              value: (task) => dayjs(task.start).format('YYYY-MM-DD'),\n              width: 78,\n            },\n            {\n              id: 4,\n              label: 'Type',\n              value: 'type',\n              width: 68,\n            },\n            {\n              id: 5,\n              label: '%',\n              value: 'progress',\n              width: 35,\n              style: {\n                'task-list-header-label': {\n                  'text-align': 'center',\n                  width: '100%',\n                },\n                'task-list-item-value-container': {\n                  'text-align': 'center',\n                  width: '100%',\n                },\n              },\n            },\n          ],\n        },\n        \u002F*locale:{\n          name: 'pl', \u002F\u002F name String\n          weekdays: 'Poniedziałek_Wtorek_Środa_Czwartek_Piątek_Sobota_Niedziela'.split('_'), \u002F\u002F weekdays Array\n          weekdaysShort: 'Pon_Wto_Śro_Czw_Pią_Sob_Nie'.split('_'), \u002F\u002F OPTIONAL, short weekdays Array, use first three letters if not provided\n          weekdaysMin: 'Pn_Wt_Śr_Cz_Pt_So_Ni'.split('_'), \u002F\u002F OPTIONAL, min weekdays Array, use first two letters if not provided\n          months: 'Styczeń_Luty_Marzec_Kwiecień_Maj_Czerwiec_Lipiec_Sierpień_Wrzesień_Październik_Listopad_Grudzień'.split('_'), \u002F\u002F months Array\n          monthsShort: 'Sty_Lut_Mar_Kwi_Maj_Cze_Lip_Sie_Wrz_Paź_Lis_Gru'.split('_'), \u002F\u002F OPTIONAL, short months Array, use first three letters if not provided\n          ordinal: n => `${n}`, \u002F\u002F ordinal Function (number) => return number + output\n          relativeTime: { \u002F\u002F relative time format strings, keep %s %d as the same\n            future: 'za %s', \u002F\u002F e.g. in 2 hours, %s been replaced with 2hours\n            past: '%s temu',\n            s: 'kilka sekund',\n            m: 'minutę',\n            mm: '%d minut',\n            h: 'godzinę',\n            hh: '%d godzin', \u002F\u002F e.g. 2 hours, %d been replaced with 2\n            d: 'dzień',\n            dd: '%d dni',\n            M: 'miesiąc',\n            MM: '%d miesięcy',\n            y: 'rok',\n            yy: '%d lat'\n          }\n       }*\u002F\n      };\n\n      \u002F\u002F create instance\n      const app = new Vue({\n        components: {\n          'gantt-header': Header,\n          'gantt-elastic': GanttElastic,\n          'gantt-footer': {\n            template: `\u003Cspan>this is a footer\u003C\u002Fspan>`,\n          },\n        },\n        data: {\n          tasks: tasks.map((task) => Object.assign({}, task)),\n          options,\n          dynamicStyle: {\n            'task-list-header-label': {\n              'font-weight': 'bold',\n            },\n          },\n          destroy: false,\n        },\n      });\n\n      \u002F\u002F gantt state which will be updated in realtime\n      let ganttState, ganttInstance;\n\n      \u002F\u002F listen to 'gantt-elastic.ready' or 'gantt-elastic.mounted' event\n      \u002F\u002F to get the gantt state for real time modification\n      app.$on('gantt-elastic-ready', (ganttElasticInstance) => {\n        ganttInstance = ganttElasticInstance;\n\n        ganttInstance.$on('tasks-changed', (tasks) => {\n          app.tasks = tasks;\n        });\n        ganttInstance.$on('options-changed', (options) => {\n          app.options = options;\n        });\n        ganttInstance.$on('dynamic-style-changed', (style) => {\n          app.dynamicStyle = style;\n        });\n\n        ganttInstance.$on('chart-task-mouseenter', ({ data, event }) => {\n          console.log('task mouse enter', { data, event });\n        });\n        ganttInstance.$on('updated', () => {\n          \u002F\u002Fconsole.log('gantt view was updated');\n        });\n        ganttInstance.$on('destroyed', () => {\n          \u002F\u002Fconsole.log('gantt was destroyed');\n        });\n        ganttInstance.$on('times-timeZoom-updated', () => {\n          console.log('time zoom changed');\n        });\n        ganttInstance.$on('taskList-task-click', ({ event, data, column }) => {\n          console.log('task list clicked! (task)', { data, column });\n        });\n      });\n\n      \u002F\u002F mount gantt to DOM\n      app.$mount('#app');\n    \u003C\u002Fscript>\n  \u003C\u002Fbody>\n\u003C\u002Fhtml>\n```\n\n### gantt-elastic as vue component\n\nTake a look at the `vue.html` inside [examples folder](https:\u002F\u002Fgithub.com\u002Fneuronetio\u002Fgantt-elastic\u002Ftree\u002Fmaster\u002Fexamples) file to see how you could add gantt-elastic inside `\u003Cscript>` tag along with the Vue framework\n\nDemo project: https:\u002F\u002Fgithub.com\u002Fneuronetio\u002Fvue-gantt-elastic\n\nYou can also import gantt-elastic as compiled js component in commonjs or umd format ([examples](https:\u002F\u002Fgithub.com\u002Fneuronetio\u002Fgantt-elastic\u002Ftree\u002Fmaster\u002Fexamples) folder) or just grab GanttElastic.vue from src directory and add to your existing vue project.\n\n```javascript\nimport Vue from 'vue';\nimport GanttElastic from \"gantt-elastic\";\nimport Header from \"gantt-elastic-header\"; \u002F\u002F if you want standard header (npm i -s gantt-elastic-header)\nnew Vue({\n  el:'#gantt',\n  template:`\u003Cgantt-elastic :tasks=\"tasks\" :options=\"options\">\n    \u003Cgantt-elastic-header slot=\"header\">\u003C\u002Fgantt-elastic-header>\n    \u003Cgantt-elastic-footer slot=\"footer\">\u003C\u002Fgantt-elastic-footer>\n  \u003C\u002Fgantt-elastic>`,\n  components: {\n    ganttElasticHeader: {template:`\u003Cspan>your header\u003C\u002Fspan>`}, \u002F\u002F or Header\n    ganttElastic: GanttElastic\n    ganttElasticFooter: {template:`\u003Cspan>your footer\u003C\u002Fspan>`},\n  },\n  data() {\n    return {\n      tasks: tasks,\n      options: options\n    };\n  }\n});\n```\n\nor\n\n```javascript\nimport Vue from 'vue';\nimport App from '.\u002FApp.vue'; \u002F\u002F your app that uses gantt-elastic from 'gantt-elastic\u002Fsrc\u002FGanttElastic.vue'\n\nnew Vue({\n  el: '#app',\n  render: (h) => h(App),\n});\n```\n\n### For webpack usage (pure javascript, inside other frameworks or Vue App\u002FComponent)\n\nTake a look at this demo project: https:\u002F\u002Fgithub.com\u002Fneuronetio\u002Fgantt-elastic-webpack for other bundlers use umd or commonjs from dist folder.\n\n```javascript\nimport GanttElastic from 'gantt-elastic\u002Fdist\u002FGantElastic.umd.js';\nimport GanttElastic from 'gantt-elastic\u002Fdist\u002FGantElastic.common.js'; \u002F\u002F same as import GanttElastic from 'gantt-elastic';\nimport GanttElastic from 'gantt-elastic\u002Fsrc\u002FGantElastic.vue'; \u002F\u002F if you want vue component directly without compilation - look above\n\u002F\u002F and the same with require\nconst GanttElastic = require('gantt-elastic\u002Fdist\u002FGantElastic.common.js');\n```\n\n### uglifyjs\n\nIf you are using uglifyjs in your project be sure to have es6 compatible version like [uglify-es](https:\u002F\u002Fwww.npmjs.com\u002Fpackage\u002Fuglify-es)\n\n### Licensce\n\nMIT\n","Gantt-elastic 是一个基于 Vue 的甘特图组件，同时也支持 jQuery 和其他前端框架。它提供了一个可编辑、响应式的甘特图解决方案，用于项目管理和任务调度。该项目的核心功能包括任务管理、时间线视图和自定义样式，通过 SVG 技术实现高度的灵活性与扩展性。然而需要注意的是，当前版本在处理中等规模项目时性能表现不佳，并不推荐直接应用于生产环境；开发者已将项目迁移至新的仓库 gantt-schedule-timeline-calendar，该新版本针对性能进行了全面优化。因此，gantt-elastic 更适合作为学习或小规模项目的参考示例使用。",2,"2026-06-11 03:20:21","top_language"]