@hitachivantara/uikit-react-lab 5.22.1 → 5.23.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 (206) hide show
  1. package/dist/cjs/Blade/Blade.cjs +169 -0
  2. package/dist/cjs/Blade/Blade.cjs.map +1 -0
  3. package/dist/cjs/Blade/Blade.styles.cjs +72 -0
  4. package/dist/cjs/Blade/Blade.styles.cjs.map +1 -0
  5. package/dist/cjs/Blades/Blades.cjs +105 -0
  6. package/dist/cjs/Blades/Blades.cjs.map +1 -0
  7. package/dist/cjs/Blades/Blades.styles.cjs +12 -0
  8. package/dist/cjs/Blades/Blades.styles.cjs.map +1 -0
  9. package/dist/cjs/Flow/Node/Parameters/Select.cjs +11 -11
  10. package/dist/cjs/Flow/Node/Parameters/Select.cjs.map +1 -1
  11. package/dist/cjs/Flow/Node/Parameters/Slider.cjs +8 -8
  12. package/dist/cjs/Flow/Node/Parameters/Slider.cjs.map +1 -1
  13. package/dist/cjs/Flow/Node/Parameters/Text.cjs +8 -8
  14. package/dist/cjs/Flow/Node/Parameters/Text.cjs.map +1 -1
  15. package/dist/cjs/Flow/nodes/DashboardNode.cjs +1 -3
  16. package/dist/cjs/Flow/nodes/DashboardNode.cjs.map +1 -1
  17. package/dist/cjs/index.cjs +8 -0
  18. package/dist/cjs/index.cjs.map +1 -1
  19. package/dist/esm/Blade/Blade.js +168 -0
  20. package/dist/esm/Blade/Blade.js.map +1 -0
  21. package/dist/esm/Blade/Blade.styles.js +72 -0
  22. package/dist/esm/Blade/Blade.styles.js.map +1 -0
  23. package/dist/esm/Blades/Blades.js +106 -0
  24. package/dist/esm/Blades/Blades.js.map +1 -0
  25. package/dist/esm/Blades/Blades.styles.js +12 -0
  26. package/dist/esm/Blades/Blades.styles.js.map +1 -0
  27. package/dist/esm/Dashboard/{Dashboard.mjs → Dashboard.js} +3 -3
  28. package/dist/esm/Dashboard/Dashboard.js.map +1 -0
  29. package/dist/esm/Dashboard/{Dashboard.styles.mjs → Dashboard.styles.js} +1 -1
  30. package/dist/esm/Dashboard/Dashboard.styles.js.map +1 -0
  31. package/dist/esm/Flow/Background/{Background.mjs → Background.js} +1 -1
  32. package/dist/esm/Flow/Background/Background.js.map +1 -0
  33. package/dist/esm/Flow/Controls/{Controls.mjs → Controls.js} +1 -1
  34. package/dist/esm/Flow/Controls/Controls.js.map +1 -0
  35. package/dist/esm/Flow/{DroppableFlow.mjs → DroppableFlow.js} +6 -6
  36. package/dist/esm/Flow/DroppableFlow.js.map +1 -0
  37. package/dist/esm/Flow/Empty/{Empty.mjs → Empty.js} +2 -2
  38. package/dist/esm/Flow/Empty/Empty.js.map +1 -0
  39. package/dist/esm/Flow/Empty/{Empty.styles.mjs → Empty.styles.js} +1 -1
  40. package/dist/esm/Flow/Empty/Empty.styles.js.map +1 -0
  41. package/dist/esm/Flow/{Flow.mjs → Flow.js} +3 -3
  42. package/dist/esm/Flow/Flow.js.map +1 -0
  43. package/dist/esm/Flow/{Flow.styles.mjs → Flow.styles.js} +2 -2
  44. package/dist/esm/Flow/Flow.styles.js.map +1 -0
  45. package/dist/esm/Flow/FlowContext/{FlowContext.mjs → FlowContext.js} +2 -2
  46. package/dist/esm/Flow/FlowContext/FlowContext.js.map +1 -0
  47. package/dist/esm/Flow/FlowContext/{NodeMetaContext.mjs → NodeMetaContext.js} +1 -1
  48. package/dist/esm/Flow/FlowContext/NodeMetaContext.js.map +1 -0
  49. package/dist/esm/Flow/Minimap/{Minimap.mjs → Minimap.js} +3 -3
  50. package/dist/esm/Flow/Minimap/Minimap.js.map +1 -0
  51. package/dist/esm/Flow/Minimap/{Minimap.styles.mjs → Minimap.styles.js} +1 -1
  52. package/dist/esm/Flow/Minimap/Minimap.styles.js.map +1 -0
  53. package/dist/esm/Flow/Node/{BaseNode.mjs → BaseNode.js} +5 -5
  54. package/dist/esm/Flow/Node/BaseNode.js.map +1 -0
  55. package/dist/esm/Flow/Node/{BaseNode.styles.mjs → BaseNode.styles.js} +1 -1
  56. package/dist/esm/Flow/Node/BaseNode.styles.js.map +1 -0
  57. package/dist/esm/Flow/Node/{Node.mjs → Node.js} +7 -7
  58. package/dist/esm/Flow/Node/Node.js.map +1 -0
  59. package/dist/esm/Flow/Node/{Node.styles.mjs → Node.styles.js} +1 -1
  60. package/dist/esm/Flow/Node/Node.styles.js.map +1 -0
  61. package/dist/esm/Flow/Node/Parameters/{ParamRenderer.mjs → ParamRenderer.js} +4 -4
  62. package/dist/esm/Flow/Node/Parameters/ParamRenderer.js.map +1 -0
  63. package/dist/esm/Flow/Node/Parameters/{Select.mjs → Select.js} +12 -12
  64. package/dist/esm/Flow/Node/Parameters/Select.js.map +1 -0
  65. package/dist/esm/Flow/Node/Parameters/{Slider.mjs → Slider.js} +9 -9
  66. package/dist/esm/Flow/Node/Parameters/Slider.js.map +1 -0
  67. package/dist/esm/Flow/Node/Parameters/{Text.mjs → Text.js} +9 -9
  68. package/dist/esm/Flow/Node/Parameters/Text.js.map +1 -0
  69. package/dist/esm/Flow/Sidebar/{Sidebar.mjs → Sidebar.js} +8 -8
  70. package/dist/esm/Flow/Sidebar/Sidebar.js.map +1 -0
  71. package/dist/esm/Flow/Sidebar/{Sidebar.styles.mjs → Sidebar.styles.js} +1 -1
  72. package/dist/esm/Flow/Sidebar/Sidebar.styles.js.map +1 -0
  73. package/dist/esm/Flow/Sidebar/SidebarGroup/{SidebarGroup.mjs → SidebarGroup.js} +5 -5
  74. package/dist/esm/Flow/Sidebar/SidebarGroup/SidebarGroup.js.map +1 -0
  75. package/dist/esm/Flow/Sidebar/SidebarGroup/{SidebarGroup.styles.mjs → SidebarGroup.styles.js} +1 -1
  76. package/dist/esm/Flow/Sidebar/SidebarGroup/SidebarGroup.styles.js.map +1 -0
  77. package/dist/esm/Flow/Sidebar/SidebarGroup/SidebarGroupItem/{DraggableSidebarGroupItem.mjs → DraggableSidebarGroupItem.js} +2 -2
  78. package/dist/esm/Flow/Sidebar/SidebarGroup/SidebarGroupItem/DraggableSidebarGroupItem.js.map +1 -0
  79. package/dist/esm/Flow/Sidebar/SidebarGroup/SidebarGroupItem/{SidebarGroupItem.mjs → SidebarGroupItem.js} +3 -3
  80. package/dist/esm/Flow/Sidebar/SidebarGroup/SidebarGroupItem/SidebarGroupItem.js.map +1 -0
  81. package/dist/esm/Flow/Sidebar/SidebarGroup/SidebarGroupItem/{SidebarGroupItem.styles.mjs → SidebarGroupItem.styles.js} +1 -1
  82. package/dist/esm/Flow/Sidebar/SidebarGroup/SidebarGroupItem/SidebarGroupItem.styles.js.map +1 -0
  83. package/dist/esm/Flow/Sidebar/{utils.mjs → utils.js} +1 -1
  84. package/dist/esm/Flow/Sidebar/utils.js.map +1 -0
  85. package/dist/esm/Flow/{base.mjs → base.js} +1 -1
  86. package/dist/esm/Flow/base.js.map +1 -0
  87. package/dist/esm/Flow/hooks/{useFlowContext.mjs → useFlowContext.js} +2 -2
  88. package/dist/esm/Flow/hooks/useFlowContext.js.map +1 -0
  89. package/dist/esm/Flow/hooks/{useFlowNode.mjs → useFlowNode.js} +1 -1
  90. package/dist/esm/Flow/hooks/useFlowNode.js.map +1 -0
  91. package/dist/esm/Flow/hooks/{useFlowNodeMeta.mjs → useFlowNodeMeta.js} +2 -2
  92. package/dist/esm/Flow/hooks/useFlowNodeMeta.js.map +1 -0
  93. package/dist/esm/Flow/nodes/{DashboardNode.mjs → DashboardNode.js} +4 -6
  94. package/dist/esm/Flow/nodes/DashboardNode.js.map +1 -0
  95. package/dist/esm/StepNavigation/DefaultNavigation/{DefaultNavigation.mjs → DefaultNavigation.js} +3 -3
  96. package/dist/esm/StepNavigation/DefaultNavigation/DefaultNavigation.js.map +1 -0
  97. package/dist/esm/StepNavigation/DefaultNavigation/Step/{Step.mjs → Step.js} +3 -3
  98. package/dist/esm/StepNavigation/DefaultNavigation/Step/Step.js.map +1 -0
  99. package/dist/esm/StepNavigation/DefaultNavigation/Step/{Step.styles.mjs → Step.styles.js} +1 -1
  100. package/dist/esm/StepNavigation/DefaultNavigation/Step/Step.styles.js.map +1 -0
  101. package/dist/esm/StepNavigation/DefaultNavigation/{utils.mjs → utils.js} +1 -1
  102. package/dist/esm/StepNavigation/DefaultNavigation/utils.js.map +1 -0
  103. package/dist/esm/StepNavigation/SimpleNavigation/Dot/{Dot.mjs → Dot.js} +4 -4
  104. package/dist/esm/StepNavigation/SimpleNavigation/Dot/Dot.js.map +1 -0
  105. package/dist/esm/StepNavigation/SimpleNavigation/Dot/{Dot.styles.mjs → Dot.styles.js} +1 -1
  106. package/dist/esm/StepNavigation/SimpleNavigation/Dot/Dot.styles.js.map +1 -0
  107. package/dist/esm/StepNavigation/SimpleNavigation/{SimpleNavigation.mjs → SimpleNavigation.js} +3 -3
  108. package/dist/esm/StepNavigation/SimpleNavigation/SimpleNavigation.js.map +1 -0
  109. package/dist/esm/StepNavigation/SimpleNavigation/{utils.mjs → utils.js} +1 -1
  110. package/dist/esm/StepNavigation/SimpleNavigation/utils.js.map +1 -0
  111. package/dist/esm/StepNavigation/{StepNavigation.mjs → StepNavigation.js} +6 -6
  112. package/dist/esm/StepNavigation/StepNavigation.js.map +1 -0
  113. package/dist/esm/StepNavigation/{StepNavigation.styles.mjs → StepNavigation.styles.js} +1 -1
  114. package/dist/esm/StepNavigation/StepNavigation.styles.js.map +1 -0
  115. package/dist/esm/StepNavigation/{utils.mjs → utils.js} +1 -1
  116. package/dist/esm/StepNavigation/utils.js.map +1 -0
  117. package/dist/esm/Wizard/{Wizard.mjs → Wizard.js} +8 -8
  118. package/dist/esm/Wizard/Wizard.js.map +1 -0
  119. package/dist/esm/Wizard/{Wizard.styles.mjs → Wizard.styles.js} +1 -1
  120. package/dist/esm/Wizard/Wizard.styles.js.map +1 -0
  121. package/dist/esm/Wizard/WizardActions/{WizardActions.mjs → WizardActions.js} +4 -4
  122. package/dist/esm/Wizard/WizardActions/WizardActions.js.map +1 -0
  123. package/dist/esm/Wizard/WizardActions/{WizardActions.styles.mjs → WizardActions.styles.js} +1 -1
  124. package/dist/esm/Wizard/WizardActions/WizardActions.styles.js.map +1 -0
  125. package/dist/esm/Wizard/WizardContainer/{WizardContainer.mjs → WizardContainer.js} +3 -3
  126. package/dist/esm/Wizard/WizardContainer/WizardContainer.js.map +1 -0
  127. package/dist/esm/Wizard/WizardContainer/{WizardContainer.styles.mjs → WizardContainer.styles.js} +1 -1
  128. package/dist/esm/Wizard/WizardContainer/WizardContainer.styles.js.map +1 -0
  129. package/dist/esm/Wizard/WizardContent/{LoadingContainer.mjs → LoadingContainer.js} +2 -2
  130. package/dist/esm/Wizard/WizardContent/LoadingContainer.js.map +1 -0
  131. package/dist/esm/Wizard/WizardContent/{LoadingContainer.styles.mjs → LoadingContainer.styles.js} +1 -1
  132. package/dist/esm/Wizard/WizardContent/LoadingContainer.styles.js.map +1 -0
  133. package/dist/esm/Wizard/WizardContent/{WizardContent.mjs → WizardContent.js} +5 -5
  134. package/dist/esm/Wizard/WizardContent/WizardContent.js.map +1 -0
  135. package/dist/esm/Wizard/WizardContent/{WizardContent.styles.mjs → WizardContent.styles.js} +1 -1
  136. package/dist/esm/Wizard/WizardContent/WizardContent.styles.js.map +1 -0
  137. package/dist/esm/Wizard/WizardContext/{WizardContext.mjs → WizardContext.js} +1 -1
  138. package/dist/esm/Wizard/WizardContext/WizardContext.js.map +1 -0
  139. package/dist/esm/Wizard/WizardTitle/{WizardTitle.mjs → WizardTitle.js} +5 -5
  140. package/dist/esm/Wizard/WizardTitle/WizardTitle.js.map +1 -0
  141. package/dist/esm/Wizard/WizardTitle/{WizardTitle.styles.mjs → WizardTitle.styles.js} +1 -1
  142. package/dist/esm/Wizard/WizardTitle/WizardTitle.styles.js.map +1 -0
  143. package/dist/esm/index.js +82 -0
  144. package/dist/esm/index.js.map +1 -0
  145. package/dist/types/index.d.ts +244 -62
  146. package/package.json +6 -6
  147. package/dist/esm/Dashboard/Dashboard.mjs.map +0 -1
  148. package/dist/esm/Dashboard/Dashboard.styles.mjs.map +0 -1
  149. package/dist/esm/Flow/Background/Background.mjs.map +0 -1
  150. package/dist/esm/Flow/Controls/Controls.mjs.map +0 -1
  151. package/dist/esm/Flow/DroppableFlow.mjs.map +0 -1
  152. package/dist/esm/Flow/Empty/Empty.mjs.map +0 -1
  153. package/dist/esm/Flow/Empty/Empty.styles.mjs.map +0 -1
  154. package/dist/esm/Flow/Flow.mjs.map +0 -1
  155. package/dist/esm/Flow/Flow.styles.mjs.map +0 -1
  156. package/dist/esm/Flow/FlowContext/FlowContext.mjs.map +0 -1
  157. package/dist/esm/Flow/FlowContext/NodeMetaContext.mjs.map +0 -1
  158. package/dist/esm/Flow/Minimap/Minimap.mjs.map +0 -1
  159. package/dist/esm/Flow/Minimap/Minimap.styles.mjs.map +0 -1
  160. package/dist/esm/Flow/Node/BaseNode.mjs.map +0 -1
  161. package/dist/esm/Flow/Node/BaseNode.styles.mjs.map +0 -1
  162. package/dist/esm/Flow/Node/Node.mjs.map +0 -1
  163. package/dist/esm/Flow/Node/Node.styles.mjs.map +0 -1
  164. package/dist/esm/Flow/Node/Parameters/ParamRenderer.mjs.map +0 -1
  165. package/dist/esm/Flow/Node/Parameters/Select.mjs.map +0 -1
  166. package/dist/esm/Flow/Node/Parameters/Slider.mjs.map +0 -1
  167. package/dist/esm/Flow/Node/Parameters/Text.mjs.map +0 -1
  168. package/dist/esm/Flow/Sidebar/Sidebar.mjs.map +0 -1
  169. package/dist/esm/Flow/Sidebar/Sidebar.styles.mjs.map +0 -1
  170. package/dist/esm/Flow/Sidebar/SidebarGroup/SidebarGroup.mjs.map +0 -1
  171. package/dist/esm/Flow/Sidebar/SidebarGroup/SidebarGroup.styles.mjs.map +0 -1
  172. package/dist/esm/Flow/Sidebar/SidebarGroup/SidebarGroupItem/DraggableSidebarGroupItem.mjs.map +0 -1
  173. package/dist/esm/Flow/Sidebar/SidebarGroup/SidebarGroupItem/SidebarGroupItem.mjs.map +0 -1
  174. package/dist/esm/Flow/Sidebar/SidebarGroup/SidebarGroupItem/SidebarGroupItem.styles.mjs.map +0 -1
  175. package/dist/esm/Flow/Sidebar/utils.mjs.map +0 -1
  176. package/dist/esm/Flow/base.mjs.map +0 -1
  177. package/dist/esm/Flow/hooks/useFlowContext.mjs.map +0 -1
  178. package/dist/esm/Flow/hooks/useFlowNode.mjs.map +0 -1
  179. package/dist/esm/Flow/hooks/useFlowNodeMeta.mjs.map +0 -1
  180. package/dist/esm/Flow/nodes/DashboardNode.mjs.map +0 -1
  181. package/dist/esm/StepNavigation/DefaultNavigation/DefaultNavigation.mjs.map +0 -1
  182. package/dist/esm/StepNavigation/DefaultNavigation/Step/Step.mjs.map +0 -1
  183. package/dist/esm/StepNavigation/DefaultNavigation/Step/Step.styles.mjs.map +0 -1
  184. package/dist/esm/StepNavigation/DefaultNavigation/utils.mjs.map +0 -1
  185. package/dist/esm/StepNavigation/SimpleNavigation/Dot/Dot.mjs.map +0 -1
  186. package/dist/esm/StepNavigation/SimpleNavigation/Dot/Dot.styles.mjs.map +0 -1
  187. package/dist/esm/StepNavigation/SimpleNavigation/SimpleNavigation.mjs.map +0 -1
  188. package/dist/esm/StepNavigation/SimpleNavigation/utils.mjs.map +0 -1
  189. package/dist/esm/StepNavigation/StepNavigation.mjs.map +0 -1
  190. package/dist/esm/StepNavigation/StepNavigation.styles.mjs.map +0 -1
  191. package/dist/esm/StepNavigation/utils.mjs.map +0 -1
  192. package/dist/esm/Wizard/Wizard.mjs.map +0 -1
  193. package/dist/esm/Wizard/Wizard.styles.mjs.map +0 -1
  194. package/dist/esm/Wizard/WizardActions/WizardActions.mjs.map +0 -1
  195. package/dist/esm/Wizard/WizardActions/WizardActions.styles.mjs.map +0 -1
  196. package/dist/esm/Wizard/WizardContainer/WizardContainer.mjs.map +0 -1
  197. package/dist/esm/Wizard/WizardContainer/WizardContainer.styles.mjs.map +0 -1
  198. package/dist/esm/Wizard/WizardContent/LoadingContainer.mjs.map +0 -1
  199. package/dist/esm/Wizard/WizardContent/LoadingContainer.styles.mjs.map +0 -1
  200. package/dist/esm/Wizard/WizardContent/WizardContent.mjs.map +0 -1
  201. package/dist/esm/Wizard/WizardContent/WizardContent.styles.mjs.map +0 -1
  202. package/dist/esm/Wizard/WizardContext/WizardContext.mjs.map +0 -1
  203. package/dist/esm/Wizard/WizardTitle/WizardTitle.mjs.map +0 -1
  204. package/dist/esm/Wizard/WizardTitle/WizardTitle.styles.mjs.map +0 -1
  205. package/dist/esm/index.mjs +0 -74
  206. package/dist/esm/index.mjs.map +0 -1
@@ -0,0 +1,169 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("@emotion/react/jsx-runtime");
4
+ const React = require("react");
5
+ const uikitReactCore = require("@hitachivantara/uikit-react-core");
6
+ const Blade_styles = require("./Blade.styles.cjs");
7
+ const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
8
+ const React__default = /* @__PURE__ */ _interopDefault(React);
9
+ const HvBlade = (props) => {
10
+ const {
11
+ id: idProp,
12
+ className,
13
+ classes: classesProp,
14
+ expanded,
15
+ defaultExpanded = false,
16
+ label,
17
+ labelVariant = "label",
18
+ headingLevel,
19
+ onChange,
20
+ disabled = false,
21
+ children,
22
+ fullWidth,
23
+ buttonProps,
24
+ containerProps,
25
+ ...others
26
+ } = uikitReactCore.useDefaultProps("HvBlade", props);
27
+ const { classes, cx } = Blade_styles.useClasses(classesProp);
28
+ const [isExpanded, setIsExpanded] = uikitReactCore.useControlled(
29
+ expanded,
30
+ Boolean(defaultExpanded)
31
+ );
32
+ const handleAction = React.useCallback(
33
+ (event) => {
34
+ if (!disabled) {
35
+ onChange?.(event, !isExpanded);
36
+ setIsExpanded(!isExpanded);
37
+ return true;
38
+ }
39
+ return false;
40
+ },
41
+ [disabled, onChange, isExpanded, setIsExpanded]
42
+ );
43
+ const handleClick = React.useCallback(
44
+ (event) => {
45
+ handleAction(event);
46
+ event.preventDefault();
47
+ event.stopPropagation();
48
+ },
49
+ [handleAction]
50
+ );
51
+ const handleKeyDown = React.useCallback(
52
+ (event) => {
53
+ let isEventHandled = false;
54
+ const { key } = event;
55
+ if (event.altKey || event.ctrlKey || event.metaKey || event.currentTarget !== event.target) {
56
+ return;
57
+ }
58
+ switch (key) {
59
+ case "Enter":
60
+ case " ":
61
+ isEventHandled = handleAction(event);
62
+ break;
63
+ default:
64
+ return;
65
+ }
66
+ if (isEventHandled) {
67
+ event.preventDefault();
68
+ event.stopPropagation();
69
+ }
70
+ },
71
+ [handleAction]
72
+ );
73
+ const id = uikitReactCore.useUniqueId(idProp, "hvblade");
74
+ const bladeHeaderId = uikitReactCore.setId(id, "button");
75
+ const bladeContainerId = uikitReactCore.setId(id, "container");
76
+ const bladeHeader = React.useMemo(() => {
77
+ const buttonLabel = typeof label === "function" ? label(isExpanded) : label;
78
+ const bladeButton = /* @__PURE__ */ jsxRuntime.jsx(
79
+ uikitReactCore.HvTypography,
80
+ {
81
+ id: bladeHeaderId,
82
+ component: "div",
83
+ role: "button",
84
+ className: cx(classes.button, {
85
+ [classes.disabled]: disabled,
86
+ [classes.textOnlyLabel]: typeof buttonLabel === "string"
87
+ }),
88
+ style: { flexShrink: headingLevel === void 0 ? 0 : void 0 },
89
+ disabled,
90
+ tabIndex: 0,
91
+ onKeyDown: handleKeyDown,
92
+ onClick: handleClick,
93
+ variant: labelVariant,
94
+ "aria-expanded": isExpanded,
95
+ "aria-controls": bladeContainerId,
96
+ ...buttonProps,
97
+ children: buttonLabel
98
+ }
99
+ );
100
+ return headingLevel === void 0 ? bladeButton : /* @__PURE__ */ jsxRuntime.jsx(
101
+ uikitReactCore.HvTypography,
102
+ {
103
+ component: `h${headingLevel}`,
104
+ variant: labelVariant,
105
+ className: classes.heading,
106
+ style: { flexShrink: 0 },
107
+ children: bladeButton
108
+ }
109
+ );
110
+ }, [
111
+ bladeContainerId,
112
+ bladeHeaderId,
113
+ buttonProps,
114
+ classes.button,
115
+ classes.disabled,
116
+ classes.heading,
117
+ classes.textOnlyLabel,
118
+ cx,
119
+ disabled,
120
+ handleClick,
121
+ handleKeyDown,
122
+ headingLevel,
123
+ isExpanded,
124
+ label,
125
+ labelVariant
126
+ ]);
127
+ const bladeRef = React__default.default.useRef(null);
128
+ const maxWidthRef = React__default.default.useRef(0);
129
+ React.useEffect(() => {
130
+ if (bladeRef.current) {
131
+ maxWidthRef.current = bladeRef.current.parentElement?.clientWidth || 0;
132
+ }
133
+ }, []);
134
+ const { style: containerStyle, ...otherContainerProps } = containerProps || {};
135
+ return /* @__PURE__ */ jsxRuntime.jsxs(
136
+ "div",
137
+ {
138
+ ref: bladeRef,
139
+ id: idProp,
140
+ className: cx(classes.root, className, {
141
+ [classes.fullWidth]: fullWidth,
142
+ [classes.expanded]: isExpanded
143
+ }),
144
+ ...others,
145
+ children: [
146
+ bladeHeader,
147
+ /* @__PURE__ */ jsxRuntime.jsx(
148
+ "div",
149
+ {
150
+ id: bladeContainerId,
151
+ role: "region",
152
+ "aria-labelledby": bladeHeaderId,
153
+ className: classes.container,
154
+ hidden: !isExpanded,
155
+ style: {
156
+ ...containerStyle,
157
+ maxWidth: isExpanded ? maxWidthRef.current : 0
158
+ },
159
+ ...otherContainerProps,
160
+ children
161
+ }
162
+ )
163
+ ]
164
+ }
165
+ );
166
+ };
167
+ exports.bladeClasses = Blade_styles.staticClasses;
168
+ exports.HvBlade = HvBlade;
169
+ //# sourceMappingURL=Blade.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Blade.cjs","sources":["../../../src/Blade/Blade.tsx"],"sourcesContent":["import React, {\n SyntheticEvent,\n useCallback,\n useMemo,\n HTMLAttributes,\n useEffect,\n} from \"react\";\n\nimport {\n ExtractNames,\n HvBaseProps,\n HvTypography,\n HvTypographyVariants,\n setId,\n useControlled,\n useDefaultProps,\n useUniqueId,\n} from \"@hitachivantara/uikit-react-core\";\n\nimport { staticClasses, useClasses } from \"./Blade.styles\";\n\nexport { staticClasses as bladeClasses };\n\nexport type HvBladeClasses = ExtractNames<typeof useClasses>;\n\nexport interface HvBladeProps\n extends HvBaseProps<HTMLDivElement, \"onChange\" | \"children\"> {\n /**\n * The content that will be rendered within the blade.\n */\n children: React.ReactNode;\n\n /**\n * The content of the blade's button.\n *\n * If a render function is provided, it will be called with the expanded state as an argument.\n */\n label?: React.ReactNode | ((expanded: boolean) => React.ReactNode);\n /**\n * Typography variant for the blade's button label.\n */\n labelVariant?: HvTypographyVariants;\n /**\n * Heading Level to apply to blade button.\n *\n * If 'undefined', the button will not have a header wrapper.\n */\n headingLevel?: 1 | 2 | 3 | 4 | 5 | 6;\n\n /**\n * Indicates whether the blade is expanded or not.\n *\n * When defined the expanded state becomes controlled.\n *\n * @default undefined\n */\n expanded?: boolean;\n /**\n * Specifies the initial expanded state of the blade when it is uncontrolled.\n */\n defaultExpanded?: boolean;\n\n /**\n * Callback function triggered when the blade's button is pressed.\n * It receives the event and the new expanded state as arguments.\n *\n * If the blade is uncontrolled, this new state will be effective.\n * If the blade is controlled, it is up to the parent component to manage this state.\n *\n * @param {SyntheticEvent} event The event source of the callback.\n * @param {boolean} value The new value.\n */\n onChange?: (event: React.SyntheticEvent, value: boolean) => void;\n\n /**\n * Specifies whether the blade is disabled. If true, the blade cannot be interacted with.\n */\n disabled?: boolean;\n\n /**\n * If true, the blade will take up the maximum width of the container when expanded.\n */\n fullWidth?: boolean;\n\n /**\n * Props to be passed to the button that toggles the blade's expanded state.\n * This can be used to further customize the appearance or behavior of the blade's button,\n * e.g. to set the aria-label attribute.\n */\n buttonProps?: HTMLAttributes<HTMLDivElement>;\n /**\n * Props to be passed to the container div that holds the blade's children.\n * This can be used to further customize the appearance or behavior of the blade's content area.\n */\n containerProps?: HTMLAttributes<HTMLDivElement>;\n /**\n * A Jss Object used to override or extend the styles applied.\n */\n classes?: HvBladeClasses;\n}\n\n/**\n * A blade is a design element that expands horizontally to reveal information, similar to an accordion.\n *\n * It is usually stacked horizontally with other blades and works best when used within a flex container.\n * The `HvBlades` component is recommended for this purpose, as it also provides better management of the\n * blades' expanded state.\n */\nexport const HvBlade = (props: HvBladeProps) => {\n const {\n id: idProp,\n className,\n classes: classesProp,\n expanded,\n defaultExpanded = false,\n label,\n labelVariant = \"label\",\n headingLevel,\n onChange,\n disabled = false,\n children,\n fullWidth,\n buttonProps,\n containerProps,\n ...others\n } = useDefaultProps(\"HvBlade\", props);\n\n const { classes, cx } = useClasses(classesProp);\n\n const [isExpanded, setIsExpanded] = useControlled(\n expanded,\n Boolean(defaultExpanded)\n );\n\n const handleAction = useCallback(\n (event: SyntheticEvent) => {\n if (!disabled) {\n onChange?.(event, !isExpanded);\n\n // This will only run if uncontrolled\n setIsExpanded(!isExpanded);\n\n return true;\n }\n return false;\n },\n [disabled, onChange, isExpanded, setIsExpanded]\n );\n\n const handleClick = useCallback(\n (event: SyntheticEvent) => {\n handleAction(event);\n event.preventDefault();\n event.stopPropagation();\n },\n [handleAction]\n );\n\n const handleKeyDown = useCallback(\n (event: React.KeyboardEvent<HTMLDivElement>) => {\n let isEventHandled = false;\n const { key } = event;\n\n if (\n event.altKey ||\n event.ctrlKey ||\n event.metaKey ||\n event.currentTarget !== event.target\n ) {\n return;\n }\n switch (key) {\n case \"Enter\":\n case \" \":\n isEventHandled = handleAction(event);\n break;\n default:\n return;\n }\n\n if (isEventHandled) {\n event.preventDefault();\n event.stopPropagation();\n }\n },\n [handleAction]\n );\n\n const id = useUniqueId(idProp, \"hvblade\");\n const bladeHeaderId = setId(id, \"button\");\n const bladeContainerId = setId(id, \"container\");\n const bladeHeader = useMemo(() => {\n const buttonLabel = typeof label === \"function\" ? label(isExpanded) : label;\n\n const bladeButton = (\n <HvTypography\n id={bladeHeaderId}\n component=\"div\"\n role=\"button\"\n className={cx(classes.button, {\n [classes.disabled]: disabled,\n [classes.textOnlyLabel]: typeof buttonLabel === \"string\",\n })}\n style={{ flexShrink: headingLevel === undefined ? 0 : undefined }}\n disabled={disabled}\n tabIndex={0}\n onKeyDown={handleKeyDown}\n onClick={handleClick}\n variant={labelVariant}\n aria-expanded={isExpanded}\n aria-controls={bladeContainerId}\n {...buttonProps}\n >\n {buttonLabel}\n </HvTypography>\n );\n return headingLevel === undefined ? (\n bladeButton\n ) : (\n <HvTypography\n component={`h${headingLevel}`}\n variant={labelVariant}\n className={classes.heading}\n style={{ flexShrink: 0 }}\n >\n {bladeButton}\n </HvTypography>\n );\n }, [\n bladeContainerId,\n bladeHeaderId,\n buttonProps,\n classes.button,\n classes.disabled,\n classes.heading,\n classes.textOnlyLabel,\n cx,\n disabled,\n handleClick,\n handleKeyDown,\n headingLevel,\n isExpanded,\n label,\n labelVariant,\n ]);\n\n const bladeRef = React.useRef<HTMLDivElement>(null);\n const maxWidthRef = React.useRef<number>(0);\n useEffect(() => {\n if (bladeRef.current) {\n maxWidthRef.current = bladeRef.current.parentElement?.clientWidth || 0;\n }\n }, []);\n\n const { style: containerStyle, ...otherContainerProps } =\n containerProps || {};\n\n return (\n <div\n ref={bladeRef}\n id={idProp}\n className={cx(classes.root, className, {\n [classes.fullWidth]: fullWidth,\n [classes.expanded]: isExpanded,\n })}\n {...others}\n >\n {bladeHeader}\n <div\n id={bladeContainerId}\n role=\"region\"\n aria-labelledby={bladeHeaderId}\n className={classes.container}\n hidden={!isExpanded}\n style={{\n ...containerStyle,\n maxWidth: isExpanded ? maxWidthRef.current : 0,\n }}\n {...otherContainerProps}\n >\n {children}\n </div>\n </div>\n );\n};\n"],"names":["useDefaultProps","useClasses","useControlled","useCallback","useUniqueId","setId","useMemo","jsx","HvTypography","React","useEffect","jsxs"],"mappings":";;;;;;;;AA4Ga,MAAA,UAAU,CAAC,UAAwB;AACxC,QAAA;AAAA,IACJ,IAAI;AAAA,IACJ;AAAA,IACA,SAAS;AAAA,IACT;AAAA,IACA,kBAAkB;AAAA,IAClB;AAAA,IACA,eAAe;AAAA,IACf;AAAA,IACA;AAAA,IACA,WAAW;AAAA,IACX;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,GAAG;AAAA,EAAA,IACDA,eAAgB,gBAAA,WAAW,KAAK;AAEpC,QAAM,EAAE,SAAS,GAAG,IAAIC,wBAAW,WAAW;AAExC,QAAA,CAAC,YAAY,aAAa,IAAIC,eAAA;AAAA,IAClC;AAAA,IACA,QAAQ,eAAe;AAAA,EAAA;AAGzB,QAAM,eAAeC,MAAA;AAAA,IACnB,CAAC,UAA0B;AACzB,UAAI,CAAC,UAAU;AACF,mBAAA,OAAO,CAAC,UAAU;AAG7B,sBAAc,CAAC,UAAU;AAElB,eAAA;AAAA,MACT;AACO,aAAA;AAAA,IACT;AAAA,IACA,CAAC,UAAU,UAAU,YAAY,aAAa;AAAA,EAAA;AAGhD,QAAM,cAAcA,MAAA;AAAA,IAClB,CAAC,UAA0B;AACzB,mBAAa,KAAK;AAClB,YAAM,eAAe;AACrB,YAAM,gBAAgB;AAAA,IACxB;AAAA,IACA,CAAC,YAAY;AAAA,EAAA;AAGf,QAAM,gBAAgBA,MAAA;AAAA,IACpB,CAAC,UAA+C;AAC9C,UAAI,iBAAiB;AACf,YAAA,EAAE,IAAQ,IAAA;AAGd,UAAA,MAAM,UACN,MAAM,WACN,MAAM,WACN,MAAM,kBAAkB,MAAM,QAC9B;AACA;AAAA,MACF;AACA,cAAQ,KAAK;AAAA,QACX,KAAK;AAAA,QACL,KAAK;AACH,2BAAiB,aAAa,KAAK;AACnC;AAAA,QACF;AACE;AAAA,MACJ;AAEA,UAAI,gBAAgB;AAClB,cAAM,eAAe;AACrB,cAAM,gBAAgB;AAAA,MACxB;AAAA,IACF;AAAA,IACA,CAAC,YAAY;AAAA,EAAA;AAGT,QAAA,KAAKC,eAAAA,YAAY,QAAQ,SAAS;AAClC,QAAA,gBAAgBC,eAAAA,MAAM,IAAI,QAAQ;AAClC,QAAA,mBAAmBA,eAAAA,MAAM,IAAI,WAAW;AACxC,QAAA,cAAcC,MAAAA,QAAQ,MAAM;AAChC,UAAM,cAAc,OAAO,UAAU,aAAa,MAAM,UAAU,IAAI;AAEtE,UAAM,cACJC,2BAAA;AAAA,MAACC,eAAA;AAAA,MAAA;AAAA,QACC,IAAI;AAAA,QACJ,WAAU;AAAA,QACV,MAAK;AAAA,QACL,WAAW,GAAG,QAAQ,QAAQ;AAAA,UAC5B,CAAC,QAAQ,QAAQ,GAAG;AAAA,UACpB,CAAC,QAAQ,aAAa,GAAG,OAAO,gBAAgB;AAAA,QAAA,CACjD;AAAA,QACD,OAAO,EAAE,YAAY,iBAAiB,SAAY,IAAI,OAAU;AAAA,QAChE;AAAA,QACA,UAAU;AAAA,QACV,WAAW;AAAA,QACX,SAAS;AAAA,QACT,SAAS;AAAA,QACT,iBAAe;AAAA,QACf,iBAAe;AAAA,QACd,GAAG;AAAA,QAEH,UAAA;AAAA,MAAA;AAAA,IAAA;AAGE,WAAA,iBAAiB,SACtB,cAEAD,2BAAA;AAAA,MAACC,eAAA;AAAA,MAAA;AAAA,QACC,WAAW,IAAI,YAAY;AAAA,QAC3B,SAAS;AAAA,QACT,WAAW,QAAQ;AAAA,QACnB,OAAO,EAAE,YAAY,EAAE;AAAA,QAEtB,UAAA;AAAA,MAAA;AAAA,IAAA;AAAA,EACH,GAED;AAAA,IACD;AAAA,IACA;AAAA,IACA;AAAA,IACA,QAAQ;AAAA,IACR,QAAQ;AAAA,IACR,QAAQ;AAAA,IACR,QAAQ;AAAA,IACR;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EAAA,CACD;AAEK,QAAA,WAAWC,eAAAA,QAAM,OAAuB,IAAI;AAC5C,QAAA,cAAcA,eAAAA,QAAM,OAAe,CAAC;AAC1CC,QAAAA,UAAU,MAAM;AACd,QAAI,SAAS,SAAS;AACpB,kBAAY,UAAU,SAAS,QAAQ,eAAe,eAAe;AAAA,IACvE;AAAA,EACF,GAAG,CAAE,CAAA;AAEL,QAAM,EAAE,OAAO,gBAAgB,GAAG,oBAAoB,IACpD,kBAAkB;AAGlB,SAAAC,2BAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,KAAK;AAAA,MACL,IAAI;AAAA,MACJ,WAAW,GAAG,QAAQ,MAAM,WAAW;AAAA,QACrC,CAAC,QAAQ,SAAS,GAAG;AAAA,QACrB,CAAC,QAAQ,QAAQ,GAAG;AAAA,MAAA,CACrB;AAAA,MACA,GAAG;AAAA,MAEH,UAAA;AAAA,QAAA;AAAA,QACDJ,2BAAA;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,IAAI;AAAA,YACJ,MAAK;AAAA,YACL,mBAAiB;AAAA,YACjB,WAAW,QAAQ;AAAA,YACnB,QAAQ,CAAC;AAAA,YACT,OAAO;AAAA,cACL,GAAG;AAAA,cACH,UAAU,aAAa,YAAY,UAAU;AAAA,YAC/C;AAAA,YACC,GAAG;AAAA,YAEH;AAAA,UAAA;AAAA,QACH;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAGN;;;"}
@@ -0,0 +1,72 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const uikitReactCore = require("@hitachivantara/uikit-react-core");
4
+ const uikitStyles = require("@hitachivantara/uikit-styles");
5
+ const { staticClasses, useClasses } = uikitReactCore.createClasses("HvBlade", {
6
+ root: {
7
+ position: "relative",
8
+ display: "flex",
9
+ minWidth: 72,
10
+ "& + $root": {
11
+ marginLeft: uikitStyles.theme.spacing("sm")
12
+ },
13
+ transition: "flex-grow 600ms linear",
14
+ zIndex: 0,
15
+ color: uikitStyles.theme.colors.secondary,
16
+ backgroundColor: uikitStyles.theme.colors.atmo1,
17
+ borderRadius: uikitStyles.theme.radii.round,
18
+ border: `1px solid ${uikitStyles.theme.colors.atmo4}`
19
+ },
20
+ expanded: {},
21
+ fullWidth: {
22
+ flexGrow: 0,
23
+ "&$expanded": {
24
+ flexGrow: 1
25
+ }
26
+ },
27
+ heading: {},
28
+ button: {
29
+ height: "100%",
30
+ minWidth: 70,
31
+ "&[disabled], &:active": {
32
+ outline: "none"
33
+ },
34
+ "&:focus": {
35
+ outline: "none",
36
+ background: uikitStyles.theme.colors.containerBackgroundHover
37
+ },
38
+ "&:hover": {
39
+ background: uikitStyles.theme.colors.containerBackgroundHover
40
+ },
41
+ "&:focus-visible": {
42
+ ...uikitReactCore.outlineStyles,
43
+ zIndex: 1
44
+ },
45
+ cursor: "pointer"
46
+ },
47
+ textOnlyLabel: {
48
+ padding: uikitStyles.theme.spacing("xs", "sm")
49
+ },
50
+ container: {
51
+ display: "inline-block",
52
+ height: "100%",
53
+ width: "100%",
54
+ minWidth: 0,
55
+ overflowX: "hidden",
56
+ maxWidth: 0,
57
+ transition: "max-width 600ms linear"
58
+ },
59
+ disabled: {
60
+ cursor: "not-allowed",
61
+ color: uikitStyles.theme.colors.secondary_60,
62
+ "&:focus": {
63
+ background: "none"
64
+ },
65
+ "&:hover": {
66
+ background: "none"
67
+ }
68
+ }
69
+ });
70
+ exports.staticClasses = staticClasses;
71
+ exports.useClasses = useClasses;
72
+ //# sourceMappingURL=Blade.styles.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Blade.styles.cjs","sources":["../../../src/Blade/Blade.styles.tsx"],"sourcesContent":["import { createClasses, outlineStyles } from \"@hitachivantara/uikit-react-core\";\nimport { theme } from \"@hitachivantara/uikit-styles\";\n\nexport const { staticClasses, useClasses } = createClasses(\"HvBlade\", {\n root: {\n position: \"relative\",\n\n display: \"flex\",\n minWidth: 72,\n\n \"& + $root\": {\n marginLeft: theme.spacing(\"sm\"),\n },\n\n transition: \"flex-grow 600ms linear\",\n\n zIndex: 0,\n\n color: theme.colors.secondary,\n backgroundColor: theme.colors.atmo1,\n borderRadius: theme.radii.round,\n border: `1px solid ${theme.colors.atmo4}`,\n },\n expanded: {},\n\n fullWidth: {\n flexGrow: 0,\n\n \"&$expanded\": {\n flexGrow: 1,\n },\n },\n\n heading: {},\n\n button: {\n height: \"100%\",\n minWidth: 70,\n\n \"&[disabled], &:active\": {\n outline: \"none\",\n },\n\n \"&:focus\": {\n outline: \"none\",\n background: theme.colors.containerBackgroundHover,\n },\n\n \"&:hover\": {\n background: theme.colors.containerBackgroundHover,\n },\n\n \"&:focus-visible\": {\n ...outlineStyles,\n zIndex: 1,\n },\n\n cursor: \"pointer\",\n },\n textOnlyLabel: {\n padding: theme.spacing(\"xs\", \"sm\"),\n },\n\n container: {\n display: \"inline-block\",\n height: \"100%\",\n width: \"100%\",\n\n minWidth: 0,\n\n overflowX: \"hidden\",\n\n maxWidth: 0,\n transition: \"max-width 600ms linear\",\n },\n\n disabled: {\n cursor: \"not-allowed\",\n color: theme.colors.secondary_60,\n\n \"&:focus\": {\n background: \"none\",\n },\n\n \"&:hover\": {\n background: \"none\",\n },\n },\n});\n"],"names":["createClasses","theme","outlineStyles"],"mappings":";;;;AAGO,MAAM,EAAE,eAAe,eAAeA,eAAAA,cAAc,WAAW;AAAA,EACpE,MAAM;AAAA,IACJ,UAAU;AAAA,IAEV,SAAS;AAAA,IACT,UAAU;AAAA,IAEV,aAAa;AAAA,MACX,YAAYC,YAAAA,MAAM,QAAQ,IAAI;AAAA,IAChC;AAAA,IAEA,YAAY;AAAA,IAEZ,QAAQ;AAAA,IAER,OAAOA,YAAAA,MAAM,OAAO;AAAA,IACpB,iBAAiBA,YAAAA,MAAM,OAAO;AAAA,IAC9B,cAAcA,YAAAA,MAAM,MAAM;AAAA,IAC1B,QAAQ,aAAaA,YAAM,MAAA,OAAO,KAAK;AAAA,EACzC;AAAA,EACA,UAAU,CAAC;AAAA,EAEX,WAAW;AAAA,IACT,UAAU;AAAA,IAEV,cAAc;AAAA,MACZ,UAAU;AAAA,IACZ;AAAA,EACF;AAAA,EAEA,SAAS,CAAC;AAAA,EAEV,QAAQ;AAAA,IACN,QAAQ;AAAA,IACR,UAAU;AAAA,IAEV,yBAAyB;AAAA,MACvB,SAAS;AAAA,IACX;AAAA,IAEA,WAAW;AAAA,MACT,SAAS;AAAA,MACT,YAAYA,YAAAA,MAAM,OAAO;AAAA,IAC3B;AAAA,IAEA,WAAW;AAAA,MACT,YAAYA,YAAAA,MAAM,OAAO;AAAA,IAC3B;AAAA,IAEA,mBAAmB;AAAA,MACjB,GAAGC,eAAA;AAAA,MACH,QAAQ;AAAA,IACV;AAAA,IAEA,QAAQ;AAAA,EACV;AAAA,EACA,eAAe;AAAA,IACb,SAASD,YAAA,MAAM,QAAQ,MAAM,IAAI;AAAA,EACnC;AAAA,EAEA,WAAW;AAAA,IACT,SAAS;AAAA,IACT,QAAQ;AAAA,IACR,OAAO;AAAA,IAEP,UAAU;AAAA,IAEV,WAAW;AAAA,IAEX,UAAU;AAAA,IACV,YAAY;AAAA,EACd;AAAA,EAEA,UAAU;AAAA,IACR,QAAQ;AAAA,IACR,OAAOA,YAAAA,MAAM,OAAO;AAAA,IAEpB,WAAW;AAAA,MACT,YAAY;AAAA,IACd;AAAA,IAEA,WAAW;AAAA,MACT,YAAY;AAAA,IACd;AAAA,EACF;AACF,CAAC;;;"}
@@ -0,0 +1,105 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("@emotion/react/jsx-runtime");
4
+ const React = require("react");
5
+ const uikitReactCore = require("@hitachivantara/uikit-react-core");
6
+ const Blades_styles = require("./Blades.styles.cjs");
7
+ function getExpandedBlades(defaultExpanded, children, atMostOneExpanded, atLeastOneExpanded) {
8
+ const childrenArray = React.Children.toArray(children);
9
+ const expandedBlades = defaultExpanded ?? childrenArray.map((child, i) => {
10
+ const childIsControlled = child?.props?.expanded !== void 0;
11
+ const childIsExpanded = childIsControlled ? child?.props?.expanded : child?.props?.defaultExpanded;
12
+ return childIsExpanded ? i : void 0;
13
+ }).filter((v) => v !== void 0);
14
+ const numberOfExpandedBlades = expandedBlades.length;
15
+ if (atLeastOneExpanded && numberOfExpandedBlades === 0 && childrenArray.length > 0) {
16
+ return [0];
17
+ }
18
+ if (atMostOneExpanded && numberOfExpandedBlades > 1) {
19
+ return [expandedBlades[0]];
20
+ }
21
+ return expandedBlades;
22
+ }
23
+ const HvBlades = (props) => {
24
+ const {
25
+ id,
26
+ className,
27
+ classes: classesProp,
28
+ children,
29
+ expanded: expandedProp,
30
+ defaultExpanded,
31
+ atMostOneExpanded = false,
32
+ atLeastOneExpanded = false,
33
+ fullWidthBlades = false,
34
+ onChange,
35
+ ...others
36
+ } = uikitReactCore.useDefaultProps("HvBlades", props);
37
+ const { classes, cx } = Blades_styles.useClasses(classesProp);
38
+ const [expanded, setExpanded] = uikitReactCore.useControlled(
39
+ expandedProp,
40
+ () => getExpandedBlades(
41
+ defaultExpanded,
42
+ children,
43
+ atMostOneExpanded,
44
+ atLeastOneExpanded
45
+ )
46
+ );
47
+ const onChildChangeInterceptor = React.useCallback(
48
+ (index, childOnChange, event, isExpanded) => {
49
+ const newValue = [];
50
+ if (atMostOneExpanded) {
51
+ if (isExpanded) {
52
+ newValue.push(index);
53
+ }
54
+ } else {
55
+ newValue.push(...expanded);
56
+ if (isExpanded) {
57
+ newValue.push(index);
58
+ } else {
59
+ newValue.splice(newValue.indexOf(index), 1);
60
+ }
61
+ }
62
+ if (atLeastOneExpanded && newValue.length === 0) {
63
+ newValue.push(index);
64
+ }
65
+ childOnChange?.(event, isExpanded);
66
+ onChange?.(event, newValue);
67
+ setExpanded(newValue);
68
+ },
69
+ [onChange, expanded, setExpanded, atMostOneExpanded, atLeastOneExpanded]
70
+ );
71
+ const modifiedChildren = React.useMemo(() => {
72
+ return React.Children.map(children, (child, i) => {
73
+ const childIsExpanded = expanded.includes(i);
74
+ return React.cloneElement(child, {
75
+ expanded: childIsExpanded,
76
+ fullWidth: child?.props?.fullWidth ?? fullWidthBlades,
77
+ buttonProps: {
78
+ ...child?.props?.buttonProps,
79
+ "aria-disabled": (
80
+ // If the accordion panel associated with an accordion header is visible,
81
+ // and if the accordion does not permit the panel to be collapsed, the header
82
+ // button element has aria-disabled set to true.
83
+ child?.props?.disabled || childIsExpanded && atMostOneExpanded && expanded.length === 1 ? true : void 0
84
+ )
85
+ },
86
+ onChange: (event, isExpanded) => onChildChangeInterceptor(
87
+ i,
88
+ child?.props?.onChange,
89
+ event,
90
+ isExpanded
91
+ )
92
+ });
93
+ });
94
+ }, [
95
+ children,
96
+ expanded,
97
+ fullWidthBlades,
98
+ atMostOneExpanded,
99
+ onChildChangeInterceptor
100
+ ]);
101
+ return /* @__PURE__ */ jsxRuntime.jsx("div", { id, className: cx(classes.root, className), ...others, children: modifiedChildren });
102
+ };
103
+ exports.bladesClasses = Blades_styles.staticClasses;
104
+ exports.HvBlades = HvBlades;
105
+ //# sourceMappingURL=Blades.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Blades.cjs","sources":["../../../src/Blades/Blades.tsx"],"sourcesContent":["import React, {\n SyntheticEvent,\n useCallback,\n useMemo,\n Children,\n cloneElement,\n} from \"react\";\n\nimport {\n ExtractNames,\n HvBaseProps,\n useDefaultProps,\n useControlled,\n} from \"@hitachivantara/uikit-react-core\";\n\nimport { staticClasses, useClasses } from \"./Blades.styles\";\n\nexport { staticClasses as bladesClasses };\n\nexport type HvBladesClasses = ExtractNames<typeof useClasses>;\n\nexport interface HvBladesProps\n extends HvBaseProps<HTMLDivElement, \"onChange\" | \"children\"> {\n /**\n * Array of indices representing the expanded state of each blade.\n *\n * When defined, the expanded state of the blades becomes controlled.\n */\n expanded?: number[];\n /**\n * Initial expanded state of the blades when in an uncontrolled state.\n *\n * It's an array of indices representing the blades that should be initially expanded.\n */\n defaultExpanded?: number[];\n\n /**\n * If true, ensures that only one blade can be expanded at a time.\n */\n atMostOneExpanded?: boolean;\n /**\n * If true, ensures that at least one blade is always expanded.\n */\n atLeastOneExpanded?: boolean;\n\n /**\n * If true, the blades will take up the full width of the container by default.\n */\n fullWidthBlades?: boolean;\n\n /**\n * Callback function triggered when the expanded state of any blade changes.\n * It receives the event and the new array of expanded indices as arguments.\n *\n * If uncontrolled, this new state will be effective.\n * If controlled, it is up to the parent component to manage this state.\n *\n * @param {SyntheticEvent} event The event source of the callback.\n * @param {number[]} value Array of indices of the blades that are expanded.\n */\n onChange?: (event: SyntheticEvent, value: number[]) => void;\n\n /**\n * The blades to be rendered within the group.\n * Must be instances of `HvBlade`, otherwise the behavior is undefined and will most likely break.\n */\n children: React.ReactNode;\n /**\n * A Jss Object used to override or extend the styles applied.\n */\n classes?: HvBladesClasses;\n}\n\nfunction getExpandedBlades(\n defaultExpanded: number[] | undefined,\n children: React.ReactNode,\n atMostOneExpanded: boolean,\n atLeastOneExpanded: boolean\n) {\n const childrenArray = Children.toArray(children);\n const expandedBlades =\n defaultExpanded ??\n childrenArray\n .map((child: any, i: number) => {\n const childIsControlled = child?.props?.expanded !== undefined;\n const childIsExpanded = childIsControlled\n ? child?.props?.expanded\n : child?.props?.defaultExpanded;\n\n return childIsExpanded ? i : undefined;\n })\n .filter((v) => v !== undefined);\n\n const numberOfExpandedBlades = expandedBlades.length;\n if (\n atLeastOneExpanded &&\n numberOfExpandedBlades === 0 &&\n childrenArray.length > 0\n ) {\n return [0];\n }\n if (atMostOneExpanded && numberOfExpandedBlades > 1) {\n return [expandedBlades[0]];\n }\n\n return expandedBlades;\n}\n\n/**\n * `HvBlades` is a component that groups multiple `HvBlade` components.\n *\n * It allows for better control over the expanded state of blades, suitable for both\n * controlled and uncontrolled scenarios.\n */\nexport const HvBlades = (props: HvBladesProps) => {\n const {\n id,\n className,\n classes: classesProp,\n children,\n expanded: expandedProp,\n defaultExpanded,\n atMostOneExpanded = false,\n atLeastOneExpanded = false,\n fullWidthBlades = false,\n onChange,\n ...others\n } = useDefaultProps(\"HvBlades\", props);\n\n const { classes, cx } = useClasses(classesProp);\n\n const [expanded, setExpanded] = useControlled(expandedProp, () =>\n getExpandedBlades(\n defaultExpanded,\n children,\n atMostOneExpanded,\n atLeastOneExpanded\n )\n );\n\n const onChildChangeInterceptor = useCallback(\n (\n index: number,\n childOnChange: (event: SyntheticEvent, isExpanded: boolean) => void,\n event: SyntheticEvent,\n isExpanded: boolean\n ) => {\n const newValue: number[] = [];\n if (atMostOneExpanded) {\n if (isExpanded) {\n newValue.push(index);\n }\n } else {\n newValue.push(...expanded);\n if (isExpanded) {\n newValue.push(index);\n } else {\n newValue.splice(newValue.indexOf(index), 1);\n }\n }\n\n if (atLeastOneExpanded && newValue.length === 0) {\n newValue.push(index);\n }\n\n childOnChange?.(event, isExpanded);\n\n onChange?.(event, newValue);\n\n // This will only run if uncontrolled\n setExpanded(newValue);\n },\n [onChange, expanded, setExpanded, atMostOneExpanded, atLeastOneExpanded]\n );\n\n const modifiedChildren = useMemo(() => {\n return Children.map(children, (child: any, i: number) => {\n const childIsExpanded = expanded.includes(i);\n\n return cloneElement(child, {\n expanded: childIsExpanded,\n fullWidth: child?.props?.fullWidth ?? fullWidthBlades,\n buttonProps: {\n ...child?.props?.buttonProps,\n \"aria-disabled\":\n // If the accordion panel associated with an accordion header is visible,\n // and if the accordion does not permit the panel to be collapsed, the header\n // button element has aria-disabled set to true.\n child?.props?.disabled ||\n (childIsExpanded && atMostOneExpanded && expanded.length === 1)\n ? true\n : undefined,\n },\n onChange: (\n event: React.ChangeEvent<HTMLInputElement>,\n isExpanded: boolean\n ) =>\n onChildChangeInterceptor(\n i,\n child?.props?.onChange,\n event,\n isExpanded\n ),\n });\n });\n }, [\n children,\n expanded,\n fullWidthBlades,\n atMostOneExpanded,\n onChildChangeInterceptor,\n ]);\n\n return (\n <div id={id} className={cx(classes.root, className)} {...others}>\n {modifiedChildren}\n </div>\n );\n};\n"],"names":["Children","useDefaultProps","useClasses","useControlled","useCallback","useMemo","cloneElement","jsx"],"mappings":";;;;;;AAyEA,SAAS,kBACP,iBACA,UACA,mBACA,oBACA;AACM,QAAA,gBAAgBA,MAAAA,SAAS,QAAQ,QAAQ;AAC/C,QAAM,iBACJ,mBACA,cACG,IAAI,CAAC,OAAY,MAAc;AACxB,UAAA,oBAAoB,OAAO,OAAO,aAAa;AACrD,UAAM,kBAAkB,oBACpB,OAAO,OAAO,WACd,OAAO,OAAO;AAElB,WAAO,kBAAkB,IAAI;AAAA,EAAA,CAC9B,EACA,OAAO,CAAC,MAAM,MAAM,MAAS;AAElC,QAAM,yBAAyB,eAAe;AAC9C,MACE,sBACA,2BAA2B,KAC3B,cAAc,SAAS,GACvB;AACA,WAAO,CAAC,CAAC;AAAA,EACX;AACI,MAAA,qBAAqB,yBAAyB,GAAG;AAC5C,WAAA,CAAC,eAAe,CAAC,CAAC;AAAA,EAC3B;AAEO,SAAA;AACT;AAQa,MAAA,WAAW,CAAC,UAAyB;AAC1C,QAAA;AAAA,IACJ;AAAA,IACA;AAAA,IACA,SAAS;AAAA,IACT;AAAA,IACA,UAAU;AAAA,IACV;AAAA,IACA,oBAAoB;AAAA,IACpB,qBAAqB;AAAA,IACrB,kBAAkB;AAAA,IAClB;AAAA,IACA,GAAG;AAAA,EAAA,IACDC,eAAgB,gBAAA,YAAY,KAAK;AAErC,QAAM,EAAE,SAAS,GAAG,IAAIC,yBAAW,WAAW;AAExC,QAAA,CAAC,UAAU,WAAW,IAAIC,eAAA;AAAA,IAAc;AAAA,IAAc,MAC1D;AAAA,MACE;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IACF;AAAA,EAAA;AAGF,QAAM,2BAA2BC,MAAA;AAAA,IAC/B,CACE,OACA,eACA,OACA,eACG;AACH,YAAM,WAAqB,CAAA;AAC3B,UAAI,mBAAmB;AACrB,YAAI,YAAY;AACd,mBAAS,KAAK,KAAK;AAAA,QACrB;AAAA,MAAA,OACK;AACI,iBAAA,KAAK,GAAG,QAAQ;AACzB,YAAI,YAAY;AACd,mBAAS,KAAK,KAAK;AAAA,QAAA,OACd;AACL,mBAAS,OAAO,SAAS,QAAQ,KAAK,GAAG,CAAC;AAAA,QAC5C;AAAA,MACF;AAEI,UAAA,sBAAsB,SAAS,WAAW,GAAG;AAC/C,iBAAS,KAAK,KAAK;AAAA,MACrB;AAEA,sBAAgB,OAAO,UAAU;AAEjC,iBAAW,OAAO,QAAQ;AAG1B,kBAAY,QAAQ;AAAA,IACtB;AAAA,IACA,CAAC,UAAU,UAAU,aAAa,mBAAmB,kBAAkB;AAAA,EAAA;AAGnE,QAAA,mBAAmBC,MAAAA,QAAQ,MAAM;AACrC,WAAOL,MAAS,SAAA,IAAI,UAAU,CAAC,OAAY,MAAc;AACjD,YAAA,kBAAkB,SAAS,SAAS,CAAC;AAE3C,aAAOM,MAAAA,aAAa,OAAO;AAAA,QACzB,UAAU;AAAA,QACV,WAAW,OAAO,OAAO,aAAa;AAAA,QACtC,aAAa;AAAA,UACX,GAAG,OAAO,OAAO;AAAA,UACjB;AAAA;AAAA;AAAA;AAAA,YAIE,OAAO,OAAO,YACb,mBAAmB,qBAAqB,SAAS,WAAW,IACzD,OACA;AAAA;AAAA,QACR;AAAA,QACA,UAAU,CACR,OACA,eAEA;AAAA,UACE;AAAA,UACA,OAAO,OAAO;AAAA,UACd;AAAA,UACA;AAAA,QACF;AAAA,MAAA,CACH;AAAA,IAAA,CACF;AAAA,EAAA,GACA;AAAA,IACD;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EAAA,CACD;AAGC,SAAAC,2BAAA,IAAC,OAAI,EAAA,IAAQ,WAAW,GAAG,QAAQ,MAAM,SAAS,GAAI,GAAG,QACtD,UACH,iBAAA,CAAA;AAEJ;;;"}
@@ -0,0 +1,12 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const uikitReactCore = require("@hitachivantara/uikit-react-core");
4
+ const { staticClasses, useClasses } = uikitReactCore.createClasses("HvBlades", {
5
+ root: {
6
+ position: "relative",
7
+ display: "flex"
8
+ }
9
+ });
10
+ exports.staticClasses = staticClasses;
11
+ exports.useClasses = useClasses;
12
+ //# sourceMappingURL=Blades.styles.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Blades.styles.cjs","sources":["../../../src/Blades/Blades.styles.tsx"],"sourcesContent":["import { createClasses } from \"@hitachivantara/uikit-react-core\";\n\nexport const { staticClasses, useClasses } = createClasses(\"HvBlades\", {\n root: {\n position: \"relative\",\n\n display: \"flex\",\n },\n});\n"],"names":["createClasses"],"mappings":";;;AAEO,MAAM,EAAE,eAAe,eAAeA,eAAAA,cAAc,YAAY;AAAA,EACrE,MAAM;AAAA,IACJ,UAAU;AAAA,IAEV,SAAS;AAAA,EACX;AACF,CAAC;;;"}
@@ -11,18 +11,18 @@ const Select = ({ nodeId, param, data }) => {
11
11
  data[id] ? Array.isArray(data[id]) ? data[id] : [data[id]] : void 0
12
12
  );
13
13
  const onSelectChange = (item) => {
14
- const nodes = reactFlowInstance.getNodes();
15
14
  const newOpts = Array.isArray(item) ? item.map((x) => x.label) : item?.label ?? void 0;
16
- const newNodes = nodes.map((node) => {
17
- if (node.id === nodeId) {
18
- node.data = {
19
- ...node.data,
20
- [id]: newOpts
21
- };
22
- }
23
- return node;
24
- });
25
- reactFlowInstance.setNodes(newNodes);
15
+ reactFlowInstance.setNodes(
16
+ (nodes) => nodes.map((node) => {
17
+ if (node.id === nodeId) {
18
+ node.data = {
19
+ ...node.data,
20
+ [id]: newOpts
21
+ };
22
+ }
23
+ return node;
24
+ })
25
+ );
26
26
  setOpts(
27
27
  newOpts ? Array.isArray(newOpts) ? newOpts : [newOpts] : void 0
28
28
  );
@@ -1 +1 @@
1
- {"version":3,"file":"Select.cjs","sources":["../../../../../src/Flow/Node/Parameters/Select.tsx"],"sourcesContent":["import { useState } from \"react\";\nimport { HvDropdown, HvDropdownProps } from \"@hitachivantara/uikit-react-core\";\nimport { useReactFlow } from \"reactflow\";\n\nimport { HvFlowNodeSelectParam } from \"../../types\";\n\ninterface SelectProps {\n nodeId: string;\n param: Omit<HvFlowNodeSelectParam, \"type\">;\n data: any;\n}\n\nconst Select = ({ nodeId, param, data }: SelectProps) => {\n const { id, label, multiple = false, options } = param;\n\n const reactFlowInstance = useReactFlow();\n\n const [opts, setOpts] = useState<string[] | undefined>(\n data[id] ? (Array.isArray(data[id]) ? data[id] : [data[id]]) : undefined\n );\n\n const onSelectChange: HvDropdownProps[\"onChange\"] = (item) => {\n const nodes = reactFlowInstance.getNodes();\n\n const newOpts = Array.isArray(item)\n ? item.map((x) => x.label as string)\n : (item?.label as string) ?? undefined;\n\n const newNodes = nodes.map((node) => {\n if (node.id === nodeId) {\n node.data = {\n ...node.data,\n [id]: newOpts,\n };\n }\n return node;\n });\n\n reactFlowInstance.setNodes(newNodes);\n setOpts(\n newOpts ? (Array.isArray(newOpts) ? newOpts : [newOpts]) : undefined\n );\n };\n\n return (\n <HvDropdown\n className=\"nodrag\" // Prevents dragging within the select field\n disablePortal\n label={label}\n values={options?.map((o) => {\n return { id: o, label: o, selected: !!opts?.find((opt) => opt === o) };\n })}\n onChange={onSelectChange}\n maxHeight={100}\n multiSelect={multiple}\n />\n );\n};\n\nexport default Select;\n"],"names":["useReactFlow","useState","jsx","HvDropdown"],"mappings":";;;;;;AAYA,MAAM,SAAS,CAAC,EAAE,QAAQ,OAAO,WAAwB;AACvD,QAAM,EAAE,IAAI,OAAO,WAAW,OAAO,QAAY,IAAA;AAEjD,QAAM,oBAAoBA,UAAAA;AAEpB,QAAA,CAAC,MAAM,OAAO,IAAIC,MAAA;AAAA,IACtB,KAAK,EAAE,IAAK,MAAM,QAAQ,KAAK,EAAE,CAAC,IAAI,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,IAAK;AAAA,EAAA;AAG3D,QAAA,iBAA8C,CAAC,SAAS;AACtD,UAAA,QAAQ,kBAAkB;AAEhC,UAAM,UAAU,MAAM,QAAQ,IAAI,IAC9B,KAAK,IAAI,CAAC,MAAM,EAAE,KAAe,IAChC,MAAM,SAAoB;AAE/B,UAAM,WAAW,MAAM,IAAI,CAAC,SAAS;AAC/B,UAAA,KAAK,OAAO,QAAQ;AACtB,aAAK,OAAO;AAAA,UACV,GAAG,KAAK;AAAA,UACR,CAAC,EAAE,GAAG;AAAA,QAAA;AAAA,MAEV;AACO,aAAA;AAAA,IAAA,CACR;AAED,sBAAkB,SAAS,QAAQ;AACnC;AAAA,MACE,UAAW,MAAM,QAAQ,OAAO,IAAI,UAAU,CAAC,OAAO,IAAK;AAAA,IAAA;AAAA,EAC7D;AAIA,SAAAC,2BAAA;AAAA,IAACC,eAAA;AAAA,IAAA;AAAA,MACC,WAAU;AAAA,MACV,eAAa;AAAA,MACb;AAAA,MACA,QAAQ,SAAS,IAAI,CAAC,MAAM;AAC1B,eAAO,EAAE,IAAI,GAAG,OAAO,GAAG,UAAU,CAAC,CAAC,MAAM,KAAK,CAAC,QAAQ,QAAQ,CAAC,EAAE;AAAA,MAAA,CACtE;AAAA,MACD,UAAU;AAAA,MACV,WAAW;AAAA,MACX,aAAa;AAAA,IAAA;AAAA,EAAA;AAGnB;AAEA,MAAA,WAAe;;"}
1
+ {"version":3,"file":"Select.cjs","sources":["../../../../../src/Flow/Node/Parameters/Select.tsx"],"sourcesContent":["import { useState } from \"react\";\nimport { HvDropdown, HvDropdownProps } from \"@hitachivantara/uikit-react-core\";\nimport { useReactFlow } from \"reactflow\";\n\nimport { HvFlowNodeSelectParam } from \"../../types\";\n\ninterface SelectProps {\n nodeId: string;\n param: Omit<HvFlowNodeSelectParam, \"type\">;\n data: any;\n}\n\nconst Select = ({ nodeId, param, data }: SelectProps) => {\n const { id, label, multiple = false, options } = param;\n\n const reactFlowInstance = useReactFlow();\n\n const [opts, setOpts] = useState<string[] | undefined>(\n data[id] ? (Array.isArray(data[id]) ? data[id] : [data[id]]) : undefined\n );\n\n const onSelectChange: HvDropdownProps[\"onChange\"] = (item) => {\n const newOpts = Array.isArray(item)\n ? item.map((x) => x.label as string)\n : (item?.label as string) ?? undefined;\n\n reactFlowInstance.setNodes((nodes) =>\n nodes.map((node) => {\n if (node.id === nodeId) {\n node.data = {\n ...node.data,\n [id]: newOpts,\n };\n }\n return node;\n })\n );\n setOpts(\n newOpts ? (Array.isArray(newOpts) ? newOpts : [newOpts]) : undefined\n );\n };\n\n return (\n <HvDropdown\n className=\"nodrag\" // Prevents dragging within the select field\n disablePortal\n label={label}\n values={options?.map((o) => {\n return { id: o, label: o, selected: !!opts?.find((opt) => opt === o) };\n })}\n onChange={onSelectChange}\n maxHeight={100}\n multiSelect={multiple}\n />\n );\n};\n\nexport default Select;\n"],"names":["useReactFlow","useState","jsx","HvDropdown"],"mappings":";;;;;;AAYA,MAAM,SAAS,CAAC,EAAE,QAAQ,OAAO,WAAwB;AACvD,QAAM,EAAE,IAAI,OAAO,WAAW,OAAO,QAAY,IAAA;AAEjD,QAAM,oBAAoBA,UAAAA;AAEpB,QAAA,CAAC,MAAM,OAAO,IAAIC,MAAA;AAAA,IACtB,KAAK,EAAE,IAAK,MAAM,QAAQ,KAAK,EAAE,CAAC,IAAI,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,IAAK;AAAA,EAAA;AAG3D,QAAA,iBAA8C,CAAC,SAAS;AAC5D,UAAM,UAAU,MAAM,QAAQ,IAAI,IAC9B,KAAK,IAAI,CAAC,MAAM,EAAE,KAAe,IAChC,MAAM,SAAoB;AAEb,sBAAA;AAAA,MAAS,CAAC,UAC1B,MAAM,IAAI,CAAC,SAAS;AACd,YAAA,KAAK,OAAO,QAAQ;AACtB,eAAK,OAAO;AAAA,YACV,GAAG,KAAK;AAAA,YACR,CAAC,EAAE,GAAG;AAAA,UAAA;AAAA,QAEV;AACO,eAAA;AAAA,MAAA,CACR;AAAA,IAAA;AAEH;AAAA,MACE,UAAW,MAAM,QAAQ,OAAO,IAAI,UAAU,CAAC,OAAO,IAAK;AAAA,IAAA;AAAA,EAC7D;AAIA,SAAAC,2BAAA;AAAA,IAACC,eAAA;AAAA,IAAA;AAAA,MACC,WAAU;AAAA,MACV,eAAa;AAAA,MACb;AAAA,MACA,QAAQ,SAAS,IAAI,CAAC,MAAM;AAC1B,eAAO,EAAE,IAAI,GAAG,OAAO,GAAG,UAAU,CAAC,CAAC,MAAM,KAAK,CAAC,QAAQ,QAAQ,CAAC,EAAE;AAAA,MAAA,CACtE;AAAA,MACD,UAAU;AAAA,MACV,WAAW;AAAA,MACX,aAAa;AAAA,IAAA;AAAA,EAAA;AAGnB;AAEA,MAAA,WAAe;;"}
@@ -19,14 +19,14 @@ const Slider = ({ nodeId, param, data }) => {
19
19
  const reactFlowInstance = ReactFlow.useReactFlow();
20
20
  const [value, setValue] = React.useState(data[id]);
21
21
  const onSliderChange = (val) => {
22
- const nodes = reactFlowInstance.getNodes();
23
- const newNodes = nodes.map((node) => {
24
- if (node.id === nodeId) {
25
- node.data = { ...node.data, [id]: val };
26
- }
27
- return node;
28
- });
29
- reactFlowInstance.setNodes(newNodes);
22
+ reactFlowInstance.setNodes(
23
+ (nodes) => nodes.map((node) => {
24
+ if (node.id === nodeId) {
25
+ node.data = { ...node.data, [id]: val };
26
+ }
27
+ return node;
28
+ })
29
+ );
30
30
  setValue(val);
31
31
  };
32
32
  return /* @__PURE__ */ jsxRuntime.jsx(
@@ -1 +1 @@
1
- {"version":3,"file":"Slider.cjs","sources":["../../../../../src/Flow/Node/Parameters/Slider.tsx"],"sourcesContent":["import { useState } from \"react\";\n\nimport { css } from \"@emotion/css\";\n\nimport { useReactFlow } from \"reactflow\";\n\nimport { HvSlider, HvSliderProps } from \"@hitachivantara/uikit-react-core\";\n\nimport { HvFlowNodeSliderParam } from \"../../types\";\n\ninterface SliderProps {\n nodeId: string;\n param: Omit<HvFlowNodeSliderParam, \"type\">;\n data: any;\n}\n\nconst classes = {\n labelContainer: css({\n marginRight: 0,\n marginLeft: 0,\n }),\n sliderBase: css({\n padding: 0,\n }),\n};\n\nconst Slider = ({ nodeId, param, data }: SliderProps) => {\n const { id } = param;\n\n const reactFlowInstance = useReactFlow();\n\n const [value, setValue] = useState(data[id]);\n\n const onSliderChange: HvSliderProps[\"onChange\"] = (val) => {\n const nodes = reactFlowInstance.getNodes();\n const newNodes = nodes.map((node) => {\n if (node.id === nodeId) {\n node.data = { ...node.data, [id]: val };\n }\n return node;\n });\n reactFlowInstance.setNodes(newNodes);\n setValue(val);\n };\n\n return (\n <HvSlider\n className=\"nodrag\"\n defaultValues={value}\n onChange={onSliderChange}\n classes={{\n labelContainer: classes.labelContainer,\n sliderBase: classes.sliderBase,\n }}\n {...param}\n />\n );\n};\n\nexport default Slider;\n"],"names":["css","useReactFlow","useState","jsx","HvSlider"],"mappings":";;;;;;;AAgBA,MAAM,UAAU;AAAA,EACd,gBAAgBA,IAAAA,IAAI;AAAA,IAClB,aAAa;AAAA,IACb,YAAY;AAAA,EAAA,CACb;AAAA,EACD,YAAYA,IAAAA,IAAI;AAAA,IACd,SAAS;AAAA,EAAA,CACV;AACH;AAEA,MAAM,SAAS,CAAC,EAAE,QAAQ,OAAO,WAAwB;AACjD,QAAA,EAAE,GAAO,IAAA;AAEf,QAAM,oBAAoBC,UAAAA;AAE1B,QAAM,CAAC,OAAO,QAAQ,IAAIC,MAAS,SAAA,KAAK,EAAE,CAAC;AAErC,QAAA,iBAA4C,CAAC,QAAQ;AACnD,UAAA,QAAQ,kBAAkB;AAChC,UAAM,WAAW,MAAM,IAAI,CAAC,SAAS;AAC/B,UAAA,KAAK,OAAO,QAAQ;AACjB,aAAA,OAAO,EAAE,GAAG,KAAK,MAAM,CAAC,EAAE,GAAG;MACpC;AACO,aAAA;AAAA,IAAA,CACR;AACD,sBAAkB,SAAS,QAAQ;AACnC,aAAS,GAAG;AAAA,EAAA;AAIZ,SAAAC,2BAAA;AAAA,IAACC,eAAA;AAAA,IAAA;AAAA,MACC,WAAU;AAAA,MACV,eAAe;AAAA,MACf,UAAU;AAAA,MACV,SAAS;AAAA,QACP,gBAAgB,QAAQ;AAAA,QACxB,YAAY,QAAQ;AAAA,MACtB;AAAA,MACC,GAAG;AAAA,IAAA;AAAA,EAAA;AAGV;AAEA,MAAA,WAAe;;"}
1
+ {"version":3,"file":"Slider.cjs","sources":["../../../../../src/Flow/Node/Parameters/Slider.tsx"],"sourcesContent":["import { useState } from \"react\";\n\nimport { css } from \"@emotion/css\";\n\nimport { useReactFlow } from \"reactflow\";\n\nimport { HvSlider, HvSliderProps } from \"@hitachivantara/uikit-react-core\";\n\nimport { HvFlowNodeSliderParam } from \"../../types\";\n\ninterface SliderProps {\n nodeId: string;\n param: Omit<HvFlowNodeSliderParam, \"type\">;\n data: any;\n}\n\nconst classes = {\n labelContainer: css({\n marginRight: 0,\n marginLeft: 0,\n }),\n sliderBase: css({\n padding: 0,\n }),\n};\n\nconst Slider = ({ nodeId, param, data }: SliderProps) => {\n const { id } = param;\n\n const reactFlowInstance = useReactFlow();\n\n const [value, setValue] = useState(data[id]);\n\n const onSliderChange: HvSliderProps[\"onChange\"] = (val) => {\n reactFlowInstance.setNodes((nodes) =>\n nodes.map((node) => {\n if (node.id === nodeId) {\n node.data = { ...node.data, [id]: val };\n }\n return node;\n })\n );\n setValue(val);\n };\n\n return (\n <HvSlider\n className=\"nodrag\" // Prevents dragging within the input field\n defaultValues={value}\n onChange={onSliderChange}\n classes={{\n labelContainer: classes.labelContainer,\n sliderBase: classes.sliderBase,\n }}\n {...param}\n />\n );\n};\n\nexport default Slider;\n"],"names":["css","useReactFlow","useState","jsx","HvSlider"],"mappings":";;;;;;;AAgBA,MAAM,UAAU;AAAA,EACd,gBAAgBA,IAAAA,IAAI;AAAA,IAClB,aAAa;AAAA,IACb,YAAY;AAAA,EAAA,CACb;AAAA,EACD,YAAYA,IAAAA,IAAI;AAAA,IACd,SAAS;AAAA,EAAA,CACV;AACH;AAEA,MAAM,SAAS,CAAC,EAAE,QAAQ,OAAO,WAAwB;AACjD,QAAA,EAAE,GAAO,IAAA;AAEf,QAAM,oBAAoBC,UAAAA;AAE1B,QAAM,CAAC,OAAO,QAAQ,IAAIC,MAAS,SAAA,KAAK,EAAE,CAAC;AAErC,QAAA,iBAA4C,CAAC,QAAQ;AACvC,sBAAA;AAAA,MAAS,CAAC,UAC1B,MAAM,IAAI,CAAC,SAAS;AACd,YAAA,KAAK,OAAO,QAAQ;AACjB,eAAA,OAAO,EAAE,GAAG,KAAK,MAAM,CAAC,EAAE,GAAG;QACpC;AACO,eAAA;AAAA,MAAA,CACR;AAAA,IAAA;AAEH,aAAS,GAAG;AAAA,EAAA;AAIZ,SAAAC,2BAAA;AAAA,IAACC,eAAA;AAAA,IAAA;AAAA,MACC,WAAU;AAAA,MACV,eAAe;AAAA,MACf,UAAU;AAAA,MACV,SAAS;AAAA,QACP,gBAAgB,QAAQ;AAAA,QACxB,YAAY,QAAQ;AAAA,MACtB;AAAA,MACC,GAAG;AAAA,IAAA;AAAA,EAAA;AAGV;AAEA,MAAA,WAAe;;"}
@@ -9,14 +9,14 @@ const Text = ({ nodeId, param, data }) => {
9
9
  const reactFlowInstance = ReactFlow.useReactFlow();
10
10
  const [text, setText] = React.useState(data[id]);
11
11
  const onTextChange = (event, val) => {
12
- const nodes = reactFlowInstance.getNodes();
13
- const newNodes = nodes.map((node) => {
14
- if (node.id === nodeId) {
15
- node.data = { ...node.data, [id]: val };
16
- }
17
- return node;
18
- });
19
- reactFlowInstance.setNodes(newNodes);
12
+ reactFlowInstance.setNodes(
13
+ (nodes) => nodes.map((node) => {
14
+ if (node.id === nodeId) {
15
+ node.data = { ...node.data, [id]: val };
16
+ }
17
+ return node;
18
+ })
19
+ );
20
20
  setText(val);
21
21
  };
22
22
  return /* @__PURE__ */ jsxRuntime.jsx(
@@ -1 +1 @@
1
- {"version":3,"file":"Text.cjs","sources":["../../../../../src/Flow/Node/Parameters/Text.tsx"],"sourcesContent":["import { useState } from \"react\";\nimport { HvInput, HvInputProps } from \"@hitachivantara/uikit-react-core\";\nimport { useReactFlow } from \"reactflow\";\n\nimport { HvFlowNodeTextParam } from \"../../types\";\n\ninterface TextProps {\n nodeId: string;\n param: Omit<HvFlowNodeTextParam, \"type\">;\n data: any;\n}\n\nconst Text = ({ nodeId, param, data }: TextProps) => {\n const { id, label } = param;\n\n const reactFlowInstance = useReactFlow();\n\n const [text, setText] = useState(data[id]);\n\n const onTextChange: HvInputProps[\"onChange\"] = (event, val) => {\n const nodes = reactFlowInstance.getNodes();\n\n const newNodes = nodes.map((node) => {\n if (node.id === nodeId) {\n node.data = { ...node.data, [id]: val };\n }\n return node;\n });\n\n reactFlowInstance.setNodes(newNodes);\n setText(val);\n };\n\n return (\n <HvInput\n className=\"nodrag\" // Prevents dragging within the input field\n label={label}\n value={text}\n onChange={onTextChange}\n />\n );\n};\n\nexport default Text;\n"],"names":["useReactFlow","useState","jsx","HvInput"],"mappings":";;;;;;AAYA,MAAM,OAAO,CAAC,EAAE,QAAQ,OAAO,WAAsB;AAC7C,QAAA,EAAE,IAAI,MAAU,IAAA;AAEtB,QAAM,oBAAoBA,UAAAA;AAE1B,QAAM,CAAC,MAAM,OAAO,IAAIC,MAAS,SAAA,KAAK,EAAE,CAAC;AAEnC,QAAA,eAAyC,CAAC,OAAO,QAAQ;AACvD,UAAA,QAAQ,kBAAkB;AAEhC,UAAM,WAAW,MAAM,IAAI,CAAC,SAAS;AAC/B,UAAA,KAAK,OAAO,QAAQ;AACjB,aAAA,OAAO,EAAE,GAAG,KAAK,MAAM,CAAC,EAAE,GAAG;MACpC;AACO,aAAA;AAAA,IAAA,CACR;AAED,sBAAkB,SAAS,QAAQ;AACnC,YAAQ,GAAG;AAAA,EAAA;AAIX,SAAAC,2BAAA;AAAA,IAACC,eAAA;AAAA,IAAA;AAAA,MACC,WAAU;AAAA,MACV;AAAA,MACA,OAAO;AAAA,MACP,UAAU;AAAA,IAAA;AAAA,EAAA;AAGhB;AAEA,MAAA,SAAe;;"}
1
+ {"version":3,"file":"Text.cjs","sources":["../../../../../src/Flow/Node/Parameters/Text.tsx"],"sourcesContent":["import { useState } from \"react\";\nimport { HvInput, HvInputProps } from \"@hitachivantara/uikit-react-core\";\nimport { useReactFlow } from \"reactflow\";\n\nimport { HvFlowNodeTextParam } from \"../../types\";\n\ninterface TextProps {\n nodeId: string;\n param: Omit<HvFlowNodeTextParam, \"type\">;\n data: any;\n}\n\nconst Text = ({ nodeId, param, data }: TextProps) => {\n const { id, label } = param;\n\n const reactFlowInstance = useReactFlow();\n\n const [text, setText] = useState(data[id]);\n\n const onTextChange: HvInputProps[\"onChange\"] = (event, val) => {\n reactFlowInstance.setNodes((nodes) =>\n nodes.map((node) => {\n if (node.id === nodeId) {\n node.data = { ...node.data, [id]: val };\n }\n return node;\n })\n );\n setText(val);\n };\n\n return (\n <HvInput\n className=\"nodrag\" // Prevents dragging within the input field\n label={label}\n value={text}\n onChange={onTextChange}\n />\n );\n};\n\nexport default Text;\n"],"names":["useReactFlow","useState","jsx","HvInput"],"mappings":";;;;;;AAYA,MAAM,OAAO,CAAC,EAAE,QAAQ,OAAO,WAAsB;AAC7C,QAAA,EAAE,IAAI,MAAU,IAAA;AAEtB,QAAM,oBAAoBA,UAAAA;AAE1B,QAAM,CAAC,MAAM,OAAO,IAAIC,MAAS,SAAA,KAAK,EAAE,CAAC;AAEnC,QAAA,eAAyC,CAAC,OAAO,QAAQ;AAC3C,sBAAA;AAAA,MAAS,CAAC,UAC1B,MAAM,IAAI,CAAC,SAAS;AACd,YAAA,KAAK,OAAO,QAAQ;AACjB,eAAA,OAAO,EAAE,GAAG,KAAK,MAAM,CAAC,EAAE,GAAG;QACpC;AACO,eAAA;AAAA,MAAA,CACR;AAAA,IAAA;AAEH,YAAQ,GAAG;AAAA,EAAA;AAIX,SAAAC,2BAAA;AAAA,IAACC,eAAA;AAAA,IAAA;AAAA,MACC,WAAU;AAAA,MACV;AAAA,MACA,OAAO;AAAA,MACP,UAAU;AAAA,IAAA;AAAA,EAAA;AAGhB;AAEA,MAAA,SAAe;;"}
@@ -16,8 +16,6 @@ const { staticClasses, useClasses } = uikitReactCore.createClasses("HvDashboardN
16
16
  }
17
17
  });
18
18
  const DEFAULT_LABELS = {
19
- title: "Dashboard",
20
- description: "Dashboard",
21
19
  emptyMessage: "No visualizations connected to the dashboard.",
22
20
  dialogTitle: "Configure dashboard",
23
21
  dialogSubtitle: "Please configure the layout of your dashboard as needed.",
@@ -43,7 +41,7 @@ const HvDashboardNode = (props) => {
43
41
  const labels = uikitReactCore.useLabels(DEFAULT_LABELS, labelsProp);
44
42
  const { classes } = useClasses(classesProp);
45
43
  return /* @__PURE__ */ jsxRuntime.jsxs(Node.HvFlowNode, { id, classes, ...others, children: [
46
- /* @__PURE__ */ jsxRuntime.jsx("div", { className: classes.actions, children }),
44
+ children && /* @__PURE__ */ jsxRuntime.jsx("div", { className: classes.actions, children }),
47
45
  /* @__PURE__ */ jsxRuntime.jsxs(
48
46
  uikitReactCore.HvDialog,
49
47
  {
@@ -1 +1 @@
1
- {"version":3,"file":"DashboardNode.cjs","sources":["../../../../src/Flow/nodes/DashboardNode.tsx"],"sourcesContent":["import {\n ExtractNames,\n HvButton,\n HvDialog,\n HvDialogActions,\n HvDialogContent,\n HvDialogProps,\n HvDialogTitle,\n HvEmptyState,\n createClasses,\n theme,\n useLabels,\n} from \"@hitachivantara/uikit-react-core\";\nimport { Info } from \"@hitachivantara/uikit-react-icons\";\n\nimport { HvDashboard, HvDashboardProps } from \"../../Dashboard\";\nimport { HvFlowNode, HvFlowNodeProps, HvFlowNodeClasses } from \"../Node\";\n\nconst { staticClasses, useClasses } = createClasses(\"HvDashboardNode\", {\n actions: {\n display: \"flex\",\n justifyContent: \"space-around\",\n padding: theme.space.xs,\n },\n empty: {\n padding: theme.spacing(\"sm\", 0, 0, 0),\n },\n});\n\nexport { staticClasses as hvDashboardNodeClasses };\n\nconst DEFAULT_LABELS = {\n title: \"Dashboard\",\n description: \"Dashboard\",\n emptyMessage: \"No visualizations connected to the dashboard.\",\n dialogTitle: \"Configure dashboard\",\n dialogSubtitle: \"Please configure the layout of your dashboard as needed.\",\n dialogApply: \"Apply\",\n dialogCancel: \"Cancel\",\n};\n\nexport interface HvDashboardNodeClasses\n extends ExtractNames<typeof useClasses>,\n HvFlowNodeClasses {}\n\nexport interface HvDashboardNodeProps\n extends HvFlowNodeProps,\n Pick<HvDialogProps, \"open\" | \"onClose\">,\n Pick<HvDashboardProps, \"layout\"> {\n classes?: HvDashboardNodeClasses;\n labels?: typeof DEFAULT_LABELS;\n previewItems?: React.ReactNode;\n onApply?: () => void;\n onCancel?: () => void;\n\n dashboardProps?: Omit<HvDashboardProps, \"children\">;\n dialogProps?: HvDialogProps;\n}\n\nexport const HvDashboardNode = (props: HvDashboardNodeProps) => {\n const {\n id,\n open,\n layout,\n labels: labelsProp,\n classes: classesProp,\n previewItems,\n children,\n dialogProps,\n dashboardProps,\n onApply,\n onCancel,\n onClose,\n ...others\n } = props;\n const labels = useLabels(DEFAULT_LABELS, labelsProp);\n const { classes } = useClasses(classesProp);\n\n return (\n <HvFlowNode id={id} classes={classes as any} {...others}>\n <div className={classes.actions}>{children}</div>\n <HvDialog\n open={open}\n maxWidth=\"lg\"\n fullWidth\n onClose={onClose}\n {...dialogProps}\n >\n <HvDialogTitle variant=\"info\">{labels?.dialogTitle}</HvDialogTitle>\n <HvDialogContent indentContent>\n {labels?.dialogSubtitle}\n {layout && layout?.length > 0 ? (\n <HvDashboard\n cols={12}\n layout={layout}\n compactType=\"vertical\"\n rowHeight={80}\n margin={[16, 16]}\n containerPadding={[0, 16]}\n {...dashboardProps}\n >\n {previewItems}\n </HvDashboard>\n ) : (\n <HvEmptyState\n className={classes.empty}\n icon={<Info role=\"none\" />}\n message={labels?.emptyMessage}\n />\n )}\n </HvDialogContent>\n <HvDialogActions>\n <HvButton variant=\"primary\" onClick={onApply}>\n {labels?.dialogApply}\n </HvButton>\n <HvButton variant=\"secondarySubtle\" onClick={onCancel}>\n {labels?.dialogCancel}\n </HvButton>\n </HvDialogActions>\n </HvDialog>\n </HvFlowNode>\n );\n};\n"],"names":["createClasses","theme","useLabels","jsxs","HvFlowNode","jsx","HvDialog","HvDialogTitle","HvDialogContent","HvDashboard","HvEmptyState","Info","HvDialogActions","HvButton"],"mappings":";;;;;;;AAkBA,MAAM,EAAE,eAAe,eAAeA,eAAAA,cAAc,mBAAmB;AAAA,EACrE,SAAS;AAAA,IACP,SAAS;AAAA,IACT,gBAAgB;AAAA,IAChB,SAASC,eAAAA,MAAM,MAAM;AAAA,EACvB;AAAA,EACA,OAAO;AAAA,IACL,SAASA,eAAM,MAAA,QAAQ,MAAM,GAAG,GAAG,CAAC;AAAA,EACtC;AACF,CAAC;AAID,MAAM,iBAAiB;AAAA,EACrB,OAAO;AAAA,EACP,aAAa;AAAA,EACb,cAAc;AAAA,EACd,aAAa;AAAA,EACb,gBAAgB;AAAA,EAChB,aAAa;AAAA,EACb,cAAc;AAChB;AAoBa,MAAA,kBAAkB,CAAC,UAAgC;AACxD,QAAA;AAAA,IACJ;AAAA,IACA;AAAA,IACA;AAAA,IACA,QAAQ;AAAA,IACR,SAAS;AAAA,IACT;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,GAAG;AAAA,EACD,IAAA;AACE,QAAA,SAASC,eAAAA,UAAU,gBAAgB,UAAU;AACnD,QAAM,EAAE,QAAA,IAAY,WAAW,WAAW;AAE1C,SACGC,2BAAAA,KAAAC,KAAAA,YAAA,EAAW,IAAQ,SAA0B,GAAG,QAC/C,UAAA;AAAA,IAAAC,2BAAA,IAAC,OAAI,EAAA,WAAW,QAAQ,SAAU,UAAS;AAAA,IAC3CF,2BAAA;AAAA,MAACG,eAAA;AAAA,MAAA;AAAA,QACC;AAAA,QACA,UAAS;AAAA,QACT,WAAS;AAAA,QACT;AAAA,QACC,GAAG;AAAA,QAEJ,UAAA;AAAA,UAAAD,2BAAA,IAACE,eAAc,eAAA,EAAA,SAAQ,QAAQ,UAAA,QAAQ,aAAY;AAAA,UACnDJ,2BAAAA,KAACK,eAAAA,iBAAgB,EAAA,eAAa,MAC3B,UAAA;AAAA,YAAQ,QAAA;AAAA,YACR,UAAU,QAAQ,SAAS,IAC1BH,2BAAA;AAAA,cAACI,UAAA;AAAA,cAAA;AAAA,gBACC,MAAM;AAAA,gBACN;AAAA,gBACA,aAAY;AAAA,gBACZ,WAAW;AAAA,gBACX,QAAQ,CAAC,IAAI,EAAE;AAAA,gBACf,kBAAkB,CAAC,GAAG,EAAE;AAAA,gBACvB,GAAG;AAAA,gBAEH,UAAA;AAAA,cAAA;AAAA,YAAA,IAGHJ,2BAAA;AAAA,cAACK,eAAA;AAAA,cAAA;AAAA,gBACC,WAAW,QAAQ;AAAA,gBACnB,MAAML,2BAAAA,IAACM,gBAAAA,MAAK,EAAA,MAAK,OAAO,CAAA;AAAA,gBACxB,SAAS,QAAQ;AAAA,cAAA;AAAA,YACnB;AAAA,UAAA,GAEJ;AAAA,0CACCC,eAAAA,iBACC,EAAA,UAAA;AAAA,YAAAP,+BAACQ,eAAAA,YAAS,SAAQ,WAAU,SAAS,SAClC,kBAAQ,aACX;AAAA,2CACCA,eAAAA,UAAS,EAAA,SAAQ,mBAAkB,SAAS,UAC1C,kBAAQ,cACX;AAAA,UAAA,GACF;AAAA,QAAA;AAAA,MAAA;AAAA,IACF;AAAA,EACF,EAAA,CAAA;AAEJ;;;"}
1
+ {"version":3,"file":"DashboardNode.cjs","sources":["../../../../src/Flow/nodes/DashboardNode.tsx"],"sourcesContent":["import {\n ExtractNames,\n HvButton,\n HvDialog,\n HvDialogActions,\n HvDialogContent,\n HvDialogProps,\n HvDialogTitle,\n HvEmptyState,\n createClasses,\n theme,\n useLabels,\n} from \"@hitachivantara/uikit-react-core\";\nimport { Info } from \"@hitachivantara/uikit-react-icons\";\n\nimport { HvDashboard, HvDashboardProps } from \"../../Dashboard\";\nimport { HvFlowNode, HvFlowNodeProps, HvFlowNodeClasses } from \"../Node\";\n\nconst { staticClasses, useClasses } = createClasses(\"HvDashboardNode\", {\n actions: {\n display: \"flex\",\n justifyContent: \"space-around\",\n padding: theme.space.xs,\n },\n empty: {\n padding: theme.spacing(\"sm\", 0, 0, 0),\n },\n});\n\nexport { staticClasses as hvDashboardNodeClasses };\n\nconst DEFAULT_LABELS = {\n emptyMessage: \"No visualizations connected to the dashboard.\",\n dialogTitle: \"Configure dashboard\",\n dialogSubtitle: \"Please configure the layout of your dashboard as needed.\",\n dialogApply: \"Apply\",\n dialogCancel: \"Cancel\",\n};\n\nexport interface HvDashboardNodeClasses\n extends ExtractNames<typeof useClasses>,\n HvFlowNodeClasses {}\n\nexport interface HvDashboardNodeProps\n extends HvFlowNodeProps,\n Pick<HvDialogProps, \"open\" | \"onClose\">,\n Pick<HvDashboardProps, \"layout\"> {\n classes?: HvDashboardNodeClasses;\n labels?: Partial<typeof DEFAULT_LABELS>;\n previewItems?: React.ReactNode;\n onApply?: () => void;\n onCancel?: () => void;\n\n dashboardProps?: Omit<HvDashboardProps, \"children\">;\n dialogProps?: HvDialogProps;\n}\n\nexport const HvDashboardNode = (props: HvDashboardNodeProps) => {\n const {\n id,\n open,\n layout,\n labels: labelsProp,\n classes: classesProp,\n previewItems,\n children,\n dialogProps,\n dashboardProps,\n onApply,\n onCancel,\n onClose,\n ...others\n } = props;\n const labels = useLabels(DEFAULT_LABELS, labelsProp);\n const { classes } = useClasses(classesProp);\n\n return (\n <HvFlowNode id={id} classes={classes as any} {...others}>\n {children && <div className={classes.actions}>{children}</div>}\n <HvDialog\n open={open}\n maxWidth=\"lg\"\n fullWidth\n onClose={onClose}\n {...dialogProps}\n >\n <HvDialogTitle variant=\"info\">{labels?.dialogTitle}</HvDialogTitle>\n <HvDialogContent indentContent>\n {labels?.dialogSubtitle}\n {layout && layout?.length > 0 ? (\n <HvDashboard\n cols={12}\n layout={layout}\n compactType=\"vertical\"\n rowHeight={80}\n margin={[16, 16]}\n containerPadding={[0, 16]}\n {...dashboardProps}\n >\n {previewItems}\n </HvDashboard>\n ) : (\n <HvEmptyState\n className={classes.empty}\n icon={<Info role=\"none\" />}\n message={labels?.emptyMessage}\n />\n )}\n </HvDialogContent>\n <HvDialogActions>\n <HvButton variant=\"primary\" onClick={onApply}>\n {labels?.dialogApply}\n </HvButton>\n <HvButton variant=\"secondarySubtle\" onClick={onCancel}>\n {labels?.dialogCancel}\n </HvButton>\n </HvDialogActions>\n </HvDialog>\n </HvFlowNode>\n );\n};\n"],"names":["createClasses","theme","useLabels","jsxs","HvFlowNode","jsx","HvDialog","HvDialogTitle","HvDialogContent","HvDashboard","HvEmptyState","Info","HvDialogActions","HvButton"],"mappings":";;;;;;;AAkBA,MAAM,EAAE,eAAe,eAAeA,eAAAA,cAAc,mBAAmB;AAAA,EACrE,SAAS;AAAA,IACP,SAAS;AAAA,IACT,gBAAgB;AAAA,IAChB,SAASC,eAAAA,MAAM,MAAM;AAAA,EACvB;AAAA,EACA,OAAO;AAAA,IACL,SAASA,eAAM,MAAA,QAAQ,MAAM,GAAG,GAAG,CAAC;AAAA,EACtC;AACF,CAAC;AAID,MAAM,iBAAiB;AAAA,EACrB,cAAc;AAAA,EACd,aAAa;AAAA,EACb,gBAAgB;AAAA,EAChB,aAAa;AAAA,EACb,cAAc;AAChB;AAoBa,MAAA,kBAAkB,CAAC,UAAgC;AACxD,QAAA;AAAA,IACJ;AAAA,IACA;AAAA,IACA;AAAA,IACA,QAAQ;AAAA,IACR,SAAS;AAAA,IACT;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,GAAG;AAAA,EACD,IAAA;AACE,QAAA,SAASC,eAAAA,UAAU,gBAAgB,UAAU;AACnD,QAAM,EAAE,QAAA,IAAY,WAAW,WAAW;AAE1C,SACGC,2BAAAA,KAAAC,KAAAA,YAAA,EAAW,IAAQ,SAA0B,GAAG,QAC9C,UAAA;AAAA,IAAA,YAAaC,2BAAA,IAAA,OAAA,EAAI,WAAW,QAAQ,SAAU,UAAS;AAAA,IACxDF,2BAAA;AAAA,MAACG,eAAA;AAAA,MAAA;AAAA,QACC;AAAA,QACA,UAAS;AAAA,QACT,WAAS;AAAA,QACT;AAAA,QACC,GAAG;AAAA,QAEJ,UAAA;AAAA,UAAAD,2BAAA,IAACE,eAAc,eAAA,EAAA,SAAQ,QAAQ,UAAA,QAAQ,aAAY;AAAA,UACnDJ,2BAAAA,KAACK,eAAAA,iBAAgB,EAAA,eAAa,MAC3B,UAAA;AAAA,YAAQ,QAAA;AAAA,YACR,UAAU,QAAQ,SAAS,IAC1BH,2BAAA;AAAA,cAACI,UAAA;AAAA,cAAA;AAAA,gBACC,MAAM;AAAA,gBACN;AAAA,gBACA,aAAY;AAAA,gBACZ,WAAW;AAAA,gBACX,QAAQ,CAAC,IAAI,EAAE;AAAA,gBACf,kBAAkB,CAAC,GAAG,EAAE;AAAA,gBACvB,GAAG;AAAA,gBAEH,UAAA;AAAA,cAAA;AAAA,YAAA,IAGHJ,2BAAA;AAAA,cAACK,eAAA;AAAA,cAAA;AAAA,gBACC,WAAW,QAAQ;AAAA,gBACnB,MAAML,2BAAAA,IAACM,gBAAAA,MAAK,EAAA,MAAK,OAAO,CAAA;AAAA,gBACxB,SAAS,QAAQ;AAAA,cAAA;AAAA,YACnB;AAAA,UAAA,GAEJ;AAAA,0CACCC,eAAAA,iBACC,EAAA,UAAA;AAAA,YAAAP,+BAACQ,eAAAA,YAAS,SAAQ,WAAU,SAAS,SAClC,kBAAQ,aACX;AAAA,2CACCA,eAAAA,UAAS,EAAA,SAAQ,mBAAkB,SAAS,UAC1C,kBAAQ,cACX;AAAA,UAAA,GACF;AAAA,QAAA;AAAA,MAAA;AAAA,IACF;AAAA,EACF,EAAA,CAAA;AAEJ;;;"}
@@ -1,5 +1,9 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const Blade_styles = require("./Blade/Blade.styles.cjs");
4
+ const Blade = require("./Blade/Blade.cjs");
5
+ const Blades_styles = require("./Blades/Blades.styles.cjs");
6
+ const Blades = require("./Blades/Blades.cjs");
3
7
  const Dashboard_styles = require("./Dashboard/Dashboard.styles.cjs");
4
8
  const Dashboard = require("./Dashboard/Dashboard.cjs");
5
9
  const Flow_styles = require("./Flow/Flow.styles.cjs");
@@ -32,6 +36,10 @@ const WizardContent = require("./Wizard/WizardContent/WizardContent.cjs");
32
36
  const WizardContext = require("./Wizard/WizardContext/WizardContext.cjs");
33
37
  const WizardTitle_styles = require("./Wizard/WizardTitle/WizardTitle.styles.cjs");
34
38
  const WizardTitle = require("./Wizard/WizardTitle/WizardTitle.cjs");
39
+ exports.bladeClasses = Blade_styles.staticClasses;
40
+ exports.HvBlade = Blade.HvBlade;
41
+ exports.bladesClasses = Blades_styles.staticClasses;
42
+ exports.HvBlades = Blades.HvBlades;
35
43
  exports.dashboardClasses = Dashboard_styles.staticClasses;
36
44
  exports.HvDashboard = Dashboard.HvDashboard;
37
45
  exports.flowClasses = Flow_styles.staticClasses;
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"index.cjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}