Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@purple/phoenix-components

Package Overview
Dependencies
Maintainers
35
Versions
197
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@purple/phoenix-components

[![This project is using Percy.io for visual regression testing.](https://percy.io/static/images/percy-badge.svg)](https://percy.io/Purple-Technology/phoenix-components)

  • 5.0.0-alpha.4
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
303
decreased by-37.91%
Maintainers
35
Weekly downloads
 
Created
Source

Phoenix components

This project is using Percy.io for visual regression testing.

Our aim is to build a simple React components library using styled-components and TypeScript.

3rd party libraries

Phoenix Components takes advantage of some 3rd party libraries to create consistently styled components

  • @tippyjs/react - dropdown and positioning engine for the Dropdown component
  • countries-and-timezones - list of timezones for the TimezonePicker component
  • is-mobile - detecting mobile device for the Select component
  • nanoid - unique string ID generator for Checkbox and Radio components
  • noUiSlider - complete solution for the Slider (and Range) component
  • react-day-picker - date picker for DatePicker and DateRangePicker components
  • react-dropzone - drag'n'drop support for the FileUpload component
  • react-inlinesvg - Inline loading of SVG files (to support hover effects) across all components using icons
  • react-pdf - PDF files preview for the FileUpload component
  • react-select - complete solution for the Select component
  • react-tabs - complete solution for the Tabs component and its subcomponents (TabList, Tab and TabPanel)

Demo & Documentation

Phoenix Components Storybook

Install

npm i @purple/phoenix-components

Usage

  1. Phoenix components use by default Mulish font with weights 400 and 600. If you want to use this default font, please add it to your project, using for example Google Fonts. (If you want to use different font family and/or different font weights, please refer to the section Customization.)
<link rel="preconnect" href="https://fonts.gstatic.com">
<link href="https://fonts.googleapis.com/css2?family=Mulish:wght@400;600&display=swap" rel="stylesheet">
  1. Import Theme from Phoenix Components and wrap the app in <ThemeProvider> from styled-components providing the Theme object. If your repository already contains custom styled-components theme, merge both themes together. If you're going to use overrides inside $pc key (see the Customization section), you need to use deep merge (e.g. merge from lodash).

    Also, import <GlobalStyles> component which provides styles such as default font and sizes, and include it once in your project.

import merge from 'lodash/merge'
import { ThemeProvider } from 'styled-components'
import { GlobalStyles, Theme as PhoenixTheme } from '@purple/phoenix-components'
import { Theme } from './CustomAppTheme'
...

function App() {
  return (
    <ThemeProvider theme={merge(PhoenixTheme, Theme)}>
      <GlobalStyles />
      { ... your app ... }
    </ThemeProvider>
  )
}

You can optionally include dir key in the theme with values either 'ltr' or 'rtl'. This is not required but it will slightly optimize CSS generated to support right-to-left layouts, resulting in smaller footprint.

...
<ThemeProvider theme={merge({ dir: 'rtl' }, Theme)}>
...
  1. Import components that you need and use them according to the docs.
import { TextInput } from '@purple/phoenix-components'

Customization

You can either extended the components with styled-components. For example:

import styled from 'styled-components'
import { TextInput } from '@purple/phoenix-components'

const StyledInput = styled(TextInput)`
	// css overrides here
`

Or you can override the default properties inside the $pc object. In your own theme file, define the overrides as shown below, deep merge your theme file with the Phoenix theme file, and provide it to ThemeProvider.

export const Theme = {
	...

	// overriding phoenix components defaults
	$pc: {
		fontFamily: 'Mulish, sans-serif',
		fontWeight: {
			regular: 400,
			bold: 600
		}
	}
}

For more information about what's possible to customize please refer directly to the file src/theme.tsx.

🔼 Migration guide from v4 to v5

Phoenix Components ver. 5 transitioned to using Design tokens. This change affected namings of several entities.

Sizes

Sizes of the components have been updated to be more consistent with other sizing and spacing units.

Previous sizeCurrent size
tinyxs
smallsm
mediummd
largelg

These changes affect components Button, ButtonGroup, DateInput, Heading, LinkButton, List, Modal, MultiSelect, Pagination, Paragraph, Tag and Text.

What to do?

Find all instances of size="tiny" and replace with size="xs". Similarly for other sizes. Don't forget that a value can be written also for example size={'tiny'} or that value can be calculated so you won't be able to look these instances so easily.

Also sizing types have been renamed.

Previous size typeCurrent size type
ComponentSizeSizing
ComponentSizeSmallMediumSizingSmMd
ComponentSizeMediumLargeSizingMdLg
ComponentSizeSmallMediumLargeSizingSmMdLg
What to do?

Replace all previous size types with the new ones.

Colors

Text colors were renamed

Previous colorCurrent color
darkestprimary
darksecondary
lighttertiary
lightestquaternary

These changes affect components Heading, Paragraph and Text.

For the ColorTheme enum and colorTheme props, the color primary has been renamed to color brand. Other colors (success, warning, error, info, neutral) remain the same.

What to do?
  • Search for all colorTheme="primary" and replace with colorTheme="brand"
  • Search for all color="darkest" and replace with color="primary". Same for dark, light and lightest.

Spacings

Spacings were also updated to be more consistent with other units. However, these changes are backwards compatible. Old values have been deprecated and will be removed in the next major version.

Previous valueCurrent value
xxxs3xs
xxs2xs
xsxs
ssm
mmd
llg
xlxl
xxl2xl
xxxl3xl
What to do?

Since these changes are backwards-compatible, you don't have to do anything right now.

Both components have now a new style available - outline. This style can be enabled by the prop named outline.

Minimal style is now available in all color themes. Default style for minimal is now brand, instead of neutral.

What to do?

If you want to keep the same styling, add colorTheme="neutral" to Buttons with minimal prop.

Tag

Previously, this component had only a single style. Currently, there are 3 styles available that correpond with the styles of the button - primary, secondary and outline. Default style is now primary. Previous style is currently secondary and must be explicitly enabled by the prop secondary.

What to do?

Search for all instances of Tag component and add secondary prop.

Heading, Paragraph and Text

Prop colorTheme has been removed and there's only color prop now excepting all text colors (primary, secondary, tertiary, quaternary), color theme colors (brand, success, warning, error, info, neutral) and any valid CSS value.

Instead of 3 sizes (small, medium, large), these components now include 4 sizes - xs, sm, md, lg. For Text and Paragraph components, default value is now sm. Since there's one more size, original size small is now xs.

What to do?
  • Search all instances of Text, Paragraph and Heading and replace colorTheme with color.
  • Replace size="small" with size="xs". (If you already replaced sizing with new sizes, you have to search for size="sm".)

Also, Paragraph component now has a new prop lineHeight which accepts standard sizing values xs, sm, md and lg or any other valid CSS value. Default value is md.

List and ListItem

Prop colorTheme has been removed and there's only color prop now excepting all text colors (primary, secondary, tertiary, quaternary), color theme colors (brand, success, warning, error, info, neutral) and any valid CSS value. Also, color prop now affects only text. To change color of the bullet, use bulletColor which accepts the same values.

What to do?
  • Search all instances of List and ListItem and replace colorTheme with bulletColor.
  • Search for all bulletColor props and change darkest to primary, dark to secondary etc. (see the section Colors)

Icon

Props colorTheme and light removed and replaced with a simple color prop. This prop behaves similarly like prop color in Heading/Text/Paragraph components, ie. excepting all text colors (primary, secondary, tertiary, quaternary), color theme colors (brand, success, warning, error, info, neutral) and any valid CSS value.

What to do?
  • Search for all instances of Icon component and if there's a light prop, then just replace it with color="white"
  • Search for all instances of Icon component and replace all colorTheme props with color (Note: If you haven't already done it before, replace values primary with brand - see the section Colors)

🔼 Migration guide from v3 to v4

In prop tables, all removed properties are listed with notes how to update the component.

Alert

Renamed to Notice.

PropertyNotes
textUse children instead.
centerTextToo specific prop. Centered text in a notice component is discouraged. If needed, however, it can be done manually through child element with custom styling.
typeUse colorTheme instead.
contentColorUse colorTheme instead.
backgroundColorUse colorTheme instead.
titleUse children instead.

Button

PropertyNotes
colorUse colorTheme instead.
backgroundUse colorTheme instead.

CheckBox

Renamed to Checkbox (B lowercase).

PropertyNotes
colorUse colorTheme instead.

DateInput

PropertyNotes
labelRemoved. If needed, use standalone component Label.

FileUpload

PropertyNotes
colorUse colorTheme instead.

SelectBox

Renamed to Select.

PropertyNotes
autoCompleteRemove. Select does not support autoComplete prop and it was not used in the v3 anyway.
descriptionDescription is not part of this component anymore. If any description above the text input is needed, use component Text or Paragraph.
backgroundRemove. Should not be desired. We strive for unified design.
borderRemove. Should not be desired. We strive for unified design.
rowHeightRemove without replacement.

SelectPicker

PropertyNotes
borderColorUse colorTheme instead.
labelRemoved. If needed, use standalone component Label.

TextArea

PropertyNotes
typeRemove without replacement. textarea does not have an attribute type.
withBorderRemove without replacement. Should not be desired. We strive for unified design.

TextInput

PropertyNotes
descriptionDescription is not part of this component anymore. If any description above the text input is needed, create a custom element with custom styling.
descriptionFontSizeThe same applies as for description prop.
backgroundRemove without replacement. Background color should not be modified.
disableErrorTextIf we don't want to display error text but want to mark the input as errored, we set the property error to true (instead of string).
focusColorRemove without replacement. Focus color should not be modified.

Keywords

FAQs

Package last updated on 24 Jan 2023

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc