anysystem-design 0.0.32 → 0.0.33

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 (39) hide show
  1. package/README.md +20 -26
  2. package/dist/Flow.css +1 -0
  3. package/dist/components/AutoComplete/AutoCompleteMultiple.js +23 -23
  4. package/dist/components/Container/Container.js +1 -1
  5. package/dist/components/FormControl/FormControl.d.ts +1 -1
  6. package/dist/components/FormControl/FormControl.js +60 -43
  7. package/dist/components/FormControl/type.d.ts +13 -5
  8. package/dist/components/RadioGroup/RadioGroup.d.ts +2 -1
  9. package/dist/components/RadioGroup/RadioGroup.js +70 -67
  10. package/dist/components/Switch/Switch.d.ts +2 -1
  11. package/dist/components/Switch/Switch.js +37 -29
  12. package/dist/features/FlowBuilder/FlowBuilder.d.ts +4 -0
  13. package/dist/features/FlowBuilder/FlowBuilder.js +44 -0
  14. package/dist/features/FlowBuilder/components/ConnectionLine.d.ts +10 -0
  15. package/dist/features/FlowBuilder/components/ConnectionLine.js +36 -0
  16. package/dist/features/FlowBuilder/components/Flow.d.ts +19 -0
  17. package/dist/features/FlowBuilder/components/Flow.js +77 -0
  18. package/dist/features/FlowBuilder/components/Sidebar.d.ts +4 -0
  19. package/dist/features/FlowBuilder/components/Sidebar.js +44 -0
  20. package/dist/features/FlowBuilder/components/nodes/BasicConfigureNode.d.ts +11 -0
  21. package/dist/features/FlowBuilder/components/nodes/BasicConfigureNode.js +49 -0
  22. package/dist/features/FlowBuilder/constants/nodeType.d.ts +11 -0
  23. package/dist/features/FlowBuilder/constants/nodeType.js +16 -0
  24. package/dist/features/FlowBuilder/contexts/DndContext.d.ts +15 -0
  25. package/dist/features/FlowBuilder/contexts/DndContext.js +22 -0
  26. package/dist/features/FlowBuilder/index.d.ts +2 -0
  27. package/dist/features/FlowBuilder/index.js +4 -0
  28. package/dist/features/FlowBuilder/types.d.ts +4 -0
  29. package/dist/features/FlowBuilder/types.js +1 -0
  30. package/dist/features/FormBuilder/FormBuilder.js +89 -88
  31. package/dist/features/FormBuilder/components/Controller.js +15 -15
  32. package/dist/features/FormBuilder/components/Droppable.js +8 -8
  33. package/dist/features/FormBuilder/components/RowController.js +11 -11
  34. package/dist/features/index.d.ts +2 -0
  35. package/dist/features/index.js +2 -0
  36. package/dist/index-C13yYZ2f.js +6189 -0
  37. package/dist/index.css +1 -1
  38. package/dist/index.js +29 -27
  39. package/package.json +4 -2
package/README.md CHANGED
@@ -1,30 +1,24 @@
1
- # React + TypeScript + Vite
1
+ # Anysystem Design
2
+ Powerful open source libraries for React.
2
3
 
3
- This template provides a minimal setup to get React working in Vite with HMR and some ESLint rules.
4
-
5
- Currently, two official plugins are available:
6
-
7
- - [@vitejs/plugin-react](https://github.com/vitejs/vite-plugin-react/blob/main/packages/plugin-react/README.md) uses [Babel](https://babeljs.io/) for Fast Refresh
8
- - [@vitejs/plugin-react-swc](https://github.com/vitejs/vite-plugin-react-swc) uses [SWC](https://swc.rs/) for Fast Refresh
9
-
10
- ## Expanding the ESLint configuration
11
-
12
- If you are developing a production application, we recommend updating the configuration to enable type aware lint rules:
13
-
14
- - Configure the top-level `parserOptions` property like this:
15
-
16
- ```js
17
- export default {
18
- // other rules...
19
- parserOptions: {
20
- ecmaVersion: 'latest',
21
- sourceType: 'module',
22
- project: ['./tsconfig.json', './tsconfig.node.json'],
23
- tsconfigRootDir: __dirname,
24
- },
4
+ ## Getting started
5
+ ```bash
6
+ npm install anysystem-design
7
+ ```
8
+ ### Basic usage
9
+
10
+ ```javascript
11
+ import {
12
+ AppProvider,
13
+ Button
14
+ } from "anysystem-design";
15
+
16
+ export default function App() {
17
+ return (
18
+ <AppProvider appName="anysystem">
19
+ <Button>Button</Button>
20
+ </AppProvider>
21
+ );
25
22
  }
26
23
  ```
27
24
 
28
- - Replace `plugin:@typescript-eslint/recommended` to `plugin:@typescript-eslint/recommended-type-checked` or `plugin:@typescript-eslint/strict-type-checked`
29
- - Optionally add `plugin:@typescript-eslint/stylistic-type-checked`
30
- - Install [eslint-plugin-react](https://github.com/jsx-eslint/eslint-plugin-react) and add `plugin:react/recommended` & `plugin:react/jsx-runtime` to the `extends` list
package/dist/Flow.css ADDED
@@ -0,0 +1 @@
1
+ .react-flow{direction:ltr;--xy-edge-stroke-default: #b1b1b7;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #555;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(255, 255, 255, .5);--xy-minimap-background-color-default: #fff;--xy-minimap-mask-background-color-default: rgb(240, 240, 240, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #e2e2e2;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: transparent;--xy-background-pattern-dots-color-default: #91919a;--xy-background-pattern-lines-color-default: #eee;--xy-background-pattern-cross-color-default: #e2e2e2;background-color:var(--xy-background-color, var(--xy-background-color-default));--xy-node-color-default: inherit;--xy-node-border-default: 1px solid #1a192b;--xy-node-background-color-default: #fff;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(0, 0, 0, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #1a192b;--xy-node-border-radius-default: 3px;--xy-handle-background-color-default: #1a192b;--xy-handle-border-color-default: #fff;--xy-selection-background-color-default: rgba(0, 89, 220, .08);--xy-selection-border-default: 1px dotted rgba(0, 89, 220, .8);--xy-controls-button-background-color-default: #fefefe;--xy-controls-button-background-color-hover-default: #f4f4f4;--xy-controls-button-color-default: inherit;--xy-controls-button-color-hover-default: inherit;--xy-controls-button-border-color-default: #eee;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #ffffff;--xy-edge-label-color-default: inherit;--xy-resize-background-color-default: #3367d9}.react-flow.dark{--xy-edge-stroke-default: #3e3e3e;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #727272;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(150, 150, 150, .25);--xy-minimap-background-color-default: #141414;--xy-minimap-mask-background-color-default: rgb(60, 60, 60, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #2b2b2b;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: #141414;--xy-background-pattern-dots-color-default: #777;--xy-background-pattern-lines-color-default: #777;--xy-background-pattern-cross-color-default: #777;--xy-node-color-default: #f8f8f8;--xy-node-border-default: 1px solid #3c3c3c;--xy-node-background-color-default: #1e1e1e;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(255, 255, 255, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #999;--xy-handle-background-color-default: #bebebe;--xy-handle-border-color-default: #1e1e1e;--xy-selection-background-color-default: rgba(200, 200, 220, .08);--xy-selection-border-default: 1px dotted rgba(200, 200, 220, .8);--xy-controls-button-background-color-default: #2b2b2b;--xy-controls-button-background-color-hover-default: #3e3e3e;--xy-controls-button-color-default: #f8f8f8;--xy-controls-button-color-hover-default: #fff;--xy-controls-button-border-color-default: #5b5b5b;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #141414;--xy-edge-label-color-default: #f8f8f8}.react-flow__background{background-color:var(--xy-background-color, var(--xy-background-color-props, var(--xy-background-color-default)));pointer-events:none;z-index:-1}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1}.react-flow__pane.draggable{cursor:grab}.react-flow__pane.dragging{cursor:grabbing}.react-flow__pane.selection{cursor:pointer}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow__edge-path{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default));stroke-width:var(--xy-edge-stroke-width, var(--xy-edge-stroke-width-default));fill:none}.react-flow__connection-path{stroke:var(--xy-connectionline-stroke, var(--xy-connectionline-stroke-default));stroke-width:var(--xy-connectionline-stroke-width, var(--xy-connectionline-stroke-width-default));fill:none}.react-flow .react-flow__edges{position:absolute}.react-flow .react-flow__edges svg{overflow:visible;position:absolute;pointer-events:none}.react-flow__edge{pointer-events:visibleStroke}.react-flow__edge.selectable{cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge.selectable:focus .react-flow__edge-path,.react-flow__edge.selectable:focus-visible .react-flow__edge-path{stroke:var(--xy-edge-stroke-selected, var(--xy-edge-stroke-selected-default))}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:dashdraw .5s linear infinite}svg.react-flow__connectionline{z-index:1001;overflow:visible;position:absolute}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:default}.react-flow__node.selectable{cursor:pointer}.react-flow__node.draggable{cursor:grab;pointer-events:all}.react-flow__node.draggable.dragging{cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background-color:var(--xy-handle-background-color, var(--xy-handle-background-color-default));border:1px solid var(--xy-handle-border-color, var(--xy-handle-border-color-default));border-radius:100%}.react-flow__handle.connectingfrom{pointer-events:all}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:0;transform:translate(-50%,50%)}.react-flow__handle-top{top:0;left:50%;transform:translate(-50%,-50%)}.react-flow__handle-left{top:50%;left:0;transform:translate(-50%,-50%)}.react-flow__handle-right{top:50%;right:0;transform:translate(50%,-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translate(-50%)}.react-flow__attribution{font-size:10px;background:var(--xy-attribution-background-color, var(--xy-attribution-background-color-default));padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;left:0;top:0}.react-flow__viewport-portal{position:absolute;width:100%;height:100%;left:0;top:0;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__minimap{background:var( --xy-minimap-background-color-props, var(--xy-minimap-background-color, var(--xy-minimap-background-color-default)) )}.react-flow__minimap-svg{display:block}.react-flow__minimap-mask{fill:var( --xy-minimap-mask-background-color-props, var(--xy-minimap-mask-background-color, var(--xy-minimap-mask-background-color-default)) );stroke:var( --xy-minimap-mask-stroke-color-props, var(--xy-minimap-mask-stroke-color, var(--xy-minimap-mask-stroke-color-default)) );stroke-width:var( --xy-minimap-mask-stroke-width-props, var(--xy-minimap-mask-stroke-width, var(--xy-minimap-mask-stroke-width-default)) )}.react-flow__minimap-node{fill:var( --xy-minimap-node-background-color-props, var(--xy-minimap-node-background-color, var(--xy-minimap-node-background-color-default)) );stroke:var( --xy-minimap-node-stroke-color-props, var(--xy-minimap-node-stroke-color, var(--xy-minimap-node-stroke-color-default)) );stroke-width:var( --xy-minimap-node-stroke-width-props, var(--xy-minimap-node-stroke-width, var(--xy-minimap-node-stroke-width-default)) )}.react-flow__background-pattern.dots{fill:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-dots-color-default)) )}.react-flow__background-pattern.lines{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-lines-color-default)) )}.react-flow__background-pattern.cross{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-cross-color-default)) )}.react-flow__controls{display:flex;flex-direction:column;box-shadow:var(--xy-controls-box-shadow, var(--xy-controls-box-shadow-default))}.react-flow__controls.horizontal{flex-direction:row}.react-flow__controls-button{display:flex;justify-content:center;align-items:center;height:26px;width:26px;padding:4px;border:none;background:var(--xy-controls-button-background-color, var(--xy-controls-button-background-color-default));border-bottom:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) );color:var( --xy-controls-button-color-props, var(--xy-controls-button-color, var(--xy-controls-button-color-default)) );cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px;fill:currentColor}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-input,.react-flow__node-default,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:var(--xy-node-border-radius, var(--xy-node-border-radius-default));width:150px;font-size:12px;color:var(--xy-node-color, var(--xy-node-color-default));text-align:center;border:var(--xy-node-border, var(--xy-node-border-default));background-color:var(--xy-node-background-color, var(--xy-node-background-color-default))}.react-flow__node-input.selectable:hover,.react-flow__node-default.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:var(--xy-node-boxshadow-hover, var(--xy-node-boxshadow-hover-default))}.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:var(--xy-node-boxshadow-selected, var(--xy-node-boxshadow-selected-default))}.react-flow__node-group{background-color:var(--xy-node-group-background-color, var(--xy-node-group-background-color-default))}.react-flow__nodesselection-rect,.react-flow__selection{background:var(--xy-selection-background-color, var(--xy-selection-background-color-default));border:var(--xy-selection-border, var(--xy-selection-border-default))}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls-button:hover{background:var( --xy-controls-button-background-color-hover-props, var(--xy-controls-button-background-color-hover, var(--xy-controls-button-background-color-hover-default)) );color:var( --xy-controls-button-color-hover-props, var(--xy-controls-button-color-hover, var(--xy-controls-button-color-hover-default)) )}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__controls-button:last-child{border-bottom:none}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:4px;height:4px;border:1px solid #fff;border-radius:1px;background-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.react-flow__edge-textbg{fill:var(--xy-edge-label-background-color, var(--xy-edge-label-background-color-default))}.react-flow__edge-text{fill:var(--xy-edge-label-color, var(--xy-edge-label-color-default))}
@@ -6,9 +6,9 @@ import { H as C } from "../../index-BVp57yIc.js";
6
6
  import { c as w } from "../../index-CBEJ8A3p.js";
7
7
  import { f as N } from "../../index-CHNNgawm.js";
8
8
  import { getValue as o } from "../Selectbox/helper.js";
9
- import { N as L, G as S, H as T, z as q, K as A } from "../../combobox-DcjIgW1K.js";
10
- import { X as R } from "../../transition-6o20faRl.js";
11
- const k = (r, t) => {
9
+ import { N as L, G as S, H as T, z as k, K as q } from "../../combobox-DcjIgW1K.js";
10
+ import { X as A } from "../../transition-6o20faRl.js";
11
+ const R = (r, t) => {
12
12
  if (t.type === "SEARCH")
13
13
  return {
14
14
  ...r,
@@ -20,8 +20,8 @@ const k = (r, t) => {
20
20
  ...r,
21
21
  value: t.value,
22
22
  selected: r.list.filter((a) => {
23
- const u = o(a, r.valueField);
24
- return t.value.includes(u);
23
+ const i = o(a, r.valueField);
24
+ return t.value.includes(i);
25
25
  }) || [],
26
26
  query: ""
27
27
  };
@@ -33,10 +33,10 @@ const k = (r, t) => {
33
33
  query: ""
34
34
  };
35
35
  if (t.type === "REMOVESELECT") {
36
- const a = o(t.selected, r.valueField), u = r.value.filter((n) => n !== a);
36
+ const a = o(t.selected, r.valueField), i = r.value.filter((n) => n !== a);
37
37
  return {
38
38
  ...r,
39
- value: u,
39
+ value: i,
40
40
  selected: r.selected ? r.selected.filter((n) => o(n, r.valueField) !== a) : []
41
41
  };
42
42
  }
@@ -45,22 +45,22 @@ const k = (r, t) => {
45
45
  id: r,
46
46
  name: t,
47
47
  value: a = [],
48
- options: u,
48
+ options: i,
49
49
  valueField: n = "value",
50
50
  onChange: f,
51
51
  onSearch: y,
52
52
  placeholder: g
53
53
  }, b) => {
54
54
  var h;
55
- const [s, c] = p.useReducer(k, {
55
+ const [s, c] = p.useReducer(R, {
56
56
  query: "",
57
- list: u,
58
- filterList: u,
57
+ list: i,
58
+ filterList: i,
59
59
  value: a || [],
60
60
  valueField: n,
61
- selected: u.filter((e) => {
62
- const i = o(e, n);
63
- return x.some(a, (d) => d + "" == i + "");
61
+ selected: i.filter((e) => {
62
+ const u = o(e, n);
63
+ return x.some(a, (d) => d + "" == u + "");
64
64
  }) || []
65
65
  });
66
66
  return p.useImperativeHandle(b, () => ({
@@ -79,12 +79,12 @@ const k = (r, t) => {
79
79
  type: "SETSELECT",
80
80
  selected: e
81
81
  });
82
- const i = (e == null ? void 0 : e.map((d) => o(d, n))) || [];
83
- f && f(i);
82
+ const u = (e == null ? void 0 : e.map((d) => o(d, n))) || [];
83
+ f && f(u);
84
84
  },
85
85
  multiple: !0,
86
86
  children: /* @__PURE__ */ m("div", { className: "relative flex gap-1", children: [
87
- s.selected.length > 0 && /* @__PURE__ */ l("ul", { className: "flex form-control gap-1", children: (h = s.selected) == null ? void 0 : h.map((e, i) => /* @__PURE__ */ l("li", { children: /* @__PURE__ */ m("div", { className: "flex p-1 rounded bg-indigo-50", children: [
87
+ s.selected.length > 0 && /* @__PURE__ */ l("ul", { className: "flex form-control gap-1", children: (h = s.selected) == null ? void 0 : h.map((e, u) => /* @__PURE__ */ l("li", { children: /* @__PURE__ */ m("div", { className: "flex p-1 rounded bg-blue-50 dark:bg-blue-900", children: [
88
88
  /* @__PURE__ */ l("span", { className: "text-xs whitespace-nowrap", children: e.label }),
89
89
  /* @__PURE__ */ l(
90
90
  "button",
@@ -94,7 +94,7 @@ const k = (r, t) => {
94
94
  children: /* @__PURE__ */ l(N, { fontSize: 12, className: "font-bold" })
95
95
  }
96
96
  )
97
- ] }) }, i)) }),
97
+ ] }) }, u)) }),
98
98
  /* @__PURE__ */ l(
99
99
  S,
100
100
  {
@@ -131,7 +131,7 @@ const k = (r, t) => {
131
131
  }
132
132
  ),
133
133
  /* @__PURE__ */ l(
134
- R,
134
+ A,
135
135
  {
136
136
  as: v,
137
137
  enter: "transition duration-100 ease-out",
@@ -141,23 +141,23 @@ const k = (r, t) => {
141
141
  leaveFrom: "scale-100 transform opacity-100",
142
142
  leaveTo: "scale-95 transform opacity-0",
143
143
  afterLeave: () => c({ type: "SEARCH", query: "" }),
144
- children: /* @__PURE__ */ l(q, { className: "absolute w-full py-1 mt-10 overflow-auto text-base bg-white shadow-lg max-h-60 rounded-md ring-1 ring-black/5 focus:outline-none dark:bg-gray-900 sm:text-sm", children: s.filterList.map((e) => /* @__PURE__ */ l(A, { as: v, value: e, children: ({ selected: i, focus: d }) => /* @__PURE__ */ m(
144
+ children: /* @__PURE__ */ l(k, { className: "absolute w-full py-1 mt-10 overflow-auto text-base bg-white shadow-lg max-h-60 rounded-md ring-1 ring-black/5 focus:outline-none dark:bg-gray-900 sm:text-sm", children: s.filterList.map((e) => /* @__PURE__ */ l(q, { as: v, value: e, children: ({ selected: u, focus: d }) => /* @__PURE__ */ m(
145
145
  "li",
146
146
  {
147
147
  className: E(
148
148
  "relative flex cursor-pointer justify-between px-5 py-4 text-black hover:bg-primary-100 dark:text-white",
149
- (i || d) && "bg-primary-100 dark:bg-gray-700",
149
+ (u || d) && "bg-primary-100 dark:bg-gray-700",
150
150
  e.enable === !1 && "cursor-not-allowed opacity-50"
151
151
  ),
152
152
  children: [
153
153
  /* @__PURE__ */ l("span", { className: "pl-5", children: e.label }),
154
- i ? /* @__PURE__ */ l(
154
+ u ? /* @__PURE__ */ l(
155
155
  "span",
156
156
  {
157
157
  className: E(
158
158
  "absolute inset-y-0 left-0 flex items-center pl-3 text-primary-600"
159
159
  ),
160
- children: /* @__PURE__ */ l(w, { className: "h-5 w-5", "aria-hidden": "true" })
160
+ children: /* @__PURE__ */ l(w, { className: "w-5 h-5", "aria-hidden": "true" })
161
161
  }
162
162
  ) : null
163
163
  ]
@@ -3,7 +3,7 @@ import { t as r } from "../../bundle-mjs-SHnj3fHy.js";
3
3
  const l = ({
4
4
  className: e,
5
5
  ...t
6
- }) => /* @__PURE__ */ m("div", { className: r("mx-auto w-full max-w-lg px-4 py-8", e), children: t == null ? void 0 : t.children });
6
+ }) => /* @__PURE__ */ m("div", { className: r("w-full max-w-lg px-4 py-8 mx-auto ", e), children: t == null ? void 0 : t.children });
7
7
  export {
8
8
  l as Container
9
9
  };
@@ -3,5 +3,5 @@ import { SelectOption } from '../Selectbox';
3
3
  import { FormControlInputProps, FormControlDateTimeProps, FormControlRadioProps, FormControlSwitchProps, FormControlConfirmProps, FormControlTelephoneProps, FormControlSelectboxProps, FormControlAutoCompleteProps } from './type';
4
4
 
5
5
  export type FormControlProps<ListOption extends SelectOption> = FormControlInputProps | FormControlDateTimeProps | FormControlRadioProps<ListOption> | FormControlSwitchProps | FormControlConfirmProps | FormControlTelephoneProps | FormControlSelectboxProps<ListOption> | FormControlAutoCompleteProps<ListOption>;
6
- declare const FormControl: <ListOption extends SelectOption>({ type, onChange, ...props }: FormControlProps<ListOption>) => React.ReactElement;
6
+ declare const FormControl: <ListOption extends SelectOption>({ type, onChange, variant, ...props }: FormControlProps<ListOption>) => React.ReactElement;
7
7
  export default FormControl;
@@ -1,68 +1,85 @@
1
- import { jsx as r } from "react/jsx-runtime";
2
- import m, { Suspense as c } from "react";
3
- import e from "../RadioGroup/RadioGroup.js";
1
+ import { jsx as l } from "react/jsx-runtime";
2
+ import a, { Suspense as s } from "react";
3
+ import d from "../RadioGroup/RadioGroup.js";
4
4
  import "../Selectbox/SelectboxBase.js";
5
5
  import "../Selectbox/SelectboxMultiple.js";
6
6
  import p from "../Selectbox/Selectbox.js";
7
- import d from "../AutoComplete/AutoComplete.js";
8
- const u = m.lazy(() => import("../Label/index.js")), f = m.lazy(() => import("../Input/index.js")), z = m.lazy(() => import("../PasswordInput/index.js")), n = m.lazy(() => import("../TelephoneInput/index.js")), b = m.lazy(() => import("../DatePicker/index.js")), w = m.lazy(() => import("../Switch/index.js")), x = m.lazy(() => import("../Checkbox/index.js")), _ = ({
9
- type: o,
10
- onChange: t,
11
- ...a
7
+ import u from "../AutoComplete/AutoComplete.js";
8
+ const f = a.lazy(() => import("../Label/index.js")), b = a.lazy(() => import("../Input/index.js")), n = a.lazy(() => import("../PasswordInput/index.js")), z = a.lazy(() => import("../TelephoneInput/index.js")), w = a.lazy(() => import("../DatePicker/index.js")), k = a.lazy(() => import("../Switch/index.js")), x = a.lazy(() => import("../Checkbox/index.js")), _ = ({
9
+ type: t,
10
+ onChange: o,
11
+ variant: e = "md",
12
+ ...c
12
13
  }) => {
13
- const { labelProps: s, ...l } = a;
14
- return /* @__PURE__ */ r(c, { fallback: null, children: o !== "confirm" ? /* @__PURE__ */ r(
15
- u,
14
+ const { labelProps: m, ...i } = c;
15
+ return /* @__PURE__ */ l(s, { fallback: null, children: t !== "confirm" ? /* @__PURE__ */ l(
16
+ f,
16
17
  {
17
- type: o === "radio" ? "normal" : o === "switch" ? "horizontal" : void 0,
18
- ...s || { label: "" },
19
- children: o === "password" ? /* @__PURE__ */ r(
20
- z,
18
+ className: e,
19
+ type: t === "radio" ? "normal" : t === "switch" ? "horizontal" : void 0,
20
+ ...m || { label: "" },
21
+ children: t === "password" ? /* @__PURE__ */ l(
22
+ n,
21
23
  {
22
- ...l,
23
- onChange: (i) => t && t(i.target.value)
24
+ ...i,
25
+ onChange: (r) => o && o(r.target.value)
24
26
  }
25
- ) : o === "date" || o === "datetime" ? /* @__PURE__ */ r(
26
- b,
27
+ ) : t === "date" || t === "datetime" ? /* @__PURE__ */ l(
28
+ w,
27
29
  {
28
- ...l,
29
- onChange: (i) => t && t(i + ""),
30
- showTime: o === "datetime"
30
+ ...i,
31
+ onChange: (r) => o && o(r + ""),
32
+ showTime: t === "datetime"
31
33
  }
32
- ) : o === "radio" ? /* @__PURE__ */ r(
33
- e,
34
+ ) : t === "radio" ? /* @__PURE__ */ l(
35
+ d,
34
36
  {
35
- ...l,
36
- onChange: t
37
+ ...i,
38
+ variant: e,
39
+ onChange: o
37
40
  }
38
- ) : o === "switch" ? /* @__PURE__ */ r(w, { ...l, onChange: t }) : o === "tel" ? /* @__PURE__ */ r(
39
- n,
41
+ ) : t === "switch" ? /* @__PURE__ */ l(
42
+ k,
43
+ {
44
+ ...i,
45
+ onChange: o,
46
+ checked: !!i.value
47
+ }
48
+ ) : t === "tel" ? /* @__PURE__ */ l(
49
+ z,
40
50
  {
41
- ...l,
42
- onChange: t
51
+ ...i,
52
+ onChange: o
43
53
  }
44
- ) : o === "select" ? /* @__PURE__ */ r(
54
+ ) : t === "select" ? /* @__PURE__ */ l(
45
55
  p,
46
56
  {
47
- ...l,
48
- onChange: (i) => t && t(i)
57
+ ...i,
58
+ onChange: (r) => o && o(r)
49
59
  }
50
- ) : o === "autocomplete" ? /* @__PURE__ */ r(
51
- d,
60
+ ) : t === "autocomplete" ? /* @__PURE__ */ l(
61
+ u,
52
62
  {
53
- ...l,
54
- onChange: t
63
+ ...i,
64
+ onChange: o
55
65
  }
56
- ) : /* @__PURE__ */ r(
57
- f,
66
+ ) : /* @__PURE__ */ l(
67
+ b,
58
68
  {
59
- type: o,
60
- onChange: (i) => t && t(typeof i == "string" ? i : i.target.value),
61
- ...l
69
+ type: t,
70
+ onChange: (r) => o && o(typeof r == "string" ? r : r.target.value),
71
+ ...i
62
72
  }
63
73
  )
64
74
  }
65
- ) : /* @__PURE__ */ r(x, { ...l, onChange: t }) });
75
+ ) : /* @__PURE__ */ l(
76
+ x,
77
+ {
78
+ ...i,
79
+ onChange: (r) => o && o(String(r.target.checked)),
80
+ label: m.label
81
+ }
82
+ ) });
66
83
  };
67
84
  export {
68
85
  _ as default
@@ -37,51 +37,59 @@ export type FormField = {
37
37
  componentProps: FormFieldInputProps | FormFieldDateTimeProps | FormFieldRadioProps<SelectOption> | FormFieldSwitchProps | FormFieldConfirmProps | FormFieldTelephoneProps | FormFieldSelectboxProps<SelectOption> | FormFieldAutoCompleteProps<SelectOption>;
38
38
  };
39
39
  export type FormFieldWithStructure = (FormField | FormField[])[];
40
- export type FormControlInputProps = {
40
+ export type FormControlInputProps = InputProps & {
41
41
  type: "password" | "text" | "number" | "email";
42
42
  labelProps: LabelBaseProps;
43
43
  onChange?: (value: string) => void;
44
- } & InputProps;
45
- export type FormFieldInputProps = Omit<FormControlInputProps, "name">;
44
+ variant?: "sm" | "md";
45
+ };
46
+ export type FormFieldInputProps = Omit<FormControlInputProps, "name" | "value" | "onChange">;
46
47
  export type FormControlDateTimeProps = DatePickerProps & {
47
48
  type: "date" | "datetime";
48
49
  labelProps: LabelBaseProps;
49
50
  onChange?: (value: string) => void;
51
+ variant?: "sm" | "md";
50
52
  };
51
53
  export type FormFieldDateTimeProps = Omit<FormControlDateTimeProps, "name" | "value" | "onChange">;
52
54
  export type FormControlRadioProps<ListOption extends SelectOption> = {
53
55
  type: "radio";
54
56
  labelProps: LabelBaseProps;
55
57
  onChange?: (value: string) => void;
58
+ variant?: "sm" | "md";
56
59
  } & RadioGroupProps<ListOption>;
57
60
  export type FormFieldRadioProps<ListOption extends SelectOption> = Omit<FormControlRadioProps<ListOption>, "name" | "value" | "onChange">;
58
61
  export type FormControlSwitchProps = {
59
62
  type: "switch";
60
63
  labelProps: LabelBaseProps;
61
64
  onChange?: (value: string) => void;
65
+ variant?: "sm" | "md";
62
66
  } & SwitchProps;
63
- export type FormFieldSwitchProps = Omit<FormControlSwitchProps, "name">;
67
+ export type FormFieldSwitchProps = Omit<FormControlSwitchProps, "name" | "value" | "onChange">;
64
68
  export type FormControlConfirmProps = {
65
69
  type: "confirm";
66
70
  labelProps: LabelBaseProps;
67
71
  onChange?: (value: string) => void;
72
+ variant?: "sm" | "md";
68
73
  } & CheckboxProps;
69
- export type FormFieldConfirmProps = Omit<FormControlConfirmProps, "name">;
74
+ export type FormFieldConfirmProps = Omit<FormControlConfirmProps, "name" | "label">;
70
75
  export type FormControlTelephoneProps = {
71
76
  type: "tel";
72
77
  labelProps: LabelBaseProps;
73
78
  onChange?: (value: string) => void;
79
+ variant?: "sm" | "md";
74
80
  } & TelephoneInputProps;
75
81
  export type FormFieldTelephoneProps = Omit<FormControlTelephoneProps, "name">;
76
82
  export type FormControlSelectboxProps<ListOption extends SelectOption> = {
77
83
  type: "select";
78
84
  labelProps: LabelBaseProps;
79
85
  onChange?: (value: string | string[]) => void;
86
+ variant?: "sm" | "md";
80
87
  } & SelectboxProps<ListOption>;
81
88
  export type FormFieldSelectboxProps<ListOption extends SelectOption> = Omit<FormControlSelectboxProps<ListOption>, "name" | "value" | "onChange">;
82
89
  export type FormControlAutoCompleteProps<ListOption extends SelectOption> = {
83
90
  type: "autocomplete";
84
91
  labelProps: LabelBaseProps;
85
92
  onChange?: (value: string | string[]) => void;
93
+ variant?: "sm" | "md";
86
94
  } & AutoCompleteProps<ListOption>;
87
95
  export type FormFieldAutoCompleteProps<ListOption extends SelectOption> = Omit<FormControlAutoCompleteProps<ListOption>, "name" | "value" | "onChange">;
@@ -1,6 +1,7 @@
1
1
  import { SelectOption, ValueField } from '../Selectbox/SelectboxBase';
2
2
 
3
3
  export type RadioGroupProps<ListOption extends SelectOption> = {
4
+ variant?: "sm" | "md";
4
5
  id?: string;
5
6
  name: string;
6
7
  options: ListOption[];
@@ -11,5 +12,5 @@ export type RadioGroupProps<ListOption extends SelectOption> = {
11
12
  onChange: (value: string) => void;
12
13
  valueField?: ValueField<ListOption>;
13
14
  };
14
- declare const RadioGroup: <ListOption extends SelectOption>({ options, value, valueField, onChange, }: RadioGroupProps<ListOption>) => import("react/jsx-runtime").JSX.Element;
15
+ declare const RadioGroup: <ListOption extends SelectOption>({ variant, options, value, valueField, onChange, }: RadioGroupProps<ListOption>) => import("react/jsx-runtime").JSX.Element;
15
16
  export default RadioGroup;