@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.
Files changed (261) hide show
  1. package/.babelrc +12 -0
  2. package/.eslintrc.json +147 -0
  3. package/.storybook/main.js +57 -0
  4. package/.storybook/manager.js +7 -0
  5. package/.storybook/preview.js +15 -0
  6. package/.storybook/tsconfig.json +30 -0
  7. package/jest.config.ts +15 -0
  8. package/jest.setup.ts +2 -0
  9. package/package.json +21 -10
  10. package/project.json +96 -0
  11. package/src/README.md +61 -0
  12. package/src/assets/svg/example_icon.svg +3 -0
  13. package/src/assets/svg/example_icon_white.svg +3 -0
  14. package/src/assets/svg/spinner.svg +3 -0
  15. package/src/assets/svg/spinner_white.svg +3 -0
  16. package/src/helpers/index.ts +4 -0
  17. package/src/helpers/playground.ts +16 -0
  18. package/src/helpers/talesOf.tsx +42 -0
  19. package/src/index.ts +2 -0
  20. package/src/lib/components/README.md +49 -0
  21. package/src/lib/components/alert-banner/alert-banner.tsx +34 -0
  22. package/src/lib/components/alert-banner/alert-level-flags.ts +77 -0
  23. package/src/lib/components/alert-banner/index.ts +1 -0
  24. package/src/lib/components/badge/badge-type-flags.ts +72 -0
  25. package/src/lib/components/badge/badge.test.tsx +29 -0
  26. package/src/lib/components/badge/badge.tsx +22 -0
  27. package/src/lib/components/badge/index.ts +1 -0
  28. package/src/lib/components/badge/stories/badge.stories.mdx +44 -0
  29. package/src/lib/components/badge/stories/components.tsx +49 -0
  30. package/{lib/components/card/atoms/card-frame.d.ts → src/lib/components/card/atoms/card-frame.tsx} +17 -7
  31. package/src/lib/components/card/atoms/index.ts +1 -0
  32. package/src/lib/components/card/card.test.tsx +162 -0
  33. package/src/lib/components/card/card.tsx +78 -0
  34. package/src/lib/components/card/components/card-alert-banner-slot.tsx +16 -0
  35. package/src/lib/components/card/components/card-controls-slot.tsx +19 -0
  36. package/src/lib/components/card/components/card-section-slot.tsx +51 -0
  37. package/src/lib/components/card/components/index.ts +3 -0
  38. package/src/lib/components/card/index.ts +2 -0
  39. package/src/lib/components/card/molecules/index.ts +1 -0
  40. package/src/lib/components/card/molecules/left-right-card.test.tsx +89 -0
  41. package/src/lib/components/card/molecules/left-right-card.tsx +63 -0
  42. package/src/lib/components/card/storybook/card.stories.mdx +100 -0
  43. package/src/lib/components/card/storybook/components.tsx +223 -0
  44. package/src/lib/components/checkbox/checkbox.test.tsx +39 -0
  45. package/src/lib/components/checkbox/checkbox.tsx +63 -0
  46. package/src/lib/components/checkbox/helpers.tsx +100 -0
  47. package/src/lib/components/checkbox/index.tsx +1 -0
  48. package/src/lib/components/checkbox/stories/checkbox.stories.mdx +57 -0
  49. package/src/lib/components/checkbox/stories/components.tsx +84 -0
  50. package/src/lib/components/divider/divider-type-flags.tsx +37 -0
  51. package/src/lib/components/divider/divider.test.tsx +34 -0
  52. package/src/lib/components/divider/divider.tsx +37 -0
  53. package/src/lib/components/divider/index.tsx +1 -0
  54. package/src/lib/components/divider/stories/components.tsx +13 -0
  55. package/src/lib/components/divider/stories/divider.stories.mdx +44 -0
  56. package/src/lib/components/flag/flag-size-flags.tsx +55 -0
  57. package/src/lib/components/flag/flag.list.tsx +788 -0
  58. package/src/lib/components/flag/flag.test.tsx +65 -0
  59. package/src/lib/components/flag/flag.tsx +97 -0
  60. package/src/lib/components/flag/index.tsx +1 -0
  61. package/src/lib/components/flag/stories/components.tsx +403 -0
  62. package/src/lib/components/flag/stories/flag.stories.mdx +48 -0
  63. package/src/lib/components/flag/stories/playGround-select.tsx +145 -0
  64. package/src/lib/components/icon/icon-list.tsx +135 -0
  65. package/src/lib/components/icon/icon.test.tsx +48 -0
  66. package/src/lib/components/icon/icon.tsx +181 -0
  67. package/src/lib/components/icon/index.tsx +1 -0
  68. package/src/lib/components/icon/stories/components.tsx +282 -0
  69. package/src/lib/components/icon/stories/icon.stories.mdx +65 -0
  70. package/src/lib/components/index.ts +19 -0
  71. package/src/lib/components/input-field/components/index.ts +2 -0
  72. package/src/lib/components/input-field/components/labeled-input.tsx +54 -0
  73. package/src/lib/components/input-field/components/stepper.tsx +60 -0
  74. package/src/lib/components/input-field/index.ts +6 -0
  75. package/src/lib/components/input-field/input-field.test.tsx +107 -0
  76. package/src/lib/components/input-field/input-field.tsx +126 -0
  77. package/src/lib/components/input-field/input-number.tsx +41 -0
  78. package/src/lib/components/input-field/input-text.tsx +30 -0
  79. package/src/lib/components/input-field/storybook/components.tsx +327 -0
  80. package/src/lib/components/input-field/storybook/input-field.stories.mdx +113 -0
  81. package/src/lib/components/layout/flex.tsx +22 -0
  82. package/src/lib/components/layout/grid-layout.tsx +40 -0
  83. package/src/lib/components/layout/index.ts +3 -0
  84. package/src/lib/components/layout/left-right-layout.tsx +67 -0
  85. package/src/lib/components/link/index.ts +1 -0
  86. package/src/lib/components/link/link.test.tsx +29 -0
  87. package/src/lib/components/link/link.tsx +56 -0
  88. package/src/lib/components/link/storybook/link.stories.mdx +52 -0
  89. package/src/lib/components/molecules/avatar/avatar-size-flags.tsx +55 -0
  90. package/src/lib/components/molecules/avatar/avatar.test.tsx +114 -0
  91. package/src/lib/components/molecules/avatar/avatar.tsx +80 -0
  92. package/src/lib/components/molecules/avatar/index.tsx +1 -0
  93. package/src/lib/components/molecules/avatar/stories/avatar.stories.mdx +52 -0
  94. package/src/lib/components/molecules/avatar/stories/components.tsx +36 -0
  95. package/src/lib/components/molecules/button/button-flags.tsx +340 -0
  96. package/src/lib/components/molecules/button/button.test.tsx +77 -0
  97. package/src/lib/components/molecules/button/button.tsx +214 -0
  98. package/src/lib/components/molecules/button/index.tsx +1 -0
  99. package/src/lib/components/molecules/button/stories/button.stories.mdx +105 -0
  100. package/src/lib/components/molecules/button/stories/components.tsx +84 -0
  101. package/src/lib/components/molecules/index.ts +3 -0
  102. package/src/lib/components/molecules/input-checkbox/index.tsx +1 -0
  103. package/src/lib/components/molecules/input-checkbox/input-checkbox.test.tsx +34 -0
  104. package/src/lib/components/molecules/input-checkbox/input-checkbox.tsx +49 -0
  105. package/src/lib/components/molecules/input-checkbox/stories/components.tsx +53 -0
  106. package/src/lib/components/molecules/input-checkbox/stories/input-checkbox.stories.mdx +49 -0
  107. package/src/lib/components/organisms/index.ts +1 -0
  108. package/src/lib/components/organisms/multi-choice-list/index.tsx +1 -0
  109. package/src/lib/components/organisms/multi-choice-list/multi-choice-list.test.tsx +33 -0
  110. package/src/lib/components/organisms/multi-choice-list/multi-choice-list.tsx +52 -0
  111. package/src/lib/components/organisms/multi-choice-list/stories/components.tsx +124 -0
  112. package/src/lib/components/organisms/multi-choice-list/stories/multi-choice-list.stories.mdx +99 -0
  113. package/src/lib/components/spinner/index.tsx +1 -0
  114. package/src/lib/components/spinner/spinner-size-flags.tsx +39 -0
  115. package/src/lib/components/spinner/spinner.test.tsx +31 -0
  116. package/src/lib/components/spinner/spinner.tsx +54 -0
  117. package/src/lib/components/spinner/stories/components.tsx +39 -0
  118. package/src/lib/components/spinner/stories/spinner.stories.mdx +35 -0
  119. package/src/lib/components/tabs/components/index.ts +1 -0
  120. package/src/lib/components/tabs/components/tab.tsx +62 -0
  121. package/src/lib/components/tabs/index.tsx +1 -0
  122. package/src/lib/components/tabs/storybook/components.tsx +282 -0
  123. package/src/lib/components/tabs/storybook/tabs.stories.mdx +97 -0
  124. package/src/lib/components/tabs/tabs.test.tsx +86 -0
  125. package/src/lib/components/tabs/tabs.tsx +101 -0
  126. package/src/lib/components/tag/components/close-button.tsx +85 -0
  127. package/src/lib/components/tag/components/index.ts +2 -0
  128. package/src/lib/components/tag/components/tag-label.tsx +44 -0
  129. package/src/lib/components/tag/index.tsx +1 -0
  130. package/src/lib/components/tag/stories/components.tsx +86 -0
  131. package/src/lib/components/tag/stories/tag.stories.mdx +42 -0
  132. package/src/lib/components/tag/tag.test.tsx +36 -0
  133. package/src/lib/components/tag/tag.tsx +33 -0
  134. package/src/lib/components/thumbnail/index.tsx +1 -0
  135. package/src/lib/components/thumbnail/stories/thumbnail.stories.mdx +34 -0
  136. package/src/lib/components/thumbnail/thumbnail-size-flags.tsx +41 -0
  137. package/src/lib/components/thumbnail/thumbnail.test.tsx +51 -0
  138. package/src/lib/components/thumbnail/thumbnail.tsx +45 -0
  139. package/src/lib/components/typography/index.ts +1 -0
  140. package/src/lib/components/typography/storybook/components.tsx +288 -0
  141. package/src/lib/components/typography/storybook/typography.stories.mdx +90 -0
  142. package/src/lib/components/typography/typography.test.tsx +97 -0
  143. package/src/lib/components/typography/typography.tsx +99 -0
  144. package/src/lib/foundations/color-system/base-palette/base-palette.stories.tsx +123 -0
  145. package/src/lib/foundations/color-system/base-palette/base-palette.ts +93 -0
  146. package/src/lib/foundations/color-system/base-palette/index.ts +1 -0
  147. package/src/lib/foundations/color-system/color-guidelines/color-guidelines.stories.mdx +85 -0
  148. package/src/lib/foundations/color-system/color-guidelines/color-guidelines.stories.tsx +231 -0
  149. package/src/lib/foundations/color-system/color-guidelines/color-guidelines.ts +160 -0
  150. package/src/lib/foundations/color-system/color-guidelines/index.ts +1 -0
  151. package/src/lib/foundations/color-system/components/color-sample.tsx +99 -0
  152. package/src/lib/foundations/color-system/components/index.ts +1 -0
  153. package/src/lib/foundations/color-system/index.ts +1 -0
  154. package/src/lib/foundations/index.ts +4 -0
  155. package/src/lib/foundations/shadows/components.tsx +59 -0
  156. package/src/lib/foundations/shadows/index.ts +1 -0
  157. package/src/lib/foundations/shadows/shadows.stories.mdx +71 -0
  158. package/src/lib/foundations/shadows/shadows.tsx +47 -0
  159. package/src/lib/foundations/spacing/index.ts +1 -0
  160. package/src/lib/foundations/spacing/spacing-guidelines.ts +24 -0
  161. package/src/lib/foundations/spacing/spacing.stories.mdx +51 -0
  162. package/src/lib/foundations/spacing/spacing.ts +18 -0
  163. package/src/lib/foundations/typography/constants.ts +25 -0
  164. package/src/lib/foundations/typography/fonts.ts +205 -0
  165. package/src/lib/foundations/typography/index.tsx +1 -0
  166. package/src/lib/foundations/typography/text-aspect-flags.ts +61 -0
  167. package/src/lib/foundations/typography/typography.tsx +102 -0
  168. package/src/lib/helpers/generic-types.ts +44 -0
  169. package/src/lib/helpers/index.ts +6 -0
  170. package/src/lib/helpers/nothing.tsx +18 -0
  171. package/src/lib/helpers/numbers.ts +67 -0
  172. package/src/lib/helpers/safe-navigation.ts +44 -0
  173. package/src/lib/helpers/slots.test.tsx +98 -0
  174. package/src/lib/helpers/slots.tsx +157 -0
  175. package/src/lib/helpers/strings.test.ts +47 -0
  176. package/src/lib/helpers/strings.ts +16 -0
  177. package/tsconfig.json +35 -0
  178. package/tsconfig.lib.json +28 -0
  179. package/tsconfig.spec.json +21 -0
  180. package/index.d.ts +0 -2
  181. package/index.js +0 -6078
  182. package/lib/components/alert-banner/alert-banner.d.ts +0 -11
  183. package/lib/components/alert-banner/alert-level-flags.d.ts +0 -13
  184. package/lib/components/alert-banner/index.d.ts +0 -1
  185. package/lib/components/badge/badge-type-flags.d.ts +0 -18
  186. package/lib/components/badge/badge.d.ts +0 -5
  187. package/lib/components/badge/index.d.ts +0 -1
  188. package/lib/components/card/atoms/index.d.ts +0 -1
  189. package/lib/components/card/card.d.ts +0 -14
  190. package/lib/components/card/components/card-alert-banner-slot.d.ts +0 -5
  191. package/lib/components/card/components/card-controls-slot.d.ts +0 -4
  192. package/lib/components/card/components/card-section-slot.d.ts +0 -11
  193. package/lib/components/card/components/index.d.ts +0 -3
  194. package/lib/components/card/index.d.ts +0 -2
  195. package/lib/components/card/molecules/index.d.ts +0 -1
  196. package/lib/components/card/molecules/left-right-card.d.ts +0 -16
  197. package/lib/components/checkbox/checkbox.d.ts +0 -11
  198. package/lib/components/checkbox/components/components.d.ts +0 -12
  199. package/lib/components/checkbox/index.d.ts +0 -1
  200. package/lib/components/divider/divider-type-flags.d.ts +0 -9
  201. package/lib/components/divider/divider.d.ts +0 -7
  202. package/lib/components/divider/index.d.ts +0 -1
  203. package/lib/components/index.d.ts +0 -12
  204. package/lib/components/input-field/components/index.d.ts +0 -2
  205. package/lib/components/input-field/components/labeled-input.d.ts +0 -11
  206. package/lib/components/input-field/components/stepper.d.ts +0 -7
  207. package/lib/components/input-field/index.d.ts +0 -3
  208. package/lib/components/input-field/input-field.d.ts +0 -25
  209. package/lib/components/input-field/input-number.d.ts +0 -18
  210. package/lib/components/input-field/input-text.d.ts +0 -14
  211. package/lib/components/layout/flex.d.ts +0 -16
  212. package/lib/components/layout/grid-layout.d.ts +0 -11
  213. package/lib/components/layout/index.d.ts +0 -3
  214. package/lib/components/layout/left-right-layout.d.ts +0 -70
  215. package/lib/components/link/index.d.ts +0 -1
  216. package/lib/components/link/link.d.ts +0 -14
  217. package/lib/components/molecules/avatar/avatar-size-flags.d.ts +0 -12
  218. package/lib/components/molecules/avatar/avatar.d.ts +0 -12
  219. package/lib/components/molecules/avatar/index.d.ts +0 -1
  220. package/lib/components/molecules/button/button-flags.d.ts +0 -39
  221. package/lib/components/molecules/button/button.d.ts +0 -24
  222. package/lib/components/molecules/button/index.d.ts +0 -1
  223. package/lib/components/molecules/index.d.ts +0 -3
  224. package/lib/components/molecules/input-checkbox/index.d.ts +0 -1
  225. package/lib/components/molecules/input-checkbox/input-checkbox.d.ts +0 -8
  226. package/lib/components/organisms/index.d.ts +0 -1
  227. package/lib/components/organisms/multi-choice-list/index.d.ts +0 -1
  228. package/lib/components/organisms/multi-choice-list/multi-choice-list.d.ts +0 -11
  229. package/lib/components/spinner/index.d.ts +0 -1
  230. package/lib/components/spinner/spinner-size-flags.d.ts +0 -10
  231. package/lib/components/spinner/spinner.d.ts +0 -9
  232. package/lib/components/thumbnail/index.d.ts +0 -1
  233. package/lib/components/thumbnail/thumbnail-size-flags.d.ts +0 -10
  234. package/lib/components/thumbnail/thumbnail.d.ts +0 -9
  235. package/lib/components/typography/index.d.ts +0 -1
  236. package/lib/components/typography/typography.d.ts +0 -23
  237. package/lib/foundations/color-system/base-palette/base-palette.d.ts +0 -77
  238. package/lib/foundations/color-system/base-palette/index.d.ts +0 -1
  239. package/lib/foundations/color-system/color-guidelines/color-guidelines.d.ts +0 -131
  240. package/lib/foundations/color-system/color-guidelines/index.d.ts +0 -1
  241. package/lib/foundations/color-system/components/color-sample.d.ts +0 -17
  242. package/lib/foundations/color-system/components/index.d.ts +0 -1
  243. package/lib/foundations/color-system/index.d.ts +0 -1
  244. package/lib/foundations/index.d.ts +0 -4
  245. package/lib/foundations/shadows/components.d.ts +0 -8
  246. package/lib/foundations/shadows/index.d.ts +0 -1
  247. package/lib/foundations/shadows/shadows.d.ts +0 -8
  248. package/lib/foundations/spacing/index.d.ts +0 -1
  249. package/lib/foundations/spacing/spacing-guidelines.d.ts +0 -22
  250. package/lib/foundations/spacing/spacing.d.ts +0 -18
  251. package/lib/foundations/typography/constants.d.ts +0 -22
  252. package/lib/foundations/typography/index.d.ts +0 -1
  253. package/lib/foundations/typography/text-aspect-flags.d.ts +0 -14
  254. package/lib/foundations/typography/typography.d.ts +0 -19
  255. package/lib/helpers/generic-types.d.ts +0 -21
  256. package/lib/helpers/index.d.ts +0 -6
  257. package/lib/helpers/nothing.d.ts +0 -8
  258. package/lib/helpers/numbers.d.ts +0 -41
  259. package/lib/helpers/safe-navigation.d.ts +0 -14
  260. package/lib/helpers/slots.d.ts +0 -8
  261. 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,6 @@
1
+ export * from './safe-navigation'
2
+ export * from './slots'
3
+ export * from './generic-types'
4
+ export * from './numbers'
5
+ export * from './nothing'
6
+ export * from './strings'
@@ -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
+ }