Sorry, but you either have no stories or none are selected somehow.
If the problem persists, check the browser console, or the terminal you've run Storybook from.
UI component library based on tailwindcss, heroicons. Topaz is a MIT licensed project that is developed and maintained by Antônio Zanotti.
npm i -D topaz-react
Install Tailwind CSS (instructions here)
Update the tailwind.config.ts file:
import type { Config } from "tailwindcss"; import presetTopazReact from "topaz-react/src/preset/tailwind-preset-topaz-react"; const config: Config = { content: ["./node_modules/topaz-react/src/components/*.{js,ts,jsx,tsx,mdx}"], presets: [presetTopazReact], }; export default config;
That's all! Topaz's components can be imported in your .tsx files.
import { TzButton } from 'topaz-react'; export default function Home() { return <TzButton label="Button" />; }
You can customize colours and font sizes, just update the tailwind.config.ts file.
import type { Config } from "tailwindcss"; import presetTopazReact from "topaz-react/src/preset/tailwind-preset-topaz-react"; const config: Config = { content: ["./node_modules/topaz-react/src/components/**/*.{js,ts,jsx,tsx,mdx}"], presets: [presetTopazReact], theme: { fontSize: { c1: '10px', c2: '12px', c3: '14px', c4: '16px', c5: '20px', c6: '24px', c7: '32px', c8: '36px', c9: '40px', c10: '48px', c11: '64px', c12: '96px', }, colors: { accent: { DEFAULT: '#0891B2', 1: '#06B6D4', 2: '#22D3EE', }, 'dark-accent': { DEFAULT: '#22D3EE', 1: '#06B6D4', 2: '#0891B2', }, primary: { DEFAULT: '#083344', 1: '#164E63', 2: '#155E75', }, 'dark-primary': { DEFAULT: '#E2E8F0', 1: '#CBD5E1', 2: '#94A3B8', }, secondary: { DEFAULT: '#94A3B8', 1: '#CBD5E1', 2: '#E2E8F0', }, 'dark-secondary': { DEFAULT: '#155E75', 1: '#164E63', 2: '#083344', }, negative: { DEFAULT: '#B91C1C', 1: '#DC2626', 2: '#EF4444', }, 'dark-negative': { DEFAULT: '#EF4444', 1: '#DC2626', 2: '#B91C1C', }, dark: { DEFAULT: '#E5E7EB', 1: '#F3F4F6', 2: '#FFFFFF', }, 'dark-dark': { DEFAULT: '#000000', 1: '#111827', 2: '#1F2937', }, light: { DEFAULT: '#000000', 1: '#111827', 2: '#1F2937', }, 'dark-light': { DEFAULT: '#FFFFFF', 1: '#F3F4F6', 2: '#E5E7EB', }, 'inverse-accent': '#000000', 'inverse-dark-accent': '#000000', 'inverse-primary': '#FFFFFF', 'inverse-dark-primary': '#000000', 'inverse-secondary': '#000000', 'inverse-dark-secondary': '#FFFFFF', 'inverse-negative': '#FFFFFF', 'inverse-dark-negative': '#000000', 'inverse-dark': '#000000', 'inverse-dark-dark': '#FFFFFF', 'inverse-light': '#FFFFFF', 'inverse-dark-light': '#000000', }, }, }; export default config;
The components was designed to work with these variants:
Light Theme:
Dark Theme:
This color palette is ordered by contrast between variants (accent, primary, secondary...) and also shades (default, 1, 2).
You can use a color contrast checker to help calculate the contrast. The colours dark-2 and dark-dark-2 are used for background.
Browse the stories in the sidebar menu to know the different React components in the Topaz catalog and see usage examples for every component. You can try change props and share the result with others, just copy the URL anytime.
If you want to simulate how the component looks in dark theme, you can switch the theme in the toolbar. It uses class strategy of tailwindcss.
The colours swap with each other by 'dark-' prefix.
If you want to see how the component looks in different screen sizes, you can switch the screen size in the toolbar. Some components on screens larger than or equal to 1024px will be ~20% smaller than its mobile version.