dinocollab-core 1.0.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 (214) hide show
  1. package/README.md +54 -0
  2. package/dist/_virtual/_rollupPluginBabelHelpers.js +431 -0
  3. package/dist/_virtual/_rollupPluginBabelHelpers.js.map +1 -0
  4. package/dist/assets/vector-404265a04f4f9c8be1f.webp +0 -0
  5. package/dist/node_modules/.pnpm/@rollup_plugin-typescript@1_d0d2002d9033600b6738d939bd598bc6/node_modules/tslib/tslib.es6.js +46 -0
  6. package/dist/node_modules/.pnpm/@rollup_plugin-typescript@1_d0d2002d9033600b6738d939bd598bc6/node_modules/tslib/tslib.es6.js.map +1 -0
  7. package/dist/src/api-context/alert-global.js +151 -0
  8. package/dist/src/api-context/alert-global.js.map +1 -0
  9. package/dist/src/api-context/drawer-global.js +105 -0
  10. package/dist/src/api-context/drawer-global.js.map +1 -0
  11. package/dist/src/api-context/global-modal.js +87 -0
  12. package/dist/src/api-context/global-modal.js.map +1 -0
  13. package/dist/src/api-context/popover-global.js +102 -0
  14. package/dist/src/api-context/popover-global.js.map +1 -0
  15. package/dist/src/api-context/popover.js +86 -0
  16. package/dist/src/api-context/popover.js.map +1 -0
  17. package/dist/src/api-context/ui.units.js +21 -0
  18. package/dist/src/api-context/ui.units.js.map +1 -0
  19. package/dist/src/components/copy-to-clipboard.js +105 -0
  20. package/dist/src/components/copy-to-clipboard.js.map +1 -0
  21. package/dist/src/components/custom.breadcrumbs.js +61 -0
  22. package/dist/src/components/custom.breadcrumbs.js.map +1 -0
  23. package/dist/src/components/help-tooltip.js +91 -0
  24. package/dist/src/components/help-tooltip.js.map +1 -0
  25. package/dist/src/components/image-with-fallback.js +48 -0
  26. package/dist/src/components/image-with-fallback.js.map +1 -0
  27. package/dist/src/components/text-editor.js +117 -0
  28. package/dist/src/components/text-editor.js.map +1 -0
  29. package/dist/src/form/create.autocomplete.chips.js +218 -0
  30. package/dist/src/form/create.autocomplete.chips.js.map +1 -0
  31. package/dist/src/form/create.date-expired.js +201 -0
  32. package/dist/src/form/create.date-expired.js.map +1 -0
  33. package/dist/src/form/create.date-picker.js +125 -0
  34. package/dist/src/form/create.date-picker.js.map +1 -0
  35. package/dist/src/form/create.form-base.js +135 -0
  36. package/dist/src/form/create.form-base.js.map +1 -0
  37. package/dist/src/form/create.form-comfirm.js +119 -0
  38. package/dist/src/form/create.form-comfirm.js.map +1 -0
  39. package/dist/src/form/create.form-grid-layout.js +177 -0
  40. package/dist/src/form/create.form-grid-layout.js.map +1 -0
  41. package/dist/src/form/create.form-grid-layout.units.js +39 -0
  42. package/dist/src/form/create.form-grid-layout.units.js.map +1 -0
  43. package/dist/src/form/create.input-base.js +260 -0
  44. package/dist/src/form/create.input-base.js.map +1 -0
  45. package/dist/src/form/create.input.file.js +74 -0
  46. package/dist/src/form/create.input.file.js.map +1 -0
  47. package/dist/src/form/create.select-simple.js +104 -0
  48. package/dist/src/form/create.select-simple.js.map +1 -0
  49. package/dist/src/form/create.select-with-api.js +271 -0
  50. package/dist/src/form/create.select-with-api.js.map +1 -0
  51. package/dist/src/form/create.text-editor.js +156 -0
  52. package/dist/src/form/create.text-editor.js.map +1 -0
  53. package/dist/src/form/dino-form.js +42 -0
  54. package/dist/src/form/dino-form.js.map +1 -0
  55. package/dist/src/form/helper.js +157 -0
  56. package/dist/src/form/helper.js.map +1 -0
  57. package/dist/src/form/modal-wrapper.js +75 -0
  58. package/dist/src/form/modal-wrapper.js.map +1 -0
  59. package/dist/src/form/validator.js +186 -0
  60. package/dist/src/form/validator.js.map +1 -0
  61. package/dist/src/hooks/index.js +48 -0
  62. package/dist/src/hooks/index.js.map +1 -0
  63. package/dist/src/index.js +26 -0
  64. package/dist/src/index.js.map +1 -0
  65. package/dist/src/redux/create.hoc-lazy.js +67 -0
  66. package/dist/src/redux/create.hoc-lazy.js.map +1 -0
  67. package/dist/src/redux/dino.js +11 -0
  68. package/dist/src/redux/dino.js.map +1 -0
  69. package/dist/src/redux/types.js +9 -0
  70. package/dist/src/redux/types.js.map +1 -0
  71. package/dist/src/redux/ui.error-page.js +80 -0
  72. package/dist/src/redux/ui.error-page.js.map +1 -0
  73. package/dist/src/redux/vector-404.webp.js +4 -0
  74. package/dist/src/redux/vector-404.webp.js.map +1 -0
  75. package/dist/src/table/context.js +12 -0
  76. package/dist/src/table/context.js.map +1 -0
  77. package/dist/src/table/create.action-row.js +135 -0
  78. package/dist/src/table/create.action-row.js.map +1 -0
  79. package/dist/src/table/create.status-cell.js +49 -0
  80. package/dist/src/table/create.status-cell.js.map +1 -0
  81. package/dist/src/table/create.table.js +233 -0
  82. package/dist/src/table/create.table.js.map +1 -0
  83. package/dist/src/table/custom.filter-operators.js +89 -0
  84. package/dist/src/table/custom.filter-operators.js.map +1 -0
  85. package/dist/src/table/dino.js +129 -0
  86. package/dist/src/table/dino.js.map +1 -0
  87. package/dist/src/table/helpers.js +116 -0
  88. package/dist/src/table/helpers.js.map +1 -0
  89. package/dist/src/table/model-filter.js +23 -0
  90. package/dist/src/table/model-filter.js.map +1 -0
  91. package/dist/src/table/toolbar-pannel.js +134 -0
  92. package/dist/src/table/toolbar-pannel.js.map +1 -0
  93. package/dist/src/table/ui.buttons.js +60 -0
  94. package/dist/src/table/ui.buttons.js.map +1 -0
  95. package/dist/src/table/ui.units.js +201 -0
  96. package/dist/src/table/ui.units.js.map +1 -0
  97. package/dist/src/utils/dayjs-config.js +12 -0
  98. package/dist/src/utils/dayjs-config.js.map +1 -0
  99. package/dist/src/utils/helpers.js +197 -0
  100. package/dist/src/utils/helpers.js.map +1 -0
  101. package/dist/src/utils/json-object.js +38 -0
  102. package/dist/src/utils/json-object.js.map +1 -0
  103. package/dist/src/utils/query-param.js +172 -0
  104. package/dist/src/utils/query-param.js.map +1 -0
  105. package/package.json +52 -0
  106. package/rollup.config.js +39 -0
  107. package/src/@types/global.d.ts +5 -0
  108. package/src/api-context/alert-global.tsx +174 -0
  109. package/src/api-context/drawer-global.tsx +116 -0
  110. package/src/api-context/global-modal.tsx +109 -0
  111. package/src/api-context/index.ts +13 -0
  112. package/src/api-context/popover-global.tsx +107 -0
  113. package/src/api-context/popover.tsx +89 -0
  114. package/src/api-context/ui.units.tsx +10 -0
  115. package/src/components/copy-to-clipboard.tsx +86 -0
  116. package/src/components/custom.breadcrumbs.tsx +67 -0
  117. package/src/components/help-tooltip.tsx +75 -0
  118. package/src/components/image-with-fallback.tsx +51 -0
  119. package/src/components/index.tsx +1 -0
  120. package/src/components/input-debounce-timer.tsx +138 -0
  121. package/src/components/loading-buttons.tsx +35 -0
  122. package/src/components/text-editor.preview.tsx +30 -0
  123. package/src/components/text-editor.tsx +125 -0
  124. package/src/form/README.md +55 -0
  125. package/src/form/create.autocomplete.chips.tsx +199 -0
  126. package/src/form/create.date-expired.tsx +195 -0
  127. package/src/form/create.date-picker.tsx +122 -0
  128. package/src/form/create.form-base.tsx +102 -0
  129. package/src/form/create.form-comfirm.tsx +83 -0
  130. package/src/form/create.form-grid-layout.tsx +170 -0
  131. package/src/form/create.form-grid-layout.units.tsx +37 -0
  132. package/src/form/create.input-base.tsx +222 -0
  133. package/src/form/create.input.file.tsx +76 -0
  134. package/src/form/create.select-simple.tsx +101 -0
  135. package/src/form/create.select-with-api.tsx +213 -0
  136. package/src/form/create.text-editor.tsx +161 -0
  137. package/src/form/dino-form.tsx +40 -0
  138. package/src/form/helper.ts +132 -0
  139. package/src/form/index.ts +12 -0
  140. package/src/form/modal-wrapper.tsx +75 -0
  141. package/src/form/types.ts +16 -0
  142. package/src/form/validator.ts +202 -0
  143. package/src/hooks/index.ts +44 -0
  144. package/src/index.ts +7 -0
  145. package/src/lab/create.autocomplete.simple.tsx +57 -0
  146. package/src/lab/create.dino-store.ts +59 -0
  147. package/src/lab/create.multi-select-dropdown.tsx +189 -0
  148. package/src/lab/create.select-mul-with-api/index.tsx +271 -0
  149. package/src/lab/create.select-mul-with-api/table-custom.tsx +194 -0
  150. package/src/lab/create.select-mul-with-api/types.ts +26 -0
  151. package/src/lab/create.select-mul-with-api/ui.units.tsx +163 -0
  152. package/src/lab/filter-bar/base.tsx +162 -0
  153. package/src/lab/filter-bar/create.filter-bar.tsx +190 -0
  154. package/src/lab/filter-bar/create.filter-menu.tsx +156 -0
  155. package/src/lab/filter-bar/create.filter-panel.tsx +95 -0
  156. package/src/lab/filter-bar/create.filtered.tsx +41 -0
  157. package/src/lab/filter-bar/create.sort-menu.tsx +43 -0
  158. package/src/lab/filter-bar/demo.tsx +50 -0
  159. package/src/lab/filter-bar/index.ts +6 -0
  160. package/src/lab/filter-bar/types.ts +105 -0
  161. package/src/lab/filter-bar/ui.units.tsx +70 -0
  162. package/src/lab/grafana-dashboard/configs.ts +43 -0
  163. package/src/lab/grafana-dashboard/date-time-range/absolute-time-rage.tsx +137 -0
  164. package/src/lab/grafana-dashboard/date-time-range/helpers.ts +126 -0
  165. package/src/lab/grafana-dashboard/date-time-range/index.tsx +62 -0
  166. package/src/lab/grafana-dashboard/date-time-range/menu-wrap.tsx +101 -0
  167. package/src/lab/grafana-dashboard/date-time-range/quick-ranges.tsx +161 -0
  168. package/src/lab/grafana-dashboard/date-time-range/types.ts +9 -0
  169. package/src/lab/grafana-dashboard/date-time-range/units.tsx +18 -0
  170. package/src/lab/grafana-dashboard/helper.ts +25 -0
  171. package/src/lab/grafana-dashboard/hooks.tsx +79 -0
  172. package/src/lab/grafana-dashboard/icons.tsx +67 -0
  173. package/src/lab/grafana-dashboard/index.tsx +120 -0
  174. package/src/lab/grafana-dashboard/top-bar.tsx +62 -0
  175. package/src/lab/grafana-dashboard/top-bar.types.ts +5 -0
  176. package/src/lab/grafana-dashboard/types.ts +8 -0
  177. package/src/lab/media-player.core1.tsx +273 -0
  178. package/src/lab/media-player.muted.tsx +62 -0
  179. package/src/lab/media-player.units.ts +80 -0
  180. package/src/lab/table-grid/create.table-grid.tsx +183 -0
  181. package/src/lab/table-grid/demo.tsx +53 -0
  182. package/src/lab/table-grid/dino.tsx +8 -0
  183. package/src/lab/table-grid/helpers.tsx +11 -0
  184. package/src/lab/table-grid/index.ts +3 -0
  185. package/src/lab/table-grid/item-actions.tsx +138 -0
  186. package/src/lab/table-grid/toolbar-pannel.tsx +98 -0
  187. package/src/lab/table-grid/types.ts +68 -0
  188. package/src/redux/create.hoc-lazy.tsx +80 -0
  189. package/src/redux/dino.ts +9 -0
  190. package/src/redux/index.ts +6 -0
  191. package/src/redux/types.ts +27 -0
  192. package/src/redux/ui.error-page.tsx +62 -0
  193. package/src/redux/ui.units.tsx +41 -0
  194. package/src/redux/vector-404.webp +0 -0
  195. package/src/table/context.tsx +16 -0
  196. package/src/table/create.action-row.tsx +91 -0
  197. package/src/table/create.status-cell.tsx +51 -0
  198. package/src/table/create.table.tsx +239 -0
  199. package/src/table/custom.filter-operators.ts +94 -0
  200. package/src/table/dino.tsx +120 -0
  201. package/src/table/helpers.ts +94 -0
  202. package/src/table/index.ts +13 -0
  203. package/src/table/model-filter.ts +43 -0
  204. package/src/table/toolbar-pannel.tsx +106 -0
  205. package/src/table/types.ts +50 -0
  206. package/src/table/ui.buttons.tsx +54 -0
  207. package/src/table/ui.units.tsx +189 -0
  208. package/src/utils/dayjs-config.ts +13 -0
  209. package/src/utils/helpers.ts +171 -0
  210. package/src/utils/index.ts +7 -0
  211. package/src/utils/json-object.ts +29 -0
  212. package/src/utils/mfe-events.tsx +34 -0
  213. package/src/utils/query-param.ts +129 -0
  214. package/tsconfig.json +20 -0
@@ -0,0 +1,260 @@
1
+ import { inherits as _inherits, createClass as _createClass, classCallCheck as _classCallCheck, callSuper as _callSuper, extends as _extends, regeneratorRuntime as _regeneratorRuntime } from '../../_virtual/_rollupPluginBabelHelpers.js';
2
+ import { __rest, __awaiter } from '../../node_modules/.pnpm/@rollup_plugin-typescript@1_d0d2002d9033600b6738d939bd598bc6/node_modules/tslib/tslib.es6.js';
3
+ import React, { Component } from 'react';
4
+ import { styled, Box, TextField, InputAdornment, IconButton, Collapse, CircularProgress } from '@mui/material';
5
+ import ContentPasteIcon from '@mui/icons-material/ContentPaste';
6
+ import { mergeObjects as _mergeObjects } from '../utils/helpers.js';
7
+ import '../utils/query-param.js';
8
+ import '../utils/dayjs-config.js';
9
+ import { getErrorMessage } from './helper.js';
10
+ import ImageWithFallback from '../components/image-with-fallback.js';
11
+
12
+ var CreateInputBase = function CreateInputBase(params) {
13
+ var InputBase = /*#__PURE__*/function (_Component) {
14
+ function InputBase(props) {
15
+ var _this;
16
+ _classCallCheck(this, InputBase);
17
+ var _a;
18
+ _this = _callSuper(this, InputBase, [props]);
19
+ _this._cachedSlots = {};
20
+ _this.mapTextFieldProps = function () {
21
+ var _a, _b, _c, _d;
22
+ var errorMessage = getErrorMessage(_this.props.messageErrors, _this.props.name);
23
+ var tfp = {
24
+ fullWidth: true,
25
+ variant: 'outlined',
26
+ name: (_a = _this.props.name) === null || _a === void 0 ? void 0 : _a.toString(),
27
+ error: errorMessage.error,
28
+ helperText: errorMessage.message,
29
+ disabled: _this.props.disabled,
30
+ onBlur: function onBlur() {
31
+ if (!_this.props.name) return;
32
+ _this.props.onBlur && _this.props.onBlur(_this.props.name);
33
+ },
34
+ label: _this.getLabel(),
35
+ placeholder: _this.props.placeholder,
36
+ InputLabelProps: !!_this.state.value ? {
37
+ shrink: true
38
+ } : {},
39
+ value: (_b = _this.state.value) !== null && _b !== void 0 ? _b : '',
40
+ onChange: _this.handleChange
41
+ };
42
+ if (_this.slots.pastenable === true) {
43
+ tfp.InputProps = {
44
+ endAdornment: /*#__PURE__*/React.createElement(InputAdornment, {
45
+ position: "end"
46
+ }, /*#__PURE__*/React.createElement(IconButton, {
47
+ onClick: _this.handlePaste,
48
+ edge: "end"
49
+ }, /*#__PURE__*/React.createElement(ContentPasteIcon, null)))
50
+ };
51
+ }
52
+ if ((_c = _this.slots) === null || _c === void 0 ? void 0 : _c.maxLength) tfp.inputProps = Object.assign(Object.assign({}, tfp.inputProps), {
53
+ maxLength: _this.slots.maxLength
54
+ });
55
+ return _mergeObjects({}, tfp, (_d = _this.slots) === null || _d === void 0 ? void 0 : _d.textFieldProps);
56
+ };
57
+ _this.renderImageSide = function (side) {
58
+ var _a;
59
+ var image = side === 'left' ? _this.slots.imageLeft : _this.slots.imageRight;
60
+ if (!image) return /*#__PURE__*/React.createElement(React.Fragment, null);
61
+ var srcValue = image.srcValue,
62
+ element = image.element,
63
+ _image$alt = image.alt,
64
+ alt = _image$alt === void 0 ? 'input-image' : _image$alt,
65
+ _image$fallbackSrc = image.fallbackSrc,
66
+ fallbackSrc = _image$fallbackSrc === void 0 ? '' : _image$fallbackSrc,
67
+ _image$debounceDelay = image.debounceDelay,
68
+ debounceDelay = _image$debounceDelay === void 0 ? 700 : _image$debounceDelay,
69
+ imageOther = __rest(image, ["srcValue", "element", "alt", "fallbackSrc", "debounceDelay"]);
70
+ if (element) {
71
+ var Element = element;
72
+ return /*#__PURE__*/React.createElement(WrapImage, null, /*#__PURE__*/React.createElement(Element, {
73
+ value: _this.state.value,
74
+ model: _this.props.data
75
+ }));
76
+ }
77
+ var src = srcValue ? srcValue(_this.state.value, _this.props.data) : (_a = imageOther.src) !== null && _a !== void 0 ? _a : _this.state.value;
78
+ var imageProps = {
79
+ src: src,
80
+ alt: alt,
81
+ fallbackSrc: fallbackSrc,
82
+ debounceDelay: debounceDelay
83
+ };
84
+ return /*#__PURE__*/React.createElement(Collapse, {
85
+ sx: {
86
+ mx: '10px'
87
+ },
88
+ "in": !!src,
89
+ unmountOnExit: true,
90
+ orientation: "horizontal"
91
+ }, /*#__PURE__*/React.createElement(WrapImage, null, /*#__PURE__*/React.createElement(ImageWithFallback, _extends({}, imageOther, imageProps, {
92
+ loading: /*#__PURE__*/React.createElement(LoadingCircularProgress, null)
93
+ }))));
94
+ };
95
+ //#endregion
96
+ _this.mergeSlots = function (currentSlots) {
97
+ var base = _mergeObjects({}, params, currentSlots);
98
+ var imageLeft = base.imageLeft,
99
+ imageRight = base.imageRight;
100
+ // mirror from left to right
101
+ if ((imageLeft === null || imageLeft === void 0 ? void 0 : imageLeft.mirror) && !imageRight) {
102
+ base.imageRight = Object.assign({}, imageLeft);
103
+ delete base.imageRight.mirror;
104
+ }
105
+ // mirror from right to left
106
+ else if ((imageRight === null || imageRight === void 0 ? void 0 : imageRight.mirror) && !imageLeft) {
107
+ base.imageLeft = Object.assign({}, imageRight);
108
+ delete base.imageLeft.mirror;
109
+ }
110
+ return base;
111
+ };
112
+ _this.getLabel = function () {
113
+ var _a, _b, _c;
114
+ if (!_this.props.label) return;
115
+ if (!((_a = _this.slots) === null || _a === void 0 ? void 0 : _a.maxLength)) return _this.props.label;
116
+ return "".concat(_this.props.label, " (").concat((_c = (_b = _this.state.value) === null || _b === void 0 ? void 0 : _b.length) !== null && _c !== void 0 ? _c : 0, "/").concat(_this.slots.maxLength, ")");
117
+ };
118
+ _this.handleChange = function (event) {
119
+ _this.setState(function (st) {
120
+ return Object.assign(Object.assign({}, st), {
121
+ value: event.target.value
122
+ });
123
+ });
124
+ };
125
+ _this.handlePaste = function () {
126
+ return __awaiter(_this, void 0, void 0, /*#__PURE__*/_regeneratorRuntime().mark(function _callee() {
127
+ var clipboardText;
128
+ return _regeneratorRuntime().wrap(function _callee$(_context) {
129
+ while (1) switch (_context.prev = _context.next) {
130
+ case 0:
131
+ _context.prev = 0;
132
+ _context.next = 3;
133
+ return navigator.clipboard.readText();
134
+ case 3:
135
+ clipboardText = _context.sent;
136
+ this.setState({
137
+ value: clipboardText
138
+ });
139
+ _context.next = 10;
140
+ break;
141
+ case 7:
142
+ _context.prev = 7;
143
+ _context.t0 = _context["catch"](0);
144
+ console.error('Error clipboard:', _context.t0);
145
+ case 10:
146
+ case "end":
147
+ return _context.stop();
148
+ }
149
+ }, _callee, this, [[0, 7]]);
150
+ }));
151
+ };
152
+ _this._cachedSlots = (_a = _this.mergeSlots(props.slots)) !== null && _a !== void 0 ? _a : {};
153
+ _this.state = {
154
+ value: _this.defaulValue
155
+ };
156
+ return _this;
157
+ }
158
+ _inherits(InputBase, _Component);
159
+ return _createClass(InputBase, [{
160
+ key: "slots",
161
+ get: function get() {
162
+ return this._cachedSlots;
163
+ }
164
+ }, {
165
+ key: "defaulValue",
166
+ get: function get() {
167
+ var _a, _b;
168
+ var _this$props = this.props,
169
+ data = _this$props.data,
170
+ name = _this$props.name;
171
+ return (_a = this.props.defaultValue) !== null && _a !== void 0 ? _a : !!data && !!name ? (_b = data[name]) === null || _b === void 0 ? void 0 : _b.toString() : undefined;
172
+ }
173
+ }, {
174
+ key: "componentDidUpdate",
175
+ value: function componentDidUpdate(prevProps) {
176
+ if (prevProps.slots !== this.props.slots) {
177
+ this._cachedSlots = this.mergeSlots(this.props.slots);
178
+ }
179
+ }
180
+ }, {
181
+ key: "shouldComponentUpdate",
182
+ value: function shouldComponentUpdate(nextProps) {
183
+ var _a, _b, _c, _d, _e, _f;
184
+ var _this$props2 = this.props,
185
+ name = _this$props2.name,
186
+ slots = _this$props2.slots;
187
+ if (!!name) {
188
+ var currentDataValue = (_c = (_b = (_a = this.props.data) === null || _a === void 0 ? void 0 : _a[name]) === null || _b === void 0 ? void 0 : _b.toString()) !== null && _c !== void 0 ? _c : '';
189
+ var nextDataValue = (_f = (_e = (_d = nextProps.data) === null || _d === void 0 ? void 0 : _d[name]) === null || _e === void 0 ? void 0 : _e.toString()) !== null && _f !== void 0 ? _f : '';
190
+ if (currentDataValue !== nextDataValue) {
191
+ this.setState({
192
+ value: nextDataValue
193
+ });
194
+ return false;
195
+ }
196
+ }
197
+ if (slots !== nextProps.slots) {
198
+ return true;
199
+ }
200
+ return true;
201
+ }
202
+ //#region Render
203
+ }, {
204
+ key: "render",
205
+ value: function render() {
206
+ var _a;
207
+ return /*#__PURE__*/React.createElement(Box, {
208
+ sx: {
209
+ display: 'flex',
210
+ alignItems: 'center'
211
+ }
212
+ }, !!this.props.disabled && /*#__PURE__*/React.createElement("input", {
213
+ hidden: true,
214
+ name: (_a = this.props.name) === null || _a === void 0 ? void 0 : _a.toString(),
215
+ defaultValue: this.defaulValue
216
+ }), this.renderImageSide('left'), /*#__PURE__*/React.createElement(TextField, this.mapTextFieldProps()), this.renderImageSide('right'));
217
+ }
218
+ }]);
219
+ }(Component);
220
+ return InputBase;
221
+ };
222
+ // export type InputTextType<T> = ReturnType<typeof CreateInputBase<T>>
223
+ var LoadingCircularProgress = function LoadingCircularProgress() {
224
+ return /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement(CircularProgress, {
225
+ size: 24
226
+ }));
227
+ };
228
+ var WrapImage = styled(Box)({
229
+ fontSize: '1rem',
230
+ height: 'var(--input-base-image-size, 54px)',
231
+ width: 'var(--input-base-image-size, 54px)',
232
+ position: 'relative',
233
+ borderRadius: '8px',
234
+ boxShadow: 'rgba(0, 0, 0, 0.16) 0px 1px 4px',
235
+ overflow: 'hidden',
236
+ '& > img': {
237
+ position: 'absolute',
238
+ top: 0,
239
+ left: 0,
240
+ backgroundRepeat: 'no-repeat',
241
+ height: '100%',
242
+ width: '100%',
243
+ backgroundSize: 'contain'
244
+ },
245
+ '& > div': {
246
+ position: 'absolute',
247
+ top: 0,
248
+ left: 0,
249
+ height: '100%',
250
+ width: '100%',
251
+ background: '#fafafa',
252
+ zIndex: 1,
253
+ display: 'flex',
254
+ alignItems: 'center',
255
+ justifyContent: 'center'
256
+ }
257
+ });
258
+
259
+ export { CreateInputBase as default };
260
+ //# sourceMappingURL=create.input-base.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"create.input-base.js","sources":["../../../src/form/create.input-base.tsx"],"sourcesContent":["import React, { Component, FC } from 'react'\r\nimport { Box, CircularProgress, Collapse, IconButton, InputAdornment, styled, TextField, TextFieldProps } from '@mui/material'\r\nimport ContentPasteIcon from '@mui/icons-material/ContentPaste'\r\nimport { mergeObjects } from '../utils'\r\nimport { IFormInputBase } from './types'\r\nimport { getErrorMessage } from './helper'\r\nimport ImageWithFallback, { ImageWithFallbackPropsOwner } from '../components/image-with-fallback'\r\n\r\nexport interface InputBaseImage<T> extends Partial<ImageWithFallbackPropsOwner> {\r\n srcValue?: (value: any, model?: Partial<T>) => string\r\n element?: React.ComponentType<{ value: any; model?: Partial<T> }>\r\n mirror?: boolean\r\n}\r\n\r\ninterface ISlots<T> {\r\n maxLength?: number\r\n textFieldProps?: TextFieldProps\r\n pastenable?: boolean\r\n imageLeft?: InputBaseImage<T>\r\n imageRight?: InputBaseImage<T>\r\n}\r\n\r\ninterface IProps<T> extends IFormInputBase<T> {\r\n slots?: ISlots<T>\r\n}\r\ninterface IState {\r\n value?: string\r\n}\r\n\r\ninterface IParams<T> extends ISlots<T> {}\r\n\r\nconst CreateInputBase = function <T>(params?: IParams<T>): React.ComponentType<IProps<T>> {\r\n class InputBase extends Component<IProps<T>, IState> {\r\n private _cachedSlots: ISlots<T> = {}\r\n constructor(props: IProps<T>) {\r\n super(props)\r\n this._cachedSlots = this.mergeSlots(props.slots) ?? {}\r\n this.state = { value: this.defaulValue }\r\n }\r\n\r\n get slots() {\r\n return this._cachedSlots\r\n }\r\n\r\n get defaulValue(): string {\r\n const { data, name } = this.props\r\n return this.props.defaultValue ?? (!!data && !!name ? data[name]?.toString() : undefined)\r\n }\r\n\r\n componentDidUpdate(prevProps: IProps<T>) {\r\n if (prevProps.slots !== this.props.slots) {\r\n this._cachedSlots = this.mergeSlots(this.props.slots)\r\n }\r\n }\r\n\r\n shouldComponentUpdate(nextProps: Readonly<IProps<T>>): boolean {\r\n const { name, slots } = this.props\r\n if (!!name) {\r\n const currentDataValue = this.props.data?.[name]?.toString() ?? ''\r\n const nextDataValue = nextProps.data?.[name]?.toString() ?? ''\r\n if (currentDataValue !== nextDataValue) {\r\n this.setState({ value: nextDataValue })\r\n return false\r\n }\r\n }\r\n\r\n if (slots !== nextProps.slots) {\r\n return true\r\n }\r\n return true\r\n }\r\n\r\n mapTextFieldProps = (): TextFieldProps => {\r\n const errorMessage = getErrorMessage(this.props.messageErrors, this.props.name)\r\n const tfp: TextFieldProps = {\r\n fullWidth: true,\r\n variant: 'outlined',\r\n name: this.props.name?.toString(),\r\n error: errorMessage.error,\r\n helperText: errorMessage.message,\r\n disabled: this.props.disabled,\r\n onBlur: () => {\r\n if (!this.props.name) return\r\n this.props.onBlur && this.props.onBlur(this.props.name)\r\n },\r\n label: this.getLabel(),\r\n placeholder: this.props.placeholder,\r\n InputLabelProps: !!this.state.value ? { shrink: true } : {},\r\n value: this.state.value ?? '',\r\n onChange: this.handleChange\r\n }\r\n if (this.slots.pastenable === true) {\r\n tfp.InputProps = {\r\n endAdornment: (\r\n <InputAdornment position='end'>\r\n <IconButton onClick={this.handlePaste} edge='end'>\r\n <ContentPasteIcon />\r\n </IconButton>\r\n </InputAdornment>\r\n )\r\n }\r\n }\r\n if (this.slots?.maxLength) tfp.inputProps = { ...tfp.inputProps, maxLength: this.slots.maxLength }\r\n return mergeObjects<TextFieldProps>({}, tfp, this.slots?.textFieldProps)\r\n }\r\n\r\n //#region Render\r\n render() {\r\n return (\r\n <Box sx={{ display: 'flex', alignItems: 'center' }}>\r\n {!!this.props.disabled && <input hidden name={this.props.name?.toString()} defaultValue={this.defaulValue} />}\r\n {this.renderImageSide('left')}\r\n <TextField {...this.mapTextFieldProps()} />\r\n {this.renderImageSide('right')}\r\n </Box>\r\n )\r\n }\r\n\r\n renderImageSide = (side: 'left' | 'right') => {\r\n const image = side === 'left' ? this.slots.imageLeft : this.slots.imageRight\r\n if (!image) return <></>\r\n const { srcValue, element, alt = 'input-image', fallbackSrc = '', debounceDelay = 700, ...imageOther } = image\r\n if (element) {\r\n const Element = element\r\n return (\r\n <WrapImage>\r\n <Element value={this.state.value} model={this.props.data} />\r\n </WrapImage>\r\n )\r\n }\r\n const src = srcValue ? srcValue(this.state.value, this.props.data) : (imageOther.src ?? this.state.value)\r\n const imageProps: ImageWithFallbackPropsOwner = { src, alt, fallbackSrc, debounceDelay }\r\n return (\r\n <Collapse sx={{ mx: '10px' }} in={!!src} unmountOnExit orientation='horizontal'>\r\n <WrapImage>\r\n <ImageWithFallback {...imageOther} {...imageProps} loading={<LoadingCircularProgress />} />\r\n </WrapImage>\r\n </Collapse>\r\n )\r\n }\r\n //#endregion\r\n\r\n private mergeSlots = (currentSlots?: ISlots<T>): ISlots<T> => {\r\n const base = mergeObjects<ISlots<T>>({}, params, currentSlots)\r\n const { imageLeft, imageRight } = base\r\n\r\n // mirror from left to right\r\n if (imageLeft?.mirror && !imageRight) {\r\n base.imageRight = { ...imageLeft }\r\n delete base.imageRight.mirror\r\n }\r\n // mirror from right to left\r\n else if (imageRight?.mirror && !imageLeft) {\r\n base.imageLeft = { ...imageRight }\r\n delete base.imageLeft.mirror\r\n }\r\n\r\n return base\r\n }\r\n\r\n getLabel = () => {\r\n if (!this.props.label) return\r\n if (!this.slots?.maxLength) return this.props.label\r\n return `${this.props.label} (${this.state.value?.length ?? 0}/${this.slots.maxLength})`\r\n }\r\n\r\n handleChange = (event: React.ChangeEvent<HTMLInputElement>) => {\r\n this.setState((st) => ({ ...st, value: event.target.value }))\r\n }\r\n\r\n handlePaste = async () => {\r\n try {\r\n const clipboardText = await navigator.clipboard.readText()\r\n this.setState({ value: clipboardText })\r\n } catch (error) {\r\n console.error('Error clipboard:', error)\r\n }\r\n }\r\n }\r\n return InputBase\r\n}\r\n\r\nexport default CreateInputBase\r\n\r\n// export type InputTextType<T> = ReturnType<typeof CreateInputBase<T>>\r\n\r\nconst LoadingCircularProgress: FC = () => (\r\n <div>\r\n <CircularProgress size={24} />\r\n </div>\r\n)\r\n\r\nconst WrapImage = styled(Box)({\r\n fontSize: '1rem',\r\n height: 'var(--input-base-image-size, 54px)',\r\n width: 'var(--input-base-image-size, 54px)',\r\n position: 'relative',\r\n borderRadius: '8px',\r\n boxShadow: 'rgba(0, 0, 0, 0.16) 0px 1px 4px',\r\n overflow: 'hidden',\r\n '& > img': {\r\n position: 'absolute',\r\n top: 0,\r\n left: 0,\r\n backgroundRepeat: 'no-repeat',\r\n height: '100%',\r\n width: '100%',\r\n backgroundSize: 'contain'\r\n },\r\n '& > div': {\r\n position: 'absolute',\r\n top: 0,\r\n left: 0,\r\n height: '100%',\r\n width: '100%',\r\n background: '#fafafa',\r\n zIndex: 1,\r\n display: 'flex',\r\n alignItems: 'center',\r\n justifyContent: 'center'\r\n }\r\n})\r\n"],"names":["CreateInputBase","params","InputBase","_Component","props","_this","_classCallCheck","_callSuper","_cachedSlots","mapTextFieldProps","errorMessage","getErrorMessage","messageErrors","name","tfp","fullWidth","variant","_a","toString","error","helperText","message","disabled","onBlur","label","getLabel","placeholder","InputLabelProps","state","value","shrink","onChange","handleChange","slots","pastenable","InputProps","endAdornment","React","createElement","InputAdornment","position","IconButton","onClick","handlePaste","edge","ContentPasteIcon","_c","maxLength","inputProps","Object","assign","mergeObjects","_d","textFieldProps","renderImageSide","side","image","imageLeft","imageRight","Fragment","srcValue","element","_image$alt","alt","_image$fallbackSrc","fallbackSrc","_image$debounceDelay","debounceDelay","imageOther","__rest","Element","WrapImage","model","data","src","imageProps","Collapse","sx","mx","unmountOnExit","orientation","ImageWithFallback","_extends","loading","LoadingCircularProgress","mergeSlots","currentSlots","base","mirror","concat","_b","length","event","setState","st","target","__awaiter","_regeneratorRuntime","mark","_callee","clipboardText","wrap","_callee$","_context","prev","next","navigator","clipboard","readText","sent","t0","console","stop","defaulValue","_inherits","_createClass","key","get","_this$props","defaultValue","undefined","componentDidUpdate","prevProps","shouldComponentUpdate","nextProps","_this$props2","currentDataValue","nextDataValue","_f","_e","render","Box","display","alignItems","hidden","TextField","Component","CircularProgress","size","styled","fontSize","height","width","borderRadius","boxShadow","overflow","top","left","backgroundRepeat","backgroundSize","background","zIndex","justifyContent"],"mappings":"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"}
@@ -0,0 +1,74 @@
1
+ import { inherits as _inherits, createClass as _createClass, extends as _extends, classCallCheck as _classCallCheck, callSuper as _callSuper } from '../../_virtual/_rollupPluginBabelHelpers.js';
2
+ import React, { Component } from 'react';
3
+ import { TextField } from '@mui/material';
4
+ import { getErrorMessage } from './helper.js';
5
+
6
+ function CreateInputFile(params) {
7
+ var FormInputFile = /*#__PURE__*/function (_Component) {
8
+ function FormInputFile() {
9
+ var _this;
10
+ _classCallCheck(this, FormInputFile);
11
+ _this = _callSuper(this, FormInputFile, arguments);
12
+ _this.refInput = null;
13
+ _this.getMergeConfig = function () {
14
+ var _a, _b, _c;
15
+ return {
16
+ accept: (_a = params === null || params === void 0 ? void 0 : params.accept) !== null && _a !== void 0 ? _a : _this.props.accept,
17
+ multiple: (_c = (_b = params === null || params === void 0 ? void 0 : params.multiple) !== null && _b !== void 0 ? _b : _this.props.multiple) !== null && _c !== void 0 ? _c : false
18
+ };
19
+ };
20
+ _this.handleChange = function (e) {
21
+ if (!_this.props.name) return;
22
+ _this.props.onBlur && _this.props.onBlur(_this.props.name);
23
+ };
24
+ _this.isExploreOpen = false;
25
+ _this.handleClick = function (e) {
26
+ _this.isExploreOpen = true;
27
+ };
28
+ _this.handleFocus = function (e) {
29
+ if (_this.isExploreOpen === true) {
30
+ _this.isExploreOpen = false;
31
+ if (!_this.props.name) return;
32
+ _this.props.onBlur && _this.props.onBlur(_this.props.name);
33
+ setTimeout(function () {
34
+ _this.refInput && _this.refInput.blur();
35
+ }, 50);
36
+ }
37
+ };
38
+ return _this;
39
+ }
40
+ _inherits(FormInputFile, _Component);
41
+ return _createClass(FormInputFile, [{
42
+ key: "render",
43
+ value: function render() {
44
+ var _this2 = this;
45
+ var _a, _b;
46
+ var eMessage = getErrorMessage(this.props.messageErrors, this.props.name);
47
+ var configs = this.getMergeConfig();
48
+ return /*#__PURE__*/React.createElement(TextField, _extends({
49
+ inputRef: function inputRef(ref) {
50
+ return _this2.refInput = ref;
51
+ },
52
+ name: (_a = this.props.name) === null || _a === void 0 ? void 0 : _a.toString(),
53
+ error: eMessage.error,
54
+ helperText: eMessage.message,
55
+ variant: "outlined",
56
+ type: "file",
57
+ fullWidth: true,
58
+ onChange: this.handleChange,
59
+ onClick: this.handleClick,
60
+ onFocus: this.handleFocus
61
+ }, this.props.textFieldProps, {
62
+ inputProps: Object.assign({
63
+ accept: configs.accept,
64
+ multiple: configs.multiple
65
+ }, (_b = this.props.textFieldProps) === null || _b === void 0 ? void 0 : _b.inputProps)
66
+ }));
67
+ }
68
+ }]);
69
+ }(Component);
70
+ return FormInputFile;
71
+ }
72
+
73
+ export { CreateInputFile as default };
74
+ //# sourceMappingURL=create.input.file.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"create.input.file.js","sources":["../../../src/form/create.input.file.tsx"],"sourcesContent":["import React, { Component } from 'react'\r\nimport { TextField, TextFieldProps } from '@mui/material'\r\nimport { IFormInputBase } from './types'\r\nimport { getErrorMessage } from './helper'\r\n\r\ninterface IParam {\r\n accept?: string\r\n multiple?: boolean\r\n}\r\n\r\nexport default function CreateInputFile<T extends Object>(params?: IParam) {\r\n interface IProps extends IFormInputBase<T> {\r\n accept?: string\r\n multiple?: boolean\r\n textFieldProps?: TextFieldProps\r\n }\r\n\r\n interface IState {}\r\n\r\n class FormInputFile extends Component<IProps, IState> {\r\n refInput: HTMLInputElement | null = null\r\n\r\n render() {\r\n const eMessage = getErrorMessage(this.props.messageErrors, this.props.name)\r\n const configs = this.getMergeConfig()\r\n return (\r\n <TextField\r\n inputRef={(ref) => (this.refInput = ref)}\r\n name={this.props.name?.toString()}\r\n error={eMessage.error}\r\n helperText={eMessage.message}\r\n variant='outlined'\r\n type='file'\r\n fullWidth\r\n onChange={this.handleChange}\r\n onClick={this.handleClick}\r\n onFocus={this.handleFocus}\r\n {...this.props.textFieldProps}\r\n inputProps={{\r\n accept: configs.accept,\r\n multiple: configs.multiple,\r\n ...this.props.textFieldProps?.inputProps\r\n }}\r\n />\r\n )\r\n }\r\n\r\n getMergeConfig = () => ({\r\n accept: params?.accept ?? this.props.accept,\r\n multiple: params?.multiple ?? this.props.multiple ?? false\r\n })\r\n\r\n handleChange: React.ChangeEventHandler<HTMLInputElement> = (e) => {\r\n if (!this.props.name) return\r\n this.props.onBlur && this.props.onBlur(this.props.name)\r\n }\r\n\r\n isExploreOpen = false\r\n\r\n handleClick: React.MouseEventHandler<HTMLDivElement> = (e) => {\r\n this.isExploreOpen = true\r\n }\r\n\r\n handleFocus: React.FocusEventHandler<HTMLInputElement> = (e) => {\r\n if (this.isExploreOpen === true) {\r\n this.isExploreOpen = false\r\n if (!this.props.name) return\r\n this.props.onBlur && this.props.onBlur(this.props.name)\r\n setTimeout(() => {\r\n this.refInput && this.refInput.blur()\r\n }, 50)\r\n }\r\n }\r\n }\r\n return FormInputFile\r\n}\r\n"],"names":["CreateInputFile","params","FormInputFile","_Component","_this","_classCallCheck","refInput","getMergeConfig","accept","_a","props","multiple","_c","_b","handleChange","e","name","onBlur","isExploreOpen","handleClick","handleFocus","setTimeout","blur","_inherits","_createClass","key","value","render","_this2","eMessage","getErrorMessage","messageErrors","configs","React","createElement","TextField","_extends","inputRef","ref","toString","error","helperText","message","variant","type","fullWidth","onChange","onClick","onFocus","textFieldProps","inputProps","Object","assign","Component"],"mappings":"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"}
@@ -0,0 +1,104 @@
1
+ import { inherits as _inherits, createClass as _createClass, classCallCheck as _classCallCheck, callSuper as _callSuper } from '../../_virtual/_rollupPluginBabelHelpers.js';
2
+ import React, { Component } from 'react';
3
+ import { FormControl, InputLabel, Select, MenuItem, Collapse, FormHelperText } from '@mui/material';
4
+ import { getErrorMessage } from './helper.js';
5
+ import { mergeObjects as _mergeObjects } from '../utils/helpers.js';
6
+ import '../utils/query-param.js';
7
+ import '../utils/dayjs-config.js';
8
+
9
+ var CreateSelectSimple = function CreateSelectSimple(args) {
10
+ var SelectSimple = /*#__PURE__*/function (_Component) {
11
+ function SelectSimple(props) {
12
+ var _this;
13
+ _classCallCheck(this, SelectSimple);
14
+ var _a;
15
+ _this = _callSuper(this, SelectSimple, [props]);
16
+ _this.mapProps = function () {
17
+ var _a, _b, _c, _d, _e;
18
+ var label = _this.getLabel();
19
+ var tfp = {
20
+ id: (_a = _this.props.name) === null || _a === void 0 ? void 0 : _a.toString(),
21
+ labelId: ((_b = _this.props.name) === null || _b === void 0 ? void 0 : _b.toString()) + label,
22
+ name: (_c = _this.props.name) === null || _c === void 0 ? void 0 : _c.toString(),
23
+ label: label,
24
+ defaultValue: _this.getDefaultValue(),
25
+ value: _this.state.value,
26
+ onChange: function onChange(event) {
27
+ var value = event.target.value + '';
28
+ _this.setState({
29
+ value: value
30
+ }, function () {
31
+ if (!!_this.props.name) {
32
+ _this.props.onBlur && _this.props.onBlur(_this.props.name);
33
+ }
34
+ var options = _this.getOptions();
35
+ var temp = options.find(function (x) {
36
+ var _a;
37
+ return ((_a = x.value) === null || _a === void 0 ? void 0 : _a.toString()) === value;
38
+ });
39
+ if (!temp) return;
40
+ _this.props.onChange && _this.props.onChange(temp);
41
+ });
42
+ },
43
+ disabled: _this.props.disabled,
44
+ fullWidth: _this.props.fullWidth !== undefined ? _this.props.fullWidth : true
45
+ };
46
+ var selectProps = (_e = (_d = _this.props.slots) === null || _d === void 0 ? void 0 : _d.selectProps) !== null && _e !== void 0 ? _e : args === null || args === void 0 ? void 0 : args.selectProps;
47
+ return _mergeObjects({}, tfp, selectProps);
48
+ };
49
+ _this.getLabel = function () {
50
+ var _a, _b;
51
+ if (!!_this.props.label && typeof _this.props.label === 'string') return _this.props.label;
52
+ return (_b = (_a = _this.props.name) === null || _a === void 0 ? void 0 : _a.toString()) !== null && _b !== void 0 ? _b : '';
53
+ };
54
+ _this.getDefaultValue = function () {
55
+ var _a, _b, _c, _d;
56
+ var _this$props = _this.props,
57
+ data = _this$props.data,
58
+ name = _this$props.name;
59
+ var options = _this.getOptions();
60
+ return (_c = (_b = (_a = _this.props.defaultValue) === null || _a === void 0 ? void 0 : _a.toString()) !== null && _b !== void 0 ? _b : !!data && !!name ? data[name] : undefined) !== null && _c !== void 0 ? _c : (_d = options[0]) === null || _d === void 0 ? void 0 : _d.value;
61
+ };
62
+ _this.getOptions = function () {
63
+ var _a, _b;
64
+ return (_b = (_a = args === null || args === void 0 ? void 0 : args.options) !== null && _a !== void 0 ? _a : _this.props.options) !== null && _b !== void 0 ? _b : [];
65
+ };
66
+ _this.state = {
67
+ value: (_a = _this.getDefaultValue()) === null || _a === void 0 ? void 0 : _a.toString()
68
+ };
69
+ return _this;
70
+ }
71
+ _inherits(SelectSimple, _Component);
72
+ return _createClass(SelectSimple, [{
73
+ key: "render",
74
+ value: function render() {
75
+ var _a, _b;
76
+ var data = this.getOptions();
77
+ var label = this.getLabel();
78
+ var errorMessage = getErrorMessage(this.props.messageErrors, this.props.name);
79
+ return /*#__PURE__*/React.createElement(React.Fragment, null, !!this.props.disabled && /*#__PURE__*/React.createElement("input", {
80
+ hidden: true,
81
+ name: (_a = this.props.name) === null || _a === void 0 ? void 0 : _a.toString(),
82
+ defaultValue: this.getDefaultValue()
83
+ }), /*#__PURE__*/React.createElement(FormControl, {
84
+ fullWidth: true,
85
+ disabled: this.props.disabled,
86
+ error: errorMessage.error
87
+ }, /*#__PURE__*/React.createElement(InputLabel, {
88
+ id: ((_b = this.props.name) === null || _b === void 0 ? void 0 : _b.toString()) + label
89
+ }, label), /*#__PURE__*/React.createElement(Select, this.mapProps(), data.map(function (item) {
90
+ return /*#__PURE__*/React.createElement(MenuItem, {
91
+ key: item.value,
92
+ value: item.value
93
+ }, item.name);
94
+ })), /*#__PURE__*/React.createElement(Collapse, {
95
+ "in": errorMessage.error
96
+ }, /*#__PURE__*/React.createElement(FormHelperText, null, errorMessage.message))));
97
+ }
98
+ }]);
99
+ }(Component);
100
+ return SelectSimple;
101
+ };
102
+
103
+ export { CreateSelectSimple as default };
104
+ //# sourceMappingURL=create.select-simple.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"create.select-simple.js","sources":["../../../src/form/create.select-simple.tsx"],"sourcesContent":["import React, { Component } from 'react'\r\nimport { Collapse, FormControl, FormHelperText, InputLabel, MenuItem, Select, SelectProps } from '@mui/material'\r\nimport { IFormInputBase } from './types'\r\nimport { getErrorMessage } from './helper'\r\nimport { mergeObjects } from '../utils'\r\n\r\nexport interface ISelectSimpleOption<TModel extends string = string> {\r\n name: string\r\n value: TModel\r\n}\r\n\r\ninterface ISlots {\r\n selectProps?: Omit<SelectProps, 'variant'>\r\n}\r\n\r\ninterface IArgs extends ISlots {\r\n options?: ISelectSimpleOption[]\r\n}\r\n\r\nconst CreateSelectSimple = function <TModel = any>(args?: IArgs) {\r\n interface IProps extends Partial<IFormInputBase<TModel>> {\r\n options?: ISelectSimpleOption[]\r\n onChange?: (value: ISelectSimpleOption) => void\r\n slots?: ISlots\r\n fullWidth?: boolean\r\n }\r\n interface IState {\r\n value?: string\r\n }\r\n class SelectSimple extends Component<IProps, IState> {\r\n constructor(props: IProps) {\r\n super(props)\r\n this.state = { value: this.getDefaultValue()?.toString() }\r\n }\r\n mapProps = (): SelectProps => {\r\n const label = this.getLabel()\r\n const tfp: SelectProps = {\r\n id: this.props.name?.toString(),\r\n labelId: this.props.name?.toString() + label,\r\n name: this.props.name?.toString(),\r\n label: label,\r\n defaultValue: this.getDefaultValue(),\r\n value: this.state.value,\r\n onChange: (event) => {\r\n const value: string = event.target.value + ''\r\n this.setState({ value }, () => {\r\n if (!!this.props.name) {\r\n this.props.onBlur && this.props.onBlur(this.props.name)\r\n }\r\n const options = this.getOptions()\r\n const temp = options.find((x) => x.value?.toString() === value)\r\n if (!temp) return\r\n this.props.onChange && this.props.onChange(temp)\r\n })\r\n },\r\n disabled: this.props.disabled,\r\n fullWidth: this.props.fullWidth !== undefined ? this.props.fullWidth : true\r\n }\r\n const selectProps = this.props.slots?.selectProps ?? args?.selectProps\r\n return mergeObjects({}, tfp, selectProps)\r\n }\r\n render() {\r\n const data = this.getOptions()\r\n const label = this.getLabel()\r\n const errorMessage = getErrorMessage(this.props.messageErrors, this.props.name)\r\n return (\r\n <React.Fragment>\r\n {!!this.props.disabled && <input hidden name={this.props.name?.toString()} defaultValue={this.getDefaultValue()} />}\r\n <FormControl fullWidth disabled={this.props.disabled} error={errorMessage.error}>\r\n <InputLabel id={this.props.name?.toString() + label}>{label}</InputLabel>\r\n <Select {...this.mapProps()}>\r\n {data.map((item) => (\r\n <MenuItem key={item.value} value={item.value}>\r\n {item.name}\r\n </MenuItem>\r\n ))}\r\n </Select>\r\n <Collapse in={errorMessage.error}>\r\n <FormHelperText>{errorMessage.message}</FormHelperText>\r\n </Collapse>\r\n </FormControl>\r\n </React.Fragment>\r\n )\r\n }\r\n getLabel = () => {\r\n if (!!this.props.label && typeof this.props.label === 'string') return this.props.label\r\n return this.props.name?.toString() ?? ''\r\n }\r\n getDefaultValue = () => {\r\n const { data, name } = this.props\r\n const options = this.getOptions()\r\n return this.props.defaultValue?.toString() ?? (!!data && !!name ? data[name] : undefined) ?? options[0]?.value\r\n }\r\n getOptions = (): ISelectSimpleOption[] => {\r\n return args?.options ?? this.props.options ?? []\r\n }\r\n }\r\n return SelectSimple\r\n}\r\nexport default CreateSelectSimple\r\nexport type SelectSimpleType<TModel> = ReturnType<typeof CreateSelectSimple<TModel>>\r\n"],"names":["CreateSelectSimple","args","SelectSimple","_Component","props","_this","_classCallCheck","_callSuper","mapProps","label","getLabel","tfp","id","name","_a","toString","labelId","_b","_c","defaultValue","getDefaultValue","value","state","onChange","event","target","setState","onBlur","options","getOptions","temp","find","x","disabled","fullWidth","undefined","selectProps","_e","slots","mergeObjects","_this$props","data","_d","_inherits","_createClass","key","render","errorMessage","getErrorMessage","messageErrors","React","createElement","Fragment","hidden","FormControl","error","InputLabel","Select","map","item","MenuItem","Collapse","FormHelperText","message","Component"],"mappings":"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"}