@edvisor/product-language 0.1.1 → 0.3.0
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/.babelrc +12 -0
- package/.eslintrc.json +147 -0
- package/.storybook/main.js +57 -0
- package/.storybook/manager.js +7 -0
- package/.storybook/preview.js +15 -0
- package/.storybook/tsconfig.json +30 -0
- package/jest.config.ts +15 -0
- package/jest.setup.ts +2 -0
- package/package.json +21 -10
- package/project.json +96 -0
- package/src/README.md +61 -0
- package/src/assets/svg/example_icon.svg +3 -0
- package/src/assets/svg/example_icon_white.svg +3 -0
- package/src/assets/svg/spinner.svg +3 -0
- package/src/assets/svg/spinner_white.svg +3 -0
- package/src/helpers/index.ts +4 -0
- package/src/helpers/playground.ts +16 -0
- package/src/helpers/talesOf.tsx +42 -0
- package/src/index.ts +2 -0
- package/src/lib/components/README.md +49 -0
- package/src/lib/components/alert-banner/alert-banner.tsx +34 -0
- package/src/lib/components/alert-banner/alert-level-flags.ts +77 -0
- package/src/lib/components/alert-banner/index.ts +1 -0
- package/src/lib/components/badge/badge-type-flags.ts +72 -0
- package/src/lib/components/badge/badge.test.tsx +29 -0
- package/src/lib/components/badge/badge.tsx +22 -0
- package/src/lib/components/badge/index.ts +1 -0
- package/src/lib/components/badge/stories/badge.stories.mdx +44 -0
- package/src/lib/components/badge/stories/components.tsx +49 -0
- package/{lib/components/card/atoms/card-frame.d.ts → src/lib/components/card/atoms/card-frame.tsx} +17 -7
- package/src/lib/components/card/atoms/index.ts +1 -0
- package/src/lib/components/card/card.test.tsx +162 -0
- package/src/lib/components/card/card.tsx +78 -0
- package/src/lib/components/card/components/card-alert-banner-slot.tsx +16 -0
- package/src/lib/components/card/components/card-controls-slot.tsx +19 -0
- package/src/lib/components/card/components/card-section-slot.tsx +51 -0
- package/src/lib/components/card/components/index.ts +3 -0
- package/src/lib/components/card/index.ts +2 -0
- package/src/lib/components/card/molecules/index.ts +1 -0
- package/src/lib/components/card/molecules/left-right-card.test.tsx +89 -0
- package/src/lib/components/card/molecules/left-right-card.tsx +63 -0
- package/src/lib/components/card/storybook/card.stories.mdx +100 -0
- package/src/lib/components/card/storybook/components.tsx +223 -0
- package/src/lib/components/checkbox/checkbox.test.tsx +39 -0
- package/src/lib/components/checkbox/checkbox.tsx +63 -0
- package/src/lib/components/checkbox/helpers.tsx +100 -0
- package/src/lib/components/checkbox/index.tsx +1 -0
- package/src/lib/components/checkbox/stories/checkbox.stories.mdx +57 -0
- package/src/lib/components/checkbox/stories/components.tsx +84 -0
- package/src/lib/components/divider/divider-type-flags.tsx +37 -0
- package/src/lib/components/divider/divider.test.tsx +34 -0
- package/src/lib/components/divider/divider.tsx +37 -0
- package/src/lib/components/divider/index.tsx +1 -0
- package/src/lib/components/divider/stories/components.tsx +13 -0
- package/src/lib/components/divider/stories/divider.stories.mdx +44 -0
- package/src/lib/components/flag/flag-size-flags.tsx +55 -0
- package/src/lib/components/flag/flag.list.tsx +788 -0
- package/src/lib/components/flag/flag.test.tsx +65 -0
- package/src/lib/components/flag/flag.tsx +97 -0
- package/src/lib/components/flag/index.tsx +1 -0
- package/src/lib/components/flag/stories/components.tsx +403 -0
- package/src/lib/components/flag/stories/flag.stories.mdx +48 -0
- package/src/lib/components/flag/stories/playGround-select.tsx +145 -0
- package/src/lib/components/icon/icon-list.tsx +135 -0
- package/src/lib/components/icon/icon.test.tsx +48 -0
- package/src/lib/components/icon/icon.tsx +181 -0
- package/src/lib/components/icon/index.tsx +1 -0
- package/src/lib/components/icon/stories/components.tsx +282 -0
- package/src/lib/components/icon/stories/icon.stories.mdx +65 -0
- package/src/lib/components/index.ts +19 -0
- package/src/lib/components/input-field/components/index.ts +2 -0
- package/src/lib/components/input-field/components/labeled-input.tsx +54 -0
- package/src/lib/components/input-field/components/stepper.tsx +60 -0
- package/src/lib/components/input-field/index.ts +6 -0
- package/src/lib/components/input-field/input-field.test.tsx +107 -0
- package/src/lib/components/input-field/input-field.tsx +126 -0
- package/src/lib/components/input-field/input-number.tsx +41 -0
- package/src/lib/components/input-field/input-text.tsx +30 -0
- package/src/lib/components/input-field/storybook/components.tsx +327 -0
- package/src/lib/components/input-field/storybook/input-field.stories.mdx +113 -0
- package/src/lib/components/layout/flex.tsx +22 -0
- package/src/lib/components/layout/grid-layout.tsx +40 -0
- package/src/lib/components/layout/index.ts +3 -0
- package/src/lib/components/layout/left-right-layout.tsx +67 -0
- package/src/lib/components/link/index.ts +1 -0
- package/src/lib/components/link/link.test.tsx +29 -0
- package/src/lib/components/link/link.tsx +56 -0
- package/src/lib/components/link/storybook/link.stories.mdx +52 -0
- package/src/lib/components/molecules/avatar/avatar-size-flags.tsx +55 -0
- package/src/lib/components/molecules/avatar/avatar.test.tsx +114 -0
- package/src/lib/components/molecules/avatar/avatar.tsx +80 -0
- package/src/lib/components/molecules/avatar/index.tsx +1 -0
- package/src/lib/components/molecules/avatar/stories/avatar.stories.mdx +52 -0
- package/src/lib/components/molecules/avatar/stories/components.tsx +36 -0
- package/src/lib/components/molecules/button/button-flags.tsx +340 -0
- package/src/lib/components/molecules/button/button.test.tsx +77 -0
- package/src/lib/components/molecules/button/button.tsx +214 -0
- package/src/lib/components/molecules/button/index.tsx +1 -0
- package/src/lib/components/molecules/button/stories/button.stories.mdx +105 -0
- package/src/lib/components/molecules/button/stories/components.tsx +84 -0
- package/src/lib/components/molecules/index.ts +3 -0
- package/src/lib/components/molecules/input-checkbox/index.tsx +1 -0
- package/src/lib/components/molecules/input-checkbox/input-checkbox.test.tsx +34 -0
- package/src/lib/components/molecules/input-checkbox/input-checkbox.tsx +49 -0
- package/src/lib/components/molecules/input-checkbox/stories/components.tsx +53 -0
- package/src/lib/components/molecules/input-checkbox/stories/input-checkbox.stories.mdx +49 -0
- package/src/lib/components/organisms/index.ts +1 -0
- package/src/lib/components/organisms/multi-choice-list/index.tsx +1 -0
- package/src/lib/components/organisms/multi-choice-list/multi-choice-list.test.tsx +33 -0
- package/src/lib/components/organisms/multi-choice-list/multi-choice-list.tsx +52 -0
- package/src/lib/components/organisms/multi-choice-list/stories/components.tsx +124 -0
- package/src/lib/components/organisms/multi-choice-list/stories/multi-choice-list.stories.mdx +99 -0
- package/src/lib/components/spinner/index.tsx +1 -0
- package/src/lib/components/spinner/spinner-size-flags.tsx +39 -0
- package/src/lib/components/spinner/spinner.test.tsx +31 -0
- package/src/lib/components/spinner/spinner.tsx +54 -0
- package/src/lib/components/spinner/stories/components.tsx +39 -0
- package/src/lib/components/spinner/stories/spinner.stories.mdx +35 -0
- package/src/lib/components/tabs/components/index.ts +1 -0
- package/src/lib/components/tabs/components/tab.tsx +62 -0
- package/src/lib/components/tabs/index.tsx +1 -0
- package/src/lib/components/tabs/storybook/components.tsx +282 -0
- package/src/lib/components/tabs/storybook/tabs.stories.mdx +97 -0
- package/src/lib/components/tabs/tabs.test.tsx +86 -0
- package/src/lib/components/tabs/tabs.tsx +101 -0
- package/src/lib/components/tag/components/close-button.tsx +85 -0
- package/src/lib/components/tag/components/index.ts +2 -0
- package/src/lib/components/tag/components/tag-label.tsx +44 -0
- package/src/lib/components/tag/index.tsx +1 -0
- package/src/lib/components/tag/stories/components.tsx +86 -0
- package/src/lib/components/tag/stories/tag.stories.mdx +42 -0
- package/src/lib/components/tag/tag.test.tsx +36 -0
- package/src/lib/components/tag/tag.tsx +33 -0
- package/src/lib/components/thumbnail/index.tsx +1 -0
- package/src/lib/components/thumbnail/stories/thumbnail.stories.mdx +34 -0
- package/src/lib/components/thumbnail/thumbnail-size-flags.tsx +41 -0
- package/src/lib/components/thumbnail/thumbnail.test.tsx +51 -0
- package/src/lib/components/thumbnail/thumbnail.tsx +45 -0
- package/src/lib/components/typography/index.ts +1 -0
- package/src/lib/components/typography/storybook/components.tsx +288 -0
- package/src/lib/components/typography/storybook/typography.stories.mdx +90 -0
- package/src/lib/components/typography/typography.test.tsx +97 -0
- package/src/lib/components/typography/typography.tsx +99 -0
- package/src/lib/foundations/color-system/base-palette/base-palette.stories.tsx +123 -0
- package/src/lib/foundations/color-system/base-palette/base-palette.ts +93 -0
- package/src/lib/foundations/color-system/base-palette/index.ts +1 -0
- package/src/lib/foundations/color-system/color-guidelines/color-guidelines.stories.mdx +85 -0
- package/src/lib/foundations/color-system/color-guidelines/color-guidelines.stories.tsx +231 -0
- package/src/lib/foundations/color-system/color-guidelines/color-guidelines.ts +160 -0
- package/src/lib/foundations/color-system/color-guidelines/index.ts +1 -0
- package/src/lib/foundations/color-system/components/color-sample.tsx +99 -0
- package/src/lib/foundations/color-system/components/index.ts +1 -0
- package/src/lib/foundations/color-system/index.ts +1 -0
- package/src/lib/foundations/index.ts +4 -0
- package/src/lib/foundations/shadows/components.tsx +59 -0
- package/src/lib/foundations/shadows/index.ts +1 -0
- package/src/lib/foundations/shadows/shadows.stories.mdx +71 -0
- package/src/lib/foundations/shadows/shadows.tsx +47 -0
- package/src/lib/foundations/spacing/index.ts +1 -0
- package/src/lib/foundations/spacing/spacing-guidelines.ts +24 -0
- package/src/lib/foundations/spacing/spacing.stories.mdx +51 -0
- package/src/lib/foundations/spacing/spacing.ts +18 -0
- package/src/lib/foundations/typography/constants.ts +25 -0
- package/src/lib/foundations/typography/fonts.ts +205 -0
- package/src/lib/foundations/typography/index.tsx +1 -0
- package/src/lib/foundations/typography/text-aspect-flags.ts +61 -0
- package/src/lib/foundations/typography/typography.tsx +102 -0
- package/src/lib/helpers/generic-types.ts +44 -0
- package/src/lib/helpers/index.ts +6 -0
- package/src/lib/helpers/nothing.tsx +18 -0
- package/src/lib/helpers/numbers.ts +67 -0
- package/src/lib/helpers/safe-navigation.ts +44 -0
- package/src/lib/helpers/slots.test.tsx +98 -0
- package/src/lib/helpers/slots.tsx +157 -0
- package/src/lib/helpers/strings.test.ts +47 -0
- package/src/lib/helpers/strings.ts +16 -0
- package/tsconfig.json +35 -0
- package/tsconfig.lib.json +28 -0
- package/tsconfig.spec.json +21 -0
- package/index.d.ts +0 -2
- package/index.js +0 -6078
- package/lib/components/alert-banner/alert-banner.d.ts +0 -11
- package/lib/components/alert-banner/alert-level-flags.d.ts +0 -13
- package/lib/components/alert-banner/index.d.ts +0 -1
- package/lib/components/badge/badge-type-flags.d.ts +0 -18
- package/lib/components/badge/badge.d.ts +0 -5
- package/lib/components/badge/index.d.ts +0 -1
- package/lib/components/card/atoms/index.d.ts +0 -1
- package/lib/components/card/card.d.ts +0 -14
- package/lib/components/card/components/card-alert-banner-slot.d.ts +0 -5
- package/lib/components/card/components/card-controls-slot.d.ts +0 -4
- package/lib/components/card/components/card-section-slot.d.ts +0 -11
- package/lib/components/card/components/index.d.ts +0 -3
- package/lib/components/card/index.d.ts +0 -2
- package/lib/components/card/molecules/index.d.ts +0 -1
- package/lib/components/card/molecules/left-right-card.d.ts +0 -16
- package/lib/components/checkbox/checkbox.d.ts +0 -11
- package/lib/components/checkbox/components/components.d.ts +0 -12
- package/lib/components/checkbox/index.d.ts +0 -1
- package/lib/components/divider/divider-type-flags.d.ts +0 -9
- package/lib/components/divider/divider.d.ts +0 -7
- package/lib/components/divider/index.d.ts +0 -1
- package/lib/components/index.d.ts +0 -12
- package/lib/components/input-field/components/index.d.ts +0 -2
- package/lib/components/input-field/components/labeled-input.d.ts +0 -11
- package/lib/components/input-field/components/stepper.d.ts +0 -7
- package/lib/components/input-field/index.d.ts +0 -3
- package/lib/components/input-field/input-field.d.ts +0 -25
- package/lib/components/input-field/input-number.d.ts +0 -18
- package/lib/components/input-field/input-text.d.ts +0 -14
- package/lib/components/layout/flex.d.ts +0 -16
- package/lib/components/layout/grid-layout.d.ts +0 -11
- package/lib/components/layout/index.d.ts +0 -3
- package/lib/components/layout/left-right-layout.d.ts +0 -70
- package/lib/components/link/index.d.ts +0 -1
- package/lib/components/link/link.d.ts +0 -14
- package/lib/components/molecules/avatar/avatar-size-flags.d.ts +0 -12
- package/lib/components/molecules/avatar/avatar.d.ts +0 -12
- package/lib/components/molecules/avatar/index.d.ts +0 -1
- package/lib/components/molecules/button/button-flags.d.ts +0 -39
- package/lib/components/molecules/button/button.d.ts +0 -24
- package/lib/components/molecules/button/index.d.ts +0 -1
- package/lib/components/molecules/index.d.ts +0 -3
- package/lib/components/molecules/input-checkbox/index.d.ts +0 -1
- package/lib/components/molecules/input-checkbox/input-checkbox.d.ts +0 -8
- package/lib/components/organisms/index.d.ts +0 -1
- package/lib/components/organisms/multi-choice-list/index.d.ts +0 -1
- package/lib/components/organisms/multi-choice-list/multi-choice-list.d.ts +0 -11
- package/lib/components/spinner/index.d.ts +0 -1
- package/lib/components/spinner/spinner-size-flags.d.ts +0 -10
- package/lib/components/spinner/spinner.d.ts +0 -9
- package/lib/components/thumbnail/index.d.ts +0 -1
- package/lib/components/thumbnail/thumbnail-size-flags.d.ts +0 -10
- package/lib/components/thumbnail/thumbnail.d.ts +0 -9
- package/lib/components/typography/index.d.ts +0 -1
- package/lib/components/typography/typography.d.ts +0 -23
- package/lib/foundations/color-system/base-palette/base-palette.d.ts +0 -77
- package/lib/foundations/color-system/base-palette/index.d.ts +0 -1
- package/lib/foundations/color-system/color-guidelines/color-guidelines.d.ts +0 -131
- package/lib/foundations/color-system/color-guidelines/index.d.ts +0 -1
- package/lib/foundations/color-system/components/color-sample.d.ts +0 -17
- package/lib/foundations/color-system/components/index.d.ts +0 -1
- package/lib/foundations/color-system/index.d.ts +0 -1
- package/lib/foundations/index.d.ts +0 -4
- package/lib/foundations/shadows/components.d.ts +0 -8
- package/lib/foundations/shadows/index.d.ts +0 -1
- package/lib/foundations/shadows/shadows.d.ts +0 -8
- package/lib/foundations/spacing/index.d.ts +0 -1
- package/lib/foundations/spacing/spacing-guidelines.d.ts +0 -22
- package/lib/foundations/spacing/spacing.d.ts +0 -18
- package/lib/foundations/typography/constants.d.ts +0 -22
- package/lib/foundations/typography/index.d.ts +0 -1
- package/lib/foundations/typography/text-aspect-flags.d.ts +0 -14
- package/lib/foundations/typography/typography.d.ts +0 -19
- package/lib/helpers/generic-types.d.ts +0 -21
- package/lib/helpers/index.d.ts +0 -6
- package/lib/helpers/nothing.d.ts +0 -8
- package/lib/helpers/numbers.d.ts +0 -41
- package/lib/helpers/safe-navigation.d.ts +0 -14
- package/lib/helpers/slots.d.ts +0 -8
- package/lib/helpers/strings.d.ts +0 -1
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { Meta, Description } from '@storybook/addon-docs';
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
<Meta title="Foundations/Spacing" />
|
|
5
|
+
|
|
6
|
+
# Spacing System
|
|
7
|
+
|
|
8
|
+
All spacing for components and typography is done in increments of 8 pixels.
|
|
9
|
+
This forms the basic unit of measurement for spacing.
|
|
10
|
+
|
|
11
|
+
For more details, check out the guidelines on [Figma](https://www.figma.com/file/ue1CurHfZ426o2T2l8Dk64/UI-Library-(in-progress)?node-id=388%3A364)
|
|
12
|
+
|
|
13
|
+
## How to use
|
|
14
|
+
|
|
15
|
+
```javascript
|
|
16
|
+
import SPACING from './spacing'
|
|
17
|
+
|
|
18
|
+
//get the token value
|
|
19
|
+
SPACING.[`YOUR-VALUE-HERE`]
|
|
20
|
+
```
|
|
21
|
+
|
|
22
|
+
## When to use
|
|
23
|
+
|
|
24
|
+
You can set this values from this props:
|
|
25
|
+
|
|
26
|
+
- width
|
|
27
|
+
- heigth
|
|
28
|
+
- margin
|
|
29
|
+
- padding
|
|
30
|
+
|
|
31
|
+
|
|
32
|
+
## List of Values
|
|
33
|
+
|
|
34
|
+
| Name | Value |
|
|
35
|
+
| ---- | ----- |
|
|
36
|
+
| `Size2` | 2px|
|
|
37
|
+
| `Size4` | 4px|
|
|
38
|
+
| `Size8` | 8px|
|
|
39
|
+
| `Size12` | 12px|
|
|
40
|
+
| `Size16` | 16px|
|
|
41
|
+
| `Size24` | 24px|
|
|
42
|
+
| `Size32` | 32px|
|
|
43
|
+
| `Size64` | 64px|
|
|
44
|
+
| `Size96` | 96px|
|
|
45
|
+
| `Size128` | 128px|
|
|
46
|
+
| `Size192` | 192px|
|
|
47
|
+
| `Size256` | 256px|
|
|
48
|
+
| `Size384` | 384px|
|
|
49
|
+
| `Size512` | 512px|
|
|
50
|
+
| `Size640` | 640px|
|
|
51
|
+
| `Size768` | 768px|
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export enum SPACING {
|
|
2
|
+
Size2 = '2px',
|
|
3
|
+
Size4 = '4px',
|
|
4
|
+
Size8 = '8px',
|
|
5
|
+
Size12 = '12px',
|
|
6
|
+
Size16 = '16px',
|
|
7
|
+
Size24 = '24px',
|
|
8
|
+
Size32 = '32px',
|
|
9
|
+
Size64 = '64px',
|
|
10
|
+
Size96 = '96px',
|
|
11
|
+
Size128 = '128px',
|
|
12
|
+
Size192 = '192px',
|
|
13
|
+
Size256 = '256px',
|
|
14
|
+
Size384 = '384px',
|
|
15
|
+
Size512 = '512px',
|
|
16
|
+
Size640 = '640px',
|
|
17
|
+
Size768 = '768px',
|
|
18
|
+
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
|
|
2
|
+
export const enum FontWeight {
|
|
3
|
+
Regular = '400',
|
|
4
|
+
Medium = '500',
|
|
5
|
+
SemiBold = '600',
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
export const FontSize = {
|
|
9
|
+
a: '13px',
|
|
10
|
+
b: '14px',
|
|
11
|
+
c: '16px',
|
|
12
|
+
d: '18px',
|
|
13
|
+
e: '20px',
|
|
14
|
+
f: '28px',
|
|
15
|
+
g: '36px',
|
|
16
|
+
} as const
|
|
17
|
+
|
|
18
|
+
export const LineHeight = {
|
|
19
|
+
a: '16px',
|
|
20
|
+
b: '20px',
|
|
21
|
+
c: '24px',
|
|
22
|
+
d: '28px',
|
|
23
|
+
e: '32px',
|
|
24
|
+
f: '44px',
|
|
25
|
+
} as const
|
|
@@ -0,0 +1,205 @@
|
|
|
1
|
+
export const InterFontFace = `
|
|
2
|
+
@font-face {
|
|
3
|
+
font-family: 'Inter';
|
|
4
|
+
font-style: normal;
|
|
5
|
+
font-weight: 300;
|
|
6
|
+
src: url(https://fonts.gstatic.com/s/inter/v12/UcC73FwrK3iLTeHuS_fvQtMwCp50KnMa2JL7W0Q5n-wU.woff2)
|
|
7
|
+
format('woff2');
|
|
8
|
+
unicode-range: U+0460-052F, U+1C80-1C88, U+20B4, U+2DE0-2DFF, U+A640-A69F,
|
|
9
|
+
U+FE2E-FE2F;
|
|
10
|
+
}
|
|
11
|
+
/* cyrillic */
|
|
12
|
+
@font-face {
|
|
13
|
+
font-family: 'Inter';
|
|
14
|
+
font-style: normal;
|
|
15
|
+
font-weight: 300;
|
|
16
|
+
src: url(https://fonts.gstatic.com/s/inter/v12/UcC73FwrK3iLTeHuS_fvQtMwCp50KnMa0ZL7W0Q5n-wU.woff2)
|
|
17
|
+
format('woff2');
|
|
18
|
+
unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
|
|
19
|
+
}
|
|
20
|
+
/* greek-ext */
|
|
21
|
+
@font-face {
|
|
22
|
+
font-family: 'Inter';
|
|
23
|
+
font-style: normal;
|
|
24
|
+
font-weight: 300;
|
|
25
|
+
src: url(https://fonts.gstatic.com/s/inter/v12/UcC73FwrK3iLTeHuS_fvQtMwCp50KnMa2ZL7W0Q5n-wU.woff2)
|
|
26
|
+
format('woff2');
|
|
27
|
+
unicode-range: U+1F00-1FFF;
|
|
28
|
+
}
|
|
29
|
+
/* greek */
|
|
30
|
+
@font-face {
|
|
31
|
+
font-family: 'Inter';
|
|
32
|
+
font-style: normal;
|
|
33
|
+
font-weight: 300;
|
|
34
|
+
src: url(https://fonts.gstatic.com/s/inter/v12/UcC73FwrK3iLTeHuS_fvQtMwCp50KnMa1pL7W0Q5n-wU.woff2)
|
|
35
|
+
format('woff2');
|
|
36
|
+
unicode-range: U+0370-03FF;
|
|
37
|
+
}
|
|
38
|
+
/* vietnamese */
|
|
39
|
+
@font-face {
|
|
40
|
+
font-family: 'Inter';
|
|
41
|
+
font-style: normal;
|
|
42
|
+
font-weight: 300;
|
|
43
|
+
src: url(https://fonts.gstatic.com/s/inter/v12/UcC73FwrK3iLTeHuS_fvQtMwCp50KnMa2pL7W0Q5n-wU.woff2)
|
|
44
|
+
format('woff2');
|
|
45
|
+
unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169,
|
|
46
|
+
U+01A0-01A1, U+01AF-01B0, U+1EA0-1EF9, U+20AB;
|
|
47
|
+
}
|
|
48
|
+
/* latin-ext */
|
|
49
|
+
@font-face {
|
|
50
|
+
font-family: 'Inter';
|
|
51
|
+
font-style: normal;
|
|
52
|
+
font-weight: 300;
|
|
53
|
+
src: url(https://fonts.gstatic.com/s/inter/v12/UcC73FwrK3iLTeHuS_fvQtMwCp50KnMa25L7W0Q5n-wU.woff2)
|
|
54
|
+
format('woff2');
|
|
55
|
+
unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB,
|
|
56
|
+
U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
|
|
57
|
+
}
|
|
58
|
+
/* latin */
|
|
59
|
+
@font-face {
|
|
60
|
+
font-family: 'Inter';
|
|
61
|
+
font-style: normal;
|
|
62
|
+
font-weight: 300;
|
|
63
|
+
src: url(https://fonts.gstatic.com/s/inter/v12/UcC73FwrK3iLTeHuS_fvQtMwCp50KnMa1ZL7W0Q5nw.woff2)
|
|
64
|
+
format('woff2');
|
|
65
|
+
unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA,
|
|
66
|
+
U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212,
|
|
67
|
+
U+2215, U+FEFF, U+FFFD;
|
|
68
|
+
}
|
|
69
|
+
/* cyrillic-ext */
|
|
70
|
+
@font-face {
|
|
71
|
+
font-family: 'Inter';
|
|
72
|
+
font-style: normal;
|
|
73
|
+
font-weight: 400;
|
|
74
|
+
src: url(https://fonts.gstatic.com/s/inter/v12/UcC73FwrK3iLTeHuS_fvQtMwCp50KnMa2JL7W0Q5n-wU.woff2)
|
|
75
|
+
format('woff2');
|
|
76
|
+
unicode-range: U+0460-052F, U+1C80-1C88, U+20B4, U+2DE0-2DFF, U+A640-A69F,
|
|
77
|
+
U+FE2E-FE2F;
|
|
78
|
+
}
|
|
79
|
+
/* cyrillic */
|
|
80
|
+
@font-face {
|
|
81
|
+
font-family: 'Inter';
|
|
82
|
+
font-style: normal;
|
|
83
|
+
font-weight: 400;
|
|
84
|
+
src: url(https://fonts.gstatic.com/s/inter/v12/UcC73FwrK3iLTeHuS_fvQtMwCp50KnMa0ZL7W0Q5n-wU.woff2)
|
|
85
|
+
format('woff2');
|
|
86
|
+
unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
|
|
87
|
+
}
|
|
88
|
+
/* greek-ext */
|
|
89
|
+
@font-face {
|
|
90
|
+
font-family: 'Inter';
|
|
91
|
+
font-style: normal;
|
|
92
|
+
font-weight: 400;
|
|
93
|
+
src: url(https://fonts.gstatic.com/s/inter/v12/UcC73FwrK3iLTeHuS_fvQtMwCp50KnMa2ZL7W0Q5n-wU.woff2)
|
|
94
|
+
format('woff2');
|
|
95
|
+
unicode-range: U+1F00-1FFF;
|
|
96
|
+
}
|
|
97
|
+
/* greek */
|
|
98
|
+
@font-face {
|
|
99
|
+
font-family: 'Inter';
|
|
100
|
+
font-style: normal;
|
|
101
|
+
font-weight: 400;
|
|
102
|
+
src: url(https://fonts.gstatic.com/s/inter/v12/UcC73FwrK3iLTeHuS_fvQtMwCp50KnMa1pL7W0Q5n-wU.woff2)
|
|
103
|
+
format('woff2');
|
|
104
|
+
unicode-range: U+0370-03FF;
|
|
105
|
+
}
|
|
106
|
+
/* vietnamese */
|
|
107
|
+
@font-face {
|
|
108
|
+
font-family: 'Inter';
|
|
109
|
+
font-style: normal;
|
|
110
|
+
font-weight: 400;
|
|
111
|
+
src: url(https://fonts.gstatic.com/s/inter/v12/UcC73FwrK3iLTeHuS_fvQtMwCp50KnMa2pL7W0Q5n-wU.woff2)
|
|
112
|
+
format('woff2');
|
|
113
|
+
unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169,
|
|
114
|
+
U+01A0-01A1, U+01AF-01B0, U+1EA0-1EF9, U+20AB;
|
|
115
|
+
}
|
|
116
|
+
/* latin-ext */
|
|
117
|
+
@font-face {
|
|
118
|
+
font-family: 'Inter';
|
|
119
|
+
font-style: normal;
|
|
120
|
+
font-weight: 400;
|
|
121
|
+
src: url(https://fonts.gstatic.com/s/inter/v12/UcC73FwrK3iLTeHuS_fvQtMwCp50KnMa25L7W0Q5n-wU.woff2)
|
|
122
|
+
format('woff2');
|
|
123
|
+
unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB,
|
|
124
|
+
U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
|
|
125
|
+
}
|
|
126
|
+
/* latin */
|
|
127
|
+
@font-face {
|
|
128
|
+
font-family: 'Inter';
|
|
129
|
+
font-style: normal;
|
|
130
|
+
font-weight: 400;
|
|
131
|
+
src: url(https://fonts.gstatic.com/s/inter/v12/UcC73FwrK3iLTeHuS_fvQtMwCp50KnMa1ZL7W0Q5nw.woff2)
|
|
132
|
+
format('woff2');
|
|
133
|
+
unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA,
|
|
134
|
+
U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212,
|
|
135
|
+
U+2215, U+FEFF, U+FFFD;
|
|
136
|
+
}
|
|
137
|
+
/* cyrillic-ext */
|
|
138
|
+
@font-face {
|
|
139
|
+
font-family: 'Inter';
|
|
140
|
+
font-style: normal;
|
|
141
|
+
font-weight: 500;
|
|
142
|
+
src: url(https://fonts.gstatic.com/s/inter/v12/UcC73FwrK3iLTeHuS_fvQtMwCp50KnMa2JL7W0Q5n-wU.woff2)
|
|
143
|
+
format('woff2');
|
|
144
|
+
unicode-range: U+0460-052F, U+1C80-1C88, U+20B4, U+2DE0-2DFF, U+A640-A69F,
|
|
145
|
+
U+FE2E-FE2F;
|
|
146
|
+
}
|
|
147
|
+
/* cyrillic */
|
|
148
|
+
@font-face {
|
|
149
|
+
font-family: 'Inter';
|
|
150
|
+
font-style: normal;
|
|
151
|
+
font-weight: 500;
|
|
152
|
+
src: url(https://fonts.gstatic.com/s/inter/v12/UcC73FwrK3iLTeHuS_fvQtMwCp50KnMa0ZL7W0Q5n-wU.woff2)
|
|
153
|
+
format('woff2');
|
|
154
|
+
unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
|
|
155
|
+
}
|
|
156
|
+
/* greek-ext */
|
|
157
|
+
@font-face {
|
|
158
|
+
font-family: 'Inter';
|
|
159
|
+
font-style: normal;
|
|
160
|
+
font-weight: 500;
|
|
161
|
+
src: url(https://fonts.gstatic.com/s/inter/v12/UcC73FwrK3iLTeHuS_fvQtMwCp50KnMa2ZL7W0Q5n-wU.woff2)
|
|
162
|
+
format('woff2');
|
|
163
|
+
unicode-range: U+1F00-1FFF;
|
|
164
|
+
}
|
|
165
|
+
/* greek */
|
|
166
|
+
@font-face {
|
|
167
|
+
font-family: 'Inter';
|
|
168
|
+
font-style: normal;
|
|
169
|
+
font-weight: 500;
|
|
170
|
+
src: url(https://fonts.gstatic.com/s/inter/v12/UcC73FwrK3iLTeHuS_fvQtMwCp50KnMa1pL7W0Q5n-wU.woff2)
|
|
171
|
+
format('woff2');
|
|
172
|
+
unicode-range: U+0370-03FF;
|
|
173
|
+
}
|
|
174
|
+
/* vietnamese */
|
|
175
|
+
@font-face {
|
|
176
|
+
font-family: 'Inter';
|
|
177
|
+
font-style: normal;
|
|
178
|
+
font-weight: 500;
|
|
179
|
+
src: url(https://fonts.gstatic.com/s/inter/v12/UcC73FwrK3iLTeHuS_fvQtMwCp50KnMa2pL7W0Q5n-wU.woff2)
|
|
180
|
+
format('woff2');
|
|
181
|
+
unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169,
|
|
182
|
+
U+01A0-01A1, U+01AF-01B0, U+1EA0-1EF9, U+20AB;
|
|
183
|
+
}
|
|
184
|
+
/* latin-ext */
|
|
185
|
+
@font-face {
|
|
186
|
+
font-family: 'Inter';
|
|
187
|
+
font-style: normal;
|
|
188
|
+
font-weight: 500;
|
|
189
|
+
src: url(https://fonts.gstatic.com/s/inter/v12/UcC73FwrK3iLTeHuS_fvQtMwCp50KnMa25L7W0Q5n-wU.woff2)
|
|
190
|
+
format('woff2');
|
|
191
|
+
unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB,
|
|
192
|
+
U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
|
|
193
|
+
}
|
|
194
|
+
/* latin */
|
|
195
|
+
@font-face {
|
|
196
|
+
font-family: 'Inter';
|
|
197
|
+
font-style: normal;
|
|
198
|
+
font-weight: 500;
|
|
199
|
+
src: url(https://fonts.gstatic.com/s/inter/v12/UcC73FwrK3iLTeHuS_fvQtMwCp50KnMa1ZL7W0Q5nw.woff2)
|
|
200
|
+
format('woff2');
|
|
201
|
+
unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA,
|
|
202
|
+
U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212,
|
|
203
|
+
U+2215, U+FEFF, U+FFFD;
|
|
204
|
+
}
|
|
205
|
+
`
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './typography'
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { bitwiseOr, isDefined, MappedEnum, PropsWithChildren, RequireOnlyOne } from '@helpers'
|
|
2
|
+
import { Text } from '../color-system'
|
|
3
|
+
|
|
4
|
+
export const enum TextAspects {
|
|
5
|
+
default = 1,
|
|
6
|
+
subdued = 2,
|
|
7
|
+
light = 4,
|
|
8
|
+
critical = 8,
|
|
9
|
+
success = 16,
|
|
10
|
+
onPrimary = 32,
|
|
11
|
+
onCritical = 64,
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
type TextOptions<T> = MappedEnum<typeof TextAspects, T>
|
|
15
|
+
|
|
16
|
+
function toTextAspect(n: number): TextAspects {
|
|
17
|
+
switch (n) {
|
|
18
|
+
case TextAspects.subdued: return TextAspects.subdued
|
|
19
|
+
case TextAspects.light: return TextAspects.light
|
|
20
|
+
case TextAspects.critical: return TextAspects.critical
|
|
21
|
+
case TextAspects.success: return TextAspects.success
|
|
22
|
+
case TextAspects.onPrimary: return TextAspects.onPrimary
|
|
23
|
+
case TextAspects.onCritical: return TextAspects.onCritical
|
|
24
|
+
default: return TextAspects.default
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
const TextAspectColors = {
|
|
29
|
+
[TextAspects.default]: Text.Default,
|
|
30
|
+
[TextAspects.subdued]: Text.Subdued,
|
|
31
|
+
[TextAspects.light]: Text.Light,
|
|
32
|
+
[TextAspects.onPrimary]: Text.OnPrimary,
|
|
33
|
+
[TextAspects.onCritical]: Text.OnPrimary,
|
|
34
|
+
[TextAspects.success]: Text.Success,
|
|
35
|
+
[TextAspects.critical]: Text.Critical,
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
export type ITextAspectProps = Partial<RequireOnlyOne<TextOptions<boolean>>> & PropsWithChildren
|
|
39
|
+
|
|
40
|
+
export type TransientTextOptions = Omit<TextOptions<boolean>, 'onCritical' | 'onPrimary'> & {
|
|
41
|
+
$onCritical?: boolean
|
|
42
|
+
$onPrimary?: boolean
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
export type ITransientTextAspectProps = Partial<RequireOnlyOne<TransientTextOptions>> & PropsWithChildren
|
|
46
|
+
|
|
47
|
+
export function getTextAspect(props: ITextAspectProps & ITransientTextAspectProps) {
|
|
48
|
+
return TextAspectColors[
|
|
49
|
+
toTextAspect(
|
|
50
|
+
bitwiseOr([
|
|
51
|
+
props.default,
|
|
52
|
+
props.subdued,
|
|
53
|
+
props.light,
|
|
54
|
+
props.critical,
|
|
55
|
+
props.success,
|
|
56
|
+
isDefined(props.onPrimary) ? props.onPrimary : props.$onPrimary,
|
|
57
|
+
isDefined(props.onCritical) ? props.onCritical : props.$onCritical,
|
|
58
|
+
])
|
|
59
|
+
)
|
|
60
|
+
]
|
|
61
|
+
}
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
import { css } from 'styled-components'
|
|
2
|
+
import { getTextAspect, ITransientTextAspectProps } from './text-aspect-flags'
|
|
3
|
+
import { FontWeight, FontSize, LineHeight } from './constants'
|
|
4
|
+
import { is } from '@helpers'
|
|
5
|
+
import { InterFontFace } from './fonts'
|
|
6
|
+
|
|
7
|
+
export type ILabelProps = ITransientTextAspectProps & {
|
|
8
|
+
default?: boolean,
|
|
9
|
+
subtle?: boolean,
|
|
10
|
+
strong?: boolean,
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
export type IBodyProps = ITransientTextAspectProps & {
|
|
14
|
+
default?: boolean,
|
|
15
|
+
strong?: boolean,
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
const LightText = css`
|
|
19
|
+
color: ${getTextAspect({ light: true })};
|
|
20
|
+
`
|
|
21
|
+
|
|
22
|
+
const Base = css<ITransientTextAspectProps>`
|
|
23
|
+
color: ${(props) => getTextAspect(props)};
|
|
24
|
+
${InterFontFace}
|
|
25
|
+
font-family: 'Inter';
|
|
26
|
+
`
|
|
27
|
+
|
|
28
|
+
const Display = css<ITransientTextAspectProps>`
|
|
29
|
+
${Base}
|
|
30
|
+
font-weight: ${FontWeight.Regular};
|
|
31
|
+
font-size: ${FontSize.g};
|
|
32
|
+
line-height: ${LineHeight.f};
|
|
33
|
+
`
|
|
34
|
+
|
|
35
|
+
const Heading1 = css<ITransientTextAspectProps>`
|
|
36
|
+
${Base}
|
|
37
|
+
font-weight: ${FontWeight.SemiBold};
|
|
38
|
+
font-size: ${FontSize.f};
|
|
39
|
+
line-height: ${LineHeight.e};
|
|
40
|
+
`
|
|
41
|
+
|
|
42
|
+
const Heading2 = css<ITransientTextAspectProps>`
|
|
43
|
+
${Heading1}
|
|
44
|
+
font-size: ${FontSize.e};
|
|
45
|
+
line-height: ${LineHeight.d};
|
|
46
|
+
`
|
|
47
|
+
|
|
48
|
+
const Heading3 = css<ITransientTextAspectProps>`
|
|
49
|
+
${Heading1}
|
|
50
|
+
font-size: ${FontSize.c};
|
|
51
|
+
line-height: ${LineHeight.c};
|
|
52
|
+
`
|
|
53
|
+
|
|
54
|
+
const Heading4 = css<ITransientTextAspectProps>`
|
|
55
|
+
${Heading1}
|
|
56
|
+
font-size: ${FontSize.b};
|
|
57
|
+
line-height: ${LineHeight.b};
|
|
58
|
+
`
|
|
59
|
+
|
|
60
|
+
const Body = css<IBodyProps>`
|
|
61
|
+
${Base}
|
|
62
|
+
font-weight: ${({ strong }) => is(strong) ? FontWeight.Medium : FontWeight.Regular};
|
|
63
|
+
font-size: ${FontSize.b};
|
|
64
|
+
line-height: ${LineHeight.b};
|
|
65
|
+
`
|
|
66
|
+
|
|
67
|
+
const BodyLarge = css<IBodyProps>`
|
|
68
|
+
${Base}
|
|
69
|
+
font-weight: ${({ strong }) => is(strong) ? FontWeight.SemiBold : FontWeight.Regular};
|
|
70
|
+
font-size: ${FontSize.d};
|
|
71
|
+
line-height: ${LineHeight.d};
|
|
72
|
+
`
|
|
73
|
+
|
|
74
|
+
const Caption = css<ITransientTextAspectProps>`
|
|
75
|
+
${Base}
|
|
76
|
+
font-weight: ${FontWeight.Regular};
|
|
77
|
+
font-size: ${FontSize.a};
|
|
78
|
+
line-height: ${LineHeight.a};
|
|
79
|
+
`
|
|
80
|
+
|
|
81
|
+
const Label = css<ILabelProps>`
|
|
82
|
+
${Base}
|
|
83
|
+
font-weight: ${({ strong }) => is(strong) ? FontWeight.Medium : FontWeight.Regular};
|
|
84
|
+
font-size: ${({ subtle }) => is(subtle) ? FontSize.a : FontSize.b};
|
|
85
|
+
line-height: ${({ subtle }) => is(subtle) ? LineHeight.a : LineHeight.b};
|
|
86
|
+
`
|
|
87
|
+
|
|
88
|
+
export const Typography = {
|
|
89
|
+
Display,
|
|
90
|
+
Heading1,
|
|
91
|
+
Heading2,
|
|
92
|
+
Heading3,
|
|
93
|
+
Heading4,
|
|
94
|
+
Body,
|
|
95
|
+
BodyLarge,
|
|
96
|
+
Caption,
|
|
97
|
+
Label,
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
export const _Typography = {
|
|
101
|
+
LightText,
|
|
102
|
+
}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
// eslint-disable-next-line no-restricted-syntax
|
|
2
|
+
import React, { FC as FunctionComponent, ForwardRefExoticComponent, ForwardRefRenderFunction, PropsWithChildren as PWC, PropsWithoutRef, RefAttributes } from 'react'
|
|
3
|
+
import { Slot } from './slots'
|
|
4
|
+
|
|
5
|
+
/** @see https://stackoverflow.com/a/49725198/29182 */
|
|
6
|
+
export type RequireOnlyOne<T, Keys extends keyof T = keyof T> = Pick<
|
|
7
|
+
T,
|
|
8
|
+
Exclude<keyof T, Keys>
|
|
9
|
+
> &
|
|
10
|
+
{
|
|
11
|
+
[K in Keys]-?: Required<Pick<T, K>> &
|
|
12
|
+
Partial<Record<Exclude<Keys, K>, undefined>>;
|
|
13
|
+
}[Keys];
|
|
14
|
+
|
|
15
|
+
export type MappedEnum<E, T> = {
|
|
16
|
+
[key in keyof E]: T;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
export type Values<T> = T[keyof T];
|
|
20
|
+
|
|
21
|
+
export type PropsWithChildren<T = unknown> = PWC<T>
|
|
22
|
+
|
|
23
|
+
// Our FC type adds the ability to specify sub-components such as Slots
|
|
24
|
+
// also, just good to wrap imports from 3rd parties in general
|
|
25
|
+
export type FC<
|
|
26
|
+
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
27
|
+
P = {},
|
|
28
|
+
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
29
|
+
E extends { [x: symbol]: FunctionComponent<PropsWithChildren> | typeof Slot } = {}
|
|
30
|
+
> = FunctionComponent<P>
|
|
31
|
+
& {
|
|
32
|
+
[key in keyof E]: E[key]
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
36
|
+
type ExtensibleForwardRef<T, P = {}, E = {}> = ForwardRefExoticComponent<PropsWithoutRef<P> & RefAttributes<T>>
|
|
37
|
+
& {
|
|
38
|
+
[key in keyof E]: E[key]
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
42
|
+
export function forwardRef<T, P = {}, E = {}>(render: ForwardRefRenderFunction<T, P>): ExtensibleForwardRef<T, P, E> {
|
|
43
|
+
return React.forwardRef(render) as ExtensibleForwardRef<T, P, E>
|
|
44
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { FC, PropsWithChildren } from './generic-types'
|
|
2
|
+
import { isDefined } from './safe-navigation'
|
|
3
|
+
|
|
4
|
+
// eslint-disable-next-line no-null/no-null
|
|
5
|
+
export const Nothing: FC = () => null
|
|
6
|
+
|
|
7
|
+
export function maybeRender<T>(prop: T, JSX: JSX.Element) {
|
|
8
|
+
return isDefined(prop) && Boolean(prop) ? JSX : <Nothing />
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
interface IIfProps {
|
|
12
|
+
is: unknown
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
export const If: FC<PropsWithChildren<IIfProps>> = (props) => {
|
|
16
|
+
// eslint-disable-next-line react/jsx-no-useless-fragment
|
|
17
|
+
return maybeRender(props.is, <>{props.children}</>)
|
|
18
|
+
}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
export type Hex = `#${string}`
|
|
2
|
+
|
|
3
|
+
export function clamp(a: number, b: number, c: number) {
|
|
4
|
+
return Math.max(a, Math.min(b, c))
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
export function toHex(n: number, length: number): Hex {
|
|
8
|
+
return `#${n.toString(16).padStart(length, '0').toUpperCase()}`
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
export function concatHex(a: Hex, b: Hex): Hex {
|
|
12
|
+
return `#${a.slice(1) + b.slice(1)}`
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
/** given an array of boolean flags, bitwiseOr interprets them as an unsigned integer
|
|
16
|
+
*
|
|
17
|
+
* ```ts
|
|
18
|
+
* bitwiseOr([false, true, false, true]) => 5 // 0b0101
|
|
19
|
+
* ```
|
|
20
|
+
*
|
|
21
|
+
* This is useful for indexing into an enum:
|
|
22
|
+
*
|
|
23
|
+
* ```ts
|
|
24
|
+
* const enum Level {
|
|
25
|
+
* default = 0,
|
|
26
|
+
* info = 0,
|
|
27
|
+
* danger = 1,
|
|
28
|
+
* warning = 2
|
|
29
|
+
* }
|
|
30
|
+
*
|
|
31
|
+
* interface IProps {
|
|
32
|
+
* info?: boolean
|
|
33
|
+
* danger?: boolean
|
|
34
|
+
* warning?: boolean
|
|
35
|
+
* }
|
|
36
|
+
*
|
|
37
|
+
* function toLevel(n: number): Level {
|
|
38
|
+
* switch (n) {
|
|
39
|
+
* case Level.info: return Level.info
|
|
40
|
+
* case Level.danger: return Level.danger
|
|
41
|
+
* case Level.warning: return Level.warning
|
|
42
|
+
* default: return Level.default
|
|
43
|
+
* }
|
|
44
|
+
* }
|
|
45
|
+
*
|
|
46
|
+
* const level = bitwiseOr([props.info, props.danger, props.warning])
|
|
47
|
+
*
|
|
48
|
+
* const levelEnum = toLevel(level)
|
|
49
|
+
* ```
|
|
50
|
+
*/
|
|
51
|
+
export function bitwiseOr(flags: unknown[]): number {
|
|
52
|
+
return flags.reduce((mask: number, flag, i) => mask | (Number(flag) << i), 0)
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
|
|
56
|
+
/** given a number, it returns the number formed by the rightmost set bit as 1 and the 0s that comes after it
|
|
57
|
+
*
|
|
58
|
+
* ```ts
|
|
59
|
+
* getRightmostSetBitNumber(12) => 4 // 12(1100) => 4(100)
|
|
60
|
+
* getRightmostSetBitNumber(40) => 8 // 40(101000) => 8(1000)
|
|
61
|
+
* ```
|
|
62
|
+
*
|
|
63
|
+
* */
|
|
64
|
+
|
|
65
|
+
export function getRightmostSetBitNumber(n: number) {
|
|
66
|
+
return n & -n
|
|
67
|
+
}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
|
|
2
|
+
/** even though we have null disabled in the repo,
|
|
3
|
+
* I still would not want isNil to skip checking null
|
|
4
|
+
* it is for juuuuust in case a third party sends us a null
|
|
5
|
+
* or something, and the types are not correct
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
/* eslint-disable no-null/no-null */
|
|
9
|
+
/* eslint-disable @typescript-eslint/ban-types */
|
|
10
|
+
|
|
11
|
+
export function isNil<T>(value: T | undefined | null): value is undefined | null {
|
|
12
|
+
return value === null || value === undefined
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
export function isDefined<T>(value: T | undefined | null): value is T {
|
|
16
|
+
return !isNil(value)
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
export function defaultTo<T>(value: T | undefined | null, fallback: T): T {
|
|
20
|
+
return isDefined(value) ? value : fallback
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
export function isEmpty<T extends { length: number }>(obj: T) {
|
|
24
|
+
return obj.length < 1
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
/** used for evaluating tri-state logic (true | false | undefined) */
|
|
28
|
+
export function is (pred?: boolean): boolean {
|
|
29
|
+
return isDefined(pred) && pred
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
export function safeArray<T>(arr: T[] | undefined | null): T[] {
|
|
33
|
+
return isDefined(arr) ? arr : []
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
export function safeCallback <T>(f?: (e: T) => void, e?: T) {
|
|
37
|
+
if (isDefined(f)) {
|
|
38
|
+
if (isDefined(e)) {
|
|
39
|
+
f(e)
|
|
40
|
+
} else {
|
|
41
|
+
(f as () => void)()
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
}
|