flowstudio 0.0.5 → 0.0.7
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/dist/components/app_layout.d.ts +3 -0
- package/dist/components/app_layout.jsx +16 -0
- package/dist/components/app_layout.jsx.map +1 -0
- package/dist/components/app_settings/data_sources.d.ts +1 -0
- package/dist/components/app_settings/data_sources.jsx +121 -0
- package/dist/components/app_settings/data_sources.jsx.map +1 -0
- package/dist/components/app_settings/deploy.d.ts +1 -0
- package/dist/components/app_settings/deploy.jsx +23 -0
- package/dist/components/app_settings/deploy.jsx.map +1 -0
- package/dist/components/app_settings/index.d.ts +1 -0
- package/dist/components/app_settings/index.jsx +42 -0
- package/dist/components/app_settings/index.jsx.map +1 -0
- package/dist/components/app_settings/service_providers.d.ts +1 -0
- package/dist/components/app_settings/service_providers.jsx +86 -0
- package/dist/components/app_settings/service_providers.jsx.map +1 -0
- package/dist/components/app_settings/simulator.d.ts +1 -0
- package/dist/components/app_settings/simulator.jsx +56 -0
- package/dist/components/app_settings/simulator.jsx.map +1 -0
- package/dist/components/combo_box/index.d.ts +3 -0
- package/dist/components/combo_box/index.jsx +109 -0
- package/dist/components/combo_box/index.jsx.map +1 -0
- package/dist/components/context.d.ts +1 -0
- package/dist/components/context.jsx +25 -0
- package/dist/components/context.jsx.map +1 -0
- package/dist/components/dock_panel.d.ts +2 -0
- package/dist/components/dock_panel.jsx +56 -0
- package/dist/components/dock_panel.jsx.map +1 -0
- package/dist/components/end.d.ts +1 -0
- package/dist/components/end.jsx +5 -0
- package/dist/components/end.jsx.map +1 -0
- package/dist/components/input.d.ts +1 -0
- package/dist/components/input.jsx +20 -0
- package/dist/components/input.jsx.map +1 -0
- package/dist/components/normal.d.ts +1 -0
- package/dist/components/normal.jsx +5 -0
- package/dist/components/normal.jsx.map +1 -0
- package/dist/components/sheet/index.d.ts +1 -0
- package/dist/components/sheet/index.jsx +33 -0
- package/dist/components/sheet/index.jsx.map +1 -0
- package/dist/components/start.d.ts +1 -0
- package/dist/components/start.jsx +38 -0
- package/dist/components/start.jsx.map +1 -0
- package/dist/components/studio/index.d.ts +1 -0
- package/dist/components/studio/index.jsx +90 -0
- package/dist/components/studio/index.jsx.map +1 -0
- package/dist/components/xnode.d.ts +2 -0
- package/dist/components/xnode.jsx +85 -0
- package/dist/components/xnode.jsx.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.js +4 -0
- package/dist/index.js.map +1 -0
- package/dist/zustand/store.d.ts +414 -0
- package/dist/zustand/store.js +48 -0
- package/dist/zustand/store.js.map +1 -0
- package/package.json +2 -2
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { Button, Card, Flex, SegmentedControl, TextField, Link } from "@radix-ui/themes";
|
|
2
|
+
import { BiHome } from "react-icons/bi";
|
|
3
|
+
// import { IoIosCog } from "react-icons/io";
|
|
4
|
+
// import NextLink from 'next/link'
|
|
5
|
+
// import DataSources from "./app_settings/data_sources";
|
|
6
|
+
// import ServiceProviders from "./app_settings/service_providers";
|
|
7
|
+
// import Simulator from "./app_settings/simulator";
|
|
8
|
+
// import Deploy from "./app_settings/deploy";
|
|
9
|
+
// import { FaDatabase } from "react-icons/fa";
|
|
10
|
+
// import Link from "next/link";
|
|
11
|
+
import { useState } from "react";
|
|
12
|
+
import { useConfigStore } from "../zustand/store";
|
|
13
|
+
import AppSettings from "./app_settings";
|
|
14
|
+
import { IoSave } from "react-icons/io5";
|
|
15
|
+
import { useQuery } from "@tanstack/react-query";
|
|
16
|
+
const DockPanel = ({ projectIdentifier }) => {
|
|
17
|
+
const [dataSourcesOpen, setDataSourcesOpen] = useState(false);
|
|
18
|
+
const [serviceProvidersOpen, setServiceProvidersOpen] = useState(false);
|
|
19
|
+
const [simulatorOpen, setSimulatorOpen] = useState(false);
|
|
20
|
+
const [deployOpen, setDeployOpen] = useState(false);
|
|
21
|
+
const { stateType, setStateType } = useConfigStore();
|
|
22
|
+
// const { isOpen: isFunctionsDrawerOpen, onOpen: onFunctionsDrawerOpen, onClose: onFunctionsDrawerClose } = useDisclosure()
|
|
23
|
+
// const { isOpen: isServiceProvidersDrawerOpen, onOpen: onServiceProvidersDrawerOpen, onClose: onServiceProvidersDrawerClose } = useDisclosure()
|
|
24
|
+
// const { isOpen: isSimulatorDrawerOpen, onOpen: onSimulatorDrawerOpen, onClose: onSimulatorDrawerClose } = useDisclosure()
|
|
25
|
+
// const { isOpen: isDeployModalOpen, onOpen: onDeployModalOpen, onClose: onDeployModalClose } = useDisclosure()
|
|
26
|
+
const { data: project, status: projectStatus } = useQuery({
|
|
27
|
+
queryKey: [`project_${projectIdentifier}`, projectIdentifier],
|
|
28
|
+
queryFn: async () => {
|
|
29
|
+
const res = await fetch(`/api/projects/${projectIdentifier}`);
|
|
30
|
+
return (res === null || res === void 0 ? void 0 : res.ok) ? res.json() : [];
|
|
31
|
+
},
|
|
32
|
+
...{ enabled: !!projectIdentifier },
|
|
33
|
+
});
|
|
34
|
+
return (<>
|
|
35
|
+
<Flex width={'100%'} justify={'center'} align={'center'}>
|
|
36
|
+
<Card size={'1'} style={{ padding: 7 }}>
|
|
37
|
+
<Flex gap={'2'}>
|
|
38
|
+
<Link href={'/app'} aria-label='Home'><Button variant={'soft'}><BiHome /></Button></Link>
|
|
39
|
+
<TextField.Root placeholder="Project Title" defaultValue={(project === null || project === void 0 ? void 0 : project.title) || ''}>
|
|
40
|
+
<TextField.Slot side={'right'} pr={'1'}>
|
|
41
|
+
<Button size={'1'} variant={'soft'}><IoSave /></Button>
|
|
42
|
+
</TextField.Slot>
|
|
43
|
+
</TextField.Root>
|
|
44
|
+
<SegmentedControl.Root defaultValue="build" variant={'surface'}>
|
|
45
|
+
<SegmentedControl.Item onClick={() => setStateType('build')} value="build">Build</SegmentedControl.Item>
|
|
46
|
+
<SegmentedControl.Item onClick={() => setStateType('analytics')} value="analytics">Analytics</SegmentedControl.Item>
|
|
47
|
+
</SegmentedControl.Root>
|
|
48
|
+
<AppSettings />
|
|
49
|
+
</Flex>
|
|
50
|
+
|
|
51
|
+
</Card>
|
|
52
|
+
</Flex>
|
|
53
|
+
</>);
|
|
54
|
+
};
|
|
55
|
+
export default DockPanel;
|
|
56
|
+
//# sourceMappingURL=dock_panel.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dock_panel.jsx","sourceRoot":"","sources":["../../src/components/dock_panel.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export default function EndNode({ data }: any): import("react").JSX.Element;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"end.jsx","sourceRoot":"","sources":["../../src/components/end.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,MAAM,SAAS,CAAC;AAG5B,MAAM,CAAC,OAAO,UAAU,OAAO,CAAC,EAAC,IAAI,EAAK;IACtC,OAAO,CACH,CAAC,KAAK,CACF,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CACZ,IAAI,CAAC,CAAC,KAAK,CAAC,CACZ,IAAI,CAAC,CAAC,EAAC,OAAO,EAAC,IAAI,CAAC,OAAO,EAAC,CAAC,CAC7B,MAAM,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,EACjB,CAAC,CAAA;AAEhB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export default function InputNode({ id, y, data }: any): import("react").JSX.Element;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { Button, Flex, TextField, } from "@radix-ui/themes";
|
|
2
|
+
import { useState } from "react";
|
|
3
|
+
import { LiaTimesSolid } from "react-icons/lia";
|
|
4
|
+
import { Handle, Position } from "@xyflow/react";
|
|
5
|
+
export default function InputNode({ id = 'i', y = 100, data }) {
|
|
6
|
+
const [show, setShow] = useState(false);
|
|
7
|
+
const handleClick = () => setShow(!show);
|
|
8
|
+
return (<Flex position={'relative'}>
|
|
9
|
+
<TextField.Root type={'text'} id={'text_value'} placeholder={'Option Text'} autoComplete={'off'} className="nodrag">
|
|
10
|
+
<TextField.Slot>
|
|
11
|
+
<Button aria-label={'close'} size={'1'} variant={'outline'} onClick={handleClick}><LiaTimesSolid /></Button>
|
|
12
|
+
</TextField.Slot>
|
|
13
|
+
|
|
14
|
+
</TextField.Root>
|
|
15
|
+
|
|
16
|
+
{/* <Input size={'1'} type={'text'} textAlign={'end'} className="nodrag" placeholder={'Option Text'} /> */}
|
|
17
|
+
<Handle type="source" position={Position.Right} id={id} style={{ right: -15, background: '#009688', borderColor: '#fff', borderWidth: 1, width: 10, height: 15, borderRadius: 3, position: 'absolute', top: 16 }}/>
|
|
18
|
+
</Flex>);
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=input.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"input.jsx","sourceRoot":"","sources":["../../src/components/input.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAG,MAAM,EAAE,IAAI,EAAE,SAAS,GAAI,MAAM,kBAAkB,CAAC;AAC9D,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACjC,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAGjD,MAAM,CAAC,OAAO,UAAU,SAAS,CAAC,EAAE,EAAE,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,IAAI,EAAO;IAC9D,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IACvC,MAAM,WAAW,GAAG,GAAG,EAAE,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAA;IAExC,OAAO,CACH,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,UAAU,CAAC,CACvB;YAAA,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,YAAY,CAAC,CAAC,WAAW,CAAC,CAAC,aAAa,CAAC,CAAC,YAAY,CAAC,CAAC,KAAK,CAAC,CAAE,SAAS,CAAC,QAAQ,CAChH;gBAAA,CAAC,SAAS,CAAC,IAAK,AAAD,CACX;oBAAA,CAAC,MAAM,CAAE,UAAU,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAE,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,CAAC,WAAW,CAAC,CAAE,CAAC,aAAa,CAAC,AAAD,EAAG,EAAE,MAAM,CAClH;gBAAA,EAAE,SAAS,CAAC,IAAI,CAEpB;;YAAA,EAAE,SAAS,CAAC,IAAI,CAEhB;;YAAA,CAAC,yGAAyG,CAC1G;YAAA,CAAC,MAAM,CACH,IAAI,CAAC,QAAQ,CACb,QAAQ,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CACzB,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE,UAAU,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,EAAE,WAAW,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,YAAY,EAAE,CAAC,EAAE,QAAQ,EAAE,UAAU,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,EAEzK;QAAA,EAAE,IAAI,CAAC,CACV,CAAA;AACL,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export default function NormalNode({ data }: any): import("react").JSX.Element;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"normal.jsx","sourceRoot":"","sources":["../../src/components/normal.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,SAAS,CAAC;AAG5B,MAAM,CAAC,OAAO,UAAU,UAAU,CAAC,EAAC,IAAI,EAAK;IACzC,OAAO,CACH,CAAC,KAAK,CACF,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CACZ,IAAI,CAAC,CAAC,QAAQ,CAAC,CACf,IAAI,CAAC,CAAC,EAAC,OAAO,EAAC,IAAI,CAAC,OAAO,EAAC,CAAC,CAC7B,MAAM,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,EACjB,CAAC,CAAA;AAEhB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export default function Sheet({ children, open, setOpen, onClose, title, showCloseBtn, maxWidth, side, ...rest }: any): import("react").JSX.Element;
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { useEffect, useState } from 'react';
|
|
3
|
+
import { Dialog, IconButton, Flex, Text, Separator } from '@radix-ui/themes';
|
|
4
|
+
import { Cross1Icon } from '@radix-ui/react-icons';
|
|
5
|
+
// import './style.css'
|
|
6
|
+
export default function Sheet({ children, open, setOpen, onClose, title = '', showCloseBtn = true, maxWidth = '500px', side = 'right', ...rest }) {
|
|
7
|
+
const [animationClass, setAnimationClass] = useState('');
|
|
8
|
+
useEffect(() => {
|
|
9
|
+
if (open) {
|
|
10
|
+
setAnimationClass(`slide-in-${side}`);
|
|
11
|
+
}
|
|
12
|
+
else {
|
|
13
|
+
setAnimationClass(`slide-out-${side}`);
|
|
14
|
+
onClose === null || onClose === void 0 ? void 0 : onClose();
|
|
15
|
+
}
|
|
16
|
+
}, [open, side]);
|
|
17
|
+
return (<Dialog.Root open={open} onOpenChange={setOpen}>
|
|
18
|
+
<Dialog.Content className={`dialog-content ${animationClass}`} width={'100%'} maxWidth={maxWidth} style={{ padding: 4 }} {...rest}>
|
|
19
|
+
<Flex direction={'column'} height={'100%'} overflow={'hidden'}>
|
|
20
|
+
<Flex flexShrink={'0'} justify={'between'} align={'center'} p={(title || showCloseBtn) ? '4' : '0'}>
|
|
21
|
+
<Dialog.Title style={{ fontWeight: 'normal', marginBottom: 0 }}>{title && <Text>{title}</Text>}</Dialog.Title>
|
|
22
|
+
{showCloseBtn && <Dialog.Close><IconButton highContrast size={'1'}><Cross1Icon /></IconButton></Dialog.Close>}
|
|
23
|
+
</Flex>
|
|
24
|
+
{title && <Separator size={'4'}/>}
|
|
25
|
+
|
|
26
|
+
<Flex flexGrow={'1'} overflow={'auto'} p={'5'}>
|
|
27
|
+
{children}
|
|
28
|
+
</Flex>
|
|
29
|
+
</Flex>
|
|
30
|
+
</Dialog.Content>
|
|
31
|
+
</Dialog.Root>);
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=index.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.jsx","sourceRoot":"","sources":["../../../src/components/sheet/index.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export default function StartNode({ data }: any): import("react").JSX.Element;
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { Button, Card, TextArea, Flex, Badge, Text, Popover, Box, } from "@radix-ui/themes";
|
|
2
|
+
import InputNode from "./input";
|
|
3
|
+
import { CiMenuKebab } from "react-icons/ci";
|
|
4
|
+
import XNode from "./xnode";
|
|
5
|
+
export default function StartNode({ data }) {
|
|
6
|
+
return (<XNode id={data.id} type={'start'} data={{ message: data.message }} inputs={data.inputs} fns={[
|
|
7
|
+
{ type: 'system', functions: ['Source Finder', 'Session GET'] },
|
|
8
|
+
{ type: 'custom', functions: ['Account Checker'] }
|
|
9
|
+
]}/>);
|
|
10
|
+
return (<Card>
|
|
11
|
+
<Box>
|
|
12
|
+
<Flex width={'100%'} align={'center'} justify={'between'}>
|
|
13
|
+
<Text>Start</Text>
|
|
14
|
+
<Popover.Root>
|
|
15
|
+
<Popover.Trigger>
|
|
16
|
+
<Button size={'1'} aria-label='Options' variant={'outline'}><CiMenuKebab /></Button>
|
|
17
|
+
</Popover.Trigger>
|
|
18
|
+
<Popover.Content maxWidth={'150px'}>
|
|
19
|
+
|
|
20
|
+
</Popover.Content>
|
|
21
|
+
</Popover.Root>
|
|
22
|
+
</Flex>
|
|
23
|
+
</Box>
|
|
24
|
+
<Box>
|
|
25
|
+
<Flex direction={'column'}>
|
|
26
|
+
<TextArea rows={6} size={'1'} className="nodrag" placeholder={'Message'} defaultValue={data.message}></TextArea>
|
|
27
|
+
<Flex direction={'column'}>
|
|
28
|
+
<InputNode id={1} y={50}/>
|
|
29
|
+
<InputNode id={2} y={130}/>
|
|
30
|
+
</Flex>
|
|
31
|
+
<Flex wrap={'wrap'}>
|
|
32
|
+
<Badge size={'1'} color={'green'}>fn (1)</Badge>
|
|
33
|
+
</Flex>
|
|
34
|
+
</Flex>
|
|
35
|
+
</Box>
|
|
36
|
+
</Card>);
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=start.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"start.jsx","sourceRoot":"","sources":["../../src/components/start.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export default function Studio({ theme, accent }: any): import("react").JSX.Element;
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import { Box } from '@radix-ui/themes';
|
|
2
|
+
// import ThemeLayout from '../layouts/ThemeLayout'
|
|
3
|
+
import { ReactFlow, useNodesState, useEdgesState, addEdge, MiniMap, Controls, Background, Panel, SmoothStepEdge } from '@xyflow/react';
|
|
4
|
+
import DockPanel from '../../components/dock_panel';
|
|
5
|
+
import StartNode from '../../components/start';
|
|
6
|
+
import EndNode from '../../components/end';
|
|
7
|
+
import NormalNode from '../../components/normal';
|
|
8
|
+
import InputNode from '../../components/input';
|
|
9
|
+
import { useConfigStore } from '../../zustand/store';
|
|
10
|
+
import AppLayout from "../app_layout";
|
|
11
|
+
import { useCallback, useEffect, useMemo, useRef, useState } from 'react';
|
|
12
|
+
export default function Studio({ theme, accent }) {
|
|
13
|
+
const identifier = '987654321';
|
|
14
|
+
const { appTheme } = useConfigStore();
|
|
15
|
+
////////////////// Nodes Management (React Flow) /////////////////////////////
|
|
16
|
+
const { nodesData, setNodesData, edgesData, setEdgesData } = useConfigStore();
|
|
17
|
+
const nodeTypes = useMemo(() => ({ startNode: StartNode, normalNode: NormalNode, endNode: EndNode, inputNode: InputNode }), []);
|
|
18
|
+
const [nodes, setNodes, onNodesChange] = useNodesState(nodesData);
|
|
19
|
+
const [edges, setEdges, onEdgesChange] = useEdgesState(edgesData);
|
|
20
|
+
const onConnect = useCallback((params) => setEdges((eds) => addEdge(params, eds)), [setEdges]);
|
|
21
|
+
const CustomSmoothstepEdge = ({ data, ...props }) => {
|
|
22
|
+
return <SmoothStepEdge {...props} data={data}/>;
|
|
23
|
+
};
|
|
24
|
+
const edgeUpdateSuccessful = useRef(true);
|
|
25
|
+
const onEdgeUpdateStart = useCallback(() => {
|
|
26
|
+
edgeUpdateSuccessful.current = false;
|
|
27
|
+
}, []);
|
|
28
|
+
const onEdgeUpdate = useCallback((oldEdge, newConnection) => {
|
|
29
|
+
edgeUpdateSuccessful.current = true;
|
|
30
|
+
// setEdges((els:any) => updateEdge(oldEdge, newConnection, els));
|
|
31
|
+
}, []);
|
|
32
|
+
const onEdgeUpdateEnd = useCallback((_, edge) => {
|
|
33
|
+
if (!edgeUpdateSuccessful.current) {
|
|
34
|
+
setEdges((eds) => eds.filter((e) => e.id !== edge.id));
|
|
35
|
+
}
|
|
36
|
+
edgeUpdateSuccessful.current = true;
|
|
37
|
+
}, []);
|
|
38
|
+
useEffect(() => {
|
|
39
|
+
if (nodes) {
|
|
40
|
+
setNodesData(nodes);
|
|
41
|
+
}
|
|
42
|
+
}, [onNodesChange]);
|
|
43
|
+
useEffect(() => {
|
|
44
|
+
if (edges) {
|
|
45
|
+
setEdgesData(edges);
|
|
46
|
+
}
|
|
47
|
+
}, [onEdgesChange]);
|
|
48
|
+
// const getNodeId = () => `randomnode_${+new Date()}`;
|
|
49
|
+
// const onAdd = useCallback(() => {
|
|
50
|
+
// const newNode = {
|
|
51
|
+
// id: getNodeId(),
|
|
52
|
+
// data: { label: 'Added node' },
|
|
53
|
+
// position: {
|
|
54
|
+
// x: Math.random() * window.innerWidth - 100,
|
|
55
|
+
// y: Math.random() * window.innerHeight,
|
|
56
|
+
// },
|
|
57
|
+
// };
|
|
58
|
+
// setNodes((nds) => nds.concat(newNode));
|
|
59
|
+
// }, [setNodes]);
|
|
60
|
+
////////////////// For Context Menu /////////////////////////////
|
|
61
|
+
const [showContextMenu, setShowContextMenu] = useState(false);
|
|
62
|
+
const [contextMenuPosition, setContextMenuPosition] = useState({ x: 0, y: 0 });
|
|
63
|
+
const handleContextMenu = (event) => {
|
|
64
|
+
event.preventDefault(); // Prevent default context menu
|
|
65
|
+
const clickX = event.clientX;
|
|
66
|
+
const clickY = event.clientY;
|
|
67
|
+
setContextMenuPosition({ x: clickX, y: clickY });
|
|
68
|
+
setShowContextMenu(true);
|
|
69
|
+
};
|
|
70
|
+
// const cardBackground = useColorModeValue('rgba(255,255,255,.8)', 'hsla(0,0%,0%,.80)')
|
|
71
|
+
return (<AppLayout theme={theme} accent={accent}>
|
|
72
|
+
<Box position={'absolute'} top={'0'} right={'0'} bottom={'0'} left={'0'} style={{}}>
|
|
73
|
+
<Box position={'relative'} style={{ width: '100%', height: '100%', contain: 'paint', willChange: 'transform', transform: 'translate(0)' }}>
|
|
74
|
+
|
|
75
|
+
<ReactFlow nodes={nodes} edges={edges} onNodesChange={onNodesChange} onEdgesChange={onEdgesChange} onConnect={onConnect} nodeTypes={nodeTypes} snapToGrid={true}
|
|
76
|
+
// onEdgeUpdate={onEdgeUpdate}
|
|
77
|
+
// onEdgeUpdateStart={onEdgeUpdateStart}
|
|
78
|
+
// onEdgeUpdateEnd={onEdgeUpdateEnd}
|
|
79
|
+
attributionPosition={"top-right"} edgeTypes={{ default: CustomSmoothstepEdge }} fitView minZoom={0.2} maxZoom={1} colorMode={appTheme}>
|
|
80
|
+
<Controls />
|
|
81
|
+
<MiniMap />
|
|
82
|
+
<Background gap={12} size={1}/>
|
|
83
|
+
<Panel position="top-center"> <DockPanel projectIdentifier={identifier}/></Panel>
|
|
84
|
+
</ReactFlow>
|
|
85
|
+
|
|
86
|
+
</Box>
|
|
87
|
+
</Box>
|
|
88
|
+
</AppLayout>);
|
|
89
|
+
}
|
|
90
|
+
//# sourceMappingURL=index.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.jsx","sourceRoot":"","sources":["../../../src/components/studio/index.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
import { useState } from "react";
|
|
2
|
+
import { Button, Card, Flex, Badge, Text, Popover, TextField, TextArea, Inset, } from "@radix-ui/themes";
|
|
3
|
+
import { CiMenuKebab } from "react-icons/ci";
|
|
4
|
+
import { Handle, Position } from "@xyflow/react";
|
|
5
|
+
import { BiPlus, BiTrash } from "react-icons/bi";
|
|
6
|
+
import { useConfigStore } from "../zustand/store";
|
|
7
|
+
// Constants
|
|
8
|
+
const color_start = '#009688';
|
|
9
|
+
const color_normal = '#2196f3';
|
|
10
|
+
const color_end = '#ff5c4d';
|
|
11
|
+
export default function XNode({ id = 0, data, fns = [], inputs = [], type = 'normal' }) {
|
|
12
|
+
const { stateType, setStateType } = useConfigStore();
|
|
13
|
+
return (<Card style={{ overflow: 'unset', contain: 'layout' }}>
|
|
14
|
+
<Inset style={{ overflow: 'unset' }}>
|
|
15
|
+
<Flex direction={'column'} gap={'3'}>
|
|
16
|
+
<Flex width={'100%'} align={'center'} justify={'between'} p={'1'} className="drag-handle" style={{ backgroundColor: type == 'start' ? color_start : type == 'normal' ? color_normal : type == 'end' ? color_end : color_normal, borderTopLeftRadius: 7, borderTopRightRadius: 7 }}>
|
|
17
|
+
<Text size={'2'} ml={'1'}>{type == 'start' ? 'Start' : type == 'normal' ? 'Normal' : type == 'end' ? 'End' : 'Normal'}</Text>
|
|
18
|
+
<Popover.Root>
|
|
19
|
+
<Popover.Trigger>
|
|
20
|
+
<Button size={'1'} variant={'soft'} aria-label='Options'><CiMenuKebab /></Button>
|
|
21
|
+
</Popover.Trigger>
|
|
22
|
+
<Popover.Content size={'1'} align="end">
|
|
23
|
+
<Flex direction={'column'} gap={'3'}>
|
|
24
|
+
<Button variant={'ghost'} size={'1'} onClick={() => { }}>Change Node</Button>
|
|
25
|
+
<Button variant={'ghost'} size={'1'} onClick={() => { }} color={'red'}>Delete Node</Button>
|
|
26
|
+
</Flex>
|
|
27
|
+
</Popover.Content>
|
|
28
|
+
</Popover.Root>
|
|
29
|
+
</Flex>
|
|
30
|
+
|
|
31
|
+
<Flex direction={'column'} gap={'3'} px={'3'}>
|
|
32
|
+
{stateType == 'build' ?
|
|
33
|
+
<TextArea size={'1'} className="nodrag" placeholder={'Message'} defaultValue={(data === null || data === void 0 ? void 0 : data.message) || ''}></TextArea>
|
|
34
|
+
: <Text size={'1'} color={'gray'} style={{ maxWidth: '180px', textWrap: 'wrap' }}>{data === null || data === void 0 ? void 0 : data.message}</Text>}
|
|
35
|
+
{/* <TextArea size={'1'} className="nodrag" placeholder={'Message'} defaultValue={data?.message || ''}></TextArea> */}
|
|
36
|
+
{type != 'end' && inputs.length > 0 &&
|
|
37
|
+
<Flex direction={'column'} gap={'2'}>
|
|
38
|
+
{inputs.map((val, ind) => (<InputNode key={ind} identifier={ind} id={val.id} parentType={type} type={val.type} text={val.text} inputType={val.inputType} allowDrag={inputs.length > 1} allowInsert={inputs.length == (ind + 1)}/>))}
|
|
39
|
+
</Flex>}
|
|
40
|
+
</Flex>
|
|
41
|
+
|
|
42
|
+
<Flex width={'100%'} align={'center'} px={'2'} pb={'2'}>
|
|
43
|
+
<Flex flexGrow={'1'}>
|
|
44
|
+
{fns.length > 0 &&
|
|
45
|
+
<Flex wrap={'wrap'} gap={'2'}>
|
|
46
|
+
{fns.map((val, ind) => (<Badge key={ind} size={'1'} color={val.type == 'system' ? 'green' : 'purple'}>fn ({val.functions.length})</Badge>))}
|
|
47
|
+
</Flex>}
|
|
48
|
+
</Flex>
|
|
49
|
+
<Flex flexShrink={'0'}>
|
|
50
|
+
<Text size={'1'}>1pg (50)</Text>
|
|
51
|
+
</Flex>
|
|
52
|
+
</Flex>
|
|
53
|
+
|
|
54
|
+
{type != 'start' &&
|
|
55
|
+
<Handle type="target" position={Position.Left} id="g" style={{ left: -6, background: type == 'normal' ? color_normal : type == 'end' ? color_end : color_normal, borderColor: '#fff', borderWidth: 1, width: 10, height: 15, borderRadius: 3, zIndex: 10 }}/>}
|
|
56
|
+
</Flex>
|
|
57
|
+
</Inset>
|
|
58
|
+
</Card>);
|
|
59
|
+
}
|
|
60
|
+
export function InputNode({ identifier, id = 0, parentType, type = 'choice', text = '', inputType = 'text', allowDrag = false, allowInsert = false }) {
|
|
61
|
+
const [show, setShow] = useState(false);
|
|
62
|
+
const handleClick = () => setShow(!show);
|
|
63
|
+
return (<Flex position={'relative'} gap={'0'} align={'center'} style={{ zIndex: 20 }}>
|
|
64
|
+
<Flex width={'100%'} direction={'column'} align={'end'}>
|
|
65
|
+
<Flex width={'100%'} align={'center'}>
|
|
66
|
+
{allowDrag && <Flex gap={'1'}>
|
|
67
|
+
{/* <Button aria-label={'Drag'} color={parentType == 'start'?'green':parentType == 'normal'?'blue':'blue'} size={'1'} ><AiOutlineDrag/></Button> */}
|
|
68
|
+
<Button size={'1'} variant={'soft'} style={{ borderTopRightRadius: 0, borderBottomRightRadius: 0 }}>{id}</Button>
|
|
69
|
+
</Flex>}
|
|
70
|
+
<TextField.Root type={inputType} defaultValue={text} id={'text_value'} placeholder={type == 'choice' ? 'Option Text' : inputType == 'number' ? '0' : 'User Input'} autoComplete={'off'} style={{ width: '100%' }}>
|
|
71
|
+
{identifier != 0 &&
|
|
72
|
+
<TextField.Slot side={'right'} pr={'1'}>
|
|
73
|
+
<Button color={'red'} aria-label={'close'} size={'1'} variant={'soft'} onClick={handleClick} style={{ width: 20, padding: 4 }}><BiTrash size={20}/></Button>
|
|
74
|
+
</TextField.Slot>}
|
|
75
|
+
|
|
76
|
+
</TextField.Root>
|
|
77
|
+
</Flex>
|
|
78
|
+
{allowInsert &&
|
|
79
|
+
<Button aria-label={'Add'} size={'1'} style={{ borderTopLeftRadius: 0, borderTopRightRadius: 0, marginRight: 5 }}><BiPlus /></Button>}
|
|
80
|
+
</Flex>
|
|
81
|
+
|
|
82
|
+
<Handle type="source" position={Position.Right} isConnectable={true} id={id} style={{ right: -19, background: parentType == 'start' ? color_start : parentType == 'normal' ? color_normal : parentType == 'end' ? color_end : color_normal, borderColor: '#fff', borderWidth: 1, width: 10, height: 15, borderRadius: 3, position: 'absolute', top: 16, zIndex: 20 }}/>
|
|
83
|
+
</Flex>);
|
|
84
|
+
}
|
|
85
|
+
//# sourceMappingURL=xnode.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"xnode.jsx","sourceRoot":"","sources":["../../src/components/xnode.tsx"],"names":[],"mappings":"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"}
|
package/dist/index.d.ts
ADDED
package/dist/index.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,kDAAkD;AAClD,OAAO,MAAM,MAAM,qBAAqB,CAAC;AAEzC,OAAO,EAAE,MAAM,EAAE,CAAC"}
|