@dktunited-techoff/techoff-suite-ui 1.10.12 → 1.10.13

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.
@@ -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":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,EAAgB,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAC1D,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAE1C,OAAO,cAAc,CAAC;AAEtB,MAAM,CAAC,MAAM,MAAM,GAAG,CAAC,EAAE,KAAK,EAAE,IAAI,EAAe,EAAE,EAAE;IACrD,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAU,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,KAAK,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;IACnG,MAAM,CAAC,cAAc,EAAE,iBAAiB,CAAC,GAAG,QAAQ,EAAW,CAAC;IAChE,MAAM,CAAC,eAAe,EAAE,kBAAkB,CAAC,GAAG,QAAQ,EAAgB,CAAC;IAEvE,WAAW;IACX,WAAW;IACX,MAAM,eAAe,GAAG,CAAC,GAAY,EAAE,IAAoB,EAAE,EAAE;QAC7D,IAAI,IAAI,KAAK,MAAM;YAAE,cAAc,CAAC,GAAG,CAAC,CAAC;aACpC,IAAI,IAAI,KAAK,KAAK;YAAE,iBAAiB,CAAC,GAAG,CAAC,CAAC;QAChD,GAAG,CAAC,OAAO,EAAE,EAAE,CAAC;IAClB,CAAC,CAAC;IAEF,YAAY;IACZ,YAAY;IACZ,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,KAAK,EAAE;YACT,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,KAAK,CAAC,CAAC;YAE3C,IAAI,GAAG,EAAE;gBACP,cAAc,CAAC,GAAG,CAAC,CAAC;aACrB;iBAAM;gBACL,MAAM,aAAa,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,KAAK,CAAC,CAAC,CAAC;gBAE7E,IAAI,aAAa,EAAE;oBACjB,MAAM,MAAM,GAAG,aAAa,CAAC,OAAO,EAAE,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,KAAK,CAAC,CAAC;oBAClE,cAAc,CAAC,aAAa,CAAC,CAAC;oBAC9B,iBAAiB,CAAC,MAAM,CAAC,CAAC;iBAC3B;qBAAM;oBACL,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;iBACzB;aACF;SACF;IACH,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;IACZ,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,WAAW,CAAC,OAAO,EAAE;YACvB,iBAAiB,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;SAC3C;aAAM;YACL,iBAAiB,CAAC,SAAS,CAAC,CAAC;YAC7B,kBAAkB,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;SACzC;IACH,CAAC,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC;IAClB,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,cAAc;YAAE,kBAAkB,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;IACjE,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC;IAErB,YAAY;IACZ,YAAY;IACZ,OAAO,CACL,6BAAK,SAAS,EAAC,SAAS;QACtB,6BAAK,SAAS,EAAC,gBAAgB;YAC7B,6BAAK,SAAS,EAAC,yBAAyB;gBACtC,6BAAK,SAAS,EAAC,eAAe,IAC3B,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CACf,6BACE,GAAG,EAAE,GAAG,CAAC,EAAE,EACX,SAAS,EAAE;;oBAEP,GAAG,CAAC,EAAE,KAAK,WAAW,CAAC,EAAE,CAAC,CAAC,CAAC,wBAAwB,CAAC,CAAC,CAAC,EAAE;oBACzD,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,wBAAwB,CAAC,CAAC,CAAC,EAAE;iBAC/C,EACD,OAAO,EAAE,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,QAAQ,IAAI,eAAe,CAAC,GAAG,EAAE,MAAM,CAAC;oBAE3D,GAAG,CAAC,IAAI,IAAI,CACX,6BAAK,SAAS,EAAC,oBAAoB;wBACjC,oBAAC,MAAM,IAAC,IAAI,EAAE,GAAG,CAAC,IAAI,GAAI,CACtB,CACP;oBACD,6BAAK,SAAS,EAAC,qBAAqB,IAAE,GAAG,CAAC,KAAK,CAAO;oBACrD,GAAG,CAAC,EAAE,KAAK,WAAW,CAAC,EAAE,IAAI,6BAAK,SAAS,EAAC,4BAA4B,GAAG;oBAE3E,GAAG,CAAC,EAAE,KAAK,WAAW,CAAC,EAAE;wBACxB,GAAG,CAAC,OAAO,EAAE,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CACzB,6BACE,GAAG,EAAE,MAAM,CAAC,EAAE,EACd,SAAS,EAAC,kBAAkB,EAC5B,OAAO,EAAE,GAAG,EAAE,CAAC,CAAC,MAAM,CAAC,QAAQ,IAAI,eAAe,CAAC,MAAM,EAAE,KAAK,CAAC;4BAEjE,oBAAC,MAAM,IAAC,IAAI,EAAC,eAAe,GAAG;4BAC/B,6BACE,SAAS,EAAE;;4BAEP,MAAM,CAAC,EAAE,KAAK,cAAc,EAAE,EAAE,CAAC,CAAC,CAAC,4BAA4B,CAAC,CAAC,CAAC,EAAE;4BACpE,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,wBAAwB,CAAC,CAAC,CAAC,EAAE;yBAClD,IAEA,MAAM,CAAC,KAAK,CACT,CACF,CACP,CAAC,CACA,CACP,CAAC,CACE,CACF;YAEL,WAAW,EAAE,OAAO,IAAI,6BAAK,SAAS,EAAC,iBAAiB,IAAE,WAAW,EAAE,OAAO,CAAO,CAClF;QAEN,6BAAK,SAAS,EAAC,mBAAmB,IAAE,eAAe,CAAO,CACtD,CACP,CAAC;AACJ,CAAC,CAAC"}
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: <></> },
@@ -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":";;;AAAA,+BAA+B;AAC/B,iCAAsE;AACtE,6CAA0C;AAE1C,wBAAsB;AAEf,MAAM,MAAM,GAAG,CAAC,EAAE,KAAK,EAAE,IAAI,EAAe,EAAE,EAAE;IACrD,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,IAAA,gBAAQ,EAAU,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,KAAK,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;IACnG,MAAM,CAAC,cAAc,EAAE,iBAAiB,CAAC,GAAG,IAAA,gBAAQ,GAAW,CAAC;IAChE,MAAM,CAAC,eAAe,EAAE,kBAAkB,CAAC,GAAG,IAAA,gBAAQ,GAAgB,CAAC;IAEvE,WAAW;IACX,WAAW;IACX,MAAM,eAAe,GAAG,CAAC,CAA0B,EAAE,GAAY,EAAE,IAAoB,EAAE,EAAE;QACzF,CAAC,CAAC,eAAe,EAAE,CAAC;QAEpB,IAAI,IAAI,KAAK,MAAM,EAAE;YACnB,cAAc,CAAC,GAAG,CAAC,CAAC;YACpB,iBAAiB,CAAC,GAAG,CAAC,OAAO,IAAI,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;SAClD;aAAM,IAAI,IAAI,KAAK,KAAK,EAAE;YACzB,iBAAiB,CAAC,GAAG,CAAC,CAAC;SACxB;QAED,GAAG,CAAC,OAAO,EAAE,EAAE,CAAC;IAClB,CAAC,CAAC;IAEF,YAAY;IACZ,YAAY;IACZ,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,IAAI,KAAK,EAAE;YACT,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,KAAK,CAAC,CAAC;YAC3C,IAAI,GAAG,EAAE;gBACP,cAAc,CAAC,GAAG,CAAC,CAAC;gBACpB,IAAI,GAAG,CAAC,OAAO;oBAAE,iBAAiB,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;;oBAC9C,iBAAiB,CAAC,SAAS,CAAC,CAAC;aACnC;iBAAM;gBACL,MAAM,aAAa,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,KAAK,CAAC,CAAC,CAAC;gBAC7E,IAAI,aAAa,EAAE;oBACjB,MAAM,MAAM,GAAG,aAAa,CAAC,OAAO,EAAE,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,KAAK,CAAC,CAAC;oBAClE,cAAc,CAAC,aAAa,CAAC,CAAC;oBAC9B,iBAAiB,CAAC,MAAM,CAAC,CAAC;iBAC3B;qBAAM;oBACL,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;iBACzB;aACF;SACF;IACH,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;IACZ,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,IAAI,WAAW,IAAI,CAAC,cAAc;YAAE,kBAAkB,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;QAC5E,IAAI,cAAc;YAAE,kBAAkB,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;IACjE,CAAC,EAAE,CAAC,WAAW,EAAE,cAAc,CAAC,CAAC,CAAC;IAElC,YAAY;IACZ,YAAY;IACZ,OAAO,CACL,6BAAK,SAAS,EAAC,SAAS;QACtB,6BAAK,SAAS,EAAC,gBAAgB;YAC7B,6BAAK,SAAS,EAAC,yBAAyB;gBACtC,6BAAK,SAAS,EAAC,eAAe,IAC3B,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CACf,6BACE,GAAG,EAAE,GAAG,CAAC,EAAE,EACX,SAAS,EAAE;;oBAEP,GAAG,CAAC,EAAE,KAAK,WAAW,CAAC,EAAE,CAAC,CAAC,CAAC,wBAAwB,CAAC,CAAC,CAAC,EAAE;oBACzD,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,wBAAwB,CAAC,CAAC,CAAC,EAAE;iBAC/C,EACD,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,QAAQ,IAAI,eAAe,CAAC,CAAC,EAAE,GAAG,EAAE,MAAM,CAAC;oBAE7D,GAAG,CAAC,IAAI,IAAI,CACX,6BAAK,SAAS,EAAC,oBAAoB;wBACjC,oBAAC,eAAM,IAAC,IAAI,EAAE,GAAG,CAAC,IAAI,GAAI,CACtB,CACP;oBACD,6BAAK,SAAS,EAAC,qBAAqB,IAAE,GAAG,CAAC,KAAK,CAAO;oBACrD,GAAG,CAAC,EAAE,KAAK,WAAW,CAAC,EAAE,IAAI,6BAAK,SAAS,EAAC,4BAA4B,GAAG;oBAE3E,GAAG,CAAC,EAAE,KAAK,WAAW,CAAC,EAAE;wBACxB,GAAG,CAAC,OAAO,EAAE,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CACzB,6BACE,GAAG,EAAE,MAAM,CAAC,EAAE,EACd,SAAS,EAAC,kBAAkB,EAC5B,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC,QAAQ,IAAI,eAAe,CAAC,CAAC,EAAE,MAAM,EAAE,KAAK,CAAC;4BAEnE,oBAAC,eAAM,IAAC,IAAI,EAAC,eAAe,GAAG;4BAC/B,6BACE,SAAS,EAAE;;4BAEP,MAAM,CAAC,EAAE,KAAK,cAAc,EAAE,EAAE,CAAC,CAAC,CAAC,4BAA4B,CAAC,CAAC,CAAC,EAAE;4BACpE,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,wBAAwB,CAAC,CAAC,CAAC,EAAE;yBAClD,IAEA,MAAM,CAAC,KAAK,CACT,CACF,CACP,CAAC,CACA,CACP,CAAC,CACE,CACF;YAEL,WAAW,EAAE,OAAO,IAAI,6BAAK,SAAS,EAAC,iBAAiB,IAAE,WAAW,EAAE,OAAO,CAAO,CAClF;QAEN,6BAAK,SAAS,EAAC,mBAAmB,IAAE,eAAe,CAAO,CACtD,CACP,CAAC;AACJ,CAAC,CAAC;AArGW,QAAA,MAAM,UAqGjB"}
@@ -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/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.10.13",
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: <></> },