@unbxd-ui/unbxd-react-components 0.2.221 → 0.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +17 -1
- package/components/Accordian/Accordian.js +14 -11
- package/components/Accordian/Accordian.stories.js +141 -118
- package/components/Accordian/index.js +1 -1
- package/components/Button/Button.js +4 -4
- package/components/Button/Button.stories.js +168 -62
- package/components/Button/DropdownButton.js +5 -6
- package/components/Button/buttonTheme.css +1 -1
- package/components/Button/index.js +2 -3
- package/components/DataLoader/DataLoader.js +6 -7
- package/components/DataLoader/DataLoader.stories.js +244 -58
- package/components/DataLoader/index.js +1 -1
- package/components/Form/Checkbox.js +12 -11
- package/components/Form/DragDropFileUploader.js +6 -7
- package/components/Form/Dropdown.js +14 -12
- package/components/Form/FileUploader.js +3 -4
- package/components/Form/Form.js +6 -7
- package/components/Form/FormElementWrapper.js +1 -1
- package/components/Form/Input.js +24 -15
- package/components/Form/RadioList.js +8 -9
- package/components/Form/RangeSlider.js +12 -13
- package/components/Form/SearchableDropdown.js +563 -0
- package/components/Form/ServerPaginatedDDList.js +53 -44
- package/components/Form/Textarea.js +26 -10
- package/components/Form/Toggle.js +6 -7
- package/components/Form/formCore.css +1 -1
- package/components/Form/formTheme.css +1 -1
- package/components/Form/index.js +8 -1
- package/components/Form/stories/Checkbox.stories.js +139 -40
- package/components/Form/stories/Dropdown.stories.js +323 -92
- package/components/Form/stories/FileUploader.stories.js +178 -19
- package/components/Form/stories/Input.stories.js +115 -0
- package/components/Form/stories/RangeSlider.stories.js +162 -64
- package/components/Form/stories/SearchableDropdown.stories.js +189 -0
- package/components/Form/stories/ServerPaginatedDropdown.stories.js +365 -0
- package/components/Form/stories/Textarea.stories.js +113 -34
- package/components/Form/stories/Toggle.stories.js +193 -14
- package/components/Form/variables.css +0 -0
- package/components/InlineModal/InlineModal.js +119 -21
- package/components/InlineModal/InlineModal.stories.js +239 -45
- package/components/InlineModal/index.js +1 -2
- package/components/InlineModal/inlineModalCore.css +1 -1
- package/components/List/List.js +11 -8
- package/components/List/List.stories.js +238 -0
- package/components/List/index.js +1 -1
- package/components/Modal/Modal.js +67 -20
- package/components/Modal/Modal.stories.js +257 -38
- package/components/Modal/index.js +1 -1
- package/components/Modal/modalCore.css +1 -1
- package/components/NoDataPlaceholder/NoDataPlaceholder.js +41 -0
- package/components/NoDataPlaceholder/NoDataPlaceholder.stories.js +42 -0
- package/components/NoDataPlaceholder/index.js +9 -0
- package/components/NoDataPlaceholder/noDataPlaceholderCore.css +1 -0
- package/components/NotificationComponent/NotificationComponent.js +20 -10
- package/components/NotificationComponent/NotificationComponent.stories.js +171 -19
- package/components/NotificationComponent/index.js +1 -1
- package/components/NotificationComponent/notificationTheme.css +1 -1
- package/components/PageLoader/PageLoader.js +84 -0
- package/components/PageLoader/PageLoader.stories.js +276 -0
- package/components/PageLoader/index.js +9 -0
- package/components/PageLoader/pageLoaderCore.css +1 -0
- package/components/ProgressBar/ProgressBar.css +0 -0
- package/components/ProgressBar/ProgressBar.js +1 -1
- package/components/ProgressBar/ProgressBar.stories.js +203 -10
- package/components/ProgressBar/index.js +1 -1
- package/components/ProgressBar/progressBarCore.css +1 -1
- package/components/Table/BaseTable.js +86 -342
- package/components/Table/PaginationComponent.js +4 -4
- package/components/Table/Table.js +7 -326
- package/components/Table/Table.stories.js +2117 -158
- package/components/Table/TableChild.js +383 -0
- package/components/Table/TableConstants.js +15 -0
- package/components/Table/hooks/usePrevious.js +14 -0
- package/components/Table/index.js +14 -1
- package/components/Table/tableCore.css +1 -1
- package/components/TableOld/BaseTable.js +373 -0
- package/components/TableOld/PaginationComponent.js +86 -0
- package/components/TableOld/TableOld.js +367 -0
- package/components/TableOld/index.js +15 -0
- package/components/TabsComponent/TabsComponent.js +6 -7
- package/components/TabsComponent/TabsComponent.stories.js +291 -53
- package/components/TabsComponent/index.js +1 -1
- package/components/ToastNotification/ToastNotificationWrapper.js +212 -0
- package/components/ToastNotification/ToastNotificationWrapper.stories.js +554 -0
- package/components/ToastNotification/index.js +40 -0
- package/components/ToastNotification/toastNotificationCore.css +1 -0
- package/components/Tooltip/Tooltip.js +231 -56
- package/components/Tooltip/Tooltip.stories.js +380 -15
- package/components/Tooltip/index.js +1 -1
- package/components/Tooltip/tooltipCore.css +1 -1
- package/components/Tooltip/tooltipTheme.css +1 -1
- package/components/common/NoDataDropdown.js +50 -0
- package/components/common/common.css +1 -0
- package/components/core.css +2 -3
- package/components/core.scss +20 -1
- package/components/index.js +66 -3
- package/components/theme.css +2 -3
- package/core/Validators.js +1 -1
- package/core/customHooks.js +4 -4
- package/core/dataLoader.js +58 -17
- package/core/index.js +1 -1
- package/core/utils.js +15 -4
- package/index.js +54 -0
- package/package.json +41 -28
- package/components/Button/DropdownButton.stories.js +0 -49
- package/components/Form/stories/DragDropFileUploader.stories.js +0 -25
- package/components/Form/stories/FormDefault.stories.js +0 -115
- package/components/Form/stories/RadioList.stories.js +0 -53
- package/components/Form/stories/TextInput.stories.js +0 -76
- package/components/Form/stories/form.stories.js +0 -233
- package/components/List/list.stories.js +0 -35
- package/core/dataLoader.stories.js +0 -119
|
@@ -3,108 +3,339 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
-
exports["default"] = exports.
|
|
6
|
+
exports["default"] = exports.WithPreselectedValue = exports.WithLabel = exports.WithCreateCTA = exports.Disabled = exports.Default = exports.CustomOptionRenderer = void 0;
|
|
7
7
|
var _react = _interopRequireDefault(require("react"));
|
|
8
|
-
var _Constants = require("../../../../public/Constants");
|
|
9
8
|
var _Dropdown = _interopRequireDefault(require("../Dropdown"));
|
|
10
9
|
var _dataLoader = _interopRequireDefault(require("../../../core/dataLoader"));
|
|
11
|
-
function _interopRequireDefault(
|
|
12
|
-
function
|
|
13
|
-
function
|
|
14
|
-
function
|
|
15
|
-
function
|
|
16
|
-
function
|
|
17
|
-
function
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
}
|
|
21
|
-
var
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
onChange: onChange,
|
|
32
|
-
noSelectionLabel: "Select"
|
|
33
|
-
});
|
|
34
|
-
};
|
|
35
|
-
SimpleUsage.story = {
|
|
36
|
-
name: "Simple Usage ",
|
|
10
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; }
|
|
11
|
+
function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
|
|
12
|
+
function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); }
|
|
13
|
+
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
14
|
+
function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); }
|
|
15
|
+
function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); }
|
|
16
|
+
function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
|
|
17
|
+
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
18
|
+
function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
|
|
19
|
+
function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
|
|
20
|
+
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
|
21
|
+
function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
|
|
22
|
+
// Set up all request configurations globally
|
|
23
|
+
_dataLoader["default"].addRequestConfig('getUsers', {
|
|
24
|
+
url: 'https://jsonplaceholder.typicode.com/users',
|
|
25
|
+
method: 'GET'
|
|
26
|
+
});
|
|
27
|
+
var meta = {
|
|
28
|
+
title: 'Components/Form/Dropdown',
|
|
29
|
+
component: _Dropdown["default"],
|
|
37
30
|
parameters: {
|
|
38
|
-
|
|
39
|
-
|
|
31
|
+
layout: 'centered'
|
|
32
|
+
},
|
|
33
|
+
tags: ['autodocs'],
|
|
34
|
+
argTypes: {
|
|
35
|
+
placeholder: {
|
|
36
|
+
control: 'text',
|
|
37
|
+
description: 'Placeholder text'
|
|
38
|
+
},
|
|
39
|
+
disabled: {
|
|
40
|
+
control: 'boolean',
|
|
41
|
+
description: 'Whether the dropdown is disabled'
|
|
42
|
+
},
|
|
43
|
+
className: {
|
|
44
|
+
control: 'text',
|
|
45
|
+
description: 'Additional CSS classes'
|
|
40
46
|
}
|
|
41
47
|
}
|
|
42
48
|
};
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
49
|
+
var _default = exports["default"] = meta;
|
|
50
|
+
var sampleOptions = [{
|
|
51
|
+
id: '1',
|
|
52
|
+
label: 'Option 1'
|
|
53
|
+
}, {
|
|
54
|
+
id: '2',
|
|
55
|
+
label: 'Option 2'
|
|
56
|
+
}, {
|
|
57
|
+
id: '3',
|
|
58
|
+
label: 'Option 3'
|
|
59
|
+
}, {
|
|
60
|
+
id: '4',
|
|
61
|
+
label: 'Option 4'
|
|
62
|
+
}, {
|
|
63
|
+
id: '5',
|
|
64
|
+
label: 'Option 5'
|
|
65
|
+
}];
|
|
66
|
+
var Default = exports.Default = {
|
|
67
|
+
render: function render() {
|
|
68
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
69
|
+
style: {
|
|
70
|
+
width: '300px'
|
|
71
|
+
}
|
|
72
|
+
}, /*#__PURE__*/_react["default"].createElement(_Dropdown["default"], {
|
|
73
|
+
idAttribute: "id",
|
|
74
|
+
nameAttribute: "label",
|
|
75
|
+
className: "demo-dropdown",
|
|
76
|
+
options: sampleOptions,
|
|
77
|
+
placeholder: "Select an option",
|
|
78
|
+
onChange: function onChange(value) {
|
|
79
|
+
return console.log('Selected:', value);
|
|
80
|
+
}
|
|
81
|
+
}));
|
|
82
|
+
}
|
|
69
83
|
};
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
84
|
+
var WithLabel = exports.WithLabel = {
|
|
85
|
+
render: function render() {
|
|
86
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
87
|
+
style: {
|
|
88
|
+
width: '300px'
|
|
89
|
+
}
|
|
90
|
+
}, /*#__PURE__*/_react["default"].createElement(_Dropdown["default"], {
|
|
91
|
+
label: "Select Option",
|
|
92
|
+
idAttribute: "id",
|
|
93
|
+
nameAttribute: "label",
|
|
94
|
+
options: sampleOptions,
|
|
95
|
+
placeholder: "Choose...",
|
|
96
|
+
onChange: function onChange(value) {
|
|
97
|
+
return console.log('Selected:', value);
|
|
98
|
+
}
|
|
99
|
+
}));
|
|
76
100
|
}
|
|
77
101
|
};
|
|
78
|
-
var
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
responseFormatter: responseFormatter
|
|
101
|
-
});
|
|
102
|
+
var WithPreselectedValue = exports.WithPreselectedValue = {
|
|
103
|
+
render: function render() {
|
|
104
|
+
var _React$useState = _react["default"].useState(sampleOptions[1]),
|
|
105
|
+
_React$useState2 = _slicedToArray(_React$useState, 2),
|
|
106
|
+
selectedValue = _React$useState2[0],
|
|
107
|
+
setSelectedValue = _React$useState2[1];
|
|
108
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
109
|
+
style: {
|
|
110
|
+
width: '300px'
|
|
111
|
+
}
|
|
112
|
+
}, /*#__PURE__*/_react["default"].createElement(_Dropdown["default"], {
|
|
113
|
+
idAttribute: "id",
|
|
114
|
+
nameAttribute: "label",
|
|
115
|
+
label: "Favorite Option",
|
|
116
|
+
options: sampleOptions,
|
|
117
|
+
value: selectedValue,
|
|
118
|
+
onChange: function onChange(value) {
|
|
119
|
+
console.log('Selected:', value);
|
|
120
|
+
setSelectedValue(value);
|
|
121
|
+
}
|
|
122
|
+
}));
|
|
123
|
+
}
|
|
102
124
|
};
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
125
|
+
var Disabled = exports.Disabled = {
|
|
126
|
+
render: function render() {
|
|
127
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
128
|
+
style: {
|
|
129
|
+
width: '300px'
|
|
130
|
+
}
|
|
131
|
+
}, /*#__PURE__*/_react["default"].createElement(_Dropdown["default"], {
|
|
132
|
+
idAttribute: "id",
|
|
133
|
+
nameAttribute: "label",
|
|
134
|
+
label: "Disabled Dropdown",
|
|
135
|
+
options: sampleOptions,
|
|
136
|
+
disabled: true,
|
|
137
|
+
value: sampleOptions[0],
|
|
138
|
+
onChange: function onChange(value) {
|
|
139
|
+
return console.log('Selected:', value);
|
|
140
|
+
}
|
|
141
|
+
}));
|
|
142
|
+
}
|
|
143
|
+
};
|
|
144
|
+
var CustomOptionRenderer = exports.CustomOptionRenderer = {
|
|
145
|
+
render: function render() {
|
|
146
|
+
var customOptions = [{
|
|
147
|
+
id: '1',
|
|
148
|
+
label: 'Success',
|
|
149
|
+
status: 'success'
|
|
150
|
+
}, {
|
|
151
|
+
id: '2',
|
|
152
|
+
label: 'Warning',
|
|
153
|
+
status: 'warning'
|
|
154
|
+
}, {
|
|
155
|
+
id: '3',
|
|
156
|
+
label: 'Error',
|
|
157
|
+
status: 'error'
|
|
158
|
+
}];
|
|
159
|
+
var CustomOption = function CustomOption(_ref) {
|
|
160
|
+
var option = _ref.option;
|
|
161
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
162
|
+
style: {
|
|
163
|
+
display: 'flex',
|
|
164
|
+
alignItems: 'center',
|
|
165
|
+
gap: '8px'
|
|
166
|
+
}
|
|
167
|
+
}, /*#__PURE__*/_react["default"].createElement("span", {
|
|
168
|
+
style: {
|
|
169
|
+
width: '8px',
|
|
170
|
+
height: '8px',
|
|
171
|
+
borderRadius: '50%',
|
|
172
|
+
backgroundColor: option.status === 'success' ? '#4CAF50' : option.status === 'warning' ? '#FFC107' : '#F44336'
|
|
173
|
+
}
|
|
174
|
+
}), option.label);
|
|
175
|
+
};
|
|
176
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
177
|
+
style: {
|
|
178
|
+
width: '300px'
|
|
179
|
+
}
|
|
180
|
+
}, /*#__PURE__*/_react["default"].createElement(_Dropdown["default"], {
|
|
181
|
+
idAttribute: "id",
|
|
182
|
+
nameAttribute: "label",
|
|
183
|
+
label: "Status",
|
|
184
|
+
options: customOptions,
|
|
185
|
+
optionRenderer: CustomOption,
|
|
186
|
+
onChange: function onChange(value) {
|
|
187
|
+
return console.log('Selected:', value);
|
|
188
|
+
}
|
|
189
|
+
}));
|
|
190
|
+
}
|
|
191
|
+
};
|
|
192
|
+
var WithCreateCTA = exports.WithCreateCTA = {
|
|
193
|
+
args: {
|
|
194
|
+
showCreateCTA: true,
|
|
195
|
+
label: 'Categories',
|
|
196
|
+
idAttribute: 'id',
|
|
197
|
+
nameAttribute: 'label',
|
|
198
|
+
showSearch: true,
|
|
199
|
+
searchPlaceholder: 'Search categories...',
|
|
200
|
+
multiSelect: true,
|
|
201
|
+
noSelectionLabel: 'Select categories'
|
|
202
|
+
},
|
|
203
|
+
render: function render() {
|
|
204
|
+
var _React$useState3 = _react["default"].useState([{
|
|
205
|
+
id: '1',
|
|
206
|
+
label: 'Electronics'
|
|
207
|
+
}, {
|
|
208
|
+
id: '2',
|
|
209
|
+
label: 'Clothing'
|
|
210
|
+
}, {
|
|
211
|
+
id: '3',
|
|
212
|
+
label: 'Books'
|
|
213
|
+
}]),
|
|
214
|
+
_React$useState4 = _slicedToArray(_React$useState3, 2),
|
|
215
|
+
options = _React$useState4[0],
|
|
216
|
+
setOptions = _React$useState4[1];
|
|
217
|
+
var _React$useState5 = _react["default"].useState([]),
|
|
218
|
+
_React$useState6 = _slicedToArray(_React$useState5, 2),
|
|
219
|
+
selectedValues = _React$useState6[0],
|
|
220
|
+
setSelectedValues = _React$useState6[1];
|
|
221
|
+
var CreateCTAComponent = function CreateCTAComponent() {
|
|
222
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
223
|
+
style: {
|
|
224
|
+
padding: '8px 16px',
|
|
225
|
+
borderTop: '1px solid #e2e8f0',
|
|
226
|
+
cursor: 'pointer',
|
|
227
|
+
display: 'flex',
|
|
228
|
+
alignItems: 'center',
|
|
229
|
+
gap: '8px',
|
|
230
|
+
color: '#2563eb',
|
|
231
|
+
fontSize: '14px'
|
|
232
|
+
}
|
|
233
|
+
}, /*#__PURE__*/_react["default"].createElement("span", {
|
|
234
|
+
style: {
|
|
235
|
+
fontSize: '16px'
|
|
236
|
+
}
|
|
237
|
+
}, "+"), /*#__PURE__*/_react["default"].createElement("span", null, "Log Selected Data"));
|
|
238
|
+
};
|
|
239
|
+
var DropdownItem = function DropdownItem(props) {
|
|
240
|
+
var itemData = props.itemData;
|
|
241
|
+
var isSelected = selectedValues.some(function (val) {
|
|
242
|
+
return val.id === itemData.id;
|
|
243
|
+
});
|
|
244
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
245
|
+
style: {
|
|
246
|
+
width: '300px'
|
|
247
|
+
}
|
|
248
|
+
}, /*#__PURE__*/_react["default"].createElement("div", {
|
|
249
|
+
onClick: function onClick() {
|
|
250
|
+
if (isSelected) {
|
|
251
|
+
setSelectedValues(selectedValues.filter(function (val) {
|
|
252
|
+
return val.id !== itemData.id;
|
|
253
|
+
}));
|
|
254
|
+
} else {
|
|
255
|
+
setSelectedValues([].concat(_toConsumableArray(selectedValues), [itemData]));
|
|
256
|
+
}
|
|
257
|
+
},
|
|
258
|
+
style: {
|
|
259
|
+
backgroundColor: isSelected ? '#e2e8f0' : 'transparent',
|
|
260
|
+
cursor: 'pointer',
|
|
261
|
+
padding: '8px 16px'
|
|
262
|
+
}
|
|
263
|
+
}, /*#__PURE__*/_react["default"].createElement("div", {
|
|
264
|
+
style: {
|
|
265
|
+
display: 'flex',
|
|
266
|
+
alignItems: 'center',
|
|
267
|
+
gap: '8px'
|
|
268
|
+
}
|
|
269
|
+
}, /*#__PURE__*/_react["default"].createElement("input", {
|
|
270
|
+
type: "checkbox",
|
|
271
|
+
checked: isSelected,
|
|
272
|
+
readOnly: true
|
|
273
|
+
}), /*#__PURE__*/_react["default"].createElement("span", null, itemData.label))));
|
|
274
|
+
};
|
|
275
|
+
var SelectionSummary = function SelectionSummary() {
|
|
276
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
277
|
+
style: {
|
|
278
|
+
display: 'flex',
|
|
279
|
+
flexWrap: 'wrap',
|
|
280
|
+
gap: '4px'
|
|
281
|
+
}
|
|
282
|
+
}, selectedValues.length > 0 ? /*#__PURE__*/_react["default"].createElement("div", {
|
|
283
|
+
style: {
|
|
284
|
+
display: 'flex',
|
|
285
|
+
flexWrap: 'wrap',
|
|
286
|
+
gap: '4px'
|
|
287
|
+
}
|
|
288
|
+
}, selectedValues.map(function (value) {
|
|
289
|
+
return /*#__PURE__*/_react["default"].createElement("span", {
|
|
290
|
+
key: value.id,
|
|
291
|
+
style: {
|
|
292
|
+
background: '#e2e8f0',
|
|
293
|
+
padding: '2px 8px',
|
|
294
|
+
borderRadius: '4px',
|
|
295
|
+
fontSize: '14px',
|
|
296
|
+
display: 'flex',
|
|
297
|
+
alignItems: 'center',
|
|
298
|
+
gap: '4px'
|
|
299
|
+
}
|
|
300
|
+
}, value.label, /*#__PURE__*/_react["default"].createElement("button", {
|
|
301
|
+
onClick: function onClick(e) {
|
|
302
|
+
e.stopPropagation();
|
|
303
|
+
setSelectedValues(selectedValues.filter(function (val) {
|
|
304
|
+
return val.id !== value.id;
|
|
305
|
+
}));
|
|
306
|
+
},
|
|
307
|
+
style: {
|
|
308
|
+
border: 'none',
|
|
309
|
+
background: 'none',
|
|
310
|
+
padding: '0',
|
|
311
|
+
cursor: 'pointer',
|
|
312
|
+
fontSize: '14px',
|
|
313
|
+
color: '#666'
|
|
314
|
+
}
|
|
315
|
+
}, "\xD7"));
|
|
316
|
+
})) : /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement("span", null, "Select categories"), /*#__PURE__*/_react["default"].createElement("span", {
|
|
317
|
+
className: "RCB-select-arrow"
|
|
318
|
+
})));
|
|
319
|
+
};
|
|
320
|
+
var handleCreateCTAClick = function handleCreateCTAClick() {
|
|
321
|
+
console.log(selectedValues);
|
|
322
|
+
};
|
|
323
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
324
|
+
style: {
|
|
325
|
+
width: '300px'
|
|
326
|
+
}
|
|
327
|
+
}, /*#__PURE__*/_react["default"].createElement(_Dropdown["default"], _extends({
|
|
328
|
+
multiSelect: true,
|
|
329
|
+
options: options,
|
|
330
|
+
value: selectedValues,
|
|
331
|
+
onChange: function onChange(value) {
|
|
332
|
+
return setSelectedValues(value);
|
|
333
|
+
},
|
|
334
|
+
showCreateCTA: true,
|
|
335
|
+
onCreateCTAClick: handleCreateCTAClick,
|
|
336
|
+
createCTAComponent: /*#__PURE__*/_react["default"].createElement(CreateCTAComponent, null),
|
|
337
|
+
DropdownItem: DropdownItem,
|
|
338
|
+
SelectionSummary: SelectionSummary
|
|
339
|
+
}, WithCreateCTA.args)));
|
|
109
340
|
}
|
|
110
341
|
};
|
|
@@ -3,27 +3,186 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
-
exports["default"] = exports.
|
|
6
|
+
exports["default"] = exports.WithLabel = exports.WithAcceptedTypes = exports.ShowFileDetails = exports.MultipleFiles = exports.Default = void 0;
|
|
7
7
|
var _react = _interopRequireDefault(require("react"));
|
|
8
8
|
var _FileUploader = _interopRequireDefault(require("../FileUploader"));
|
|
9
|
-
function _interopRequireDefault(
|
|
10
|
-
|
|
11
|
-
|
|
9
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; }
|
|
10
|
+
function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
|
|
11
|
+
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
12
|
+
function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
|
|
13
|
+
function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
|
|
14
|
+
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
|
15
|
+
function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
|
|
16
|
+
var meta = {
|
|
17
|
+
title: 'Components/Form/FileUploader',
|
|
18
|
+
component: _FileUploader["default"],
|
|
19
|
+
parameters: {
|
|
20
|
+
layout: 'centered',
|
|
21
|
+
docs: {
|
|
22
|
+
description: {
|
|
23
|
+
component: 'A flexible file upload component that supports single and multiple file uploads with custom triggers.'
|
|
24
|
+
}
|
|
25
|
+
},
|
|
26
|
+
storySource: {
|
|
27
|
+
showCode: true
|
|
28
|
+
}
|
|
29
|
+
},
|
|
30
|
+
tags: ['autodocs'],
|
|
31
|
+
argTypes: {
|
|
32
|
+
accept: {
|
|
33
|
+
control: 'text',
|
|
34
|
+
description: 'Accepted file types (e.g., ".jpg,.png,.pdf")'
|
|
35
|
+
},
|
|
36
|
+
multiple: {
|
|
37
|
+
control: 'boolean',
|
|
38
|
+
description: 'Allow multiple file uploads'
|
|
39
|
+
},
|
|
40
|
+
disabled: {
|
|
41
|
+
control: 'boolean',
|
|
42
|
+
description: 'Whether the uploader is disabled'
|
|
43
|
+
},
|
|
44
|
+
error: {
|
|
45
|
+
control: 'text',
|
|
46
|
+
description: 'Error message to display'
|
|
47
|
+
},
|
|
48
|
+
className: {
|
|
49
|
+
control: 'text',
|
|
50
|
+
description: 'Additional CSS classes'
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
};
|
|
54
|
+
var _default = exports["default"] = meta;
|
|
55
|
+
var Default = exports.Default = {
|
|
56
|
+
render: function render() {
|
|
57
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
58
|
+
style: {
|
|
59
|
+
width: '300px'
|
|
60
|
+
}
|
|
61
|
+
}, /*#__PURE__*/_react["default"].createElement(_FileUploader["default"], {
|
|
62
|
+
name: "file-uploader1",
|
|
63
|
+
onChange: function onChange(files) {
|
|
64
|
+
return console.log('Files:', files);
|
|
65
|
+
}
|
|
66
|
+
}, /*#__PURE__*/_react["default"].createElement("a", {
|
|
67
|
+
href: "#",
|
|
68
|
+
style: {
|
|
69
|
+
color: '#2563eb',
|
|
70
|
+
textDecoration: 'none'
|
|
71
|
+
}
|
|
72
|
+
}, "Click to upload a file")));
|
|
73
|
+
}
|
|
12
74
|
};
|
|
13
|
-
var
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
75
|
+
var WithLabel = exports.WithLabel = {
|
|
76
|
+
render: function render() {
|
|
77
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
78
|
+
style: {
|
|
79
|
+
width: '300px'
|
|
80
|
+
}
|
|
81
|
+
}, /*#__PURE__*/_react["default"].createElement(_FileUploader["default"], {
|
|
82
|
+
label: "File Uploader",
|
|
83
|
+
name: "file-uploader2",
|
|
84
|
+
onChange: function onChange(files) {
|
|
85
|
+
return console.log('Files:', files);
|
|
86
|
+
}
|
|
87
|
+
}, /*#__PURE__*/_react["default"].createElement("a", {
|
|
88
|
+
href: "#",
|
|
89
|
+
style: {
|
|
90
|
+
color: '#2563eb',
|
|
91
|
+
textDecoration: 'none'
|
|
92
|
+
}
|
|
93
|
+
}, "Choose file")));
|
|
94
|
+
}
|
|
95
|
+
};
|
|
96
|
+
var WithAcceptedTypes = exports.WithAcceptedTypes = {
|
|
97
|
+
render: function render() {
|
|
98
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
99
|
+
style: {
|
|
100
|
+
width: '300px'
|
|
101
|
+
}
|
|
102
|
+
}, /*#__PURE__*/_react["default"].createElement(_FileUploader["default"], {
|
|
103
|
+
name: "file-uploader3",
|
|
104
|
+
label: "Upload Images",
|
|
105
|
+
accept: ".jpg,.jpeg,.png,.gif",
|
|
106
|
+
helperText: "Accepted formats: JPG, PNG, GIF",
|
|
107
|
+
onChange: function onChange(files) {
|
|
108
|
+
return console.log('Files:', files);
|
|
109
|
+
}
|
|
110
|
+
}, /*#__PURE__*/_react["default"].createElement("a", {
|
|
111
|
+
href: "#",
|
|
112
|
+
style: {
|
|
113
|
+
color: '#2563eb',
|
|
114
|
+
textDecoration: 'none'
|
|
115
|
+
}
|
|
116
|
+
}, "Select images")));
|
|
117
|
+
}
|
|
118
|
+
};
|
|
119
|
+
var MultipleFiles = exports.MultipleFiles = {
|
|
120
|
+
args: {
|
|
121
|
+
name: "file-uploader4",
|
|
122
|
+
label: "Upload Documents",
|
|
123
|
+
multiple: true,
|
|
124
|
+
helperText: "Upload multiple documents",
|
|
125
|
+
onChange: function onChange(files) {
|
|
126
|
+
return console.log('Files:', files);
|
|
19
127
|
}
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
128
|
+
},
|
|
129
|
+
render: function render(args) {
|
|
130
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
131
|
+
style: {
|
|
132
|
+
width: '300px'
|
|
133
|
+
}
|
|
134
|
+
}, /*#__PURE__*/_react["default"].createElement(_FileUploader["default"], args, /*#__PURE__*/_react["default"].createElement("a", {
|
|
135
|
+
href: "#",
|
|
136
|
+
style: {
|
|
137
|
+
color: '#2563eb',
|
|
138
|
+
textDecoration: 'none'
|
|
139
|
+
}
|
|
140
|
+
}, "Upload multiple files")));
|
|
141
|
+
}
|
|
142
|
+
};
|
|
143
|
+
var ShowFileDetails = exports.ShowFileDetails = {
|
|
144
|
+
render: function render() {
|
|
145
|
+
var _React$useState = _react["default"].useState([]),
|
|
146
|
+
_React$useState2 = _slicedToArray(_React$useState, 2),
|
|
147
|
+
files = _React$useState2[0],
|
|
148
|
+
setFiles = _React$useState2[1];
|
|
149
|
+
var handleChange = function handleChange(newFiles) {
|
|
150
|
+
setFiles(Array.from(newFiles));
|
|
151
|
+
console.log('Files:', newFiles);
|
|
152
|
+
};
|
|
153
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
154
|
+
style: {
|
|
155
|
+
width: '300px'
|
|
156
|
+
}
|
|
157
|
+
}, /*#__PURE__*/_react["default"].createElement(_FileUploader["default"], {
|
|
158
|
+
name: "file-uploader5",
|
|
159
|
+
label: "Upload Files",
|
|
160
|
+
multiple: true,
|
|
161
|
+
value: files,
|
|
162
|
+
onChange: handleChange
|
|
163
|
+
}, /*#__PURE__*/_react["default"].createElement("a", {
|
|
164
|
+
href: "#",
|
|
165
|
+
style: {
|
|
166
|
+
color: '#2563eb',
|
|
167
|
+
textDecoration: 'none'
|
|
168
|
+
}
|
|
169
|
+
}, files.length > 0 ? 'Add more files' : 'Upload files')), files.length > 0 && /*#__PURE__*/_react["default"].createElement("div", {
|
|
170
|
+
style: {
|
|
171
|
+
marginTop: '16px'
|
|
172
|
+
}
|
|
173
|
+
}, /*#__PURE__*/_react["default"].createElement("h4", {
|
|
174
|
+
style: {
|
|
175
|
+
margin: '0 0 8px 0'
|
|
176
|
+
}
|
|
177
|
+
}, "Selected Files:"), /*#__PURE__*/_react["default"].createElement("ul", {
|
|
178
|
+
style: {
|
|
179
|
+
margin: 0,
|
|
180
|
+
padding: '0 0 0 20px'
|
|
181
|
+
}
|
|
182
|
+
}, files.map(function (file, index) {
|
|
183
|
+
return /*#__PURE__*/_react["default"].createElement("li", {
|
|
184
|
+
key: index
|
|
185
|
+
}, file.name, " (", (file.size / 1024).toFixed(1), "KB)");
|
|
186
|
+
}))));
|
|
187
|
+
}
|
|
29
188
|
};
|