@ledgerhq/lumen-ui-rnative 0.1.36 → 0.1.37

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.
Files changed (159) hide show
  1. package/dist/module/lib/Animations/Pulse/Pulse.mdx +1 -1
  2. package/dist/module/lib/Animations/Spin/Spin.mdx +1 -1
  3. package/dist/module/lib/Components/AddressInput/AddressInput.mdx +1 -1
  4. package/dist/module/lib/Components/AmountDisplay/AmountDisplay.js +68 -39
  5. package/dist/module/lib/Components/AmountDisplay/AmountDisplay.js.map +1 -1
  6. package/dist/module/lib/Components/AmountDisplay/AmountDisplay.mdx +7 -1
  7. package/dist/module/lib/Components/AmountDisplay/AmountDisplay.stories.js +24 -0
  8. package/dist/module/lib/Components/AmountDisplay/AmountDisplay.stories.js.map +1 -1
  9. package/dist/module/lib/Components/AmountDisplay/types.js.map +1 -1
  10. package/dist/module/lib/Components/AmountInput/AmountInput.mdx +1 -1
  11. package/dist/module/lib/Components/Avatar/Avatar.mdx +1 -1
  12. package/dist/module/lib/Components/Banner/Banner.mdx +1 -1
  13. package/dist/module/lib/Components/BottomSheet/BottomSheet.mdx +1 -1
  14. package/dist/module/lib/Components/Button/Button.mdx +1 -1
  15. package/dist/module/lib/Components/Card/Card.stories.js +4 -9
  16. package/dist/module/lib/Components/Card/Card.stories.js.map +1 -1
  17. package/dist/module/lib/Components/CardButton/CardButton.mdx +1 -1
  18. package/dist/module/lib/Components/Checkbox/Checkbox.mdx +1 -1
  19. package/dist/module/lib/Components/Divider/Divider.mdx +1 -1
  20. package/dist/module/lib/Components/DotIcon/DotIcon.js +44 -23
  21. package/dist/module/lib/Components/DotIcon/DotIcon.js.map +1 -1
  22. package/dist/module/lib/Components/DotIcon/DotIcon.mdx +92 -0
  23. package/dist/module/lib/Components/DotIcon/DotIcon.stories.js +47 -0
  24. package/dist/module/lib/Components/DotIcon/DotIcon.stories.js.map +1 -1
  25. package/dist/module/lib/Components/DotSymbol/DotSymbol.js +52 -30
  26. package/dist/module/lib/Components/DotSymbol/DotSymbol.js.map +1 -1
  27. package/dist/module/lib/Components/DotSymbol/DotSymbol.mdx +79 -2
  28. package/dist/module/lib/Components/DotSymbol/DotSymbol.stories.js +41 -0
  29. package/dist/module/lib/Components/DotSymbol/DotSymbol.stories.js.map +1 -1
  30. package/dist/module/lib/Components/IconButton/IconButton.mdx +1 -1
  31. package/dist/module/lib/Components/InteractiveIcon/InteractiveIcon.mdx +1 -1
  32. package/dist/module/lib/Components/Link/Link.mdx +1 -1
  33. package/dist/module/lib/Components/MediaBanner/MediaBanner.mdx +1 -1
  34. package/dist/module/lib/Components/MediaButton/MediaButton.js +17 -17
  35. package/dist/module/lib/Components/MediaButton/MediaButton.js.map +1 -1
  36. package/dist/module/lib/Components/MediaButton/MediaButton.mdx +3 -3
  37. package/dist/module/lib/Components/MediaButton/MediaButton.stories.js +17 -17
  38. package/dist/module/lib/Components/MediaButton/MediaButton.stories.js.map +1 -1
  39. package/dist/module/lib/Components/MediaButton/MediaButton.test.js +4 -4
  40. package/dist/module/lib/Components/MediaButton/MediaButton.test.js.map +1 -1
  41. package/dist/module/lib/Components/MediaImage/MediaImage.js +20 -4
  42. package/dist/module/lib/Components/MediaImage/MediaImage.js.map +1 -1
  43. package/dist/module/lib/Components/MediaImage/MediaImage.stories.js +35 -0
  44. package/dist/module/lib/Components/MediaImage/MediaImage.stories.js.map +1 -1
  45. package/dist/module/lib/Components/NavBar/CoinCapsule.js +2 -2
  46. package/dist/module/lib/Components/NavBar/CoinCapsule.js.map +1 -1
  47. package/dist/module/lib/Components/NavBar/NavBar.js +2 -2
  48. package/dist/module/lib/Components/NavBar/NavBar.js.map +1 -1
  49. package/dist/module/lib/Components/NavBar/NavBar.mdx +2 -2
  50. package/dist/module/lib/Components/NavBar/NavBar.stories.js +1 -1
  51. package/dist/module/lib/Components/NavBar/NavBar.stories.js.map +1 -1
  52. package/dist/module/lib/Components/NavBar/NavBar.test.js +3 -3
  53. package/dist/module/lib/Components/NavBar/NavBar.test.js.map +1 -1
  54. package/dist/module/lib/Components/OptionList/OptionList.stories.js +4 -4
  55. package/dist/module/lib/Components/OptionList/OptionList.stories.js.map +1 -1
  56. package/dist/module/lib/Components/PageIndicator/PageIndicator.js +13 -8
  57. package/dist/module/lib/Components/PageIndicator/PageIndicator.js.map +1 -1
  58. package/dist/module/lib/Components/PageIndicator/PageIndicator.test.js +58 -0
  59. package/dist/module/lib/Components/PageIndicator/PageIndicator.test.js.map +1 -1
  60. package/dist/module/lib/Components/SearchInput/SearchInput.mdx +1 -1
  61. package/dist/module/lib/Components/SegmentedControl/SegmentedControl.mdx +1 -1
  62. package/dist/module/lib/Components/Select/Select.mdx +1 -1
  63. package/dist/module/lib/Components/Spinner/Spinner.mdx +1 -1
  64. package/dist/module/lib/Components/Spot/Spot.mdx +1 -1
  65. package/dist/module/lib/Components/Stepper/Stepper.mdx +1 -1
  66. package/dist/module/lib/Components/Subheader/Subheader.mdx +1 -1
  67. package/dist/module/lib/Components/Switch/Switch.mdx +1 -1
  68. package/dist/module/lib/Components/TabBar/TabBar.mdx +1 -1
  69. package/dist/module/lib/Components/TextInput/TextInput.mdx +1 -1
  70. package/dist/module/lib/Components/Tile/Tile.mdx +1 -1
  71. package/dist/module/lib/Components/Tooltip/Tooltip.mdx +1 -1
  72. package/dist/typescript/src/lib/Components/AmountDisplay/AmountDisplay.d.ts +1 -1
  73. package/dist/typescript/src/lib/Components/AmountDisplay/AmountDisplay.d.ts.map +1 -1
  74. package/dist/typescript/src/lib/Components/AmountDisplay/index.d.ts +1 -1
  75. package/dist/typescript/src/lib/Components/AmountDisplay/index.d.ts.map +1 -1
  76. package/dist/typescript/src/lib/Components/AmountDisplay/types.d.ts +10 -3
  77. package/dist/typescript/src/lib/Components/AmountDisplay/types.d.ts.map +1 -1
  78. package/dist/typescript/src/lib/Components/DotIcon/DotIcon.d.ts +1 -1
  79. package/dist/typescript/src/lib/Components/DotIcon/DotIcon.d.ts.map +1 -1
  80. package/dist/typescript/src/lib/Components/DotIcon/types.d.ts +6 -0
  81. package/dist/typescript/src/lib/Components/DotIcon/types.d.ts.map +1 -1
  82. package/dist/typescript/src/lib/Components/DotSymbol/DotSymbol.d.ts +1 -1
  83. package/dist/typescript/src/lib/Components/DotSymbol/DotSymbol.d.ts.map +1 -1
  84. package/dist/typescript/src/lib/Components/DotSymbol/types.d.ts +6 -0
  85. package/dist/typescript/src/lib/Components/DotSymbol/types.d.ts.map +1 -1
  86. package/dist/typescript/src/lib/Components/MediaButton/MediaButton.d.ts +3 -3
  87. package/dist/typescript/src/lib/Components/MediaButton/MediaButton.d.ts.map +1 -1
  88. package/dist/typescript/src/lib/Components/MediaButton/types.d.ts +6 -6
  89. package/dist/typescript/src/lib/Components/MediaButton/types.d.ts.map +1 -1
  90. package/dist/typescript/src/lib/Components/MediaImage/MediaImage.d.ts +1 -1
  91. package/dist/typescript/src/lib/Components/MediaImage/MediaImage.d.ts.map +1 -1
  92. package/dist/typescript/src/lib/Components/MediaImage/types.d.ts +6 -0
  93. package/dist/typescript/src/lib/Components/MediaImage/types.d.ts.map +1 -1
  94. package/dist/typescript/src/lib/Components/NavBar/CoinCapsule.d.ts +1 -1
  95. package/dist/typescript/src/lib/Components/NavBar/CoinCapsule.d.ts.map +1 -1
  96. package/dist/typescript/src/lib/Components/NavBar/NavBar.d.ts +1 -1
  97. package/dist/typescript/src/lib/Components/NavBar/NavBar.d.ts.map +1 -1
  98. package/dist/typescript/src/lib/Components/NavBar/types.d.ts +3 -3
  99. package/dist/typescript/src/lib/Components/NavBar/types.d.ts.map +1 -1
  100. package/dist/typescript/src/lib/Components/PageIndicator/PageIndicator.d.ts.map +1 -1
  101. package/package.json +3 -3
  102. package/src/lib/Animations/Pulse/Pulse.mdx +1 -1
  103. package/src/lib/Animations/Spin/Spin.mdx +1 -1
  104. package/src/lib/Components/AddressInput/AddressInput.mdx +1 -1
  105. package/src/lib/Components/AmountDisplay/AmountDisplay.mdx +7 -1
  106. package/src/lib/Components/AmountDisplay/AmountDisplay.stories.tsx +18 -0
  107. package/src/lib/Components/AmountDisplay/AmountDisplay.tsx +71 -40
  108. package/src/lib/Components/AmountDisplay/index.ts +5 -1
  109. package/src/lib/Components/AmountDisplay/types.ts +12 -3
  110. package/src/lib/Components/AmountInput/AmountInput.mdx +1 -1
  111. package/src/lib/Components/Avatar/Avatar.mdx +1 -1
  112. package/src/lib/Components/Banner/Banner.mdx +1 -1
  113. package/src/lib/Components/BottomSheet/BottomSheet.mdx +1 -1
  114. package/src/lib/Components/Button/Button.mdx +1 -1
  115. package/src/lib/Components/Card/Card.stories.tsx +1 -3
  116. package/src/lib/Components/CardButton/CardButton.mdx +1 -1
  117. package/src/lib/Components/Checkbox/Checkbox.mdx +1 -1
  118. package/src/lib/Components/Divider/Divider.mdx +1 -1
  119. package/src/lib/Components/DotIcon/DotIcon.mdx +92 -0
  120. package/src/lib/Components/DotIcon/DotIcon.stories.tsx +35 -0
  121. package/src/lib/Components/DotIcon/DotIcon.tsx +31 -14
  122. package/src/lib/Components/DotIcon/types.ts +6 -0
  123. package/src/lib/Components/DotSymbol/DotSymbol.mdx +79 -2
  124. package/src/lib/Components/DotSymbol/DotSymbol.stories.tsx +17 -0
  125. package/src/lib/Components/DotSymbol/DotSymbol.tsx +42 -24
  126. package/src/lib/Components/DotSymbol/types.ts +6 -0
  127. package/src/lib/Components/IconButton/IconButton.mdx +1 -1
  128. package/src/lib/Components/InteractiveIcon/InteractiveIcon.mdx +1 -1
  129. package/src/lib/Components/Link/Link.mdx +1 -1
  130. package/src/lib/Components/MediaBanner/MediaBanner.mdx +1 -1
  131. package/src/lib/Components/MediaButton/MediaButton.mdx +3 -3
  132. package/src/lib/Components/MediaButton/MediaButton.stories.tsx +29 -15
  133. package/src/lib/Components/MediaButton/MediaButton.test.tsx +4 -4
  134. package/src/lib/Components/MediaButton/MediaButton.tsx +33 -20
  135. package/src/lib/Components/MediaButton/types.ts +6 -6
  136. package/src/lib/Components/MediaImage/MediaImage.stories.tsx +18 -0
  137. package/src/lib/Components/MediaImage/MediaImage.tsx +12 -2
  138. package/src/lib/Components/MediaImage/types.ts +6 -0
  139. package/src/lib/Components/NavBar/CoinCapsule.tsx +2 -2
  140. package/src/lib/Components/NavBar/NavBar.mdx +2 -2
  141. package/src/lib/Components/NavBar/NavBar.stories.tsx +3 -1
  142. package/src/lib/Components/NavBar/NavBar.test.tsx +3 -3
  143. package/src/lib/Components/NavBar/NavBar.tsx +2 -2
  144. package/src/lib/Components/NavBar/types.ts +3 -3
  145. package/src/lib/Components/OptionList/OptionList.stories.tsx +4 -4
  146. package/src/lib/Components/PageIndicator/PageIndicator.test.tsx +78 -0
  147. package/src/lib/Components/PageIndicator/PageIndicator.tsx +15 -7
  148. package/src/lib/Components/SearchInput/SearchInput.mdx +1 -1
  149. package/src/lib/Components/SegmentedControl/SegmentedControl.mdx +1 -1
  150. package/src/lib/Components/Select/Select.mdx +1 -1
  151. package/src/lib/Components/Spinner/Spinner.mdx +1 -1
  152. package/src/lib/Components/Spot/Spot.mdx +1 -1
  153. package/src/lib/Components/Stepper/Stepper.mdx +1 -1
  154. package/src/lib/Components/Subheader/Subheader.mdx +1 -1
  155. package/src/lib/Components/Switch/Switch.mdx +1 -1
  156. package/src/lib/Components/TabBar/TabBar.mdx +1 -1
  157. package/src/lib/Components/TextInput/TextInput.mdx +1 -1
  158. package/src/lib/Components/Tile/Tile.mdx +1 -1
  159. package/src/lib/Components/Tooltip/Tooltip.mdx +1 -1
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
 
3
- import { StyleSheet } from 'react-native';
3
+ import { DisabledProvider, useDisabledContext } from '@ledgerhq/lumen-utils-shared';
4
4
  import { useStyleSheet } from "../../../styles/index.js";
5
5
  import { Box } from "../Utility/index.js";
6
6
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
@@ -49,13 +49,20 @@ const useStyles = ({
49
49
  size,
50
50
  shape,
51
51
  pin,
52
- appearance
52
+ appearance,
53
+ disabled
53
54
  }) => {
54
55
  return useStyleSheet(t => {
55
56
  const sizeValue = t.sizes[`s${size}`];
56
57
  const radius = shape === 'circle' ? t.borderRadius.full : dotSquareRadiusMap[size];
57
58
  const pinOffset = getPinOffset(pin);
58
59
  return {
60
+ root: {
61
+ position: 'relative',
62
+ ...(disabled && {
63
+ opacity: 0.3
64
+ })
65
+ },
59
66
  dot: {
60
67
  position: 'absolute',
61
68
  zIndex: 10,
@@ -74,7 +81,7 @@ const useStyles = ({
74
81
  color: t.colors.text.onInteractive
75
82
  }
76
83
  };
77
- }, [size, shape, pin, appearance]);
84
+ }, [size, shape, pin, appearance, disabled]);
78
85
  };
79
86
 
80
87
  /**
@@ -96,37 +103,51 @@ export const DotIcon = ({
96
103
  pin = 'bottom-end',
97
104
  size = 20,
98
105
  shape = 'circle',
106
+ disabled: disabledProp = false,
99
107
  lx = {},
100
108
  style,
101
109
  ref,
102
110
  ...rest
103
111
  }) => {
112
+ const disabled = useDisabledContext({
113
+ consumerName: 'DotIcon',
114
+ mergeWith: {
115
+ disabled: disabledProp
116
+ }
117
+ });
104
118
  const styles = useStyles({
105
119
  size,
106
120
  shape,
107
121
  pin,
108
- appearance
122
+ appearance,
123
+ disabled
109
124
  });
110
- return /*#__PURE__*/_jsx(Box, {
111
- ref: ref,
112
- lx: lx,
113
- style: StyleSheet.flatten([{
114
- position: 'relative'
115
- }, style]),
116
- ...rest,
117
- children: /*#__PURE__*/_jsxs(Box, {
118
- style: {
119
- alignSelf: 'flex-start',
120
- position: 'relative'
125
+ return /*#__PURE__*/_jsx(DisabledProvider, {
126
+ value: {
127
+ disabled: false
128
+ },
129
+ children: /*#__PURE__*/_jsx(Box, {
130
+ ref: ref,
131
+ lx: lx,
132
+ style: [styles.root, style],
133
+ accessibilityState: {
134
+ disabled
121
135
  },
122
- children: [children, /*#__PURE__*/_jsx(Box, {
123
- testID: "dot-icon-dot",
124
- style: styles.dot,
125
- children: /*#__PURE__*/_jsx(Icon, {
126
- size: dotIconSizeMap[size],
127
- style: styles.icon
128
- })
129
- })]
136
+ ...rest,
137
+ children: /*#__PURE__*/_jsxs(Box, {
138
+ style: {
139
+ alignSelf: 'flex-start',
140
+ position: 'relative'
141
+ },
142
+ children: [children, /*#__PURE__*/_jsx(Box, {
143
+ testID: "dot-icon-dot",
144
+ style: styles.dot,
145
+ children: /*#__PURE__*/_jsx(Icon, {
146
+ size: dotIconSizeMap[size],
147
+ style: styles.icon
148
+ })
149
+ })]
150
+ })
130
151
  })
131
152
  });
132
153
  };
@@ -1 +1 @@
1
- {"version":3,"names":["StyleSheet","useStyleSheet","Box","jsx","_jsx","jsxs","_jsxs","dotIconSizeMap","dotSquareRadiusMap","mediaImageDotIconSizeMap","spotDotIconSizeMap","pinAxisMap","DOT_OFFSET","getPinOffset","pin","v","h","appearanceBgMap","success","muted","error","useStyles","size","shape","appearance","t","sizeValue","sizes","radius","borderRadius","full","pinOffset","dot","position","zIndex","width","height","borderWidth","backgroundColor","colors","bg","borderColor","border","baseInverted","overflow","alignItems","justifyContent","icon","color","text","onInteractive","DotIcon","children","Icon","lx","style","ref","rest","styles","flatten","alignSelf","testID","displayName"],"sourceRoot":"../../../../../src","sources":["lib/Components/DotIcon/DotIcon.tsx"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["DisabledProvider","useDisabledContext","useStyleSheet","Box","jsx","_jsx","jsxs","_jsxs","dotIconSizeMap","dotSquareRadiusMap","mediaImageDotIconSizeMap","spotDotIconSizeMap","pinAxisMap","DOT_OFFSET","getPinOffset","pin","v","h","appearanceBgMap","success","muted","error","useStyles","size","shape","appearance","disabled","t","sizeValue","sizes","radius","borderRadius","full","pinOffset","root","position","opacity","dot","zIndex","width","height","borderWidth","backgroundColor","colors","bg","borderColor","border","baseInverted","overflow","alignItems","justifyContent","icon","color","text","onInteractive","DotIcon","children","Icon","disabledProp","lx","style","ref","rest","consumerName","mergeWith","styles","value","accessibilityState","alignSelf","testID","displayName"],"sourceRoot":"../../../../../src","sources":["lib/Components/DotIcon/DotIcon.tsx"],"mappings":"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","ignoreList":[]}
@@ -1,13 +1,18 @@
1
1
  import { Meta, Canvas, Controls } from '@storybook/addon-docs/blocks';
2
2
  import * as DotIconStories from './DotIcon.stories';
3
+ import { CustomTabs, Tab } from '../../../../.storybook/components';
3
4
 
4
5
  <Meta title='Communication/DotIcon' of={DotIconStories} />
5
6
 
6
7
  # DotIcon
7
8
 
9
+ <CustomTabs>
10
+ <Tab label="Overview">
11
+
8
12
  ## Introduction
9
13
 
10
14
  DotIcon positions a small icon indicator at a configurable corner of a child element such as MediaImage or Spot. The dot background uses a semantic color (`success`, `muted`, or `error`) to convey meaning at a glance.
15
+
11
16
  > View in [Figma](https://www.figma.com/design/zSkvGGiqcnhywp2l3HTHxA/1.-Symbol-Library?node-id=6159-1866).
12
17
 
13
18
  ## Anatomy
@@ -50,7 +55,94 @@ The dot size is driven by the parent MediaImage or Spot size via the mapping hel
50
55
 
51
56
  <Canvas of={DotIconStories.SizeShowcase} />
52
57
 
58
+ ### Disabled
59
+
60
+ Only set `disabled` on `DotIcon`. The state is propagated to the child via context. Passing it to both stacks the opacity overlay.
61
+
62
+ <Canvas of={DotIconStories.DisabledShowcase} />
63
+
53
64
  ## Accessibility
54
65
 
55
66
  - The icon is purely decorative; the child element should carry its own accessibility label.
56
67
  - Pair semantic appearances with meaningful icons so the state can be understood without relying on color alone.
68
+
69
+ </Tab>
70
+ <Tab label="Implementation">
71
+
72
+ ## Setup
73
+
74
+ Install and set up the library with our [Setup Guide →](?path=/docs/getting-started-setup--docs).
75
+
76
+ ### Basic Usage
77
+
78
+ ```tsx
79
+ import { DotIcon, MediaImage } from '@ledgerhq/lumen-ui-rnative';
80
+ import { ArrowDown } from '@ledgerhq/lumen-ui-rnative/symbols';
81
+
82
+ function MyComponent() {
83
+ return (
84
+ <DotIcon appearance='success' icon={ArrowDown}>
85
+ <MediaImage src='https://example.com/ada.png' alt='Cardano' size={48} />
86
+ </DotIcon>
87
+ );
88
+ }
89
+ ```
90
+
91
+ ### Pin Placement
92
+
93
+ Position the dot at any of the four corners of the child:
94
+
95
+ ```tsx
96
+ <DotIcon appearance='success' icon={ArrowDown} pin='top-end'>
97
+ <MediaImage src='https://example.com/ada.png' alt='Cardano' size={48} />
98
+ </DotIcon>
99
+ ```
100
+
101
+ ### Shapes
102
+
103
+ Use `shape='square'` to match a square child element:
104
+
105
+ ```tsx
106
+ <DotIcon appearance='muted' icon={ArrowDown} shape='square'>
107
+ <MediaImage src='https://example.com/ada.png' alt='Cardano' size={48} shape='square' />
108
+ </DotIcon>
109
+ ```
110
+
111
+ ### Appearances
112
+
113
+ Pick a semantic color via `appearance`:
114
+
115
+ ```tsx
116
+ <DotIcon appearance='success' icon={ArrowDown}>...</DotIcon>
117
+ <DotIcon appearance='muted' icon={ArrowUp}>...</DotIcon>
118
+ <DotIcon appearance='error' icon={Close}>...</DotIcon>
119
+ ```
120
+
121
+ ### Sizing
122
+
123
+ The dot size is driven by the parent's size via the mapping helpers:
124
+
125
+ ```tsx
126
+ import { DotIcon, mediaImageDotIconSizeMap, MediaImage } from '@ledgerhq/lumen-ui-rnative';
127
+
128
+ <DotIcon
129
+ appearance='success'
130
+ icon={ArrowDown}
131
+ size={mediaImageDotIconSizeMap[48]}
132
+ >
133
+ <MediaImage src='https://example.com/ada.png' alt='Cardano' size={48} />
134
+ </DotIcon>;
135
+ ```
136
+
137
+ ### Disabled State
138
+
139
+ Only set `disabled` on `DotIcon`. The state is propagated to the child via context. Passing it to both stacks the opacity overlay.
140
+
141
+ ```tsx
142
+ <DotIcon appearance='success' icon={ArrowDown} disabled>
143
+ <MediaImage src='https://example.com/ada.png' alt='Cardano' size={48} />
144
+ </DotIcon>
145
+ ```
146
+
147
+ </Tab>
148
+ </CustomTabs>
@@ -160,6 +160,53 @@ export const AppearanceShowcase = {
160
160
  })]
161
161
  })
162
162
  };
163
+ export const DisabledShowcase = {
164
+ args: {
165
+ appearance: 'success',
166
+ icon: ArrowDown
167
+ },
168
+ render: () => /*#__PURE__*/_jsxs(Box, {
169
+ lx: {
170
+ flexDirection: 'row',
171
+ alignItems: 'center',
172
+ gap: 's32'
173
+ },
174
+ children: [/*#__PURE__*/_jsx(DotIcon, {
175
+ appearance: "success",
176
+ icon: ArrowDown,
177
+ size: mediaImageDotIconSizeMap[48],
178
+ pin: "bottom-end",
179
+ disabled: true,
180
+ children: /*#__PURE__*/_jsx(MediaImage, {
181
+ src: parentSrc,
182
+ size: 48,
183
+ shape: "circle"
184
+ })
185
+ }), /*#__PURE__*/_jsx(DotIcon, {
186
+ appearance: "muted",
187
+ icon: ArrowUp,
188
+ size: mediaImageDotIconSizeMap[48],
189
+ pin: "bottom-end",
190
+ disabled: true,
191
+ children: /*#__PURE__*/_jsx(MediaImage, {
192
+ src: parentSrc,
193
+ size: 48,
194
+ shape: "circle"
195
+ })
196
+ }), /*#__PURE__*/_jsx(DotIcon, {
197
+ appearance: "error",
198
+ icon: Close,
199
+ size: mediaImageDotIconSizeMap[48],
200
+ pin: "bottom-end",
201
+ disabled: true,
202
+ children: /*#__PURE__*/_jsx(MediaImage, {
203
+ src: parentSrc,
204
+ size: 48,
205
+ shape: "circle"
206
+ })
207
+ })]
208
+ })
209
+ };
163
210
  export const SizeShowcase = {
164
211
  args: {
165
212
  appearance: 'muted',
@@ -1 +1 @@
1
- {"version":3,"names":["ArrowDown","ArrowUp","Close","Link","Star","MediaImage","Spinner","Box","DotIcon","mediaImageDotIconSizeMap","jsx","_jsx","jsxs","_jsxs","meta","component","title","parameters","docs","source","language","format","type","parentSrc","Base","args","appearance","icon","pin","size","shape","children","src","alt","PinShowcase","render","lx","flexDirection","alignItems","gap","ShapeShowcase","AppearanceShowcase","SizeShowcase"],"sourceRoot":"../../../../../src","sources":["lib/Components/DotIcon/DotIcon.stories.tsx"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["ArrowDown","ArrowUp","Close","Link","Star","MediaImage","Spinner","Box","DotIcon","mediaImageDotIconSizeMap","jsx","_jsx","jsxs","_jsxs","meta","component","title","parameters","docs","source","language","format","type","parentSrc","Base","args","appearance","icon","pin","size","shape","children","src","alt","PinShowcase","render","lx","flexDirection","alignItems","gap","ShapeShowcase","AppearanceShowcase","DisabledShowcase","disabled","SizeShowcase"],"sourceRoot":"../../../../../src","sources":["lib/Components/DotIcon/DotIcon.stories.tsx"],"mappings":"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","ignoreList":[]}
@@ -1,7 +1,8 @@
1
1
  "use strict";
2
2
 
3
+ import { DisabledProvider, useDisabledContext } from '@ledgerhq/lumen-utils-shared';
3
4
  import { useEffect, useState } from 'react';
4
- import { Image, StyleSheet } from 'react-native';
5
+ import { Image } from 'react-native';
5
6
  import { useStyleSheet } from "../../../styles/index.js";
6
7
  import { Box } from "../Utility/index.js";
7
8
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
@@ -56,13 +57,20 @@ const getPinOffset = (pin, size) => {
56
57
  const useStyles = ({
57
58
  size,
58
59
  shape,
59
- pin
60
+ pin,
61
+ disabled
60
62
  }) => {
61
63
  return useStyleSheet(t => {
62
64
  const sizeValue = t.sizes[`s${size}`];
63
65
  const radius = shape === 'circle' ? t.borderRadius.full : dotSquareRadiusMap[size];
64
66
  const pinOffset = getPinOffset(pin, size);
65
67
  return {
68
+ root: {
69
+ position: 'relative',
70
+ ...(disabled && {
71
+ opacity: 0.3
72
+ })
73
+ },
66
74
  dot: {
67
75
  position: 'absolute',
68
76
  zIndex: 10,
@@ -80,7 +88,7 @@ const useStyles = ({
80
88
  height: '100%'
81
89
  }
82
90
  };
83
- }, [size, shape, pin]);
91
+ }, [size, shape, pin, disabled]);
84
92
  };
85
93
 
86
94
  /**
@@ -101,46 +109,60 @@ export const DotSymbol = ({
101
109
  pin = 'bottom-end',
102
110
  size = 20,
103
111
  shape = 'circle',
112
+ disabled: disabledProp = false,
104
113
  lx = {},
105
114
  style,
106
115
  ref,
107
116
  ...rest
108
117
  }) => {
118
+ const [error, setError] = useState(false);
119
+ const disabled = useDisabledContext({
120
+ consumerName: 'DotSymbol',
121
+ mergeWith: {
122
+ disabled: disabledProp
123
+ }
124
+ });
109
125
  const styles = useStyles({
110
126
  size,
111
127
  shape,
112
- pin
128
+ pin,
129
+ disabled
113
130
  });
114
- const [error, setError] = useState(false);
115
131
  useEffect(() => {
116
132
  setError(false);
117
133
  }, [src]);
118
- return /*#__PURE__*/_jsx(Box, {
119
- ref: ref,
120
- lx: lx,
121
- style: StyleSheet.flatten([{
122
- position: 'relative'
123
- }, style]),
124
- accessibilityRole: "image",
125
- accessibilityLabel: alt,
126
- ...rest,
127
- children: /*#__PURE__*/_jsxs(Box, {
128
- style: {
129
- alignSelf: 'flex-start',
130
- position: 'relative'
134
+ return /*#__PURE__*/_jsx(DisabledProvider, {
135
+ value: {
136
+ disabled: false
137
+ },
138
+ children: /*#__PURE__*/_jsx(Box, {
139
+ ref: ref,
140
+ lx: lx,
141
+ style: [styles.root, style],
142
+ accessibilityRole: "image",
143
+ accessibilityLabel: alt,
144
+ accessibilityState: {
145
+ disabled
131
146
  },
132
- children: [children, /*#__PURE__*/_jsx(Box, {
133
- style: styles.dot,
134
- children: !error && /*#__PURE__*/_jsx(Image, {
135
- source: {
136
- uri: src
137
- },
138
- style: styles.image,
139
- accessible: false,
140
- onError: () => setError(true),
141
- testID: "dot-symbol-img"
142
- })
143
- })]
147
+ ...rest,
148
+ children: /*#__PURE__*/_jsxs(Box, {
149
+ style: {
150
+ alignSelf: 'flex-start',
151
+ position: 'relative'
152
+ },
153
+ children: [children, /*#__PURE__*/_jsx(Box, {
154
+ style: styles.dot,
155
+ children: !error && /*#__PURE__*/_jsx(Image, {
156
+ source: {
157
+ uri: src
158
+ },
159
+ style: styles.image,
160
+ accessible: false,
161
+ onError: () => setError(true),
162
+ testID: "dot-symbol-img"
163
+ })
164
+ })]
165
+ })
144
166
  })
145
167
  });
146
168
  };
@@ -1 +1 @@
1
- {"version":3,"names":["useEffect","useState","Image","StyleSheet","useStyleSheet","Box","jsx","_jsx","jsxs","_jsxs","dotSquareRadiusMap","offsetBySize","mediaImageDotSizeMap","spotDotSizeMap","pinAxisMap","getPinOffset","pin","size","v","h","offset","useStyles","shape","t","sizeValue","sizes","radius","borderRadius","full","pinOffset","dot","position","zIndex","width","height","borderWidth","backgroundColor","colors","bg","muted","borderColor","border","baseInverted","overflow","image","DotSymbol","children","src","alt","lx","style","ref","rest","styles","error","setError","flatten","accessibilityRole","accessibilityLabel","alignSelf","source","uri","accessible","onError","testID","displayName"],"sourceRoot":"../../../../../src","sources":["lib/Components/DotSymbol/DotSymbol.tsx"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["DisabledProvider","useDisabledContext","useEffect","useState","Image","useStyleSheet","Box","jsx","_jsx","jsxs","_jsxs","dotSquareRadiusMap","offsetBySize","mediaImageDotSizeMap","spotDotSizeMap","pinAxisMap","getPinOffset","pin","size","v","h","offset","useStyles","shape","disabled","t","sizeValue","sizes","radius","borderRadius","full","pinOffset","root","position","opacity","dot","zIndex","width","height","borderWidth","backgroundColor","colors","bg","muted","borderColor","border","baseInverted","overflow","image","DotSymbol","children","src","alt","disabledProp","lx","style","ref","rest","error","setError","consumerName","mergeWith","styles","value","accessibilityRole","accessibilityLabel","accessibilityState","alignSelf","source","uri","accessible","onError","testID","displayName"],"sourceRoot":"../../../../../src","sources":["lib/Components/DotSymbol/DotSymbol.tsx"],"mappings":"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","ignoreList":[]}
@@ -4,14 +4,17 @@ import { CustomTabs, Tab } from '../../../../.storybook/components';
4
4
 
5
5
  <Meta title='Communication/DotSymbol' of={DotSymbolStories} />
6
6
 
7
+ # DotSymbol
8
+
7
9
  <CustomTabs>
8
10
  <Tab label="Overview">
9
- # DotSymbol
10
11
 
11
12
  ## Introduction
12
13
 
13
14
  DotSymbol positions a small image indicator at a configurable corner of a child element such as MediaImage or Spot. It is commonly used to show a network badge or secondary icon overlapping a primary symbol.
14
15
 
16
+ > View in [Figma](https://www.figma.com/design/zSkvGGiqcnhywp2l3HTHxA/1.-Symbol-Library?node-id=8602-380&m=dev).
17
+
15
18
  ## Anatomy
16
19
 
17
20
  <Canvas of={DotSymbolStories.Base} />
@@ -46,9 +49,83 @@ The dot size is driven by the parent MediaImage or Spot size via the mapping hel
46
49
 
47
50
  <Canvas of={DotSymbolStories.SizeShowcase} />
48
51
 
52
+ ### Disabled
53
+
54
+ Only set `disabled` on `DotSymbol`. The state is propagated to the child via context. Passing it to both stacks the opacity overlay.
55
+
56
+ <Canvas of={DotSymbolStories.DisabledShowcase} />
57
+
49
58
  ## Accessibility
50
59
 
51
60
  - Always provide a meaningful `alt` prop on the DotSymbol so the indicator image is announced by screen readers.
52
61
  - The child element should carry its own accessibility label independently.
62
+
63
+ </Tab>
64
+ <Tab label="Implementation">
65
+
66
+ ## Setup
67
+
68
+ Install and set up the library with our [Setup Guide →](?path=/docs/getting-started-setup--docs).
69
+
70
+ ### Basic Usage
71
+
72
+ ```tsx
73
+ import { DotSymbol, MediaImage } from '@ledgerhq/lumen-ui-rnative';
74
+
75
+ function MyComponent() {
76
+ return (
77
+ <DotSymbol src='https://example.com/btc.png' alt='Bitcoin network'>
78
+ <MediaImage src='https://example.com/ada.png' alt='Cardano' size={48} />
79
+ </DotSymbol>
80
+ );
81
+ }
82
+ ```
83
+
84
+ ### Pin Placement
85
+
86
+ Position the dot at any of the four corners of the child:
87
+
88
+ ```tsx
89
+ <DotSymbol src='https://example.com/btc.png' alt='Bitcoin' pin='top-end'>
90
+ <MediaImage src='https://example.com/ada.png' alt='Cardano' size={48} />
91
+ </DotSymbol>
92
+ ```
93
+
94
+ ### Shapes
95
+
96
+ Use `shape='square'` to match a square child element:
97
+
98
+ ```tsx
99
+ <DotSymbol src='https://example.com/btc.png' alt='Bitcoin' shape='square'>
100
+ <MediaImage src='https://example.com/ada.png' alt='Cardano' size={48} shape='square' />
101
+ </DotSymbol>
102
+ ```
103
+
104
+ ### Sizing
105
+
106
+ The dot size is driven by the parent's size via the mapping helpers:
107
+
108
+ ```tsx
109
+ import { DotSymbol, mediaImageDotSizeMap, MediaImage } from '@ledgerhq/lumen-ui-rnative';
110
+
111
+ <DotSymbol
112
+ src='https://example.com/btc.png'
113
+ alt='Bitcoin'
114
+ size={mediaImageDotSizeMap[48]}
115
+ >
116
+ <MediaImage src='https://example.com/ada.png' alt='Cardano' size={48} />
117
+ </DotSymbol>;
118
+ ```
119
+
120
+ ### Disabled State
121
+
122
+ Only set `disabled` on `DotSymbol`. The state is propagated to the child via context. Passing it to both stacks the opacity overlay.
123
+
124
+ ```tsx
125
+ <DotSymbol src='https://example.com/btc.png' alt='Bitcoin' disabled>
126
+ <MediaImage src='https://example.com/ada.png' alt='Cardano' size={48} />
127
+ </DotSymbol>
128
+ ```
129
+
53
130
  </Tab>
54
- </CustomTabs>
131
+ </CustomTabs>
@@ -160,6 +160,47 @@ export const ShapeShowcase = {
160
160
  })
161
161
  })
162
162
  };
163
+ export const DisabledShowcase = {
164
+ args: {
165
+ src: dotSrc,
166
+ alt: 'Disabled showcase'
167
+ },
168
+ render: () => /*#__PURE__*/_jsxs(Box, {
169
+ lx: {
170
+ flexDirection: 'row',
171
+ alignItems: 'center',
172
+ gap: 's32'
173
+ },
174
+ children: [/*#__PURE__*/_jsx(DotSymbol, {
175
+ src: dotSrc,
176
+ pin: "bottom-end",
177
+ disabled: true,
178
+ children: /*#__PURE__*/_jsx(MediaImage, {
179
+ src: parentSrc,
180
+ size: 48,
181
+ shape: "circle"
182
+ })
183
+ }), /*#__PURE__*/_jsx(DotSymbol, {
184
+ src: dotSrc,
185
+ pin: "bottom-end",
186
+ shape: "square",
187
+ disabled: true,
188
+ children: /*#__PURE__*/_jsx(MediaImage, {
189
+ src: parentSrc,
190
+ size: 48,
191
+ shape: "square"
192
+ })
193
+ }), /*#__PURE__*/_jsx(DotSymbol, {
194
+ src: dotSrc,
195
+ pin: "bottom-end",
196
+ disabled: true,
197
+ children: /*#__PURE__*/_jsx(Spot, {
198
+ appearance: "icon",
199
+ icon: CoinAlert
200
+ })
201
+ })]
202
+ })
203
+ };
163
204
  export const SizeShowcase = {
164
205
  args: {
165
206
  src: dotSrc,