Skip to content

Svelte Gantt Chart component with interactive, drag-and-drop interface

License

Notifications You must be signed in to change notification settings

svar-widgets/gantt

Repository files navigation

SVAR Svelte Gantt Chart

🌐 Website • 💡 Getting Started • 👀 Demos

npm License npm downloads

SVAR Svelte Gantt is a customizable, easy-to-use, and interactive Gantt chart component written in Svelte. Its intuitive interface allows users to add and manage tasks and dependencies directly on the timeline using drag-and-drop or via a simple task edit form.

UI of SVAR Svelte Gantt Chart - Screenshot

✨ Key Features

  • Interactive drag-and-drop interface
  • Intuitive and customizable task edit form
  • Set task dependencies on the timeline or in a popup form
  • Hierarchical view of sub tasks
  • Reordering tasks in grid with drag-and-drop
  • Configurable timeline (hours, days, weeks)
  • Zooming with scroll
  • Showing task progress on the taskbar
  • Toolbar and context menu
  • Tooltips for taskbars
  • Fast performance with big data sets

🛠️ How to Use

To use the widget, simply import the package and include the component in your Svelte file:

<script>
	import { Gantt } from "wx-svelte-gantt";

	const tasks = [
		{
			id: 1,
			start: new Date(2024, 3, 2),
			end: new Date(2024, 3, 17),
			text: "Project planning",
			progress: 30,
			parent: 0,
			type: "summary",
			open: true,
			details: "Outline the project's scope and resources.",
		},
	];
	const links = [];
	const scales = [
		{ unit: "month", step: 1, format: "MMMM yyy" },
		{ unit: "day", step: 1, format: "d", css: dayStyle },
	];
</script>

<Gantt {tasks} {links} {scales} />

For further instructions, follow the deatailed how-to-start guide.

💻 How to Modify

Typically, you don't need to modify the code. However, if you wish to do so, follow these steps:

  1. Run yarn to install dependencies. Note that this project is a monorepo using yarn workspaces, so npm will not work
  2. Start the project in development mode with yarn start

✅ Run Tests

To run the test:

  1. Start the test examples with:
    yarn start:tests
  2. In a separate console, run the end-to-end tests with:
    yarn test:cypress

💬 Need Help?

Post an Issue or use our community forum.