@royaltics/ui 1.6.14 → 1.6.16
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/dist/forms/SelectMultiple.d.ts +3 -2
- package/dist/forms/SelectMultiple.d.ts.map +1 -1
- package/dist/forms/SelectMultiple.js +66 -13
- package/dist/forms/SelectMultiple.js.map +1 -1
- package/dist/forms/SelectMultiple.stories.d.ts +2 -10
- package/dist/forms/SelectMultiple.stories.d.ts.map +1 -1
- package/dist/forms/SelectMultiple.stories.js +2 -73
- package/dist/forms/SelectMultiple.stories.js.map +1 -1
- package/package.json +1 -1
|
@@ -7,8 +7,9 @@ export interface SelectMultipleProps extends ComponentInputBase {
|
|
|
7
7
|
KeyFindItem?: string;
|
|
8
8
|
onKeyDown?: (e: any) => void;
|
|
9
9
|
state: [any] | [any, React.Dispatch<any>];
|
|
10
|
-
|
|
10
|
+
placeholder?: string;
|
|
11
|
+
searchable?: boolean;
|
|
11
12
|
}
|
|
12
|
-
declare const _default: React.MemoExoticComponent<({ id, lb, state, onKeyDown, data, referer, keyText, keyValue, required, readOnly, className, KeyFindItem, size, variant,
|
|
13
|
+
declare const _default: React.MemoExoticComponent<({ id, lb, state, onKeyDown, data, referer, keyText, keyValue, required, readOnly, className, KeyFindItem, size, variant, placeholder, searchable }: SelectMultipleProps) => JSX.Element>;
|
|
13
14
|
export default _default;
|
|
14
15
|
//# sourceMappingURL=SelectMultiple.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SelectMultiple.d.ts","sourceRoot":"","sources":["../../src/forms/SelectMultiple.tsx"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"SelectMultiple.d.ts","sourceRoot":"","sources":["../../src/forms/SelectMultiple.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA4C,MAAM,OAAO,CAAC;AACjE,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AAIxD,MAAM,WAAW,mBAAoB,SAAQ,kBAAkB;IAC3D,IAAI,EAAE,GAAG,EAAE,CAAC;IACZ,OAAO,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;IAC5B,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,SAAS,CAAC,EAAE,CAAC,CAAC,EAAE,GAAG,KAAK,IAAI,CAAC;IAC7B,KAAK,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC;IAC1C,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,UAAU,CAAC,EAAE,OAAO,CAAC;CACxB;uMAmCE,mBAAmB,KAAG,GAAG,CAAC,OAAO;AAoNpC,wBAAoC"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import React, { memo, useEffect } from "react";
|
|
1
|
+
import React, { memo, useEffect, useState, useRef } from "react";
|
|
2
2
|
import { cn, cvaMix } from "../utils/index.js";
|
|
3
3
|
import { Variants } from "../constants/Variants.js";
|
|
4
4
|
const classNamesProps = cvaMix("flex flex-col items-stretch justify-start", {
|
|
@@ -12,40 +12,93 @@ const classNamesProps = cvaMix("flex flex-col items-stretch justify-start", {
|
|
|
12
12
|
width: 'full',
|
|
13
13
|
variant: 'fill'
|
|
14
14
|
});
|
|
15
|
-
const SelectMultiple = ({ id, lb, state, onKeyDown, data, referer, keyText = 'names', keyValue = 'id', required = false, readOnly, className, KeyFindItem, size = 'xs', variant = 'outline',
|
|
15
|
+
const SelectMultiple = ({ id, lb, state, onKeyDown, data, referer, keyText = 'names', keyValue = 'id', required = false, readOnly, className, KeyFindItem, size = 'xs', variant = 'outline', placeholder = 'Seleccione opciones...', searchable = true }) => {
|
|
16
16
|
const [inputs, setInputs] = state;
|
|
17
|
+
const [isOpen, setIsOpen] = useState(false);
|
|
18
|
+
const [searchTerm, setSearchTerm] = useState('');
|
|
19
|
+
const dropdownRef = useRef(null);
|
|
17
20
|
const isObject = (item) => typeof item === 'object';
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
const
|
|
21
|
+
// Close dropdown when clicking outside
|
|
22
|
+
useEffect(() => {
|
|
23
|
+
const handleClickOutside = (event) => {
|
|
24
|
+
if (dropdownRef.current && !dropdownRef.current.contains(event.target)) {
|
|
25
|
+
setIsOpen(false);
|
|
26
|
+
setSearchTerm('');
|
|
27
|
+
}
|
|
28
|
+
};
|
|
29
|
+
document.addEventListener('mousedown', handleClickOutside);
|
|
30
|
+
return () => document.removeEventListener('mousedown', handleClickOutside);
|
|
31
|
+
}, []);
|
|
32
|
+
const selectedValues = inputs?.[id] !== undefined && Array.isArray(inputs[id]) ? inputs[id] : [];
|
|
33
|
+
const toggleOption = (value) => {
|
|
34
|
+
if (readOnly)
|
|
35
|
+
return;
|
|
36
|
+
const newValues = selectedValues.includes(value)
|
|
37
|
+
? selectedValues.filter((v) => v !== value)
|
|
38
|
+
: [...selectedValues, value];
|
|
21
39
|
if (KeyFindItem) {
|
|
22
|
-
const findItems =
|
|
23
|
-
setInputs?.({ [id]:
|
|
40
|
+
const findItems = newValues.map(val => data.find((item) => item === val || item[keyValue] === val));
|
|
41
|
+
setInputs?.({ [id]: newValues, [KeyFindItem]: findItems });
|
|
24
42
|
}
|
|
25
43
|
else {
|
|
26
|
-
setInputs?.({ [id]:
|
|
44
|
+
setInputs?.({ [id]: newValues });
|
|
27
45
|
}
|
|
28
46
|
};
|
|
47
|
+
const getItemText = (item) => {
|
|
48
|
+
if (!isObject(item))
|
|
49
|
+
return item;
|
|
50
|
+
return Array.isArray(keyText)
|
|
51
|
+
? `${item[keyText[0]]} - ${item[keyText[1]]}`
|
|
52
|
+
: item[keyText];
|
|
53
|
+
};
|
|
54
|
+
const getItemValue = (item) => {
|
|
55
|
+
return isObject(item) ? item[keyValue] : item;
|
|
56
|
+
};
|
|
57
|
+
const filteredData = searchable && searchTerm
|
|
58
|
+
? data.filter(item => {
|
|
59
|
+
const text = getItemText(item).toString().toLowerCase();
|
|
60
|
+
return text.includes(searchTerm.toLowerCase());
|
|
61
|
+
})
|
|
62
|
+
: data;
|
|
29
63
|
useEffect(() => {
|
|
30
64
|
if (!data || data.length == 0 || !id)
|
|
31
65
|
return;
|
|
32
66
|
if (inputs[id] == undefined || !Array.isArray(inputs[id])) {
|
|
33
|
-
// Initialize with empty array for multiple selection
|
|
34
67
|
setInputs?.({ [id]: [] });
|
|
35
68
|
}
|
|
36
69
|
else {
|
|
37
|
-
// Validate that all selected values exist in data
|
|
38
70
|
const validValues = inputs[id].filter((value) => data.find((item) => item == value || item[keyValue] == value));
|
|
39
71
|
if (validValues.length !== inputs[id].length) {
|
|
40
72
|
setInputs?.({ [id]: validValues });
|
|
41
73
|
}
|
|
42
74
|
}
|
|
43
75
|
}, [data]);
|
|
44
|
-
return (React.createElement("div", { className: cn("flex flex-col items-stretch justify-start", className) },
|
|
45
|
-
lb && React.createElement("label", { htmlFor: id, className: cn(`font-medium text-input-label`) },
|
|
76
|
+
return (React.createElement("div", { className: cn("flex flex-col items-stretch justify-start relative", className), ref: dropdownRef },
|
|
77
|
+
lb && React.createElement("label", { htmlFor: id, className: cn(`font-medium text-input-label mb-1`) },
|
|
46
78
|
lb,
|
|
47
79
|
":"),
|
|
48
|
-
React.createElement("select", { ref: referer, required: required, disabled: readOnly,
|
|
80
|
+
React.createElement("select", { ref: referer, required: required, disabled: readOnly, name: id, value: selectedValues, onChange: () => { }, multiple: true, className: "hidden", tabIndex: -1 }, data && data.map((item, index) => (React.createElement("option", { key: index, value: getItemValue(item) }, getItemText(item))))),
|
|
81
|
+
React.createElement("div", { onClick: () => !readOnly && setIsOpen(!isOpen), onKeyDown: onKeyDown, className: cn('appearance-none custom cursor-pointer rounded-md h-auto w-full border-1 border-input-border outline-none transition-all', classNamesProps({ variant, size }), readOnly && 'opacity-60 cursor-not-allowed', isOpen && 'ring-2 ring-primary/50', "select-ui") },
|
|
82
|
+
React.createElement("div", { className: "flex gap-1.5 items-center overflow-hidden pr-8" }, selectedValues.length === 0 ? (React.createElement("span", { className: "text-foreground/40 text-sm truncate" }, placeholder)) : (React.createElement("div", { className: "flex gap-1.5 items-center flex-1 min-w-0" }, selectedValues.map((value) => {
|
|
83
|
+
const item = data.find(d => getItemValue(d) === value);
|
|
84
|
+
return (React.createElement("span", { key: value, className: cn("inline-flex items-center px-2 py-0.5 rounded text-xs whitespace-nowrap flex-shrink-0", "bg-primary/20 text-primary border border-primary/30") }, item ? getItemText(item) : value));
|
|
85
|
+
})))),
|
|
86
|
+
React.createElement("div", { className: "absolute right-2 top-1/2 -translate-y-1/2 pointer-events-none" },
|
|
87
|
+
React.createElement("svg", { className: cn("w-4 h-4 transition-transform text-accent", isOpen && "rotate-180"), fill: "none", stroke: "currentColor", viewBox: "0 0 24 24" },
|
|
88
|
+
React.createElement("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M19 9l-7 7-7-7" })))),
|
|
89
|
+
isOpen && !readOnly && (React.createElement("div", { className: cn("absolute z-50 w-full mt-1 rounded-md border border-input-border shadow-lg overflow-hidden", variant === 'fill' ? 'bg-input-options' : 'bg-background/90 backdrop-blur-sm', "top-full") },
|
|
90
|
+
searchable && (React.createElement("div", { className: "p-2 border-b border-input-border" },
|
|
91
|
+
React.createElement("input", { type: "text", placeholder: "Buscar...", value: searchTerm, onChange: (e) => setSearchTerm(e.target.value), className: cn("w-full px-2 py-1.5 text-sm rounded border border-input-border outline-none", "bg-transparent focus:ring-2 focus:ring-primary/50 even:bg-foreground/10"), onClick: (e) => e.stopPropagation() }))),
|
|
92
|
+
React.createElement("div", { className: "max-h-60 overflow-y-auto" }, filteredData.length === 0 ? (React.createElement("div", { className: "px-3 py-2 text-sm text-foreground/40" }, "No se encontraron opciones")) : (filteredData.map((item, index) => {
|
|
93
|
+
const value = getItemValue(item);
|
|
94
|
+
const isSelected = selectedValues.includes(value);
|
|
95
|
+
return (React.createElement("div", { key: index, onClick: () => toggleOption(value), className: cn("px-3 py-2 cursor-pointer transition-colors flex items-center gap-2", "hover:bg-primary/20", isSelected && "bg-primary/10") },
|
|
96
|
+
React.createElement("div", { className: cn("w-4 h-4 rounded border-2 flex items-center justify-center flex-shrink-0", isSelected
|
|
97
|
+
? "bg-primary border-primary"
|
|
98
|
+
: "border-foreground/40") }, isSelected && (React.createElement("svg", { className: "w-3 h-3 text-primary-foreground", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24" },
|
|
99
|
+
React.createElement("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 3, d: "M5 13l4 4L19 7" })))),
|
|
100
|
+
React.createElement("span", { className: "text-sm" }, getItemText(item))));
|
|
101
|
+
})))))));
|
|
49
102
|
};
|
|
50
103
|
export default memo(SelectMultiple);
|
|
51
104
|
//# sourceMappingURL=SelectMultiple.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SelectMultiple.js","sourceRoot":"","sources":["../../src/forms/SelectMultiple.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"SelectMultiple.js","sourceRoot":"","sources":["../../src/forms/SelectMultiple.tsx"],"names":[],"mappings":"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"}
|
|
@@ -3,24 +3,16 @@ import { SelectMultipleProps } from './SelectMultiple.js';
|
|
|
3
3
|
import React from 'react';
|
|
4
4
|
declare const meta: {
|
|
5
5
|
title: string;
|
|
6
|
-
component: React.MemoExoticComponent<({ id, lb, state, onKeyDown, data, referer, keyText, keyValue, required, readOnly, className, KeyFindItem, size, variant,
|
|
6
|
+
component: React.MemoExoticComponent<({ id, lb, state, onKeyDown, data, referer, keyText, keyValue, required, readOnly, className, KeyFindItem, size, variant, placeholder, searchable }: SelectMultipleProps) => JSX.Element>;
|
|
7
7
|
parameters: {
|
|
8
8
|
layout: string;
|
|
9
9
|
};
|
|
10
10
|
tags: string[];
|
|
11
11
|
argTypes: {
|
|
12
|
-
|
|
13
|
-
control: {
|
|
14
|
-
type: "number";
|
|
15
|
-
};
|
|
16
|
-
description: string;
|
|
17
|
-
};
|
|
12
|
+
[x: string]: any;
|
|
18
13
|
};
|
|
19
14
|
};
|
|
20
15
|
export default meta;
|
|
21
16
|
export declare const SelectMultipleBasic: StoryObj<typeof meta>;
|
|
22
17
|
export declare const SelectMultipleWithPreselection: StoryObj<typeof meta>;
|
|
23
|
-
export declare const SelectMultipleOutline: StoryObj<typeof meta>;
|
|
24
|
-
export declare const SelectMultipleSimpleArray: StoryObj<typeof meta>;
|
|
25
|
-
export declare const SelectMultipleReadOnly: StoryObj<typeof meta>;
|
|
26
18
|
//# sourceMappingURL=SelectMultiple.stories.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SelectMultiple.stories.d.ts","sourceRoot":"","sources":["../../src/forms/SelectMultiple.stories.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAQ,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAuB,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAE1E,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,QAAA,MAAM,IAAI
|
|
1
|
+
{"version":3,"file":"SelectMultiple.stories.d.ts","sourceRoot":"","sources":["../../src/forms/SelectMultiple.stories.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAQ,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAuB,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAE1E,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,QAAA,MAAM,IAAI;;;;;;;;;;CAW2B,CAAC;AAEtC,eAAe,IAAI,CAAC;AAIpB,eAAO,MAAM,mBAAmB,EAAE,QAAQ,CAAC,OAAO,IAAI,CAsCrD,CAAC;AAGF,eAAO,MAAM,8BAA8B,EAAE,QAAQ,CAAC,OAAO,IAAI,CAoChE,CAAC"}
|
|
@@ -11,10 +11,6 @@ const meta = {
|
|
|
11
11
|
tags: ['autodocs'],
|
|
12
12
|
argTypes: {
|
|
13
13
|
...ArgumentsInputs,
|
|
14
|
-
selectSize: {
|
|
15
|
-
control: { type: 'number' },
|
|
16
|
-
description: 'Number of visible options in the select',
|
|
17
|
-
},
|
|
18
14
|
}
|
|
19
15
|
};
|
|
20
16
|
export default meta;
|
|
@@ -23,7 +19,7 @@ export const SelectMultipleBasic = {
|
|
|
23
19
|
render: (args) => {
|
|
24
20
|
const [inputs, setInputs] = React.useState({ selectedItems: [] });
|
|
25
21
|
return (React.createElement("div", { className: 'flex flex-col gap-3 text-white' },
|
|
26
|
-
React.createElement(SelectMultiple, { data: args.data, id: "selectedItems", lb: args.lb, state: [inputs, setInputs], variant: args.variant, size: args.size, readOnly: args.readOnly
|
|
22
|
+
React.createElement(SelectMultiple, { data: args.data, id: "selectedItems", lb: args.lb, state: [inputs, setInputs], variant: args.variant, size: args.size, readOnly: args.readOnly }),
|
|
27
23
|
React.createElement("div", { className: 'mt-4 p-4 bg-gray-800 rounded-md' },
|
|
28
24
|
React.createElement("p", { className: 'text-sm font-semibold mb-2' }, "Selected Values:"),
|
|
29
25
|
React.createElement("pre", { className: 'text-xs' }, JSON.stringify(inputs.selectedItems, null, 2)))));
|
|
@@ -33,7 +29,6 @@ export const SelectMultipleBasic = {
|
|
|
33
29
|
lb: 'Selección Múltiple',
|
|
34
30
|
state: [{ selectedItems: [] }],
|
|
35
31
|
readOnly: false,
|
|
36
|
-
selectSize: 4,
|
|
37
32
|
data: [
|
|
38
33
|
{ id: 1, names: "Opción 1" },
|
|
39
34
|
{ id: 2, names: "Opción 2" },
|
|
@@ -47,7 +42,7 @@ export const SelectMultipleWithPreselection = {
|
|
|
47
42
|
render: (args) => {
|
|
48
43
|
const [inputs, setInputs] = React.useState({ selectedItems: ['2', '4'] });
|
|
49
44
|
return (React.createElement("div", { className: 'flex flex-col gap-3 text-white' },
|
|
50
|
-
React.createElement(SelectMultiple, { data: args.data, id: "selectedItems", lb: args.lb, state: [inputs, setInputs], variant: args.variant, size: args.size
|
|
45
|
+
React.createElement(SelectMultiple, { data: args.data, id: "selectedItems", lb: args.lb, state: [inputs, setInputs], variant: args.variant, size: args.size }),
|
|
51
46
|
React.createElement("div", { className: 'mt-4 p-4 bg-gray-800 rounded-md' },
|
|
52
47
|
React.createElement("p", { className: 'text-sm font-semibold mb-2' }, "Selected Values:"),
|
|
53
48
|
React.createElement("pre", { className: 'text-xs' }, JSON.stringify(inputs.selectedItems, null, 2)))));
|
|
@@ -56,7 +51,6 @@ export const SelectMultipleWithPreselection = {
|
|
|
56
51
|
id: 'selectedItems',
|
|
57
52
|
lb: 'Con Preselección',
|
|
58
53
|
state: [{ selectedItems: ['2', '4'] }],
|
|
59
|
-
selectSize: 5,
|
|
60
54
|
data: [
|
|
61
55
|
{ id: 1, names: "Opción 1" },
|
|
62
56
|
{ id: 2, names: "Opción 2" },
|
|
@@ -66,69 +60,4 @@ export const SelectMultipleWithPreselection = {
|
|
|
66
60
|
]
|
|
67
61
|
},
|
|
68
62
|
};
|
|
69
|
-
export const SelectMultipleOutline = {
|
|
70
|
-
render: (args) => {
|
|
71
|
-
const [inputs, setInputs] = React.useState({ options: [] });
|
|
72
|
-
return (React.createElement("div", { className: 'flex flex-col gap-3 text-white' },
|
|
73
|
-
React.createElement(SelectMultiple, { data: args.data, id: "options", lb: args.lb, state: [inputs, setInputs], variant: args.variant, size: args.size, selectSize: args.selectSize }),
|
|
74
|
-
React.createElement("div", { className: 'mt-4 p-4 bg-gray-800 rounded-md' },
|
|
75
|
-
React.createElement("p", { className: 'text-sm font-semibold mb-2' }, "Selected Values:"),
|
|
76
|
-
React.createElement("pre", { className: 'text-xs' }, JSON.stringify(inputs.options, null, 2)))));
|
|
77
|
-
},
|
|
78
|
-
args: {
|
|
79
|
-
id: 'options',
|
|
80
|
-
lb: 'Variante Outline',
|
|
81
|
-
state: [{ options: [] }],
|
|
82
|
-
variant: 'outline',
|
|
83
|
-
selectSize: 6,
|
|
84
|
-
data: [
|
|
85
|
-
{ id: 1, names: "Opción 1" },
|
|
86
|
-
{ id: 2, names: "Opción 2" },
|
|
87
|
-
{ id: 3, names: "Opción 3" },
|
|
88
|
-
{ id: 4, names: "Opción 4" },
|
|
89
|
-
{ id: 5, names: "Opción 5" },
|
|
90
|
-
{ id: 6, names: "Opción 6" }
|
|
91
|
-
]
|
|
92
|
-
},
|
|
93
|
-
};
|
|
94
|
-
export const SelectMultipleSimpleArray = {
|
|
95
|
-
render: (args) => {
|
|
96
|
-
const [inputs, setInputs] = React.useState({ fruits: [] });
|
|
97
|
-
return (React.createElement("div", { className: 'flex flex-col gap-3 text-white' },
|
|
98
|
-
React.createElement(SelectMultiple, { data: args.data, id: "fruits", lb: args.lb, state: [inputs, setInputs], variant: args.variant, size: args.size, selectSize: args.selectSize }),
|
|
99
|
-
React.createElement("div", { className: 'mt-4 p-4 bg-gray-800 rounded-md' },
|
|
100
|
-
React.createElement("p", { className: 'text-sm font-semibold mb-2' }, "Selected Values:"),
|
|
101
|
-
React.createElement("pre", { className: 'text-xs' }, JSON.stringify(inputs.fruits, null, 2)))));
|
|
102
|
-
},
|
|
103
|
-
args: {
|
|
104
|
-
id: 'fruits',
|
|
105
|
-
lb: 'Array Simple (sin objetos)',
|
|
106
|
-
state: [{ fruits: [] }],
|
|
107
|
-
selectSize: 5,
|
|
108
|
-
data: ["Manzana", "Banana", "Naranja", "Uva", "Sandía", "Piña"]
|
|
109
|
-
},
|
|
110
|
-
};
|
|
111
|
-
export const SelectMultipleReadOnly = {
|
|
112
|
-
render: (args) => {
|
|
113
|
-
const [inputs, setInputs] = React.useState({ readOnlyItems: ['1', '3'] });
|
|
114
|
-
return (React.createElement("div", { className: 'flex flex-col gap-3 text-white' },
|
|
115
|
-
React.createElement(SelectMultiple, { data: args.data, id: "readOnlyItems", lb: args.lb, state: [inputs, setInputs], variant: args.variant, size: args.size, readOnly: args.readOnly, selectSize: args.selectSize }),
|
|
116
|
-
React.createElement("div", { className: 'mt-4 p-4 bg-gray-800 rounded-md' },
|
|
117
|
-
React.createElement("p", { className: 'text-sm font-semibold mb-2' }, "Selected Values:"),
|
|
118
|
-
React.createElement("pre", { className: 'text-xs' }, JSON.stringify(inputs.readOnlyItems, null, 2)))));
|
|
119
|
-
},
|
|
120
|
-
args: {
|
|
121
|
-
id: 'readOnlyItems',
|
|
122
|
-
lb: 'Solo Lectura',
|
|
123
|
-
state: [{ readOnlyItems: ['1', '3'] }],
|
|
124
|
-
readOnly: true,
|
|
125
|
-
selectSize: 4,
|
|
126
|
-
data: [
|
|
127
|
-
{ id: 1, names: "Opción 1" },
|
|
128
|
-
{ id: 2, names: "Opción 2" },
|
|
129
|
-
{ id: 3, names: "Opción 3" },
|
|
130
|
-
{ id: 4, names: "Opción 4" }
|
|
131
|
-
]
|
|
132
|
-
},
|
|
133
|
-
};
|
|
134
63
|
//# sourceMappingURL=SelectMultiple.stories.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SelectMultiple.stories.js","sourceRoot":"","sources":["../../src/forms/SelectMultiple.stories.tsx"],"names":[],"mappings":"AAEA,OAAO,cAAuC,MAAM,qBAAqB,CAAC;AAC1E,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAC/D,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,wDAAwD;AACxD,MAAM,IAAI,GAAG;IACT,KAAK,EAAE,yBAAyB;IAChC,SAAS,EAAE,cAAc;IACzB,UAAU,EAAE;QACR,MAAM,EAAE,UAAU;KACrB;IACD,IAAI,EAAE,CAAC,UAAU,CAAC;IAClB,QAAQ,EAAE;QACN,GAAG,eAAe;
|
|
1
|
+
{"version":3,"file":"SelectMultiple.stories.js","sourceRoot":"","sources":["../../src/forms/SelectMultiple.stories.tsx"],"names":[],"mappings":"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"}
|