From b054e18aeffd320246d2b73a17bdfe1cbcd2097c Mon Sep 17 00:00:00 2001 From: Jack Medrek Date: Wed, 31 Jan 2024 20:01:27 -0500 Subject: [PATCH] functionality to add new flow and edit flows --- src/components/FlowsPanel.vue | 56 +++++++++++++++++++++++++++-------- src/core/network.ts | 3 +- src/core/typedefs.ts | 1 + 3 files changed, 47 insertions(+), 13 deletions(-) diff --git a/src/components/FlowsPanel.vue b/src/components/FlowsPanel.vue index a836e80..378bff0 100644 --- a/src/components/FlowsPanel.vue +++ b/src/components/FlowsPanel.vue @@ -2,6 +2,19 @@ import { ref, watch, nextTick } from 'vue' import { Network } from '@/hooks/useStates' +const editCellRenderer = () => ({ column, rowIndex, rowData }: any) => { + if (rowIndex === Network.Flows.value.length - 1 && rowData.editing) { + return ( + + ) + } else { + return
{rowData[column.dataKey!]}
+ } +} + const columns: any = [ { key: 'flow_id', @@ -16,28 +29,24 @@ const columns: any = [ title: 'SRC', dataKey: 'e2e_src', width: 40, - align: 'center' + align: 'center', + cellRenderer: editCellRenderer() }, { key: 'dst', title: 'DST', dataKey: 'e2e_dst', width: 40, - align: 'center' + align: 'center', + cellRenderer: editCellRenderer() }, - // { - // key: 'deadline', - // title: 'Deadline', - // dataKey: 'deadline', - // width: 50, - // align: 'center' - // }, { key: 'period', title: 'PERIOD', dataKey: 'period', width: 40, - align: 'center' + align: 'center', + cellRenderer: editCellRenderer() }, { key: 'path', @@ -51,8 +60,8 @@ const columns: any = [ title: 'WORKLOAD', dataKey: 'workload', width: 50, - align: 'center' - // cellRenderer: ({ cellData: payload_size }: any) => payload_size.toString() + align: 'center', + cellRenderer: editCellRenderer() } ] @@ -69,6 +78,27 @@ watch( { deep: true } ) +const addFlow = () => { + const newFlow = { + id: Network.Flows.value.length + 1, + e2e_src: 0, + e2e_dst: 0, + deadline: 0, + workload: 0, + period: 0, + path: [], + editing: true + } + Network.Flows.value.push(newFlow) + console.log('added flow') +} + +const saveFlow = () => { + const lastFlow = Network.Flows.value[Network.Flows.value.length - 1] + // lastFlow.path = Network.findPath(lastFlow.e2e_src, lastFlow.e2e_dst) + lastFlow.editing = false +} + const Row = ({ cells, rowData }: any) => { if (rowData.detail) return
{rowData.detail}
return cells @@ -80,6 +110,8 @@ Row.inheritAttrs = false