UNPKG

@svar-ui/svelte-gantt

Version:

Interactive and customizable Svelte Gantt chart component

101 lines (74 loc) 3.23 kB
<div align="center"> # SVAR Svelte Gantt Chart </div> <div align="center"> [Website](https://svar.dev/svelte/gantt/) • [Getting Started](https://docs.svar.dev/svelte/gantt/getting_started/) • [Demos](https://docs.svar.dev/svelte/gantt/samples/#/base/willow) </div> <div align="center"> [![npm](https://img.shields.io/npm/v/@svar-ui/svelte-gantt.svg)](https://www.npmjs.com/package/@svar-ui/svelte-gantt) [![License](https://img.shields.io/github/license/svar-widgets/gantt)](https://github.com/svar-widgets/gantt/blob/main/license.txt) [![npm downloads](https://img.shields.io/npm/dm/@svar-ui/svelte-gantt.svg)](https://www.npmjs.com/package/@svar-ui/svelte-gantt) [![Last Commit](https://img.shields.io/github/last-commit/svar-widgets/gantt)](https://github.com/svar-widgets/gantt) </div> [SVAR Svelte Gantt](https://svar.dev/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. <div align="center"> <img src="https://cdn.svar.dev/public/gantt-chart-ui.png" alt="UI of SVAR Svelte Gantt Chart - Screenshot"> </div> </br> ### :sparkles: Key Features - Interactive drag-and-drop interface - Intuitive and customizable task edit form - Set task dependencies on the timeline or in a popup form - Showing task progress on the taskbar - Hierarchical view of sub tasks - Reordering tasks in grid with drag-and-drop - Configurable timeline (hours, days, weeks) - Ability to use custom HTML in grid cells - Toolbar and context menu - Tooltips for taskbars - Zooming with scroll - Fast performance with big data sets - Light and dark skins ### :hammer_and_wrench: How to Use To use the Gantt chart widget, simply import the package and include the component in your Svelte file: ```svelte <script> import { Gantt } from "@svar-ui/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](https://docs.svar.dev/svelte/gantt/getting_started/). ### :computer: 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` ### :white_check_mark: Run Tests To run the test: 1. Start the test examples with: ```sh yarn start:tests ``` 2. In a separate console, run the end-to-end tests with: ```sh yarn test:cypress ``` ### :speech_balloon: Need Help? Join our [community forum](https://forum.svar.dev) to get help and submit feature requests.