Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/melfore/konva-timeline
@melfore/konva-timeline is a free, open source, TypeScript ReactJS library that uses konva and react-konva to render a scheduler / gantt / calendar component using canvas.
https://github.com/melfore/konva-timeline
calendar canvas dnd free gantt konva konva-react open-source opensource reactjs scheduler timeline tracker typescript
Last synced: 6 days ago
JSON representation
@melfore/konva-timeline is a free, open source, TypeScript ReactJS library that uses konva and react-konva to render a scheduler / gantt / calendar component using canvas.
- Host: GitHub
- URL: https://github.com/melfore/konva-timeline
- Owner: melfore
- License: mit
- Created: 2023-06-12T09:52:27.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-10-02T13:51:16.000Z (4 months ago)
- Last Synced: 2025-01-09T22:08:58.521Z (13 days ago)
- Topics: calendar, canvas, dnd, free, gantt, konva, konva-react, open-source, opensource, reactjs, scheduler, timeline, tracker, typescript
- Language: TypeScript
- Homepage: https://melfore.github.io/konva-timeline/
- Size: 15.4 MB
- Stars: 42
- Watchers: 3
- Forks: 3
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# @melfore/konva-timeline
[![Konva Timeline - Release](https://github.com/melfore/konva-timeline/actions/workflows/release.yml/badge.svg?branch=main)](https://github.com/melfore/konva-timeline/actions/workflows/release.yml) [![Commitizen friendly](https://img.shields.io/badge/commitizen-friendly-brightgreen.svg)](http://commitizen.github.io/cz-cli/)
`@melfore/konva-timeline` is a TypeScript ReactJS library that uses `konva` and `react-konva` to render a timeline component using canvas.
![sample](./assets/sample.gif)
## Features
This library is meant to represent data on a time range. It has been developed in a way to be the most generic it could. It can be used to display _gantt charts_, _schedulers_ and _planners_.
The library follows the concept of organizing data (tasks) belonging to specific groups (resources) over a predefined time window.
### Interaction
There can be from none to many tasks per each resource and tasks can be moved across resources. Tasks can also be resized and hovered.
For each user interaction with tasks there is a dedicated hook function exposed by the component's props. This enables various use cases like displaying the details of a task inside a modal or calling an API each time the task is moved.
### Gantt
In order to create and display connection between tasks is neccesary setting dedicated props:
- relatedTasks is a string array prop of TaskData that contains Ids of related Tasks.
- enableLines is a global prop for the visualization of the connections.In this case OnTasksChange return also array of all tasks id that are inpacted by changed end of a the task at hand, and value of time in milliseconds of this variation.
⚠️ By relatedTasks is mean these tasks that their start can depends of the end of the task in question.
![gantt](./assets/gantt.png)
### Custom display
Size of columns and rows can be adjusted using dedicated props:
![column width](./assets/column-width.png)
![row height](./assets/row-height.png)
Resolution of the timeline can be changed as well, choosing the right one for your scenario.
Below a comparison of the same data set using 5 mins resolution:
![5mins resolution](./assets/resolution-5mins.png)
Now with 2 hours resolution:
![2hrs resolution](./assets/resolution-2hrs.png)
### Tasks
In many of the above mentioned use cases it's important to track the progress of tasks. That's why we offer a built-in visualization for percentage of completion:
![completed percentage](./assets/completed-percentage.png)
Tasks can also have their label displayed:
![label display](./assets/label-display.png)
### Handling timezones and DST
The library uses `luxon` to handle dates and date-times. This allows localization (see next paragraph) and handling of timezones and DST.
The default timezone configuration is `system` (meaning the system's local zone). This can be overridden using the dedicated prop.
Along with timezones, the library handles DST changes (if any).
In the example below the switch of DST for spring 2020, happening between March 28th and March 29th.![timezones dst](./assets/timezones-dst.png)
### Localization
Date formats and static texts can be localized:
![localized](./assets/localized.png)
### Area Select
Select area to get its timeRange and resourceId:
![area selected](./assets/selected-area.png)
### Personalized ToolTip
It's possible to personalize the toolTip passing createToolTip callback that return jsx element
![personalized toolTip](./assets/personalized-tooltip.png)
### Personalized Resource and Clickable Resource
It's possible to personalize the resource passing `customResources` callback that return jsx element.
CustomResources expose a prop `ResourceData` that contain data of a single resource and also its dimension,
it allow a easy acces to the width and heigh in order to fit a custom Resource.If `onResourceClick` is set, it allow an click event on resource
![personalized toolTip](./assets/customRes.png)
### Summary
Display a new column by setting Summary data prop, id of a single summary's value must be the same as the resource's id in order to display that value in the right place.
If id does not exist, 🚫 will be dispaly instead of the value.In order to diplay the data its also necessary set `showSummary` prop.
Default summary header is "Summary", its possible to change it passing a new header by `summaryHeader` prop
![personalized toolTip](./assets/summary.png)
## Getting started
To install the library run:
```
npm i @melfore/konva-timeline
```This library has the following required peerDependencies:
```
"konva": ">= 9.2.0 < 10",
"luxon": ">= 3.3.0 < 4",
"react": ">= 18.2.0 < 19",
"react-dom": ">= 18.2.0 < 19",
"react-konva": ">= 18.2.9 < 19",
"react-konva-utils": ">= 1.0.5 < 2"
```### ⚠️ Installing with npm < 7
If installing with versions of npm < 7, you have to manually install them.
```
npm i konva luxon react react-dom react-konva
```Beware to check the versions installed, they must match peerDependencies ranges.
### Usage
Import the `KonvaTimeline` component from `@melfore/konva-timeline` library:
```
import { KonvaTimeline } from "@melfore/konva-timeline";
```Provide the minimum set of required props.
```
```This will print an empty timeline with three resources:
![usage empty](./assets/usage-empty.png)
Add an array of tasks:
```
```The `resourceId` property of each task assigns the task to the respective resource.
![usage final](./assets/usage-final.png)
## Documentation and examples
Browse official StoryBook