@siteed/design-system
TypeScript icon, indicating that this package has built-in type declarations

0.8.1 • Public • Published

@siteed/design-system

Introduction

@siteed/design-system is a comprehensive cross-platform design system built for Expo and React Native. It extends react-native-paper to provide a robust set of UI components that are easy to implement and customize. Designed with an opinionated selection of libraries, it simplifies the integration process and reduces setup time, allowing developers to focus on building high-quality mobile apps efficiently.

Key Features

  • Opinionated Library Choices: Includes essential libraries such as react-native-paper and react-native-safe-area-context, ensuring compatibility and functionality.
  • Ready-to-Use Components: From typography to modals, get access to a variety of UI components that are production-ready and customizable.
  • Streamlined Configuration: Pre-configured settings and integrations to speed up the development process, making it ideal for rapid prototyping and production projects.
  • Dark Mode Support: Easily toggle themes with built-in dark mode support.

Installation

npx expo install @siteed/design-system @siteed/react-native-logger react-native-paper react-native-safe-area-context @gorhom/bottom-sheet@5.0.0-alpha.9 react-native-gesture-handler @expo/vector-icons expo-localization react-native-reanimated react-native-screens react-native-vector-icons @react-navigation/native

with web support

npx expo install react-dom react-native-web @expo/metro-runtime react-native-web
npx expo customize metro.config.js

Usage

Quickly integrate the design system into your app by importing and using the provided components and utilities:

import 'intl-pluralrules';
// Keep polyfills on top
import { LabelSwitch, ScreenWrapper, UIProvider, useThemePreferences, Picker, SelectOption } from "@siteed/design-system";
import { LoggerProvider } from '@siteed/react-native-logger';
import { StatusBar } from 'expo-status-bar';
import { StyleSheet, View } from 'react-native';
import { Text } from 'react-native-paper';
import React from 'react';

export function App() {
  const { toggleDarkMode, darkMode } = useThemePreferences()
  const [options, setOptions] = React.useState<SelectOption[]>([{ label: 'Option 1', value: 'option1', selected: true }, { label: 'Option 2', value: 'option2' }])
  return (
    <ScreenWrapper withScrollView contentContainerStyle={styles.container}>
      <Text>Open up App.tsx to start working on your app!</Text>
      <View style={{width: '100%'}}>
        <LabelSwitch label="Dark Mode" value={darkMode} onValueChange={toggleDarkMode} />
        <Picker label="Category" options={options} onFinish={setOptions} />
      </View>
      <StatusBar style="auto" />
    </ScreenWrapper>
  );
}

export default function WrapApp() {
  return (
    <LoggerProvider>
      <UIProvider>
        <App />
      </UIProvider>
    </LoggerProvider>)
}

const styles = StyleSheet.create({
  container: {
    flex: 1,
    width: '100%',
    alignItems: 'center',
    justifyContent: 'center',
  },
});

For a full list of components and their usage, you can explore the storybook

Storybook

Explore the components and their usage more thoroughly by running the Storybook locally:

yarn storybook

Readme

Keywords

none

Package Sidebar

Install

npm i @siteed/design-system

Weekly Downloads

12

Version

0.8.1

License

MIT

Unpacked Size

388 kB

Total Files

334

Last publish

Collaborators

  • abreton