index.tsx 2.2 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 *
 *    http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

18
import type { Graph } from '@antv/x6'
19
import { defineComponent, ref, provide } from 'vue'
20 21 22 23
import DagToolbar from './dag-toolbar'
import DagCanvas from './dag-canvas'
import DagSidebar from './dag-sidebar'
import Styles from './dag.module.scss'
24
import DagFormatModal from './dag-format-modal'
25
import './x6-style.scss'
26 27

export interface Dragged {
28 29 30
  x: number
  y: number
  type: string
31 32 33
}

export default defineComponent({
34
  name: 'workflow-dag',
35 36
  setup(props, context) {
    // Whether the graph can be operated
37 38
    const readonly = ref(false)
    provide('readonly', readonly)
39

40 41
    const graph = ref<Graph>()
    provide('graph', graph)
42 43 44 45 46 47 48 49 50 51 52 53

    // The sidebar slots
    const toolbarSlots = {
      left: context.slots.toolbarLeft,
      right: context.slots.toolbarRight
    }

    // The element currently being dragged up
    const dragged = ref<Dragged>({
      x: 0,
      y: 0,
      type: ''
54
    })
55

56 57 58 59 60 61 62 63 64 65
    // Dag format modal visible
    const formatModalVisible = ref<boolean>(false)
    const openFormatModal = (bool: boolean) => {
      formatModalVisible.value = bool
    }
    provide('formatModal', {
      openFormatModal,
      formatModalVisible
    })

66 67 68 69 70 71 72
    return () => (
      <div class={Styles.dag}>
        <DagToolbar v-slots={toolbarSlots} />
        <div class={Styles.content}>
          <DagSidebar dragged={dragged} />
          <DagCanvas dragged={dragged} />
        </div>
73
        <DagFormatModal show={formatModalVisible.value} />
74 75 76
      </div>
    )
  }
77
})