npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@reactuiutils/horizontal-timeline

v1.0.4

Published

A horizontal timeline component for React

Downloads

192

Readme

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

Acknowledgments