A React component that shows some events' time and duration on a time scale.
Visit the Live Demo.
- Displays items according to their start and end time.
- Displays items in groups.
- Items with overlapping intervals will display in a stack.
- User can use mouse to pan along the timeline.
- User can scroll in and out to change time scale.
Live Demo: Live Demo
npm install -g nwb@0.23.x
git clone https://github.com/michaelyinopen/timeline.git
cd timeline
npm install
npm start
// or
yarn install
yarn start
npm build
npm pack
// OR
npm build
yarn pack
Creates a michaelyin-timeline-1.0.1.tgz
npm i michaelyin-timeline-1.0.1.tgz
// OR
yarn add michaelyin-timeline-1.0.1.tgz
import {
Timeline,
GroupAxis,
TimelineContent,
ScheduleContainer,
TimeAxis
} from '@michaelyin/timeline';
...
const MyComponent = () => {
return (
<Timeline
timeOptions={timeOptions}
groups={groups}
items={items}
>
<TimelineContent>
<GroupAxis />
<ScheduleContainer focusToZoom />
</TimelineContent>
<TimeAxis />
</Timeline>
);
}
Use the timeline component and its children components as above. The timeline will be rendered with the groups and items.
timeOptions
an object of{ minTime, // javascript Date maxTime, // javascript Date viewStartTime, // javascript Date viewEndTime, // javascript Date minViewDuration, // milliseconds maxViewDuration, // milliseconds }
groups
an array of object of{ id, // unique identifier title, // displayed on the group axis on the left description, // tooltip of the group axis }
items
an array of object of{ id, // unique identifier title, // displayed on the item (optional if you set itemComponent prop) groupId, // id of group start, // javascript Date end, // javascript Date }
itemComponent
(Optional) you can pass a custom react component to render the items. The component receives the item'sid
as prop. See Custom Render Item and Groups.groupComponent
(Optional) you can pass a custom react component to render the group's area where items are placed. The component receives the group'sid
as prop. This does not affect the group axis on the left. See Custom Render Item and Groups.
Note: timeOptions
, groups
and items
props are used only to initialize the timeline. Updates to these props will not take effect, see Controlled Timeline if you want to update these props.
Note: other properties in timeOptions
, groups
and items
objects are ignored.
focusToZoom
By default, when mouse is over the timeline schedule, scrolling will zoom the view time. SetfocusToZoom
to prevent scroll zoom, unless the schedule is selected. Use this if documet scrolling is interrupted by timeline.
focusToZoom
By default, when mouse is over the time-axis, scrolling will zoom the view time. SetfocusToZoom
to prevent scroll zoom, unless the time axis is selected. Use this if documet scrolling is interrupted by timeline.
Other than providing a self-contained Timeline
component, this library also provides a ControlledTimeline
to facilitate integration with other parts of an application.
See Controlled Timeline
The render of items and groups can be changed by setting itemComponent
and/or groupComponent
props on Timeline.
See Custom Render Item and Groups.
see CONTRIBUTING