@dktunited-techoff/techoff-suite-ui 1.10.12 → 1.11.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 (36) hide show
  1. package/esm/components/TsTabs/TsTabs.js +15 -14
  2. package/esm/components/TsTabs/TsTabs.js.map +1 -1
  3. package/esm/components/TsTabs/__stories__/TsTabs.stories.mdx +3 -2
  4. package/esm/index.d.ts +1 -0
  5. package/esm/index.js +1 -0
  6. package/esm/index.js.map +1 -1
  7. package/esm/layouts/TsSearchHeader/TsSearchHeader.css +98 -0
  8. package/esm/layouts/TsSearchHeader/TsSearchHeader.d.ts +5 -0
  9. package/esm/layouts/TsSearchHeader/TsSearchHeader.js +25 -0
  10. package/esm/layouts/TsSearchHeader/TsSearchHeader.js.map +1 -0
  11. package/esm/layouts/TsSearchHeader/TsSearchHeader.types.d.ts +14 -0
  12. package/esm/layouts/TsSearchHeader/TsSearchHeader.types.js +2 -0
  13. package/esm/layouts/TsSearchHeader/TsSearchHeader.types.js.map +1 -0
  14. package/esm/layouts/TsSearchHeader/__stories__/TsSearchHeader.stories.mdx +39 -0
  15. package/lib/components/TsTabs/TsTabs.js +15 -14
  16. package/lib/components/TsTabs/TsTabs.js.map +1 -1
  17. package/lib/components/TsTabs/__stories__/TsTabs.stories.mdx +3 -2
  18. package/lib/index.d.ts +1 -0
  19. package/lib/index.js +1 -0
  20. package/lib/index.js.map +1 -1
  21. package/lib/layouts/TsSearchHeader/TsSearchHeader.css +98 -0
  22. package/lib/layouts/TsSearchHeader/TsSearchHeader.d.ts +5 -0
  23. package/lib/layouts/TsSearchHeader/TsSearchHeader.js +30 -0
  24. package/lib/layouts/TsSearchHeader/TsSearchHeader.js.map +1 -0
  25. package/lib/layouts/TsSearchHeader/TsSearchHeader.types.d.ts +14 -0
  26. package/lib/layouts/TsSearchHeader/TsSearchHeader.types.js +3 -0
  27. package/lib/layouts/TsSearchHeader/TsSearchHeader.types.js.map +1 -0
  28. package/lib/layouts/TsSearchHeader/__stories__/TsSearchHeader.stories.mdx +39 -0
  29. package/package.json +1 -1
  30. package/src/components/TsTabs/TsTabs.tsx +17 -17
  31. package/src/components/TsTabs/__stories__/TsTabs.stories.mdx +3 -2
  32. package/src/index.ts +1 -0
  33. package/src/layouts/TsSearchHeader/TsSearchHeader.css +98 -0
  34. package/src/layouts/TsSearchHeader/TsSearchHeader.tsx +58 -0
  35. package/src/layouts/TsSearchHeader/TsSearchHeader.types.ts +11 -0
  36. package/src/layouts/TsSearchHeader/__stories__/TsSearchHeader.stories.mdx +39 -0
@@ -8,11 +8,15 @@ export const TsTabs = ({ value, tabs }) => {
8
8
  const [renderedElement, setRenderedElement] = useState();
9
9
  // ########
10
10
  // Handlers
11
- const handleSelectTab = (tab, type) => {
12
- if (type === 'main')
11
+ const handleSelectTab = (e, tab, type) => {
12
+ e.stopPropagation();
13
+ if (type === 'main') {
13
14
  setSelectedTab(tab);
14
- else if (type === 'sub')
15
+ setSelectedSubTab(tab.subTabs && tab.subTabs[0]);
16
+ }
17
+ else if (type === 'sub') {
15
18
  setSelectedSubTab(tab);
19
+ }
16
20
  tab.onClick?.();
17
21
  };
18
22
  // #########
@@ -22,6 +26,10 @@ export const TsTabs = ({ value, tabs }) => {
22
26
  const tab = tabs.find(t => t.id === value);
23
27
  if (tab) {
24
28
  setSelectedTab(tab);
29
+ if (tab.subTabs)
30
+ setSelectedSubTab(tab.subTabs[0]);
31
+ else
32
+ setSelectedSubTab(undefined);
25
33
  }
26
34
  else {
27
35
  const tabWithSubTab = tabs.find(t => t.subTabs?.find(st => st.id === value));
@@ -37,18 +45,11 @@ export const TsTabs = ({ value, tabs }) => {
37
45
  }
38
46
  }, [value]);
39
47
  useEffect(() => {
40
- if (selectedTab.subTabs) {
41
- setSelectedSubTab(selectedTab.subTabs[0]);
42
- }
43
- else {
44
- setSelectedSubTab(undefined);
48
+ if (selectedTab && !selectedSubTab)
45
49
  setRenderedElement(selectedTab.element);
46
- }
47
- }, [selectedTab]);
48
- useEffect(() => {
49
50
  if (selectedSubTab)
50
51
  setRenderedElement(selectedSubTab.element);
51
- }, [selectedSubTab]);
52
+ }, [selectedTab, selectedSubTab]);
52
53
  // #########
53
54
  // Rendering
54
55
  return (React.createElement("div", { className: "ts-tabs" },
@@ -58,13 +59,13 @@ export const TsTabs = ({ value, tabs }) => {
58
59
  ts-tabs-item
59
60
  ${tab.id === selectedTab.id ? 'ts-tabs-item--selected' : ''}
60
61
  ${tab.disabled ? 'ts-tabs-item--disabled' : ''}
61
- `, onClick: () => !tab.disabled && handleSelectTab(tab, 'main') },
62
+ `, onClick: e => !tab.disabled && handleSelectTab(e, tab, 'main') },
62
63
  tab.icon && (React.createElement("div", { className: "ts-tabs-item--icon" },
63
64
  React.createElement(TsIcon, { name: tab.icon }))),
64
65
  React.createElement("div", { className: "ts-tabs-item--label" }, tab.label),
65
66
  tab.id === selectedTab.id && React.createElement("div", { className: "ts-tabs-item--selected-pin" }),
66
67
  tab.id === selectedTab.id &&
67
- tab.subTabs?.map(subTab => (React.createElement("div", { key: subTab.id, className: "ts-tabs-sub-item", onClick: () => !subTab.disabled && handleSelectTab(subTab, 'sub') },
68
+ tab.subTabs?.map(subTab => (React.createElement("div", { key: subTab.id, className: "ts-tabs-sub-item", onClick: e => !subTab.disabled && handleSelectTab(e, subTab, 'sub') },
68
69
  React.createElement(TsIcon, { name: "chevron-right" }),
69
70
  React.createElement("div", { className: `
70
71
  ts-tabs-sub-item--label
@@ -1 +1 @@
1
- {"version":3,"file":"TsTabs.js","sourceRoot":"","sources":["../../../src/components/TsTabs/TsTabs.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"TsTabs.js","sourceRoot":"","sources":["../../../src/components/TsTabs/TsTabs.tsx"],"names":[],"mappings":"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"}
@@ -20,15 +20,16 @@ Tabs are used to move from one content to another within the same context.
20
20
  tabs: [
21
21
  {
22
22
  id: '1',
23
- label: 'Tab item 1',
23
+ label: 'Tab item',
24
24
  element: <p>Tab item 1 content</p>,
25
25
  },
26
26
  {
27
27
  id: '2',
28
- label: 'Tab item 2',
28
+ label: 'Tab item with sub tabs',
29
29
  subTabs: [
30
30
  { id: '2.1', label: 'Sub tab item 2.1', element: <p>Sub tab item 2.1 content</p> },
31
31
  { id: '2.2', label: 'Sub tab item 2.2', element: <p>Sub tab item 2.2 content</p> },
32
+ { id: '2.3', label: 'Sub tab item 2.3', element: <p>Sub tab item 2.3 content</p> },
32
33
  ],
33
34
  },
34
35
  { id: 'disabled', label: 'Tab item disabled', disabled: true, element: <></> },
package/esm/index.d.ts CHANGED
@@ -12,3 +12,4 @@ export * from './components/TsTooltip/TsTooltip';
12
12
  export * from './layouts/TsHeader/TsHeader';
13
13
  export * from './layouts/TsHeader/TsHeaderProfile';
14
14
  export * from './layouts/TsNavigation/TsNavigation';
15
+ export * from './layouts/TsSearchHeader/TsSearchHeader';
package/esm/index.js CHANGED
@@ -12,4 +12,5 @@ export * from './components/TsTooltip/TsTooltip';
12
12
  export * from './layouts/TsHeader/TsHeader';
13
13
  export * from './layouts/TsHeader/TsHeaderProfile';
14
14
  export * from './layouts/TsNavigation/TsNavigation';
15
+ export * from './layouts/TsSearchHeader/TsSearchHeader';
15
16
  //# sourceMappingURL=index.js.map
package/esm/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,gCAAgC,CAAC;AAC/C,cAAc,oCAAoC,CAAC;AACnD,cAAc,gDAAgD,CAAC;AAC/D,cAAc,4DAA4D,CAAC;AAC3E,cAAc,4BAA4B,CAAC;AAC3C,cAAc,oDAAoD,CAAC;AACnE,cAAc,sCAAsC,CAAC;AACrD,cAAc,gCAAgC,CAAC;AAC/C,cAAc,oCAAoC,CAAC;AACnD,cAAc,4BAA4B,CAAC;AAC3C,cAAc,kCAAkC,CAAC;AACjD,cAAc,6BAA6B,CAAC;AAC5C,cAAc,oCAAoC,CAAC;AACnD,cAAc,qCAAqC,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,gCAAgC,CAAC;AAC/C,cAAc,oCAAoC,CAAC;AACnD,cAAc,gDAAgD,CAAC;AAC/D,cAAc,4DAA4D,CAAC;AAC3E,cAAc,4BAA4B,CAAC;AAC3C,cAAc,oDAAoD,CAAC;AACnE,cAAc,sCAAsC,CAAC;AACrD,cAAc,gCAAgC,CAAC;AAC/C,cAAc,oCAAoC,CAAC;AACnD,cAAc,4BAA4B,CAAC;AAC3C,cAAc,kCAAkC,CAAC;AACjD,cAAc,6BAA6B,CAAC;AAC5C,cAAc,oCAAoC,CAAC;AACnD,cAAc,qCAAqC,CAAC;AACpD,cAAc,yCAAyC,CAAC"}
@@ -0,0 +1,98 @@
1
+ .ts-search-header {
2
+ position: relative;
3
+ width: 450px;
4
+ height: 32px;
5
+ }
6
+
7
+ .ts-search-header-input-container {
8
+ display: flex;
9
+ width: 100%;
10
+ height: 100%;
11
+ border-radius: 9999px;
12
+ border: none;
13
+ box-shadow: 0px 12px 9px 0px #10101012;
14
+ background: white;
15
+ }
16
+
17
+ .ts-search-header-input-container-icon {
18
+ display: flex;
19
+ align-items: center;
20
+ justify-content: center;
21
+ width: 48px;
22
+ height: 32px;
23
+ color: #687787;
24
+ }
25
+
26
+ .ts-search-header-bar-input {
27
+ display: flex;
28
+ flex: 1;
29
+ align-items: center;
30
+ justify-content: center;
31
+ height: 32px;
32
+ color: #8c96a2;
33
+ overflow: hidden;
34
+ text-overflow: ellipsis;
35
+ white-space: nowrap;
36
+ }
37
+
38
+ .ts-search-header-bar-input input {
39
+ width: 100%;
40
+ height: 100%;
41
+ border: none;
42
+ }
43
+
44
+ .ts-search-header-bar-input input::placeholder {
45
+ text-align: center;
46
+ }
47
+
48
+ .ts-search-header-dropdown {
49
+ position: absolute;
50
+ top: 100%;
51
+ width: 450px;
52
+ max-height: 250px;
53
+ padding: 12px;
54
+ box-shadow: 0px 8px 9px 0px #1010101a;
55
+ background: white;
56
+ transform: translateY(10px);
57
+ overflow: auto;
58
+ }
59
+
60
+ .ts-search-header-loader {
61
+ display: flex;
62
+ justify-content: center;
63
+ }
64
+
65
+ .ts-search-header-message {
66
+ text-align: center;
67
+ font-style: italic;
68
+ color: #4e5d6b;
69
+ }
70
+
71
+ .ts-search-header-items {
72
+ width: 100%;
73
+ height: 100%;
74
+ }
75
+
76
+ .ts-search-header-item {
77
+ width: 100%;
78
+ height: 32px;
79
+ padding: 0 12px;
80
+ border: none;
81
+ background: white;
82
+ text-align: left;
83
+ cursor: pointer;
84
+ }
85
+
86
+ .ts-search-header-item:hover {
87
+ background: #ebecf7;
88
+ }
89
+
90
+ /* ######### */
91
+ /* GLOBALS */
92
+ * {
93
+ font-size: 14px;
94
+ outline: none;
95
+ box-sizing: border-box;
96
+ font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans',
97
+ 'Helvetica Neue', sans-serif;
98
+ }
@@ -0,0 +1,5 @@
1
+ import * as React from 'react';
2
+ import { TsSearchHeaderProps, TsSearchHeaderItemProps } from './TsSearchHeader.types';
3
+ import './TsSearchHeader.css';
4
+ export declare const TsSearchHeaderItem: ({ id, label, onClick }: TsSearchHeaderItemProps) => React.JSX.Element;
5
+ export declare const TsSearchHeader: ({ placeholder, noItemMessage, isLoading, value, items, onChange, }: TsSearchHeaderProps) => React.JSX.Element;
@@ -0,0 +1,25 @@
1
+ import * as React from 'react';
2
+ import { TsIcon } from '../../components/TsIcon/TsIcon';
3
+ import { TsLoader } from '../../components/TsLoader/TsLoader';
4
+ import './TsSearchHeader.css';
5
+ export const TsSearchHeaderItem = ({ id, label, onClick }) => {
6
+ // Rendering
7
+ return (React.createElement("button", { className: "ts-search-header-item", id: id, onClick: onClick },
8
+ React.createElement("div", { className: "ts-search-header-item-label" }, label)));
9
+ };
10
+ export const TsSearchHeader = ({ placeholder, noItemMessage, isLoading, value, items, onChange, }) => {
11
+ // Rendering
12
+ return (React.createElement("div", { className: "ts-search-header" },
13
+ React.createElement("div", { className: "ts-search-header-input-container" },
14
+ React.createElement("div", { className: "ts-search-header-input-container-icon" },
15
+ React.createElement(TsIcon, { name: "search", size: "16" })),
16
+ React.createElement("div", { className: "ts-search-header-bar-input" },
17
+ React.createElement("input", { id: "search", name: "search", placeholder: placeholder, value: value, onChange: e => onChange(e.target.value) })),
18
+ React.createElement("div", { className: "ts-search-header-input-container-icon" })),
19
+ value && (React.createElement("div", { className: "ts-search-header-dropdown" },
20
+ isLoading && (React.createElement("div", { className: "ts-search-header-loader" },
21
+ React.createElement(TsLoader, { size: "sm" }))),
22
+ !isLoading && (!items || items.length === 0) && (React.createElement("div", { className: "ts-search-header-message" }, noItemMessage ?? 'No item found.')),
23
+ !isLoading && items && items.length > 0 && React.createElement("div", { className: "ts-search-header-items" }, items)))));
24
+ };
25
+ //# sourceMappingURL=TsSearchHeader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TsSearchHeader.js","sourceRoot":"","sources":["../../../src/layouts/TsSearchHeader/TsSearchHeader.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,EAAE,MAAM,EAAE,MAAM,gCAAgC,CAAC;AACxD,OAAO,EAAE,QAAQ,EAAE,MAAM,oCAAoC,CAAC;AAC9D,OAAO,sBAAsB,CAAC;AAE9B,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,OAAO,EAA2B,EAAE,EAAE;IACpF,YAAY;IACZ,OAAO,CACL,gCAAQ,SAAS,EAAC,uBAAuB,EAAC,EAAE,EAAE,EAAE,EAAE,OAAO,EAAE,OAAO;QAChE,6BAAK,SAAS,EAAC,6BAA6B,IAAE,KAAK,CAAO,CACnD,CACV,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,EAC7B,WAAW,EACX,aAAa,EACb,SAAS,EACT,KAAK,EACL,KAAK,EACL,QAAQ,GACY,EAAE,EAAE;IACxB,YAAY;IACZ,OAAO,CACL,6BAAK,SAAS,EAAC,kBAAkB;QAC/B,6BAAK,SAAS,EAAC,kCAAkC;YAC/C,6BAAK,SAAS,EAAC,uCAAuC;gBACpD,oBAAC,MAAM,IAAC,IAAI,EAAC,QAAQ,EAAC,IAAI,EAAC,IAAI,GAAG,CAC9B;YACN,6BAAK,SAAS,EAAC,4BAA4B;gBACzC,+BACE,EAAE,EAAC,QAAQ,EACX,IAAI,EAAC,QAAQ,EACb,WAAW,EAAE,WAAW,EACxB,KAAK,EAAE,KAAK,EACZ,QAAQ,EAAE,CAAC,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,GACvC,CACE;YACN,6BAAK,SAAS,EAAC,uCAAuC,GAAG,CACrD;QAEL,KAAK,IAAI,CACR,6BAAK,SAAS,EAAC,2BAA2B;YACvC,SAAS,IAAI,CACZ,6BAAK,SAAS,EAAC,yBAAyB;gBACtC,oBAAC,QAAQ,IAAC,IAAI,EAAC,IAAI,GAAG,CAClB,CACP;YACA,CAAC,SAAS,IAAI,CAAC,CAAC,KAAK,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,CAAC,IAAI,CAC/C,6BAAK,SAAS,EAAC,0BAA0B,IAAE,aAAa,IAAI,gBAAgB,CAAO,CACpF;YACA,CAAC,SAAS,IAAI,KAAK,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,IAAI,6BAAK,SAAS,EAAC,wBAAwB,IAAE,KAAK,CAAO,CAC7F,CACP,CACG,CACP,CAAC;AACJ,CAAC,CAAC"}
@@ -0,0 +1,14 @@
1
+ import { ReactElement } from 'react';
2
+ export type TsSearchHeaderItemProps = {
3
+ id: string;
4
+ label: string;
5
+ onClick?: () => void;
6
+ };
7
+ export type TsSearchHeaderProps = {
8
+ placeholder?: string;
9
+ noItemMessage?: string;
10
+ value: string;
11
+ isLoading?: boolean;
12
+ items?: ReactElement[];
13
+ onChange: (val: string) => void;
14
+ };
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=TsSearchHeader.types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TsSearchHeader.types.js","sourceRoot":"","sources":["../../../src/layouts/TsSearchHeader/TsSearchHeader.types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,39 @@
1
+ import React from 'react';
2
+ import { ArgsTable, Canvas, Meta, Story } from '@storybook/blocks';
3
+ import { TsSearchHeader, TsSearchHeaderItem } from '../TsSearchHeader';
4
+
5
+ <Meta title="Layouts/Search header" />
6
+
7
+ # Search header
8
+
9
+ Search allows users to specify a word or phrase to find relevant content without using navigation. Search can be used as the primary means of discovering content or as a filter to help the user find content.
10
+
11
+ ## Overview
12
+
13
+ <Canvas>
14
+ <Story
15
+ name="Overview"
16
+ args={{
17
+ placeholder: "Search a product by name, by conception code",
18
+ noItemMessage: "",
19
+ value: "",
20
+ isLoading: false,
21
+ items: [
22
+ <TsSearchHeaderItem id="1" label="Item 1" />,
23
+ <TsSearchHeaderItem id="2" label="Item 2" />,
24
+ <TsSearchHeaderItem id="3" label="Item 3" />,
25
+ <TsSearchHeaderItem id="4" label="Item 4" />,
26
+ ],
27
+ onChange: () => undefined,
28
+ }}
29
+
30
+ >
31
+
32
+ {args => <div style={{display: 'flex', width: '100%', height: '300px', justifyContent: 'center'}}><TsSearchHeader {...args} /></div>}
33
+
34
+ </Story>
35
+ </Canvas>
36
+
37
+ ## Props
38
+
39
+ <ArgsTable story="Overview" of={TsSearchHeader} />
@@ -11,11 +11,15 @@ const TsTabs = ({ value, tabs }) => {
11
11
  const [renderedElement, setRenderedElement] = (0, react_1.useState)();
12
12
  // ########
13
13
  // Handlers
14
- const handleSelectTab = (tab, type) => {
15
- if (type === 'main')
14
+ const handleSelectTab = (e, tab, type) => {
15
+ e.stopPropagation();
16
+ if (type === 'main') {
16
17
  setSelectedTab(tab);
17
- else if (type === 'sub')
18
+ setSelectedSubTab(tab.subTabs && tab.subTabs[0]);
19
+ }
20
+ else if (type === 'sub') {
18
21
  setSelectedSubTab(tab);
22
+ }
19
23
  tab.onClick?.();
20
24
  };
21
25
  // #########
@@ -25,6 +29,10 @@ const TsTabs = ({ value, tabs }) => {
25
29
  const tab = tabs.find(t => t.id === value);
26
30
  if (tab) {
27
31
  setSelectedTab(tab);
32
+ if (tab.subTabs)
33
+ setSelectedSubTab(tab.subTabs[0]);
34
+ else
35
+ setSelectedSubTab(undefined);
28
36
  }
29
37
  else {
30
38
  const tabWithSubTab = tabs.find(t => t.subTabs?.find(st => st.id === value));
@@ -40,18 +48,11 @@ const TsTabs = ({ value, tabs }) => {
40
48
  }
41
49
  }, [value]);
42
50
  (0, react_1.useEffect)(() => {
43
- if (selectedTab.subTabs) {
44
- setSelectedSubTab(selectedTab.subTabs[0]);
45
- }
46
- else {
47
- setSelectedSubTab(undefined);
51
+ if (selectedTab && !selectedSubTab)
48
52
  setRenderedElement(selectedTab.element);
49
- }
50
- }, [selectedTab]);
51
- (0, react_1.useEffect)(() => {
52
53
  if (selectedSubTab)
53
54
  setRenderedElement(selectedSubTab.element);
54
- }, [selectedSubTab]);
55
+ }, [selectedTab, selectedSubTab]);
55
56
  // #########
56
57
  // Rendering
57
58
  return (React.createElement("div", { className: "ts-tabs" },
@@ -61,13 +62,13 @@ const TsTabs = ({ value, tabs }) => {
61
62
  ts-tabs-item
62
63
  ${tab.id === selectedTab.id ? 'ts-tabs-item--selected' : ''}
63
64
  ${tab.disabled ? 'ts-tabs-item--disabled' : ''}
64
- `, onClick: () => !tab.disabled && handleSelectTab(tab, 'main') },
65
+ `, onClick: e => !tab.disabled && handleSelectTab(e, tab, 'main') },
65
66
  tab.icon && (React.createElement("div", { className: "ts-tabs-item--icon" },
66
67
  React.createElement(TsIcon_1.TsIcon, { name: tab.icon }))),
67
68
  React.createElement("div", { className: "ts-tabs-item--label" }, tab.label),
68
69
  tab.id === selectedTab.id && React.createElement("div", { className: "ts-tabs-item--selected-pin" }),
69
70
  tab.id === selectedTab.id &&
70
- tab.subTabs?.map(subTab => (React.createElement("div", { key: subTab.id, className: "ts-tabs-sub-item", onClick: () => !subTab.disabled && handleSelectTab(subTab, 'sub') },
71
+ tab.subTabs?.map(subTab => (React.createElement("div", { key: subTab.id, className: "ts-tabs-sub-item", onClick: e => !subTab.disabled && handleSelectTab(e, subTab, 'sub') },
71
72
  React.createElement(TsIcon_1.TsIcon, { name: "chevron-right" }),
72
73
  React.createElement("div", { className: `
73
74
  ts-tabs-sub-item--label
@@ -1 +1 @@
1
- {"version":3,"file":"TsTabs.js","sourceRoot":"","sources":["../../../src/components/TsTabs/TsTabs.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"TsTabs.js","sourceRoot":"","sources":["../../../src/components/TsTabs/TsTabs.tsx"],"names":[],"mappings":"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"}
@@ -20,15 +20,16 @@ Tabs are used to move from one content to another within the same context.
20
20
  tabs: [
21
21
  {
22
22
  id: '1',
23
- label: 'Tab item 1',
23
+ label: 'Tab item',
24
24
  element: <p>Tab item 1 content</p>,
25
25
  },
26
26
  {
27
27
  id: '2',
28
- label: 'Tab item 2',
28
+ label: 'Tab item with sub tabs',
29
29
  subTabs: [
30
30
  { id: '2.1', label: 'Sub tab item 2.1', element: <p>Sub tab item 2.1 content</p> },
31
31
  { id: '2.2', label: 'Sub tab item 2.2', element: <p>Sub tab item 2.2 content</p> },
32
+ { id: '2.3', label: 'Sub tab item 2.3', element: <p>Sub tab item 2.3 content</p> },
32
33
  ],
33
34
  },
34
35
  { id: 'disabled', label: 'Tab item disabled', disabled: true, element: <></> },
package/lib/index.d.ts CHANGED
@@ -12,3 +12,4 @@ export * from './components/TsTooltip/TsTooltip';
12
12
  export * from './layouts/TsHeader/TsHeader';
13
13
  export * from './layouts/TsHeader/TsHeaderProfile';
14
14
  export * from './layouts/TsNavigation/TsNavigation';
15
+ export * from './layouts/TsSearchHeader/TsSearchHeader';
package/lib/index.js CHANGED
@@ -28,4 +28,5 @@ __exportStar(require("./components/TsTooltip/TsTooltip"), exports);
28
28
  __exportStar(require("./layouts/TsHeader/TsHeader"), exports);
29
29
  __exportStar(require("./layouts/TsHeader/TsHeaderProfile"), exports);
30
30
  __exportStar(require("./layouts/TsNavigation/TsNavigation"), exports);
31
+ __exportStar(require("./layouts/TsSearchHeader/TsSearchHeader"), exports);
31
32
  //# sourceMappingURL=index.js.map
package/lib/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,iEAA+C;AAC/C,qEAAmD;AACnD,iFAA+D;AAC/D,6FAA2E;AAC3E,6DAA2C;AAC3C,qFAAmE;AACnE,uEAAqD;AACrD,iEAA+C;AAC/C,qEAAmD;AACnD,6DAA2C;AAC3C,mEAAiD;AACjD,8DAA4C;AAC5C,qEAAmD;AACnD,sEAAoD"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,iEAA+C;AAC/C,qEAAmD;AACnD,iFAA+D;AAC/D,6FAA2E;AAC3E,6DAA2C;AAC3C,qFAAmE;AACnE,uEAAqD;AACrD,iEAA+C;AAC/C,qEAAmD;AACnD,6DAA2C;AAC3C,mEAAiD;AACjD,8DAA4C;AAC5C,qEAAmD;AACnD,sEAAoD;AACpD,0EAAwD"}
@@ -0,0 +1,98 @@
1
+ .ts-search-header {
2
+ position: relative;
3
+ width: 450px;
4
+ height: 32px;
5
+ }
6
+
7
+ .ts-search-header-input-container {
8
+ display: flex;
9
+ width: 100%;
10
+ height: 100%;
11
+ border-radius: 9999px;
12
+ border: none;
13
+ box-shadow: 0px 12px 9px 0px #10101012;
14
+ background: white;
15
+ }
16
+
17
+ .ts-search-header-input-container-icon {
18
+ display: flex;
19
+ align-items: center;
20
+ justify-content: center;
21
+ width: 48px;
22
+ height: 32px;
23
+ color: #687787;
24
+ }
25
+
26
+ .ts-search-header-bar-input {
27
+ display: flex;
28
+ flex: 1;
29
+ align-items: center;
30
+ justify-content: center;
31
+ height: 32px;
32
+ color: #8c96a2;
33
+ overflow: hidden;
34
+ text-overflow: ellipsis;
35
+ white-space: nowrap;
36
+ }
37
+
38
+ .ts-search-header-bar-input input {
39
+ width: 100%;
40
+ height: 100%;
41
+ border: none;
42
+ }
43
+
44
+ .ts-search-header-bar-input input::placeholder {
45
+ text-align: center;
46
+ }
47
+
48
+ .ts-search-header-dropdown {
49
+ position: absolute;
50
+ top: 100%;
51
+ width: 450px;
52
+ max-height: 250px;
53
+ padding: 12px;
54
+ box-shadow: 0px 8px 9px 0px #1010101a;
55
+ background: white;
56
+ transform: translateY(10px);
57
+ overflow: auto;
58
+ }
59
+
60
+ .ts-search-header-loader {
61
+ display: flex;
62
+ justify-content: center;
63
+ }
64
+
65
+ .ts-search-header-message {
66
+ text-align: center;
67
+ font-style: italic;
68
+ color: #4e5d6b;
69
+ }
70
+
71
+ .ts-search-header-items {
72
+ width: 100%;
73
+ height: 100%;
74
+ }
75
+
76
+ .ts-search-header-item {
77
+ width: 100%;
78
+ height: 32px;
79
+ padding: 0 12px;
80
+ border: none;
81
+ background: white;
82
+ text-align: left;
83
+ cursor: pointer;
84
+ }
85
+
86
+ .ts-search-header-item:hover {
87
+ background: #ebecf7;
88
+ }
89
+
90
+ /* ######### */
91
+ /* GLOBALS */
92
+ * {
93
+ font-size: 14px;
94
+ outline: none;
95
+ box-sizing: border-box;
96
+ font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans',
97
+ 'Helvetica Neue', sans-serif;
98
+ }
@@ -0,0 +1,5 @@
1
+ import * as React from 'react';
2
+ import { TsSearchHeaderProps, TsSearchHeaderItemProps } from './TsSearchHeader.types';
3
+ import './TsSearchHeader.css';
4
+ export declare const TsSearchHeaderItem: ({ id, label, onClick }: TsSearchHeaderItemProps) => React.JSX.Element;
5
+ export declare const TsSearchHeader: ({ placeholder, noItemMessage, isLoading, value, items, onChange, }: TsSearchHeaderProps) => React.JSX.Element;
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TsSearchHeader = exports.TsSearchHeaderItem = void 0;
4
+ const React = require("react");
5
+ const TsIcon_1 = require("../../components/TsIcon/TsIcon");
6
+ const TsLoader_1 = require("../../components/TsLoader/TsLoader");
7
+ require("./TsSearchHeader.css");
8
+ const TsSearchHeaderItem = ({ id, label, onClick }) => {
9
+ // Rendering
10
+ return (React.createElement("button", { className: "ts-search-header-item", id: id, onClick: onClick },
11
+ React.createElement("div", { className: "ts-search-header-item-label" }, label)));
12
+ };
13
+ exports.TsSearchHeaderItem = TsSearchHeaderItem;
14
+ const TsSearchHeader = ({ placeholder, noItemMessage, isLoading, value, items, onChange, }) => {
15
+ // Rendering
16
+ return (React.createElement("div", { className: "ts-search-header" },
17
+ React.createElement("div", { className: "ts-search-header-input-container" },
18
+ React.createElement("div", { className: "ts-search-header-input-container-icon" },
19
+ React.createElement(TsIcon_1.TsIcon, { name: "search", size: "16" })),
20
+ React.createElement("div", { className: "ts-search-header-bar-input" },
21
+ React.createElement("input", { id: "search", name: "search", placeholder: placeholder, value: value, onChange: e => onChange(e.target.value) })),
22
+ React.createElement("div", { className: "ts-search-header-input-container-icon" })),
23
+ value && (React.createElement("div", { className: "ts-search-header-dropdown" },
24
+ isLoading && (React.createElement("div", { className: "ts-search-header-loader" },
25
+ React.createElement(TsLoader_1.TsLoader, { size: "sm" }))),
26
+ !isLoading && (!items || items.length === 0) && (React.createElement("div", { className: "ts-search-header-message" }, noItemMessage ?? 'No item found.')),
27
+ !isLoading && items && items.length > 0 && React.createElement("div", { className: "ts-search-header-items" }, items)))));
28
+ };
29
+ exports.TsSearchHeader = TsSearchHeader;
30
+ //# sourceMappingURL=TsSearchHeader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TsSearchHeader.js","sourceRoot":"","sources":["../../../src/layouts/TsSearchHeader/TsSearchHeader.tsx"],"names":[],"mappings":";;;AAAA,+BAA+B;AAE/B,2DAAwD;AACxD,iEAA8D;AAC9D,gCAA8B;AAEvB,MAAM,kBAAkB,GAAG,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,OAAO,EAA2B,EAAE,EAAE;IACpF,YAAY;IACZ,OAAO,CACL,gCAAQ,SAAS,EAAC,uBAAuB,EAAC,EAAE,EAAE,EAAE,EAAE,OAAO,EAAE,OAAO;QAChE,6BAAK,SAAS,EAAC,6BAA6B,IAAE,KAAK,CAAO,CACnD,CACV,CAAC;AACJ,CAAC,CAAC;AAPW,QAAA,kBAAkB,sBAO7B;AAEK,MAAM,cAAc,GAAG,CAAC,EAC7B,WAAW,EACX,aAAa,EACb,SAAS,EACT,KAAK,EACL,KAAK,EACL,QAAQ,GACY,EAAE,EAAE;IACxB,YAAY;IACZ,OAAO,CACL,6BAAK,SAAS,EAAC,kBAAkB;QAC/B,6BAAK,SAAS,EAAC,kCAAkC;YAC/C,6BAAK,SAAS,EAAC,uCAAuC;gBACpD,oBAAC,eAAM,IAAC,IAAI,EAAC,QAAQ,EAAC,IAAI,EAAC,IAAI,GAAG,CAC9B;YACN,6BAAK,SAAS,EAAC,4BAA4B;gBACzC,+BACE,EAAE,EAAC,QAAQ,EACX,IAAI,EAAC,QAAQ,EACb,WAAW,EAAE,WAAW,EACxB,KAAK,EAAE,KAAK,EACZ,QAAQ,EAAE,CAAC,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,GACvC,CACE;YACN,6BAAK,SAAS,EAAC,uCAAuC,GAAG,CACrD;QAEL,KAAK,IAAI,CACR,6BAAK,SAAS,EAAC,2BAA2B;YACvC,SAAS,IAAI,CACZ,6BAAK,SAAS,EAAC,yBAAyB;gBACtC,oBAAC,mBAAQ,IAAC,IAAI,EAAC,IAAI,GAAG,CAClB,CACP;YACA,CAAC,SAAS,IAAI,CAAC,CAAC,KAAK,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,CAAC,IAAI,CAC/C,6BAAK,SAAS,EAAC,0BAA0B,IAAE,aAAa,IAAI,gBAAgB,CAAO,CACpF;YACA,CAAC,SAAS,IAAI,KAAK,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,IAAI,6BAAK,SAAS,EAAC,wBAAwB,IAAE,KAAK,CAAO,CAC7F,CACP,CACG,CACP,CAAC;AACJ,CAAC,CAAC;AA1CW,QAAA,cAAc,kBA0CzB"}
@@ -0,0 +1,14 @@
1
+ import { ReactElement } from 'react';
2
+ export type TsSearchHeaderItemProps = {
3
+ id: string;
4
+ label: string;
5
+ onClick?: () => void;
6
+ };
7
+ export type TsSearchHeaderProps = {
8
+ placeholder?: string;
9
+ noItemMessage?: string;
10
+ value: string;
11
+ isLoading?: boolean;
12
+ items?: ReactElement[];
13
+ onChange: (val: string) => void;
14
+ };
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=TsSearchHeader.types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TsSearchHeader.types.js","sourceRoot":"","sources":["../../../src/layouts/TsSearchHeader/TsSearchHeader.types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,39 @@
1
+ import React from 'react';
2
+ import { ArgsTable, Canvas, Meta, Story } from '@storybook/blocks';
3
+ import { TsSearchHeader, TsSearchHeaderItem } from '../TsSearchHeader';
4
+
5
+ <Meta title="Layouts/Search header" />
6
+
7
+ # Search header
8
+
9
+ Search allows users to specify a word or phrase to find relevant content without using navigation. Search can be used as the primary means of discovering content or as a filter to help the user find content.
10
+
11
+ ## Overview
12
+
13
+ <Canvas>
14
+ <Story
15
+ name="Overview"
16
+ args={{
17
+ placeholder: "Search a product by name, by conception code",
18
+ noItemMessage: "",
19
+ value: "",
20
+ isLoading: false,
21
+ items: [
22
+ <TsSearchHeaderItem id="1" label="Item 1" />,
23
+ <TsSearchHeaderItem id="2" label="Item 2" />,
24
+ <TsSearchHeaderItem id="3" label="Item 3" />,
25
+ <TsSearchHeaderItem id="4" label="Item 4" />,
26
+ ],
27
+ onChange: () => undefined,
28
+ }}
29
+
30
+ >
31
+
32
+ {args => <div style={{display: 'flex', width: '100%', height: '300px', justifyContent: 'center'}}><TsSearchHeader {...args} /></div>}
33
+
34
+ </Story>
35
+ </Canvas>
36
+
37
+ ## Props
38
+
39
+ <ArgsTable story="Overview" of={TsSearchHeader} />
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dktunited-techoff/techoff-suite-ui",
3
- "version": "1.10.12",
3
+ "version": "1.11.0",
4
4
  "main": "lib/index.js",
5
5
  "types": "./lib",
6
6
  "module": "esm/index.js",
@@ -1,5 +1,5 @@
1
1
  import * as React from 'react';
2
- import { ReactElement, useEffect, useState } from 'react';
2
+ import { MouseEvent, ReactElement, useEffect, useState } from 'react';
3
3
  import { TsIcon } from '../TsIcon/TsIcon';
4
4
  import { TabItem, TsTabsProps } from './TsTabs.types';
5
5
  import './TsTabs.css';
@@ -11,9 +11,16 @@ export const TsTabs = ({ value, tabs }: TsTabsProps) => {
11
11
 
12
12
  // ########
13
13
  // Handlers
14
- const handleSelectTab = (tab: TabItem, type: 'main' | 'sub') => {
15
- if (type === 'main') setSelectedTab(tab);
16
- else if (type === 'sub') setSelectedSubTab(tab);
14
+ const handleSelectTab = (e: MouseEvent<HTMLElement>, tab: TabItem, type: 'main' | 'sub') => {
15
+ e.stopPropagation();
16
+
17
+ if (type === 'main') {
18
+ setSelectedTab(tab);
19
+ setSelectedSubTab(tab.subTabs && tab.subTabs[0]);
20
+ } else if (type === 'sub') {
21
+ setSelectedSubTab(tab);
22
+ }
23
+
17
24
  tab.onClick?.();
18
25
  };
19
26
 
@@ -22,12 +29,12 @@ export const TsTabs = ({ value, tabs }: TsTabsProps) => {
22
29
  useEffect(() => {
23
30
  if (value) {
24
31
  const tab = tabs.find(t => t.id === value);
25
-
26
32
  if (tab) {
27
33
  setSelectedTab(tab);
34
+ if (tab.subTabs) setSelectedSubTab(tab.subTabs[0]);
35
+ else setSelectedSubTab(undefined);
28
36
  } else {
29
37
  const tabWithSubTab = tabs.find(t => t.subTabs?.find(st => st.id === value));
30
-
31
38
  if (tabWithSubTab) {
32
39
  const subTab = tabWithSubTab.subTabs?.find(st => st.id === value);
33
40
  setSelectedTab(tabWithSubTab);
@@ -39,16 +46,9 @@ export const TsTabs = ({ value, tabs }: TsTabsProps) => {
39
46
  }
40
47
  }, [value]);
41
48
  useEffect(() => {
42
- if (selectedTab.subTabs) {
43
- setSelectedSubTab(selectedTab.subTabs[0]);
44
- } else {
45
- setSelectedSubTab(undefined);
46
- setRenderedElement(selectedTab.element);
47
- }
48
- }, [selectedTab]);
49
- useEffect(() => {
49
+ if (selectedTab && !selectedSubTab) setRenderedElement(selectedTab.element);
50
50
  if (selectedSubTab) setRenderedElement(selectedSubTab.element);
51
- }, [selectedSubTab]);
51
+ }, [selectedTab, selectedSubTab]);
52
52
 
53
53
  // #########
54
54
  // Rendering
@@ -65,7 +65,7 @@ export const TsTabs = ({ value, tabs }: TsTabsProps) => {
65
65
  ${tab.id === selectedTab.id ? 'ts-tabs-item--selected' : ''}
66
66
  ${tab.disabled ? 'ts-tabs-item--disabled' : ''}
67
67
  `}
68
- onClick={() => !tab.disabled && handleSelectTab(tab, 'main')}
68
+ onClick={e => !tab.disabled && handleSelectTab(e, tab, 'main')}
69
69
  >
70
70
  {tab.icon && (
71
71
  <div className="ts-tabs-item--icon">
@@ -80,7 +80,7 @@ export const TsTabs = ({ value, tabs }: TsTabsProps) => {
80
80
  <div
81
81
  key={subTab.id}
82
82
  className="ts-tabs-sub-item"
83
- onClick={() => !subTab.disabled && handleSelectTab(subTab, 'sub')}
83
+ onClick={e => !subTab.disabled && handleSelectTab(e, subTab, 'sub')}
84
84
  >
85
85
  <TsIcon name="chevron-right" />
86
86
  <div
@@ -20,15 +20,16 @@ Tabs are used to move from one content to another within the same context.
20
20
  tabs: [
21
21
  {
22
22
  id: '1',
23
- label: 'Tab item 1',
23
+ label: 'Tab item',
24
24
  element: <p>Tab item 1 content</p>,
25
25
  },
26
26
  {
27
27
  id: '2',
28
- label: 'Tab item 2',
28
+ label: 'Tab item with sub tabs',
29
29
  subTabs: [
30
30
  { id: '2.1', label: 'Sub tab item 2.1', element: <p>Sub tab item 2.1 content</p> },
31
31
  { id: '2.2', label: 'Sub tab item 2.2', element: <p>Sub tab item 2.2 content</p> },
32
+ { id: '2.3', label: 'Sub tab item 2.3', element: <p>Sub tab item 2.3 content</p> },
32
33
  ],
33
34
  },
34
35
  { id: 'disabled', label: 'Tab item disabled', disabled: true, element: <></> },
package/src/index.ts CHANGED
@@ -12,3 +12,4 @@ export * from './components/TsTooltip/TsTooltip';
12
12
  export * from './layouts/TsHeader/TsHeader';
13
13
  export * from './layouts/TsHeader/TsHeaderProfile';
14
14
  export * from './layouts/TsNavigation/TsNavigation';
15
+ export * from './layouts/TsSearchHeader/TsSearchHeader';
@@ -0,0 +1,98 @@
1
+ .ts-search-header {
2
+ position: relative;
3
+ width: 450px;
4
+ height: 32px;
5
+ }
6
+
7
+ .ts-search-header-input-container {
8
+ display: flex;
9
+ width: 100%;
10
+ height: 100%;
11
+ border-radius: 9999px;
12
+ border: none;
13
+ box-shadow: 0px 12px 9px 0px #10101012;
14
+ background: white;
15
+ }
16
+
17
+ .ts-search-header-input-container-icon {
18
+ display: flex;
19
+ align-items: center;
20
+ justify-content: center;
21
+ width: 48px;
22
+ height: 32px;
23
+ color: #687787;
24
+ }
25
+
26
+ .ts-search-header-bar-input {
27
+ display: flex;
28
+ flex: 1;
29
+ align-items: center;
30
+ justify-content: center;
31
+ height: 32px;
32
+ color: #8c96a2;
33
+ overflow: hidden;
34
+ text-overflow: ellipsis;
35
+ white-space: nowrap;
36
+ }
37
+
38
+ .ts-search-header-bar-input input {
39
+ width: 100%;
40
+ height: 100%;
41
+ border: none;
42
+ }
43
+
44
+ .ts-search-header-bar-input input::placeholder {
45
+ text-align: center;
46
+ }
47
+
48
+ .ts-search-header-dropdown {
49
+ position: absolute;
50
+ top: 100%;
51
+ width: 450px;
52
+ max-height: 250px;
53
+ padding: 12px;
54
+ box-shadow: 0px 8px 9px 0px #1010101a;
55
+ background: white;
56
+ transform: translateY(10px);
57
+ overflow: auto;
58
+ }
59
+
60
+ .ts-search-header-loader {
61
+ display: flex;
62
+ justify-content: center;
63
+ }
64
+
65
+ .ts-search-header-message {
66
+ text-align: center;
67
+ font-style: italic;
68
+ color: #4e5d6b;
69
+ }
70
+
71
+ .ts-search-header-items {
72
+ width: 100%;
73
+ height: 100%;
74
+ }
75
+
76
+ .ts-search-header-item {
77
+ width: 100%;
78
+ height: 32px;
79
+ padding: 0 12px;
80
+ border: none;
81
+ background: white;
82
+ text-align: left;
83
+ cursor: pointer;
84
+ }
85
+
86
+ .ts-search-header-item:hover {
87
+ background: #ebecf7;
88
+ }
89
+
90
+ /* ######### */
91
+ /* GLOBALS */
92
+ * {
93
+ font-size: 14px;
94
+ outline: none;
95
+ box-sizing: border-box;
96
+ font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans',
97
+ 'Helvetica Neue', sans-serif;
98
+ }
@@ -0,0 +1,58 @@
1
+ import * as React from 'react';
2
+ import { TsSearchHeaderProps, TsSearchHeaderItemProps } from './TsSearchHeader.types';
3
+ import { TsIcon } from '../../components/TsIcon/TsIcon';
4
+ import { TsLoader } from '../../components/TsLoader/TsLoader';
5
+ import './TsSearchHeader.css';
6
+
7
+ export const TsSearchHeaderItem = ({ id, label, onClick }: TsSearchHeaderItemProps) => {
8
+ // Rendering
9
+ return (
10
+ <button className="ts-search-header-item" id={id} onClick={onClick}>
11
+ <div className="ts-search-header-item-label">{label}</div>
12
+ </button>
13
+ );
14
+ };
15
+
16
+ export const TsSearchHeader = ({
17
+ placeholder,
18
+ noItemMessage,
19
+ isLoading,
20
+ value,
21
+ items,
22
+ onChange,
23
+ }: TsSearchHeaderProps) => {
24
+ // Rendering
25
+ return (
26
+ <div className="ts-search-header">
27
+ <div className="ts-search-header-input-container">
28
+ <div className="ts-search-header-input-container-icon">
29
+ <TsIcon name="search" size="16" />
30
+ </div>
31
+ <div className="ts-search-header-bar-input">
32
+ <input
33
+ id="search"
34
+ name="search"
35
+ placeholder={placeholder}
36
+ value={value}
37
+ onChange={e => onChange(e.target.value)}
38
+ />
39
+ </div>
40
+ <div className="ts-search-header-input-container-icon" />
41
+ </div>
42
+
43
+ {value && (
44
+ <div className="ts-search-header-dropdown">
45
+ {isLoading && (
46
+ <div className="ts-search-header-loader">
47
+ <TsLoader size="sm" />
48
+ </div>
49
+ )}
50
+ {!isLoading && (!items || items.length === 0) && (
51
+ <div className="ts-search-header-message">{noItemMessage ?? 'No item found.'}</div>
52
+ )}
53
+ {!isLoading && items && items.length > 0 && <div className="ts-search-header-items">{items}</div>}
54
+ </div>
55
+ )}
56
+ </div>
57
+ );
58
+ };
@@ -0,0 +1,11 @@
1
+ import { ReactElement } from 'react';
2
+
3
+ export type TsSearchHeaderItemProps = { id: string; label: string; onClick?: () => void };
4
+ export type TsSearchHeaderProps = {
5
+ placeholder?: string;
6
+ noItemMessage?: string;
7
+ value: string;
8
+ isLoading?: boolean;
9
+ items?: ReactElement[];
10
+ onChange: (val: string) => void;
11
+ };
@@ -0,0 +1,39 @@
1
+ import React from 'react';
2
+ import { ArgsTable, Canvas, Meta, Story } from '@storybook/blocks';
3
+ import { TsSearchHeader, TsSearchHeaderItem } from '../TsSearchHeader';
4
+
5
+ <Meta title="Layouts/Search header" />
6
+
7
+ # Search header
8
+
9
+ Search allows users to specify a word or phrase to find relevant content without using navigation. Search can be used as the primary means of discovering content or as a filter to help the user find content.
10
+
11
+ ## Overview
12
+
13
+ <Canvas>
14
+ <Story
15
+ name="Overview"
16
+ args={{
17
+ placeholder: "Search a product by name, by conception code",
18
+ noItemMessage: "",
19
+ value: "",
20
+ isLoading: false,
21
+ items: [
22
+ <TsSearchHeaderItem id="1" label="Item 1" />,
23
+ <TsSearchHeaderItem id="2" label="Item 2" />,
24
+ <TsSearchHeaderItem id="3" label="Item 3" />,
25
+ <TsSearchHeaderItem id="4" label="Item 4" />,
26
+ ],
27
+ onChange: () => undefined,
28
+ }}
29
+
30
+ >
31
+
32
+ {args => <div style={{display: 'flex', width: '100%', height: '300px', justifyContent: 'center'}}><TsSearchHeader {...args} /></div>}
33
+
34
+ </Story>
35
+ </Canvas>
36
+
37
+ ## Props
38
+
39
+ <ArgsTable story="Overview" of={TsSearchHeader} />