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

react-grid-draw-ui

v1.2.4

Published

A public React NPM library that enables developers to draw grid(s) on top of their web page UI and use the contents within a 2D array data structure.

Downloads

463

Readme

NPM npm version install size

React Grid Draw UI

A sophisticated canvas-based drawing and grid-creation React component library.

Demo: https://ticketedmoon.github.io/react-grid-draw-ui/
Demo Code: https://github.com/Ticketedmoon/react-grid-draw-ui/tree/master/demo

Why is this useful?

This package was born out of needing to copy dynamically generated web content into the clipboard for pasting while maintaining the table structure within the clipboard. Very useful for pasting into Excel or other table-centric applications. This package will allow any react application to very easily integrate the ability to draw grids on top of the DOM structure nested within the wrapper component the package provides.

The package does not provide you with the ability to copy the data directly, but could be added in the future. The reason being is that I didn't want this package to become a multi-functional package and rather to just focus on a single responsibility. However, the public hook provided will allow you to extract the grid data - specifically, it returns an array of 2D arrays (grids), where each index represents the drawing order of the grids. With each 2D array, you can implement your own copy-to-clipboard functionality with relative ease if that is a goal.

Prerequisites

  • React version >= 16.8 (Hook support)

Features Include:

  • Drawing a box on a given react page using simple mouse drag and clicks.
  • Selecting points along the border of the box to indicate columns/rows for a particular grid.
  • Adjustable grid colour, box line width, circle-hover-on-border size, circle-border-shift distance, border-box mouse tolerance via props - More to be added.
  • Multiple Grid Creation - You can draw multiple grids and retrieve data from those multiple grids with a function call.
  • Simplicity - Simply just wrap any div with the <ReactGridDrawUI> component, and it should work out of the box.
  • File support - This library supports both jsx and tsx.

Installing and usage

Install react-grid-draw-ui from npm with the following command.

npm install react-grid-draw-ui

Then use it in your app:

import React, {FunctionComponent} from "react";

import {ReactGridDrawUI, useGridData} from "react-grid-draw-ui";


const App = () => {

	const [getGridData, clearDownGrids, drawRectanglesFromPayloadFunction] = useGridData();

	return (
		<div>
			<div className={"title"}>
				<h2> React Grid Draw UI NPM Library Demo </h2>
			</div>
			<ReactGridDrawUI>
				<div>
					<div>
						<div className={"test-container"}>
							<p> test-A </p>
						</div>
						<div className={"test-container1"}>
							<p> test-B </p>
						</div>
						<div className={"test-container1"}>
							<p> test-C </p>
						</div>
					</div>
				</div>
			</ReactGridDrawUI>
			<button onClick={() => console.log(getGridData())}> Gets Grid Data in a 2D array (Check the web console for results) </button>
			<button onClick={() => clearDownGrids()}> Remove all drawn grids </button>
		</div>
	)
};

Example Demo:

Example Demo Gif

Note:
Whatever width you specify this inner div, the canvas will encompass that element's width. Using the example above, the drawing canvas will be equivalent to the width of the inner div. The example above has the width of the inner div set to 100% with flex display set with two columns - visible in the Github repo demo directory.

Props

You can control the following props by providing values for them. If you don't, react-grid-draw-ui will manage and default them for you.

  • lineClickTolerance - Specifies how far away from the border of the grid can the user click to place a grid line.
  • selectCircleSize - Specifies the size of the circle that appears on-hover of the border of a particular grid.
  • circleLineShiftSize - Specifies the rigidity of the mouse line-detection on the border - lower values will appear smoother, higher values will appear more rigid.
  • contextLineWidth - Specifies the size of the grid lines and on-hover grid lines.
  • lineColour - Specifies the colour of the drawn grids.

Example: <ReactGridDrawUI lineColour={"#ff0000"} contextLineWidth={3}> etc...

Default prop values

  • lineClickTolerance: 15
  • selectCircleSize: 3
  • circleLineShiftSize: 10
  • contextLineWidth: 1
  • lineColour: #1290FF - (Note: You can specify string literals or hex values here)

Public Facing library functions

react-grid-draw-ui exposes 2 elements publicly:

  • <ReactGridDrawUI> - The Wrapper component showed in the example above.
  • useGridData() - A custom hook for getting grid data or using the function suite we provide - see example above.
    • getGridData - Extracts the textual data within your drawn grid and returns the results in a 2D array,
    • clearDownGrids - Removes all grids that were drawn,
    • drawRectanglesFromPayload - This function accepts a list of GridRectangle[] which enables you to pre-render grids on the UI, without the user needing to manually draw.

Grid Rectangle:

type GridRectangle = {
	startX: number,
	startY: number
	endX: number
	endY: number,
	width: number,
	height: number,
	colour?: string,
	horizontalPointsSelected: HorizontalLineType[],
	verticalPointsSelected: VerticalLineType[],
	undoLineList: boolean[]
}

Horizontal Line Type:

type HorizontalLineType = {
	startX: number,
	endX: number
	startY: number,
	colour: string
}

Vertical Line Type:

type VerticalLineType = {
	startX: number,
	startY: number,
	endY: number,
	colour: string
}

Support

For any contributions or feature requests, please head over to the project Github and check out the contribution guide lines or put in an issue for areas where you think the project can be improved.

Thanks

A large thank you to all of those involved and supporting the project.

License

MIT Licensed. Copyright (c) Shane Creedon 2020.