@reactuiutils/horizontal-timeline
TypeScript icon, indicating that this package has built-in type declarations

1.0.4 • Public • Published

Horizontal Timeline

A simple horizontal timeline component made with React.

This is an re-implementation using design composition, typescript and responsive CSS of the Horizontal Timeline from mailtop.

Thank you guys for the original work ❤️.

Installation

# with npm
npm install @reactuiutils/horizontal-timeline
# with yarn
yarn add @reactuiutils/horizontal-timeline
# with pnpm
pnpm i @reactuiutils/horizontal-timeline

Usage

CSS Import

1.Import the timeline.css file into the main file or corresponding file in your project

import '@reactuiutils/horizontal-timeline/timeline.css';

2.Use the components

import {
  Action,
  Event,
  Subtitle,
  Timeline,
  Title,
} from '@reactuiutils/horizontal-timeline';
import { FaBug, FaRegCalendarCheck } from 'react-icons/fa'; // or any other icon

export const MyTimeline = () => {
  return (
    <Timeline minEvents={6}>
      {/* Without action */}
      <Event color="#87a2c7" icon={FaRegCalendarCheck}>
        <Title>Agendado</Title>
        <Subtitle>26/03/2019 09:51</Subtitle>
      </Event>

      {/* With action */}
      <Event color="red" icon={FaBug}>
        <Title>Erro</Title>
        <Subtitle>26/03/2019 09:51</Subtitle>
        <Action onClick={() => alert('clicou')}>Detalhes</Action>
      </Event>

      {/* Without title, subtitle and action */}
      <Event color="darkGreen" icon={FaRegCalendarCheck} />
    </Timeline>
  );
};

Preview

preview image

Props

Timeline

The Timeline component is used to render a horizontal timeline.

Props

  • minEvents (number): The minimum number of events to display on the timeline. If the rendered events are less than this number, the timeline will be render fallbacks instead to complete the total number.

Event

The Event component represents an event on the timeline.

Props

  • color (string): The color of the event.
  • icon (ReactNode): The icon to display for the event. Any valid SVG component can be used.

Title

The Title component represents the title of an event.

Subtitle

The Subtitle component represents the subtitle of an event.

Action

The Action component represents an action associated with an event.

Props

  • onClick (function): The function to be called when the action is clicked.

License

## License

MIT

Contributing

Feel free to contribute to this project. Any help is welcome.

Developmet

  1. Clone the repository
  2. Install the dependencies using pnpm i on root folder
  3. To Run the lib on development mode use pnpm lib dev on root folder
  4. To Run the example on development mode use pnpm example-vite dev on root folder
  5. To build the lib use pnpm lib build on root folder

Folders

  • lib - /lib - The library source code
  • example-vite - /examples/example-with-vite - The example source code

Technologies and Tools

  • React - A JavaScript library for building user interfaces
  • TypeScript - A typed superset of JavaScript that compiles to plain JavaScript
  • Vite - A build tool that aims to provide a faster and leaner development experience for modern web projects
  • pnpm - A fast, disk space efficient package manager
  • Tailwind CSS - A utility-first CSS framework for rapidly building custom designs

This project are planned to be an monorepo using pnpm-workspaces.

Author

  • renanlido - Renan Oliveira

Acknowledgments

  • mailtop - Original work
  • guilhermeoholz - Original work

Package Sidebar

Install

npm i @reactuiutils/horizontal-timeline

Weekly Downloads

33

Version

1.0.4

License

MIT

Unpacked Size

16.5 kB

Total Files

5

Last publish

Collaborators

  • renanlido