@eccenca/gui-elements 24.4.1-featurechatcomponentscmem6775.4 → 24.4.1-featurepreparefinalnextcmem6943.1

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 (552) hide show
  1. package/CHANGELOG.md +101 -2
  2. package/README.md +63 -16
  3. package/dist/cjs/cmem/markdown/Markdown.js.map +1 -1
  4. package/dist/cjs/cmem/react-flow/ReactFlow/ReactFlow.js +67 -13
  5. package/dist/cjs/cmem/react-flow/ReactFlow/ReactFlow.js.map +1 -1
  6. package/dist/cjs/cmem/react-flow/ReactFlow/ReactFlowV12.js +45 -0
  7. package/dist/cjs/cmem/react-flow/ReactFlow/ReactFlowV12.js.map +1 -0
  8. package/dist/cjs/cmem/react-flow/ReactFlow/ReactFlowV9.js +30 -0
  9. package/dist/cjs/cmem/react-flow/ReactFlow/ReactFlowV9.js.map +1 -0
  10. package/dist/cjs/cmem/react-flow/StickyNoteModal/StickyNoteModal.js +2 -2
  11. package/dist/cjs/cmem/react-flow/StickyNoteModal/StickyNoteModal.js.map +1 -1
  12. package/dist/cjs/cmem/react-flow/configuration/graph.js +12 -10
  13. package/dist/cjs/cmem/react-flow/configuration/graph.js.map +1 -1
  14. package/dist/cjs/cmem/react-flow/configuration/linking.js +2 -0
  15. package/dist/cjs/cmem/react-flow/configuration/linking.js.map +1 -1
  16. package/dist/cjs/cmem/react-flow/configuration/unspecified.js +2 -1
  17. package/dist/cjs/cmem/react-flow/configuration/unspecified.js.map +1 -1
  18. package/dist/cjs/cmem/react-flow/configuration/workflow.js +2 -0
  19. package/dist/cjs/cmem/react-flow/configuration/workflow.js.map +1 -1
  20. package/dist/cjs/cmem/react-flow/extensions/scrollOnDragHook.js +9 -3
  21. package/dist/cjs/cmem/react-flow/extensions/scrollOnDragHook.js.map +1 -1
  22. package/dist/cjs/cmem/react-flow/index.js +5 -1
  23. package/dist/cjs/cmem/react-flow/index.js.map +1 -1
  24. package/dist/cjs/common/index.js +5 -0
  25. package/dist/cjs/common/index.js.map +1 -1
  26. package/dist/cjs/common/utils/CssCustomProperties.js +9 -3
  27. package/dist/cjs/common/utils/CssCustomProperties.js.map +1 -1
  28. package/dist/cjs/common/utils/colorCalculateDistance.js +27 -0
  29. package/dist/cjs/common/utils/colorCalculateDistance.js.map +1 -0
  30. package/dist/cjs/common/utils/colorHash.js +143 -0
  31. package/dist/cjs/common/utils/colorHash.js.map +1 -0
  32. package/dist/cjs/common/utils/getColorConfiguration.js +37 -4
  33. package/dist/cjs/common/utils/getColorConfiguration.js.map +1 -1
  34. package/dist/cjs/components/AutoSuggestion/AutoSuggestion.js +13 -10
  35. package/dist/cjs/components/AutoSuggestion/AutoSuggestion.js.map +1 -1
  36. package/dist/cjs/components/AutoSuggestion/AutoSuggestionList.js +3 -0
  37. package/dist/cjs/components/AutoSuggestion/AutoSuggestionList.js.map +1 -1
  38. package/dist/cjs/components/AutoSuggestion/ExtendedCodeEditor.js.map +1 -1
  39. package/dist/cjs/components/AutocompleteField/AutoCompleteField.js +16 -6
  40. package/dist/cjs/components/AutocompleteField/AutoCompleteField.js.map +1 -1
  41. package/dist/cjs/components/AutocompleteField/autoCompleteFieldUtils.js.map +1 -1
  42. package/dist/cjs/components/Button/Button.js +11 -26
  43. package/dist/cjs/components/Button/Button.js.map +1 -1
  44. package/dist/cjs/components/CodeAutocompleteField/index.js +6 -1
  45. package/dist/cjs/components/CodeAutocompleteField/index.js.map +1 -1
  46. package/dist/cjs/components/Dialog/Modal.js +2 -1
  47. package/dist/cjs/components/Dialog/Modal.js.map +1 -1
  48. package/dist/cjs/components/Dialog/SimpleDialog.js +2 -1
  49. package/dist/cjs/components/Dialog/SimpleDialog.js.map +1 -1
  50. package/dist/cjs/components/Form/FieldItem.js +2 -19
  51. package/dist/cjs/components/Form/FieldItem.js.map +1 -1
  52. package/dist/cjs/components/Form/FieldSet.js +2 -20
  53. package/dist/cjs/components/Form/FieldSet.js.map +1 -1
  54. package/dist/cjs/components/Icon/BaseIcon.js +2 -2
  55. package/dist/cjs/components/Icon/BaseIcon.js.map +1 -1
  56. package/dist/cjs/components/Icon/IconButton.js.map +1 -1
  57. package/dist/cjs/components/Icon/canonicalIconNames.js +2 -0
  58. package/dist/cjs/components/Icon/canonicalIconNames.js.map +1 -1
  59. package/dist/cjs/components/MultiSelect/MultiSelect.js +14 -27
  60. package/dist/cjs/components/MultiSelect/MultiSelect.js.map +1 -1
  61. package/dist/cjs/components/{AutocompleteField → MultiSuggestField}/index.js +1 -7
  62. package/dist/cjs/components/MultiSuggestField/index.js.map +1 -0
  63. package/dist/cjs/components/Notification/Notification.js +3 -23
  64. package/dist/cjs/components/Notification/Notification.js.map +1 -1
  65. package/dist/cjs/components/OverviewItem/OverviewItemList.js +1 -2
  66. package/dist/cjs/components/OverviewItem/OverviewItemList.js.map +1 -1
  67. package/dist/cjs/components/Spinner/Spinner.js +17 -8
  68. package/dist/cjs/components/Spinner/Spinner.js.map +1 -1
  69. package/dist/cjs/components/SuggestField/index.js +5 -2
  70. package/dist/cjs/components/SuggestField/index.js.map +1 -1
  71. package/dist/cjs/components/Table/Table.js.map +1 -1
  72. package/dist/cjs/components/Table/TableContainer.js.map +1 -1
  73. package/dist/cjs/components/Tabs/Tab.js +3 -2
  74. package/dist/cjs/components/Tabs/Tab.js.map +1 -1
  75. package/dist/cjs/components/TextField/SearchField.js.map +1 -1
  76. package/dist/cjs/components/Tooltip/Tooltip.js +1 -1
  77. package/dist/cjs/components/Tooltip/Tooltip.js.map +1 -1
  78. package/dist/cjs/components/Typography/OverflowText.js.map +1 -1
  79. package/dist/cjs/components/VisualTour/VisualTour.js +200 -0
  80. package/dist/cjs/components/VisualTour/VisualTour.js.map +1 -0
  81. package/dist/cjs/components/index.js +6 -8
  82. package/dist/cjs/components/index.js.map +1 -1
  83. package/dist/cjs/configuration/constants.js +3 -1
  84. package/dist/cjs/configuration/constants.js.map +1 -1
  85. package/dist/cjs/extensions/codemirror/CodeMirror.js +3 -2
  86. package/dist/cjs/extensions/codemirror/CodeMirror.js.map +1 -1
  87. package/dist/cjs/extensions/codemirror/hooks/useCodemirrorModeExtension.hooks.js +3 -0
  88. package/dist/cjs/extensions/codemirror/hooks/useCodemirrorModeExtension.hooks.js.map +1 -1
  89. package/dist/cjs/extensions/react-flow/edges/EdgeBezier.js +50 -0
  90. package/dist/cjs/extensions/react-flow/edges/EdgeBezier.js.map +1 -0
  91. package/dist/cjs/extensions/react-flow/edges/EdgeDefault.js +21 -3
  92. package/dist/cjs/extensions/react-flow/edges/EdgeDefault.js.map +1 -1
  93. package/dist/cjs/extensions/react-flow/edges/EdgeDefaultV12.js +46 -22
  94. package/dist/cjs/extensions/react-flow/edges/EdgeDefaultV12.js.map +1 -1
  95. package/dist/cjs/extensions/react-flow/edges/EdgeDefs.js +3 -0
  96. package/dist/cjs/extensions/react-flow/edges/EdgeDefs.js.map +1 -1
  97. package/dist/cjs/extensions/react-flow/edges/EdgeNew.js +41 -0
  98. package/dist/cjs/extensions/react-flow/edges/EdgeNew.js.map +1 -0
  99. package/dist/cjs/extensions/react-flow/edges/EdgeStep.js +19 -2
  100. package/dist/cjs/extensions/react-flow/edges/EdgeStep.js.map +1 -1
  101. package/dist/cjs/extensions/react-flow/edges/EdgeStraight.js +6 -0
  102. package/dist/cjs/extensions/react-flow/edges/EdgeStraight.js.map +1 -0
  103. package/dist/cjs/extensions/react-flow/edges/utils.js +12 -1
  104. package/dist/cjs/extensions/react-flow/edges/utils.js.map +1 -1
  105. package/dist/cjs/extensions/react-flow/handles/HandleDefault.js +14 -15
  106. package/dist/cjs/extensions/react-flow/handles/HandleDefault.js.map +1 -1
  107. package/dist/cjs/extensions/react-flow/index.js +6 -6
  108. package/dist/cjs/extensions/react-flow/index.js.map +1 -1
  109. package/dist/cjs/extensions/react-flow/markers/MarkerArrowClosedInverse.js +3 -0
  110. package/dist/cjs/extensions/react-flow/markers/MarkerArrowClosedInverse.js.map +1 -1
  111. package/dist/cjs/extensions/react-flow/markers/ReactFlowMarkers.js +17 -2
  112. package/dist/cjs/extensions/react-flow/markers/ReactFlowMarkers.js.map +1 -1
  113. package/dist/cjs/extensions/react-flow/minimap/MiniMap.js +21 -2
  114. package/dist/cjs/extensions/react-flow/minimap/MiniMap.js.map +1 -1
  115. package/dist/cjs/extensions/react-flow/minimap/MiniMapV12.js +51 -0
  116. package/dist/cjs/extensions/react-flow/minimap/MiniMapV12.js.map +1 -0
  117. package/dist/cjs/extensions/react-flow/nodes/NodeContent.js +57 -54
  118. package/dist/cjs/extensions/react-flow/nodes/NodeContent.js.map +1 -1
  119. package/dist/cjs/extensions/react-flow/nodes/NodeDefault.js +2 -2
  120. package/dist/cjs/extensions/react-flow/nodes/NodeDefault.js.map +1 -1
  121. package/dist/cjs/extensions/react-flow/nodes/nodeUtils.js +2 -1
  122. package/dist/cjs/extensions/react-flow/nodes/nodeUtils.js.map +1 -1
  123. package/dist/cjs/extensions/react-flow/versionsupport.js +13 -11
  124. package/dist/cjs/extensions/react-flow/versionsupport.js.map +1 -1
  125. package/dist/cjs/index.js +1 -3
  126. package/dist/cjs/index.js.map +1 -1
  127. package/dist/esm/cmem/markdown/Markdown.js.map +1 -1
  128. package/dist/esm/cmem/react-flow/ReactFlow/ReactFlow.js +67 -13
  129. package/dist/esm/cmem/react-flow/ReactFlow/ReactFlow.js.map +1 -1
  130. package/dist/esm/cmem/react-flow/ReactFlow/ReactFlowV12.js +66 -0
  131. package/dist/esm/cmem/react-flow/ReactFlow/ReactFlowV12.js.map +1 -0
  132. package/dist/esm/{legacy-replacements/Button/AffirmativeButton.js → cmem/react-flow/ReactFlow/ReactFlowV9.js} +12 -7
  133. package/dist/esm/cmem/react-flow/ReactFlow/ReactFlowV9.js.map +1 -0
  134. package/dist/esm/cmem/react-flow/StickyNoteModal/StickyNoteModal.js +3 -3
  135. package/dist/esm/cmem/react-flow/StickyNoteModal/StickyNoteModal.js.map +1 -1
  136. package/dist/esm/cmem/react-flow/configuration/graph.js +12 -10
  137. package/dist/esm/cmem/react-flow/configuration/graph.js.map +1 -1
  138. package/dist/esm/cmem/react-flow/configuration/linking.js +2 -0
  139. package/dist/esm/cmem/react-flow/configuration/linking.js.map +1 -1
  140. package/dist/esm/cmem/react-flow/configuration/unspecified.js +2 -1
  141. package/dist/esm/cmem/react-flow/configuration/unspecified.js.map +1 -1
  142. package/dist/esm/cmem/react-flow/configuration/workflow.js +2 -0
  143. package/dist/esm/cmem/react-flow/configuration/workflow.js.map +1 -1
  144. package/dist/esm/cmem/react-flow/extensions/scrollOnDragHook.js +7 -1
  145. package/dist/esm/cmem/react-flow/extensions/scrollOnDragHook.js.map +1 -1
  146. package/dist/esm/cmem/react-flow/index.js +2 -1
  147. package/dist/esm/cmem/react-flow/index.js.map +1 -1
  148. package/dist/esm/common/index.js +5 -0
  149. package/dist/esm/common/index.js.map +1 -1
  150. package/dist/esm/common/utils/CssCustomProperties.js +9 -3
  151. package/dist/esm/common/utils/CssCustomProperties.js.map +1 -1
  152. package/dist/esm/common/utils/colorCalculateDistance.js +21 -0
  153. package/dist/esm/common/utils/colorCalculateDistance.js.map +1 -0
  154. package/dist/esm/common/utils/colorHash.js +140 -0
  155. package/dist/esm/common/utils/colorHash.js.map +1 -0
  156. package/dist/esm/common/utils/getColorConfiguration.js +37 -4
  157. package/dist/esm/common/utils/getColorConfiguration.js.map +1 -1
  158. package/dist/esm/components/AutoSuggestion/AutoSuggestion.js +13 -11
  159. package/dist/esm/components/AutoSuggestion/AutoSuggestion.js.map +1 -1
  160. package/dist/esm/components/AutoSuggestion/AutoSuggestionList.js +3 -0
  161. package/dist/esm/components/AutoSuggestion/AutoSuggestionList.js.map +1 -1
  162. package/dist/esm/components/AutoSuggestion/ExtendedCodeEditor.js.map +1 -1
  163. package/dist/esm/components/AutocompleteField/AutoCompleteField.js +15 -6
  164. package/dist/esm/components/AutocompleteField/AutoCompleteField.js.map +1 -1
  165. package/dist/esm/components/AutocompleteField/autoCompleteFieldUtils.js.map +1 -1
  166. package/dist/esm/components/Button/Button.js +11 -26
  167. package/dist/esm/components/Button/Button.js.map +1 -1
  168. package/dist/esm/components/CodeAutocompleteField/index.js +4 -1
  169. package/dist/esm/components/CodeAutocompleteField/index.js.map +1 -1
  170. package/dist/esm/components/Dialog/Modal.js +2 -1
  171. package/dist/esm/components/Dialog/Modal.js.map +1 -1
  172. package/dist/esm/components/Dialog/SimpleDialog.js +2 -1
  173. package/dist/esm/components/Dialog/SimpleDialog.js.map +1 -1
  174. package/dist/esm/components/Form/FieldItem.js +2 -19
  175. package/dist/esm/components/Form/FieldItem.js.map +1 -1
  176. package/dist/esm/components/Form/FieldSet.js +2 -20
  177. package/dist/esm/components/Form/FieldSet.js.map +1 -1
  178. package/dist/esm/components/Icon/BaseIcon.js +2 -2
  179. package/dist/esm/components/Icon/BaseIcon.js.map +1 -1
  180. package/dist/esm/components/Icon/IconButton.js.map +1 -1
  181. package/dist/esm/components/Icon/canonicalIconNames.js +2 -0
  182. package/dist/esm/components/Icon/canonicalIconNames.js.map +1 -1
  183. package/dist/esm/components/MultiSelect/MultiSelect.js +13 -27
  184. package/dist/esm/components/MultiSelect/MultiSelect.js.map +1 -1
  185. package/dist/esm/components/MultiSuggestField/index.js +2 -0
  186. package/dist/esm/components/MultiSuggestField/index.js.map +1 -0
  187. package/dist/esm/components/Notification/Notification.js +3 -23
  188. package/dist/esm/components/Notification/Notification.js.map +1 -1
  189. package/dist/esm/components/OverviewItem/OverviewItemList.js +1 -2
  190. package/dist/esm/components/OverviewItem/OverviewItemList.js.map +1 -1
  191. package/dist/esm/components/Spinner/Spinner.js +14 -8
  192. package/dist/esm/components/Spinner/Spinner.js.map +1 -1
  193. package/dist/esm/components/SuggestField/index.js +4 -1
  194. package/dist/esm/components/SuggestField/index.js.map +1 -1
  195. package/dist/esm/components/Table/Table.js.map +1 -1
  196. package/dist/esm/components/Table/TableContainer.js.map +1 -1
  197. package/dist/esm/components/Tabs/Tab.js +3 -2
  198. package/dist/esm/components/Tabs/Tab.js.map +1 -1
  199. package/dist/esm/components/TextField/SearchField.js.map +1 -1
  200. package/dist/esm/components/Tooltip/Tooltip.js +1 -1
  201. package/dist/esm/components/Tooltip/Tooltip.js.map +1 -1
  202. package/dist/esm/components/Typography/OverflowText.js.map +1 -1
  203. package/dist/esm/components/VisualTour/VisualTour.js +213 -0
  204. package/dist/esm/components/VisualTour/VisualTour.js.map +1 -0
  205. package/dist/esm/components/index.js +6 -8
  206. package/dist/esm/components/index.js.map +1 -1
  207. package/dist/esm/configuration/constants.js +2 -0
  208. package/dist/esm/configuration/constants.js.map +1 -1
  209. package/dist/esm/extensions/codemirror/CodeMirror.js +5 -4
  210. package/dist/esm/extensions/codemirror/CodeMirror.js.map +1 -1
  211. package/dist/esm/extensions/codemirror/hooks/useCodemirrorModeExtension.hooks.js +3 -0
  212. package/dist/esm/extensions/codemirror/hooks/useCodemirrorModeExtension.hooks.js.map +1 -1
  213. package/dist/esm/extensions/react-flow/edges/EdgeBezier.js +35 -0
  214. package/dist/esm/extensions/react-flow/edges/EdgeBezier.js.map +1 -0
  215. package/dist/esm/extensions/react-flow/edges/EdgeDefault.js +21 -3
  216. package/dist/esm/extensions/react-flow/edges/EdgeDefault.js.map +1 -1
  217. package/dist/esm/extensions/react-flow/edges/EdgeDefaultV12.js +24 -20
  218. package/dist/esm/extensions/react-flow/edges/EdgeDefaultV12.js.map +1 -1
  219. package/dist/esm/extensions/react-flow/edges/EdgeDefs.js +3 -0
  220. package/dist/esm/extensions/react-flow/edges/EdgeDefs.js.map +1 -1
  221. package/dist/esm/extensions/react-flow/edges/EdgeNew.js +45 -0
  222. package/dist/esm/extensions/react-flow/edges/EdgeNew.js.map +1 -0
  223. package/dist/esm/extensions/react-flow/edges/EdgeStep.js +19 -2
  224. package/dist/esm/extensions/react-flow/edges/EdgeStep.js.map +1 -1
  225. package/dist/esm/extensions/react-flow/edges/EdgeStraight.js +2 -0
  226. package/dist/esm/extensions/react-flow/edges/EdgeStraight.js.map +1 -0
  227. package/dist/esm/extensions/react-flow/edges/utils.js +27 -1
  228. package/dist/esm/extensions/react-flow/edges/utils.js.map +1 -1
  229. package/dist/esm/extensions/react-flow/handles/HandleDefault.js +16 -17
  230. package/dist/esm/extensions/react-flow/handles/HandleDefault.js.map +1 -1
  231. package/dist/esm/extensions/react-flow/index.js +6 -3
  232. package/dist/esm/extensions/react-flow/index.js.map +1 -1
  233. package/dist/esm/extensions/react-flow/markers/MarkerArrowClosedInverse.js +3 -0
  234. package/dist/esm/extensions/react-flow/markers/MarkerArrowClosedInverse.js.map +1 -1
  235. package/dist/esm/extensions/react-flow/markers/ReactFlowMarkers.js +17 -2
  236. package/dist/esm/extensions/react-flow/markers/ReactFlowMarkers.js.map +1 -1
  237. package/dist/esm/extensions/react-flow/minimap/MiniMap.js +22 -3
  238. package/dist/esm/extensions/react-flow/minimap/MiniMap.js.map +1 -1
  239. package/dist/esm/extensions/react-flow/minimap/MiniMapV12.js +36 -0
  240. package/dist/esm/extensions/react-flow/minimap/MiniMapV12.js.map +1 -0
  241. package/dist/esm/extensions/react-flow/nodes/NodeContent.js +84 -81
  242. package/dist/esm/extensions/react-flow/nodes/NodeContent.js.map +1 -1
  243. package/dist/esm/extensions/react-flow/nodes/NodeDefault.js +1 -1
  244. package/dist/esm/extensions/react-flow/nodes/NodeDefault.js.map +1 -1
  245. package/dist/esm/extensions/react-flow/nodes/nodeUtils.js +2 -1
  246. package/dist/esm/extensions/react-flow/nodes/nodeUtils.js.map +1 -1
  247. package/dist/esm/extensions/react-flow/versionsupport.js +15 -13
  248. package/dist/esm/extensions/react-flow/versionsupport.js.map +1 -1
  249. package/dist/esm/index.js +1 -2
  250. package/dist/esm/index.js.map +1 -1
  251. package/dist/types/cmem/markdown/Markdown.d.ts +1 -8
  252. package/dist/types/cmem/react-flow/ReactFlow/ReactFlow.d.ts +38 -6
  253. package/dist/types/cmem/react-flow/ReactFlow/ReactFlowV12.d.ts +7 -0
  254. package/dist/types/cmem/react-flow/ReactFlow/ReactFlowV9.d.ts +7 -0
  255. package/dist/types/cmem/react-flow/configuration/graph.d.ts +9 -9
  256. package/dist/types/cmem/react-flow/configuration/linking.d.ts +6 -6
  257. package/dist/types/cmem/react-flow/configuration/unspecified.d.ts +3 -3
  258. package/dist/types/cmem/react-flow/configuration/workflow.d.ts +4 -4
  259. package/dist/types/cmem/react-flow/extensions/scrollOnDragHook.d.ts +19 -16
  260. package/dist/types/cmem/react-flow/index.d.ts +2 -1
  261. package/dist/types/common/index.d.ts +5 -1
  262. package/dist/types/common/utils/CssCustomProperties.d.ts +6 -6
  263. package/dist/types/common/utils/colorCalculateDistance.d.ts +12 -0
  264. package/dist/types/common/utils/colorHash.d.ts +29 -0
  265. package/dist/types/common/utils/getColorConfiguration.d.ts +1 -1
  266. package/dist/types/components/AutoSuggestion/AutoSuggestion.d.ts +7 -17
  267. package/dist/types/components/AutoSuggestion/AutoSuggestionList.d.ts +4 -4
  268. package/dist/types/components/AutoSuggestion/ExtendedCodeEditor.d.ts +0 -1
  269. package/dist/types/components/AutocompleteField/AutoCompleteField.d.ts +17 -10
  270. package/dist/types/components/AutocompleteField/autoCompleteFieldUtils.d.ts +2 -2
  271. package/dist/types/components/AutocompleteField/interfaces.d.ts +2 -4
  272. package/dist/types/components/Button/Button.d.ts +1 -21
  273. package/dist/types/components/CodeAutocompleteField/index.d.ts +5 -1
  274. package/dist/types/components/Dialog/Modal.d.ts +2 -1
  275. package/dist/types/components/Dialog/SimpleDialog.d.ts +0 -1
  276. package/dist/types/components/Form/FieldItem.d.ts +1 -25
  277. package/dist/types/components/Form/FieldSet.d.ts +1 -21
  278. package/dist/types/components/Icon/BaseIcon.d.ts +1 -10
  279. package/dist/types/components/Icon/IconButton.d.ts +2 -1
  280. package/dist/types/components/Icon/canonicalIconNames.d.ts +2 -0
  281. package/dist/types/components/MultiSelect/MultiSelect.d.ts +17 -33
  282. package/dist/types/components/MultiSuggestField/index.d.ts +1 -0
  283. package/dist/types/components/Notification/Notification.d.ts +1 -24
  284. package/dist/types/components/OverviewItem/OverviewItemList.d.ts +1 -6
  285. package/dist/types/components/Spinner/Spinner.d.ts +6 -5
  286. package/dist/types/components/SuggestField/index.d.ts +6 -2
  287. package/dist/types/components/Table/Table.d.ts +1 -1
  288. package/dist/types/components/Table/TableContainer.d.ts +2 -2
  289. package/dist/types/components/Tabs/Tab.d.ts +4 -4
  290. package/dist/types/components/TextField/SearchField.d.ts +1 -1
  291. package/dist/types/components/Tooltip/Tooltip.d.ts +2 -1
  292. package/dist/types/components/Typography/OverflowText.d.ts +0 -5
  293. package/dist/types/components/VisualTour/VisualTour.d.ts +39 -0
  294. package/dist/types/components/index.d.ts +6 -8
  295. package/dist/types/configuration/constants.d.ts +2 -0
  296. package/dist/types/extensions/codemirror/CodeMirror.d.ts +4 -5
  297. package/dist/types/extensions/codemirror/hooks/useCodemirrorModeExtension.hooks.d.ts +2 -0
  298. package/dist/types/extensions/react-flow/edges/EdgeBezier.d.ts +20 -0
  299. package/dist/types/extensions/react-flow/edges/EdgeDefault.d.ts +29 -7
  300. package/dist/types/extensions/react-flow/edges/EdgeDefaultV12.d.ts +16 -27
  301. package/dist/types/extensions/react-flow/edges/EdgeDefs.d.ts +3 -0
  302. package/dist/types/extensions/react-flow/edges/EdgeNew.d.ts +3 -0
  303. package/dist/types/extensions/react-flow/edges/EdgeStep.d.ts +23 -5
  304. package/dist/types/extensions/react-flow/edges/EdgeStraight.d.ts +1 -0
  305. package/dist/types/extensions/react-flow/edges/utils.d.ts +2 -0
  306. package/dist/types/extensions/react-flow/handles/HandleDefault.d.ts +12 -6
  307. package/dist/types/extensions/react-flow/index.d.ts +6 -2
  308. package/dist/types/extensions/react-flow/markers/MarkerArrowClosedInverse.d.ts +3 -0
  309. package/dist/types/extensions/react-flow/markers/ReactFlowMarkers.d.ts +21 -2
  310. package/dist/types/extensions/react-flow/minimap/MiniMap.d.ts +18 -7
  311. package/dist/types/extensions/react-flow/minimap/MiniMapV12.d.ts +10 -0
  312. package/dist/types/extensions/react-flow/nodes/NodeContent.d.ts +15 -12
  313. package/dist/types/extensions/react-flow/nodes/NodeDefault.d.ts +7 -3
  314. package/dist/types/extensions/react-flow/nodes/nodeUtils.d.ts +12 -5
  315. package/dist/types/extensions/react-flow/versionsupport.d.ts +8 -4
  316. package/dist/types/index.d.ts +1 -2
  317. package/package.json +2 -3
  318. package/src/_shame.scss +1 -1
  319. package/src/cmem/markdown/Markdown.stories.tsx +0 -1
  320. package/src/cmem/markdown/Markdown.tsx +4 -12
  321. package/src/cmem/react-flow/ReactFlow/ReactFlow.stories.tsx +472 -366
  322. package/src/cmem/react-flow/ReactFlow/ReactFlow.tsx +176 -72
  323. package/src/cmem/react-flow/ReactFlow/ReactFlowV12.tsx +56 -0
  324. package/src/cmem/react-flow/ReactFlow/ReactFlowV9.tsx +29 -0
  325. package/src/cmem/react-flow/StickyNoteModal/StickyNoteModal.tsx +0 -1
  326. package/src/cmem/react-flow/_canvas.scss +1 -1
  327. package/src/cmem/react-flow/_edges.scss +13 -13
  328. package/src/cmem/react-flow/_handles.scss +18 -18
  329. package/src/cmem/react-flow/_minimap.scss +19 -19
  330. package/src/cmem/react-flow/configuration/_colors-graph.scss +19 -36
  331. package/src/cmem/react-flow/configuration/_colors-linking.scss +14 -26
  332. package/src/cmem/react-flow/configuration/_colors-workflow.scss +15 -27
  333. package/src/cmem/react-flow/configuration/graph.ts +13 -11
  334. package/src/cmem/react-flow/configuration/linking.ts +3 -1
  335. package/src/cmem/react-flow/configuration/unspecified.ts +2 -1
  336. package/src/cmem/react-flow/configuration/workflow.ts +3 -1
  337. package/src/cmem/react-flow/extensions/scrollOnDragHook.ts +19 -21
  338. package/src/cmem/react-flow/index.ts +2 -1
  339. package/src/cmem/react-flow/nodes/_colors.scss +20 -20
  340. package/src/common/index.ts +5 -0
  341. package/src/common/scss/_color-functions.scss +134 -0
  342. package/src/common/utils/CssCustomProperties.ts +22 -15
  343. package/src/common/utils/colorCalculateDistance.ts +28 -0
  344. package/src/common/utils/colorHash.ts +195 -0
  345. package/src/common/utils/getColorConfiguration.ts +45 -7
  346. package/src/components/Accordion/accordion.scss +6 -5
  347. package/src/components/Application/_colors.scss +15 -0
  348. package/src/components/Application/_header.scss +7 -7
  349. package/src/components/Application/_toolbar.scss +5 -5
  350. package/src/components/Application/application.scss +1 -0
  351. package/src/components/Application/stories/Application.stories.tsx +2 -2
  352. package/src/components/Application/stories/ColorPalettes.stories.tsx +885 -0
  353. package/src/components/AutoSuggestion/AutoSuggestion.tsx +15 -31
  354. package/src/components/AutoSuggestion/AutoSuggestionList.tsx +12 -5
  355. package/src/components/AutoSuggestion/ExtendedCodeEditor.tsx +0 -2
  356. package/src/components/AutocompleteField/AutoCompleteField.tsx +19 -13
  357. package/src/components/AutocompleteField/autoCompleteFieldUtils.tsx +2 -2
  358. package/src/components/AutocompleteField/interfaces.ts +1 -5
  359. package/src/components/Button/Button.stories.tsx +0 -4
  360. package/src/components/Button/Button.tsx +10 -57
  361. package/src/components/Button/button.scss +17 -17
  362. package/src/components/Card/card.scss +13 -13
  363. package/src/components/Checkbox/checkbox.scss +2 -2
  364. package/src/components/CodeAutocompleteField/index.ts +8 -1
  365. package/src/components/ContentGroup/_contentgroup.scss +8 -2
  366. package/src/components/Dialog/Modal.tsx +5 -2
  367. package/src/components/Dialog/SimpleDialog.tsx +2 -1
  368. package/src/components/Dialog/dialog.scss +4 -1
  369. package/src/components/Form/FieldItem.tsx +3 -49
  370. package/src/components/Form/FieldSet.tsx +1 -45
  371. package/src/components/Form/form.scss +2 -2
  372. package/src/components/Icon/BaseIcon.tsx +0 -14
  373. package/src/components/Icon/IconButton.tsx +2 -1
  374. package/src/components/Icon/canonicalIconNames.tsx +2 -0
  375. package/src/components/Label/label.scss +1 -1
  376. package/src/components/Link/link.scss +1 -1
  377. package/src/components/Menu/menu.scss +4 -27
  378. package/src/components/MultiSelect/MultiSelect.tsx +23 -60
  379. package/src/components/MultiSuggestField/MultiSuggestField.stories.tsx +1 -1
  380. package/src/components/MultiSuggestField/index.ts +1 -0
  381. package/src/components/Notification/Notification.stories.tsx +4 -4
  382. package/src/components/Notification/Notification.tsx +3 -51
  383. package/src/components/Notification/notification.scss +3 -3
  384. package/src/components/OverviewItem/OverviewItemList.tsx +0 -7
  385. package/src/components/OverviewItem/overviewitem.scss +6 -9
  386. package/src/components/OverviewItem/stories/OverviewItemList.stories.tsx +0 -1
  387. package/src/components/Pagination/pagination.scss +1 -1
  388. package/src/components/Spinner/Spinner.tsx +19 -14
  389. package/src/components/Spinner/spinner.scss +5 -4
  390. package/src/components/Sticky/sticky.scss +7 -7
  391. package/src/components/SuggestField/index.ts +7 -1
  392. package/src/components/Table/Table.tsx +1 -2
  393. package/src/components/Table/TableContainer.tsx +2 -2
  394. package/src/components/Table/table.scss +34 -46
  395. package/src/components/Tabs/Tab.tsx +3 -2
  396. package/src/components/Tabs/stories/Tab.stories.tsx +1 -1
  397. package/src/components/Tabs/stories/TabPanel.stories.tsx +1 -1
  398. package/src/components/Tabs/stories/TabTitle.stories.tsx +1 -1
  399. package/src/components/Tag/tag.scss +20 -20
  400. package/src/components/TextField/SearchField.tsx +1 -6
  401. package/src/components/TextField/stories/SearchField.stories.tsx +0 -4
  402. package/src/components/TextField/textfield.scss +8 -8
  403. package/src/components/Tooltip/Tooltip.tsx +7 -4
  404. package/src/components/Tooltip/tooltip.scss +7 -3
  405. package/src/components/Typography/OverflowText.tsx +1 -6
  406. package/src/components/Typography/typography.scss +1 -1
  407. package/src/components/VisualTour/VisualTour.tsx +381 -0
  408. package/src/components/VisualTour/stories/VisualTour.stories.tsx +112 -0
  409. package/src/components/VisualTour/stories/defaultTour.ts +42 -0
  410. package/src/components/VisualTour/visualTour.scss +83 -0
  411. package/src/components/index.scss +1 -0
  412. package/src/components/index.ts +6 -8
  413. package/src/configuration/_libprefix.scss +1 -0
  414. package/src/configuration/_palettes.scss +39 -0
  415. package/src/configuration/_variables.scss +21 -20
  416. package/src/configuration/constants.ts +2 -0
  417. package/src/extensions/codemirror/CodeMirror.tsx +7 -8
  418. package/src/extensions/codemirror/_codemirror.scss +2 -2
  419. package/src/extensions/codemirror/hooks/useCodemirrorModeExtension.hooks.ts +4 -0
  420. package/src/extensions/react-flow/_config.scss +7 -6
  421. package/src/extensions/react-flow/_react-flow.scss +1 -4
  422. package/src/extensions/react-flow/_react-flow_v12.scss +215 -3
  423. package/src/extensions/react-flow/edges/EdgeBezier.tsx +47 -0
  424. package/src/extensions/react-flow/edges/EdgeDefault.tsx +51 -13
  425. package/src/extensions/react-flow/edges/EdgeDefaultV12.tsx +79 -78
  426. package/src/extensions/react-flow/edges/EdgeDefs.tsx +3 -0
  427. package/src/extensions/react-flow/edges/EdgeNew.tsx +52 -0
  428. package/src/extensions/react-flow/edges/EdgeStep.tsx +41 -6
  429. package/src/extensions/react-flow/edges/EdgeStraight.tsx +1 -0
  430. package/src/extensions/react-flow/edges/_edges.scss +10 -4
  431. package/src/extensions/react-flow/edges/stories/EdgeDefault.stories.tsx +1 -2
  432. package/src/extensions/react-flow/edges/stories/EdgeDefaultV12.stories.tsx +32 -25
  433. package/src/extensions/react-flow/edges/utils.ts +19 -1
  434. package/src/extensions/react-flow/handles/HandleDefault.tsx +40 -35
  435. package/src/extensions/react-flow/handles/_handles.scss +2 -2
  436. package/src/extensions/react-flow/handles/stories/HandleDefault.stories.tsx +4 -6
  437. package/src/extensions/react-flow/index.ts +7 -5
  438. package/src/extensions/react-flow/markers/MarkerArrowClosedInverse.tsx +3 -0
  439. package/src/extensions/react-flow/markers/ReactFlowMarkers.tsx +58 -1
  440. package/src/extensions/react-flow/markers/_markers.scss +31 -0
  441. package/src/extensions/react-flow/minimap/MiniMap.stories.tsx +12 -18
  442. package/src/extensions/react-flow/minimap/MiniMap.tsx +44 -9
  443. package/src/extensions/react-flow/minimap/MiniMapV12.tsx +39 -0
  444. package/src/extensions/react-flow/minimap/_minimap.scss +14 -0
  445. package/src/extensions/react-flow/nodes/NodeContent.tsx +135 -113
  446. package/src/extensions/react-flow/nodes/NodeDefault.tsx +9 -5
  447. package/src/extensions/react-flow/nodes/_nodes.scss +29 -23
  448. package/src/extensions/react-flow/nodes/nodeUtils.tsx +15 -6
  449. package/src/extensions/react-flow/nodes/stories/NodeDefault.stories.tsx +3 -5
  450. package/src/extensions/react-flow/versionsupport.ts +17 -15
  451. package/src/extensions/uppy/_fileupload.scss +2 -2
  452. package/src/includes/blueprintjs/_colormap.scss +150 -0
  453. package/src/includes/blueprintjs/_variables.scss +39 -9
  454. package/src/includes/carbon-components/_variables.scss +23 -8
  455. package/src/index.scss +11 -0
  456. package/src/index.ts +1 -2
  457. package/dist/cjs/components/AutoSuggestion/index.js +0 -8
  458. package/dist/cjs/components/AutoSuggestion/index.js.map +0 -1
  459. package/dist/cjs/components/AutocompleteField/index.js.map +0 -1
  460. package/dist/cjs/components/CodeAutocompleteField/CodeAutocompleteField.js +0 -32
  461. package/dist/cjs/components/CodeAutocompleteField/CodeAutocompleteField.js.map +0 -1
  462. package/dist/cjs/components/MultiSuggestField/MultiSuggestField.js +0 -37
  463. package/dist/cjs/components/MultiSuggestField/MultiSuggestField.js.map +0 -1
  464. package/dist/cjs/components/SuggestField/SuggestField.js +0 -38
  465. package/dist/cjs/components/SuggestField/SuggestField.js.map +0 -1
  466. package/dist/cjs/extensions/react-flow/edges/edgeTypes.js +0 -28
  467. package/dist/cjs/extensions/react-flow/edges/edgeTypes.js.map +0 -1
  468. package/dist/cjs/extensions/react-flow/nodes/nodeTypes.js +0 -18
  469. package/dist/cjs/extensions/react-flow/nodes/nodeTypes.js.map +0 -1
  470. package/dist/cjs/legacy-replacements/Button/AffirmativeButton.js +0 -25
  471. package/dist/cjs/legacy-replacements/Button/AffirmativeButton.js.map +0 -1
  472. package/dist/cjs/legacy-replacements/Button/Button.js +0 -65
  473. package/dist/cjs/legacy-replacements/Button/Button.js.map +0 -1
  474. package/dist/cjs/legacy-replacements/Button/DismissiveButton.js +0 -25
  475. package/dist/cjs/legacy-replacements/Button/DismissiveButton.js.map +0 -1
  476. package/dist/cjs/legacy-replacements/Button/DisruptiveButton.js +0 -25
  477. package/dist/cjs/legacy-replacements/Button/DisruptiveButton.js.map +0 -1
  478. package/dist/cjs/legacy-replacements/Checkbox/Checkbox.js +0 -58
  479. package/dist/cjs/legacy-replacements/Checkbox/Checkbox.js.map +0 -1
  480. package/dist/cjs/legacy-replacements/Radio/RadioButton.js +0 -51
  481. package/dist/cjs/legacy-replacements/Radio/RadioButton.js.map +0 -1
  482. package/dist/cjs/legacy-replacements/Tabs/Tabs.js +0 -34
  483. package/dist/cjs/legacy-replacements/Tabs/Tabs.js.map +0 -1
  484. package/dist/cjs/legacy-replacements/TextField/TextField.js +0 -75
  485. package/dist/cjs/legacy-replacements/TextField/TextField.js.map +0 -1
  486. package/dist/cjs/legacy-replacements/index.js +0 -22
  487. package/dist/cjs/legacy-replacements/index.js.map +0 -1
  488. package/dist/esm/components/AutoSuggestion/index.js +0 -4
  489. package/dist/esm/components/AutoSuggestion/index.js.map +0 -1
  490. package/dist/esm/components/AutocompleteField/index.js +0 -7
  491. package/dist/esm/components/AutocompleteField/index.js.map +0 -1
  492. package/dist/esm/components/CodeAutocompleteField/CodeAutocompleteField.js +0 -37
  493. package/dist/esm/components/CodeAutocompleteField/CodeAutocompleteField.js.map +0 -1
  494. package/dist/esm/components/MultiSuggestField/MultiSuggestField.js +0 -42
  495. package/dist/esm/components/MultiSuggestField/MultiSuggestField.js.map +0 -1
  496. package/dist/esm/components/SuggestField/SuggestField.js +0 -43
  497. package/dist/esm/components/SuggestField/SuggestField.js.map +0 -1
  498. package/dist/esm/extensions/react-flow/edges/edgeTypes.js +0 -25
  499. package/dist/esm/extensions/react-flow/edges/edgeTypes.js.map +0 -1
  500. package/dist/esm/extensions/react-flow/nodes/nodeTypes.js +0 -15
  501. package/dist/esm/extensions/react-flow/nodes/nodeTypes.js.map +0 -1
  502. package/dist/esm/legacy-replacements/Button/AffirmativeButton.js.map +0 -1
  503. package/dist/esm/legacy-replacements/Button/Button.js +0 -69
  504. package/dist/esm/legacy-replacements/Button/Button.js.map +0 -1
  505. package/dist/esm/legacy-replacements/Button/DismissiveButton.js +0 -30
  506. package/dist/esm/legacy-replacements/Button/DismissiveButton.js.map +0 -1
  507. package/dist/esm/legacy-replacements/Button/DisruptiveButton.js +0 -30
  508. package/dist/esm/legacy-replacements/Button/DisruptiveButton.js.map +0 -1
  509. package/dist/esm/legacy-replacements/Checkbox/Checkbox.js +0 -63
  510. package/dist/esm/legacy-replacements/Checkbox/Checkbox.js.map +0 -1
  511. package/dist/esm/legacy-replacements/Radio/RadioButton.js +0 -56
  512. package/dist/esm/legacy-replacements/Radio/RadioButton.js.map +0 -1
  513. package/dist/esm/legacy-replacements/Tabs/Tabs.js +0 -39
  514. package/dist/esm/legacy-replacements/Tabs/Tabs.js.map +0 -1
  515. package/dist/esm/legacy-replacements/TextField/TextField.js +0 -82
  516. package/dist/esm/legacy-replacements/TextField/TextField.js.map +0 -1
  517. package/dist/esm/legacy-replacements/index.js +0 -10
  518. package/dist/esm/legacy-replacements/index.js.map +0 -1
  519. package/dist/types/components/AutoSuggestion/index.d.ts +0 -5
  520. package/dist/types/components/AutocompleteField/index.d.ts +0 -5
  521. package/dist/types/components/CodeAutocompleteField/CodeAutocompleteField.d.ts +0 -11
  522. package/dist/types/components/MultiSuggestField/MultiSuggestField.d.ts +0 -19
  523. package/dist/types/components/SuggestField/SuggestField.d.ts +0 -21
  524. package/dist/types/extensions/react-flow/edges/edgeTypes.d.ts +0 -16
  525. package/dist/types/extensions/react-flow/nodes/nodeTypes.d.ts +0 -13
  526. package/dist/types/legacy-replacements/Button/AffirmativeButton.d.ts +0 -3
  527. package/dist/types/legacy-replacements/Button/Button.d.ts +0 -6
  528. package/dist/types/legacy-replacements/Button/DismissiveButton.d.ts +0 -3
  529. package/dist/types/legacy-replacements/Button/DisruptiveButton.d.ts +0 -3
  530. package/dist/types/legacy-replacements/Checkbox/Checkbox.d.ts +0 -3
  531. package/dist/types/legacy-replacements/Radio/RadioButton.d.ts +0 -3
  532. package/dist/types/legacy-replacements/Tabs/Tabs.d.ts +0 -24
  533. package/dist/types/legacy-replacements/TextField/TextField.d.ts +0 -3
  534. package/dist/types/legacy-replacements/index.d.ts +0 -10
  535. package/src/components/AutoSuggestion/index.ts +0 -7
  536. package/src/components/AutocompleteField/AutoCompleteField.stories.tsx +0 -14
  537. package/src/components/AutocompleteField/index.ts +0 -6
  538. package/src/components/CodeAutocompleteField/CodeAutocompleteField.tsx +0 -22
  539. package/src/components/MultiSuggestField/MultiSuggestField.tsx +0 -35
  540. package/src/components/SuggestField/SuggestField.tsx +0 -33
  541. package/src/extensions/react-flow/edges/edgeTypes.ts +0 -29
  542. package/src/extensions/react-flow/nodes/nodeTypes.ts +0 -15
  543. package/src/legacy-replacements/Button/AffirmativeButton.tsx +0 -12
  544. package/src/legacy-replacements/Button/Button.tsx +0 -80
  545. package/src/legacy-replacements/Button/DismissiveButton.tsx +0 -12
  546. package/src/legacy-replacements/Button/DisruptiveButton.tsx +0 -12
  547. package/src/legacy-replacements/Checkbox/Checkbox.tsx +0 -59
  548. package/src/legacy-replacements/Radio/RadioButton.tsx +0 -37
  549. package/src/legacy-replacements/Tabs/Tabs.stories.tsx +0 -36
  550. package/src/legacy-replacements/Tabs/Tabs.tsx +0 -69
  551. package/src/legacy-replacements/TextField/TextField.tsx +0 -89
  552. package/src/legacy-replacements/index.ts +0 -11
@@ -6,8 +6,9 @@ $eccgui-size-typo-tooltip-lineheight: $eccgui-size-typo-caption-lineheight !defa
6
6
  $eccgui-size-tooltip-width: 20em !default;
7
7
 
8
8
  // library vars
9
- $tooltip-background-color: $eccgui-color-applicationheader-text; // !default;
10
- $tooltip-text-color: $eccgui-color-applicationheader-background; // !default;
9
+ $tooltip-background-color: #{eccgui-color-var("layout", "grey", "900")};
10
+ $tooltip-text-color: #{eccgui-color-var("identity", "text", "300")};
11
+
11
12
  // $dark-tooltip-background-color: $light-gray3 !default;
12
13
  // $dark-tooltip-text-color: $dark-gray5 !default;
13
14
  $tooltip-padding-vertical: $eccgui-size-block-whitespace * 0.25; // !default;
@@ -45,7 +46,10 @@ $tooltip-padding-horizontal: $eccgui-size-block-whitespace * 0.5; // !default;
45
46
  pre,
46
47
  .#{$eccgui}-typography__contentblock pre,
47
48
  pre.#{$eccgui}-typography__text {
48
- background-color: color.invert($eccgui-color-workspace-background);
49
+ background-color: eccgui-color-mix(
50
+ eccgui-color-var("identity", "background", "900") 100% * $eccgui-opacity-ghostly,
51
+ transparent
52
+ );
49
53
  }
50
54
  }
51
55
 
@@ -1,7 +1,7 @@
1
1
  import React from "react";
2
2
 
3
- import { CLASSPREFIX as eccgui } from "../../configuration/constants";
4
3
  import { TestableComponent } from "../../components/interfaces";
4
+ import { CLASSPREFIX as eccgui } from "../../configuration/constants";
5
5
 
6
6
  export interface OverflowTextProps extends React.HTMLAttributes<HTMLElement>, TestableComponent {
7
7
  /**
@@ -25,11 +25,6 @@ export interface OverflowTextProps extends React.HTMLAttributes<HTMLElement>, Te
25
25
  * HTML element that is used for the component.
26
26
  */
27
27
  useHtmlElement?: "p" | "div" | "span";
28
- /**
29
- * Used for all other necessary properties.
30
- * @deprecated (v25) we will allow only basic HTML element properties and testing IDs
31
- */
32
- [key: string]: any;
33
28
  }
34
29
 
35
30
  /** Prevents text from overflowing. */
@@ -53,7 +53,7 @@ mark {
53
53
  styles from other stylesheets we cannot control here
54
54
  TODO: need to reevaluated when it is not used together with MDL anymore
55
55
  */
56
- background-color: rgba($eccgui-color-info-background, 1) !important;
56
+ background-color: eccgui-color-rgba($eccgui-color-info-background, 1) !important;
57
57
  }
58
58
 
59
59
  // HtmlContentBlock
@@ -0,0 +1,381 @@
1
+ import React from "react";
2
+ import { createPortal } from "react-dom";
3
+ import { Classes as BlueprintClasses } from "@blueprintjs/core";
4
+ import { createPopper } from "@popperjs/core";
5
+
6
+ import { CLASSPREFIX as eccgui } from "../../configuration/constants";
7
+ import {
8
+ Badge,
9
+ Button,
10
+ Card,
11
+ CardActions,
12
+ CardActionsAux,
13
+ CardContent,
14
+ CardHeader,
15
+ CardOptions,
16
+ CardTitle,
17
+ IconButton,
18
+ Markdown,
19
+ ModalSize,
20
+ SimpleDialog,
21
+ Spacing,
22
+ TooltipSize,
23
+ } from "../../index";
24
+
25
+ export interface VisualTourProps {
26
+ /** The steps of the tour. */
27
+ steps: VisualTourStep[];
28
+ /** Called when the tour is cancelled or closed at then end. This should usually remove the component from the outside. */
29
+ onClose: () => void;
30
+ /** Label of the button to close the tour. */
31
+ closeLabel?: string;
32
+ /** The label for the 'next' button. */
33
+ nextLabel?: string;
34
+ /** The label for the 'previous' button. */
35
+ prevLabel?: string;
36
+ /** The step target is usable, e.g. it can be clicked. */
37
+ usableStepTarget?: boolean;
38
+ /** Need to be set to `true` that the tour is displayed. */
39
+ isOpen?: boolean;
40
+ }
41
+
42
+ export interface VisualTourStep {
43
+ title: string;
44
+ /** The description or more elaborate content element that is shown in the modal/overlay. */
45
+ content: string | (() => React.JSX.Element);
46
+ /** Optional element that should be highlighted. The step content is displayed as a tooltip instead of a modal.
47
+ * In case of an array, the first match is highlighted. */
48
+ highlightElementQuery?: string | string[];
49
+ /** The texts used in the step, e.g. when custom layouts are rendered, these will be used for the text strings. */
50
+ texts?: Record<string, string>;
51
+ /** An image URL. This will be displayed in the step description. */
52
+ image?: string;
53
+ /** The size of the tooltip or modal. */
54
+ size?: TooltipSize | ModalSize;
55
+ /** The step target is usable, e.g. it can be clicked. Overwrites the setting in `<VisualTour/>`. */
56
+ usableStepTarget?: boolean;
57
+ }
58
+
59
+ /** This should be used for defining steps in a separate object/file. Use with 'satisfies' after the object definition. */
60
+ export type VisualTourStepDefinitions = Record<string, Partial<VisualTourStep>>;
61
+
62
+ const highlightElementBaseClass = `${eccgui}-visual-tour__highlighted-element`;
63
+
64
+ /** A visual tour multi-step tour of the current view. */
65
+ export const VisualTour = ({
66
+ steps,
67
+ onClose,
68
+ closeLabel = "Close",
69
+ nextLabel = "Next",
70
+ prevLabel = "Back",
71
+ usableStepTarget = false,
72
+ isOpen = false,
73
+ }: VisualTourProps) => {
74
+ if (isOpen === false) {
75
+ return null;
76
+ }
77
+
78
+ const [currentStepIndex, setCurrentStepIndex] = React.useState<number>(0);
79
+ const [currentStepComponent, setCurrentStepComponent] = React.useState<React.JSX.Element | null>(null);
80
+
81
+ React.useEffect(() => {
82
+ const closeTour = () => {
83
+ // clear observer and disconnect
84
+ if (lastObserver) {
85
+ lastObserver.takeRecords();
86
+ lastObserver.disconnect();
87
+ }
88
+ // empty step
89
+ setCurrentStepComponent(null);
90
+ // remove highlight classes
91
+ document.querySelector(`.${highlightElementBaseClass}`)?.classList.remove(highlightElementBaseClass);
92
+ document
93
+ .querySelector(`.${highlightElementBaseClass}--useable`)
94
+ ?.classList.remove(`${highlightElementBaseClass}--useable`);
95
+ // call callback function from outside
96
+ onClose();
97
+ };
98
+
99
+ const step = steps[currentStepIndex];
100
+ if (!step) {
101
+ // This should not happen
102
+ closeTour();
103
+ return;
104
+ }
105
+ const highlightElementClass = (
106
+ typeof step["usableStepTarget"] === "undefined" ? usableStepTarget : step["usableStepTarget"]
107
+ )
108
+ ? `${highlightElementBaseClass}--useable`
109
+ : highlightElementBaseClass;
110
+ const hasNextStep = currentStepIndex + 1 < steps.length;
111
+ const hasPreviousStep = currentStepIndex > 0;
112
+ // Configure optional highlighting
113
+ let elementToHighlight: HTMLElement | null = null;
114
+ let lastObserver: MutationObserver | null = null;
115
+ const setStepComponent = () => {
116
+ const stepDisplay = (
117
+ <Badge tagProps={{ emphasis: "weaker" }} size="large">
118
+ {` ${currentStepIndex + 1}/${steps.length} `}
119
+ </Badge>
120
+ );
121
+ const closeButton = <IconButton name="navigation-close" text={closeLabel} onClick={closeTour} />;
122
+ const titleOptions = (
123
+ <>
124
+ {stepDisplay}
125
+ {closeButton}
126
+ </>
127
+ );
128
+ const actionButtons = [
129
+ hasNextStep ? (
130
+ <Button
131
+ key={"next"}
132
+ variant="outlined"
133
+ intent={"primary"}
134
+ onClick={() => {
135
+ setCurrentStepIndex(currentStepIndex + 1);
136
+ }}
137
+ rightIcon={"navigation-next"}
138
+ >
139
+ {nextLabel}: {steps[currentStepIndex + 1].title}
140
+ </Button>
141
+ ) : (
142
+ <Button
143
+ key={"close"}
144
+ text={closeLabel}
145
+ onClick={closeTour}
146
+ variant="outlined"
147
+ intent={"primary"}
148
+ rightIcon={"navigation-close"}
149
+ />
150
+ ),
151
+ hasPreviousStep ? (
152
+ <CardActionsAux>
153
+ <Button
154
+ key={"prev"}
155
+ variant="outlined"
156
+ onClick={() => {
157
+ setCurrentStepIndex(currentStepIndex - 1);
158
+ }}
159
+ icon={"navigation-previous"}
160
+ >
161
+ {prevLabel}
162
+ </Button>
163
+ </CardActionsAux>
164
+ ) : null,
165
+ ];
166
+ // TODO: What to do if an element should have been highlighted, but none was found?
167
+ if (elementToHighlight) {
168
+ setCurrentStepComponent(
169
+ <StepPopover
170
+ highlightedElement={elementToHighlight}
171
+ titleOption={titleOptions}
172
+ actionButtons={actionButtons}
173
+ step={step}
174
+ />
175
+ );
176
+ } else {
177
+ setCurrentStepComponent(
178
+ <StepModal
179
+ titleOption={titleOptions}
180
+ actionButtons={actionButtons}
181
+ step={step}
182
+ onClose={closeTour}
183
+ />
184
+ );
185
+ }
186
+ };
187
+ const addElementHighlighting = () => {
188
+ if (step.highlightElementQuery) {
189
+ const queries: string[] =
190
+ typeof step.highlightElementQuery === "string"
191
+ ? [step.highlightElementQuery]
192
+ : step.highlightElementQuery;
193
+ queries.forEach((query) => {
194
+ if (elementToHighlight == null) {
195
+ elementToHighlight = document.querySelector(query);
196
+ }
197
+ });
198
+ } else {
199
+ elementToHighlight = null;
200
+ }
201
+ if (elementToHighlight) {
202
+ // Typescript for some reason incorrectly infers the type of elementToHighlight as never
203
+ (elementToHighlight as HTMLElement).classList.add(highlightElementClass);
204
+ (elementToHighlight as HTMLElement).scrollIntoView({
205
+ behavior: "smooth",
206
+ block: "center",
207
+ });
208
+ if (lastObserver) {
209
+ lastObserver.disconnect();
210
+ }
211
+ lastObserver = new MutationObserver(function () {
212
+ // Re-new element highlighting
213
+ if (step.highlightElementQuery) {
214
+ if (!document.body.contains(elementToHighlight)) {
215
+ // Element has been removed or replaced
216
+ elementToHighlight = null;
217
+ addElementHighlighting();
218
+ } else if (!elementToHighlight?.classList.contains(highlightElementClass)) {
219
+ // Only the classes have been removed
220
+ elementToHighlight?.classList.add(highlightElementClass);
221
+ }
222
+ }
223
+ });
224
+ lastObserver.observe(document.body, { childList: true, subtree: true });
225
+ }
226
+ setStepComponent();
227
+ };
228
+ addElementHighlighting();
229
+ return () => {
230
+ // Remove previous element highlight
231
+ document.querySelector(`.${highlightElementClass}`)?.classList.remove(highlightElementClass);
232
+ if (lastObserver) {
233
+ lastObserver.disconnect();
234
+ }
235
+ };
236
+ }, [currentStepIndex, usableStepTarget]);
237
+
238
+ return currentStepComponent;
239
+ };
240
+
241
+ interface StepModalProps {
242
+ step: VisualTourStep;
243
+ // Current step starting with 1
244
+ titleOption: React.JSX.Element;
245
+ // Close the visual tour
246
+ onClose: () => void;
247
+ // The navigation buttons
248
+ actionButtons: (React.JSX.Element | null)[];
249
+ }
250
+
251
+ // Main content of a step
252
+ const StepContent = ({ step }: { step: VisualTourStep }) => {
253
+ return (
254
+ <>
255
+ {step.image && (
256
+ <>
257
+ <img src={step.image} />
258
+ <Spacing size="small" />
259
+ </>
260
+ )}
261
+ {typeof step.content === "string" ? <Markdown>{step.content}</Markdown> : step.content()}
262
+ </>
263
+ );
264
+ };
265
+
266
+ /** Modal that is displayed for a step. */
267
+ const StepModal = ({ step, titleOption, onClose, actionButtons }: StepModalProps) => {
268
+ return (
269
+ <SimpleDialog
270
+ title={step.title}
271
+ headerOptions={titleOption}
272
+ isOpen={true}
273
+ preventSimpleClosing={true}
274
+ onClose={onClose}
275
+ actions={actionButtons}
276
+ size={step.size === "medium" ? "regular" : step.size ?? "regular"}
277
+ overlayClassName={`${eccgui}-visual-tour__dialog`}
278
+ >
279
+ <StepContent step={step} />
280
+ </SimpleDialog>
281
+ );
282
+ };
283
+
284
+ interface StepPopoverProps {
285
+ highlightedElement: Element;
286
+ step: VisualTourStep;
287
+ // Current step starting with 1
288
+ titleOption: React.JSX.Element;
289
+ // The navigation buttons
290
+ actionButtons: (React.JSX.Element | null)[];
291
+ }
292
+
293
+ /** Popover that is displayed and points at the highlighted element. */
294
+ const StepPopover = ({ highlightedElement, step, titleOption, actionButtons }: StepPopoverProps) => {
295
+ const tooltipRef = React.useCallback(
296
+ (tooltip: HTMLDivElement | null) => {
297
+ if (tooltip) {
298
+ createPopper(highlightedElement, tooltip, {
299
+ placement: "auto",
300
+ modifiers: [
301
+ {
302
+ name: "offset",
303
+ options: {
304
+ offset: [0, 15],
305
+ },
306
+ },
307
+ ],
308
+ });
309
+ }
310
+ },
311
+ [highlightedElement]
312
+ );
313
+
314
+ const backdropRef = React.useCallback(
315
+ (backdrop: HTMLDivElement | null) => {
316
+ const highlightStencil = () => {
317
+ const targetRect = highlightedElement.getBoundingClientRect();
318
+ backdrop!.style.left = `calc(${
319
+ targetRect.left + window.scrollX + "px"
320
+ } - var(--${eccgui}-visual-tour-focus-padding))`;
321
+ backdrop!.style.top = `calc(${
322
+ targetRect.top + window.scrollY + "px"
323
+ } - var(--${eccgui}-visual-tour-focus-padding))`;
324
+ backdrop!.style.width = `calc(${
325
+ targetRect.width + "px"
326
+ } + 2 * var(--${eccgui}-visual-tour-focus-padding))`;
327
+ backdrop!.style.height = `calc(${
328
+ targetRect.height + "px"
329
+ } + 2 * var(--${eccgui}-visual-tour-focus-padding))`;
330
+ };
331
+ if (backdrop) {
332
+ highlightStencil();
333
+ window.addEventListener("resize", highlightStencil);
334
+ return () => {
335
+ window.removeEventListener("resize", highlightStencil);
336
+ };
337
+ }
338
+ return;
339
+ },
340
+ [highlightedElement]
341
+ );
342
+
343
+ return createPortal(
344
+ <div className={`${eccgui}-visual-tour`}>
345
+ <div className={`${eccgui}-visual-tour__focushelper`} ref={backdropRef} />
346
+ <div>
347
+ <div className={`${eccgui}-visual-tour__backdrop`} />
348
+ </div>
349
+ <div
350
+ className={
351
+ `${eccgui}-visual-tour__overlay` +
352
+ ` ${eccgui}-visual-tour__overlay--${step.size ?? "large"}` +
353
+ ` ${BlueprintClasses.POPOVER}`
354
+ }
355
+ role="tooltip"
356
+ ref={tooltipRef}
357
+ >
358
+ <div
359
+ className={`${eccgui}-visual-tour__arrow ${BlueprintClasses.POPOVER_ARROW}`}
360
+ data-popper-arrow
361
+ aria-hidden
362
+ />
363
+ <div className={`${BlueprintClasses.POPOVER_CONTENT} ${eccgui}-visual-tour__overlay__content`}>
364
+ <Card isOnlyLayout elevation={-1} whitespaceAmount="small">
365
+ <CardHeader>
366
+ <CardTitle>{step.title}</CardTitle>
367
+ <CardOptions>{titleOption}</CardOptions>
368
+ </CardHeader>
369
+ <CardContent>
370
+ <StepContent step={step} />
371
+ </CardContent>
372
+ <CardActions inverseDirection>{actionButtons}</CardActions>
373
+ </Card>
374
+ </div>
375
+ </div>
376
+ </div>,
377
+ document.body
378
+ );
379
+ };
380
+
381
+ export default VisualTour;
@@ -0,0 +1,112 @@
1
+ import React from "react";
2
+ import { Meta, StoryFn } from "@storybook/react";
3
+
4
+ import {
5
+ Button,
6
+ Icon,
7
+ OverflowText,
8
+ OverviewItem,
9
+ OverviewItemDepiction,
10
+ OverviewItemDescription,
11
+ OverviewItemLine,
12
+ Toolbar,
13
+ ToolbarSection,
14
+ VisualTour,
15
+ VisualTourProps,
16
+ } from "../../../../index";
17
+
18
+ import stepDefinitionsEn from "./defaultTour";
19
+
20
+ export default {
21
+ title: "Components/VisualTour",
22
+ component: VisualTour,
23
+ argTypes: {},
24
+ } as Meta<typeof VisualTour>;
25
+
26
+ const Template: StoryFn<typeof VisualTour> = (args: VisualTourProps) => {
27
+ const [isOpen, setIsOpen] = React.useState<boolean | undefined>();
28
+
29
+ return (
30
+ <div style={{ minHeight: "600px", minWidth: "800px" }}>
31
+ <Toolbar id={"tourContainer"}>
32
+ <ToolbarSection canGrow={true}>
33
+ <span id={"textSection"}>Some text</span>
34
+ </ToolbarSection>
35
+ <ToolbarSection id={"buttonSection"}>
36
+ <Button id={"actionA"}>Action A</Button>
37
+ <Button id={"actionB"}>Action B</Button>
38
+ <Button id={"startTour"} intent={"primary"} onClick={() => setIsOpen(true)}>
39
+ Start tour!
40
+ </Button>
41
+ </ToolbarSection>
42
+ </Toolbar>
43
+ <div id="actionC" style={{ margin: "1rem", padding: "1rem", border: "dotted 1px lightgray" }}>
44
+ Some other element for the tour.
45
+ </div>
46
+ <div style={{ height: "100vh" }} />
47
+ <div id="actionD" style={{ margin: "1rem", padding: "1rem", border: "dotted 1px lightgray" }}>
48
+ Another element for the tour, not visible at first.
49
+ </div>
50
+ <VisualTour
51
+ {...args}
52
+ onClose={() => setIsOpen(false)}
53
+ isOpen={typeof isOpen !== "undefined" ? isOpen : args.isOpen}
54
+ />
55
+ </div>
56
+ );
57
+ };
58
+
59
+ const stepDefinitions = stepDefinitionsEn;
60
+
61
+ export const Default = Template.bind({});
62
+ const defaultArgs: VisualTourProps = {
63
+ steps: [
64
+ {
65
+ ...stepDefinitions.firstStep,
66
+ },
67
+ {
68
+ ...stepDefinitions.customContent,
69
+ content: () => {
70
+ const texts = stepDefinitions.customContent.texts;
71
+ return (
72
+ <OverviewItem>
73
+ <OverviewItemDepiction>
74
+ <Icon name={"item-info"} />
75
+ </OverviewItemDepiction>
76
+ <OverviewItemDescription>
77
+ <OverviewItemLine>
78
+ <OverflowText>{texts.firstLine}</OverflowText>
79
+ </OverviewItemLine>
80
+ <OverviewItemLine>
81
+ <OverflowText>{texts.secondLine}</OverflowText>
82
+ </OverviewItemLine>
83
+ </OverviewItemDescription>
84
+ </OverviewItem>
85
+ );
86
+ },
87
+ },
88
+ {
89
+ ...stepDefinitions.highlightElementA,
90
+ highlightElementQuery: "#actionA",
91
+ },
92
+ {
93
+ ...stepDefinitions.highlightElementB,
94
+ highlightElementQuery: "#actionB",
95
+ },
96
+ {
97
+ ...stepDefinitions.highlightElementLeft,
98
+ highlightElementQuery: "#textSection",
99
+ },
100
+ {
101
+ ...stepDefinitions.highlightElementC,
102
+ highlightElementQuery: "#actionC",
103
+ },
104
+ {
105
+ ...stepDefinitions.highlightElementD,
106
+ highlightElementQuery: "#actionD",
107
+ },
108
+ ],
109
+ onClose: () => {},
110
+ isOpen: false,
111
+ };
112
+ Default.args = defaultArgs;
@@ -0,0 +1,42 @@
1
+ import { VisualTourStepDefinitions } from "../VisualTour";
2
+
3
+ const definition = {
4
+ firstStep: {
5
+ title: "First step",
6
+ content: "This is a demonstration of a visual tour. A step can be simple text.",
7
+ },
8
+ customContent: {
9
+ title: "Custom content",
10
+ texts: {
11
+ firstLine: "Or a step can be arbitrary content that is displayed in a modal by default.",
12
+ secondLine: "The developer can choose what's appropriate.",
13
+ },
14
+ },
15
+ highlightElementA: {
16
+ title: "Highlight element A",
17
+ usableStepTarget: false,
18
+ content:
19
+ "It's possible to highlight specific elements on a page. The step content is then displayed in a kind of tooltip instead of a modal.",
20
+ },
21
+ highlightElementB: {
22
+ title: "Highlight element B",
23
+ usableStepTarget: true,
24
+ content: "Context overlay for another highlighted element.",
25
+ },
26
+ highlightElementLeft: {
27
+ title: "Highlight element on the left & portrait image",
28
+ image: "https://upload.wikimedia.org/wikipedia/commons/a/a3/Knowledge_graph_installation_at_the_Futurium_Berlin_21.jpg",
29
+ content: "The tooltip is placed where it is best seen by the user.",
30
+ },
31
+ highlightElementC: {
32
+ title: "Highlight element C & landscape image",
33
+ image: "https://upload.wikimedia.org/wikipedia/commons/1/15/Knowledge_graph_installation_at_the_Futurium_Berlin.jpg",
34
+ content: "Element outside tour container.",
35
+ },
36
+ highlightElementD: {
37
+ title: "Highlight element D",
38
+ content: "Element not visible at first.",
39
+ },
40
+ } satisfies VisualTourStepDefinitions;
41
+
42
+ export default definition;
@@ -0,0 +1,83 @@
1
+ .#{$eccgui}-visual-tour {
2
+ opacity: 1;
3
+
4
+ --#{$eccgui}-visual-tour-focus-padding: #{0.5 * $eccgui-size-block-whitespace};
5
+ }
6
+
7
+ [class*="#{$eccgui}-visual-tour__highlighted-element"] {
8
+ .#{$eccgui}-overviewitem__actions--hiddeninteractions:has(&) {
9
+ display: inherit;
10
+ }
11
+ }
12
+
13
+ .#{$eccgui}-visual-tour__highlighted-element--useable {
14
+ position: relative;
15
+ z-index: 999999 !important;
16
+ }
17
+
18
+ .#{$eccgui}-visual-tour__focushelper {
19
+ position: absolute;
20
+ z-index: 8001; // 1 over application header
21
+ box-sizing: border-box;
22
+ border: 2px solid $eccgui-color-accent;
23
+ border-radius: var(--#{$eccgui}-visual-tour-focus-padding);
24
+ box-shadow: 0 0 0 10000px $eccgui-color-modal-backdrop;
25
+ }
26
+
27
+ .#{$eccgui}-visual-tour__backdrop {
28
+ position: fixed;
29
+ inset: 0;
30
+ box-sizing: content-box;
31
+ opacity: 0;
32
+ }
33
+
34
+ .#{$eccgui}-visual-tour__arrow {
35
+ &::before {
36
+ background: $card-background-color;
37
+ }
38
+
39
+ .#{$eccgui}-visual-tour__overlay[data-popper-placement="top"] & {
40
+ bottom: -0.5 * $eccgui-size-block-whitespace;
41
+ }
42
+ .#{$eccgui}-visual-tour__overlay[data-popper-placement="right"] & {
43
+ left: -0.5 * $eccgui-size-block-whitespace;
44
+ }
45
+ .#{$eccgui}-visual-tour__overlay[data-popper-placement="bottom"] & {
46
+ top: -0.5 * $eccgui-size-block-whitespace;
47
+ }
48
+ .#{$eccgui}-visual-tour__overlay[data-popper-placement="left"] & {
49
+ right: -0.5 * $eccgui-size-block-whitespace;
50
+ }
51
+ }
52
+
53
+ .#{$eccgui}-visual-tour__overlay {
54
+ z-index: 8002; // 2 over application header
55
+ &--small {
56
+ @extend .#{$eccgui}-tooltip--small;
57
+ }
58
+
59
+ &--medium {
60
+ @extend .#{$eccgui}-tooltip--medium;
61
+ }
62
+
63
+ &--large {
64
+ @extend .#{$eccgui}-tooltip--large;
65
+ }
66
+ }
67
+
68
+ .#{$eccgui}-card__content {
69
+ .#{$eccgui}-visual-tour__overlay__content & {
70
+ max-height: 45vh;
71
+ }
72
+ .#{$eccgui}-visual-tour__overlay__content &,
73
+ .#{$eccgui}-visual-tour__dialog & {
74
+ img {
75
+ display: block;
76
+ width: auto;
77
+ max-width: 100%;
78
+ height: auto;
79
+ max-height: 40vh;
80
+ margin: 0 auto;
81
+ }
82
+ }
83
+ }
@@ -35,6 +35,7 @@
35
35
  @import "./TagInput/taginput";
36
36
  @import "./Toolbar/toolbar";
37
37
  @import "./Tooltip/tooltip";
38
+ @import "./VisualTour/visualTour";
38
39
  @import "./Tree/tree";
39
40
  @import "./Typography/typography";
40
41
  @import "./Workspace/workspace";