@xxmachina/components 19.0.0-preview.9 → 19.1.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.
- package/extras/flow/index.d.ts +183 -0
- package/features/command/index.d.ts +67 -1
- package/features/query/index.d.ts +117 -1
- package/fesm2022/xxmachina-components-extras-flow.mjs +389 -0
- package/fesm2022/xxmachina-components-extras-flow.mjs.map +1 -0
- package/fesm2022/xxmachina-components-features-command.mjs +7 -8
- package/fesm2022/xxmachina-components-features-command.mjs.map +1 -1
- package/fesm2022/xxmachina-components-features-query.mjs +120 -96
- package/fesm2022/xxmachina-components-features-query.mjs.map +1 -1
- package/fesm2022/xxmachina-components-groups-command-form.mjs +3 -3
- package/fesm2022/xxmachina-components-groups-command-form.mjs.map +1 -1
- package/fesm2022/xxmachina-components-groups-query-form.mjs +110 -24
- package/fesm2022/xxmachina-components-groups-query-form.mjs.map +1 -1
- package/fesm2022/xxmachina-components-molecules-calendar-paginator.mjs +4 -4
- package/fesm2022/xxmachina-components-molecules-calendar-paginator.mjs.map +1 -1
- package/fesm2022/xxmachina-components-molecules-daily-cell.mjs +13 -13
- package/fesm2022/xxmachina-components-molecules-daily-cell.mjs.map +1 -1
- package/fesm2022/xxmachina-components-molecules-weekly-header.mjs +5 -5
- package/fesm2022/xxmachina-components-molecules-weekly-header.mjs.map +1 -1
- package/fesm2022/xxmachina-components-organisms-calendar-section.mjs +5 -5
- package/fesm2022/xxmachina-components-organisms-calendar-section.mjs.map +1 -1
- package/fesm2022/xxmachina-components-organisms-event-input-section.mjs +3 -3
- package/fesm2022/xxmachina-components-organisms-event-input-section.mjs.map +1 -1
- package/fesm2022/xxmachina-components-organisms-terminal-input-section.mjs +123 -0
- package/fesm2022/xxmachina-components-organisms-terminal-input-section.mjs.map +1 -0
- package/fesm2022/xxmachina-components-organisms-video-trimmer-section.mjs +6 -6
- package/fesm2022/xxmachina-components-organisms-video-trimmer-section.mjs.map +1 -1
- package/fesm2022/xxmachina-components-organisms-xterm.mjs +94 -0
- package/fesm2022/xxmachina-components-organisms-xterm.mjs.map +1 -0
- package/fesm2022/xxmachina-components-pages-command.mjs +196 -48
- package/fesm2022/xxmachina-components-pages-command.mjs.map +1 -1
- package/fesm2022/xxmachina-components-pages-query.mjs +394 -92
- package/fesm2022/xxmachina-components-pages-query.mjs.map +1 -1
- package/fesm2022/xxmachina-components-pages-thread.mjs +176 -0
- package/fesm2022/xxmachina-components-pages-thread.mjs.map +1 -0
- package/fesm2022/{xxmachina-components-routes-commands-command.routes-CeRVzy3Z.mjs → xxmachina-components-routes-commands-command.routes-CSwIdXZg.mjs} +4 -11
- package/fesm2022/xxmachina-components-routes-commands-command.routes-CSwIdXZg.mjs.map +1 -0
- package/fesm2022/{xxmachina-components-routes-commands-pages.routes-Cm6Yd40h.mjs → xxmachina-components-routes-commands-pages.routes-j2xVop4W.mjs} +4 -4
- package/fesm2022/xxmachina-components-routes-commands-pages.routes-j2xVop4W.mjs.map +1 -0
- package/fesm2022/xxmachina-components-routes-commands.mjs +8 -3
- package/fesm2022/xxmachina-components-routes-commands.mjs.map +1 -1
- package/fesm2022/xxmachina-components-routes-pages.mjs +3 -1
- package/fesm2022/xxmachina-components-routes-pages.mjs.map +1 -1
- package/fesm2022/xxmachina-components-routes-preloading.mjs +3 -3
- package/fesm2022/xxmachina-components-routes-preloading.mjs.map +1 -1
- package/fesm2022/xxmachina-components-routes-queries-pages.routes-CfrglCIL.mjs +9 -0
- package/fesm2022/xxmachina-components-routes-queries-pages.routes-CfrglCIL.mjs.map +1 -0
- package/fesm2022/xxmachina-components-routes-queries.mjs +16 -7
- package/fesm2022/xxmachina-components-routes-queries.mjs.map +1 -1
- package/fesm2022/{xxmachina-components-routes-query-pages.routes-H2vrF7kQ.mjs → xxmachina-components-routes-query-pages.routes-CxTbOJDQ.mjs} +9 -9
- package/fesm2022/xxmachina-components-routes-query-pages.routes-CxTbOJDQ.mjs.map +1 -0
- package/fesm2022/xxmachina-components-routes-query.mjs +5 -3
- package/fesm2022/xxmachina-components-routes-query.mjs.map +1 -1
- package/fesm2022/{xxmachina-components-routes-resources-pages.routes-BSjrrV1g.mjs → xxmachina-components-routes-resources-pages.routes-CzjQOxwT.mjs} +4 -4
- package/fesm2022/xxmachina-components-routes-resources-pages.routes-CzjQOxwT.mjs.map +1 -0
- package/fesm2022/{xxmachina-components-routes-resources-resource.routes-DzGgwitX.mjs → xxmachina-components-routes-resources-resource.routes-C5KpB3KM.mjs} +3 -3
- package/fesm2022/xxmachina-components-routes-resources-resource.routes-C5KpB3KM.mjs.map +1 -0
- package/fesm2022/xxmachina-components-routes-resources.mjs +8 -6
- package/fesm2022/xxmachina-components-routes-resources.mjs.map +1 -1
- package/fesm2022/xxmachina-components-routes-side-chat.mjs +4 -112
- package/fesm2022/xxmachina-components-routes-side-chat.mjs.map +1 -1
- package/fesm2022/xxmachina-components-routes-side.mjs +4 -2
- package/fesm2022/xxmachina-components-routes-side.mjs.map +1 -1
- package/fesm2022/xxmachina-components-routes-transformer.mjs +99 -0
- package/fesm2022/xxmachina-components-routes-transformer.mjs.map +1 -0
- package/fesm2022/xxmachina-components-routes-transformers-pages.routes-02pVsNas.mjs +9 -0
- package/fesm2022/xxmachina-components-routes-transformers-pages.routes-02pVsNas.mjs.map +1 -0
- package/fesm2022/xxmachina-components-routes-transformers.mjs +75 -0
- package/fesm2022/xxmachina-components-routes-transformers.mjs.map +1 -0
- package/fesm2022/xxmachina-components-routes.mjs +8 -4
- package/fesm2022/xxmachina-components-routes.mjs.map +1 -1
- package/fesm2022/xxmachina-components-services-app.mjs +30 -0
- package/fesm2022/xxmachina-components-services-app.mjs.map +1 -0
- package/fesm2022/xxmachina-components-services-assistant.mjs +3 -3
- package/fesm2022/xxmachina-components-services-assistant.mjs.map +1 -1
- package/fesm2022/xxmachina-components-services-calendar.mjs +3 -3
- package/fesm2022/xxmachina-components-services-calendar.mjs.map +1 -1
- package/fesm2022/xxmachina-components-services-command.mjs +11 -10
- package/fesm2022/xxmachina-components-services-command.mjs.map +1 -1
- package/fesm2022/xxmachina-components-services-context.mjs +23 -0
- package/fesm2022/xxmachina-components-services-context.mjs.map +1 -0
- package/fesm2022/xxmachina-components-services-contract.mjs +4 -4
- package/fesm2022/xxmachina-components-services-contract.mjs.map +1 -1
- package/fesm2022/xxmachina-components-services-debug.mjs +3 -3
- package/fesm2022/xxmachina-components-services-debug.mjs.map +1 -1
- package/fesm2022/xxmachina-components-services-forms-query.mjs +13 -3
- package/fesm2022/xxmachina-components-services-forms-query.mjs.map +1 -1
- package/fesm2022/xxmachina-components-services-forms-schedule.mjs +4 -4
- package/fesm2022/xxmachina-components-services-forms-schedule.mjs.map +1 -1
- package/fesm2022/xxmachina-components-services-forms-variables.mjs +34 -0
- package/fesm2022/xxmachina-components-services-forms-variables.mjs.map +1 -0
- package/fesm2022/xxmachina-components-services-graphql.mjs +7 -6
- package/fesm2022/xxmachina-components-services-graphql.mjs.map +1 -1
- package/fesm2022/xxmachina-components-services-invoice.mjs +7 -4
- package/fesm2022/xxmachina-components-services-invoice.mjs.map +1 -1
- package/fesm2022/xxmachina-components-services-json-schema.mjs +3 -3
- package/fesm2022/xxmachina-components-services-json-schema.mjs.map +1 -1
- package/fesm2022/xxmachina-components-services-link.mjs +3 -3
- package/fesm2022/xxmachina-components-services-link.mjs.map +1 -1
- package/fesm2022/xxmachina-components-services-message.mjs +50 -0
- package/fesm2022/xxmachina-components-services-message.mjs.map +1 -0
- package/fesm2022/xxmachina-components-services-openai.mjs +113 -0
- package/fesm2022/xxmachina-components-services-openai.mjs.map +1 -0
- package/fesm2022/xxmachina-components-services-openapi.mjs +5 -5
- package/fesm2022/xxmachina-components-services-openapi.mjs.map +1 -1
- package/fesm2022/xxmachina-components-services-order.mjs +4 -4
- package/fesm2022/xxmachina-components-services-order.mjs.map +1 -1
- package/fesm2022/xxmachina-components-services-partner.mjs +4 -4
- package/fesm2022/xxmachina-components-services-partner.mjs.map +1 -1
- package/fesm2022/xxmachina-components-services-query.mjs +32 -45
- package/fesm2022/xxmachina-components-services-query.mjs.map +1 -1
- package/fesm2022/xxmachina-components-services-recording.mjs +3 -3
- package/fesm2022/xxmachina-components-services-recording.mjs.map +1 -1
- package/fesm2022/xxmachina-components-services-schedule.mjs +10 -7
- package/fesm2022/xxmachina-components-services-schedule.mjs.map +1 -1
- package/fesm2022/xxmachina-components-services-thread.mjs +5 -7
- package/fesm2022/xxmachina-components-services-thread.mjs.map +1 -1
- package/fesm2022/xxmachina-components-services-transformer.mjs +31 -0
- package/fesm2022/xxmachina-components-services-transformer.mjs.map +1 -0
- package/fesm2022/xxmachina-components-services-youtube.mjs +3 -3
- package/fesm2022/xxmachina-components-services-youtube.mjs.map +1 -1
- package/fesm2022/xxmachina-components-templates-agent.mjs +549 -0
- package/fesm2022/xxmachina-components-templates-agent.mjs.map +1 -0
- package/fesm2022/xxmachina-components-templates-background.mjs +202 -5
- package/fesm2022/xxmachina-components-templates-background.mjs.map +1 -1
- package/fesm2022/xxmachina-components-templates-invoice-iframe.mjs +3 -3
- package/fesm2022/xxmachina-components-templates-invoice-iframe.mjs.map +1 -1
- package/fesm2022/xxmachina-components-templates-scheduler.mjs +5 -5
- package/fesm2022/xxmachina-components-templates-scheduler.mjs.map +1 -1
- package/fesm2022/xxmachina-components-templates-video.mjs +6 -6
- package/fesm2022/xxmachina-components-templates-video.mjs.map +1 -1
- package/fesm2022/xxmachina-components-validators-query.mjs +2 -2
- package/fesm2022/xxmachina-components-validators-query.mjs.map +1 -1
- package/fesm2022/xxmachina-components.mjs +218 -39
- package/fesm2022/xxmachina-components.mjs.map +1 -1
- package/groups/command-form/index.d.ts +13 -1
- package/groups/query-form/index.d.ts +54 -1
- package/index.d.ts +66 -3
- package/molecules/calendar-paginator/index.d.ts +14 -1
- package/molecules/daily-cell/index.d.ts +35 -1
- package/molecules/weekly-header/index.d.ts +11 -1
- package/organisms/calendar-section/index.d.ts +25 -1
- package/organisms/event-input-section/index.d.ts +45 -1
- package/organisms/terminal-input-section/index.d.ts +37 -0
- package/organisms/video-trimmer-section/index.d.ts +30 -1
- package/organisms/xterm/index.d.ts +23 -0
- package/package.json +53 -5
- package/pages/command/index.d.ts +217 -1
- package/pages/query/index.d.ts +292 -1
- package/pages/thread/index.d.ts +109 -0
- package/routes/commands/index.d.ts +5 -1
- package/routes/index.d.ts +4 -1
- package/routes/pages/index.d.ts +5 -1
- package/routes/preloading/index.d.ts +11 -1
- package/routes/queries/index.d.ts +5 -1
- package/routes/query/index.d.ts +5 -1
- package/routes/resources/index.d.ts +5 -1
- package/routes/side/chat/index.d.ts +5 -2
- package/routes/side/index.d.ts +5 -1
- package/routes/transformer/index.d.ts +5 -0
- package/routes/transformers/index.d.ts +5 -0
- package/services/app/index.d.ts +17 -0
- package/services/assistant/index.d.ts +20 -1
- package/services/calendar/index.d.ts +13 -1
- package/services/command/index.d.ts +54 -1
- package/services/context/index.d.ts +10 -0
- package/services/contract/index.d.ts +11 -1
- package/services/debug/index.d.ts +14 -1
- package/services/forms/query/index.d.ts +45 -1
- package/services/forms/schedule/index.d.ts +42 -1
- package/services/forms/variables/index.d.ts +12 -0
- package/services/graphql/index.d.ts +20 -1
- package/services/invoice/index.d.ts +19 -1
- package/services/json-schema/index.d.ts +15 -1
- package/services/link/index.d.ts +13 -1
- package/services/message/index.d.ts +23 -0
- package/services/openai/index.d.ts +35 -0
- package/services/openapi/index.d.ts +17 -1
- package/services/order/index.d.ts +13 -1
- package/services/partner/index.d.ts +11 -1
- package/services/query/index.d.ts +42 -1
- package/services/recording/index.d.ts +20 -1
- package/services/schedule/index.d.ts +26 -1
- package/services/thread/index.d.ts +30 -1
- package/services/transformer/index.d.ts +19 -0
- package/services/youtube/index.d.ts +10 -1
- package/templates/agent/index.d.ts +54 -0
- package/templates/background/index.d.ts +44 -1
- package/templates/invoice-iframe/index.d.ts +13 -1
- package/templates/scheduler/index.d.ts +31 -1
- package/templates/video/index.d.ts +36 -1
- package/validators/query/index.d.ts +7 -1
- package/app.d.ts +0 -7
- package/features/command/command.feature.d.ts +0 -63
- package/features/query/query.feature.d.ts +0 -92
- package/fesm2022/xxmachina-components-routes-commands-command.routes-CeRVzy3Z.mjs.map +0 -1
- package/fesm2022/xxmachina-components-routes-commands-pages.routes-Cm6Yd40h.mjs.map +0 -1
- package/fesm2022/xxmachina-components-routes-queries-pages.routes-BfWsTCij.mjs +0 -9
- package/fesm2022/xxmachina-components-routes-queries-pages.routes-BfWsTCij.mjs.map +0 -1
- package/fesm2022/xxmachina-components-routes-query-pages.routes-H2vrF7kQ.mjs.map +0 -1
- package/fesm2022/xxmachina-components-routes-resources-pages.routes-BSjrrV1g.mjs.map +0 -1
- package/fesm2022/xxmachina-components-routes-resources-resource.routes-DzGgwitX.mjs.map +0 -1
- package/fesm2022/xxmachina-components-services-query-config.mjs +0 -47
- package/fesm2022/xxmachina-components-services-query-config.mjs.map +0 -1
- package/groups/command-form/command-form.group.d.ts +0 -10
- package/groups/query-form/query-form.group.d.ts +0 -19
- package/molecules/calendar-paginator/calendar-paginator.molecule.d.ts +0 -11
- package/molecules/daily-cell/daily-cell.molecule.d.ts +0 -32
- package/molecules/weekly-header/weekly-header.molecule.d.ts +0 -8
- package/organisms/calendar-section/calendar-section.organism.d.ts +0 -22
- package/organisms/event-input-section/event-input-section.organism.d.ts +0 -43
- package/organisms/video-trimmer-section/video-trimmer-section.organism.d.ts +0 -25
- package/pages/command/command.page.d.ts +0 -113
- package/pages/query/query.page.d.ts +0 -145
- package/router/index.d.ts +0 -5
- package/routes/commands/commands.routes.d.ts +0 -3
- package/routes/commands/pages/command/command.routes.d.ts +0 -2
- package/routes/commands/pages/pages.routes.d.ts +0 -3
- package/routes/pages/pages.routes.d.ts +0 -3
- package/routes/preloading/preloading.strategy.d.ts +0 -8
- package/routes/queries/pages/pages.routes.d.ts +0 -3
- package/routes/queries/queries.routes.d.ts +0 -3
- package/routes/query/pages/pages.routes.d.ts +0 -3
- package/routes/query/query.routes.d.ts +0 -4
- package/routes/resources/pages/pages.routes.d.ts +0 -3
- package/routes/resources/pages/resource/resource.routes.d.ts +0 -3
- package/routes/resources/resources.routes.d.ts +0 -3
- package/routes/side/chat/chat.component.d.ts +0 -37
- package/routes/side/chat/chat.routes.d.ts +0 -3
- package/routes/side/pages.routes.d.ts +0 -3
- package/services/assistant/assistant.service.d.ts +0 -17
- package/services/calendar/calendar.service.d.ts +0 -10
- package/services/command/command.service.d.ts +0 -49
- package/services/contract/contract.service.d.ts +0 -7
- package/services/debug/debug.service.d.ts +0 -11
- package/services/forms/query/query.service.d.ts +0 -38
- package/services/forms/schedule/schedule.service.d.ts +0 -39
- package/services/graphql/graphql.service.d.ts +0 -14
- package/services/invoice/invoice.service.d.ts +0 -15
- package/services/json-schema/json-schema.service.d.ts +0 -12
- package/services/link/link.service.d.ts +0 -10
- package/services/openapi/openapi.service.d.ts +0 -14
- package/services/order/order.service.d.ts +0 -10
- package/services/partner/partner.service.d.ts +0 -7
- package/services/query/query.service.d.ts +0 -34
- package/services/query-config/index.d.ts +0 -1
- package/services/query-config/query-config.service.d.ts +0 -26
- package/services/recording/recording.service.d.ts +0 -17
- package/services/schedule/schedule.service.d.ts +0 -23
- package/services/thread/thread.service.d.ts +0 -27
- package/services/youtube/youtube.service.d.ts +0 -7
- package/templates/background/background.template.d.ts +0 -13
- package/templates/invoice-iframe/invoice-iframe.template.d.ts +0 -10
- package/templates/scheduler/scheduler.template.d.ts +0 -29
- package/templates/video/video.template.d.ts +0 -31
- 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
|