Мощные открытые библиотеки для создания графических интерфейсов с использованием React или Svelte. Готовые к использованию и бесконечно настраиваемые.
Репозиторий xyflow является домом для четырёх пакетов:
@xyflow/react
packages/react
reactflow
ветка v11
@xyflow/svelte
packages/svelte
@xyflow/system
packages/system
Используете ли вы React Flow или Svelte Flow для личного проекта? Отлично! Поддержите нас, сообщив о найденных багах, отправив нам скриншоты ваших проектов и звезды на Github 🌟
Используете ли вы React Flow или Svelte Flow в вашей организации и получаете доход от этого? Отлично! Мы полагаемся на вашу поддержку для развития и поддержки наших библиотек под лицензией MIT. Для React Flow вы можете сделать это на сайте React Flow Pro, а для обоих наших библиотек — через Github Sponsors.
Лучший способ начать работу — проверьте раздел React Flow или Svelte Flow "Учебник". Однако если вы хотите получить представление о том, как установить и использовать библиотеки, вы можете просмотреть это здесь:
npm install @xyflow/react
import { useCallback } from 'react';
import {
ReactFlow,
MiniMap,
Controls,
Background,
useNodesState,
useEdgesState,
addEdge,
} from '@xyflow/react';
import '@xyflow/react/dist/style.css';
const initialNodes = [
{ id: '1', position: { x: 0, y: 0 }, data: { label: '1' } },
{ id: '2', position: { x: 0, y: 100 }, data: { label: '2' } },
];
const initialEdges = [{ id: 'e1-2', source: '1', target: '2' }];
function Flow() {
const [nodes, setNodes, onNodesChange] = useNodesState(initialNodes);
const [edges, setEdges, onEdgesChange] = useEdgesState(initialEdges);
const onConnect = useCallback((params) => setEdges((eds) => addEdge(params, eds))), [setEdges]);
return (
<ReactFlow
nodes={nodes}
edges={edges}
onNodesChange={onNodesChange}
onEdgesChange={onEdgesChange}
onConnect={onConnect}
>
<MiniMap />
<Controls />
<Background />
</ReactFlow>
);
}
export default Flow;
npm install @xyflow/svelte
<script lang="ts">
import { writable } from 'svelte/store';
import {
SvelteFlow,
Controls,
Background,
BackgroundVariant,
MiniMap,
} from '@xyflow/svelte';
import '@xyflow/svelte/dist/style.css'
const nodes = writable([
{
id: '1',
type: 'input',
data: { label: 'Input Node' },
position: { x: 0, y: 0 }
},
{
id: '2',
type: 'custom',
data: { label: 'Node' },
position: { x: 0, y: 150 }
}
]);
const edges = writable([
{
id: '1-2',
type: 'default',
source: '1',
target: '2',
label: 'Edge Text'
}
]);
</script>
<SvelteFlow
{nodes}
{edges}
fitView
on:nodeclick={(event) => console.log('on node click', event)}
>
<Controls />
<Background variant={BackgroundVariant.Dots} />
<MiniMap />
</SvelteFlow>
Для выпуска пакетов мы используем changesets вместе с actions GitHub changeset. Основная идея заключается в следующем:
React Flow и Svelte Flow поддерживаются командой за xyflow. Если вам нужна помощь или вы хотите связаться с нами по поводу сотрудничества, свяжитесь с нами через нашу форму обратной связи или присоединитесь к нашему каналу Discord.
React Flow и Svelte Flow имеют лицензию MIT.
Вы можете оставить комментарий после Вход в систему
Неприемлемый контент может быть отображен здесь и не будет показан на странице. Вы можете проверить и изменить его с помощью соответствующей функции редактирования.
Если вы подтверждаете, что содержание не содержит непристойной лексики/перенаправления на рекламу/насилия/вульгарной порнографии/нарушений/пиратства/ложного/незначительного или незаконного контента, связанного с национальными законами и предписаниями, вы можете нажать «Отправить» для подачи апелляции, и мы обработаем ее как можно скорее.
Комментарии ( 0 )