@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.
- package/dist/module/lib/Animations/Pulse/Pulse.mdx +1 -1
- package/dist/module/lib/Animations/Spin/Spin.mdx +1 -1
- package/dist/module/lib/Components/AddressInput/AddressInput.mdx +1 -1
- package/dist/module/lib/Components/AmountDisplay/AmountDisplay.js +68 -39
- package/dist/module/lib/Components/AmountDisplay/AmountDisplay.js.map +1 -1
- package/dist/module/lib/Components/AmountDisplay/AmountDisplay.mdx +7 -1
- package/dist/module/lib/Components/AmountDisplay/AmountDisplay.stories.js +24 -0
- package/dist/module/lib/Components/AmountDisplay/AmountDisplay.stories.js.map +1 -1
- package/dist/module/lib/Components/AmountDisplay/types.js.map +1 -1
- package/dist/module/lib/Components/AmountInput/AmountInput.mdx +1 -1
- package/dist/module/lib/Components/Avatar/Avatar.mdx +1 -1
- package/dist/module/lib/Components/Banner/Banner.mdx +1 -1
- package/dist/module/lib/Components/BottomSheet/BottomSheet.mdx +1 -1
- package/dist/module/lib/Components/Button/Button.mdx +1 -1
- package/dist/module/lib/Components/Card/Card.stories.js +4 -9
- package/dist/module/lib/Components/Card/Card.stories.js.map +1 -1
- package/dist/module/lib/Components/CardButton/CardButton.mdx +1 -1
- package/dist/module/lib/Components/Checkbox/Checkbox.mdx +1 -1
- package/dist/module/lib/Components/Divider/Divider.mdx +1 -1
- package/dist/module/lib/Components/DotIcon/DotIcon.js +44 -23
- package/dist/module/lib/Components/DotIcon/DotIcon.js.map +1 -1
- package/dist/module/lib/Components/DotIcon/DotIcon.mdx +92 -0
- package/dist/module/lib/Components/DotIcon/DotIcon.stories.js +47 -0
- package/dist/module/lib/Components/DotIcon/DotIcon.stories.js.map +1 -1
- package/dist/module/lib/Components/DotSymbol/DotSymbol.js +52 -30
- package/dist/module/lib/Components/DotSymbol/DotSymbol.js.map +1 -1
- package/dist/module/lib/Components/DotSymbol/DotSymbol.mdx +79 -2
- package/dist/module/lib/Components/DotSymbol/DotSymbol.stories.js +41 -0
- package/dist/module/lib/Components/DotSymbol/DotSymbol.stories.js.map +1 -1
- package/dist/module/lib/Components/IconButton/IconButton.mdx +1 -1
- package/dist/module/lib/Components/InteractiveIcon/InteractiveIcon.mdx +1 -1
- package/dist/module/lib/Components/Link/Link.mdx +1 -1
- package/dist/module/lib/Components/MediaBanner/MediaBanner.mdx +1 -1
- package/dist/module/lib/Components/MediaButton/MediaButton.js +17 -17
- package/dist/module/lib/Components/MediaButton/MediaButton.js.map +1 -1
- package/dist/module/lib/Components/MediaButton/MediaButton.mdx +3 -3
- package/dist/module/lib/Components/MediaButton/MediaButton.stories.js +17 -17
- package/dist/module/lib/Components/MediaButton/MediaButton.stories.js.map +1 -1
- package/dist/module/lib/Components/MediaButton/MediaButton.test.js +4 -4
- package/dist/module/lib/Components/MediaButton/MediaButton.test.js.map +1 -1
- package/dist/module/lib/Components/MediaImage/MediaImage.js +20 -4
- package/dist/module/lib/Components/MediaImage/MediaImage.js.map +1 -1
- package/dist/module/lib/Components/MediaImage/MediaImage.stories.js +35 -0
- package/dist/module/lib/Components/MediaImage/MediaImage.stories.js.map +1 -1
- package/dist/module/lib/Components/NavBar/CoinCapsule.js +2 -2
- package/dist/module/lib/Components/NavBar/CoinCapsule.js.map +1 -1
- package/dist/module/lib/Components/NavBar/NavBar.js +2 -2
- package/dist/module/lib/Components/NavBar/NavBar.js.map +1 -1
- package/dist/module/lib/Components/NavBar/NavBar.mdx +2 -2
- package/dist/module/lib/Components/NavBar/NavBar.stories.js +1 -1
- package/dist/module/lib/Components/NavBar/NavBar.stories.js.map +1 -1
- package/dist/module/lib/Components/NavBar/NavBar.test.js +3 -3
- package/dist/module/lib/Components/NavBar/NavBar.test.js.map +1 -1
- package/dist/module/lib/Components/OptionList/OptionList.stories.js +4 -4
- package/dist/module/lib/Components/OptionList/OptionList.stories.js.map +1 -1
- package/dist/module/lib/Components/PageIndicator/PageIndicator.js +13 -8
- package/dist/module/lib/Components/PageIndicator/PageIndicator.js.map +1 -1
- package/dist/module/lib/Components/PageIndicator/PageIndicator.test.js +58 -0
- package/dist/module/lib/Components/PageIndicator/PageIndicator.test.js.map +1 -1
- package/dist/module/lib/Components/SearchInput/SearchInput.mdx +1 -1
- package/dist/module/lib/Components/SegmentedControl/SegmentedControl.mdx +1 -1
- package/dist/module/lib/Components/Select/Select.mdx +1 -1
- package/dist/module/lib/Components/Spinner/Spinner.mdx +1 -1
- package/dist/module/lib/Components/Spot/Spot.mdx +1 -1
- package/dist/module/lib/Components/Stepper/Stepper.mdx +1 -1
- package/dist/module/lib/Components/Subheader/Subheader.mdx +1 -1
- package/dist/module/lib/Components/Switch/Switch.mdx +1 -1
- package/dist/module/lib/Components/TabBar/TabBar.mdx +1 -1
- package/dist/module/lib/Components/TextInput/TextInput.mdx +1 -1
- package/dist/module/lib/Components/Tile/Tile.mdx +1 -1
- package/dist/module/lib/Components/Tooltip/Tooltip.mdx +1 -1
- package/dist/typescript/src/lib/Components/AmountDisplay/AmountDisplay.d.ts +1 -1
- package/dist/typescript/src/lib/Components/AmountDisplay/AmountDisplay.d.ts.map +1 -1
- package/dist/typescript/src/lib/Components/AmountDisplay/index.d.ts +1 -1
- package/dist/typescript/src/lib/Components/AmountDisplay/index.d.ts.map +1 -1
- package/dist/typescript/src/lib/Components/AmountDisplay/types.d.ts +10 -3
- package/dist/typescript/src/lib/Components/AmountDisplay/types.d.ts.map +1 -1
- package/dist/typescript/src/lib/Components/DotIcon/DotIcon.d.ts +1 -1
- package/dist/typescript/src/lib/Components/DotIcon/DotIcon.d.ts.map +1 -1
- package/dist/typescript/src/lib/Components/DotIcon/types.d.ts +6 -0
- package/dist/typescript/src/lib/Components/DotIcon/types.d.ts.map +1 -1
- package/dist/typescript/src/lib/Components/DotSymbol/DotSymbol.d.ts +1 -1
- package/dist/typescript/src/lib/Components/DotSymbol/DotSymbol.d.ts.map +1 -1
- package/dist/typescript/src/lib/Components/DotSymbol/types.d.ts +6 -0
- package/dist/typescript/src/lib/Components/DotSymbol/types.d.ts.map +1 -1
- package/dist/typescript/src/lib/Components/MediaButton/MediaButton.d.ts +3 -3
- package/dist/typescript/src/lib/Components/MediaButton/MediaButton.d.ts.map +1 -1
- package/dist/typescript/src/lib/Components/MediaButton/types.d.ts +6 -6
- package/dist/typescript/src/lib/Components/MediaButton/types.d.ts.map +1 -1
- package/dist/typescript/src/lib/Components/MediaImage/MediaImage.d.ts +1 -1
- package/dist/typescript/src/lib/Components/MediaImage/MediaImage.d.ts.map +1 -1
- package/dist/typescript/src/lib/Components/MediaImage/types.d.ts +6 -0
- package/dist/typescript/src/lib/Components/MediaImage/types.d.ts.map +1 -1
- package/dist/typescript/src/lib/Components/NavBar/CoinCapsule.d.ts +1 -1
- package/dist/typescript/src/lib/Components/NavBar/CoinCapsule.d.ts.map +1 -1
- package/dist/typescript/src/lib/Components/NavBar/NavBar.d.ts +1 -1
- package/dist/typescript/src/lib/Components/NavBar/NavBar.d.ts.map +1 -1
- package/dist/typescript/src/lib/Components/NavBar/types.d.ts +3 -3
- package/dist/typescript/src/lib/Components/NavBar/types.d.ts.map +1 -1
- package/dist/typescript/src/lib/Components/PageIndicator/PageIndicator.d.ts.map +1 -1
- package/package.json +3 -3
- package/src/lib/Animations/Pulse/Pulse.mdx +1 -1
- package/src/lib/Animations/Spin/Spin.mdx +1 -1
- package/src/lib/Components/AddressInput/AddressInput.mdx +1 -1
- package/src/lib/Components/AmountDisplay/AmountDisplay.mdx +7 -1
- package/src/lib/Components/AmountDisplay/AmountDisplay.stories.tsx +18 -0
- package/src/lib/Components/AmountDisplay/AmountDisplay.tsx +71 -40
- package/src/lib/Components/AmountDisplay/index.ts +5 -1
- package/src/lib/Components/AmountDisplay/types.ts +12 -3
- package/src/lib/Components/AmountInput/AmountInput.mdx +1 -1
- package/src/lib/Components/Avatar/Avatar.mdx +1 -1
- package/src/lib/Components/Banner/Banner.mdx +1 -1
- package/src/lib/Components/BottomSheet/BottomSheet.mdx +1 -1
- package/src/lib/Components/Button/Button.mdx +1 -1
- package/src/lib/Components/Card/Card.stories.tsx +1 -3
- package/src/lib/Components/CardButton/CardButton.mdx +1 -1
- package/src/lib/Components/Checkbox/Checkbox.mdx +1 -1
- package/src/lib/Components/Divider/Divider.mdx +1 -1
- package/src/lib/Components/DotIcon/DotIcon.mdx +92 -0
- package/src/lib/Components/DotIcon/DotIcon.stories.tsx +35 -0
- package/src/lib/Components/DotIcon/DotIcon.tsx +31 -14
- package/src/lib/Components/DotIcon/types.ts +6 -0
- package/src/lib/Components/DotSymbol/DotSymbol.mdx +79 -2
- package/src/lib/Components/DotSymbol/DotSymbol.stories.tsx +17 -0
- package/src/lib/Components/DotSymbol/DotSymbol.tsx +42 -24
- package/src/lib/Components/DotSymbol/types.ts +6 -0
- package/src/lib/Components/IconButton/IconButton.mdx +1 -1
- package/src/lib/Components/InteractiveIcon/InteractiveIcon.mdx +1 -1
- package/src/lib/Components/Link/Link.mdx +1 -1
- package/src/lib/Components/MediaBanner/MediaBanner.mdx +1 -1
- package/src/lib/Components/MediaButton/MediaButton.mdx +3 -3
- package/src/lib/Components/MediaButton/MediaButton.stories.tsx +29 -15
- package/src/lib/Components/MediaButton/MediaButton.test.tsx +4 -4
- package/src/lib/Components/MediaButton/MediaButton.tsx +33 -20
- package/src/lib/Components/MediaButton/types.ts +6 -6
- package/src/lib/Components/MediaImage/MediaImage.stories.tsx +18 -0
- package/src/lib/Components/MediaImage/MediaImage.tsx +12 -2
- package/src/lib/Components/MediaImage/types.ts +6 -0
- package/src/lib/Components/NavBar/CoinCapsule.tsx +2 -2
- package/src/lib/Components/NavBar/NavBar.mdx +2 -2
- package/src/lib/Components/NavBar/NavBar.stories.tsx +3 -1
- package/src/lib/Components/NavBar/NavBar.test.tsx +3 -3
- package/src/lib/Components/NavBar/NavBar.tsx +2 -2
- package/src/lib/Components/NavBar/types.ts +3 -3
- package/src/lib/Components/OptionList/OptionList.stories.tsx +4 -4
- package/src/lib/Components/PageIndicator/PageIndicator.test.tsx +78 -0
- package/src/lib/Components/PageIndicator/PageIndicator.tsx +15 -7
- package/src/lib/Components/SearchInput/SearchInput.mdx +1 -1
- package/src/lib/Components/SegmentedControl/SegmentedControl.mdx +1 -1
- package/src/lib/Components/Select/Select.mdx +1 -1
- package/src/lib/Components/Spinner/Spinner.mdx +1 -1
- package/src/lib/Components/Spot/Spot.mdx +1 -1
- package/src/lib/Components/Stepper/Stepper.mdx +1 -1
- package/src/lib/Components/Subheader/Subheader.mdx +1 -1
- package/src/lib/Components/Switch/Switch.mdx +1 -1
- package/src/lib/Components/TabBar/TabBar.mdx +1 -1
- package/src/lib/Components/TextInput/TextInput.mdx +1 -1
- package/src/lib/Components/Tile/Tile.mdx +1 -1
- package/src/lib/Components/Tooltip/Tooltip.mdx +1 -1
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
import {
|
|
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(
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
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
|
-
|
|
123
|
-
|
|
124
|
-
style:
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
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":["
|
|
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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
|
|
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
|
|
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(
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
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
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
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","
|
|
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":";;AAAA,SACEA,gBAAgB,EAChBC,kBAAkB,QACb,8BAA8B;AACrC,SAASC,SAAS,EAAEC,QAAQ,QAAQ,OAAO;AAC3C,SAASC,KAAK,QAAQ,cAAc;AACpC,SAASC,aAAa,QAAQ,0BAAiB;AAG/C,SAASC,GAAG,QAAQ,qBAAY;AAAC,SAAAC,GAAA,IAAAC,IAAA,EAAAC,IAAA,IAAAC,KAAA;AAGjC,MAAMC,kBAAiD,GAAG;EACxD,CAAC,EAAE,CAAC;EACJ,EAAE,EAAE,CAAC;EACL,EAAE,EAAE,CAAC;EACL,EAAE,EAAE,CAAC;EACL,EAAE,EAAE,CAAC;EACL,EAAE,EAAE;AACN,CAAC;AAED,MAAMC,YAA2C,GAAG;EAClD,CAAC,EAAE,CAAC,CAAC;EACL,EAAE,EAAE,CAAC,CAAC;EACN,EAAE,EAAE,CAAC,CAAC;EACN,EAAE,EAAE,CAAC,CAAC;EACN,EAAE,EAAE,CAAC,CAAC;EACN,EAAE,EAAE,CAAC;AACP,CAAC;AAED,OAAO,MAAMC,oBAA2D,GAAG;EACzE,EAAE,EAAE,CAAC;EACL,EAAE,EAAE,CAAC;EACL,EAAE,EAAE,CAAC;EACL,EAAE,EAAE,EAAE;EACN,EAAE,EAAE,EAAE;EACN,EAAE,EAAE,EAAE;EACN,EAAE,EAAE,EAAE;EACN,EAAE,EAAE,EAAE;EACN,EAAE,EAAE;AACN,CAAC;AAED,OAAO,MAAMC,cAA+C,GAAG;EAC7D,EAAE,EAAE,EAAE;EACN,EAAE,EAAE,EAAE;EACN,EAAE,EAAE,EAAE;EACN,EAAE,EAAE,EAAE;EACN,EAAE,EAAE;AACN,CAAC;AAED,MAAMC,UAAwE,GAC5E;EACE,WAAW,EAAE,CAAC,KAAK,EAAE,MAAM,CAAC;EAC5B,SAAS,EAAE,CAAC,KAAK,EAAE,OAAO,CAAC;EAC3B,cAAc,EAAE,CAAC,QAAQ,EAAE,MAAM,CAAC;EAClC,YAAY,EAAE,CAAC,QAAQ,EAAE,OAAO;AAClC,CAAC;AAEH,MAAMC,YAAY,GAAGA,CACnBC,GAAiB,EACjBC,IAAmB,KACQ;EAC3B,MAAM,CAACC,CAAC,EAAEC,CAAC,CAAC,GAAGL,UAAU,CAACE,GAAG,CAAC;EAC9B,MAAMI,MAAM,GAAGT,YAAY,CAACM,IAAI,CAAC;EACjC,OAAO;IAAE,CAACC,CAAC,GAAGE,MAAM;IAAE,CAACD,CAAC,GAAGC;EAAO,CAAC;AACrC,CAAC;AAED,MAAMC,SAAS,GAAGA,CAAC;EACjBJ,IAAI;EACJK,KAAK;EACLN,GAAG;EACHO;AAMF,CAAC,KAAK;EACJ,OAAOnB,aAAa,CACjBoB,CAAC,IAAK;IACL,MAAMC,SAAS,GAAGD,CAAC,CAACE,KAAK,CAAC,IAAIT,IAAI,EAAE,CAAmC;IACvE,MAAMU,MAAM,GACVL,KAAK,KAAK,QAAQ,GAAGE,CAAC,CAACI,YAAY,CAACC,IAAI,GAAGnB,kBAAkB,CAACO,IAAI,CAAC;IACrE,MAAMa,SAAS,GAAGf,YAAY,CAACC,GAAG,EAAEC,IAAI,CAAC;IAEzC,OAAO;MACLc,IAAI,EAAE;QACJC,QAAQ,EAAE,UAAU;QACpB,IAAIT,QAAQ,IAAI;UAAEU,OAAO,EAAE;QAAI,CAAC;MAClC,CAAC;MACDC,GAAG,EAAE;QACHF,QAAQ,EAAE,UAAU;QACpBG,MAAM,EAAE,EAAE;QACVC,KAAK,EAAEX,SAAS;QAChBY,MAAM,EAAEZ,SAAS;QACjBG,YAAY,EAAED,MAAM;QACpBW,WAAW,EAAE,CAAC;QACdC,eAAe,EAAEf,CAAC,CAACgB,MAAM,CAACC,EAAE,CAACC,KAAK;QAClCC,WAAW,EAAEnB,CAAC,CAACgB,MAAM,CAACI,MAAM,CAACC,YAAY;QACzCC,QAAQ,EAAE,QAAQ;QAClB,GAAGhB;MACL,CAAC;MACDiB,KAAK,EAAE;QACLX,KAAK,EAAE,MAAM;QACbC,MAAM,EAAE;MACV;IACF,CAAC;EACH,CAAC,EACD,CAACpB,IAAI,EAAEK,KAAK,EAAEN,GAAG,EAAEO,QAAQ,CAC7B,CAAC;AACH,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,MAAMyB,SAAS,GAAGA,CAAC;EACxBC,QAAQ;EACRC,GAAG;EACHC,GAAG;EACHnC,GAAG,GAAG,YAAY;EAClBC,IAAI,GAAG,EAAE;EACTK,KAAK,GAAG,QAAQ;EAChBC,QAAQ,EAAE6B,YAAY,GAAG,KAAK;EAC9BC,EAAE,GAAG,CAAC,CAAC;EACPC,KAAK;EACLC,GAAG;EACH,GAAGC;AACW,CAAC,KAAK;EACpB,MAAM,CAACC,KAAK,EAAEC,QAAQ,CAAC,GAAGxD,QAAQ,CAAC,KAAK,CAAC;EACzC,MAAMqB,QAAQ,GAAGvB,kBAAkB,CAAC;IAClC2D,YAAY,EAAE,WAAW;IACzBC,SAAS,EAAE;MAAErC,QAAQ,EAAE6B;IAAa;EACtC,CAAC,CAAC;EACF,MAAMS,MAAM,GAAGxC,SAAS,CAAC;IAAEJ,IAAI;IAAEK,KAAK;IAAEN,GAAG;IAAEO;EAAS,CAAC,CAAC;EAExDtB,SAAS,CAAC,MAAM;IACdyD,QAAQ,CAAC,KAAK,CAAC;EACjB,CAAC,EAAE,CAACR,GAAG,CAAC,CAAC;EAET,oBACE3C,IAAA,CAACR,gBAAgB;IAAC+D,KAAK,EAAE;MAAEvC,QAAQ,EAAE;IAAM,CAAE;IAAA0B,QAAA,eAC3C1C,IAAA,CAACF,GAAG;MACFkD,GAAG,EAAEA,GAAI;MACTF,EAAE,EAAEA,EAAG;MACPC,KAAK,EAAE,CAACO,MAAM,CAAC9B,IAAI,EAAEuB,KAAK,CAAE;MAC5BS,iBAAiB,EAAC,OAAO;MACzBC,kBAAkB,EAAEb,GAAI;MACxBc,kBAAkB,EAAE;QAAE1C;MAAS,CAAE;MAAA,GAC7BiC,IAAI;MAAAP,QAAA,eAERxC,KAAA,CAACJ,GAAG;QAACiD,KAAK,EAAE;UAAEY,SAAS,EAAE,YAAY;UAAElC,QAAQ,EAAE;QAAW,CAAE;QAAAiB,QAAA,GAC3DA,QAAQ,eACT1C,IAAA,CAACF,GAAG;UAACiD,KAAK,EAAEO,MAAM,CAAC3B,GAAI;UAAAe,QAAA,EACpB,CAACQ,KAAK,iBACLlD,IAAA,CAACJ,KAAK;YACJgE,MAAM,EAAE;cAAEC,GAAG,EAAElB;YAAI,CAAE;YACrBI,KAAK,EAAEO,MAAM,CAACd,KAAM;YACpBsB,UAAU,EAAE,KAAM;YAClBC,OAAO,EAAEA,CAAA,KAAMZ,QAAQ,CAAC,IAAI,CAAE;YAC9Ba,MAAM,EAAC;UAAgB,CACxB;QACF,CACE,CAAC;MAAA,CACH;IAAC,CACH;EAAC,CACU,CAAC;AAEvB,CAAC;AAEDvB,SAAS,CAACwB,WAAW,GAAG,WAAW","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,
|