td-stylekit 24.0.3 → 24.4.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/CHANGELOG.md CHANGED
@@ -1,3 +1,31 @@
1
+ # [24.4.0](https://github.com/treasure-data/td-stylekit/compare/v24.3.0...v24.4.0) (2021-12-10)
2
+
3
+
4
+ ### Features
5
+
6
+ * **CON-8896:** Add Marketplace icons ([#1204](https://github.com/treasure-data/td-stylekit/issues/1204)) ([cd4fbf8](https://github.com/treasure-data/td-stylekit/commit/cd4fbf8))
7
+
8
+ # [24.3.0](https://github.com/treasure-data/td-stylekit/compare/v24.2.0...v24.3.0) (2021-12-09)
9
+
10
+
11
+ ### Features
12
+
13
+ * **Select:** Expose the closeMenuOnSelect prop ([#1207](https://github.com/treasure-data/td-stylekit/issues/1207)) ([fedc1e7](https://github.com/treasure-data/td-stylekit/commit/fedc1e7))
14
+
15
+ # [24.2.0](https://github.com/treasure-data/td-stylekit/compare/v24.1.0...v24.2.0) (2021-10-27)
16
+
17
+
18
+ ### Features
19
+
20
+ * **Modal:** Render Header children ([#1200](https://github.com/treasure-data/td-stylekit/issues/1200)) ([64b3f95](https://github.com/treasure-data/td-stylekit/commit/64b3f95))
21
+
22
+ # [24.1.0](https://github.com/treasure-data/td-stylekit/compare/v24.0.3...v24.1.0) (2021-10-26)
23
+
24
+
25
+ ### Features
26
+
27
+ * **CON-8796:** Add new icons for journey builder ([#1201](https://github.com/treasure-data/td-stylekit/issues/1201)) ([8dbf106](https://github.com/treasure-data/td-stylekit/commit/8dbf106))
28
+
1
29
  ## [24.0.3](https://github.com/treasure-data/td-stylekit/compare/v24.0.2...v24.0.3) (2021-10-06)
2
30
 
3
31
 
package/LICENSE ADDED
@@ -0,0 +1 @@
1
+ Copyright 2021 Treasure Data inc, all rights reserved.
package/README.md CHANGED
@@ -27,13 +27,14 @@ return () => (
27
27
 
28
28
  ## Scripts 👩‍💻
29
29
 
30
- | script | description |
31
- | ------------ | ------------------------------------- |
32
- | `build` | generate a production build of module |
33
- | `test` | run unit tests |
34
- | `tdd` | run tests in watch mode |
35
- | `start` | start dev documentation server |
36
- | `docs:build` | generate static build of docs |
30
+ | script | description |
31
+ | -------------------- | ------------------------------------- |
32
+ | `build` | generate a production build of module |
33
+ | `test` | run unit tests |
34
+ | `tdd` | run tests in watch mode |
35
+ | `start` | start dev documentation server |
36
+ | `docs:build` | generate static build of docs |
37
+ | `download:snapshots` | copy changed snapshots from CircleCI |
37
38
 
38
39
  ## Release 🛸
39
40
 
@@ -43,32 +44,30 @@ Detailed documentation on the release process and how to format commit messages
43
44
 
44
45
  ## Visual Regression Testing 📉
45
46
 
46
- We run visual regression tests on every commit. If you need to update the screenshots for legitimate changes, please [install docker](https://docs.docker.com/docker-for-mac/install/) first. Then [increase Docker](https://docs.docker.com/docker-for-mac/#memory) runtime memory limit to 4 GB. Then follow these steps:
47
+ Visual regression tests take snapshots of each Storybook story and compare them to existing snapshots to identify any visual differences introduced by code changes.
47
48
 
48
- ```bash
49
- docker build -t td-stylekit-docs . # only need to do this every time the source code changes
50
- docker run -it --rm --name differencify td-stylekit-docs
51
- ```
49
+ If a visual regression test fails, that means you've made visual changes to a component. If this is unintentional, it'll alert you to your mistake. If this is intentional, you'll need to update the snapshots to make the test pass.
52
50
 
53
- After storybook has started, run the following in a separate terminal:
51
+ ## Updating Visual Regression Tests 🌠
54
52
 
55
- ```bash
56
- docker exec -it differencify yarn test:visual-update
57
- ```
53
+ ### **Prerequisites**
58
54
 
59
- > (Optional) To increase execution speed, you can specify a filter for the snapshots so that only a limited number are tested/updated:
60
- >
61
- > ```bash
62
- > docker exec -it differencify yarn test:visual-update <ComponentName>
63
- > ```
55
+ - Set up the `$CIRCLECI_TOKEN` environment variable in your local environment
56
+ - Instructions can be found [here](https://github.com/treasure-data/td-crystal/blob/main/packages/build/docs/prerequisites.md#circleci-personal-access-token)
64
57
 
65
- Finally, copy the updated snapshots from the Docker container to your file system:
58
+ ### **Steps**
59
+
60
+ Push your changes, allow CircleCI to finish executing the _Visual Regression_ step, then run:
66
61
 
67
62
  ```bash
68
- docker cp differencify:/tmp/stylekit/differencify_reports/__image_snapshots__/ differencify_reports/
63
+ yarn download:snapshots # Use the --help flag for more options
69
64
  ```
70
65
 
71
- We generate the screenshots inside a docker image because this more closely simulates where the tests are run in circleci, and we avoid any visual differences caused by operating system details.
66
+ - This will script will download any altered snapshots that have been saved in CircleCI's Artifacts to your local snapshot directory.
67
+
68
+ - From there, you can simply commit the new snapshots.
69
+
70
+ ## Disabling Visual Regression Tests ❌
72
71
 
73
72
  Screenshot are automatically generated for all stories. However, if you need to disable tests due to hard-to-screenshot stories, like animations, you have a couple options:
74
73
 
@@ -98,7 +97,7 @@ Contributions are always welcome! Read our [contribution guidelines](https://tre
98
97
  - Set break points wherever you need
99
98
  - Press F5. This will launch a new Chrome browser and run td-stylekit in debugging mode
100
99
 
101
- ## Resolving Security Issues
100
+ ## Resolving Security Issues 🔐
102
101
 
103
102
  ### Using Dependabot
104
103
 
@@ -2303,6 +2303,7 @@ export declare const Spacer: StyledComponent<React.DetailedHTMLProps<React.HTMLA
2303
2303
  }>;
2304
2304
  export declare const OperatorSelect: StyledComponent<import("../Select").SelectComponentProps | ({
2305
2305
  arrowIcon?: React.ComponentClass<import("react-select").IndicatorProps<any>, any> | React.FunctionComponent<import("react-select").IndicatorProps<any>> | undefined;
2306
+ closeMenuOnSelect?: boolean | undefined;
2306
2307
  componentStyles?: import("../Select").SelectComponentStyles | undefined;
2307
2308
  creatable?: boolean | undefined;
2308
2309
  creatableOptionRenderer?: ((props: import("../Select/components").OptionRendererProps) => React.ReactNode) | undefined;
@@ -448,6 +448,10 @@ export declare type IconTypes = {
448
448
  DetailNavIcon: React.ComponentType<JSX.IntrinsicElements['svg']>;
449
449
  Document: React.ComponentType<JSX.IntrinsicElements['svg']>;
450
450
  DocumentIcon: React.ComponentType<JSX.IntrinsicElements['svg']>;
451
+ Download: React.ComponentType<JSX.IntrinsicElements['svg']>;
452
+ DownloadIcon: React.ComponentType<JSX.IntrinsicElements['svg']>;
453
+ End: React.ComponentType<JSX.IntrinsicElements['svg']>;
454
+ EndIcon: React.ComponentType<JSX.IntrinsicElements['svg']>;
451
455
  FilledDownArrow: React.ComponentType<JSX.IntrinsicElements['svg']>;
452
456
  FilledDownArrowIcon: React.ComponentType<JSX.IntrinsicElements['svg']>;
453
457
  FilledLeftArrow: React.ComponentType<JSX.IntrinsicElements['svg']>;
@@ -466,6 +470,8 @@ export declare type IconTypes = {
466
470
  FolderTagPersonIcon: React.ComponentType<JSX.IntrinsicElements['svg']>;
467
471
  Funnel: React.ComponentType<JSX.IntrinsicElements['svg']>;
468
472
  FunnelIcon: React.ComponentType<JSX.IntrinsicElements['svg']>;
473
+ Goal: React.ComponentType<JSX.IntrinsicElements['svg']>;
474
+ GoalIcon: React.ComponentType<JSX.IntrinsicElements['svg']>;
469
475
  Group: React.ComponentType<JSX.IntrinsicElements['svg']>;
470
476
  GroupIcon: React.ComponentType<JSX.IntrinsicElements['svg']>;
471
477
  HelpNav: React.ComponentType<JSX.IntrinsicElements['svg']>;
@@ -524,12 +530,18 @@ export declare type IconTypes = {
524
530
  SettingIcon: React.ComponentType<JSX.IntrinsicElements['svg']>;
525
531
  Share: React.ComponentType<JSX.IntrinsicElements['svg']>;
526
532
  ShareIcon: React.ComponentType<JSX.IntrinsicElements['svg']>;
533
+ ShoppingBag: React.ComponentType<JSX.IntrinsicElements['svg']>;
534
+ ShoppingBagIcon: React.ComponentType<JSX.IntrinsicElements['svg']>;
527
535
  Sisense: React.ComponentType<JSX.IntrinsicElements['svg']>;
528
536
  SisenseIcon: React.ComponentType<JSX.IntrinsicElements['svg']>;
529
537
  Source: React.ComponentType<JSX.IntrinsicElements['svg']>;
530
538
  SourceIcon: React.ComponentType<JSX.IntrinsicElements['svg']>;
531
539
  Stage: React.ComponentType<JSX.IntrinsicElements['svg']>;
532
540
  StageIcon: React.ComponentType<JSX.IntrinsicElements['svg']>;
541
+ Store: React.ComponentType<JSX.IntrinsicElements['svg']>;
542
+ StoreIcon: React.ComponentType<JSX.IntrinsicElements['svg']>;
543
+ Summary: React.ComponentType<JSX.IntrinsicElements['svg']>;
544
+ SummaryIcon: React.ComponentType<JSX.IntrinsicElements['svg']>;
533
545
  SymbolMinus: React.ComponentType<JSX.IntrinsicElements['svg']>;
534
546
  SymbolMinusIcon: React.ComponentType<JSX.IntrinsicElements['svg']>;
535
547
  Table: React.ComponentType<JSX.IntrinsicElements['svg']>;
@@ -868,6 +868,14 @@ React.createElement("g", null, /*#__PURE__*/React.createElement("path", {
868
868
  React.createElement("path", {
869
869
  d: "M12.879 4H7.5C6.675 4 6 4.675 6 5.5v12c0 .825.675 1.5 1.5 1.5h9c.825 0 1.5-.675 1.5-1.5V9.121a1.5 1.5 0 00-.44-1.06l-3.62-3.622A1.5 1.5 0 0012.879 4zm2.807 4.907a.2.2 0 01-.14.343H12.95a.2.2 0 01-.2-.2V6.506a.2.2 0 01.34-.143l2.596 2.544zm-7.354 3.127a1 1 0 011-1h5.336a1 1 0 010 2H9.332a1 1 0 01-1-1zm1 2.5a1 1 0 000 2h5.336a1 1 0 100-2H9.332z",
870
870
  fillRule: "evenodd"
871
+ }),Download: /*#__PURE__*/
872
+ React.createElement("path", {
873
+ d: "M6.531 4a1 1 0 00-.864.496l-1.53 2.625A1 1 0 004 7.625v10.5C4 19.16 4.84 20 5.875 20h12.25C19.16 20 20 19.16 20 18.125v-10.5a1 1 0 00-.136-.504l-1.532-2.625A1 1 0 0017.47 4H6.53zM6 7.895L7.106 6h9.788L18 7.895v.058H6v-.058zm6.566 9.37l2.4-2.4A.8.8 0 0014.4 13.5H13v-3a1 1 0 00-2 0v3H9.6a.8.8 0 00-.565 1.366l2.4 2.4a.8.8 0 001.131 0z",
874
+ fillRule: "evenodd"
875
+ }),End: /*#__PURE__*/
876
+ React.createElement("path", {
877
+ d: "M20 12a8 8 0 11-16 0 8 8 0 0116 0zm-2.5 0a5.5 5.5 0 11-11 0 5.5 5.5 0 0111 0z",
878
+ fillRule: "evenodd"
871
879
  }),FilledDownArrow: /*#__PURE__*/
872
880
  React.createElement("path", {
873
881
  d: "M6.762 10.144l4.97 4.97a.889.889 0 001.257 0l4.97-4.97c.56-.56.164-1.519-.629-1.519H7.39c-.792 0-1.189.958-.628 1.519z"
@@ -899,7 +907,14 @@ React.createElement("path", {
899
907
  }),Funnel: /*#__PURE__*/
900
908
  React.createElement("path", {
901
909
  d: "M4 4.5a.5.5 0 01.5-.5h15a.5.5 0 01.5.5v1.385a.5.5 0 01-.5.5h-15a.5.5 0 01-.5-.5V4.5zM6.856 8a.3.3 0 00-.233.49l3.486 4.26a.5.5 0 01.113.317v6.07a.5.5 0 00.749.434l2.555-1.463a.5.5 0 00.252-.434v-4.607a.5.5 0 01.113-.316l3.486-4.26a.3.3 0 00-.233-.49H6.856z"
902
- }),Group: /*#__PURE__*/
910
+ }),Goal: /*#__PURE__*/
911
+ React.createElement("g", null, /*#__PURE__*/React.createElement("path", {
912
+ d: "M19.962 7.31a.5.5 0 01-.108.545l-2 2A.5.5 0 0117.5 10h-2.293l-1.91 1.91.003.09a1.3 1.3 0 11-1.2-1.297l1.9-1.9V6.501a.501.501 0 01.146-.354l2-2A.5.5 0 0117 4.5V7h2.5a.5.5 0 01.462.309z"
913
+ }), /*#__PURE__*/React.createElement("path", {
914
+ d: "M19.752 10.017a.079.079 0 00-.132-.036l-1.117 1.117a.757.757 0 01-.245.163.135.135 0 00-.087.135 6.2 6.2 0 11-5.574-5.568.139.139 0 00.138-.089.757.757 0 01.164-.246l1.131-1.13a.065.065 0 00-.03-.11 8 8 0 105.752 5.764z"
915
+ }), /*#__PURE__*/React.createElement("path", {
916
+ d: "M16.681 11.576a.287.287 0 00-.29-.258h-.688a.3.3 0 00-.213.089l-.503.506a.318.318 0 00-.09.212 2.9 2.9 0 11-3.039-3.022.318.318 0 00.211-.09l.522-.524a.3.3 0 00.087-.211v-.67c0-.149-.11-.276-.258-.29a4.7 4.7 0 104.26 4.257z"
917
+ })),Group: /*#__PURE__*/
903
918
  React.createElement("path", {
904
919
  d: "M11.682 9.09a2.584 2.584 0 01-2.587 2.596A2.592 2.592 0 016.5 9.09a2.592 2.592 0 012.595-2.595 2.584 2.584 0 012.587 2.595zM17.812 9.273a2.41 2.41 0 11-4.818 0 2.41 2.41 0 114.818 0zM9.09 13.14c-1.694 0-5.09.851-5.09 2.546v1.09c0 .4.327.728.727.728h8.727a.73.73 0 00.728-.727v-1.091c0-1.695-3.396-2.546-5.091-2.546zM14.204 13.177c.254-.022.494-.037.705-.037 1.695 0 5.091.851 5.091 2.546v1.09a.73.73 0 01-.727.728h-3.768c.08-.225.131-.473.131-.727v-1.091c0-1.07-.574-1.876-1.403-2.48l-.007-.008a.064.064 0 00-.022-.021z"
905
920
  }),Help: /*#__PURE__*/
@@ -1056,6 +1071,10 @@ React.createElement("g", null, /*#__PURE__*/React.createElement("path", {
1056
1071
  })),Share: /*#__PURE__*/
1057
1072
  React.createElement("path", {
1058
1073
  d: "M21 5a3 3 0 01-4.905 2.318l-7.12 4.296a3.03 3.03 0 01-.027.948l7.113 4.149a3 3 0 11-1.008 1.727L7.939 14.29a3 3 0 11.128-4.463l6.994-4.22A3 3 0 1121 5z"
1074
+ }),ShoppingBag: /*#__PURE__*/
1075
+ React.createElement("path", {
1076
+ d: "M10 4a2 2 0 00-2 2v2H6a1 1 0 00-1 1v9a2 2 0 002 2h10a2 2 0 002-2V9a1 1 0 00-1-1h-2V6a2 2 0 00-2-2h-4zm4 4V6h-4v2h4zm-5 4a1 1 0 100-2 1 1 0 000 2zm6 0a1 1 0 100-2 1 1 0 000 2z",
1077
+ fillRule: "evenodd"
1059
1078
  }),Sisense: /*#__PURE__*/
1060
1079
  React.createElement("g", null, /*#__PURE__*/React.createElement("path", {
1061
1080
  d: "M4.875 3.687a1.187 1.187 0 00-2.375 0v15.517A2.296 2.296 0 004.796 21.5h15.517a1.187 1.187 0 100-2.375H4.875V3.687z"
@@ -1074,6 +1093,14 @@ React.createElement("path", {
1074
1093
  }),Stage: /*#__PURE__*/
1075
1094
  React.createElement("path", {
1076
1095
  d: "M7.327 19a1 1 0 102 0v-6.151l7.063-3.398a.5.5 0 000-.902L9.327 5.151V5a1 1 0 10-2 0v14z"
1096
+ }),Store: /*#__PURE__*/
1097
+ React.createElement("path", {
1098
+ d: "M7 4.75a1 1 0 000 2h10a1 1 0 100-2H7zm-.823 3.5h11.646c.345 0 .65.23.76.574l1.376 4.336c.027.085.041.175.041.265v.704c0 .463-.358.84-.8.84H19v3.281a1 1 0 11-2 0v-3.281h-2v3.281a1 1 0 01-1 1H6a1 1 0 01-1-1v-3.281h-.2c-.442 0-.8-.377-.8-.84v-.704c0-.09.014-.18.04-.265l1.378-4.336a.804.804 0 01.759-.574zM13 14.969H7v2.281h6v-2.281z",
1099
+ fillRule: "evenodd"
1100
+ }),Summary: /*#__PURE__*/
1101
+ React.createElement("path", {
1102
+ d: "M6 5.5a2 2 0 00-2 2v9a2 2 0 002 2h12a2 2 0 002-2v-9a2 2 0 00-2-2H6zm0 3a1 1 0 011-1h3a1 1 0 110 2H7a1 1 0 01-1-1zM6 12a1 1 0 011-1h3a1 1 0 110 2H7a1 1 0 01-1-1zm0 3.5a1 1 0 011-1h3a1 1 0 110 2H7a1 1 0 01-1-1zm7-7a1 1 0 011-1h3a1 1 0 011 1v7a1 1 0 01-1 1h-3a1 1 0 01-1-1v-7z",
1103
+ fillRule: "evenodd"
1077
1104
  }),SymbolCircleCheck: /*#__PURE__*/
1078
1105
  React.createElement("path", {
1079
1106
  d: "M12 20a8 8 0 100-16 8 8 0 000 16zm4.858-9.2a1 1 0 00-1.436-1.392l-4.412 4.55-2.432-2.507a1 1 0 00-1.435 1.393l3.15 3.247a1 1 0 001.436 0l5.129-5.291z",
@@ -315,7 +315,7 @@ export declare class Modal extends Component<ModalProps, ModalState> {
315
315
  icon?: React.ReactNode;
316
316
  }) => JSX.Element;
317
317
  };
318
- static Header: ({ closeTitle, id, title, subtitle, dynamite, destructive, onHide, disableCancel, ...props }: import(".").HeaderProps) => JSX.Element;
318
+ static Header: ({ closeTitle, id, title, subtitle, dynamite, destructive, onHide, disableCancel, children, ...props }: import(".").HeaderProps) => JSX.Element;
319
319
  static Message: typeof ModalMessage;
320
320
  state: ModalState;
321
321
  setPageInstrumentation: (page: string) => void;
@@ -1,4 +1,4 @@
1
- /// <reference types="react" />
1
+ import React from 'react';
2
2
  export declare type HeaderProps = {
3
3
  id?: string;
4
4
  title?: string;
@@ -9,7 +9,8 @@ export declare type HeaderProps = {
9
9
  disableCancel?: boolean;
10
10
  smallFont?: boolean;
11
11
  closeTitle?: string;
12
+ children?: React.ReactNode;
12
13
  };
13
- declare const Header: ({ closeTitle, id, title, subtitle, dynamite, destructive, onHide, disableCancel, ...props }: HeaderProps) => JSX.Element;
14
+ declare const Header: ({ closeTitle, id, title, subtitle, dynamite, destructive, onHide, disableCancel, children, ...props }: HeaderProps) => JSX.Element;
14
15
  export default Header;
15
16
  //# sourceMappingURL=Header.d.ts.map
@@ -22,7 +22,8 @@ var Header = function Header(_ref) {
22
22
  onHide = _ref.onHide,
23
23
  _ref$disableCancel = _ref.disableCancel,
24
24
  disableCancel = _ref$disableCancel === void 0 ? false : _ref$disableCancel,
25
- props = _objectWithoutProperties(_ref, ["closeTitle", "id", "title", "subtitle", "dynamite", "destructive", "onHide", "disableCancel"]);
25
+ children = _ref.children,
26
+ props = _objectWithoutProperties(_ref, ["closeTitle", "id", "title", "subtitle", "dynamite", "destructive", "onHide", "disableCancel", "children"]);
26
27
 
27
28
  var titleId = id ? "".concat(id, "_title") : '';
28
29
  var subtitleId = id ? "".concat(id, "_subtitle") : '';
@@ -47,7 +48,7 @@ var Header = function Header(_ref) {
47
48
  "data-gs": gs("src", "modal", "components", "header-container", "title-container", "modal-subtitle"),
48
49
  text: subtitle,
49
50
  id: subtitleId
50
- })), ___EmotionJSX(CloseIcon, {
51
+ })), children, ___EmotionJSX(CloseIcon, {
51
52
  "data-gs-c": gsC("icon-medium-close"),
52
53
  "data-gs": gs("src", "modal", "components", "header-container", "close-icon"),
53
54
  onClick: onHide,
@@ -13,6 +13,8 @@ export declare type StructuredOption = {
13
13
  export declare type SelectComponentProps = {
14
14
  /** Provide a custom dropdown arrow */
15
15
  arrowIcon?: IndicatorComponentType<any>;
16
+ /** Close the select menu when the user selects an option. If multi is true, then this defaults to false. */
17
+ closeMenuOnSelect?: boolean;
16
18
  /** Object of Style options to add to or override deeply nested react-select defaults: https://react-select.com/styles */
17
19
  componentStyles?: SelectComponentStyles;
18
20
  /** Allow user to create values (enables searchable) */
@@ -137,7 +137,7 @@ export var SelectComponent = /*#__PURE__*/function (_PureComponent) {
137
137
  return {
138
138
  marginRight: theme.space[1]
139
139
  };
140
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Select/Select.tsx"],"names":[],"mappings":"AA4PyB","file":"../../../src/Select/Select.tsx","sourcesContent":["import type { CSSObject } from '@emotion/core'\nimport { useTheme } from 'emotion-theming'\nimport React, { PureComponent, MutableRefObject } from 'react'\nimport Select, { components, createFilter } from 'react-select'\nimport type {\n  IndicatorComponentType,\n  IndicatorProps,\n  Props as SelectProps,\n  SelectComponentsConfig,\n  SingleValueProps as SingleValueComponentProps,\n  MenuListComponentProps,\n  OptionProps as OptionComponentProps\n} from 'react-select'\nimport RightTruncatedText from '../RightTruncatedText'\nimport type { Theme, ThemeProp } from '../ThemeProvider'\nimport { CreatableSelect, MenuList, MenuPortal, Option } from './components'\nimport type {\n  OptionRendererProps,\n  Options,\n  OptionType,\n  OptionValue\n} from './components'\nimport type { CreatableReactSelectProps } from './components/CreatableSelect'\nimport * as Elements from './elements'\nimport { getCustomStyles, getOptions } from './utils'\nimport isObject from 'lodash/isObject'\nimport type { SelectComponentStyles } from './types'\nimport variantProps from './variantProps'\nimport styled from '@emotion/styled'\n\nexport type StructuredOption = {\n  name?: string | null\n  value?: any\n  label?: string\n}\n\nexport type SelectComponentProps = {\n  /** Provide a custom dropdown arrow */\n  arrowIcon?: IndicatorComponentType<any>\n\n  /** Object of Style options to add to or override deeply nested react-select defaults: https://react-select.com/styles */\n  componentStyles?: SelectComponentStyles\n\n  /** Allow user to create values (enables searchable) */\n  creatable?: boolean\n\n  /**\n   * Render a custom format when creating a new value\n   */\n  creatableOptionRenderer?: (props: OptionRendererProps) => React.ReactNode\n\n  /** Custom components passed through */\n  customComponents?: SelectComponentsConfig<any>\n\n  /** Apply unique inline styles if dataGrid is true */\n  dataGrid?: boolean\n  /** Instrumentation */\n  'data-instrumentation'?: string\n\n  /** Select is disabled */\n  disabled?: boolean\n\n  /** Render an icon for a given option. */\n  getIconForOption?: (props: OptionRendererProps) => React.ReactNode\n\n  /**\n   * Function responsible for returning a name for a given option/value.\n   */\n  getLabelForOption?: (option: OptionValue) => string\n\n  /**\n   * Optional function responsible for returning an optgroup label for an option.\n   */\n  getOptgroupForOption?: (value?: OptionValue) => string\n\n  /**\n   * Function responsible for returning secondary text for a given single value.\n   */\n  getSingleValueSecondaryText?: (value?: string) => string\n\n  /** Set width of the menu based on option character length (approximate!), overrides menuWidth */\n  guessMenuWidth?: boolean\n\n  /** Form control's validity */\n  invalid?: boolean\n\n  /** Custom menu height */\n  maxHeight?: number\n\n  /** Custom menu width (typically the menu is the same width as the select element) */\n  menuWidth?: string\n\n  /** Enable selection of multiple values */\n  multi?: boolean\n\n  /** Uniquely identifies this form control. */\n  name: string\n\n  /** Override message for no results when searching */\n  noResultsMessage?: string\n\n  /**\n   * Callback triggered when user selects a new value.\n   */\n  onChange: (option: { name: string; value: any }) => void\n\n  /** Height of the option menu (in px) */\n  optionHeight?: number\n\n  /**\n   * Render a custom for every option\n   */\n  optionRenderer?: (props: OptionRendererProps) => React.ReactNode\n\n  /** Array of options to display in the select menu */\n  options: Options\n\n  /** Enable user search to filter options */\n  searchable?: boolean\n\n  /** Include OptGroup in search filter for children */\n  searchOptGroup?: boolean\n\n  /** Minimal styles to show selected value as text */\n  textOnly?: boolean\n\n  /**\n   * Gives ability to grab ref to Select.\n   * Only callbacks and mutable references are supported: if using `useRef()` do\n   * not forget to own the reference adding `null` as in\n   * `const ref = useRef<HTMLInputElement | null>(null)`.\n   */\n  selectRef?:\n    | ((instance: HTMLInputElement | null) => void)\n    | MutableRefObject<HTMLInputElement | null>\n\n  /* Style modifier */\n  style?: CSSObject\n\n  /** Selected value */\n  value?: number | string | Array<any>\n\n  /** Form Control warning is present */\n  warning?: boolean\n\n  /** Custom width passed through */\n  width?: string\n} & Omit<SelectProps, 'theme'>\n\ntype SelectComponentPropsOrCreatable =\n  | SelectComponentProps\n  | (SelectComponentProps & CreatableReactSelectProps)\n\n/**\n * Render a select component. Extra props are passed through to react-select.\n * See more options here: https://react-select.com/props\n */\nexport class SelectComponent extends PureComponent<\n  SelectComponentPropsOrCreatable & ThemeProp\n> {\n  static defaultProps = {\n    creatable: false,\n    creatableOptionRenderer: null,\n    customComponents: null,\n    'data-instrumentation': 'select',\n    getLabelForOption: (option: any) => option.label,\n    getOptgroupForOption: () => '',\n    onChange: () => {},\n    optionRenderer: null,\n    searchable: false,\n    searchOptGroup: false\n  }\n\n  _getValue = (structuredOptions: Array<StructuredOption | OptionValue>) => {\n    const { value, multi } = this.props\n\n    if (value == null) {\n      return value\n    }\n\n    if (multi) {\n      return Array.isArray(value)\n        ? value.map<any>(val => {\n            const currentOption = structuredOptions.find(option => {\n              if (isObject(option)) {\n                return option.value === val\n              }\n\n              return option === val\n            })\n            return currentOption || { value: val, label: val }\n          })\n        : []\n    } else {\n      const currentOption = structuredOptions.find(option => {\n        if (isObject(option)) {\n          return option.value === value\n        }\n\n        return option === value\n      })\n      if (currentOption) {\n        return currentOption\n      }\n    }\n    // if value is a falsy native data type but doesn't match an option then return value\n    if (!value) {\n      return value\n    }\n\n    // important for rendering arbitrary input not in the option list\n    return {\n      value,\n      label: value\n    }\n  }\n\n  _renderArrow: React.FC<IndicatorProps<any>> = ({\n    getStyles,\n    innerProps,\n    ...props\n  }) => (\n    <Elements.ArrowDownIcon\n      css={getStyles('dropdownIndicator', props)}\n      {...innerProps}\n    />\n  )\n\n  _renderMenuList: React.FC<MenuListComponentProps<OptionType>> = (\n    props: MenuListComponentProps<OptionType>\n  ) => (\n    <MenuList\n      {...props}\n      maxHeight={this.props.maxHeight}\n      theme={this.props.theme}\n      rowHeight={this.props.optionHeight}\n    />\n  )\n\n  _renderOption: React.FC<OptionComponentProps<any>> = props => (\n    <Option\n      {...props}\n      creatableOptionRenderer={this.props.creatableOptionRenderer}\n      getIconForOption={this.props.getIconForOption}\n      optionRenderer={this.props.optionRenderer}\n    />\n  )\n\n  _renderSingleValue: React.FC<SingleValueComponentProps<any>> = ({\n    children,\n    ...props\n  }) => {\n    const PrimaryLabel = styled('span')(({ theme }) => ({\n      marginRight: theme.space[1]\n    }))\n    const SecondaryLabel = styled('span')(({ theme }) => ({\n      color: theme.palette.neutral[9],\n      fontWeight: 600,\n      whiteSpace: 'nowrap',\n      overflow: 'hidden',\n      textOverflow: 'ellipsis'\n    }))\n    const secondaryText = this.props.getSingleValueSecondaryText\n      ? this.props.getSingleValueSecondaryText(props.data.value)\n      : null\n    const singleValue = secondaryText ? (\n      <RightTruncatedText\n        title={`${children} ${secondaryText}`}\n        text={\n          <>\n            <PrimaryLabel>{children}</PrimaryLabel>\n            <SecondaryLabel>{secondaryText}</SecondaryLabel>\n          </>\n        }\n      />\n    ) : (\n      <RightTruncatedText text={children} />\n    )\n    return (\n      <components.SingleValue {...props}>{singleValue}</components.SingleValue>\n    )\n  }\n\n  _onChange = (selected: StructuredOption | Array<StructuredOption>) => {\n    const { multi, name, onChange } = this.props\n    const value = multi\n      ? ((selected as Array<StructuredOption>) || []).map(\n          option => option.value\n        )\n      : (selected as StructuredOption).value\n    if (onChange) {\n      onChange({ name, value })\n    }\n  }\n\n  render() {\n    const {\n      arrowIcon,\n      creatable,\n      customComponents,\n      disabled,\n      'data-instrumentation': dataInstrumentation,\n      getLabelForOption = (option: any) => option.label,\n      getOptgroupForOption = () => '',\n      multi,\n      options,\n      componentStyles,\n      searchable,\n      selectRef,\n      theme,\n      searchOptGroup = false\n    } = this.props\n\n    const structuredOptions = getOptions({\n      options,\n      getLabelForOption,\n      getOptgroupForOption\n    })\n\n    const customStyles = getCustomStyles(\n      this.props,\n      structuredOptions,\n      componentStyles\n    )\n\n    const SelectComponent = creatable ? CreatableSelect : Select\n\n    const applySelectRef = ref => {\n      if (selectRef) {\n        if (typeof selectRef === 'function') {\n          selectRef(ref)\n        } else {\n          selectRef.current = ref\n        }\n      }\n    }\n\n    const injectInstrumentation = ref => {\n      const safeSelectRef = ref && (ref.select.select || ref.select)\n      if (safeSelectRef) {\n        safeSelectRef.controlRef.setAttribute('data-gs-c', this.props.name)\n        safeSelectRef.controlRef.setAttribute(\n          'data-instrumentation',\n          this.props['data-instrumentation']\n        )\n      }\n    }\n\n    return (\n      <SelectComponent\n        {...this.props}\n        data-instrumentation={dataInstrumentation}\n        captureMenuScroll={false}\n        components={{\n          DropdownIndicator: arrowIcon || this._renderArrow,\n          IndicatorSeparator: null,\n          MenuList: this._renderMenuList,\n          Option: this._renderOption,\n          MenuPortal,\n          SingleValue: this._renderSingleValue,\n          ...customComponents\n        }}\n        // defaultMenuIsOpen is not supported until CON-4380 is fixed.\n        defaultMenuIsOpen={false}\n        inputId={this.props.name}\n        isClearable={false}\n        isDisabled={disabled}\n        isMulti={multi}\n        closeMenuOnSelect={!multi}\n        isOptionDisabled={option =>\n          !!(option.disabled || (option.type && option.type === 'header'))\n        }\n        isSearchable={searchable || creatable}\n        // menuPlacement has to be auto for tethered Menu to work correctly.\n        menuPlacement=\"auto\"\n        menuPortalTarget={document.body}\n        onChange={this._onChange}\n        options={structuredOptions}\n        ref={ref => {\n          applySelectRef(ref)\n          injectInstrumentation(ref)\n        }}\n        styles={customStyles}\n        theme={defaultTheme => ({ ...defaultTheme, ...theme })}\n        value={this._getValue(structuredOptions)}\n        // When ignoreAccents is true, it causes a significant lag when options exceed 1000 items.\n        filterOption={createFilter({\n          ignoreAccents: false,\n          stringify: obj =>\n            `${obj.label} ${\n              (searchOptGroup && getOptgroupForOption(obj.value)) || ''\n            }`\n        })}\n      />\n    )\n  }\n}\n\nfunction WrappedComponent(props: SelectComponentPropsOrCreatable) {\n  const theme: Theme = useTheme()\n  return <SelectComponent {...props} theme={theme} />\n}\n\nWrappedComponent.Elements = Elements\nWrappedComponent.variantProps = variantProps\n\nexport default WrappedComponent\n"]} */");
140
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Select/Select.tsx"],"names":[],"mappings":"AA+PyB","file":"../../../src/Select/Select.tsx","sourcesContent":["import type { CSSObject } from '@emotion/core'\nimport { useTheme } from 'emotion-theming'\nimport React, { PureComponent, MutableRefObject } from 'react'\nimport Select, { components, createFilter } from 'react-select'\nimport type {\n  IndicatorComponentType,\n  IndicatorProps,\n  Props as SelectProps,\n  SelectComponentsConfig,\n  SingleValueProps as SingleValueComponentProps,\n  MenuListComponentProps,\n  OptionProps as OptionComponentProps\n} from 'react-select'\nimport RightTruncatedText from '../RightTruncatedText'\nimport type { Theme, ThemeProp } from '../ThemeProvider'\nimport { CreatableSelect, MenuList, MenuPortal, Option } from './components'\nimport type {\n  OptionRendererProps,\n  Options,\n  OptionType,\n  OptionValue\n} from './components'\nimport type { CreatableReactSelectProps } from './components/CreatableSelect'\nimport * as Elements from './elements'\nimport { getCustomStyles, getOptions } from './utils'\nimport isObject from 'lodash/isObject'\nimport type { SelectComponentStyles } from './types'\nimport variantProps from './variantProps'\nimport styled from '@emotion/styled'\n\nexport type StructuredOption = {\n  name?: string | null\n  value?: any\n  label?: string\n}\n\nexport type SelectComponentProps = {\n  /** Provide a custom dropdown arrow */\n  arrowIcon?: IndicatorComponentType<any>\n\n  /** Close the select menu when the user selects an option. If multi is true, then this defaults to false. */\n  closeMenuOnSelect?: boolean\n\n  /** Object of Style options to add to or override deeply nested react-select defaults: https://react-select.com/styles */\n  componentStyles?: SelectComponentStyles\n\n  /** Allow user to create values (enables searchable) */\n  creatable?: boolean\n\n  /**\n   * Render a custom format when creating a new value\n   */\n  creatableOptionRenderer?: (props: OptionRendererProps) => React.ReactNode\n\n  /** Custom components passed through */\n  customComponents?: SelectComponentsConfig<any>\n\n  /** Apply unique inline styles if dataGrid is true */\n  dataGrid?: boolean\n  /** Instrumentation */\n  'data-instrumentation'?: string\n\n  /** Select is disabled */\n  disabled?: boolean\n\n  /** Render an icon for a given option. */\n  getIconForOption?: (props: OptionRendererProps) => React.ReactNode\n\n  /**\n   * Function responsible for returning a name for a given option/value.\n   */\n  getLabelForOption?: (option: OptionValue) => string\n\n  /**\n   * Optional function responsible for returning an optgroup label for an option.\n   */\n  getOptgroupForOption?: (value?: OptionValue) => string\n\n  /**\n   * Function responsible for returning secondary text for a given single value.\n   */\n  getSingleValueSecondaryText?: (value?: string) => string\n\n  /** Set width of the menu based on option character length (approximate!), overrides menuWidth */\n  guessMenuWidth?: boolean\n\n  /** Form control's validity */\n  invalid?: boolean\n\n  /** Custom menu height */\n  maxHeight?: number\n\n  /** Custom menu width (typically the menu is the same width as the select element) */\n  menuWidth?: string\n\n  /** Enable selection of multiple values */\n  multi?: boolean\n\n  /** Uniquely identifies this form control. */\n  name: string\n\n  /** Override message for no results when searching */\n  noResultsMessage?: string\n\n  /**\n   * Callback triggered when user selects a new value.\n   */\n  onChange: (option: { name: string; value: any }) => void\n\n  /** Height of the option menu (in px) */\n  optionHeight?: number\n\n  /**\n   * Render a custom for every option\n   */\n  optionRenderer?: (props: OptionRendererProps) => React.ReactNode\n\n  /** Array of options to display in the select menu */\n  options: Options\n\n  /** Enable user search to filter options */\n  searchable?: boolean\n\n  /** Include OptGroup in search filter for children */\n  searchOptGroup?: boolean\n\n  /** Minimal styles to show selected value as text */\n  textOnly?: boolean\n\n  /**\n   * Gives ability to grab ref to Select.\n   * Only callbacks and mutable references are supported: if using `useRef()` do\n   * not forget to own the reference adding `null` as in\n   * `const ref = useRef<HTMLInputElement | null>(null)`.\n   */\n  selectRef?:\n    | ((instance: HTMLInputElement | null) => void)\n    | MutableRefObject<HTMLInputElement | null>\n\n  /* Style modifier */\n  style?: CSSObject\n\n  /** Selected value */\n  value?: number | string | Array<any>\n\n  /** Form Control warning is present */\n  warning?: boolean\n\n  /** Custom width passed through */\n  width?: string\n} & Omit<SelectProps, 'theme'>\n\ntype SelectComponentPropsOrCreatable =\n  | SelectComponentProps\n  | (SelectComponentProps & CreatableReactSelectProps)\n\n/**\n * Render a select component. Extra props are passed through to react-select.\n * See more options here: https://react-select.com/props\n */\nexport class SelectComponent extends PureComponent<\n  SelectComponentPropsOrCreatable & ThemeProp\n> {\n  static defaultProps = {\n    creatable: false,\n    creatableOptionRenderer: null,\n    customComponents: null,\n    'data-instrumentation': 'select',\n    getLabelForOption: (option: any) => option.label,\n    getOptgroupForOption: () => '',\n    onChange: () => {},\n    optionRenderer: null,\n    searchable: false,\n    searchOptGroup: false\n  }\n\n  _getValue = (structuredOptions: Array<StructuredOption | OptionValue>) => {\n    const { value, multi } = this.props\n\n    if (value == null) {\n      return value\n    }\n\n    if (multi) {\n      return Array.isArray(value)\n        ? value.map<any>(val => {\n            const currentOption = structuredOptions.find(option => {\n              if (isObject(option)) {\n                return option.value === val\n              }\n\n              return option === val\n            })\n            return currentOption || { value: val, label: val }\n          })\n        : []\n    } else {\n      const currentOption = structuredOptions.find(option => {\n        if (isObject(option)) {\n          return option.value === value\n        }\n\n        return option === value\n      })\n      if (currentOption) {\n        return currentOption\n      }\n    }\n    // if value is a falsy native data type but doesn't match an option then return value\n    if (!value) {\n      return value\n    }\n\n    // important for rendering arbitrary input not in the option list\n    return {\n      value,\n      label: value\n    }\n  }\n\n  _renderArrow: React.FC<IndicatorProps<any>> = ({\n    getStyles,\n    innerProps,\n    ...props\n  }) => (\n    <Elements.ArrowDownIcon\n      css={getStyles('dropdownIndicator', props)}\n      {...innerProps}\n    />\n  )\n\n  _renderMenuList: React.FC<MenuListComponentProps<OptionType>> = (\n    props: MenuListComponentProps<OptionType>\n  ) => (\n    <MenuList\n      {...props}\n      maxHeight={this.props.maxHeight}\n      theme={this.props.theme}\n      rowHeight={this.props.optionHeight}\n    />\n  )\n\n  _renderOption: React.FC<OptionComponentProps<any>> = props => (\n    <Option\n      {...props}\n      creatableOptionRenderer={this.props.creatableOptionRenderer}\n      getIconForOption={this.props.getIconForOption}\n      optionRenderer={this.props.optionRenderer}\n    />\n  )\n\n  _renderSingleValue: React.FC<SingleValueComponentProps<any>> = ({\n    children,\n    ...props\n  }) => {\n    const PrimaryLabel = styled('span')(({ theme }) => ({\n      marginRight: theme.space[1]\n    }))\n    const SecondaryLabel = styled('span')(({ theme }) => ({\n      color: theme.palette.neutral[9],\n      fontWeight: 600,\n      whiteSpace: 'nowrap',\n      overflow: 'hidden',\n      textOverflow: 'ellipsis'\n    }))\n    const secondaryText = this.props.getSingleValueSecondaryText\n      ? this.props.getSingleValueSecondaryText(props.data.value)\n      : null\n    const singleValue = secondaryText ? (\n      <RightTruncatedText\n        title={`${children} ${secondaryText}`}\n        text={\n          <>\n            <PrimaryLabel>{children}</PrimaryLabel>\n            <SecondaryLabel>{secondaryText}</SecondaryLabel>\n          </>\n        }\n      />\n    ) : (\n      <RightTruncatedText text={children} />\n    )\n    return (\n      <components.SingleValue {...props}>{singleValue}</components.SingleValue>\n    )\n  }\n\n  _onChange = (selected: StructuredOption | Array<StructuredOption>) => {\n    const { multi, name, onChange } = this.props\n    const value = multi\n      ? ((selected as Array<StructuredOption>) || []).map(\n          option => option.value\n        )\n      : (selected as StructuredOption).value\n    if (onChange) {\n      onChange({ name, value })\n    }\n  }\n\n  render() {\n    const {\n      arrowIcon,\n      creatable,\n      customComponents,\n      disabled,\n      'data-instrumentation': dataInstrumentation,\n      getLabelForOption = (option: any) => option.label,\n      getOptgroupForOption = () => '',\n      multi,\n      options,\n      componentStyles,\n      searchable,\n      selectRef,\n      theme,\n      searchOptGroup = false\n    } = this.props\n\n    const structuredOptions = getOptions({\n      options,\n      getLabelForOption,\n      getOptgroupForOption\n    })\n\n    const customStyles = getCustomStyles(\n      this.props,\n      structuredOptions,\n      componentStyles\n    )\n\n    const SelectComponent = creatable ? CreatableSelect : Select\n\n    const applySelectRef = ref => {\n      if (selectRef) {\n        if (typeof selectRef === 'function') {\n          selectRef(ref)\n        } else {\n          selectRef.current = ref\n        }\n      }\n    }\n\n    const injectInstrumentation = ref => {\n      const safeSelectRef = ref && (ref.select.select || ref.select)\n      if (safeSelectRef) {\n        safeSelectRef.controlRef.setAttribute('data-gs-c', this.props.name)\n        safeSelectRef.controlRef.setAttribute(\n          'data-instrumentation',\n          this.props['data-instrumentation']\n        )\n      }\n    }\n\n    return (\n      <SelectComponent\n        {...this.props}\n        data-instrumentation={dataInstrumentation}\n        captureMenuScroll={false}\n        components={{\n          DropdownIndicator: arrowIcon || this._renderArrow,\n          IndicatorSeparator: null,\n          MenuList: this._renderMenuList,\n          Option: this._renderOption,\n          MenuPortal,\n          SingleValue: this._renderSingleValue,\n          ...customComponents\n        }}\n        // defaultMenuIsOpen is not supported until CON-4380 is fixed.\n        defaultMenuIsOpen={false}\n        inputId={this.props.name}\n        isClearable={false}\n        isDisabled={disabled}\n        isMulti={multi}\n        closeMenuOnSelect={\n          this.props.closeMenuOnSelect !== undefined\n            ? this.props.closeMenuOnSelect\n            : !multi\n        }\n        isOptionDisabled={option =>\n          !!(option.disabled || (option.type && option.type === 'header'))\n        }\n        isSearchable={searchable || creatable}\n        // menuPlacement has to be auto for tethered Menu to work correctly.\n        menuPlacement=\"auto\"\n        menuPortalTarget={document.body}\n        onChange={this._onChange}\n        options={structuredOptions}\n        ref={ref => {\n          applySelectRef(ref)\n          injectInstrumentation(ref)\n        }}\n        styles={customStyles}\n        theme={defaultTheme => ({ ...defaultTheme, ...theme })}\n        value={this._getValue(structuredOptions)}\n        // When ignoreAccents is true, it causes a significant lag when options exceed 1000 items.\n        filterOption={createFilter({\n          ignoreAccents: false,\n          stringify: obj =>\n            `${obj.label} ${\n              (searchOptGroup && getOptgroupForOption(obj.value)) || ''\n            }`\n        })}\n      />\n    )\n  }\n}\n\nfunction WrappedComponent(props: SelectComponentPropsOrCreatable) {\n  const theme: Theme = useTheme()\n  return <SelectComponent {...props} theme={theme} />\n}\n\nWrappedComponent.Elements = Elements\nWrappedComponent.variantProps = variantProps\n\nexport default WrappedComponent\n"]} */");
141
141
 
142
142
  var SecondaryLabel = /*#__PURE__*/_styled('span', {
143
143
  target: "eus61bj1"
@@ -150,7 +150,7 @@ export var SelectComponent = /*#__PURE__*/function (_PureComponent) {
150
150
  overflow: 'hidden',
151
151
  textOverflow: 'ellipsis'
152
152
  };
153
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Select/Select.tsx"],"names":[],"mappings":"AA+P2B","file":"../../../src/Select/Select.tsx","sourcesContent":["import type { CSSObject } from '@emotion/core'\nimport { useTheme } from 'emotion-theming'\nimport React, { PureComponent, MutableRefObject } from 'react'\nimport Select, { components, createFilter } from 'react-select'\nimport type {\n  IndicatorComponentType,\n  IndicatorProps,\n  Props as SelectProps,\n  SelectComponentsConfig,\n  SingleValueProps as SingleValueComponentProps,\n  MenuListComponentProps,\n  OptionProps as OptionComponentProps\n} from 'react-select'\nimport RightTruncatedText from '../RightTruncatedText'\nimport type { Theme, ThemeProp } from '../ThemeProvider'\nimport { CreatableSelect, MenuList, MenuPortal, Option } from './components'\nimport type {\n  OptionRendererProps,\n  Options,\n  OptionType,\n  OptionValue\n} from './components'\nimport type { CreatableReactSelectProps } from './components/CreatableSelect'\nimport * as Elements from './elements'\nimport { getCustomStyles, getOptions } from './utils'\nimport isObject from 'lodash/isObject'\nimport type { SelectComponentStyles } from './types'\nimport variantProps from './variantProps'\nimport styled from '@emotion/styled'\n\nexport type StructuredOption = {\n  name?: string | null\n  value?: any\n  label?: string\n}\n\nexport type SelectComponentProps = {\n  /** Provide a custom dropdown arrow */\n  arrowIcon?: IndicatorComponentType<any>\n\n  /** Object of Style options to add to or override deeply nested react-select defaults: https://react-select.com/styles */\n  componentStyles?: SelectComponentStyles\n\n  /** Allow user to create values (enables searchable) */\n  creatable?: boolean\n\n  /**\n   * Render a custom format when creating a new value\n   */\n  creatableOptionRenderer?: (props: OptionRendererProps) => React.ReactNode\n\n  /** Custom components passed through */\n  customComponents?: SelectComponentsConfig<any>\n\n  /** Apply unique inline styles if dataGrid is true */\n  dataGrid?: boolean\n  /** Instrumentation */\n  'data-instrumentation'?: string\n\n  /** Select is disabled */\n  disabled?: boolean\n\n  /** Render an icon for a given option. */\n  getIconForOption?: (props: OptionRendererProps) => React.ReactNode\n\n  /**\n   * Function responsible for returning a name for a given option/value.\n   */\n  getLabelForOption?: (option: OptionValue) => string\n\n  /**\n   * Optional function responsible for returning an optgroup label for an option.\n   */\n  getOptgroupForOption?: (value?: OptionValue) => string\n\n  /**\n   * Function responsible for returning secondary text for a given single value.\n   */\n  getSingleValueSecondaryText?: (value?: string) => string\n\n  /** Set width of the menu based on option character length (approximate!), overrides menuWidth */\n  guessMenuWidth?: boolean\n\n  /** Form control's validity */\n  invalid?: boolean\n\n  /** Custom menu height */\n  maxHeight?: number\n\n  /** Custom menu width (typically the menu is the same width as the select element) */\n  menuWidth?: string\n\n  /** Enable selection of multiple values */\n  multi?: boolean\n\n  /** Uniquely identifies this form control. */\n  name: string\n\n  /** Override message for no results when searching */\n  noResultsMessage?: string\n\n  /**\n   * Callback triggered when user selects a new value.\n   */\n  onChange: (option: { name: string; value: any }) => void\n\n  /** Height of the option menu (in px) */\n  optionHeight?: number\n\n  /**\n   * Render a custom for every option\n   */\n  optionRenderer?: (props: OptionRendererProps) => React.ReactNode\n\n  /** Array of options to display in the select menu */\n  options: Options\n\n  /** Enable user search to filter options */\n  searchable?: boolean\n\n  /** Include OptGroup in search filter for children */\n  searchOptGroup?: boolean\n\n  /** Minimal styles to show selected value as text */\n  textOnly?: boolean\n\n  /**\n   * Gives ability to grab ref to Select.\n   * Only callbacks and mutable references are supported: if using `useRef()` do\n   * not forget to own the reference adding `null` as in\n   * `const ref = useRef<HTMLInputElement | null>(null)`.\n   */\n  selectRef?:\n    | ((instance: HTMLInputElement | null) => void)\n    | MutableRefObject<HTMLInputElement | null>\n\n  /* Style modifier */\n  style?: CSSObject\n\n  /** Selected value */\n  value?: number | string | Array<any>\n\n  /** Form Control warning is present */\n  warning?: boolean\n\n  /** Custom width passed through */\n  width?: string\n} & Omit<SelectProps, 'theme'>\n\ntype SelectComponentPropsOrCreatable =\n  | SelectComponentProps\n  | (SelectComponentProps & CreatableReactSelectProps)\n\n/**\n * Render a select component. Extra props are passed through to react-select.\n * See more options here: https://react-select.com/props\n */\nexport class SelectComponent extends PureComponent<\n  SelectComponentPropsOrCreatable & ThemeProp\n> {\n  static defaultProps = {\n    creatable: false,\n    creatableOptionRenderer: null,\n    customComponents: null,\n    'data-instrumentation': 'select',\n    getLabelForOption: (option: any) => option.label,\n    getOptgroupForOption: () => '',\n    onChange: () => {},\n    optionRenderer: null,\n    searchable: false,\n    searchOptGroup: false\n  }\n\n  _getValue = (structuredOptions: Array<StructuredOption | OptionValue>) => {\n    const { value, multi } = this.props\n\n    if (value == null) {\n      return value\n    }\n\n    if (multi) {\n      return Array.isArray(value)\n        ? value.map<any>(val => {\n            const currentOption = structuredOptions.find(option => {\n              if (isObject(option)) {\n                return option.value === val\n              }\n\n              return option === val\n            })\n            return currentOption || { value: val, label: val }\n          })\n        : []\n    } else {\n      const currentOption = structuredOptions.find(option => {\n        if (isObject(option)) {\n          return option.value === value\n        }\n\n        return option === value\n      })\n      if (currentOption) {\n        return currentOption\n      }\n    }\n    // if value is a falsy native data type but doesn't match an option then return value\n    if (!value) {\n      return value\n    }\n\n    // important for rendering arbitrary input not in the option list\n    return {\n      value,\n      label: value\n    }\n  }\n\n  _renderArrow: React.FC<IndicatorProps<any>> = ({\n    getStyles,\n    innerProps,\n    ...props\n  }) => (\n    <Elements.ArrowDownIcon\n      css={getStyles('dropdownIndicator', props)}\n      {...innerProps}\n    />\n  )\n\n  _renderMenuList: React.FC<MenuListComponentProps<OptionType>> = (\n    props: MenuListComponentProps<OptionType>\n  ) => (\n    <MenuList\n      {...props}\n      maxHeight={this.props.maxHeight}\n      theme={this.props.theme}\n      rowHeight={this.props.optionHeight}\n    />\n  )\n\n  _renderOption: React.FC<OptionComponentProps<any>> = props => (\n    <Option\n      {...props}\n      creatableOptionRenderer={this.props.creatableOptionRenderer}\n      getIconForOption={this.props.getIconForOption}\n      optionRenderer={this.props.optionRenderer}\n    />\n  )\n\n  _renderSingleValue: React.FC<SingleValueComponentProps<any>> = ({\n    children,\n    ...props\n  }) => {\n    const PrimaryLabel = styled('span')(({ theme }) => ({\n      marginRight: theme.space[1]\n    }))\n    const SecondaryLabel = styled('span')(({ theme }) => ({\n      color: theme.palette.neutral[9],\n      fontWeight: 600,\n      whiteSpace: 'nowrap',\n      overflow: 'hidden',\n      textOverflow: 'ellipsis'\n    }))\n    const secondaryText = this.props.getSingleValueSecondaryText\n      ? this.props.getSingleValueSecondaryText(props.data.value)\n      : null\n    const singleValue = secondaryText ? (\n      <RightTruncatedText\n        title={`${children} ${secondaryText}`}\n        text={\n          <>\n            <PrimaryLabel>{children}</PrimaryLabel>\n            <SecondaryLabel>{secondaryText}</SecondaryLabel>\n          </>\n        }\n      />\n    ) : (\n      <RightTruncatedText text={children} />\n    )\n    return (\n      <components.SingleValue {...props}>{singleValue}</components.SingleValue>\n    )\n  }\n\n  _onChange = (selected: StructuredOption | Array<StructuredOption>) => {\n    const { multi, name, onChange } = this.props\n    const value = multi\n      ? ((selected as Array<StructuredOption>) || []).map(\n          option => option.value\n        )\n      : (selected as StructuredOption).value\n    if (onChange) {\n      onChange({ name, value })\n    }\n  }\n\n  render() {\n    const {\n      arrowIcon,\n      creatable,\n      customComponents,\n      disabled,\n      'data-instrumentation': dataInstrumentation,\n      getLabelForOption = (option: any) => option.label,\n      getOptgroupForOption = () => '',\n      multi,\n      options,\n      componentStyles,\n      searchable,\n      selectRef,\n      theme,\n      searchOptGroup = false\n    } = this.props\n\n    const structuredOptions = getOptions({\n      options,\n      getLabelForOption,\n      getOptgroupForOption\n    })\n\n    const customStyles = getCustomStyles(\n      this.props,\n      structuredOptions,\n      componentStyles\n    )\n\n    const SelectComponent = creatable ? CreatableSelect : Select\n\n    const applySelectRef = ref => {\n      if (selectRef) {\n        if (typeof selectRef === 'function') {\n          selectRef(ref)\n        } else {\n          selectRef.current = ref\n        }\n      }\n    }\n\n    const injectInstrumentation = ref => {\n      const safeSelectRef = ref && (ref.select.select || ref.select)\n      if (safeSelectRef) {\n        safeSelectRef.controlRef.setAttribute('data-gs-c', this.props.name)\n        safeSelectRef.controlRef.setAttribute(\n          'data-instrumentation',\n          this.props['data-instrumentation']\n        )\n      }\n    }\n\n    return (\n      <SelectComponent\n        {...this.props}\n        data-instrumentation={dataInstrumentation}\n        captureMenuScroll={false}\n        components={{\n          DropdownIndicator: arrowIcon || this._renderArrow,\n          IndicatorSeparator: null,\n          MenuList: this._renderMenuList,\n          Option: this._renderOption,\n          MenuPortal,\n          SingleValue: this._renderSingleValue,\n          ...customComponents\n        }}\n        // defaultMenuIsOpen is not supported until CON-4380 is fixed.\n        defaultMenuIsOpen={false}\n        inputId={this.props.name}\n        isClearable={false}\n        isDisabled={disabled}\n        isMulti={multi}\n        closeMenuOnSelect={!multi}\n        isOptionDisabled={option =>\n          !!(option.disabled || (option.type && option.type === 'header'))\n        }\n        isSearchable={searchable || creatable}\n        // menuPlacement has to be auto for tethered Menu to work correctly.\n        menuPlacement=\"auto\"\n        menuPortalTarget={document.body}\n        onChange={this._onChange}\n        options={structuredOptions}\n        ref={ref => {\n          applySelectRef(ref)\n          injectInstrumentation(ref)\n        }}\n        styles={customStyles}\n        theme={defaultTheme => ({ ...defaultTheme, ...theme })}\n        value={this._getValue(structuredOptions)}\n        // When ignoreAccents is true, it causes a significant lag when options exceed 1000 items.\n        filterOption={createFilter({\n          ignoreAccents: false,\n          stringify: obj =>\n            `${obj.label} ${\n              (searchOptGroup && getOptgroupForOption(obj.value)) || ''\n            }`\n        })}\n      />\n    )\n  }\n}\n\nfunction WrappedComponent(props: SelectComponentPropsOrCreatable) {\n  const theme: Theme = useTheme()\n  return <SelectComponent {...props} theme={theme} />\n}\n\nWrappedComponent.Elements = Elements\nWrappedComponent.variantProps = variantProps\n\nexport default WrappedComponent\n"]} */");
153
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Select/Select.tsx"],"names":[],"mappings":"AAkQ2B","file":"../../../src/Select/Select.tsx","sourcesContent":["import type { CSSObject } from '@emotion/core'\nimport { useTheme } from 'emotion-theming'\nimport React, { PureComponent, MutableRefObject } from 'react'\nimport Select, { components, createFilter } from 'react-select'\nimport type {\n  IndicatorComponentType,\n  IndicatorProps,\n  Props as SelectProps,\n  SelectComponentsConfig,\n  SingleValueProps as SingleValueComponentProps,\n  MenuListComponentProps,\n  OptionProps as OptionComponentProps\n} from 'react-select'\nimport RightTruncatedText from '../RightTruncatedText'\nimport type { Theme, ThemeProp } from '../ThemeProvider'\nimport { CreatableSelect, MenuList, MenuPortal, Option } from './components'\nimport type {\n  OptionRendererProps,\n  Options,\n  OptionType,\n  OptionValue\n} from './components'\nimport type { CreatableReactSelectProps } from './components/CreatableSelect'\nimport * as Elements from './elements'\nimport { getCustomStyles, getOptions } from './utils'\nimport isObject from 'lodash/isObject'\nimport type { SelectComponentStyles } from './types'\nimport variantProps from './variantProps'\nimport styled from '@emotion/styled'\n\nexport type StructuredOption = {\n  name?: string | null\n  value?: any\n  label?: string\n}\n\nexport type SelectComponentProps = {\n  /** Provide a custom dropdown arrow */\n  arrowIcon?: IndicatorComponentType<any>\n\n  /** Close the select menu when the user selects an option. If multi is true, then this defaults to false. */\n  closeMenuOnSelect?: boolean\n\n  /** Object of Style options to add to or override deeply nested react-select defaults: https://react-select.com/styles */\n  componentStyles?: SelectComponentStyles\n\n  /** Allow user to create values (enables searchable) */\n  creatable?: boolean\n\n  /**\n   * Render a custom format when creating a new value\n   */\n  creatableOptionRenderer?: (props: OptionRendererProps) => React.ReactNode\n\n  /** Custom components passed through */\n  customComponents?: SelectComponentsConfig<any>\n\n  /** Apply unique inline styles if dataGrid is true */\n  dataGrid?: boolean\n  /** Instrumentation */\n  'data-instrumentation'?: string\n\n  /** Select is disabled */\n  disabled?: boolean\n\n  /** Render an icon for a given option. */\n  getIconForOption?: (props: OptionRendererProps) => React.ReactNode\n\n  /**\n   * Function responsible for returning a name for a given option/value.\n   */\n  getLabelForOption?: (option: OptionValue) => string\n\n  /**\n   * Optional function responsible for returning an optgroup label for an option.\n   */\n  getOptgroupForOption?: (value?: OptionValue) => string\n\n  /**\n   * Function responsible for returning secondary text for a given single value.\n   */\n  getSingleValueSecondaryText?: (value?: string) => string\n\n  /** Set width of the menu based on option character length (approximate!), overrides menuWidth */\n  guessMenuWidth?: boolean\n\n  /** Form control's validity */\n  invalid?: boolean\n\n  /** Custom menu height */\n  maxHeight?: number\n\n  /** Custom menu width (typically the menu is the same width as the select element) */\n  menuWidth?: string\n\n  /** Enable selection of multiple values */\n  multi?: boolean\n\n  /** Uniquely identifies this form control. */\n  name: string\n\n  /** Override message for no results when searching */\n  noResultsMessage?: string\n\n  /**\n   * Callback triggered when user selects a new value.\n   */\n  onChange: (option: { name: string; value: any }) => void\n\n  /** Height of the option menu (in px) */\n  optionHeight?: number\n\n  /**\n   * Render a custom for every option\n   */\n  optionRenderer?: (props: OptionRendererProps) => React.ReactNode\n\n  /** Array of options to display in the select menu */\n  options: Options\n\n  /** Enable user search to filter options */\n  searchable?: boolean\n\n  /** Include OptGroup in search filter for children */\n  searchOptGroup?: boolean\n\n  /** Minimal styles to show selected value as text */\n  textOnly?: boolean\n\n  /**\n   * Gives ability to grab ref to Select.\n   * Only callbacks and mutable references are supported: if using `useRef()` do\n   * not forget to own the reference adding `null` as in\n   * `const ref = useRef<HTMLInputElement | null>(null)`.\n   */\n  selectRef?:\n    | ((instance: HTMLInputElement | null) => void)\n    | MutableRefObject<HTMLInputElement | null>\n\n  /* Style modifier */\n  style?: CSSObject\n\n  /** Selected value */\n  value?: number | string | Array<any>\n\n  /** Form Control warning is present */\n  warning?: boolean\n\n  /** Custom width passed through */\n  width?: string\n} & Omit<SelectProps, 'theme'>\n\ntype SelectComponentPropsOrCreatable =\n  | SelectComponentProps\n  | (SelectComponentProps & CreatableReactSelectProps)\n\n/**\n * Render a select component. Extra props are passed through to react-select.\n * See more options here: https://react-select.com/props\n */\nexport class SelectComponent extends PureComponent<\n  SelectComponentPropsOrCreatable & ThemeProp\n> {\n  static defaultProps = {\n    creatable: false,\n    creatableOptionRenderer: null,\n    customComponents: null,\n    'data-instrumentation': 'select',\n    getLabelForOption: (option: any) => option.label,\n    getOptgroupForOption: () => '',\n    onChange: () => {},\n    optionRenderer: null,\n    searchable: false,\n    searchOptGroup: false\n  }\n\n  _getValue = (structuredOptions: Array<StructuredOption | OptionValue>) => {\n    const { value, multi } = this.props\n\n    if (value == null) {\n      return value\n    }\n\n    if (multi) {\n      return Array.isArray(value)\n        ? value.map<any>(val => {\n            const currentOption = structuredOptions.find(option => {\n              if (isObject(option)) {\n                return option.value === val\n              }\n\n              return option === val\n            })\n            return currentOption || { value: val, label: val }\n          })\n        : []\n    } else {\n      const currentOption = structuredOptions.find(option => {\n        if (isObject(option)) {\n          return option.value === value\n        }\n\n        return option === value\n      })\n      if (currentOption) {\n        return currentOption\n      }\n    }\n    // if value is a falsy native data type but doesn't match an option then return value\n    if (!value) {\n      return value\n    }\n\n    // important for rendering arbitrary input not in the option list\n    return {\n      value,\n      label: value\n    }\n  }\n\n  _renderArrow: React.FC<IndicatorProps<any>> = ({\n    getStyles,\n    innerProps,\n    ...props\n  }) => (\n    <Elements.ArrowDownIcon\n      css={getStyles('dropdownIndicator', props)}\n      {...innerProps}\n    />\n  )\n\n  _renderMenuList: React.FC<MenuListComponentProps<OptionType>> = (\n    props: MenuListComponentProps<OptionType>\n  ) => (\n    <MenuList\n      {...props}\n      maxHeight={this.props.maxHeight}\n      theme={this.props.theme}\n      rowHeight={this.props.optionHeight}\n    />\n  )\n\n  _renderOption: React.FC<OptionComponentProps<any>> = props => (\n    <Option\n      {...props}\n      creatableOptionRenderer={this.props.creatableOptionRenderer}\n      getIconForOption={this.props.getIconForOption}\n      optionRenderer={this.props.optionRenderer}\n    />\n  )\n\n  _renderSingleValue: React.FC<SingleValueComponentProps<any>> = ({\n    children,\n    ...props\n  }) => {\n    const PrimaryLabel = styled('span')(({ theme }) => ({\n      marginRight: theme.space[1]\n    }))\n    const SecondaryLabel = styled('span')(({ theme }) => ({\n      color: theme.palette.neutral[9],\n      fontWeight: 600,\n      whiteSpace: 'nowrap',\n      overflow: 'hidden',\n      textOverflow: 'ellipsis'\n    }))\n    const secondaryText = this.props.getSingleValueSecondaryText\n      ? this.props.getSingleValueSecondaryText(props.data.value)\n      : null\n    const singleValue = secondaryText ? (\n      <RightTruncatedText\n        title={`${children} ${secondaryText}`}\n        text={\n          <>\n            <PrimaryLabel>{children}</PrimaryLabel>\n            <SecondaryLabel>{secondaryText}</SecondaryLabel>\n          </>\n        }\n      />\n    ) : (\n      <RightTruncatedText text={children} />\n    )\n    return (\n      <components.SingleValue {...props}>{singleValue}</components.SingleValue>\n    )\n  }\n\n  _onChange = (selected: StructuredOption | Array<StructuredOption>) => {\n    const { multi, name, onChange } = this.props\n    const value = multi\n      ? ((selected as Array<StructuredOption>) || []).map(\n          option => option.value\n        )\n      : (selected as StructuredOption).value\n    if (onChange) {\n      onChange({ name, value })\n    }\n  }\n\n  render() {\n    const {\n      arrowIcon,\n      creatable,\n      customComponents,\n      disabled,\n      'data-instrumentation': dataInstrumentation,\n      getLabelForOption = (option: any) => option.label,\n      getOptgroupForOption = () => '',\n      multi,\n      options,\n      componentStyles,\n      searchable,\n      selectRef,\n      theme,\n      searchOptGroup = false\n    } = this.props\n\n    const structuredOptions = getOptions({\n      options,\n      getLabelForOption,\n      getOptgroupForOption\n    })\n\n    const customStyles = getCustomStyles(\n      this.props,\n      structuredOptions,\n      componentStyles\n    )\n\n    const SelectComponent = creatable ? CreatableSelect : Select\n\n    const applySelectRef = ref => {\n      if (selectRef) {\n        if (typeof selectRef === 'function') {\n          selectRef(ref)\n        } else {\n          selectRef.current = ref\n        }\n      }\n    }\n\n    const injectInstrumentation = ref => {\n      const safeSelectRef = ref && (ref.select.select || ref.select)\n      if (safeSelectRef) {\n        safeSelectRef.controlRef.setAttribute('data-gs-c', this.props.name)\n        safeSelectRef.controlRef.setAttribute(\n          'data-instrumentation',\n          this.props['data-instrumentation']\n        )\n      }\n    }\n\n    return (\n      <SelectComponent\n        {...this.props}\n        data-instrumentation={dataInstrumentation}\n        captureMenuScroll={false}\n        components={{\n          DropdownIndicator: arrowIcon || this._renderArrow,\n          IndicatorSeparator: null,\n          MenuList: this._renderMenuList,\n          Option: this._renderOption,\n          MenuPortal,\n          SingleValue: this._renderSingleValue,\n          ...customComponents\n        }}\n        // defaultMenuIsOpen is not supported until CON-4380 is fixed.\n        defaultMenuIsOpen={false}\n        inputId={this.props.name}\n        isClearable={false}\n        isDisabled={disabled}\n        isMulti={multi}\n        closeMenuOnSelect={\n          this.props.closeMenuOnSelect !== undefined\n            ? this.props.closeMenuOnSelect\n            : !multi\n        }\n        isOptionDisabled={option =>\n          !!(option.disabled || (option.type && option.type === 'header'))\n        }\n        isSearchable={searchable || creatable}\n        // menuPlacement has to be auto for tethered Menu to work correctly.\n        menuPlacement=\"auto\"\n        menuPortalTarget={document.body}\n        onChange={this._onChange}\n        options={structuredOptions}\n        ref={ref => {\n          applySelectRef(ref)\n          injectInstrumentation(ref)\n        }}\n        styles={customStyles}\n        theme={defaultTheme => ({ ...defaultTheme, ...theme })}\n        value={this._getValue(structuredOptions)}\n        // When ignoreAccents is true, it causes a significant lag when options exceed 1000 items.\n        filterOption={createFilter({\n          ignoreAccents: false,\n          stringify: obj =>\n            `${obj.label} ${\n              (searchOptGroup && getOptgroupForOption(obj.value)) || ''\n            }`\n        })}\n      />\n    )\n  }\n}\n\nfunction WrappedComponent(props: SelectComponentPropsOrCreatable) {\n  const theme: Theme = useTheme()\n  return <SelectComponent {...props} theme={theme} />\n}\n\nWrappedComponent.Elements = Elements\nWrappedComponent.variantProps = variantProps\n\nexport default WrappedComponent\n"]} */");
154
154
 
155
155
  var secondaryText = _this.props.getSingleValueSecondaryText ? _this.props.getSingleValueSecondaryText(props.data.value) : null;
156
156
  var singleValue = secondaryText ? ___EmotionJSX(RightTruncatedText, {
@@ -266,7 +266,7 @@ export var SelectComponent = /*#__PURE__*/function (_PureComponent) {
266
266
  isClearable: false,
267
267
  isDisabled: disabled,
268
268
  isMulti: multi,
269
- closeMenuOnSelect: !multi,
269
+ closeMenuOnSelect: this.props.closeMenuOnSelect !== undefined ? this.props.closeMenuOnSelect : !multi,
270
270
  isOptionDisabled: function isOptionDisabled(option) {
271
271
  return !!(option.disabled || option.type && option.type === 'header');
272
272
  },
@@ -5,8 +5,7 @@ if (typeof window !== "undefined" && !window.gs) window.gs = function () {};
5
5
  if (typeof window !== "undefined" && !window.gsC) window.gsC = function () {};
6
6
  import { useTheme, withTheme } from 'emotion-theming';
7
7
  import React from 'react';
8
- import { VictoryArea, VictoryAxis, VictoryChart, VictoryGroup, VictoryScatter // @ts-ignore: Victory's types are incomplete, VictoryStyleObject is, in fact, exported
9
- , VictoryVoronoiContainer } from 'victory';
8
+ import { VictoryArea, VictoryAxis, VictoryChart, VictoryGroup, VictoryScatter, VictoryVoronoiContainer } from 'victory';
10
9
  import { chartUtils, Container, Defs, Noop, Tooltip } from '../ChartPrimitives';
11
10
 
12
11
  function AreaChart(_ref) {
package/package.json CHANGED
@@ -1,9 +1,10 @@
1
1
  {
2
2
  "name": "td-stylekit",
3
- "version": "24.0.3",
3
+ "version": "24.4.0",
4
4
  "main": "dist/es/index.js",
5
5
  "module": "dist/es/index.js",
6
6
  "types": "dist/es/index.d.ts",
7
+ "license": "SEE LICENSE IN LICENSE",
7
8
  "sideEffects": false,
8
9
  "scripts": {
9
10
  "prebuild": "rimraf dist",
@@ -15,19 +16,18 @@
15
16
  "docs:start": "start-storybook --docs --port 9001 --config-dir .storybook --static-dir docs/assets",
16
17
  "typescript": "tsc --noEmit -p .",
17
18
  "format": "prettier --write --ignore-path .gitignore '**/*.{ts,tsx,js,json}'",
18
- "build:icons": "./bin/build-icons > dist/es/Icon/types.js",
19
- "build:icons:types": "./bin/build-icons types > src/Icon/staticTypes.ts",
19
+ "build:icons": "node bin/icons/build.js > dist/es/Icon/types.js",
20
+ "build:icons:types": "bin/icons/build.js types > src/Icon/staticTypes.ts",
20
21
  "build:types": "tsc --declaration --emitDeclarationOnly --declarationMap && cp -r dist/es/src/* dist/es/",
21
22
  "lint": "eslint . --ext .js,.ts,.tsx",
22
23
  "release": "semantic-release",
23
24
  "start": "yarn docs:start",
24
25
  "tdd": "yarn test --watch",
25
26
  "test:dependencies": "depcruise --config .dependency-cruiser.js .",
26
- "test:icons": "./bin/build-icons-test",
27
- "test:visual-update": "update=true ./bin/visual-regression-test",
28
- "test:visual": "./bin/visual-regression-test",
29
- "test:visual-ci": "./bin/runVisualRegressionTest.sh",
30
- "test": "jest --env=jsdom"
27
+ "test:icons": "bin/icons/buildTest.ts",
28
+ "test:visual-regression": "bin/visual-regression/test.ts",
29
+ "test": "jest --env=jsdom",
30
+ "download:snapshots": "bin/visual-regression/downloadSnapshots.ts"
31
31
  },
32
32
  "dependencies": {
33
33
  "@babel/runtime": "^7.11.2",
@@ -106,6 +106,7 @@
106
106
  "@testing-library/jest-dom": "^5.11.8",
107
107
  "@testing-library/react": "^11.2.2",
108
108
  "@testing-library/user-event": "^12.6.0",
109
+ "ts-node": "^10.2.1",
109
110
  "@types/jest": "^25.1.3",
110
111
  "@types/lodash.clamp": "^4.0.6",
111
112
  "@types/lodash.curry": "^4.1.6",
@@ -139,6 +140,7 @@
139
140
  "babel-plugin-require-context-hook": "^1.0.0",
140
141
  "babel-preset-react-app": "^9.0.2",
141
142
  "cheerio": "^1.0.0-rc.3",
143
+ "commander": "^6.0.0",
142
144
  "core-js": "^3.2.1",
143
145
  "cross-env": "^6.0.3",
144
146
  "danger": "^9.2.1",
@@ -282,7 +284,10 @@
282
284
  ],
283
285
  "parser": "@typescript-eslint/parser",
284
286
  "parserOptions": {
285
- "project": "./tsconfig.json"
287
+ "project": [
288
+ "./tsconfig.json",
289
+ "./bin/tsconfig.json"
290
+ ]
286
291
  },
287
292
  "plugins": [
288
293
  "@typescript-eslint",
@@ -347,7 +352,14 @@
347
352
  "arrowParens": "avoid",
348
353
  "semi": false,
349
354
  "singleQuote": true,
350
- "trailingComma": "none"
355
+ "trailingComma": "none",
356
+ "overrides": [
357
+ {
358
+ "files": [
359
+ "*/**"
360
+ ]
361
+ }
362
+ ]
351
363
  },
352
364
  "husky": {
353
365
  "hooks": {
package/tsconfig.json CHANGED
@@ -24,7 +24,8 @@
24
24
  "allowSyntheticDefaultImports": true,
25
25
  "downlevelIteration": true,
26
26
  "importsNotUsedAsValues": "error",
27
- "isolatedModules": true
27
+ "isolatedModules": true,
28
+ "esModuleInterop": true
28
29
  },
29
30
  "files": ["src/index.ts"],
30
31
  "include": ["src/**/*", "types/**/*", "docs/**/*"],
package/Dockerfile DELETED
@@ -1,51 +0,0 @@
1
- FROM ubuntu:xenial
2
- ENV LANG en_US.UTF-8
3
-
4
- WORKDIR /tmp/stylekit
5
-
6
- RUN apt-get update && \
7
- apt-get install -yq libgconf-2-4 \
8
- gconf-service libasound2 libatk1.0-0 libc6 libcairo2 libcups2 libdbus-1-3 libexpat1 libfontconfig1 \
9
- libgcc1 libgconf-2-4 libgdk-pixbuf2.0-0 libglib2.0-0 libgtk-3-0 libnspr4 libpango-1.0-0 \
10
- libpangocairo-1.0-0 libstdc++6 libx11-6 libx11-xcb1 libxcb1 libxcomposite1 libxcursor1 libxdamage1 \
11
- libxext6 libxfixes3 libxi6 libxrandr2 libxrender1 libxss1 libxtst6 ca-certificates fonts-liberation \
12
- libappindicator1 libnss3 lsb-release xdg-utils && \
13
- apt-get update && \
14
- apt-get install -y wget curl --no-install-recommends && \
15
- wget --no-check-certificate -q -O - https://dl-ssl.google.com/linux/linux_signing_key.pub | apt-key add - && \
16
- sh -c 'echo "deb [arch=amd64] http://dl.google.com/linux/chrome/deb/ stable main" >> /etc/apt/sources.list.d/google.list' && \
17
- apt-get update && \
18
- apt-get install -y google-chrome-unstable fonts-ipafont-gothic fonts-wqy-zenhei fonts-thai-tlwg fonts-kacst ttf-freefont --no-install-recommends && \
19
- rm -rf /var/lib/apt/lists/* && \
20
- rm -rf /src/*.deb
21
-
22
- ENV NODEJS_VERSION 12.10.0
23
- ENV PATH="/root/.nvm/versions/node/v${NODEJS_VERSION}/bin:${PATH}"
24
- RUN cd /tmp && wget https://raw.githubusercontent.com/creationix/nvm/v0.33.9/install.sh && \
25
- echo "8ed3356ae40f0d6627eea2aaa21910771d2f95af43b97f4a7d1b220d8b72d6da /tmp/install.sh" | sha256sum -c - && \
26
- bash /tmp/install.sh && \
27
- bash -c "source /root/.nvm/nvm.sh && nvm install $NODEJS_VERSION"
28
-
29
- ENV YARN_VERSION 1.19.0
30
- RUN set -ex \
31
- && for key in \
32
- 6A010C5166006599AA17F08146C2130DFD2497F5 \
33
- ; do \
34
- gpg --keyserver hkp://p80.pool.sks-keyservers.net:80 --recv-keys "$key" || \
35
- gpg --keyserver hkp://ipv4.pool.sks-keyservers.net --recv-keys "$key" || \
36
- gpg --keyserver hkp://pgp.mit.edu:80 --recv-keys "$key" ; \
37
- done \
38
- && curl -fSLO --compressed "https://yarnpkg.com/downloads/$YARN_VERSION/yarn-v$YARN_VERSION.tar.gz" \
39
- && curl -fSLO --compressed "https://yarnpkg.com/downloads/$YARN_VERSION/yarn-v$YARN_VERSION.tar.gz.asc" \
40
- && gpg --batch --verify yarn-v$YARN_VERSION.tar.gz.asc yarn-v$YARN_VERSION.tar.gz \
41
- && mkdir -p /opt \
42
- && tar -xzf yarn-v$YARN_VERSION.tar.gz -C /opt/ \
43
- && ln -s /opt/yarn-v$YARN_VERSION/bin/yarn /usr/local/bin/yarn \
44
- && ln -s /opt/yarn-v$YARN_VERSION/bin/yarnpkg /usr/local/bin/yarnpkg \
45
- && rm yarn-v$YARN_VERSION.tar.gz.asc yarn-v$YARN_VERSION.tar.gz
46
-
47
- COPY . .
48
-
49
- RUN bash -c "source /root/.nvm/nvm.sh && yarn"
50
-
51
- CMD [ "yarn", "docs:start", "--quiet", "--ci" ]