@dktunited-techoff/techoff-suite-ui 1.14.0 → 1.14.2
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/esm/components/TsDropdowns/TsDropdown/TsDropdown.js +4 -4
- package/esm/components/TsDropdowns/TsDropdown/TsDropdown.js.map +1 -1
- package/esm/components/TsDropdowns/TsDropdown/TsDropdown.tsx +4 -4
- package/esm/components/TsModal/TsModal.d.ts +1 -1
- package/esm/components/TsModal/TsModal.js +4 -3
- package/esm/components/TsModal/TsModal.js.map +1 -1
- package/esm/components/TsModal/TsModal.types.d.ts +2 -0
- package/esm/components/TsModal/__stories__/TsModal.stories.mdx +12 -0
- package/lib/components/TsDropdowns/TsDropdown/TsDropdown.js +4 -4
- package/lib/components/TsDropdowns/TsDropdown/TsDropdown.js.map +1 -1
- package/lib/components/TsDropdowns/TsDropdown/TsDropdown.tsx +4 -4
- package/lib/components/TsModal/TsModal.d.ts +1 -1
- package/lib/components/TsModal/TsModal.js +4 -3
- package/lib/components/TsModal/TsModal.js.map +1 -1
- package/lib/components/TsModal/TsModal.types.d.ts +2 -0
- package/lib/components/TsModal/__stories__/TsModal.stories.mdx +12 -0
- package/package.json +1 -1
- package/src/components/TsDropdowns/TsDropdown/TsDropdown.tsx +4 -4
- package/src/components/TsModal/TsModal.tsx +24 -7
- package/src/components/TsModal/TsModal.types.ts +2 -0
- package/src/components/TsModal/__stories__/TsModal.stories.mdx +12 -0
|
@@ -16,7 +16,7 @@ export const TsDropdown = ({ containerRef, error, errorAction, label, noItemFoun
|
|
|
16
16
|
// ########
|
|
17
17
|
// Fetchers
|
|
18
18
|
const fetchOptions = () => {
|
|
19
|
-
if (!
|
|
19
|
+
if (!items.length && loadOptions) {
|
|
20
20
|
setIsLoading(true);
|
|
21
21
|
setIsFetchError(false);
|
|
22
22
|
loadOptions(searchValue)
|
|
@@ -39,10 +39,10 @@ export const TsDropdown = ({ containerRef, error, errorAction, label, noItemFoun
|
|
|
39
39
|
fetchOptions();
|
|
40
40
|
}, [...reloadOptionsOn, disabled]);
|
|
41
41
|
useEffect(() => {
|
|
42
|
-
if (searchable &&
|
|
43
|
-
setItems(
|
|
42
|
+
if (searchable && items.length) {
|
|
43
|
+
setItems(items.filter(item => getOptionLabel(item).toLowerCase().includes(searchValue.toLowerCase())));
|
|
44
44
|
}
|
|
45
|
-
if (searchable && !
|
|
45
|
+
if (searchable && !items.length && loadOptions) {
|
|
46
46
|
setIsLoading(true);
|
|
47
47
|
setIsFetchError(false);
|
|
48
48
|
const timeOutId = setTimeout(fetchOptions, 500);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TsDropdown.js","sourceRoot":"","sources":["../../../../src/components/TsDropdowns/TsDropdown/TsDropdown.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAEpD,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAC7C,OAAO,EAAE,OAAO,EAAE,MAAM,+BAA+B,CAAC;AACxD,OAAO,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAC;AACnE,OAAO,EAAE,QAAQ,EAAE,MAAM,yBAAyB,CAAC;AACnD,OAAO,kBAAkB,CAAC;AAE1B,MAAM,CAAC,MAAM,UAAU,GAAG,CAAK,EAC7B,YAAY,EACZ,KAAK,EACL,WAAW,EACX,KAAK,EACL,kBAAkB,EAClB,OAAO,EACP,WAAW,EACX,eAAe,GAAG,EAAE,EACpB,iBAAiB,EACjB,KAAK,EACL,QAAQ,EACR,UAAU,EACV,MAAM,EACN,cAAc,EACd,cAAc,EACd,WAAW,EACX,QAAQ,GACW,EAAE,EAAE;IACvB,MAAM,CAAC,gBAAgB,EAAE,mBAAmB,CAAC,GAAG,QAAQ,CAAU,KAAK,CAAC,CAAC;IACzE,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAS,EAAE,CAAC,CAAC;IAC3D,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAM,OAAO,IAAI,EAAE,CAAC,CAAC;IACvD,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAU,KAAK,CAAC,CAAC;IAC3D,MAAM,CAAC,YAAY,EAAE,eAAe,CAAC,GAAG,QAAQ,CAAU,KAAK,CAAC,CAAC;IACjE,MAAM,WAAW,GAAG,eAAe,CAAC,GAAG,EAAE,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC,CAAC;IACtE,MAAM,eAAe,GAAG,MAAM,CAAiB,IAAI,CAAC,CAAC;IAErD,WAAW;IACX,WAAW;IACX,MAAM,YAAY,GAAG,GAAG,EAAE;QACxB,IAAI,CAAC,
|
|
1
|
+
{"version":3,"file":"TsDropdown.js","sourceRoot":"","sources":["../../../../src/components/TsDropdowns/TsDropdown/TsDropdown.tsx"],"names":[],"mappings":"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"}
|
|
@@ -37,7 +37,7 @@ export const TsDropdown = <T,>({
|
|
|
37
37
|
// ########
|
|
38
38
|
// Fetchers
|
|
39
39
|
const fetchOptions = () => {
|
|
40
|
-
if (!
|
|
40
|
+
if (!items.length && loadOptions) {
|
|
41
41
|
setIsLoading(true);
|
|
42
42
|
setIsFetchError(false);
|
|
43
43
|
loadOptions(searchValue)
|
|
@@ -61,11 +61,11 @@ export const TsDropdown = <T,>({
|
|
|
61
61
|
if (!disabled) fetchOptions();
|
|
62
62
|
}, [...reloadOptionsOn, disabled]);
|
|
63
63
|
useEffect(() => {
|
|
64
|
-
if (searchable &&
|
|
65
|
-
setItems(
|
|
64
|
+
if (searchable && items.length) {
|
|
65
|
+
setItems(items.filter(item => getOptionLabel(item).toLowerCase().includes(searchValue.toLowerCase())));
|
|
66
66
|
}
|
|
67
67
|
|
|
68
|
-
if (searchable && !
|
|
68
|
+
if (searchable && !items.length && loadOptions) {
|
|
69
69
|
setIsLoading(true);
|
|
70
70
|
setIsFetchError(false);
|
|
71
71
|
const timeOutId = setTimeout(fetchOptions, 500);
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import * as React from 'react';
|
|
2
2
|
import { TsModalProps } from './TsModal.types';
|
|
3
3
|
import './TsModal.css';
|
|
4
|
-
export declare const TsModal: ({ children, actionLabel, actionIcon, style, title, onAction, onClose }: TsModalProps) => React.JSX.Element;
|
|
4
|
+
export declare const TsModal: ({ children, actionDisabled, actionLabel, actionLoading, actionIcon, style, title, onAction, onClose, }: TsModalProps) => React.JSX.Element;
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import * as React from 'react';
|
|
2
2
|
import { TsButton } from '../TsButton/TsButton';
|
|
3
3
|
import './TsModal.css';
|
|
4
|
-
|
|
4
|
+
import { TsLoader } from '../TsLoader/TsLoader';
|
|
5
|
+
export const TsModal = ({ children, actionDisabled, actionLabel, actionLoading, actionIcon, style, title, onAction, onClose, }) => {
|
|
5
6
|
// Rendering
|
|
6
7
|
return (React.createElement("div", { className: "ts-modal-container" },
|
|
7
8
|
React.createElement("div", { className: "ts-modal-blur" }),
|
|
@@ -10,8 +11,8 @@ export const TsModal = ({ children, actionLabel, actionIcon, style, title, onAct
|
|
|
10
11
|
React.createElement("div", { className: "ts-modal-title" }, title),
|
|
11
12
|
React.createElement(TsButton, { icon: "close", variant: "ghost", rounded: true, onClick: onClose })),
|
|
12
13
|
React.createElement("div", { className: "ts-modal-content" }, children),
|
|
13
|
-
React.createElement("div", { className: "ts-modal-footer" },
|
|
14
|
+
React.createElement("div", { className: "ts-modal-footer" }, !actionLoading ? (React.createElement(React.Fragment, null,
|
|
14
15
|
React.createElement(TsButton, { variant: "secondary", onClick: onClose }, "Cancel"),
|
|
15
|
-
React.createElement(TsButton, { icon: actionIcon, variant: "primary", onClick: onAction }, actionLabel)))));
|
|
16
|
+
React.createElement(TsButton, { icon: actionIcon, variant: "primary", disabled: actionDisabled, onClick: onAction }, actionLabel))) : (React.createElement(TsLoader, null))))));
|
|
16
17
|
};
|
|
17
18
|
//# sourceMappingURL=TsModal.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TsModal.js","sourceRoot":"","sources":["../../../src/components/TsModal/TsModal.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAChD,OAAO,eAAe,CAAC;
|
|
1
|
+
{"version":3,"file":"TsModal.js","sourceRoot":"","sources":["../../../src/components/TsModal/TsModal.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAChD,OAAO,eAAe,CAAC;AACvB,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAEhD,MAAM,CAAC,MAAM,OAAO,GAAG,CAAC,EACtB,QAAQ,EACR,cAAc,EACd,WAAW,EACX,aAAa,EACb,UAAU,EACV,KAAK,EACL,KAAK,EACL,QAAQ,EACR,OAAO,GACM,EAAE,EAAE;IACjB,YAAY;IACZ,OAAO,CACL,6BAAK,SAAS,EAAC,oBAAoB;QACjC,6BAAK,SAAS,EAAC,eAAe,GAAG;QAEjC,6BAAK,SAAS,EAAC,UAAU,EAAC,KAAK,EAAE,KAAK;YACpC,6BAAK,SAAS,EAAC,iBAAiB;gBAC9B,6BAAK,SAAS,EAAC,gBAAgB,IAAE,KAAK,CAAO;gBAE7C,oBAAC,QAAQ,IAAC,IAAI,EAAC,OAAO,EAAC,OAAO,EAAC,OAAO,EAAC,OAAO,QAAC,OAAO,EAAE,OAAO,GAAI,CAC/D;YAEN,6BAAK,SAAS,EAAC,kBAAkB,IAAE,QAAQ,CAAO;YAElD,6BAAK,SAAS,EAAC,iBAAiB,IAC7B,CAAC,aAAa,CAAC,CAAC,CAAC,CAChB;gBACE,oBAAC,QAAQ,IAAC,OAAO,EAAC,WAAW,EAAC,OAAO,EAAE,OAAO,aAEnC;gBACX,oBAAC,QAAQ,IAAC,IAAI,EAAE,UAAU,EAAE,OAAO,EAAC,SAAS,EAAC,QAAQ,EAAE,cAAc,EAAE,OAAO,EAAE,QAAQ,IACtF,WAAW,CACH,CACV,CACJ,CAAC,CAAC,CAAC,CACF,oBAAC,QAAQ,OAAG,CACb,CACG,CACF,CACF,CACP,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -6,6 +6,11 @@ import { icons } from '../../TsIcon/icons';
|
|
|
6
6
|
<Meta title="Components/Modal" />
|
|
7
7
|
|
|
8
8
|
export const modalArgTypes = {
|
|
9
|
+
actionDisabled: {
|
|
10
|
+
control: 'boolean',
|
|
11
|
+
description: 'Define if the action button is disabled',
|
|
12
|
+
table: { defaultValue: { summary: 'false' } },
|
|
13
|
+
},
|
|
9
14
|
actionIcon: {
|
|
10
15
|
control: 'select',
|
|
11
16
|
options: Object.keys(icons),
|
|
@@ -15,6 +20,11 @@ export const modalArgTypes = {
|
|
|
15
20
|
control: 'text',
|
|
16
21
|
description: 'Label of the modal action button.',
|
|
17
22
|
},
|
|
23
|
+
actionLoading: {
|
|
24
|
+
control: 'boolean',
|
|
25
|
+
description: 'Define if the action button is loading',
|
|
26
|
+
table: { defaultValue: { summary: 'false' } },
|
|
27
|
+
},
|
|
18
28
|
title: {
|
|
19
29
|
control: 'text',
|
|
20
30
|
description: 'Title of the modal.',
|
|
@@ -40,8 +50,10 @@ The Modal Component is the main Component of the Overlay pattern and is used to
|
|
|
40
50
|
name="Overview"
|
|
41
51
|
args={{
|
|
42
52
|
title: 'New modal',
|
|
53
|
+
actionDisabled: false,
|
|
43
54
|
actionIcon: 'add',
|
|
44
55
|
actionLabel: 'Create',
|
|
56
|
+
actionLoading: false,
|
|
45
57
|
onAction: () => console.log('Action !'),
|
|
46
58
|
onClose: () => console.log('Close !'),
|
|
47
59
|
}}
|
|
@@ -19,7 +19,7 @@ const TsDropdown = ({ containerRef, error, errorAction, label, noItemFoundMessag
|
|
|
19
19
|
// ########
|
|
20
20
|
// Fetchers
|
|
21
21
|
const fetchOptions = () => {
|
|
22
|
-
if (!
|
|
22
|
+
if (!items.length && loadOptions) {
|
|
23
23
|
setIsLoading(true);
|
|
24
24
|
setIsFetchError(false);
|
|
25
25
|
loadOptions(searchValue)
|
|
@@ -42,10 +42,10 @@ const TsDropdown = ({ containerRef, error, errorAction, label, noItemFoundMessag
|
|
|
42
42
|
fetchOptions();
|
|
43
43
|
}, [...reloadOptionsOn, disabled]);
|
|
44
44
|
(0, react_1.useEffect)(() => {
|
|
45
|
-
if (searchable &&
|
|
46
|
-
setItems(
|
|
45
|
+
if (searchable && items.length) {
|
|
46
|
+
setItems(items.filter(item => getOptionLabel(item).toLowerCase().includes(searchValue.toLowerCase())));
|
|
47
47
|
}
|
|
48
|
-
if (searchable && !
|
|
48
|
+
if (searchable && !items.length && loadOptions) {
|
|
49
49
|
setIsLoading(true);
|
|
50
50
|
setIsFetchError(false);
|
|
51
51
|
const timeOutId = setTimeout(fetchOptions, 500);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TsDropdown.js","sourceRoot":"","sources":["../../../../src/components/TsDropdowns/TsDropdown/TsDropdown.tsx"],"names":[],"mappings":";;;AAAA,+BAA+B;AAC/B,iCAAoD;AAEpD,gDAA6C;AAC7C,2DAAwD;AACxD,wEAAmE;AACnE,sDAAmD;AACnD,4BAA0B;AAEnB,MAAM,UAAU,GAAG,CAAK,EAC7B,YAAY,EACZ,KAAK,EACL,WAAW,EACX,KAAK,EACL,kBAAkB,EAClB,OAAO,EACP,WAAW,EACX,eAAe,GAAG,EAAE,EACpB,iBAAiB,EACjB,KAAK,EACL,QAAQ,EACR,UAAU,EACV,MAAM,EACN,cAAc,EACd,cAAc,EACd,WAAW,EACX,QAAQ,GACW,EAAE,EAAE;IACvB,MAAM,CAAC,gBAAgB,EAAE,mBAAmB,CAAC,GAAG,IAAA,gBAAQ,EAAU,KAAK,CAAC,CAAC;IACzE,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,IAAA,gBAAQ,EAAS,EAAE,CAAC,CAAC;IAC3D,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,IAAA,gBAAQ,EAAM,OAAO,IAAI,EAAE,CAAC,CAAC;IACvD,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,IAAA,gBAAQ,EAAU,KAAK,CAAC,CAAC;IAC3D,MAAM,CAAC,YAAY,EAAE,eAAe,CAAC,GAAG,IAAA,gBAAQ,EAAU,KAAK,CAAC,CAAC;IACjE,MAAM,WAAW,GAAG,IAAA,mCAAe,EAAC,GAAG,EAAE,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC,CAAC;IACtE,MAAM,eAAe,GAAG,IAAA,cAAM,EAAiB,IAAI,CAAC,CAAC;IAErD,WAAW;IACX,WAAW;IACX,MAAM,YAAY,GAAG,GAAG,EAAE;QACxB,IAAI,CAAC,
|
|
1
|
+
{"version":3,"file":"TsDropdown.js","sourceRoot":"","sources":["../../../../src/components/TsDropdowns/TsDropdown/TsDropdown.tsx"],"names":[],"mappings":"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"}
|
|
@@ -37,7 +37,7 @@ export const TsDropdown = <T,>({
|
|
|
37
37
|
// ########
|
|
38
38
|
// Fetchers
|
|
39
39
|
const fetchOptions = () => {
|
|
40
|
-
if (!
|
|
40
|
+
if (!items.length && loadOptions) {
|
|
41
41
|
setIsLoading(true);
|
|
42
42
|
setIsFetchError(false);
|
|
43
43
|
loadOptions(searchValue)
|
|
@@ -61,11 +61,11 @@ export const TsDropdown = <T,>({
|
|
|
61
61
|
if (!disabled) fetchOptions();
|
|
62
62
|
}, [...reloadOptionsOn, disabled]);
|
|
63
63
|
useEffect(() => {
|
|
64
|
-
if (searchable &&
|
|
65
|
-
setItems(
|
|
64
|
+
if (searchable && items.length) {
|
|
65
|
+
setItems(items.filter(item => getOptionLabel(item).toLowerCase().includes(searchValue.toLowerCase())));
|
|
66
66
|
}
|
|
67
67
|
|
|
68
|
-
if (searchable && !
|
|
68
|
+
if (searchable && !items.length && loadOptions) {
|
|
69
69
|
setIsLoading(true);
|
|
70
70
|
setIsFetchError(false);
|
|
71
71
|
const timeOutId = setTimeout(fetchOptions, 500);
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import * as React from 'react';
|
|
2
2
|
import { TsModalProps } from './TsModal.types';
|
|
3
3
|
import './TsModal.css';
|
|
4
|
-
export declare const TsModal: ({ children, actionLabel, actionIcon, style, title, onAction, onClose }: TsModalProps) => React.JSX.Element;
|
|
4
|
+
export declare const TsModal: ({ children, actionDisabled, actionLabel, actionLoading, actionIcon, style, title, onAction, onClose, }: TsModalProps) => React.JSX.Element;
|
|
@@ -4,7 +4,8 @@ exports.TsModal = void 0;
|
|
|
4
4
|
const React = require("react");
|
|
5
5
|
const TsButton_1 = require("../TsButton/TsButton");
|
|
6
6
|
require("./TsModal.css");
|
|
7
|
-
const
|
|
7
|
+
const TsLoader_1 = require("../TsLoader/TsLoader");
|
|
8
|
+
const TsModal = ({ children, actionDisabled, actionLabel, actionLoading, actionIcon, style, title, onAction, onClose, }) => {
|
|
8
9
|
// Rendering
|
|
9
10
|
return (React.createElement("div", { className: "ts-modal-container" },
|
|
10
11
|
React.createElement("div", { className: "ts-modal-blur" }),
|
|
@@ -13,9 +14,9 @@ const TsModal = ({ children, actionLabel, actionIcon, style, title, onAction, on
|
|
|
13
14
|
React.createElement("div", { className: "ts-modal-title" }, title),
|
|
14
15
|
React.createElement(TsButton_1.TsButton, { icon: "close", variant: "ghost", rounded: true, onClick: onClose })),
|
|
15
16
|
React.createElement("div", { className: "ts-modal-content" }, children),
|
|
16
|
-
React.createElement("div", { className: "ts-modal-footer" },
|
|
17
|
+
React.createElement("div", { className: "ts-modal-footer" }, !actionLoading ? (React.createElement(React.Fragment, null,
|
|
17
18
|
React.createElement(TsButton_1.TsButton, { variant: "secondary", onClick: onClose }, "Cancel"),
|
|
18
|
-
React.createElement(TsButton_1.TsButton, { icon: actionIcon, variant: "primary", onClick: onAction }, actionLabel)))));
|
|
19
|
+
React.createElement(TsButton_1.TsButton, { icon: actionIcon, variant: "primary", disabled: actionDisabled, onClick: onAction }, actionLabel))) : (React.createElement(TsLoader_1.TsLoader, null))))));
|
|
19
20
|
};
|
|
20
21
|
exports.TsModal = TsModal;
|
|
21
22
|
//# sourceMappingURL=TsModal.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TsModal.js","sourceRoot":"","sources":["../../../src/components/TsModal/TsModal.tsx"],"names":[],"mappings":";;;AAAA,+BAA+B;AAE/B,mDAAgD;AAChD,yBAAuB;
|
|
1
|
+
{"version":3,"file":"TsModal.js","sourceRoot":"","sources":["../../../src/components/TsModal/TsModal.tsx"],"names":[],"mappings":";;;AAAA,+BAA+B;AAE/B,mDAAgD;AAChD,yBAAuB;AACvB,mDAAgD;AAEzC,MAAM,OAAO,GAAG,CAAC,EACtB,QAAQ,EACR,cAAc,EACd,WAAW,EACX,aAAa,EACb,UAAU,EACV,KAAK,EACL,KAAK,EACL,QAAQ,EACR,OAAO,GACM,EAAE,EAAE;IACjB,YAAY;IACZ,OAAO,CACL,6BAAK,SAAS,EAAC,oBAAoB;QACjC,6BAAK,SAAS,EAAC,eAAe,GAAG;QAEjC,6BAAK,SAAS,EAAC,UAAU,EAAC,KAAK,EAAE,KAAK;YACpC,6BAAK,SAAS,EAAC,iBAAiB;gBAC9B,6BAAK,SAAS,EAAC,gBAAgB,IAAE,KAAK,CAAO;gBAE7C,oBAAC,mBAAQ,IAAC,IAAI,EAAC,OAAO,EAAC,OAAO,EAAC,OAAO,EAAC,OAAO,QAAC,OAAO,EAAE,OAAO,GAAI,CAC/D;YAEN,6BAAK,SAAS,EAAC,kBAAkB,IAAE,QAAQ,CAAO;YAElD,6BAAK,SAAS,EAAC,iBAAiB,IAC7B,CAAC,aAAa,CAAC,CAAC,CAAC,CAChB;gBACE,oBAAC,mBAAQ,IAAC,OAAO,EAAC,WAAW,EAAC,OAAO,EAAE,OAAO,aAEnC;gBACX,oBAAC,mBAAQ,IAAC,IAAI,EAAE,UAAU,EAAE,OAAO,EAAC,SAAS,EAAC,QAAQ,EAAE,cAAc,EAAE,OAAO,EAAE,QAAQ,IACtF,WAAW,CACH,CACV,CACJ,CAAC,CAAC,CAAC,CACF,oBAAC,mBAAQ,OAAG,CACb,CACG,CACF,CACF,CACP,CAAC;AACJ,CAAC,CAAC;AA1CW,QAAA,OAAO,WA0ClB"}
|
|
@@ -6,6 +6,11 @@ import { icons } from '../../TsIcon/icons';
|
|
|
6
6
|
<Meta title="Components/Modal" />
|
|
7
7
|
|
|
8
8
|
export const modalArgTypes = {
|
|
9
|
+
actionDisabled: {
|
|
10
|
+
control: 'boolean',
|
|
11
|
+
description: 'Define if the action button is disabled',
|
|
12
|
+
table: { defaultValue: { summary: 'false' } },
|
|
13
|
+
},
|
|
9
14
|
actionIcon: {
|
|
10
15
|
control: 'select',
|
|
11
16
|
options: Object.keys(icons),
|
|
@@ -15,6 +20,11 @@ export const modalArgTypes = {
|
|
|
15
20
|
control: 'text',
|
|
16
21
|
description: 'Label of the modal action button.',
|
|
17
22
|
},
|
|
23
|
+
actionLoading: {
|
|
24
|
+
control: 'boolean',
|
|
25
|
+
description: 'Define if the action button is loading',
|
|
26
|
+
table: { defaultValue: { summary: 'false' } },
|
|
27
|
+
},
|
|
18
28
|
title: {
|
|
19
29
|
control: 'text',
|
|
20
30
|
description: 'Title of the modal.',
|
|
@@ -40,8 +50,10 @@ The Modal Component is the main Component of the Overlay pattern and is used to
|
|
|
40
50
|
name="Overview"
|
|
41
51
|
args={{
|
|
42
52
|
title: 'New modal',
|
|
53
|
+
actionDisabled: false,
|
|
43
54
|
actionIcon: 'add',
|
|
44
55
|
actionLabel: 'Create',
|
|
56
|
+
actionLoading: false,
|
|
45
57
|
onAction: () => console.log('Action !'),
|
|
46
58
|
onClose: () => console.log('Close !'),
|
|
47
59
|
}}
|
package/package.json
CHANGED
|
@@ -37,7 +37,7 @@ export const TsDropdown = <T,>({
|
|
|
37
37
|
// ########
|
|
38
38
|
// Fetchers
|
|
39
39
|
const fetchOptions = () => {
|
|
40
|
-
if (!
|
|
40
|
+
if (!items.length && loadOptions) {
|
|
41
41
|
setIsLoading(true);
|
|
42
42
|
setIsFetchError(false);
|
|
43
43
|
loadOptions(searchValue)
|
|
@@ -61,11 +61,11 @@ export const TsDropdown = <T,>({
|
|
|
61
61
|
if (!disabled) fetchOptions();
|
|
62
62
|
}, [...reloadOptionsOn, disabled]);
|
|
63
63
|
useEffect(() => {
|
|
64
|
-
if (searchable &&
|
|
65
|
-
setItems(
|
|
64
|
+
if (searchable && items.length) {
|
|
65
|
+
setItems(items.filter(item => getOptionLabel(item).toLowerCase().includes(searchValue.toLowerCase())));
|
|
66
66
|
}
|
|
67
67
|
|
|
68
|
-
if (searchable && !
|
|
68
|
+
if (searchable && !items.length && loadOptions) {
|
|
69
69
|
setIsLoading(true);
|
|
70
70
|
setIsFetchError(false);
|
|
71
71
|
const timeOutId = setTimeout(fetchOptions, 500);
|
|
@@ -2,8 +2,19 @@ import * as React from 'react';
|
|
|
2
2
|
import { TsModalProps } from './TsModal.types';
|
|
3
3
|
import { TsButton } from '../TsButton/TsButton';
|
|
4
4
|
import './TsModal.css';
|
|
5
|
+
import { TsLoader } from '../TsLoader/TsLoader';
|
|
5
6
|
|
|
6
|
-
export const TsModal = ({
|
|
7
|
+
export const TsModal = ({
|
|
8
|
+
children,
|
|
9
|
+
actionDisabled,
|
|
10
|
+
actionLabel,
|
|
11
|
+
actionLoading,
|
|
12
|
+
actionIcon,
|
|
13
|
+
style,
|
|
14
|
+
title,
|
|
15
|
+
onAction,
|
|
16
|
+
onClose,
|
|
17
|
+
}: TsModalProps) => {
|
|
7
18
|
// Rendering
|
|
8
19
|
return (
|
|
9
20
|
<div className="ts-modal-container">
|
|
@@ -19,12 +30,18 @@ export const TsModal = ({ children, actionLabel, actionIcon, style, title, onAct
|
|
|
19
30
|
<div className="ts-modal-content">{children}</div>
|
|
20
31
|
|
|
21
32
|
<div className="ts-modal-footer">
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
33
|
+
{!actionLoading ? (
|
|
34
|
+
<>
|
|
35
|
+
<TsButton variant="secondary" onClick={onClose}>
|
|
36
|
+
Cancel
|
|
37
|
+
</TsButton>
|
|
38
|
+
<TsButton icon={actionIcon} variant="primary" disabled={actionDisabled} onClick={onAction}>
|
|
39
|
+
{actionLabel}
|
|
40
|
+
</TsButton>
|
|
41
|
+
</>
|
|
42
|
+
) : (
|
|
43
|
+
<TsLoader />
|
|
44
|
+
)}
|
|
28
45
|
</div>
|
|
29
46
|
</div>
|
|
30
47
|
</div>
|
|
@@ -6,6 +6,11 @@ import { icons } from '../../TsIcon/icons';
|
|
|
6
6
|
<Meta title="Components/Modal" />
|
|
7
7
|
|
|
8
8
|
export const modalArgTypes = {
|
|
9
|
+
actionDisabled: {
|
|
10
|
+
control: 'boolean',
|
|
11
|
+
description: 'Define if the action button is disabled',
|
|
12
|
+
table: { defaultValue: { summary: 'false' } },
|
|
13
|
+
},
|
|
9
14
|
actionIcon: {
|
|
10
15
|
control: 'select',
|
|
11
16
|
options: Object.keys(icons),
|
|
@@ -15,6 +20,11 @@ export const modalArgTypes = {
|
|
|
15
20
|
control: 'text',
|
|
16
21
|
description: 'Label of the modal action button.',
|
|
17
22
|
},
|
|
23
|
+
actionLoading: {
|
|
24
|
+
control: 'boolean',
|
|
25
|
+
description: 'Define if the action button is loading',
|
|
26
|
+
table: { defaultValue: { summary: 'false' } },
|
|
27
|
+
},
|
|
18
28
|
title: {
|
|
19
29
|
control: 'text',
|
|
20
30
|
description: 'Title of the modal.',
|
|
@@ -40,8 +50,10 @@ The Modal Component is the main Component of the Overlay pattern and is used to
|
|
|
40
50
|
name="Overview"
|
|
41
51
|
args={{
|
|
42
52
|
title: 'New modal',
|
|
53
|
+
actionDisabled: false,
|
|
43
54
|
actionIcon: 'add',
|
|
44
55
|
actionLabel: 'Create',
|
|
56
|
+
actionLoading: false,
|
|
45
57
|
onAction: () => console.log('Action !'),
|
|
46
58
|
onClose: () => console.log('Close !'),
|
|
47
59
|
}}
|