@artsy/palette-mobile 13.2.34 → 13.2.36
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/Theme.d.ts +17 -0
- package/dist/Theme.js +20 -0
- package/dist/animation/CssTransition.d.ts +17 -0
- package/dist/animation/CssTransition.js +48 -0
- package/dist/animation/index.d.ts +1 -0
- package/dist/animation/index.js +1 -0
- package/dist/constants.d.ts +14 -0
- package/dist/constants.js +12 -0
- package/dist/elements/ArtsyKeyboardAvoidingView/ArtsyKeyboardAvoidingView.d.ts +13 -0
- package/dist/elements/ArtsyKeyboardAvoidingView/ArtsyKeyboardAvoidingView.js +118 -0
- package/dist/elements/ArtsyKeyboardAvoidingView/index.d.ts +1 -0
- package/dist/elements/ArtsyKeyboardAvoidingView/index.js +1 -0
- package/dist/elements/Autocomplete/Autocomplete.d.ts +13 -0
- package/dist/elements/Autocomplete/Autocomplete.js +49 -0
- package/dist/elements/Autocomplete/Autocomplete.tests.d.ts +1 -0
- package/dist/elements/Autocomplete/Autocomplete.tests.js +78 -0
- package/dist/elements/Autocomplete/index.d.ts +1 -0
- package/dist/elements/Autocomplete/index.js +1 -0
- package/dist/elements/Avatar/Avatar.d.ts +11 -0
- package/dist/elements/Avatar/Avatar.js +50 -0
- package/dist/elements/Avatar/Avatar.stories.d.ts +8 -0
- package/dist/elements/Avatar/Avatar.stories.js +11 -0
- package/dist/elements/Avatar/Avatar.tests.d.ts +1 -0
- package/dist/elements/Avatar/Avatar.tests.js +12 -0
- package/dist/elements/Avatar/index.d.ts +1 -0
- package/dist/elements/Avatar/index.js +1 -0
- package/dist/elements/BackButton/BackButton.d.ts +13 -0
- package/dist/elements/BackButton/BackButton.js +11 -0
- package/dist/elements/BackButton/BackButton.stories.d.ts +7 -0
- package/dist/elements/BackButton/BackButton.stories.js +10 -0
- package/dist/elements/BackButton/index.d.ts +1 -0
- package/dist/elements/BackButton/index.js +1 -0
- package/dist/elements/Banner/Banner.d.ts +33 -0
- package/dist/elements/Banner/Banner.js +55 -0
- package/dist/elements/Banner/Banner.stories.d.ts +7 -0
- package/dist/elements/Banner/Banner.stories.js +10 -0
- package/dist/elements/Banner/index.d.ts +1 -0
- package/dist/elements/Banner/index.js +1 -0
- package/dist/elements/BorderBox/BorderBox.d.ts +12 -0
- package/dist/elements/BorderBox/BorderBox.js +15 -0
- package/dist/elements/BorderBox/index.d.ts +1 -0
- package/dist/elements/BorderBox/index.js +1 -0
- package/dist/elements/Box/Box.d.ts +15 -0
- package/dist/elements/Box/Box.js +15 -0
- package/dist/elements/Box/Box.stories.d.ts +10 -0
- package/dist/elements/Box/Box.stories.js +18 -0
- package/dist/elements/Box/index.d.ts +1 -0
- package/dist/elements/Box/index.js +1 -0
- package/dist/elements/Button/Button.d.ts +40 -0
- package/dist/elements/Button/Button.js +335 -0
- package/dist/elements/Button/Button.stories.d.ts +11 -0
- package/dist/elements/Button/Button.stories.js +35 -0
- package/dist/elements/Button/CTAButton.d.ts +3 -0
- package/dist/elements/Button/CTAButton.js +3 -0
- package/dist/elements/Button/FollowButton.d.ts +9 -0
- package/dist/elements/Button/FollowButton.js +8 -0
- package/dist/elements/Button/LinkButton.d.ts +3 -0
- package/dist/elements/Button/LinkButton.js +4 -0
- package/dist/elements/Button/colors.d.ts +9 -0
- package/dist/elements/Button/colors.js +74 -0
- package/dist/elements/Button/index.d.ts +4 -0
- package/dist/elements/Button/index.js +4 -0
- package/dist/elements/ButtonNew/Button.d.ts +34 -0
- package/dist/elements/ButtonNew/Button.js +102 -0
- package/dist/elements/ButtonNew/Button.stories.d.ts +18 -0
- package/dist/elements/ButtonNew/Button.stories.js +52 -0
- package/dist/elements/ButtonNew/Button.tests.d.ts +1 -0
- package/dist/elements/ButtonNew/Button.tests.js +29 -0
- package/dist/elements/ButtonNew/CTAButton.d.ts +3 -0
- package/dist/elements/ButtonNew/CTAButton.js +3 -0
- package/dist/elements/ButtonNew/FollowButton.d.ts +9 -0
- package/dist/elements/ButtonNew/FollowButton.js +8 -0
- package/dist/elements/ButtonNew/LinkButton.d.ts +3 -0
- package/dist/elements/ButtonNew/LinkButton.js +4 -0
- package/dist/elements/ButtonNew/colors.d.ts +9 -0
- package/dist/elements/ButtonNew/colors.js +74 -0
- package/dist/elements/ButtonNew/index.d.ts +4 -0
- package/dist/elements/ButtonNew/index.js +4 -0
- package/dist/elements/Checkbox/Check.d.ts +10 -0
- package/dist/elements/Checkbox/Check.js +65 -0
- package/dist/elements/Checkbox/Checkbox.d.ts +20 -0
- package/dist/elements/Checkbox/Checkbox.js +77 -0
- package/dist/elements/Checkbox/Checkbox.stories.d.ts +7 -0
- package/dist/elements/Checkbox/Checkbox.stories.js +12 -0
- package/dist/elements/Checkbox/index.d.ts +2 -0
- package/dist/elements/Checkbox/index.js +2 -0
- package/dist/elements/ClassTheme/ClassTheme.d.ts +6 -0
- package/dist/elements/ClassTheme/ClassTheme.js +6 -0
- package/dist/elements/ClassTheme/index.d.ts +1 -0
- package/dist/elements/ClassTheme/index.js +1 -0
- package/dist/elements/Collapse/Collapse.d.ts +6 -0
- package/dist/elements/Collapse/Collapse.js +8 -0
- package/dist/elements/Collapse/Collapse.stories.d.ts +7 -0
- package/dist/elements/Collapse/Collapse.stories.js +12 -0
- package/dist/elements/Collapse/index.d.ts +1 -0
- package/dist/elements/Collapse/index.js +1 -0
- package/dist/elements/CollapsibleMenuItem/CollapsibleMenuItem.d.ts +20 -0
- package/dist/elements/CollapsibleMenuItem/CollapsibleMenuItem.js +43 -0
- package/dist/elements/CollapsibleMenuItem/CollapsibleMenuItem.stories.d.ts +12 -0
- package/dist/elements/CollapsibleMenuItem/CollapsibleMenuItem.stories.js +86 -0
- package/dist/elements/CollapsibleMenuItem/index.d.ts +1 -0
- package/dist/elements/CollapsibleMenuItem/index.js +1 -0
- package/dist/elements/Dialog/Dialog.d.ts +15 -0
- package/dist/elements/Dialog/Dialog.js +68 -0
- package/dist/elements/Dialog/Dialog.stories.d.ts +1 -0
- package/dist/elements/Dialog/Dialog.stories.js +22 -0
- package/dist/elements/Dialog/Dialog.tests.d.ts +1 -0
- package/dist/elements/Dialog/Dialog.tests.js +54 -0
- package/dist/elements/Dialog/index.d.ts +1 -0
- package/dist/elements/Dialog/index.js +1 -0
- package/dist/elements/EntityHeader/EntityHeader.d.ts +19 -0
- package/dist/elements/EntityHeader/EntityHeader.js +21 -0
- package/dist/elements/EntityHeader/EntityHeader.stories.d.ts +11 -0
- package/dist/elements/EntityHeader/EntityHeader.stories.js +25 -0
- package/dist/elements/EntityHeader/index.d.ts +1 -0
- package/dist/elements/EntityHeader/index.js +1 -0
- package/dist/elements/Flex/Flex.d.ts +5 -0
- package/dist/elements/Flex/Flex.js +4 -0
- package/dist/elements/Flex/index.d.ts +1 -0
- package/dist/elements/Flex/index.js +1 -0
- package/dist/elements/Header/ArtsyLogoHeader.d.ts +6 -0
- package/dist/elements/Header/ArtsyLogoHeader.js +17 -0
- package/dist/elements/Header/index.d.ts +1 -0
- package/dist/elements/Header/index.js +1 -0
- package/dist/elements/Histogram/Histogram.d.ts +12 -0
- package/dist/elements/Histogram/Histogram.js +23 -0
- package/dist/elements/Histogram/index.d.ts +1 -0
- package/dist/elements/Histogram/index.js +1 -0
- package/dist/elements/Image/Image.d.ts +24 -0
- package/dist/elements/Image/Image.js +75 -0
- package/dist/elements/Image/Image.stories.d.ts +1 -0
- package/dist/elements/Image/Image.stories.js +16 -0
- package/dist/elements/Image/index.d.ts +1 -0
- package/dist/elements/Image/index.js +1 -0
- package/dist/elements/Input/Input.d.ts +78 -0
- package/dist/elements/Input/Input.js +363 -0
- package/dist/elements/Input/Input.stories.d.ts +1 -0
- package/dist/elements/Input/Input.stories.js +9 -0
- package/dist/elements/Input/Input.tests.d.ts +1 -0
- package/dist/elements/Input/Input.tests.js +50 -0
- package/dist/elements/Input/InputTitle.d.ts +6 -0
- package/dist/elements/Input/InputTitle.js +8 -0
- package/dist/elements/Input/helpers.d.ts +42 -0
- package/dist/elements/Input/helpers.js +107 -0
- package/dist/elements/Input/index.d.ts +3 -0
- package/dist/elements/Input/index.js +3 -0
- package/dist/elements/Input/maskValue.d.ts +6 -0
- package/dist/elements/Input/maskValue.js +44 -0
- package/dist/elements/Input/maskValue.tests.d.ts +1 -0
- package/dist/elements/Input/maskValue.tests.js +56 -0
- package/dist/elements/Join/Join.d.ts +29 -0
- package/dist/elements/Join/Join.js +37 -0
- package/dist/elements/Join/index.d.ts +1 -0
- package/dist/elements/Join/index.js +1 -0
- package/dist/elements/LazyFlatlist/LazyFlatlist.d.ts +10 -0
- package/dist/elements/LazyFlatlist/LazyFlatlist.js +15 -0
- package/dist/elements/LazyFlatlist/index.d.ts +2 -0
- package/dist/elements/LazyFlatlist/index.js +2 -0
- package/dist/elements/LazyFlatlist/useHasSeenItem.d.ts +12 -0
- package/dist/elements/LazyFlatlist/useHasSeenItem.js +27 -0
- package/dist/elements/LegacyScreen/LegacyScreen.d.ts +35 -0
- package/dist/elements/LegacyScreen/LegacyScreen.js +132 -0
- package/dist/elements/LegacyScreen/index.d.ts +1 -0
- package/dist/elements/LegacyScreen/index.js +1 -0
- package/dist/elements/LegacyTabs/ContentTabs.d.ts +6 -0
- package/dist/elements/LegacyTabs/ContentTabs.js +22 -0
- package/dist/elements/LegacyTabs/NavigationalTabs.d.ts +7 -0
- package/dist/elements/LegacyTabs/NavigationalTabs.js +25 -0
- package/dist/elements/LegacyTabs/StepTabs.d.ts +7 -0
- package/dist/elements/LegacyTabs/StepTabs.js +34 -0
- package/dist/elements/LegacyTabs/Tab.d.ts +11 -0
- package/dist/elements/LegacyTabs/Tab.js +20 -0
- package/dist/elements/LegacyTabs/TabBarContainer.d.ts +24 -0
- package/dist/elements/LegacyTabs/TabBarContainer.js +83 -0
- package/dist/elements/LegacyTabs/index.d.ts +18 -0
- package/dist/elements/LegacyTabs/index.js +10 -0
- package/dist/elements/List/BulletedItem.d.ts +8 -0
- package/dist/elements/List/BulletedItem.js +8 -0
- package/dist/elements/List/List.stories.d.ts +1 -0
- package/dist/elements/List/List.stories.js +8 -0
- package/dist/elements/List/index.d.ts +1 -0
- package/dist/elements/List/index.js +1 -0
- package/dist/elements/MeasuredView/MeasuredView.d.ts +19 -0
- package/dist/elements/MeasuredView/MeasuredView.js +24 -0
- package/dist/elements/MeasuredView/index.d.ts +1 -0
- package/dist/elements/MeasuredView/index.js +1 -0
- package/dist/elements/MenuItem/MenuItem.d.ts +11 -0
- package/dist/elements/MenuItem/MenuItem.js +10 -0
- package/dist/elements/MenuItem/MenuItem.stories.d.ts +7 -0
- package/dist/elements/MenuItem/MenuItem.stories.js +7 -0
- package/dist/elements/MenuItem/index.d.ts +1 -0
- package/dist/elements/MenuItem/index.js +1 -0
- package/dist/elements/Message/Message.d.ts +19 -0
- package/dist/elements/Message/Message.js +66 -0
- package/dist/elements/Message/Message.stories.d.ts +1 -0
- package/dist/elements/Message/Message.stories.js +10 -0
- package/dist/elements/Message/Message.tests.d.ts +1 -0
- package/dist/elements/Message/Message.tests.js +26 -0
- package/dist/elements/Message/index.d.ts +1 -0
- package/dist/elements/Message/index.js +1 -0
- package/dist/elements/Pill/Pill.d.ts +20 -0
- package/dist/elements/Pill/Pill.js +161 -0
- package/dist/elements/Pill/Pill.stories.d.ts +6 -0
- package/dist/elements/Pill/Pill.stories.js +26 -0
- package/dist/elements/Pill/Pill.tests.d.ts +1 -0
- package/dist/elements/Pill/Pill.tests.js +18 -0
- package/dist/elements/Pill/index.d.ts +1 -0
- package/dist/elements/Pill/index.js +1 -0
- package/dist/elements/PopIn/PopIn.d.ts +6 -0
- package/dist/elements/PopIn/PopIn.js +41 -0
- package/dist/elements/PopIn/index.d.ts +1 -0
- package/dist/elements/PopIn/index.js +1 -0
- package/dist/elements/Popover/Popover.d.ts +24 -0
- package/dist/elements/Popover/Popover.js +42 -0
- package/dist/elements/Popover/Popover.stories.d.ts +1 -0
- package/dist/elements/Popover/Popover.stories.js +21 -0
- package/dist/elements/Popover/index.d.ts +1 -0
- package/dist/elements/Popover/index.js +1 -0
- package/dist/elements/ProgressBar/ProgressBar.d.ts +14 -0
- package/dist/elements/ProgressBar/ProgressBar.js +29 -0
- package/dist/elements/ProgressBar/ProgressBar.stories.d.ts +1 -0
- package/dist/elements/ProgressBar/ProgressBar.stories.js +6 -0
- package/dist/elements/ProgressBar/ProgressBar.tests.d.ts +1 -0
- package/dist/elements/ProgressBar/ProgressBar.tests.js +26 -0
- package/dist/elements/ProgressBar/index.d.ts +1 -0
- package/dist/elements/ProgressBar/index.js +1 -0
- package/dist/elements/Radio/RadioButton.d.ts +24 -0
- package/dist/elements/Radio/RadioButton.js +81 -0
- package/dist/elements/Radio/RadioButton.stories.d.ts +6 -0
- package/dist/elements/Radio/RadioButton.stories.js +22 -0
- package/dist/elements/Radio/RadioDot.d.ts +15 -0
- package/dist/elements/Radio/RadioDot.js +68 -0
- package/dist/elements/Radio/index.d.ts +2 -0
- package/dist/elements/Radio/index.js +2 -0
- package/dist/elements/Screen/Background.d.ts +4 -0
- package/dist/elements/Screen/Background.js +3 -0
- package/dist/elements/Screen/Body.d.ts +8 -0
- package/dist/elements/Screen/Body.js +11 -0
- package/dist/elements/Screen/BottomView.d.ts +6 -0
- package/dist/elements/Screen/BottomView.js +12 -0
- package/dist/elements/Screen/FloatingHeader.d.ts +7 -0
- package/dist/elements/Screen/FloatingHeader.js +10 -0
- package/dist/elements/Screen/FullWidthDivider.d.ts +3 -0
- package/dist/elements/Screen/FullWidthDivider.js +6 -0
- package/dist/elements/Screen/FullWidthItem.d.ts +3 -0
- package/dist/elements/Screen/FullWidthItem.js +6 -0
- package/dist/elements/Screen/Header.d.ts +18 -0
- package/dist/elements/Screen/Header.js +41 -0
- package/dist/elements/Screen/Screen.stories.d.ts +1 -0
- package/dist/elements/Screen/Screen.stories.js +19 -0
- package/dist/elements/Screen/ScreenBase.d.ts +7 -0
- package/dist/elements/Screen/ScreenBase.js +12 -0
- package/dist/elements/Screen/ScreenFlatList.d.ts +6 -0
- package/dist/elements/Screen/ScreenFlatList.js +15 -0
- package/dist/elements/Screen/ScreenScrollContext.d.ts +9 -0
- package/dist/elements/Screen/ScreenScrollContext.js +30 -0
- package/dist/elements/Screen/ScreenScrollView.d.ts +3 -0
- package/dist/elements/Screen/ScreenScrollView.js +15 -0
- package/dist/elements/Screen/StickySubHeader.d.ts +7 -0
- package/dist/elements/Screen/StickySubHeader.js +44 -0
- package/dist/elements/Screen/constants.d.ts +12 -0
- package/dist/elements/Screen/constants.js +11 -0
- package/dist/elements/Screen/hooks/useAnimatedHeaderScrolling.d.ts +2 -0
- package/dist/elements/Screen/hooks/useAnimatedHeaderScrolling.js +38 -0
- package/dist/elements/Screen/hooks/useListenForScreenScroll.d.ts +3 -0
- package/dist/elements/Screen/hooks/useListenForScreenScroll.js +20 -0
- package/dist/elements/Screen/index.d.ts +25 -0
- package/dist/elements/Screen/index.js +31 -0
- package/dist/elements/SearchInput/SearchInput.d.ts +6 -0
- package/dist/elements/SearchInput/SearchInput.js +13 -0
- package/dist/elements/SearchInput/index.d.ts +1 -0
- package/dist/elements/SearchInput/index.js +1 -0
- package/dist/elements/Separator/Separator.d.ts +8 -0
- package/dist/elements/Separator/Separator.js +16 -0
- package/dist/elements/Separator/Separator.stories.d.ts +7 -0
- package/dist/elements/Separator/Separator.stories.js +8 -0
- package/dist/elements/Separator/ShadowSeparator.d.ts +1 -0
- package/dist/elements/Separator/ShadowSeparator.js +7 -0
- package/dist/elements/Separator/index.d.ts +2 -0
- package/dist/elements/Separator/index.js +2 -0
- package/dist/elements/SimpleMessage/SimpleMessage.d.ts +12 -0
- package/dist/elements/SimpleMessage/SimpleMessage.js +15 -0
- package/dist/elements/SimpleMessage/index.d.ts +1 -0
- package/dist/elements/SimpleMessage/index.js +1 -0
- package/dist/elements/Skeleton/Skeleton.d.ts +18 -0
- package/dist/elements/Skeleton/Skeleton.js +31 -0
- package/dist/elements/Skeleton/Skeleton.stories.d.ts +9 -0
- package/dist/elements/Skeleton/Skeleton.stories.js +12 -0
- package/dist/elements/Skeleton/index.d.ts +1 -0
- package/dist/elements/Skeleton/index.js +1 -0
- package/dist/elements/Spacer/Spacer.d.ts +10 -0
- package/dist/elements/Spacer/Spacer.js +6 -0
- package/dist/elements/Spacer/Spacer.stories.d.ts +9 -0
- package/dist/elements/Spacer/Spacer.stories.js +23 -0
- package/dist/elements/Spacer/index.d.ts +1 -0
- package/dist/elements/Spacer/index.js +1 -0
- package/dist/elements/Spinner/Spinner.d.ts +31 -0
- package/dist/elements/Spinner/Spinner.js +86 -0
- package/dist/elements/Spinner/index.d.ts +1 -0
- package/dist/elements/Spinner/index.js +1 -0
- package/dist/elements/Switch/Switch.d.ts +24 -0
- package/dist/elements/Switch/Switch.js +21 -0
- package/dist/elements/Switch/Switch.stories.d.ts +7 -0
- package/dist/elements/Switch/Switch.stories.js +22 -0
- package/dist/elements/Switch/index.d.ts +1 -0
- package/dist/elements/Switch/index.js +1 -0
- package/dist/elements/Tabs/SubTabBar.d.ts +8 -0
- package/dist/elements/Tabs/SubTabBar.js +26 -0
- package/dist/elements/Tabs/TabFlashList.d.ts +3 -0
- package/dist/elements/Tabs/TabFlashList.js +13 -0
- package/dist/elements/Tabs/TabFlatList.d.ts +3 -0
- package/dist/elements/Tabs/TabFlatList.js +13 -0
- package/dist/elements/Tabs/TabMasonry.d.ts +5 -0
- package/dist/elements/Tabs/TabMasonry.js +13 -0
- package/dist/elements/Tabs/TabScrollView.d.ts +3 -0
- package/dist/elements/Tabs/TabScrollView.js +19 -0
- package/dist/elements/Tabs/Tabs.d.ts +30 -0
- package/dist/elements/Tabs/Tabs.js +26 -0
- package/dist/elements/Tabs/Tabs.stories.d.ts +1 -0
- package/dist/elements/Tabs/Tabs.stories.js +11 -0
- package/dist/elements/Tabs/TabsContainer.d.ts +13 -0
- package/dist/elements/Tabs/TabsContainer.js +45 -0
- package/dist/elements/Tabs/TabsWithHeader.d.ts +12 -0
- package/dist/elements/Tabs/TabsWithHeader.js +11 -0
- package/dist/elements/Tabs/hooks/useListenForTabContentScroll.d.ts +1 -0
- package/dist/elements/Tabs/hooks/useListenForTabContentScroll.js +11 -0
- package/dist/elements/Tabs/index.d.ts +1 -0
- package/dist/elements/Tabs/index.js +1 -0
- package/dist/elements/Text/LinkText.d.ts +3 -0
- package/dist/elements/Text/LinkText.js +3 -0
- package/dist/elements/Text/Text.d.ts +22 -0
- package/dist/elements/Text/Text.js +31 -0
- package/dist/elements/Text/Text.stories.d.ts +11 -0
- package/dist/elements/Text/Text.stories.js +28 -0
- package/dist/elements/Text/Text.tests.d.ts +1 -0
- package/dist/elements/Text/Text.tests.js +10 -0
- package/dist/elements/Text/helpers.d.ts +14 -0
- package/dist/elements/Text/helpers.js +29 -0
- package/dist/elements/Text/index.d.ts +3 -0
- package/dist/elements/Text/index.js +3 -0
- package/dist/elements/ToolTip/ToolTip.d.ts +45 -0
- package/dist/elements/ToolTip/ToolTip.js +109 -0
- package/dist/elements/ToolTip/ToolTip.stories.d.ts +1 -0
- package/dist/elements/ToolTip/ToolTip.stories.js +12 -0
- package/dist/elements/ToolTip/ToolTip.tests.d.ts +1 -0
- package/dist/elements/ToolTip/ToolTip.tests.js +15 -0
- package/dist/elements/ToolTip/ToolTipFlyout.d.ts +21 -0
- package/dist/elements/ToolTip/ToolTipFlyout.js +60 -0
- package/dist/elements/ToolTip/index.d.ts +1 -0
- package/dist/elements/ToolTip/index.js +1 -0
- package/dist/elements/Touchable/Touchable.d.ts +19 -0
- package/dist/elements/Touchable/Touchable.js +27 -0
- package/dist/elements/Touchable/Touchable.stories.d.ts +7 -0
- package/dist/elements/Touchable/Touchable.stories.js +11 -0
- package/dist/elements/Touchable/TouchableHighlightColor.d.ts +14 -0
- package/dist/elements/Touchable/TouchableHighlightColor.js +15 -0
- package/dist/elements/Touchable/TouchableWithScale.d.ts +7 -0
- package/dist/elements/Touchable/TouchableWithScale.js +20 -0
- package/dist/elements/Touchable/index.d.ts +3 -0
- package/dist/elements/Touchable/index.js +3 -0
- package/dist/elements/VisualClue/VisualClue.stories.d.ts +1 -0
- package/dist/elements/VisualClue/VisualClue.stories.js +6 -0
- package/dist/elements/VisualClue/VisualClueDot.d.ts +8 -0
- package/dist/elements/VisualClue/VisualClueDot.js +14 -0
- package/dist/elements/VisualClue/VisualClueText.d.ts +5 -0
- package/dist/elements/VisualClue/VisualClueText.js +16 -0
- package/dist/elements/VisualClue/index.d.ts +2 -0
- package/dist/elements/VisualClue/index.js +2 -0
- package/dist/elements/index.d.ts +45 -0
- package/dist/elements/index.js +45 -0
- package/dist/index.d.ts +10 -0
- package/dist/index.js +10 -0
- package/dist/setupJest.d.ts +1 -0
- package/dist/setupJest.js +10 -0
- package/dist/storybook/decorators.d.ts +4 -0
- package/dist/storybook/decorators.js +29 -0
- package/dist/storybook/helpers.d.ts +20 -0
- package/dist/storybook/helpers.js +22 -0
- package/dist/svgs/AddCircleFillIcon.d.ts +3 -0
- package/dist/svgs/AddCircleFillIcon.js +7 -0
- package/dist/svgs/AddCircleIcon.d.ts +3 -0
- package/dist/svgs/AddCircleIcon.js +7 -0
- package/dist/svgs/AddIcon.d.ts +3 -0
- package/dist/svgs/AddIcon.js +7 -0
- package/dist/svgs/AlertCircleFillIcon.d.ts +3 -0
- package/dist/svgs/AlertCircleFillIcon.js +7 -0
- package/dist/svgs/AlertIcon.d.ts +3 -0
- package/dist/svgs/AlertIcon.js +7 -0
- package/dist/svgs/ArrowCircleFillIcons.d.ts +4 -0
- package/dist/svgs/ArrowCircleFillIcons.js +9 -0
- package/dist/svgs/ArrowDownCircleIcon.d.ts +3 -0
- package/dist/svgs/ArrowDownCircleIcon.js +7 -0
- package/dist/svgs/ArrowDownIcon.d.ts +3 -0
- package/dist/svgs/ArrowDownIcon.js +7 -0
- package/dist/svgs/ArrowLeftCircleIcon.d.ts +3 -0
- package/dist/svgs/ArrowLeftCircleIcon.js +7 -0
- package/dist/svgs/ArrowLeftIcon.d.ts +3 -0
- package/dist/svgs/ArrowLeftIcon.js +7 -0
- package/dist/svgs/ArrowRightCircleIcon.d.ts +3 -0
- package/dist/svgs/ArrowRightCircleIcon.js +7 -0
- package/dist/svgs/ArrowRightIcon.d.ts +3 -0
- package/dist/svgs/ArrowRightIcon.js +7 -0
- package/dist/svgs/ArrowUpCircleIcon.d.ts +3 -0
- package/dist/svgs/ArrowUpCircleIcon.js +7 -0
- package/dist/svgs/ArrowUpIcon.d.ts +3 -0
- package/dist/svgs/ArrowUpIcon.js +7 -0
- package/dist/svgs/ArtsyLogoBlackIcon.d.ts +7 -0
- package/dist/svgs/ArtsyLogoBlackIcon.js +7 -0
- package/dist/svgs/ArtsyLogoWhiteIcon.d.ts +3 -0
- package/dist/svgs/ArtsyLogoWhiteIcon.js +5 -0
- package/dist/svgs/ArtsyMarkBlackIcon.d.ts +3 -0
- package/dist/svgs/ArtsyMarkBlackIcon.js +7 -0
- package/dist/svgs/ArtsyMarkWhiteIcon.d.ts +3 -0
- package/dist/svgs/ArtsyMarkWhiteIcon.js +5 -0
- package/dist/svgs/ArtworkIcon.d.ts +3 -0
- package/dist/svgs/ArtworkIcon.js +7 -0
- package/dist/svgs/AuctionIcon.d.ts +3 -0
- package/dist/svgs/AuctionIcon.js +7 -0
- package/dist/svgs/BellFillIcon.d.ts +3 -0
- package/dist/svgs/BellFillIcon.js +7 -0
- package/dist/svgs/BellIcon.d.ts +3 -0
- package/dist/svgs/BellIcon.js +7 -0
- package/dist/svgs/BlueChipIcon.d.ts +3 -0
- package/dist/svgs/BlueChipIcon.js +7 -0
- package/dist/svgs/BoltCircleFill.d.ts +3 -0
- package/dist/svgs/BoltCircleFill.js +7 -0
- package/dist/svgs/BoltFill.d.ts +3 -0
- package/dist/svgs/BoltFill.js +7 -0
- package/dist/svgs/BookmarkFill.d.ts +3 -0
- package/dist/svgs/BookmarkFill.js +7 -0
- package/dist/svgs/BriefcaseIcon.d.ts +3 -0
- package/dist/svgs/BriefcaseIcon.js +7 -0
- package/dist/svgs/CertificateIcon.d.ts +3 -0
- package/dist/svgs/CertificateIcon.js +7 -0
- package/dist/svgs/CheckCircleFillIcon.d.ts +3 -0
- package/dist/svgs/CheckCircleFillIcon.js +7 -0
- package/dist/svgs/CheckCircleIcon.d.ts +3 -0
- package/dist/svgs/CheckCircleIcon.js +7 -0
- package/dist/svgs/CheckIcon.d.ts +3 -0
- package/dist/svgs/CheckIcon.js +7 -0
- package/dist/svgs/ChevronIcon.d.ts +8 -0
- package/dist/svgs/ChevronIcon.js +15 -0
- package/dist/svgs/ClockFill.d.ts +3 -0
- package/dist/svgs/ClockFill.js +7 -0
- package/dist/svgs/CloseCircleFillIcon.d.ts +3 -0
- package/dist/svgs/CloseCircleFillIcon.js +7 -0
- package/dist/svgs/CloseCircleIcon.d.ts +3 -0
- package/dist/svgs/CloseCircleIcon.js +7 -0
- package/dist/svgs/CloseIcon.d.ts +3 -0
- package/dist/svgs/CloseIcon.js +7 -0
- package/dist/svgs/CollapseIcon.d.ts +3 -0
- package/dist/svgs/CollapseIcon.js +7 -0
- package/dist/svgs/CreditCardIcon.d.ts +9 -0
- package/dist/svgs/CreditCardIcon.js +18 -0
- package/dist/svgs/DecreaseIcon.d.ts +3 -0
- package/dist/svgs/DecreaseIcon.js +7 -0
- package/dist/svgs/DocumentIcon.d.ts +3 -0
- package/dist/svgs/DocumentIcon.js +7 -0
- package/dist/svgs/DownloadIcon.d.ts +3 -0
- package/dist/svgs/DownloadIcon.js +7 -0
- package/dist/svgs/EditIcon.d.ts +3 -0
- package/dist/svgs/EditIcon.js +7 -0
- package/dist/svgs/EmptyCheckCircleIcon.d.ts +3 -0
- package/dist/svgs/EmptyCheckCircleIcon.js +7 -0
- package/dist/svgs/EnterIcon.d.ts +3 -0
- package/dist/svgs/EnterIcon.js +7 -0
- package/dist/svgs/EnvelopeIcon.d.ts +3 -0
- package/dist/svgs/EnvelopeIcon.js +7 -0
- package/dist/svgs/EstablishedIcon.d.ts +3 -0
- package/dist/svgs/EstablishedIcon.js +7 -0
- package/dist/svgs/ExclamationMarkCircleFill.d.ts +3 -0
- package/dist/svgs/ExclamationMarkCircleFill.js +7 -0
- package/dist/svgs/ExpandIcon.d.ts +3 -0
- package/dist/svgs/ExpandIcon.js +7 -0
- package/dist/svgs/EyeClosedIcon.d.ts +3 -0
- package/dist/svgs/EyeClosedIcon.js +7 -0
- package/dist/svgs/EyeOpenedIcon.d.ts +3 -0
- package/dist/svgs/EyeOpenedIcon.js +7 -0
- package/dist/svgs/FacebookIcon.d.ts +3 -0
- package/dist/svgs/FacebookIcon.js +7 -0
- package/dist/svgs/FairIcon.d.ts +3 -0
- package/dist/svgs/FairIcon.js +7 -0
- package/dist/svgs/FilterIcon.d.ts +3 -0
- package/dist/svgs/FilterIcon.js +7 -0
- package/dist/svgs/FullWidthIcon.d.ts +3 -0
- package/dist/svgs/FullWidthIcon.js +7 -0
- package/dist/svgs/GenomeIcon.d.ts +3 -0
- package/dist/svgs/GenomeIcon.js +7 -0
- package/dist/svgs/GraphIcon.d.ts +3 -0
- package/dist/svgs/GraphIcon.js +7 -0
- package/dist/svgs/GridIcon.d.ts +3 -0
- package/dist/svgs/GridIcon.js +7 -0
- package/dist/svgs/GuaranteeIcon.d.ts +3 -0
- package/dist/svgs/GuaranteeIcon.js +8 -0
- package/dist/svgs/HeartFillIcon.d.ts +3 -0
- package/dist/svgs/HeartFillIcon.js +7 -0
- package/dist/svgs/HeartIcon.d.ts +3 -0
- package/dist/svgs/HeartIcon.js +7 -0
- package/dist/svgs/HideIcon.d.ts +3 -0
- package/dist/svgs/HideIcon.js +7 -0
- package/dist/svgs/HomeIcon.d.ts +3 -0
- package/dist/svgs/HomeIcon.js +7 -0
- package/dist/svgs/Icon.d.ts +10 -0
- package/dist/svgs/Icon.js +34 -0
- package/dist/svgs/ImageIcon.d.ts +3 -0
- package/dist/svgs/ImageIcon.js +7 -0
- package/dist/svgs/ImageSetIcon.d.ts +3 -0
- package/dist/svgs/ImageSetIcon.js +7 -0
- package/dist/svgs/IncreaseIcon.d.ts +3 -0
- package/dist/svgs/IncreaseIcon.js +7 -0
- package/dist/svgs/InfoCircleIcon.d.ts +3 -0
- package/dist/svgs/InfoCircleIcon.js +7 -0
- package/dist/svgs/InstagramAppIcon.d.ts +3 -0
- package/dist/svgs/InstagramAppIcon.js +3 -0
- package/dist/svgs/InstitutionIcon.d.ts +3 -0
- package/dist/svgs/InstitutionIcon.js +7 -0
- package/dist/svgs/LinkIcon.d.ts +3 -0
- package/dist/svgs/LinkIcon.js +7 -0
- package/dist/svgs/LoaderIcon.d.ts +3 -0
- package/dist/svgs/LoaderIcon.js +7 -0
- package/dist/svgs/LockIcon.d.ts +3 -0
- package/dist/svgs/LockIcon.js +7 -0
- package/dist/svgs/LogoutIcon.d.ts +3 -0
- package/dist/svgs/LogoutIcon.js +7 -0
- package/dist/svgs/MagnifyingGlassIcon.d.ts +3 -0
- package/dist/svgs/MagnifyingGlassIcon.js +7 -0
- package/dist/svgs/MapPinIcon.d.ts +3 -0
- package/dist/svgs/MapPinIcon.js +7 -0
- package/dist/svgs/MenuIcon.d.ts +3 -0
- package/dist/svgs/MenuIcon.js +7 -0
- package/dist/svgs/MessageIcon.d.ts +3 -0
- package/dist/svgs/MessageIcon.js +8 -0
- package/dist/svgs/MessagesAppIcon.d.ts +3 -0
- package/dist/svgs/MessagesAppIcon.js +5 -0
- package/dist/svgs/MoneyCircleIcon.d.ts +3 -0
- package/dist/svgs/MoneyCircleIcon.js +7 -0
- package/dist/svgs/MoneyFillIcon.d.ts +3 -0
- package/dist/svgs/MoneyFillIcon.js +7 -0
- package/dist/svgs/MoreIcon.d.ts +3 -0
- package/dist/svgs/MoreIcon.js +7 -0
- package/dist/svgs/MultiplePersonsIcon.d.ts +3 -0
- package/dist/svgs/MultiplePersonsIcon.js +7 -0
- package/dist/svgs/NoArtworkIcon.d.ts +3 -0
- package/dist/svgs/NoArtworkIcon.js +7 -0
- package/dist/svgs/NoImageIcon.d.ts +3 -0
- package/dist/svgs/NoImageIcon.js +7 -0
- package/dist/svgs/PageIcon.d.ts +3 -0
- package/dist/svgs/PageIcon.js +7 -0
- package/dist/svgs/Payment2Icon.d.ts +3 -0
- package/dist/svgs/Payment2Icon.js +7 -0
- package/dist/svgs/PaymentIcon.d.ts +3 -0
- package/dist/svgs/PaymentIcon.js +7 -0
- package/dist/svgs/PersonIcon.d.ts +3 -0
- package/dist/svgs/PersonIcon.js +7 -0
- package/dist/svgs/PublicationIcon.d.ts +3 -0
- package/dist/svgs/PublicationIcon.js +7 -0
- package/dist/svgs/QuestionCircleIcon.d.ts +3 -0
- package/dist/svgs/QuestionCircleIcon.js +7 -0
- package/dist/svgs/ReloadIcon.d.ts +3 -0
- package/dist/svgs/ReloadIcon.js +7 -0
- package/dist/svgs/SecureLockIcon.d.ts +3 -0
- package/dist/svgs/SecureLockIcon.js +7 -0
- package/dist/svgs/SettingsIcon.d.ts +3 -0
- package/dist/svgs/SettingsIcon.js +7 -0
- package/dist/svgs/ShareIcon.d.ts +3 -0
- package/dist/svgs/ShareIcon.js +7 -0
- package/dist/svgs/ShieldFilledIcon.d.ts +3 -0
- package/dist/svgs/ShieldFilledIcon.js +7 -0
- package/dist/svgs/ShieldIcon.d.ts +9 -0
- package/dist/svgs/ShieldIcon.js +7 -0
- package/dist/svgs/StarCircleFill.d.ts +3 -0
- package/dist/svgs/StarCircleFill.js +7 -0
- package/dist/svgs/StarCircleIcon.d.ts +3 -0
- package/dist/svgs/StarCircleIcon.js +7 -0
- package/dist/svgs/Stopwatch.d.ts +3 -0
- package/dist/svgs/Stopwatch.js +7 -0
- package/dist/svgs/Tag2Icon.d.ts +3 -0
- package/dist/svgs/Tag2Icon.js +8 -0
- package/dist/svgs/TagIcon.d.ts +3 -0
- package/dist/svgs/TagIcon.js +7 -0
- package/dist/svgs/TimerIcon.d.ts +3 -0
- package/dist/svgs/TimerIcon.js +7 -0
- package/dist/svgs/TopEmergingIcon.d.ts +3 -0
- package/dist/svgs/TopEmergingIcon.js +7 -0
- package/dist/svgs/TrashIcon.d.ts +3 -0
- package/dist/svgs/TrashIcon.js +7 -0
- package/dist/svgs/TrendingIcon.d.ts +3 -0
- package/dist/svgs/TrendingIcon.js +7 -0
- package/dist/svgs/TriangleDown.d.ts +3 -0
- package/dist/svgs/TriangleDown.js +7 -0
- package/dist/svgs/TwitterIcon.d.ts +3 -0
- package/dist/svgs/TwitterIcon.js +7 -0
- package/dist/svgs/UserMultiIcon.d.ts +3 -0
- package/dist/svgs/UserMultiIcon.js +7 -0
- package/dist/svgs/UserSingleIcon.d.ts +3 -0
- package/dist/svgs/UserSingleIcon.js +7 -0
- package/dist/svgs/VerifiedIcon.d.ts +3 -0
- package/dist/svgs/VerifiedIcon.js +7 -0
- package/dist/svgs/VerifiedPersonIcon.d.ts +3 -0
- package/dist/svgs/VerifiedPersonIcon.js +7 -0
- package/dist/svgs/WhatsAppAppIcon.d.ts +3 -0
- package/dist/svgs/WhatsAppAppIcon.js +4 -0
- package/dist/svgs/WorldGlobeCircleIcon.d.ts +3 -0
- package/dist/svgs/WorldGlobeCircleIcon.js +7 -0
- package/dist/svgs/XCircleIcon.d.ts +3 -0
- package/dist/svgs/XCircleIcon.js +7 -0
- package/dist/svgs/icons.stories.d.ts +7 -0
- package/dist/svgs/icons.stories.js +17 -0
- package/dist/svgs/index.d.ts +113 -0
- package/dist/svgs/index.js +113 -0
- package/dist/tokens.d.ts +67 -0
- package/dist/tokens.js +104 -0
- package/dist/types.d.ts +16 -0
- package/dist/types.js +7 -0
- package/dist/utils/Wrap.d.ts +12 -0
- package/dist/utils/Wrap.js +17 -0
- package/dist/utils/colors.stories.d.ts +6 -0
- package/dist/utils/colors.stories.js +47 -0
- package/dist/utils/createGeminiUrl.d.ts +9 -0
- package/dist/utils/createGeminiUrl.js +26 -0
- package/dist/utils/flattenChildren.d.ts +4 -0
- package/dist/utils/flattenChildren.js +13 -0
- package/dist/utils/formatLargeNumber.d.ts +1 -0
- package/dist/utils/formatLargeNumber.js +14 -0
- package/dist/utils/formatLargeNumbers.tests.d.ts +1 -0
- package/dist/utils/formatLargeNumbers.tests.js +18 -0
- package/dist/utils/hooks/index.d.ts +4 -0
- package/dist/utils/hooks/index.js +4 -0
- package/dist/utils/hooks/useColor.d.ts +1 -0
- package/dist/utils/hooks/useColor.js +2 -0
- package/dist/utils/hooks/useMeasure.d.ts +12 -0
- package/dist/utils/hooks/useMeasure.js +24 -0
- package/dist/utils/hooks/useScreenDimensions.d.ts +29 -0
- package/dist/utils/hooks/useScreenDimensions.js +26 -0
- package/dist/utils/hooks/useSpace.d.ts +1 -0
- package/dist/utils/hooks/useSpace.js +2 -0
- package/dist/utils/hooks/useTheme.d.ts +17 -0
- package/dist/utils/hooks/useTheme.js +30 -0
- package/dist/utils/normalizeText.d.ts +1 -0
- package/dist/utils/normalizeText.js +228 -0
- package/dist/utils/space.stories.d.ts +6 -0
- package/dist/utils/space.stories.js +13 -0
- package/dist/utils/tests/renderWithWrappers.d.ts +10 -0
- package/dist/utils/tests/renderWithWrappers.js +20 -0
- package/dist/utils/text.d.ts +19 -0
- package/dist/utils/text.js +19 -0
- package/dist/utils/types.d.ts +7 -0
- package/dist/utils/types.js +1 -0
- package/dist/utils/webTokensToMobile.d.ts +23 -0
- package/dist/utils/webTokensToMobile.js +37 -0
- package/package.json +6 -1
package/dist/Theme.d.ts
ADDED
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { ThemeType, ThemeWithDarkModeType, THEMES } from "./tokens";
|
|
3
|
+
type ThemeOptions = keyof typeof THEMES;
|
|
4
|
+
interface ThemeProps {
|
|
5
|
+
children?: React.ReactNode;
|
|
6
|
+
theme?: ThemeOptions;
|
|
7
|
+
}
|
|
8
|
+
export declare const Theme: React.FC<ThemeProps>;
|
|
9
|
+
/**
|
|
10
|
+
* Only use this if it's are absolutely neccessary, and only in tests.
|
|
11
|
+
*/
|
|
12
|
+
export declare const _test_THEMES: {
|
|
13
|
+
v3: ThemeType;
|
|
14
|
+
v3light: ThemeWithDarkModeType;
|
|
15
|
+
v3dark: ThemeWithDarkModeType;
|
|
16
|
+
};
|
|
17
|
+
export {};
|
package/dist/Theme.js
ADDED
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { ThemeProvider } from "styled-components/native";
|
|
3
|
+
import { THEMES } from "./tokens";
|
|
4
|
+
export const Theme = ({ children, theme = "v3light" }) => {
|
|
5
|
+
const currentTheme = getTheme(theme);
|
|
6
|
+
return _jsx(ThemeProvider, { theme: currentTheme, children: children });
|
|
7
|
+
};
|
|
8
|
+
const getTheme = (theme) => {
|
|
9
|
+
if (theme === "v3light") {
|
|
10
|
+
return THEMES.v3light;
|
|
11
|
+
}
|
|
12
|
+
if (theme === "v3dark") {
|
|
13
|
+
return THEMES.v3dark;
|
|
14
|
+
}
|
|
15
|
+
return THEMES.v3light;
|
|
16
|
+
};
|
|
17
|
+
/**
|
|
18
|
+
* Only use this if it's are absolutely neccessary, and only in tests.
|
|
19
|
+
*/
|
|
20
|
+
export const _test_THEMES = THEMES;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { Component } from "react";
|
|
2
|
+
import { StyleProp, ViewProps, ViewStyle } from "react-native";
|
|
3
|
+
interface CssTransitionProps extends ViewProps {
|
|
4
|
+
animate: string[];
|
|
5
|
+
duration: number;
|
|
6
|
+
}
|
|
7
|
+
interface CssTransitionState {
|
|
8
|
+
previousStyle: StyleProp<ViewStyle>;
|
|
9
|
+
}
|
|
10
|
+
export declare class CssTransition extends Component<CssTransitionProps, CssTransitionState> {
|
|
11
|
+
private animatedValue;
|
|
12
|
+
constructor(props: any);
|
|
13
|
+
UNSAFE_componentWillReceiveProps(nextProps: CssTransitionProps): void;
|
|
14
|
+
render(): JSX.Element;
|
|
15
|
+
private mergeStyles;
|
|
16
|
+
}
|
|
17
|
+
export {};
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { Component } from "react";
|
|
3
|
+
import { Animated } from "react-native";
|
|
4
|
+
export class CssTransition extends Component {
|
|
5
|
+
animatedValue = new Animated.Value(0);
|
|
6
|
+
// @ts-expect-error STRICTNESS_MIGRATION --- 🚨 Unsafe legacy code 🚨 Please delete this and fix any type errors if you have time 🙏
|
|
7
|
+
constructor(props) {
|
|
8
|
+
super(props);
|
|
9
|
+
this.state = {
|
|
10
|
+
previousStyle: props.style,
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
UNSAFE_componentWillReceiveProps(nextProps) {
|
|
14
|
+
this.setState({
|
|
15
|
+
previousStyle: this.props.style,
|
|
16
|
+
});
|
|
17
|
+
this.animatedValue = new Animated.Value(0);
|
|
18
|
+
Animated.timing(this.animatedValue, {
|
|
19
|
+
toValue: 1,
|
|
20
|
+
duration: nextProps.duration,
|
|
21
|
+
// not all style properties are animatable with the native driver
|
|
22
|
+
useNativeDriver: false,
|
|
23
|
+
}).start();
|
|
24
|
+
}
|
|
25
|
+
render() {
|
|
26
|
+
const { style, duration, ...props } = this.props;
|
|
27
|
+
const { previousStyle } = this.state;
|
|
28
|
+
const prevStyle = this.mergeStyles(previousStyle);
|
|
29
|
+
const nextStyle = this.mergeStyles(style);
|
|
30
|
+
const animateCheckboxStyle = this.props.animate.reduce((acc, cssProperty) => {
|
|
31
|
+
// @ts-expect-error STRICTNESS_MIGRATION --- 🚨 Unsafe legacy code 🚨 Please delete this and fix any type errors if you have time 🙏
|
|
32
|
+
acc[cssProperty] = this.animatedValue.interpolate({
|
|
33
|
+
inputRange: [0, 1],
|
|
34
|
+
outputRange: [prevStyle[cssProperty], nextStyle[cssProperty]],
|
|
35
|
+
});
|
|
36
|
+
return acc;
|
|
37
|
+
}, {});
|
|
38
|
+
return _jsx(Animated.View, { style: [style, animateCheckboxStyle], ...props });
|
|
39
|
+
}
|
|
40
|
+
// @ts-expect-error STRICTNESS_MIGRATION --- 🚨 Unsafe legacy code 🚨 Please delete this and fix any type errors if you have time 🙏
|
|
41
|
+
mergeStyles(style) {
|
|
42
|
+
// @ts-expect-error STRICTNESS_MIGRATION --- 🚨 Unsafe legacy code 🚨 Please delete this and fix any type errors if you have time 🙏
|
|
43
|
+
return style.reduce((acc, obj) => {
|
|
44
|
+
Object.keys(obj).forEach((key) => (acc[key] = obj[key]));
|
|
45
|
+
return acc;
|
|
46
|
+
}, {});
|
|
47
|
+
}
|
|
48
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./CssTransition";
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./CssTransition";
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Touch area box for UI elements
|
|
3
|
+
*/
|
|
4
|
+
export declare const DEFAULT_HIT_SLOP: {
|
|
5
|
+
top: number;
|
|
6
|
+
bottom: number;
|
|
7
|
+
left: number;
|
|
8
|
+
right: number;
|
|
9
|
+
};
|
|
10
|
+
/**
|
|
11
|
+
* Default active opacity for elements that use Palette's <Touchable />
|
|
12
|
+
*/
|
|
13
|
+
export declare let DEFAULT_ACTIVE_OPACITY: number;
|
|
14
|
+
export declare const setGlobalActiveOpacity: (opacity: number) => void;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Touch area box for UI elements
|
|
3
|
+
*/
|
|
4
|
+
export const DEFAULT_HIT_SLOP = { top: 20, bottom: 20, left: 20, right: 20 };
|
|
5
|
+
/**
|
|
6
|
+
* Default active opacity for elements that use Palette's <Touchable />
|
|
7
|
+
*/
|
|
8
|
+
export let DEFAULT_ACTIVE_OPACITY = 0.8;
|
|
9
|
+
// Set things globally
|
|
10
|
+
export const setGlobalActiveOpacity = (opacity) => {
|
|
11
|
+
DEFAULT_ACTIVE_OPACITY = opacity;
|
|
12
|
+
};
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
export declare const ArtsyKeyboardAvoidingViewContext: import("react").Context<{
|
|
3
|
+
isPresentedModally: boolean;
|
|
4
|
+
isVisible: boolean;
|
|
5
|
+
/**
|
|
6
|
+
* bottom offset is used when the screen is presented modally to account for
|
|
7
|
+
* any extra padding at the bottom of the screen (i.e. added for safe area insets)
|
|
8
|
+
*/
|
|
9
|
+
bottomOffset: number;
|
|
10
|
+
}>;
|
|
11
|
+
export declare const ArtsyKeyboardAvoidingView: ({ children }: {
|
|
12
|
+
children: React.ReactNode;
|
|
13
|
+
}) => JSX.Element;
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { Component, createRef, useContext, createContext } from "react";
|
|
3
|
+
import { Dimensions, Keyboard, LayoutAnimation, StatusBar, Platform, StyleSheet, View, } from "react-native";
|
|
4
|
+
export const ArtsyKeyboardAvoidingViewContext = createContext({
|
|
5
|
+
isPresentedModally: false,
|
|
6
|
+
isVisible: true,
|
|
7
|
+
/**
|
|
8
|
+
* bottom offset is used when the screen is presented modally to account for
|
|
9
|
+
* any extra padding at the bottom of the screen (i.e. added for safe area insets)
|
|
10
|
+
*/
|
|
11
|
+
bottomOffset: 0,
|
|
12
|
+
});
|
|
13
|
+
export const ArtsyKeyboardAvoidingView = ({ children }) => {
|
|
14
|
+
const { isPresentedModally, isVisible, bottomOffset } = useContext(ArtsyKeyboardAvoidingViewContext);
|
|
15
|
+
return (_jsx(KeyboardAvoidingView, { enabled: isVisible, mode: isPresentedModally ? "bottom-based" : "top-based", bottomOffset: bottomOffset, style: { flex: 1 }, children: children }));
|
|
16
|
+
};
|
|
17
|
+
/**
|
|
18
|
+
* This code was mostly copied directly from 'react-native'
|
|
19
|
+
*
|
|
20
|
+
* The things we've changed are:
|
|
21
|
+
* - to allow for bottom-based keyboard height calculations for modals
|
|
22
|
+
* - to use measureInWindow to get the view offset, rather than the bounding box from onLayout
|
|
23
|
+
*
|
|
24
|
+
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
25
|
+
*
|
|
26
|
+
* This source code is licensed under the MIT license found in the
|
|
27
|
+
* LICENSE file in the root directory of https://github.com/facebook/react-native
|
|
28
|
+
*/
|
|
29
|
+
class KeyboardAvoidingView extends Component {
|
|
30
|
+
_frame = null;
|
|
31
|
+
_subscriptions = [];
|
|
32
|
+
_initialFrameHeight = 0;
|
|
33
|
+
viewRef = createRef();
|
|
34
|
+
constructor(props) {
|
|
35
|
+
super(props);
|
|
36
|
+
this.state = { bottom: 0 };
|
|
37
|
+
}
|
|
38
|
+
_relativeKeyboardHeight(keyboardFrame) {
|
|
39
|
+
const frame = this._frame;
|
|
40
|
+
if (!frame || !keyboardFrame) {
|
|
41
|
+
return 0;
|
|
42
|
+
}
|
|
43
|
+
switch (this.props.mode) {
|
|
44
|
+
case "top-based": {
|
|
45
|
+
let keyboardY = keyboardFrame.screenY;
|
|
46
|
+
// on android the View layout frame coords start at -statusBarHeight but the
|
|
47
|
+
// keyboard screenY starts at 0 so we need to offset it to match the View frame
|
|
48
|
+
if (Platform.OS === "android") {
|
|
49
|
+
keyboardY -= StatusBar.currentHeight ?? 0;
|
|
50
|
+
}
|
|
51
|
+
// Calculate the displacement needed for the view such that it
|
|
52
|
+
// no longer overlaps with the keyboard
|
|
53
|
+
return Math.max(frame.y + frame.height - keyboardY, 0);
|
|
54
|
+
}
|
|
55
|
+
case "bottom-based": {
|
|
56
|
+
let keyboardHeight = Dimensions.get("screen").height - keyboardFrame.screenY;
|
|
57
|
+
keyboardHeight -= this.props.bottomOffset;
|
|
58
|
+
return Math.max(keyboardHeight, 0);
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
_onKeyboardChange = (event) => {
|
|
63
|
+
if (event == null) {
|
|
64
|
+
this.setState({ bottom: 0 });
|
|
65
|
+
return;
|
|
66
|
+
}
|
|
67
|
+
const { duration, easing, endCoordinates } = event;
|
|
68
|
+
const height = this._relativeKeyboardHeight(endCoordinates);
|
|
69
|
+
if (this.state.bottom === height) {
|
|
70
|
+
return;
|
|
71
|
+
}
|
|
72
|
+
if (duration && easing) {
|
|
73
|
+
LayoutAnimation.configureNext({
|
|
74
|
+
// We have to pass the duration equal to minimal accepted duration defined here: RCTLayoutAnimation.m
|
|
75
|
+
duration: duration > 10 ? duration : 10,
|
|
76
|
+
update: {
|
|
77
|
+
duration: duration > 10 ? duration : 10,
|
|
78
|
+
type: LayoutAnimation.Types[easing] || "keyboard",
|
|
79
|
+
},
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
this.setState({ bottom: height });
|
|
83
|
+
};
|
|
84
|
+
_onLayout = (event) => {
|
|
85
|
+
this._frame = event.nativeEvent.layout;
|
|
86
|
+
this.viewRef.current?.measureInWindow((x, y) => {
|
|
87
|
+
this._frame.x = x;
|
|
88
|
+
this._frame.y = y;
|
|
89
|
+
});
|
|
90
|
+
if (!this._initialFrameHeight) {
|
|
91
|
+
// save the initial frame height, before the keyboard is visible
|
|
92
|
+
this._initialFrameHeight = this._frame.height;
|
|
93
|
+
}
|
|
94
|
+
};
|
|
95
|
+
componentDidMount() {
|
|
96
|
+
if (Platform.OS === "ios") {
|
|
97
|
+
this._subscriptions = [
|
|
98
|
+
Keyboard.addListener("keyboardWillChangeFrame", this._onKeyboardChange),
|
|
99
|
+
];
|
|
100
|
+
}
|
|
101
|
+
else {
|
|
102
|
+
this._subscriptions = [
|
|
103
|
+
Keyboard.addListener("keyboardDidHide", this._onKeyboardChange),
|
|
104
|
+
Keyboard.addListener("keyboardDidShow", this._onKeyboardChange),
|
|
105
|
+
];
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
componentWillUnmount() {
|
|
109
|
+
this._subscriptions.forEach((subscription) => {
|
|
110
|
+
subscription.remove();
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
render() {
|
|
114
|
+
const { children, mode, enabled, style, ...props } = this.props;
|
|
115
|
+
const bottomHeight = enabled ? this.state.bottom : 0;
|
|
116
|
+
return (_jsx(View, { ref: this.viewRef, style: StyleSheet.compose(style, { paddingBottom: bottomHeight }), onLayout: this._onLayout, ...props, children: children }));
|
|
117
|
+
}
|
|
118
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './ArtsyKeyboardAvoidingView';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './ArtsyKeyboardAvoidingView';
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export interface AutocompleteEntry<T> {
|
|
2
|
+
key: T;
|
|
3
|
+
searchTerms: string[];
|
|
4
|
+
importance: number;
|
|
5
|
+
}
|
|
6
|
+
export declare class Autocomplete<T> {
|
|
7
|
+
private entries;
|
|
8
|
+
private maxCacheItems;
|
|
9
|
+
private cache;
|
|
10
|
+
private cacheOrder;
|
|
11
|
+
constructor(entries: Array<AutocompleteEntry<T>>, maxCacheItems?: number, stopWords?: string[]);
|
|
12
|
+
getSuggestions(searchString: string): T[];
|
|
13
|
+
}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { normalizeText } from "../../utils/normalizeText";
|
|
2
|
+
export class Autocomplete {
|
|
3
|
+
entries;
|
|
4
|
+
maxCacheItems;
|
|
5
|
+
cache = {};
|
|
6
|
+
cacheOrder = [];
|
|
7
|
+
constructor(entries, maxCacheItems = 100, stopWords = ["of", "the", "and"]) {
|
|
8
|
+
this.entries = entries;
|
|
9
|
+
this.maxCacheItems = maxCacheItems;
|
|
10
|
+
for (const entry of entries) {
|
|
11
|
+
entry.searchTerms = entry.searchTerms.map(normalizeText);
|
|
12
|
+
for (const searchTerm of entry.searchTerms.slice(0)) {
|
|
13
|
+
const parts = searchTerm.split(/\s+/).filter((s) => !stopWords.includes(s));
|
|
14
|
+
if (parts.length > 1) {
|
|
15
|
+
entry.searchTerms.push(...parts);
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
getSuggestions(searchString) {
|
|
21
|
+
searchString = normalizeText(searchString);
|
|
22
|
+
if (this.cache[searchString]) {
|
|
23
|
+
return this.cache[searchString].map((e) => e.key);
|
|
24
|
+
}
|
|
25
|
+
// refine previous results if available
|
|
26
|
+
let possibleEntries = this.entries;
|
|
27
|
+
for (let i = searchString.length - 2; i > 0; i--) {
|
|
28
|
+
if (this.cache[searchString.slice(0, i)]) {
|
|
29
|
+
possibleEntries = this.cache[searchString.slice(0, i)];
|
|
30
|
+
break;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
const results = possibleEntries.filter((entry) => {
|
|
34
|
+
for (const searchTerm of entry.searchTerms) {
|
|
35
|
+
if (searchTerm.startsWith(searchString)) {
|
|
36
|
+
return true;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
return false;
|
|
40
|
+
});
|
|
41
|
+
results.sort((a, b) => b.importance - a.importance);
|
|
42
|
+
this.cache[searchString] = results;
|
|
43
|
+
this.cacheOrder.push(searchString);
|
|
44
|
+
while (this.cacheOrder.length > this.maxCacheItems) {
|
|
45
|
+
delete this.cache[this.cacheOrder.shift()];
|
|
46
|
+
}
|
|
47
|
+
return results.map((e) => e.key);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import { Autocomplete } from "./Autocomplete";
|
|
2
|
+
const artists = [
|
|
3
|
+
{
|
|
4
|
+
key: "Pablo Picasso",
|
|
5
|
+
importance: 100,
|
|
6
|
+
searchTerms: ["Pablo Picasso"],
|
|
7
|
+
},
|
|
8
|
+
{
|
|
9
|
+
key: "Grayson Perry",
|
|
10
|
+
importance: 10,
|
|
11
|
+
searchTerms: ["Grayson Perry"],
|
|
12
|
+
},
|
|
13
|
+
{
|
|
14
|
+
key: "Prince",
|
|
15
|
+
importance: 50,
|
|
16
|
+
searchTerms: ["Prince", "The artist formerly known as 'Prince'"],
|
|
17
|
+
},
|
|
18
|
+
{
|
|
19
|
+
key: "James Brown",
|
|
20
|
+
importance: 100,
|
|
21
|
+
searchTerms: ["JB", "The King of Funk"],
|
|
22
|
+
},
|
|
23
|
+
];
|
|
24
|
+
describe(Autocomplete, () => {
|
|
25
|
+
it(`lets you search for individual words in search terms`, async () => {
|
|
26
|
+
const auto = new Autocomplete(artists);
|
|
27
|
+
expect(auto.getSuggestions("formerly")).toEqual(["Prince"]);
|
|
28
|
+
});
|
|
29
|
+
it(`doesn't care about capitalization`, async () => {
|
|
30
|
+
const auto = new Autocomplete(artists);
|
|
31
|
+
expect(auto.getSuggestions("fOrMerly")).toEqual(["Prince"]);
|
|
32
|
+
});
|
|
33
|
+
it(`doesn't care about punctuation`, async () => {
|
|
34
|
+
const auto = new Autocomplete([
|
|
35
|
+
...artists,
|
|
36
|
+
{
|
|
37
|
+
key: "Dog",
|
|
38
|
+
importance: +Infinity,
|
|
39
|
+
searchTerms: ["Santa's little helper"],
|
|
40
|
+
},
|
|
41
|
+
]);
|
|
42
|
+
expect(auto.getSuggestions("fOrMerl,y")).toEqual(["Prince"]);
|
|
43
|
+
expect(auto.getSuggestions("santas")).toEqual(["Dog"]);
|
|
44
|
+
});
|
|
45
|
+
it(`doesn't care about diacritics`, async () => {
|
|
46
|
+
const auto = new Autocomplete([
|
|
47
|
+
...artists,
|
|
48
|
+
{
|
|
49
|
+
key: "Nordic",
|
|
50
|
+
importance: +Infinity,
|
|
51
|
+
searchTerms: ["Jón Jønssön"],
|
|
52
|
+
},
|
|
53
|
+
]);
|
|
54
|
+
expect(auto.getSuggestions("Jon")).toEqual(["Nordic"]);
|
|
55
|
+
expect(auto.getSuggestions("Jonsson")).toEqual(["Nordic"]);
|
|
56
|
+
});
|
|
57
|
+
it(`orders results according to importance`, async () => {
|
|
58
|
+
const auto = new Autocomplete(artists);
|
|
59
|
+
expect(auto.getSuggestions("p")).toEqual(["Pablo Picasso", "Prince", "Grayson Perry"]);
|
|
60
|
+
});
|
|
61
|
+
it(`returns nothing when there are no matches`, async () => {
|
|
62
|
+
const auto = new Autocomplete(artists);
|
|
63
|
+
expect(auto.getSuggestions("z")).toEqual([]);
|
|
64
|
+
});
|
|
65
|
+
it(`ignores stop words which don't appear at the beginning of a search term`, async () => {
|
|
66
|
+
const auto = new Autocomplete([
|
|
67
|
+
...artists,
|
|
68
|
+
{
|
|
69
|
+
key: "PaRappa the Rapper",
|
|
70
|
+
importance: +Infinity * 2,
|
|
71
|
+
searchTerms: ["PaRappa the Rapper"],
|
|
72
|
+
},
|
|
73
|
+
], 10, ["the"]);
|
|
74
|
+
expect(auto.getSuggestions("the")).toContain("James Brown");
|
|
75
|
+
expect(auto.getSuggestions("the")).not.toContain("PaRappa the Rapper");
|
|
76
|
+
expect(auto.getSuggestions("Rapper")).toEqual(["PaRappa the Rapper"]);
|
|
77
|
+
});
|
|
78
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./Autocomplete";
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./Autocomplete";
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { ImgHTMLAttributes } from "react";
|
|
2
|
+
export type AvatarSize = "xxs" | "xs" | "sm" | "md";
|
|
3
|
+
export interface AvatarProps extends ImgHTMLAttributes<any> {
|
|
4
|
+
src?: string;
|
|
5
|
+
/** If an image is missing, show initials instead */
|
|
6
|
+
initials?: string;
|
|
7
|
+
/** The size of the Avatar */
|
|
8
|
+
size?: AvatarSize;
|
|
9
|
+
}
|
|
10
|
+
/** A circular Avatar component containing an image or initials */
|
|
11
|
+
export declare const Avatar: ({ src, initials, size }: AvatarProps) => JSX.Element;
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useState } from "react";
|
|
3
|
+
import { Image } from "react-native";
|
|
4
|
+
import Animated, { useAnimatedStyle, useSharedValue, withTiming, Easing, withDelay, } from "react-native-reanimated";
|
|
5
|
+
import { useColor } from "../../utils/hooks";
|
|
6
|
+
import { Box } from "../Box";
|
|
7
|
+
import { Flex } from "../Flex";
|
|
8
|
+
import { Text } from "../Text";
|
|
9
|
+
const DEFAULT_SIZE = "md";
|
|
10
|
+
const VARIANTS = {
|
|
11
|
+
xxs: {
|
|
12
|
+
diameter: 30,
|
|
13
|
+
textSize: "xs",
|
|
14
|
+
},
|
|
15
|
+
xs: {
|
|
16
|
+
diameter: 45,
|
|
17
|
+
textSize: "sm-display",
|
|
18
|
+
},
|
|
19
|
+
sm: {
|
|
20
|
+
diameter: 70,
|
|
21
|
+
textSize: "md",
|
|
22
|
+
},
|
|
23
|
+
md: {
|
|
24
|
+
diameter: 100,
|
|
25
|
+
textSize: "lg-display",
|
|
26
|
+
},
|
|
27
|
+
};
|
|
28
|
+
/** A circular Avatar component containing an image or initials */
|
|
29
|
+
export const Avatar = ({ src, initials, size = DEFAULT_SIZE }) => {
|
|
30
|
+
const color = useColor();
|
|
31
|
+
const [loading, setLoading] = useState(true);
|
|
32
|
+
const opacity = useSharedValue(0);
|
|
33
|
+
opacity.value = withDelay(100, withTiming(1, {
|
|
34
|
+
duration: 200,
|
|
35
|
+
easing: Easing.sin,
|
|
36
|
+
}));
|
|
37
|
+
const style = useAnimatedStyle(() => {
|
|
38
|
+
return {
|
|
39
|
+
opacity: loading ? 0 : opacity.value,
|
|
40
|
+
};
|
|
41
|
+
}, [loading]);
|
|
42
|
+
const { diameter, textSize } = VARIANTS[size];
|
|
43
|
+
if (src) {
|
|
44
|
+
return (_jsx(Box, { width: diameter, height: diameter, borderRadius: diameter / 2, overflow: "hidden", borderColor: color("white100"), borderWidth: 1, children: _jsx(Animated.View, { style: style, children: _jsx(Image, { onLoadStart: () => setLoading(true), onLoadEnd: () => setLoading(false), resizeMode: "cover", source: { uri: src }, accessibilityLabel: "AvatarImage", style: {
|
|
45
|
+
width: diameter,
|
|
46
|
+
height: diameter,
|
|
47
|
+
} }) }) }));
|
|
48
|
+
}
|
|
49
|
+
return (_jsx(Flex, { width: diameter, height: diameter, borderColor: "black10", borderWidth: 1, borderRadius: diameter, overflow: "hidden", alignItems: "center", justifyContent: "center", accessibilityLabel: "Avatar", children: _jsx(Text, { variant: textSize, children: initials }) }));
|
|
50
|
+
};
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { AvatarProps } from "./Avatar";
|
|
3
|
+
declare const _default: {
|
|
4
|
+
title: string;
|
|
5
|
+
component: ({ src, initials, size }: AvatarProps) => JSX.Element;
|
|
6
|
+
};
|
|
7
|
+
export default _default;
|
|
8
|
+
export declare function Variants(): JSX.Element;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Avatar } from "./Avatar";
|
|
3
|
+
import { List, Row } from "../../storybook/helpers";
|
|
4
|
+
export default {
|
|
5
|
+
title: "Avatar",
|
|
6
|
+
component: Avatar,
|
|
7
|
+
};
|
|
8
|
+
const sizes = ["md", "sm", "xs", "xxs"];
|
|
9
|
+
export function Variants() {
|
|
10
|
+
return (_jsxs(List, { children: [_jsx(Row, { children: sizes.map((s) => (_jsx(Avatar, { initials: "A", size: s }, s))) }), _jsx(Row, { children: sizes.map((s) => (_jsx(Avatar, { initials: "AA", size: s }, s))) }), _jsx(Row, { children: sizes.map((s) => (_jsx(Avatar, { src: "https://placekitten.com/300/300", size: s }, s))) })] }));
|
|
11
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { screen } from "@testing-library/react-native";
|
|
3
|
+
import { Image } from "react-native";
|
|
4
|
+
import { Avatar } from "./Avatar";
|
|
5
|
+
import { renderWithWrappers } from "../../utils/tests/renderWithWrappers";
|
|
6
|
+
describe("Avatar", () => {
|
|
7
|
+
it("renders initials if no image url and initials provided", () => {
|
|
8
|
+
renderWithWrappers(_jsx(Avatar, { initials: "AB" }));
|
|
9
|
+
expect(screen.UNSAFE_queryByType(Image)).not.toBeTruthy();
|
|
10
|
+
expect(screen.getByText("AB")).toBeTruthy();
|
|
11
|
+
});
|
|
12
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./Avatar";
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./Avatar";
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { TouchableOpacityProps, ViewProps } from "react-native";
|
|
3
|
+
import { Color } from "../../types";
|
|
4
|
+
export interface BackButtonProps {
|
|
5
|
+
color?: Color;
|
|
6
|
+
hitSlop?: ViewProps["hitSlop"];
|
|
7
|
+
onPress?: () => void;
|
|
8
|
+
showX?: boolean;
|
|
9
|
+
style?: TouchableOpacityProps["style"];
|
|
10
|
+
iconSize?: number;
|
|
11
|
+
}
|
|
12
|
+
export declare const BackButton: React.FC<BackButtonProps>;
|
|
13
|
+
export declare const BackButtonWithBackground: React.FC<BackButtonProps>;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { TouchableOpacity } from "react-native";
|
|
3
|
+
import { DEFAULT_HIT_SLOP } from "../../constants";
|
|
4
|
+
import { ChevronIcon, CloseIcon } from "../../svgs";
|
|
5
|
+
import { Flex } from "../Flex";
|
|
6
|
+
export const BackButton = ({ color = "onBackgroundHigh", hitSlop = DEFAULT_HIT_SLOP, onPress, showX = false, style, iconSize = 18, }) => {
|
|
7
|
+
return (_jsx(TouchableOpacity, { onPress: onPress, hitSlop: hitSlop, accessibilityRole: "button", accessibilityLabel: showX ? "Close" : "Go back", accessibilityHint: showX ? "Dismiss this screen" : "Go back to the previous screen", style: style, children: showX ? (_jsx(CloseIcon, { fill: color, width: iconSize, height: iconSize })) : (_jsx(ChevronIcon, { direction: "left", fill: color, height: iconSize, width: iconSize })) }));
|
|
8
|
+
};
|
|
9
|
+
export const BackButtonWithBackground = ({ color = "onBackgroundHigh", hitSlop = DEFAULT_HIT_SLOP, onPress, showX = false, style, }) => {
|
|
10
|
+
return (_jsx(TouchableOpacity, { onPress: onPress, hitSlop: hitSlop, children: _jsx(Flex, { backgroundColor: "background", width: 40, height: 40, borderRadius: 20, alignItems: "center", justifyContent: "center", accessibilityRole: "button", accessibilityLabel: showX ? "Close" : "Go back", accessibilityHint: showX ? "Dismiss this screen" : "Go back to the previous screen", style: style, children: showX ? (_jsx(CloseIcon, { fill: color, width: 26, height: 26 })) : (_jsx(ChevronIcon, { fill: color, direction: "left" })) }) }));
|
|
11
|
+
};
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { BackButton, BackButtonWithBackground } from "./BackButton";
|
|
3
|
+
import { Text } from "../../elements/Text";
|
|
4
|
+
import { List } from "../../storybook/helpers";
|
|
5
|
+
import { Flex } from "../Flex";
|
|
6
|
+
export default {
|
|
7
|
+
title: "BackButton",
|
|
8
|
+
component: BackButton,
|
|
9
|
+
};
|
|
10
|
+
export const Styled = () => (_jsxs(List, { style: { marginLeft: 50 }, contentContainerStyle: { alignItems: "flex-start" }, children: [_jsx(Text, { children: "Back button" }), _jsx(BackButton, {}), _jsx(Text, { children: "Back button with background" }), _jsxs(Flex, { children: [_jsx(Flex, { backgroundColor: "red", width: 50, height: 50, position: "absolute" }), _jsx(BackButtonWithBackground, {})] })] }));
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./BackButton";
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./BackButton";
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { FlexProps } from "styled-system";
|
|
3
|
+
export type BannerVariant = keyof typeof BANNER_VARIANTS;
|
|
4
|
+
export interface BannerProps extends FlexProps {
|
|
5
|
+
text: string;
|
|
6
|
+
onClose?: () => void;
|
|
7
|
+
dismissable?: boolean;
|
|
8
|
+
variant?: BannerVariant;
|
|
9
|
+
}
|
|
10
|
+
export declare const Banner: ({ text, onClose, dismissable, variant, ...restProps }: BannerProps) => JSX.Element;
|
|
11
|
+
declare const BANNER_VARIANTS: {
|
|
12
|
+
defaultLight: {
|
|
13
|
+
backgroundColor: string;
|
|
14
|
+
color: string;
|
|
15
|
+
};
|
|
16
|
+
defaultDark: {
|
|
17
|
+
backgroundColor: string;
|
|
18
|
+
color: string;
|
|
19
|
+
};
|
|
20
|
+
success: {
|
|
21
|
+
backgroundColor: string;
|
|
22
|
+
color: string;
|
|
23
|
+
};
|
|
24
|
+
error: {
|
|
25
|
+
backgroundColor: string;
|
|
26
|
+
color: string;
|
|
27
|
+
};
|
|
28
|
+
brand: {
|
|
29
|
+
backgroundColor: string;
|
|
30
|
+
color: string;
|
|
31
|
+
};
|
|
32
|
+
};
|
|
33
|
+
export {};
|