diff options
author | Kirill Rogovoy <[email protected]> | 2021-07-20 21:24:52 +0300 |
---|---|---|
committer | Kirill Rogovoy <[email protected]> | 2021-07-20 21:24:52 +0300 |
commit | 5f4611d65e40eae3ca6191a15f68d69ea5a1c4cb (patch) | |
tree | 273dfc086444533d86d580961c92ba8d14781a67 /storybook | |
parent | f0bf4e7afdcd8b02a62be45ab3e7d047ed865a79 (diff) |
WIP
Diffstat (limited to 'storybook')
-rw-r--r-- | storybook/index.ts | 4 | ||||
-rw-r--r-- | storybook/storybook-registry.ts | 10 | ||||
-rw-r--r-- | storybook/storybook.tsx | 32 | ||||
-rw-r--r-- | storybook/toggle-storybook.tsx | 51 | ||||
-rw-r--r-- | storybook/toggle-storybook.web.tsx | 30 | ||||
-rw-r--r-- | storybook/views/index.ts | 3 | ||||
-rw-r--r-- | storybook/views/story-screen.tsx | 19 | ||||
-rw-r--r-- | storybook/views/story.tsx | 18 | ||||
-rw-r--r-- | storybook/views/use-case.tsx | 73 |
9 files changed, 0 insertions, 240 deletions
diff --git a/storybook/index.ts b/storybook/index.ts deleted file mode 100644 index 43bfa66..0000000 --- a/storybook/index.ts +++ /dev/null @@ -1,4 +0,0 @@ -// this is the native storybook entry point -// import { StorybookUI } from "./config" - -export * from './storybook' diff --git a/storybook/storybook-registry.ts b/storybook/storybook-registry.ts deleted file mode 100644 index 453b0d0..0000000 --- a/storybook/storybook-registry.ts +++ /dev/null @@ -1,10 +0,0 @@ -require('../app/components/text/text.story') -require('../app/components/auto-image/auto-image.story') -require('../app/components/button/button.story') -require('../app/components/form-row/form-row.story') -require('../app/components/switch/switch.story') -require('../app/components/text-field/text-field.story') -require('../app/components/checkbox/checkbox.story') -require('../app/components/wallpaper/wallpaper.story') -require('../app/components/icon/icon.story') -require('../app/components/header/header.story') diff --git a/storybook/storybook.tsx b/storybook/storybook.tsx deleted file mode 100644 index c48e3ef..0000000 --- a/storybook/storybook.tsx +++ /dev/null @@ -1,32 +0,0 @@ -import React, { useEffect } from 'react' -import { getStorybookUI, configure } from '@storybook/react-native' -import { initFonts } from '../app/theme/fonts' - -declare let module - -configure(() => { - require('./storybook-registry') -}, module) - -const StorybookUI = getStorybookUI({ - port: 9001, - host: 'localhost', - onDeviceUI: true, - asyncStorage: - require('@react-native-async-storage/async-storage').default || null, -}) - -export function StorybookUIRoot() { - useEffect(() => { - ;(async () => { - await initFonts() // expo only - if (typeof __TEST__ === 'undefined' || !__TEST__) { - const Reactotron = require('../app/services/reactotron') - const reactotron = new Reactotron.Reactotron() - reactotron.setup() - } - })() - }, []) - - return <StorybookUI /> -} diff --git a/storybook/toggle-storybook.tsx b/storybook/toggle-storybook.tsx deleted file mode 100644 index 301695a..0000000 --- a/storybook/toggle-storybook.tsx +++ /dev/null @@ -1,51 +0,0 @@ -import React, { useState, useEffect } from 'react' -import { DevSettings } from 'react-native' -import { loadString, saveString } from '../app/utils/storage' - -/** - * Toggle Storybook mode, in __DEV__ mode only. - * - * In non-__DEV__ mode, or when Storybook isn't toggled on, - * renders its children. - * - * The mode flag is persisted in async storage, which means it - * persists across reloads/restarts - this is handy when developing - * new components in Storybook. - */ -export function ToggleStorybook(props) { - const [showStorybook, setShowStorybook] = useState(false) - const [StorybookUIRoot, setStorybookUIRoot] = useState(null) - - useEffect(() => { - if (__DEV__ && DevSettings) { - // Load the setting from storage if it's there - loadString('devStorybook').then((storedSetting) => { - // Set the initial value - setShowStorybook(storedSetting === 'on') - - // Add our toggle command to the menu - DevSettings.addMenuItem('Toggle Storybook', () => { - setShowStorybook((show) => { - // On toggle, flip the current value - show = !show - - // Write it back to storage - saveString('devStorybook', show ? 'on' : 'off') - - // Return it to change the local state - return show - }) - }) - - // Load the storybook UI once - setStorybookUIRoot(() => require('./storybook').StorybookUIRoot) - }) - } - }, []) - - if (showStorybook) { - return StorybookUIRoot ? <StorybookUIRoot /> : null - } else { - return props.children - } -} diff --git a/storybook/toggle-storybook.web.tsx b/storybook/toggle-storybook.web.tsx deleted file mode 100644 index 9da2ada..0000000 --- a/storybook/toggle-storybook.web.tsx +++ /dev/null @@ -1,30 +0,0 @@ -import React, { useState, useEffect } from 'react' -import * as QueryString from 'query-string' - -interface StorybookQueryParams { - storybook?: boolean -} - -export const ToggleStorybook = (props) => { - const [StorybookUIRoot, setStorybookUIRoot] = useState<any>(null) - const [queryParams, setQueryParams] = useState<StorybookQueryParams>({}) - - useEffect(() => { - if (__DEV__) { - // Load the storybook UI once - setStorybookUIRoot(() => require('./storybook').StorybookUIRoot) - } - }, []) - - useEffect(() => { - if (__DEV__) { - setQueryParams(QueryString.parse(window.location.search)) - } - }, [window.location.search]) - - if (queryParams?.storybook) { - return StorybookUIRoot ? <StorybookUIRoot /> : null - } else { - return props.children - } -} diff --git a/storybook/views/index.ts b/storybook/views/index.ts deleted file mode 100644 index fb7ed3e..0000000 --- a/storybook/views/index.ts +++ /dev/null @@ -1,3 +0,0 @@ -export * from './story-screen' -export * from './story' -export * from './use-case' diff --git a/storybook/views/story-screen.tsx b/storybook/views/story-screen.tsx deleted file mode 100644 index 1e59efd..0000000 --- a/storybook/views/story-screen.tsx +++ /dev/null @@ -1,19 +0,0 @@ -import * as React from 'react' -import { ViewStyle, KeyboardAvoidingView, Platform } from 'react-native' - -const ROOT: ViewStyle = { backgroundColor: '#f0f0f0', flex: 1 } - -export interface StoryScreenProps { - children?: React.ReactNode -} - -const behavior = Platform.OS === 'ios' ? 'padding' : undefined -export const StoryScreen = (props: StoryScreenProps) => ( - <KeyboardAvoidingView - style={ROOT} - behavior={behavior} - keyboardVerticalOffset={50} - > - {props.children} - </KeyboardAvoidingView> -) diff --git a/storybook/views/story.tsx b/storybook/views/story.tsx deleted file mode 100644 index 68d298e..0000000 --- a/storybook/views/story.tsx +++ /dev/null @@ -1,18 +0,0 @@ -import * as React from 'react' -import { ScrollView, View, ViewStyle } from 'react-native' - -export interface StoryProps { - children?: React.ReactNode -} - -const ROOT: ViewStyle = { flex: 1 } - -export function Story(props: StoryProps) { - return ( - <View style={ROOT}> - <ScrollView keyboardShouldPersistTaps="handled"> - {props.children} - </ScrollView> - </View> - ) -} diff --git a/storybook/views/use-case.tsx b/storybook/views/use-case.tsx deleted file mode 100644 index b7f6647..0000000 --- a/storybook/views/use-case.tsx +++ /dev/null @@ -1,73 +0,0 @@ -import * as React from 'react' -import { View, Text, TextStyle, ViewStyle } from 'react-native' - -const ROOT: ViewStyle = { backgroundColor: '#eee' } -const TITLE: TextStyle = { fontWeight: '600', color: '#3d3d3d' } -const TITLE_WRAPPER: ViewStyle = {} -const USE_CASE_WRAPPER: ViewStyle = { - position: 'absolute', - top: 0, - left: 0, - right: 0, - borderTopColor: '#e6e6e6', - borderTopWidth: 1, - flexDirection: 'row', -} -const USE_CASE: TextStyle = { - fontSize: 10, - color: '#666', - paddingHorizontal: 4, - paddingBottom: 2, -} -const USAGE: TextStyle = { color: '#666', fontSize: 10, paddingTop: 0 } -const HEADER: ViewStyle = { - paddingTop: 20, - paddingBottom: 10, - paddingHorizontal: 10, - borderBottomColor: '#e6e6e6', - borderBottomWidth: 1, -} -const COMPONENT: ViewStyle = { backgroundColor: '#fff' } - -export interface UseCaseProps { - /** The title. */ - text: string - /** When should we be using this? */ - usage?: string - /** The component use case. */ - children: React.ReactNode - /** A style override. Rarely used. */ - style?: ViewStyle - /** Don't use any padding because it's important to see the spacing. */ - noPad?: boolean - /** Don't use background color because it's important to see the color. */ - noBackground?: boolean -} - -export function UseCase(props: UseCaseProps) { - const style: ViewStyle = { - ...COMPONENT, - ...{ padding: props.noPad ? 0 : 10 }, - ...{ - backgroundColor: props.noBackground - ? 'rgba(0,0,0,0)' - : COMPONENT.backgroundColor, - }, - ...props.style, - } - - return ( - <View style={ROOT}> - <View style={HEADER}> - <View style={USE_CASE_WRAPPER}> - <Text style={USE_CASE}>Use Case</Text> - </View> - <View style={TITLE_WRAPPER}> - <Text style={TITLE}>{props.text}</Text> - </View> - {props.usage ? <Text style={USAGE}>{props.usage}</Text> : null} - </View> - <View style={style}>{props.children}</View> - </View> - ) -} |