typeflow-editor
typeflow-editor copied to clipboard
vue + mxGraph to build the draw tool for Typeflow
typeflow-editor
build with the vue and mxGraph
backend resource: https://github.com/yvettemuki/editor-service
Introduction
ATTENTION: LATEST VERSION MAY NOT AS TOTALLY SAME AS THE BELOW INTRO DISPLAYED
Core appearance
data:image/s3,"s3://crabby-images/d804d/d804dde179c0a32fe76160f940d87bb8cb261ece" alt=""
Left side is the element bar including different types of draggable resources, and also including the graph page setting bar of its size
data:image/s3,"s3://crabby-images/ddb81/ddb813dbc17f3a7d8fb89ee9d6700afe88e96ef6" alt=""
To add custom element, click the "+" icon in specific element bar and input the new type name to create new one
data:image/s3,"s3://crabby-images/6f8c0/6f8c0116d91c8ffd7e724a0fda4512bd558e9131" alt=""
To set the specific element type group, click the "gear" icon to open the element type setting panel
data:image/s3,"s3://crabby-images/a2fe8/a2fe8fb72e8a7d96d24ede5fb349cce1fb2db542" alt=""
After drag one of the elements in three types of Definition(PureFunction/InputEndpoint/OutputEndpoint), the form will display to fill
data:image/s3,"s3://crabby-images/3f84c/3f84c85cbb9c3b4b5fac1126a554a7ae49e03fb9" alt=""
You should select the variable type in the type selector and input the variable value
data:image/s3,"s3://crabby-images/bd446/bd446a9a80b331fd24159b7cabecb6b1206adb9e" alt=""
If you create the Array type, you need to choose the Array type in second type selector
data:image/s3,"s3://crabby-images/2862d/2862d39047286c7bcb6e79a39896596d5f6c9c99" alt=""
If you create Object type, you need to click "Object" option and you will get into the create panel
data:image/s3,"s3://crabby-images/96c8c/96c8caf482380fdb599307545f6a6b3cd71a7e04" alt=""
note: all the array type and object type you create will be saved in default (Type Setting function will soon be available)
After fill some Definition creating forms, you can connect them in the rule:
only the same name output of one Definition instance can connect to another Definition instance's input with the same name
data:image/s3,"s3://crabby-images/28df6/28df69dbcd9879e0ca37bc3d672f55cf587860bb" alt=""
data:image/s3,"s3://crabby-images/c2159/c2159ad4081dbaa8972b255e5e9105d6d7cb03d0" alt=""
After finish dragging elements, filling their forms and connecting them, you will get the typeflow model
data:image/s3,"s3://crabby-images/3d493/3d493549e72004ee219fadb967aa3c8b95daba25" alt=""
To check or update the created elements you can double click the Definition vertex (InputEndpoint, OutputEndpoint, PureFunction)
data:image/s3,"s3://crabby-images/52a63/52a6351182870a97d6e95da04c69faba657039e8" alt=""
data:image/s3,"s3://crabby-images/24685/246851f3bf761ec6beb1084164e7d6156e77e3cc" alt=""
To undo, redo, delete, zoom(in/out), you can click the right-side float toolbar
data:image/s3,"s3://crabby-images/990ea/990ea9701da8f0da43a8515f2c42f25a419f562d" alt=""
To import model, export model, generate code and save model, you can click the buttons on the top side
export can choose 3 types: png, svg and xml
data:image/s3,"s3://crabby-images/ab667/ab6673d56238bafbfe8869c09bc2a32fa5a2c16b" alt=""
data:image/s3,"s3://crabby-images/fce60/fce60413aa68365380492f4ec90ca671dd50a9a2" alt=""
When import, you can choose import from local or from database
data:image/s3,"s3://crabby-images/e6e3e/e6e3e822f26333fe67c2f3c11baa36370aa2fd3a" alt=""
When from database, and you can delete model when click the "delete" button on the right top side of each item
data:image/s3,"s3://crabby-images/7c470/7c470419a87e5a2d508ab967f0c8ad56845c9d54" alt=""
To check some model information
data:image/s3,"s3://crabby-images/42fed/42fed51112a982f2ff724c64eb934982d6ee6231" alt=""
When you click the "?" icon, you can get the guidance about how to use typeflow editor
data:image/s3,"s3://crabby-images/e7349/e7349e88e3b66340ac6de037c593e7f79d38618e" alt=""
data:image/s3,"s3://crabby-images/58864/58864271b32a97368fe8569afe10a7431b8ce449" alt=""
About vue-cli installation
This project use vue-cli3, please make sure you have installed vue-cli3 and update node version to at least 8.9
More details about installation, go to https://cli.vuejs.org/zh/guide/installation.html
Project setup
npm install
Compiles and hot-reloads for development
npm run serve
Attention:
Default port is 8080, if you need see vue-cli3 document to change the default port
When you change the backend server address(port), you need to change the proxy in vue.config.js file