@xxmachina/components 19.0.0-preview.9 → 19.1.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 (256) hide show
  1. package/extras/flow/index.d.ts +183 -0
  2. package/features/command/index.d.ts +67 -1
  3. package/features/query/index.d.ts +117 -1
  4. package/fesm2022/xxmachina-components-extras-flow.mjs +389 -0
  5. package/fesm2022/xxmachina-components-extras-flow.mjs.map +1 -0
  6. package/fesm2022/xxmachina-components-features-command.mjs +7 -8
  7. package/fesm2022/xxmachina-components-features-command.mjs.map +1 -1
  8. package/fesm2022/xxmachina-components-features-query.mjs +120 -96
  9. package/fesm2022/xxmachina-components-features-query.mjs.map +1 -1
  10. package/fesm2022/xxmachina-components-groups-command-form.mjs +3 -3
  11. package/fesm2022/xxmachina-components-groups-command-form.mjs.map +1 -1
  12. package/fesm2022/xxmachina-components-groups-query-form.mjs +110 -24
  13. package/fesm2022/xxmachina-components-groups-query-form.mjs.map +1 -1
  14. package/fesm2022/xxmachina-components-molecules-calendar-paginator.mjs +4 -4
  15. package/fesm2022/xxmachina-components-molecules-calendar-paginator.mjs.map +1 -1
  16. package/fesm2022/xxmachina-components-molecules-daily-cell.mjs +13 -13
  17. package/fesm2022/xxmachina-components-molecules-daily-cell.mjs.map +1 -1
  18. package/fesm2022/xxmachina-components-molecules-weekly-header.mjs +5 -5
  19. package/fesm2022/xxmachina-components-molecules-weekly-header.mjs.map +1 -1
  20. package/fesm2022/xxmachina-components-organisms-calendar-section.mjs +5 -5
  21. package/fesm2022/xxmachina-components-organisms-calendar-section.mjs.map +1 -1
  22. package/fesm2022/xxmachina-components-organisms-event-input-section.mjs +3 -3
  23. package/fesm2022/xxmachina-components-organisms-event-input-section.mjs.map +1 -1
  24. package/fesm2022/xxmachina-components-organisms-terminal-input-section.mjs +123 -0
  25. package/fesm2022/xxmachina-components-organisms-terminal-input-section.mjs.map +1 -0
  26. package/fesm2022/xxmachina-components-organisms-video-trimmer-section.mjs +6 -6
  27. package/fesm2022/xxmachina-components-organisms-video-trimmer-section.mjs.map +1 -1
  28. package/fesm2022/xxmachina-components-organisms-xterm.mjs +94 -0
  29. package/fesm2022/xxmachina-components-organisms-xterm.mjs.map +1 -0
  30. package/fesm2022/xxmachina-components-pages-command.mjs +196 -48
  31. package/fesm2022/xxmachina-components-pages-command.mjs.map +1 -1
  32. package/fesm2022/xxmachina-components-pages-query.mjs +394 -92
  33. package/fesm2022/xxmachina-components-pages-query.mjs.map +1 -1
  34. package/fesm2022/xxmachina-components-pages-thread.mjs +176 -0
  35. package/fesm2022/xxmachina-components-pages-thread.mjs.map +1 -0
  36. package/fesm2022/{xxmachina-components-routes-commands-command.routes-CeRVzy3Z.mjs → xxmachina-components-routes-commands-command.routes-CSwIdXZg.mjs} +4 -11
  37. package/fesm2022/xxmachina-components-routes-commands-command.routes-CSwIdXZg.mjs.map +1 -0
  38. package/fesm2022/{xxmachina-components-routes-commands-pages.routes-Cm6Yd40h.mjs → xxmachina-components-routes-commands-pages.routes-j2xVop4W.mjs} +4 -4
  39. package/fesm2022/xxmachina-components-routes-commands-pages.routes-j2xVop4W.mjs.map +1 -0
  40. package/fesm2022/xxmachina-components-routes-commands.mjs +8 -3
  41. package/fesm2022/xxmachina-components-routes-commands.mjs.map +1 -1
  42. package/fesm2022/xxmachina-components-routes-pages.mjs +3 -1
  43. package/fesm2022/xxmachina-components-routes-pages.mjs.map +1 -1
  44. package/fesm2022/xxmachina-components-routes-preloading.mjs +3 -3
  45. package/fesm2022/xxmachina-components-routes-preloading.mjs.map +1 -1
  46. package/fesm2022/xxmachina-components-routes-queries-pages.routes-CfrglCIL.mjs +9 -0
  47. package/fesm2022/xxmachina-components-routes-queries-pages.routes-CfrglCIL.mjs.map +1 -0
  48. package/fesm2022/xxmachina-components-routes-queries.mjs +16 -7
  49. package/fesm2022/xxmachina-components-routes-queries.mjs.map +1 -1
  50. package/fesm2022/{xxmachina-components-routes-query-pages.routes-H2vrF7kQ.mjs → xxmachina-components-routes-query-pages.routes-CxTbOJDQ.mjs} +9 -9
  51. package/fesm2022/xxmachina-components-routes-query-pages.routes-CxTbOJDQ.mjs.map +1 -0
  52. package/fesm2022/xxmachina-components-routes-query.mjs +5 -3
  53. package/fesm2022/xxmachina-components-routes-query.mjs.map +1 -1
  54. package/fesm2022/{xxmachina-components-routes-resources-pages.routes-BSjrrV1g.mjs → xxmachina-components-routes-resources-pages.routes-CzjQOxwT.mjs} +4 -4
  55. package/fesm2022/xxmachina-components-routes-resources-pages.routes-CzjQOxwT.mjs.map +1 -0
  56. package/fesm2022/{xxmachina-components-routes-resources-resource.routes-DzGgwitX.mjs → xxmachina-components-routes-resources-resource.routes-C5KpB3KM.mjs} +3 -3
  57. package/fesm2022/xxmachina-components-routes-resources-resource.routes-C5KpB3KM.mjs.map +1 -0
  58. package/fesm2022/xxmachina-components-routes-resources.mjs +8 -6
  59. package/fesm2022/xxmachina-components-routes-resources.mjs.map +1 -1
  60. package/fesm2022/xxmachina-components-routes-side-chat.mjs +4 -112
  61. package/fesm2022/xxmachina-components-routes-side-chat.mjs.map +1 -1
  62. package/fesm2022/xxmachina-components-routes-side.mjs +4 -2
  63. package/fesm2022/xxmachina-components-routes-side.mjs.map +1 -1
  64. package/fesm2022/xxmachina-components-routes-transformer.mjs +99 -0
  65. package/fesm2022/xxmachina-components-routes-transformer.mjs.map +1 -0
  66. package/fesm2022/xxmachina-components-routes-transformers-pages.routes-02pVsNas.mjs +9 -0
  67. package/fesm2022/xxmachina-components-routes-transformers-pages.routes-02pVsNas.mjs.map +1 -0
  68. package/fesm2022/xxmachina-components-routes-transformers.mjs +75 -0
  69. package/fesm2022/xxmachina-components-routes-transformers.mjs.map +1 -0
  70. package/fesm2022/xxmachina-components-routes.mjs +8 -4
  71. package/fesm2022/xxmachina-components-routes.mjs.map +1 -1
  72. package/fesm2022/xxmachina-components-services-app.mjs +30 -0
  73. package/fesm2022/xxmachina-components-services-app.mjs.map +1 -0
  74. package/fesm2022/xxmachina-components-services-assistant.mjs +3 -3
  75. package/fesm2022/xxmachina-components-services-assistant.mjs.map +1 -1
  76. package/fesm2022/xxmachina-components-services-calendar.mjs +3 -3
  77. package/fesm2022/xxmachina-components-services-calendar.mjs.map +1 -1
  78. package/fesm2022/xxmachina-components-services-command.mjs +11 -10
  79. package/fesm2022/xxmachina-components-services-command.mjs.map +1 -1
  80. package/fesm2022/xxmachina-components-services-context.mjs +23 -0
  81. package/fesm2022/xxmachina-components-services-context.mjs.map +1 -0
  82. package/fesm2022/xxmachina-components-services-contract.mjs +4 -4
  83. package/fesm2022/xxmachina-components-services-contract.mjs.map +1 -1
  84. package/fesm2022/xxmachina-components-services-debug.mjs +3 -3
  85. package/fesm2022/xxmachina-components-services-debug.mjs.map +1 -1
  86. package/fesm2022/xxmachina-components-services-forms-query.mjs +13 -3
  87. package/fesm2022/xxmachina-components-services-forms-query.mjs.map +1 -1
  88. package/fesm2022/xxmachina-components-services-forms-schedule.mjs +4 -4
  89. package/fesm2022/xxmachina-components-services-forms-schedule.mjs.map +1 -1
  90. package/fesm2022/xxmachina-components-services-forms-variables.mjs +34 -0
  91. package/fesm2022/xxmachina-components-services-forms-variables.mjs.map +1 -0
  92. package/fesm2022/xxmachina-components-services-graphql.mjs +7 -6
  93. package/fesm2022/xxmachina-components-services-graphql.mjs.map +1 -1
  94. package/fesm2022/xxmachina-components-services-invoice.mjs +7 -4
  95. package/fesm2022/xxmachina-components-services-invoice.mjs.map +1 -1
  96. package/fesm2022/xxmachina-components-services-json-schema.mjs +3 -3
  97. package/fesm2022/xxmachina-components-services-json-schema.mjs.map +1 -1
  98. package/fesm2022/xxmachina-components-services-link.mjs +3 -3
  99. package/fesm2022/xxmachina-components-services-link.mjs.map +1 -1
  100. package/fesm2022/xxmachina-components-services-message.mjs +50 -0
  101. package/fesm2022/xxmachina-components-services-message.mjs.map +1 -0
  102. package/fesm2022/xxmachina-components-services-openai.mjs +113 -0
  103. package/fesm2022/xxmachina-components-services-openai.mjs.map +1 -0
  104. package/fesm2022/xxmachina-components-services-openapi.mjs +5 -5
  105. package/fesm2022/xxmachina-components-services-openapi.mjs.map +1 -1
  106. package/fesm2022/xxmachina-components-services-order.mjs +4 -4
  107. package/fesm2022/xxmachina-components-services-order.mjs.map +1 -1
  108. package/fesm2022/xxmachina-components-services-partner.mjs +4 -4
  109. package/fesm2022/xxmachina-components-services-partner.mjs.map +1 -1
  110. package/fesm2022/xxmachina-components-services-query.mjs +32 -45
  111. package/fesm2022/xxmachina-components-services-query.mjs.map +1 -1
  112. package/fesm2022/xxmachina-components-services-recording.mjs +3 -3
  113. package/fesm2022/xxmachina-components-services-recording.mjs.map +1 -1
  114. package/fesm2022/xxmachina-components-services-schedule.mjs +10 -7
  115. package/fesm2022/xxmachina-components-services-schedule.mjs.map +1 -1
  116. package/fesm2022/xxmachina-components-services-thread.mjs +5 -7
  117. package/fesm2022/xxmachina-components-services-thread.mjs.map +1 -1
  118. package/fesm2022/xxmachina-components-services-transformer.mjs +31 -0
  119. package/fesm2022/xxmachina-components-services-transformer.mjs.map +1 -0
  120. package/fesm2022/xxmachina-components-services-youtube.mjs +3 -3
  121. package/fesm2022/xxmachina-components-services-youtube.mjs.map +1 -1
  122. package/fesm2022/xxmachina-components-templates-agent.mjs +549 -0
  123. package/fesm2022/xxmachina-components-templates-agent.mjs.map +1 -0
  124. package/fesm2022/xxmachina-components-templates-background.mjs +202 -5
  125. package/fesm2022/xxmachina-components-templates-background.mjs.map +1 -1
  126. package/fesm2022/xxmachina-components-templates-invoice-iframe.mjs +3 -3
  127. package/fesm2022/xxmachina-components-templates-invoice-iframe.mjs.map +1 -1
  128. package/fesm2022/xxmachina-components-templates-scheduler.mjs +5 -5
  129. package/fesm2022/xxmachina-components-templates-scheduler.mjs.map +1 -1
  130. package/fesm2022/xxmachina-components-templates-video.mjs +6 -6
  131. package/fesm2022/xxmachina-components-templates-video.mjs.map +1 -1
  132. package/fesm2022/xxmachina-components-validators-query.mjs +2 -2
  133. package/fesm2022/xxmachina-components-validators-query.mjs.map +1 -1
  134. package/fesm2022/xxmachina-components.mjs +218 -39
  135. package/fesm2022/xxmachina-components.mjs.map +1 -1
  136. package/groups/command-form/index.d.ts +13 -1
  137. package/groups/query-form/index.d.ts +54 -1
  138. package/index.d.ts +66 -3
  139. package/molecules/calendar-paginator/index.d.ts +14 -1
  140. package/molecules/daily-cell/index.d.ts +35 -1
  141. package/molecules/weekly-header/index.d.ts +11 -1
  142. package/organisms/calendar-section/index.d.ts +25 -1
  143. package/organisms/event-input-section/index.d.ts +45 -1
  144. package/organisms/terminal-input-section/index.d.ts +37 -0
  145. package/organisms/video-trimmer-section/index.d.ts +30 -1
  146. package/organisms/xterm/index.d.ts +23 -0
  147. package/package.json +65 -17
  148. package/pages/command/index.d.ts +217 -1
  149. package/pages/query/index.d.ts +292 -1
  150. package/pages/thread/index.d.ts +109 -0
  151. package/routes/commands/index.d.ts +5 -1
  152. package/routes/index.d.ts +4 -1
  153. package/routes/pages/index.d.ts +5 -1
  154. package/routes/preloading/index.d.ts +11 -1
  155. package/routes/queries/index.d.ts +5 -1
  156. package/routes/query/index.d.ts +5 -1
  157. package/routes/resources/index.d.ts +5 -1
  158. package/routes/side/chat/index.d.ts +5 -2
  159. package/routes/side/index.d.ts +5 -1
  160. package/routes/transformer/index.d.ts +5 -0
  161. package/routes/transformers/index.d.ts +5 -0
  162. package/services/app/index.d.ts +17 -0
  163. package/services/assistant/index.d.ts +20 -1
  164. package/services/calendar/index.d.ts +13 -1
  165. package/services/command/index.d.ts +54 -1
  166. package/services/context/index.d.ts +10 -0
  167. package/services/contract/index.d.ts +11 -1
  168. package/services/debug/index.d.ts +14 -1
  169. package/services/forms/query/index.d.ts +45 -1
  170. package/services/forms/schedule/index.d.ts +42 -1
  171. package/services/forms/variables/index.d.ts +12 -0
  172. package/services/graphql/index.d.ts +20 -1
  173. package/services/invoice/index.d.ts +19 -1
  174. package/services/json-schema/index.d.ts +15 -1
  175. package/services/link/index.d.ts +13 -1
  176. package/services/message/index.d.ts +23 -0
  177. package/services/openai/index.d.ts +35 -0
  178. package/services/openapi/index.d.ts +17 -1
  179. package/services/order/index.d.ts +13 -1
  180. package/services/partner/index.d.ts +11 -1
  181. package/services/query/index.d.ts +42 -1
  182. package/services/recording/index.d.ts +20 -1
  183. package/services/schedule/index.d.ts +26 -1
  184. package/services/thread/index.d.ts +30 -1
  185. package/services/transformer/index.d.ts +19 -0
  186. package/services/youtube/index.d.ts +10 -1
  187. package/templates/agent/index.d.ts +54 -0
  188. package/templates/background/index.d.ts +44 -1
  189. package/templates/invoice-iframe/index.d.ts +13 -1
  190. package/templates/scheduler/index.d.ts +31 -1
  191. package/templates/video/index.d.ts +36 -1
  192. package/validators/query/index.d.ts +7 -1
  193. package/app.d.ts +0 -7
  194. package/features/command/command.feature.d.ts +0 -63
  195. package/features/query/query.feature.d.ts +0 -92
  196. package/fesm2022/xxmachina-components-routes-commands-command.routes-CeRVzy3Z.mjs.map +0 -1
  197. package/fesm2022/xxmachina-components-routes-commands-pages.routes-Cm6Yd40h.mjs.map +0 -1
  198. package/fesm2022/xxmachina-components-routes-queries-pages.routes-BfWsTCij.mjs +0 -9
  199. package/fesm2022/xxmachina-components-routes-queries-pages.routes-BfWsTCij.mjs.map +0 -1
  200. package/fesm2022/xxmachina-components-routes-query-pages.routes-H2vrF7kQ.mjs.map +0 -1
  201. package/fesm2022/xxmachina-components-routes-resources-pages.routes-BSjrrV1g.mjs.map +0 -1
  202. package/fesm2022/xxmachina-components-routes-resources-resource.routes-DzGgwitX.mjs.map +0 -1
  203. package/fesm2022/xxmachina-components-services-query-config.mjs +0 -47
  204. package/fesm2022/xxmachina-components-services-query-config.mjs.map +0 -1
  205. package/groups/command-form/command-form.group.d.ts +0 -10
  206. package/groups/query-form/query-form.group.d.ts +0 -19
  207. package/molecules/calendar-paginator/calendar-paginator.molecule.d.ts +0 -11
  208. package/molecules/daily-cell/daily-cell.molecule.d.ts +0 -32
  209. package/molecules/weekly-header/weekly-header.molecule.d.ts +0 -8
  210. package/organisms/calendar-section/calendar-section.organism.d.ts +0 -22
  211. package/organisms/event-input-section/event-input-section.organism.d.ts +0 -43
  212. package/organisms/video-trimmer-section/video-trimmer-section.organism.d.ts +0 -25
  213. package/pages/command/command.page.d.ts +0 -113
  214. package/pages/query/query.page.d.ts +0 -145
  215. package/router/index.d.ts +0 -5
  216. package/routes/commands/commands.routes.d.ts +0 -3
  217. package/routes/commands/pages/command/command.routes.d.ts +0 -2
  218. package/routes/commands/pages/pages.routes.d.ts +0 -3
  219. package/routes/pages/pages.routes.d.ts +0 -3
  220. package/routes/preloading/preloading.strategy.d.ts +0 -8
  221. package/routes/queries/pages/pages.routes.d.ts +0 -3
  222. package/routes/queries/queries.routes.d.ts +0 -3
  223. package/routes/query/pages/pages.routes.d.ts +0 -3
  224. package/routes/query/query.routes.d.ts +0 -4
  225. package/routes/resources/pages/pages.routes.d.ts +0 -3
  226. package/routes/resources/pages/resource/resource.routes.d.ts +0 -3
  227. package/routes/resources/resources.routes.d.ts +0 -3
  228. package/routes/side/chat/chat.component.d.ts +0 -37
  229. package/routes/side/chat/chat.routes.d.ts +0 -3
  230. package/routes/side/pages.routes.d.ts +0 -3
  231. package/services/assistant/assistant.service.d.ts +0 -17
  232. package/services/calendar/calendar.service.d.ts +0 -10
  233. package/services/command/command.service.d.ts +0 -49
  234. package/services/contract/contract.service.d.ts +0 -7
  235. package/services/debug/debug.service.d.ts +0 -11
  236. package/services/forms/query/query.service.d.ts +0 -38
  237. package/services/forms/schedule/schedule.service.d.ts +0 -39
  238. package/services/graphql/graphql.service.d.ts +0 -14
  239. package/services/invoice/invoice.service.d.ts +0 -15
  240. package/services/json-schema/json-schema.service.d.ts +0 -12
  241. package/services/link/link.service.d.ts +0 -10
  242. package/services/openapi/openapi.service.d.ts +0 -14
  243. package/services/order/order.service.d.ts +0 -10
  244. package/services/partner/partner.service.d.ts +0 -7
  245. package/services/query/query.service.d.ts +0 -34
  246. package/services/query-config/index.d.ts +0 -1
  247. package/services/query-config/query-config.service.d.ts +0 -26
  248. package/services/recording/recording.service.d.ts +0 -17
  249. package/services/schedule/schedule.service.d.ts +0 -23
  250. package/services/thread/thread.service.d.ts +0 -27
  251. package/services/youtube/youtube.service.d.ts +0 -7
  252. package/templates/background/background.template.d.ts +0 -13
  253. package/templates/invoice-iframe/invoice-iframe.template.d.ts +0 -10
  254. package/templates/scheduler/scheduler.template.d.ts +0 -29
  255. package/templates/video/video.template.d.ts +0 -31
  256. package/validators/query/query.validators.d.ts +0 -4
@@ -0,0 +1,389 @@
1
+ import * as i0 from '@angular/core';
2
+ import { input, output, Directive, Component, inject, EnvironmentInjector, createComponent, Injectable, Input, ElementRef, ViewContainerRef, contentChildren, computed, effect, ViewEncapsulation } from '@angular/core';
3
+ import { NgAtomicComponent } from '@ng-atomic/core';
4
+ import * as React from 'react';
5
+ import React__default, { useRef, useEffect, memo } from 'react';
6
+ import { createRoot } from 'react-dom/client';
7
+ import ReactFlow, { ReactFlowProvider, MiniMap, Controls, Background, BackgroundVariant, NodeResizer, Handle, Position } from 'reactflow';
8
+ import { CommonModule } from '@angular/common';
9
+
10
+ const ReactFlowWrapper = ({ props }) => {
11
+ const minimapStyle = {
12
+ height: 120,
13
+ };
14
+ const mergedProps = {
15
+ ...props,
16
+ nodesDraggable: props.nodesDraggable !== false,
17
+ nodesConnectable: props.nodesConnectable !== false,
18
+ elementsSelectable: props.elementsSelectable !== false,
19
+ proOptions: { hideAttribution: true, ...props.proOptions },
20
+ };
21
+ return React.createElement(ReactFlowProvider, null, React.createElement(ReactFlow, mergedProps, React.createElement(MiniMap, { style: minimapStyle, zoomable: true, pannable: true }), React.createElement(Controls, null), React.createElement(Background, { variant: BackgroundVariant.Dots, gap: 16, size: 1 })));
22
+ };
23
+
24
+ class ReactFlowComponentStore {
25
+ constructor() {
26
+ // Signal inputs
27
+ this.nodes = input();
28
+ this.edges = input();
29
+ this.defaultNodes = input();
30
+ this.defaultEdges = input();
31
+ this.defaultEdgeOptions = input();
32
+ // Node templates for custom rendering
33
+ this.nodeTemplates = input();
34
+ // Signal inputs for configuration
35
+ this.nodeTypes = input();
36
+ this.edgeTypes = input();
37
+ this.connectionLineType = input();
38
+ this.connectionLineStyle = input();
39
+ this.connectionLineComponent = input();
40
+ this.connectionLineContainerStyle = input();
41
+ this.connectionMode = input();
42
+ this.deleteKeyCode = input();
43
+ this.selectionKeyCode = input();
44
+ this.selectionOnDrag = input();
45
+ this.selectionMode = input();
46
+ this.panActivationKeyCode = input();
47
+ this.multiSelectionKeyCode = input();
48
+ this.zoomActivationKeyCode = input();
49
+ this.snapToGrid = input();
50
+ this.snapGrid = input();
51
+ this.onlyRenderVisibleElements = input();
52
+ this.nodesDraggable = input();
53
+ this.nodesConnectable = input();
54
+ this.nodesFocusable = input();
55
+ this.nodeOrigin = input();
56
+ this.edgesFocusable = input();
57
+ this.initNodeOrigin = input();
58
+ this.elementsSelectable = input();
59
+ this.selectNodesOnDrag = input();
60
+ this.panOnDrag = input();
61
+ this.minZoom = input();
62
+ this.maxZoom = input();
63
+ this.defaultViewport = input();
64
+ this.translateExtent = input();
65
+ this.preventScrolling = input();
66
+ this.nodeExtent = input();
67
+ this.defaultMarkerColor = input();
68
+ this.zoomOnScroll = input();
69
+ this.zoomOnPinch = input();
70
+ this.panOnScroll = input();
71
+ this.panOnScrollSpeed = input();
72
+ this.panOnScrollMode = input();
73
+ this.zoomOnDoubleClick = input();
74
+ this.edgeUpdaterRadius = input();
75
+ this.noDragClassName = input();
76
+ this.noWheelClassName = input();
77
+ this.noPanClassName = input();
78
+ this.fitView = input();
79
+ this.fitViewOptions = input();
80
+ this.connectOnClick = input();
81
+ this.attributionPosition = input();
82
+ this.proOptions = input();
83
+ this.elevateNodesOnSelect = input();
84
+ this.elevateEdgesOnSelect = input();
85
+ this.disableKeyboardA11y = input();
86
+ this.autoPanOnNodeDrag = input();
87
+ this.autoPanOnConnect = input();
88
+ this.connectionRadius = input();
89
+ // Signal outputs for events
90
+ this.onNodeClick = output();
91
+ this.onNodeDoubleClick = output();
92
+ this.onNodeMouseEnter = output();
93
+ this.onNodeMouseMove = output();
94
+ this.onNodeMouseLeave = output();
95
+ this.onNodeContextMenu = output();
96
+ this.onNodeDragStart = output();
97
+ this.onNodeDrag = output();
98
+ this.onNodeDragStop = output();
99
+ this.onEdgeClick = output();
100
+ this.onEdgeUpdate = output();
101
+ this.onEdgeContextMenu = output();
102
+ this.onEdgeMouseEnter = output();
103
+ this.onEdgeMouseMove = output();
104
+ this.onEdgeMouseLeave = output();
105
+ this.onEdgeDoubleClick = output();
106
+ this.onEdgeUpdateStart = output();
107
+ this.onEdgeUpdateEnd = output();
108
+ this.onNodesChange = output();
109
+ this.onEdgesChange = output();
110
+ this.onNodesDelete = output();
111
+ this.onEdgesDelete = output();
112
+ this.onSelectionDragStart = output();
113
+ this.onSelectionDrag = output();
114
+ this.onSelectionDragStop = output();
115
+ this.onSelectionStart = output();
116
+ this.onSelectionEnd = output();
117
+ this.onSelectionContextMenu = output();
118
+ this.onConnect = output();
119
+ this.onConnectStart = output();
120
+ this.onConnectEnd = output();
121
+ this.onClickConnectStart = output();
122
+ this.onClickConnectEnd = output();
123
+ this.onDragOver = output();
124
+ this.onDrop = output();
125
+ this.onInit = output();
126
+ this.onMove = output();
127
+ this.onMoveStart = output();
128
+ this.onMoveEnd = output();
129
+ this.onSelectionChange = output();
130
+ this.onPaneScroll = output();
131
+ this.onPaneClick = output();
132
+ this.onPaneContextMenu = output();
133
+ this.onPaneMouseEnter = output();
134
+ this.onPaneMouseMove = output();
135
+ this.onPaneMouseLeave = output();
136
+ this.onError = output();
137
+ this.onNodeResizeEnd = output();
138
+ }
139
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.5", ngImport: i0, type: ReactFlowComponentStore, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
140
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "20.0.5", type: ReactFlowComponentStore, isStandalone: true, inputs: { nodes: { classPropertyName: "nodes", publicName: "nodes", isSignal: true, isRequired: false, transformFunction: null }, edges: { classPropertyName: "edges", publicName: "edges", isSignal: true, isRequired: false, transformFunction: null }, defaultNodes: { classPropertyName: "defaultNodes", publicName: "defaultNodes", isSignal: true, isRequired: false, transformFunction: null }, defaultEdges: { classPropertyName: "defaultEdges", publicName: "defaultEdges", isSignal: true, isRequired: false, transformFunction: null }, defaultEdgeOptions: { classPropertyName: "defaultEdgeOptions", publicName: "defaultEdgeOptions", isSignal: true, isRequired: false, transformFunction: null }, nodeTemplates: { classPropertyName: "nodeTemplates", publicName: "nodeTemplates", isSignal: true, isRequired: false, transformFunction: null }, nodeTypes: { classPropertyName: "nodeTypes", publicName: "nodeTypes", isSignal: true, isRequired: false, transformFunction: null }, edgeTypes: { classPropertyName: "edgeTypes", publicName: "edgeTypes", isSignal: true, isRequired: false, transformFunction: null }, connectionLineType: { classPropertyName: "connectionLineType", publicName: "connectionLineType", isSignal: true, isRequired: false, transformFunction: null }, connectionLineStyle: { classPropertyName: "connectionLineStyle", publicName: "connectionLineStyle", isSignal: true, isRequired: false, transformFunction: null }, connectionLineComponent: { classPropertyName: "connectionLineComponent", publicName: "connectionLineComponent", isSignal: true, isRequired: false, transformFunction: null }, connectionLineContainerStyle: { classPropertyName: "connectionLineContainerStyle", publicName: "connectionLineContainerStyle", isSignal: true, isRequired: false, transformFunction: null }, connectionMode: { classPropertyName: "connectionMode", publicName: "connectionMode", isSignal: true, isRequired: false, transformFunction: null }, deleteKeyCode: { classPropertyName: "deleteKeyCode", publicName: "deleteKeyCode", isSignal: true, isRequired: false, transformFunction: null }, selectionKeyCode: { classPropertyName: "selectionKeyCode", publicName: "selectionKeyCode", isSignal: true, isRequired: false, transformFunction: null }, selectionOnDrag: { classPropertyName: "selectionOnDrag", publicName: "selectionOnDrag", isSignal: true, isRequired: false, transformFunction: null }, selectionMode: { classPropertyName: "selectionMode", publicName: "selectionMode", isSignal: true, isRequired: false, transformFunction: null }, panActivationKeyCode: { classPropertyName: "panActivationKeyCode", publicName: "panActivationKeyCode", isSignal: true, isRequired: false, transformFunction: null }, multiSelectionKeyCode: { classPropertyName: "multiSelectionKeyCode", publicName: "multiSelectionKeyCode", isSignal: true, isRequired: false, transformFunction: null }, zoomActivationKeyCode: { classPropertyName: "zoomActivationKeyCode", publicName: "zoomActivationKeyCode", isSignal: true, isRequired: false, transformFunction: null }, snapToGrid: { classPropertyName: "snapToGrid", publicName: "snapToGrid", isSignal: true, isRequired: false, transformFunction: null }, snapGrid: { classPropertyName: "snapGrid", publicName: "snapGrid", isSignal: true, isRequired: false, transformFunction: null }, onlyRenderVisibleElements: { classPropertyName: "onlyRenderVisibleElements", publicName: "onlyRenderVisibleElements", isSignal: true, isRequired: false, transformFunction: null }, nodesDraggable: { classPropertyName: "nodesDraggable", publicName: "nodesDraggable", isSignal: true, isRequired: false, transformFunction: null }, nodesConnectable: { classPropertyName: "nodesConnectable", publicName: "nodesConnectable", isSignal: true, isRequired: false, transformFunction: null }, nodesFocusable: { classPropertyName: "nodesFocusable", publicName: "nodesFocusable", isSignal: true, isRequired: false, transformFunction: null }, nodeOrigin: { classPropertyName: "nodeOrigin", publicName: "nodeOrigin", isSignal: true, isRequired: false, transformFunction: null }, edgesFocusable: { classPropertyName: "edgesFocusable", publicName: "edgesFocusable", isSignal: true, isRequired: false, transformFunction: null }, initNodeOrigin: { classPropertyName: "initNodeOrigin", publicName: "initNodeOrigin", isSignal: true, isRequired: false, transformFunction: null }, elementsSelectable: { classPropertyName: "elementsSelectable", publicName: "elementsSelectable", isSignal: true, isRequired: false, transformFunction: null }, selectNodesOnDrag: { classPropertyName: "selectNodesOnDrag", publicName: "selectNodesOnDrag", isSignal: true, isRequired: false, transformFunction: null }, panOnDrag: { classPropertyName: "panOnDrag", publicName: "panOnDrag", isSignal: true, isRequired: false, transformFunction: null }, minZoom: { classPropertyName: "minZoom", publicName: "minZoom", isSignal: true, isRequired: false, transformFunction: null }, maxZoom: { classPropertyName: "maxZoom", publicName: "maxZoom", isSignal: true, isRequired: false, transformFunction: null }, defaultViewport: { classPropertyName: "defaultViewport", publicName: "defaultViewport", isSignal: true, isRequired: false, transformFunction: null }, translateExtent: { classPropertyName: "translateExtent", publicName: "translateExtent", isSignal: true, isRequired: false, transformFunction: null }, preventScrolling: { classPropertyName: "preventScrolling", publicName: "preventScrolling", isSignal: true, isRequired: false, transformFunction: null }, nodeExtent: { classPropertyName: "nodeExtent", publicName: "nodeExtent", isSignal: true, isRequired: false, transformFunction: null }, defaultMarkerColor: { classPropertyName: "defaultMarkerColor", publicName: "defaultMarkerColor", isSignal: true, isRequired: false, transformFunction: null }, zoomOnScroll: { classPropertyName: "zoomOnScroll", publicName: "zoomOnScroll", isSignal: true, isRequired: false, transformFunction: null }, zoomOnPinch: { classPropertyName: "zoomOnPinch", publicName: "zoomOnPinch", isSignal: true, isRequired: false, transformFunction: null }, panOnScroll: { classPropertyName: "panOnScroll", publicName: "panOnScroll", isSignal: true, isRequired: false, transformFunction: null }, panOnScrollSpeed: { classPropertyName: "panOnScrollSpeed", publicName: "panOnScrollSpeed", isSignal: true, isRequired: false, transformFunction: null }, panOnScrollMode: { classPropertyName: "panOnScrollMode", publicName: "panOnScrollMode", isSignal: true, isRequired: false, transformFunction: null }, zoomOnDoubleClick: { classPropertyName: "zoomOnDoubleClick", publicName: "zoomOnDoubleClick", isSignal: true, isRequired: false, transformFunction: null }, edgeUpdaterRadius: { classPropertyName: "edgeUpdaterRadius", publicName: "edgeUpdaterRadius", isSignal: true, isRequired: false, transformFunction: null }, noDragClassName: { classPropertyName: "noDragClassName", publicName: "noDragClassName", isSignal: true, isRequired: false, transformFunction: null }, noWheelClassName: { classPropertyName: "noWheelClassName", publicName: "noWheelClassName", isSignal: true, isRequired: false, transformFunction: null }, noPanClassName: { classPropertyName: "noPanClassName", publicName: "noPanClassName", isSignal: true, isRequired: false, transformFunction: null }, fitView: { classPropertyName: "fitView", publicName: "fitView", isSignal: true, isRequired: false, transformFunction: null }, fitViewOptions: { classPropertyName: "fitViewOptions", publicName: "fitViewOptions", isSignal: true, isRequired: false, transformFunction: null }, connectOnClick: { classPropertyName: "connectOnClick", publicName: "connectOnClick", isSignal: true, isRequired: false, transformFunction: null }, attributionPosition: { classPropertyName: "attributionPosition", publicName: "attributionPosition", isSignal: true, isRequired: false, transformFunction: null }, proOptions: { classPropertyName: "proOptions", publicName: "proOptions", isSignal: true, isRequired: false, transformFunction: null }, elevateNodesOnSelect: { classPropertyName: "elevateNodesOnSelect", publicName: "elevateNodesOnSelect", isSignal: true, isRequired: false, transformFunction: null }, elevateEdgesOnSelect: { classPropertyName: "elevateEdgesOnSelect", publicName: "elevateEdgesOnSelect", isSignal: true, isRequired: false, transformFunction: null }, disableKeyboardA11y: { classPropertyName: "disableKeyboardA11y", publicName: "disableKeyboardA11y", isSignal: true, isRequired: false, transformFunction: null }, autoPanOnNodeDrag: { classPropertyName: "autoPanOnNodeDrag", publicName: "autoPanOnNodeDrag", isSignal: true, isRequired: false, transformFunction: null }, autoPanOnConnect: { classPropertyName: "autoPanOnConnect", publicName: "autoPanOnConnect", isSignal: true, isRequired: false, transformFunction: null }, connectionRadius: { classPropertyName: "connectionRadius", publicName: "connectionRadius", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onNodeClick: "onNodeClick", onNodeDoubleClick: "onNodeDoubleClick", onNodeMouseEnter: "onNodeMouseEnter", onNodeMouseMove: "onNodeMouseMove", onNodeMouseLeave: "onNodeMouseLeave", onNodeContextMenu: "onNodeContextMenu", onNodeDragStart: "onNodeDragStart", onNodeDrag: "onNodeDrag", onNodeDragStop: "onNodeDragStop", onEdgeClick: "onEdgeClick", onEdgeUpdate: "onEdgeUpdate", onEdgeContextMenu: "onEdgeContextMenu", onEdgeMouseEnter: "onEdgeMouseEnter", onEdgeMouseMove: "onEdgeMouseMove", onEdgeMouseLeave: "onEdgeMouseLeave", onEdgeDoubleClick: "onEdgeDoubleClick", onEdgeUpdateStart: "onEdgeUpdateStart", onEdgeUpdateEnd: "onEdgeUpdateEnd", onNodesChange: "onNodesChange", onEdgesChange: "onEdgesChange", onNodesDelete: "onNodesDelete", onEdgesDelete: "onEdgesDelete", onSelectionDragStart: "onSelectionDragStart", onSelectionDrag: "onSelectionDrag", onSelectionDragStop: "onSelectionDragStop", onSelectionStart: "onSelectionStart", onSelectionEnd: "onSelectionEnd", onSelectionContextMenu: "onSelectionContextMenu", onConnect: "onConnect", onConnectStart: "onConnectStart", onConnectEnd: "onConnectEnd", onClickConnectStart: "onClickConnectStart", onClickConnectEnd: "onClickConnectEnd", onDragOver: "onDragOver", onDrop: "onDrop", onInit: "onInit", onMove: "onMove", onMoveStart: "onMoveStart", onMoveEnd: "onMoveEnd", onSelectionChange: "onSelectionChange", onPaneScroll: "onPaneScroll", onPaneClick: "onPaneClick", onPaneContextMenu: "onPaneContextMenu", onPaneMouseEnter: "onPaneMouseEnter", onPaneMouseMove: "onPaneMouseMove", onPaneMouseLeave: "onPaneMouseLeave", onError: "onError", onNodeResizeEnd: "onNodeResizeEnd" }, ngImport: i0 }); }
141
+ }
142
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.5", ngImport: i0, type: ReactFlowComponentStore, decorators: [{
143
+ type: Directive,
144
+ args: [{ standalone: true }]
145
+ }] });
146
+
147
+ class NodeComponent {
148
+ constructor() {
149
+ this.data = input();
150
+ }
151
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.5", ngImport: i0, type: NodeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
152
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "20.0.5", type: NodeComponent, isStandalone: true, selector: "machina-task-node", inputs: { data: { classPropertyName: "data", publicName: "data", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: `
153
+ <div class="task-node" [class]="'status-' + data().status">
154
+ <div class="task-header">
155
+ <span class="status-indicator"></span>
156
+ <span class="assignee">あああ{{ data().assignee }}</span>
157
+ </div>
158
+ <div class="task-label">{{ data().label }}</div>
159
+ </div>
160
+ `, isInline: true, styles: [":host .task-node{background:#fff;border:2px solid #ddd;border-radius:8px;padding:10px;min-width:200px;box-shadow:0 2px 4px #0000001a}:host .task-node.status-pending{border-color:#9e9e9e}:host .task-node.status-pending .status-indicator{background:#9e9e9e}:host .task-node.status-in_progress{border-color:#2196f3}:host .task-node.status-in_progress .status-indicator{background:#2196f3}:host .task-node.status-completed{border-color:#4caf50}:host .task-node.status-completed .status-indicator{background:#4caf50}:host .task-node.status-abandoned{border-color:#f44336}:host .task-node.status-abandoned .status-indicator{background:#f44336}:host .task-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}:host .status-indicator{width:8px;height:8px;border-radius:50%;background:#ddd}:host .assignee{font-size:12px;color:#666}:host .task-label{font-size:14px;font-weight:500;color:#333}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }] }); }
161
+ }
162
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.5", ngImport: i0, type: NodeComponent, decorators: [{
163
+ type: Component,
164
+ args: [{ selector: 'machina-task-node', standalone: true, imports: [CommonModule], template: `
165
+ <div class="task-node" [class]="'status-' + data().status">
166
+ <div class="task-header">
167
+ <span class="status-indicator"></span>
168
+ <span class="assignee">あああ{{ data().assignee }}</span>
169
+ </div>
170
+ <div class="task-label">{{ data().label }}</div>
171
+ </div>
172
+ `, styles: [":host .task-node{background:#fff;border:2px solid #ddd;border-radius:8px;padding:10px;min-width:200px;box-shadow:0 2px 4px #0000001a}:host .task-node.status-pending{border-color:#9e9e9e}:host .task-node.status-pending .status-indicator{background:#9e9e9e}:host .task-node.status-in_progress{border-color:#2196f3}:host .task-node.status-in_progress .status-indicator{background:#2196f3}:host .task-node.status-completed{border-color:#4caf50}:host .task-node.status-completed .status-indicator{background:#4caf50}:host .task-node.status-abandoned{border-color:#f44336}:host .task-node.status-abandoned .status-indicator{background:#f44336}:host .task-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}:host .status-indicator{width:8px;height:8px;border-radius:50%;background:#ddd}:host .assignee{font-size:12px;color:#666}:host .task-label{font-size:14px;font-weight:500;color:#333}\n"] }]
173
+ }] });
174
+
175
+ // Global reference to Angular app injector (will be set by ReactFlowComponent)
176
+ let globalInjector = null;
177
+ function setAngularContext(injector, appRef) {
178
+ globalInjector = injector;
179
+ }
180
+ class NodeService {
181
+ constructor() {
182
+ this.componentCache = new Map();
183
+ this.injector = inject(EnvironmentInjector);
184
+ }
185
+ createNodeComponent(hostElement) {
186
+ if (this.componentCache.has(hostElement)) {
187
+ return this.componentCache.get(hostElement);
188
+ }
189
+ const component = createComponent(NodeComponent, {
190
+ environmentInjector: this.injector,
191
+ hostElement,
192
+ });
193
+ this.componentCache.set(hostElement, component);
194
+ return component;
195
+ }
196
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.5", ngImport: i0, type: NodeService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
197
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.0.5", ngImport: i0, type: NodeService, providedIn: 'root' }); }
198
+ }
199
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.5", ngImport: i0, type: NodeService, decorators: [{
200
+ type: Injectable,
201
+ args: [{ providedIn: 'root' }]
202
+ }] });
203
+ const Node = ({ data }) => {
204
+ const containerRef = useRef(null);
205
+ const component = globalInjector?.get(NodeService).createNodeComponent(containerRef.current);
206
+ useEffect(() => component.setInput('data', data), [data]);
207
+ return (React__default.createElement("div", { ref: containerRef },
208
+ React__default.createElement(NodeResizer, { minWidth: 400, minHeight: 300, isVisible: true }),
209
+ React__default.createElement(Handle, { type: "target", position: Position.Left, style: { zIndex: 10 } }),
210
+ React__default.createElement(Handle, { type: "source", position: Position.Right, style: { zIndex: 10 } })));
211
+ };
212
+ var TaskNode = memo(Node);
213
+
214
+ const GroupNode = ({ data }) => {
215
+ return (React__default.createElement("div", { className: "group-node" },
216
+ React__default.createElement(Handle, { type: "target", position: Position.Left }),
217
+ React__default.createElement("div", { className: "group-node-header" },
218
+ React__default.createElement("h3", null, data.label),
219
+ React__default.createElement("span", { className: "group-assignee" }, data.assignee)),
220
+ React__default.createElement(Handle, { type: "source", position: Position.Right })));
221
+ };
222
+ var GroupNode$1 = memo(GroupNode);
223
+
224
+ function createTemplateNodeComponent(template, vcr, onNodeResizeEnd) {
225
+ const TemplateNode = ({ data, selected, id }) => {
226
+ const containerRef = useRef(null);
227
+ const viewRefRef = useRef(null);
228
+ // 初回のみAngularビューを作成(破棄・再作成を防ぐ)
229
+ useEffect(() => {
230
+ const viewRef = vcr.createEmbeddedView(template, {});
231
+ viewRef.rootNodes.forEach(node => containerRef.current.appendChild(node));
232
+ viewRef.context = { $implicit: data, data };
233
+ viewRefRef.current = viewRef;
234
+ viewRef.markForCheck();
235
+ return () => {
236
+ if (viewRefRef.current) {
237
+ viewRefRef.current.destroy();
238
+ viewRefRef.current = null;
239
+ }
240
+ };
241
+ }, []); // 空の依存配列 - 初回のみ実行
242
+ // dataが変更されたときはコンテキストのみ更新(ビューは再作成しない)
243
+ useEffect(() => {
244
+ if (viewRefRef.current) {
245
+ viewRefRef.current.context = { $implicit: data, data };
246
+ viewRefRef.current.markForCheck();
247
+ }
248
+ }, [data]);
249
+ const handleResizeEnd = (event, params) => {
250
+ if (onNodeResizeEnd) {
251
+ onNodeResizeEnd(id, params.width, params.height);
252
+ }
253
+ };
254
+ return (React__default.createElement("div", { ref: containerRef },
255
+ React__default.createElement(NodeResizer, { minWidth: 400, minHeight: 300, isVisible: true, onResizeEnd: handleResizeEnd }),
256
+ React__default.createElement(Handle, { type: "target", position: Position.Left, style: { zIndex: 10 } }),
257
+ React__default.createElement(Handle, { type: "source", position: Position.Right, style: { zIndex: 10 } })));
258
+ };
259
+ // memoなしで返す(デバッグ用:renameが動作するか確認)
260
+ // 動作確認後、適切なmemo戦略を検討
261
+ return TemplateNode;
262
+ }
263
+
264
+ const NODE_TYPES = {
265
+ task: TaskNode,
266
+ group: GroupNode$1,
267
+ };
268
+
269
+ class FlowNodeDirective {
270
+ constructor(template) {
271
+ this.template = template;
272
+ }
273
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.5", ngImport: i0, type: FlowNodeDirective, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive }); }
274
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "20.0.5", type: FlowNodeDirective, isStandalone: true, selector: "[flowNode]", inputs: { type: ["flowNode", "type"] }, ngImport: i0 }); }
275
+ }
276
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.5", ngImport: i0, type: FlowNodeDirective, decorators: [{
277
+ type: Directive,
278
+ args: [{
279
+ selector: '[flowNode]',
280
+ standalone: true,
281
+ }]
282
+ }], ctorParameters: () => [{ type: i0.TemplateRef }], propDecorators: { type: [{
283
+ type: Input,
284
+ args: ['flowNode']
285
+ }] } });
286
+
287
+ class ReactFlowComponent extends NgAtomicComponent {
288
+ constructor() {
289
+ super();
290
+ this.store = inject(ReactFlowComponentStore);
291
+ this.el = inject((ElementRef));
292
+ this.vcr = inject(ViewContainerRef);
293
+ this._nodeTypesCache = {};
294
+ this.contentNodeTemplates = contentChildren(FlowNodeDirective);
295
+ this.nodeTypes = computed(() => {
296
+ const templates = this.contentNodeTemplates();
297
+ const nodeTypes = {};
298
+ if (templates) {
299
+ templates.forEach((template) => {
300
+ if (!this._nodeTypesCache[template.type]) {
301
+ // onNodeResizeEndコールバックを渡す
302
+ this._nodeTypesCache[template.type] = createTemplateNodeComponent(template.template, this.vcr, (nodeId, width, height) => {
303
+ this.store.onNodeResizeEnd?.emit({ nodeId, width, height });
304
+ });
305
+ }
306
+ nodeTypes[template.type] = this._nodeTypesCache[template.type];
307
+ });
308
+ }
309
+ return nodeTypes;
310
+ });
311
+ effect(() => this.render());
312
+ }
313
+ ngOnInit() {
314
+ this._root = createRoot(this.el.nativeElement);
315
+ }
316
+ ngOnDestroy() {
317
+ this._root.unmount();
318
+ }
319
+ render() {
320
+ this._root.render(React.createElement(ReactFlowWrapper, {
321
+ props: {
322
+ ...Object.entries(this.store)
323
+ .filter(([key, value]) => !key.startsWith('on') && typeof value === 'function' && key !== 'nodeTypes' && key !== 'nodeTemplates')
324
+ .reduce((acc, [key, getter]) => {
325
+ acc[key] = getter();
326
+ return acc;
327
+ }, {}),
328
+ nodeTypes: this.nodeTypes(), // Use the merged node types
329
+ ...Object.entries(this.store)
330
+ .filter(([key, value]) => key.startsWith('on') && value && typeof value.emit === 'function')
331
+ .reduce((handlers, [eventName, output]) => {
332
+ handlers[eventName] = (...args) => {
333
+ // Special case: onError emits only the first argument
334
+ const emitValue = eventName === 'onError' ? args[0] : args;
335
+ output.emit(emitValue);
336
+ };
337
+ return handlers;
338
+ }, {})
339
+ },
340
+ }));
341
+ }
342
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.5", ngImport: i0, type: ReactFlowComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
343
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "20.0.5", type: ReactFlowComponent, isStandalone: true, selector: "machina-react-flow", queries: [{ propertyName: "contentNodeTemplates", predicate: FlowNodeDirective, isSignal: true }], usesInheritance: true, hostDirectives: [{ directive: ReactFlowComponentStore, inputs: ["nodes", "nodes", "edges", "edges", "defaultNodes", "defaultNodes", "defaultEdges", "defaultEdges", "defaultEdgeOptions", "defaultEdgeOptions", "nodeTemplates", "nodeTemplates", "nodeTypes", "nodeTypes", "edgeTypes", "edgeTypes", "connectionLineType", "connectionLineType", "connectionLineStyle", "connectionLineStyle", "connectionLineComponent", "connectionLineComponent", "connectionLineContainerStyle", "connectionLineContainerStyle", "connectionMode", "connectionMode", "deleteKeyCode", "deleteKeyCode", "selectionKeyCode", "selectionKeyCode", "selectionOnDrag", "selectionOnDrag", "selectionMode", "selectionMode", "panActivationKeyCode", "panActivationKeyCode", "multiSelectionKeyCode", "multiSelectionKeyCode", "zoomActivationKeyCode", "zoomActivationKeyCode", "snapToGrid", "snapToGrid", "snapGrid", "snapGrid", "onlyRenderVisibleElements", "onlyRenderVisibleElements", "nodesDraggable", "nodesDraggable", "nodesConnectable", "nodesConnectable", "nodesFocusable", "nodesFocusable", "nodeOrigin", "nodeOrigin", "edgesFocusable", "edgesFocusable", "initNodeOrigin", "initNodeOrigin", "elementsSelectable", "elementsSelectable", "selectNodesOnDrag", "selectNodesOnDrag", "panOnDrag", "panOnDrag", "minZoom", "minZoom", "maxZoom", "maxZoom", "defaultViewport", "defaultViewport", "translateExtent", "translateExtent", "preventScrolling", "preventScrolling", "nodeExtent", "nodeExtent", "defaultMarkerColor", "defaultMarkerColor", "zoomOnScroll", "zoomOnScroll", "zoomOnPinch", "zoomOnPinch", "panOnScroll", "panOnScroll", "panOnScrollSpeed", "panOnScrollSpeed", "panOnScrollMode", "panOnScrollMode", "zoomOnDoubleClick", "zoomOnDoubleClick", "edgeUpdaterRadius", "edgeUpdaterRadius", "noDragClassName", "noDragClassName", "noWheelClassName", "noWheelClassName", "noPanClassName", "noPanClassName", "fitView", "fitView", "fitViewOptions", "fitViewOptions", "connectOnClick", "connectOnClick", "attributionPosition", "attributionPosition", "proOptions", "proOptions", "elevateNodesOnSelect", "elevateNodesOnSelect", "elevateEdgesOnSelect", "elevateEdgesOnSelect", "disableKeyboardA11y", "disableKeyboardA11y", "autoPanOnNodeDrag", "autoPanOnNodeDrag", "autoPanOnConnect", "autoPanOnConnect", "connectionRadius", "connectionRadius"], outputs: ["onNodeClick", "onNodeClick", "onNodeDoubleClick", "onNodeDoubleClick", "onNodeMouseEnter", "onNodeMouseEnter", "onNodeMouseMove", "onNodeMouseMove", "onNodeMouseLeave", "onNodeMouseLeave", "onNodeContextMenu", "onNodeContextMenu", "onNodeDragStart", "onNodeDragStart", "onNodeDrag", "onNodeDrag", "onNodeDragStop", "onNodeDragStop", "onEdgeClick", "onEdgeClick", "onEdgeUpdate", "onEdgeUpdate", "onEdgeContextMenu", "onEdgeContextMenu", "onEdgeMouseEnter", "onEdgeMouseEnter", "onEdgeMouseMove", "onEdgeMouseMove", "onEdgeMouseLeave", "onEdgeMouseLeave", "onEdgeDoubleClick", "onEdgeDoubleClick", "onEdgeUpdateStart", "onEdgeUpdateStart", "onEdgeUpdateEnd", "onEdgeUpdateEnd", "onNodesChange", "onNodesChange", "onEdgesChange", "onEdgesChange", "onNodesDelete", "onNodesDelete", "onEdgesDelete", "onEdgesDelete", "onSelectionDragStart", "onSelectionDragStart", "onSelectionDrag", "onSelectionDrag", "onSelectionDragStop", "onSelectionDragStop", "onSelectionStart", "onSelectionStart", "onSelectionEnd", "onSelectionEnd", "onSelectionContextMenu", "onSelectionContextMenu", "onConnect", "onConnect", "onConnectStart", "onConnectStart", "onConnectEnd", "onConnectEnd", "onClickConnectStart", "onClickConnectStart", "onClickConnectEnd", "onClickConnectEnd", "onDragOver", "onDragOver", "onDrop", "onDrop", "onInit", "onInit", "onMove", "onMove", "onMoveStart", "onMoveStart", "onMoveEnd", "onMoveEnd", "onSelectionChange", "onSelectionChange", "onPaneScroll", "onPaneScroll", "onPaneClick", "onPaneClick", "onPaneContextMenu", "onPaneContextMenu", "onPaneMouseEnter", "onPaneMouseEnter", "onPaneMouseMove", "onPaneMouseMove", "onPaneMouseLeave", "onPaneMouseLeave", "onError", "onError", "onNodeResizeEnd", "onNodeResizeEnd"] }], ngImport: i0, template: `<ng-content></ng-content>`, isInline: true, styles: [".react-flow{direction:ltr}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1;cursor:-webkit-grab;cursor:grab}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow .react-flow__edges{pointer-events:none;overflow:visible}.react-flow__edge-path,.react-flow__connection-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;-webkit-animation:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:-webkit-grab;cursor:grab}.react-flow__node.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:-webkit-grab;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background:#1a192b;border:1px solid white;border-radius:100%}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:-4px;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{right:-4px;top:50%;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translate(-50%)}.react-flow__attribution{font-size:10px;background:#ffffff80;padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@-webkit-keyframes dashdraw{0%{stroke-dashoffset:10}}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-default,.react-flow__node-input,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:3px;width:150px;font-size:12px;color:#222;text-align:center;border-width:1px;border-style:solid;border-color:#1a192b;background-color:#fff}.react-flow__node-default.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted rgba(0,89,220,.8)}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{border:none;background:#fefefe;border-bottom:1px solid #eee;box-sizing:content-box;display:flex;justify-content:center;align-items:center;width:16px;height:16px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;padding:5px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:4px;height:4px;border:1px solid #fff;border-radius:1px;background-color:#3367d9;transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:#3367d9;border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}:host{display:block;width:100%;height:100%}:host .react-flow{width:100%;height:100%;background-color:#f8f8f8!important}:host .react-flow .react-flow__renderer{z-index:1}:host .react-flow .react-flow__background{background-color:#f8f8f8!important}:host .react-flow .react-flow__viewport{z-index:2}:host .react-flow .react-flow__nodes{z-index:4}:host .react-flow .react-flow__node{cursor:grab!important;z-index:5!important}:host .react-flow .react-flow__node:active{cursor:grabbing!important}:host .react-flow .react-flow__node.nopan{cursor:grab!important;pointer-events:auto!important}:host .react-flow .react-flow__node-default{background:#4ecdc4!important;border:3px solid #333!important;border-radius:8px!important;padding:15px!important;color:#fff!important;font-weight:700!important;font-size:18px!important;box-shadow:0 4px 8px #0000004d!important;opacity:1!important;min-width:200px!important}:host .react-flow .react-flow__node-default[data-id=\"1\"]{background:#ff6b6b!important}:host .react-flow .react-flow__node-default[data-id=\"2\"]{background:#4ecdc4!important}:host .react-flow .react-flow__handle{background:#555!important;width:12px!important;height:12px!important;border:2px solid #fff!important;opacity:1!important}:host .react-flow .react-flow__handle:hover{background:#1976d2!important}:host .react-flow .react-flow__handle-top{top:-6px!important}:host .react-flow .react-flow__handle-right{right:-6px!important}:host .react-flow .react-flow__handle-bottom{bottom:-6px!important}:host .react-flow .react-flow__handle-left{left:-6px!important}:host .react-flow .react-flow__edge-path{stroke:#000!important;stroke-width:3px!important}:host .react-flow .react-flow__edge.selected .react-flow__edge-path{stroke:#1976d2!important;stroke-width:3}:host .react-flow .react-flow__controls button{background:#fff!important;border:1px solid #333!important;color:#333!important}:host .react-flow .react-flow__controls button:hover{background:#f0f0f0!important}:host .react-flow .react-flow__minimap{background-color:#f8f8f8!important;border:1px solid #333!important}:host .react-flow .react-flow__minimap .react-flow__minimap-mask{fill:#e0e0e0!important}:host .react-flow .react-flow__minimap .react-flow__minimap-node{fill:#333!important}:host .react-flow .react-flow__background pattern{stroke:#e0e0e0!important}:host .react-flow .react-flow__connectionline .react-flow__edge-path{stroke:#1976d2!important;stroke-width:3px!important;stroke-dasharray:5 5!important;animation:dash .5s linear infinite!important}@keyframes dash{to{stroke-dashoffset:-10}}:host .react-flow .react-flow__node-group{background:#f0f0f099!important;border:2px dashed #d1d5db!important;border-radius:16px!important;padding:60px 40px 40px!important;pointer-events:all!important;box-sizing:border-box!important}:host .react-flow .react-flow__node-group.selected{border-color:#3b82f6!important;border-style:solid!important;background:#f0f0f0cc!important}:host .react-flow .react-flow__node-task{background:transparent!important;border:none!important;padding:0!important}\n"], encapsulation: i0.ViewEncapsulation.None }); }
344
+ }
345
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.5", ngImport: i0, type: ReactFlowComponent, decorators: [{
346
+ type: Component,
347
+ args: [{ selector: 'machina-react-flow', template: `<ng-content></ng-content>`, standalone: true, encapsulation: ViewEncapsulation.None, hostDirectives: [
348
+ {
349
+ directive: ReactFlowComponentStore,
350
+ inputs: [
351
+ 'nodes', 'edges', 'defaultNodes', 'defaultEdges', 'defaultEdgeOptions',
352
+ 'nodeTemplates', 'nodeTypes', 'edgeTypes', 'connectionLineType', 'connectionLineStyle',
353
+ 'connectionLineComponent', 'connectionLineContainerStyle', 'connectionMode',
354
+ 'deleteKeyCode', 'selectionKeyCode', 'selectionOnDrag', 'selectionMode',
355
+ 'panActivationKeyCode', 'multiSelectionKeyCode', 'zoomActivationKeyCode',
356
+ 'snapToGrid', 'snapGrid', 'onlyRenderVisibleElements', 'nodesDraggable',
357
+ 'nodesConnectable', 'nodesFocusable', 'nodeOrigin', 'edgesFocusable',
358
+ 'initNodeOrigin', 'elementsSelectable', 'selectNodesOnDrag', 'panOnDrag',
359
+ 'minZoom', 'maxZoom', 'defaultViewport', 'translateExtent', 'preventScrolling',
360
+ 'nodeExtent', 'defaultMarkerColor', 'zoomOnScroll', 'zoomOnPinch', 'panOnScroll',
361
+ 'panOnScrollSpeed', 'panOnScrollMode', 'zoomOnDoubleClick', 'edgeUpdaterRadius',
362
+ 'noDragClassName', 'noWheelClassName', 'noPanClassName', 'fitView', 'fitViewOptions',
363
+ 'connectOnClick', 'attributionPosition', 'proOptions', 'elevateNodesOnSelect',
364
+ 'elevateEdgesOnSelect', 'disableKeyboardA11y', 'autoPanOnNodeDrag', 'autoPanOnConnect',
365
+ 'connectionRadius'
366
+ ],
367
+ outputs: [
368
+ 'onNodeClick', 'onNodeDoubleClick', 'onNodeMouseEnter', 'onNodeMouseMove',
369
+ 'onNodeMouseLeave', 'onNodeContextMenu', 'onNodeDragStart', 'onNodeDrag',
370
+ 'onNodeDragStop', 'onEdgeClick', 'onEdgeUpdate', 'onEdgeContextMenu',
371
+ 'onEdgeMouseEnter', 'onEdgeMouseMove', 'onEdgeMouseLeave', 'onEdgeDoubleClick',
372
+ 'onEdgeUpdateStart', 'onEdgeUpdateEnd', 'onNodesChange', 'onEdgesChange',
373
+ 'onNodesDelete', 'onEdgesDelete', 'onSelectionDragStart', 'onSelectionDrag',
374
+ 'onSelectionDragStop', 'onSelectionStart', 'onSelectionEnd', 'onSelectionContextMenu',
375
+ 'onConnect', 'onConnectStart', 'onConnectEnd', 'onClickConnectStart',
376
+ 'onClickConnectEnd', 'onDragOver', 'onDrop', 'onInit', 'onMove', 'onMoveStart',
377
+ 'onMoveEnd', 'onSelectionChange', 'onPaneScroll', 'onPaneClick', 'onPaneContextMenu',
378
+ 'onPaneMouseEnter', 'onPaneMouseMove', 'onPaneMouseLeave', 'onError', 'onNodeResizeEnd'
379
+ ]
380
+ }
381
+ ], styles: [".react-flow{direction:ltr}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1;cursor:-webkit-grab;cursor:grab}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow .react-flow__edges{pointer-events:none;overflow:visible}.react-flow__edge-path,.react-flow__connection-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;-webkit-animation:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:-webkit-grab;cursor:grab}.react-flow__node.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:-webkit-grab;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background:#1a192b;border:1px solid white;border-radius:100%}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:-4px;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{right:-4px;top:50%;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translate(-50%)}.react-flow__attribution{font-size:10px;background:#ffffff80;padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@-webkit-keyframes dashdraw{0%{stroke-dashoffset:10}}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-default,.react-flow__node-input,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:3px;width:150px;font-size:12px;color:#222;text-align:center;border-width:1px;border-style:solid;border-color:#1a192b;background-color:#fff}.react-flow__node-default.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted rgba(0,89,220,.8)}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{border:none;background:#fefefe;border-bottom:1px solid #eee;box-sizing:content-box;display:flex;justify-content:center;align-items:center;width:16px;height:16px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;padding:5px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:4px;height:4px;border:1px solid #fff;border-radius:1px;background-color:#3367d9;transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:#3367d9;border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}:host{display:block;width:100%;height:100%}:host .react-flow{width:100%;height:100%;background-color:#f8f8f8!important}:host .react-flow .react-flow__renderer{z-index:1}:host .react-flow .react-flow__background{background-color:#f8f8f8!important}:host .react-flow .react-flow__viewport{z-index:2}:host .react-flow .react-flow__nodes{z-index:4}:host .react-flow .react-flow__node{cursor:grab!important;z-index:5!important}:host .react-flow .react-flow__node:active{cursor:grabbing!important}:host .react-flow .react-flow__node.nopan{cursor:grab!important;pointer-events:auto!important}:host .react-flow .react-flow__node-default{background:#4ecdc4!important;border:3px solid #333!important;border-radius:8px!important;padding:15px!important;color:#fff!important;font-weight:700!important;font-size:18px!important;box-shadow:0 4px 8px #0000004d!important;opacity:1!important;min-width:200px!important}:host .react-flow .react-flow__node-default[data-id=\"1\"]{background:#ff6b6b!important}:host .react-flow .react-flow__node-default[data-id=\"2\"]{background:#4ecdc4!important}:host .react-flow .react-flow__handle{background:#555!important;width:12px!important;height:12px!important;border:2px solid #fff!important;opacity:1!important}:host .react-flow .react-flow__handle:hover{background:#1976d2!important}:host .react-flow .react-flow__handle-top{top:-6px!important}:host .react-flow .react-flow__handle-right{right:-6px!important}:host .react-flow .react-flow__handle-bottom{bottom:-6px!important}:host .react-flow .react-flow__handle-left{left:-6px!important}:host .react-flow .react-flow__edge-path{stroke:#000!important;stroke-width:3px!important}:host .react-flow .react-flow__edge.selected .react-flow__edge-path{stroke:#1976d2!important;stroke-width:3}:host .react-flow .react-flow__controls button{background:#fff!important;border:1px solid #333!important;color:#333!important}:host .react-flow .react-flow__controls button:hover{background:#f0f0f0!important}:host .react-flow .react-flow__minimap{background-color:#f8f8f8!important;border:1px solid #333!important}:host .react-flow .react-flow__minimap .react-flow__minimap-mask{fill:#e0e0e0!important}:host .react-flow .react-flow__minimap .react-flow__minimap-node{fill:#333!important}:host .react-flow .react-flow__background pattern{stroke:#e0e0e0!important}:host .react-flow .react-flow__connectionline .react-flow__edge-path{stroke:#1976d2!important;stroke-width:3px!important;stroke-dasharray:5 5!important;animation:dash .5s linear infinite!important}@keyframes dash{to{stroke-dashoffset:-10}}:host .react-flow .react-flow__node-group{background:#f0f0f099!important;border:2px dashed #d1d5db!important;border-radius:16px!important;padding:60px 40px 40px!important;pointer-events:all!important;box-sizing:border-box!important}:host .react-flow .react-flow__node-group.selected{border-color:#3b82f6!important;border-style:solid!important;background:#f0f0f0cc!important}:host .react-flow .react-flow__node-task{background:transparent!important;border:none!important;padding:0!important}\n"] }]
382
+ }], ctorParameters: () => [] });
383
+
384
+ /**
385
+ * Generated bundle index. Do not edit.
386
+ */
387
+
388
+ export { FlowNodeDirective, NODE_TYPES, ReactFlowComponent, ReactFlowComponentStore, createTemplateNodeComponent, setAngularContext };
389
+ //# sourceMappingURL=xxmachina-components-extras-flow.mjs.map