@dmitrychebayewski/material-ui-4-color
TypeScript icon, indicating that this package has built-in type declarations

1.2.5 • Public • Published

material-ui-color picker and other components

Build Status codecov NPM version License minisize dependency status dev dependency status peer dependency status Downloads

Collections of color components for material-ui. No dependencies, small, highly customizable and theming support !

Video of ColorPicker

Contents

Why rework Mikbry's project?

  • Plans are submitting PR into his mui-color project, but I need enhanced Color Picker MUI 4 for a limited time;
  • Allows passing useful properties to material-ui TextField underlying component;
  • Stable version 1.2.0 codebase, Material UI V.4;
  • ColorPicker adornment: Button, embedded in the underlying TextField (similarly to material-ui-pickers experience).

Why another ColorPicker ?

  • Fully compatible with Material-UI : theming and low level components
  • Highly customizable ColorPicker : gradient picker, palette, input format, deferred mode
  • Small in size (<30kb) without any direct dependencies
  • Use modern React hook and coding conventions
  • Documentation made with Storybook, using Component Story Format and MDX

Documentation

Full documentation is available here :

https://mikbry.github.io/material-ui-color/

Examples

You can find examples here and here.

Also in codesanbox

Requirements

  • Works on modern browsers supporting ES6+ (Not compatible with IE)
  • React and Material-UI frameworks

Install

yarn add @dmitrychebayewski/material-ui-4-color

Or using npm

npm install @dmitrychebayewski/material-ui-4-color

Usage

you need to have in your dependencies:

    "@material-ui/core": "^4.11.2",
    "material-ui-popup-state": "^1.7.1",
    "prop-types": "^15.7.2",
    "react": "^17.0.1",
    "react-dom": "^17.0.1",

material-ui-color bring 5 components.

<ColorPicker/>

A popover component to display a color tool box. It uses ColorBox and material-ui-popup-state.

import { ColorPicker } from 'material-ui-color';

export const Container = () => (
  <div>
    <ColorPicker defaultValue="transparent"/>
  </div>
);

ColorPicker documentation

<ColorBox />

A component to display a color tool box

import { ColorBox } from 'material-ui-color';

export const Container = () => (
  <div>
    <ColorBox defaultValue="transparent"/>
  </div>
);

ColorBox documentation

<ColorInput />

An input component to display/edit color values in different format (plain, hex, rgb, hsl, hsv).

import { ColorInput } from 'material-ui-color';

export const Container = () => (
  <div>
    <ColorInput defaultValue="red"/>
  </div>
);

ColorInput documentation

<ColorPalette />

A component to display a grid of color buckets.

import { ColorPalette } from '@dmitrychebayewski/material-ui-4-color';

const palette = {
  red: '#ff0000',
  blue: '#0000ff',
  green: '#00ff00',
  yellow: 'yellow',
  cyan: 'cyan',
  lime: 'lime',
  gray: 'gray',
  orange: 'orange',
  purple: 'purple',
  black: 'black',
  white: 'white',
  pink: 'pink',
  darkblue: 'darkblue',
};

export const Container = () => (
  <div>
    <ColorPalette palette={palette} />
  </div>
);

ColorPalette documentation

<ColorButton />

Displays a button filled with a color

import { ColorButton } from 'material-ui-color';

export const Container = () => (
  <div>
    <ColorButton color="red"/>
  </div>
);

ColorButton documentation

Roadmap

v1.2.5 - Current version

  • More Picker Button adornments
  • Submit a PR to Mikbry's mui-color
  • Make @dmitrychebayewski/material-ui-4-color deprecated

Contribute

Contributions welcome! Read the contribution guidelines first.

License

Released under MIT License

Package Sidebar

Install

npm i @dmitrychebayewski/material-ui-4-color

Weekly Downloads

2

Version

1.2.5

License

MIT

Unpacked Size

267 kB

Total Files

8

Last publish

Collaborators

  • dmitrychebayewski