WorkflowAdd.vue 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227
  1. <template>
  2. <div class="workflow-add container-height">
  3. <Breadcrumb />
  4. <el-form :model="ruleForm" :rules="rules" ref="ruleFormRef" label-position="top" class="page-add">
  5. <div class="padding16 bg_color_fff border_radius_10">
  6. <div class="gap10">
  7. <div class="line_vertical"></div>
  8. <div class="font_size20 bold">文件上传</div>
  9. <div class="gray999 font_size14">支持格式:JSON、YAML、ZIP(最大10MB)</div>
  10. </div>
  11. <div class="mt10">
  12. <!-- 上传 -->
  13. <FileUploader
  14. ref="fileUploader"
  15. accept=".json,.yaml,.yml,.zip"
  16. :multiple="false"
  17. :auto-upload="true"
  18. :drag="true"
  19. v-model="files"
  20. tip="请上传JSON、YAML、ZIP格式的文件,最大10MB"
  21. @success="handleUploadSuccess"
  22. @error="handleUploadError"
  23. @progress="handleUploadProgress"
  24. />
  25. </div>
  26. </div>
  27. <div class="padding16 bg_color_fff border_radius_10 mt10">
  28. <div class="gap10">
  29. <div class="line_vertical"></div>
  30. <div class="font_size20 bold">基本信息</div>
  31. </div>
  32. <div class="mt10">
  33. <el-form-item label="工作流标题" prop="name">
  34. <el-input v-model="ruleForm.name" placeholder="请输入工作流标题" maxlength="50"/>
  35. </el-form-item>
  36. <el-form-item label="工作流类型" prop="name">
  37. <el-input v-model="ruleForm.name" placeholder="请输入工作流标题" maxlength="50" />
  38. </el-form-item>
  39. <el-form-item label="工作流预览">
  40. <div>支持批量上传文件,文件格式不限,最多只能上传 5 份文件</div>
  41. <!-- 图片类型 -->
  42. <FileUploader
  43. ref="fileUploader"
  44. accept="image/*"
  45. :max-size="100"
  46. :multiple="true"
  47. :auto-upload="true"
  48. list-type="picture-card"
  49. :data="{ directory: 'workflow' }"
  50. buttonText=""
  51. v-model="images"
  52. tip=""
  53. @success="handleUploadSuccess"
  54. @error="handleUploadError"
  55. @progress="handleUploadProgress"
  56. />
  57. </el-form-item>
  58. <el-form-item label="详情">
  59. <BlockNoteEditor v-model="editorContent" :editable="true"/>
  60. </el-form-item>
  61. </div>
  62. </div>
  63. <div class="padding16 bg_color_fff border_radius_10 mt10">
  64. <div class="gap10 mb20">
  65. <div class="line_vertical"></div>
  66. <div class="font_size20 bold">价格设置</div>
  67. </div>
  68. <el-form-item label="付费设置" style="width: 500px">
  69. <div class="gap20 mt10 mb20">
  70. <div class="payType active gap10">
  71. <div class="checkType"></div>
  72. <div>付费(用户需付费后使用)</div>
  73. </div>
  74. <div class="payType gap10">
  75. <div class="checkType"></div>
  76. <div>付费(用户需付费后使用)</div>
  77. </div>
  78. </div>
  79. <el-input v-model="ruleForm.name" placeholder="请输入暴米币数量" maxlength="50" type="number">
  80. <template #append>暴米币</template>
  81. </el-input>
  82. </el-form-item>
  83. </div>
  84. <div class="mt20">
  85. <el-button type="primary" class="font_size16 gradient" @click="submitForm" size="large">
  86. <el-icon><Promotion /></el-icon>
  87. <span class="ml10">发布工作流</span>
  88. </el-button>
  89. <el-button class="font_size16" @click="goBack" size="large">
  90. <el-icon><Close /></el-icon>
  91. <span class="ml10">取消</span>
  92. </el-button>
  93. </div>
  94. </el-form>
  95. </div>
  96. </template>
  97. <script setup>
  98. import { ref, onMounted, reactive } from 'vue'
  99. import { useRoute, useRouter } from 'vue-router'
  100. import FileUploader from '@/components/FileUploader.vue'
  101. import DGTMessage from '@/utils/message'
  102. import BlockNoteEditor from '@/components/BlockNoteEditor.vue';
  103. const route = useRoute()
  104. const router = useRouter()
  105. // 从路由参数中获取 activePlatform
  106. const activePlatform = ref(route.query.activePlatform || '');
  107. // 上传文件列表
  108. const uploadedFiles = ref([])
  109. // 图片列表
  110. const images = ref(
  111. [
  112. {
  113. url:"http://jcxxpt.oss-cn-beijing.aliyuncs.com/id_card/2025/12/26/MFE1Qdqi9tXdc0cb704ec71877b97f0f0bde3a1bbb72_20251226111105A001.jpg"
  114. }
  115. ]
  116. )
  117. const files = ref(
  118. [
  119. {
  120. url:"http://jcxxpt.oss-cn-beijing.aliyuncs.com/common/2025/12/26/Iwk7y3ArgL5Of52f7c2309b56d382f14540de00dd6ea_20251226111356A002.zip"
  121. }
  122. ]
  123. )
  124. // const uploadUrl = ref('/api/upload') // 实际项目中替换为真实的上传接口地址
  125. const editorContent = ref(
  126. [
  127. {
  128. type: "paragraph",
  129. content: [{ type: "text", text: "只读模式" }]
  130. },
  131. {
  132. "id": "378ce968-02c2-4856-888b-c35a355aa84b",
  133. "type": "codeBlock",
  134. "props": {
  135. "language": "text"
  136. },
  137. "content": [],
  138. "children": []
  139. }
  140. ]
  141. );
  142. // 表单实例
  143. const ruleFormRef = ref(null)
  144. const ruleForm = reactive({
  145. name: '',
  146. uploadedFiles: []
  147. })
  148. // 校验规则
  149. const rules = reactive({
  150. name: [
  151. { required: true, message: '请输入工作流标题', trigger: 'blur' },
  152. ],
  153. })
  154. onMounted(() => {
  155. });
  156. // 提交表单
  157. const submitForm = async () => {
  158. console.log('提交表单', ruleForm,images.value)
  159. return;
  160. await ruleFormRef.value.validate((valid, fields) => {
  161. console.log(valid, fields)
  162. if (!valid) {
  163. DGTMessage.warning(fields.name[0].message)
  164. return
  165. }
  166. DGTMessage.success('表单提交成功')
  167. })
  168. }
  169. // 上传成功处理
  170. const handleUploadSuccess = (response, rawFile, uploadedFiles) => {
  171. // DGTMessage.success('文件上传成功')
  172. console.log('上传成功:', response,uploadedFiles)
  173. }
  174. // 上传失败处理
  175. const handleUploadError = (error, rawFile, uploadedFiles) => {
  176. // DGTMessage.error('文件上传失败')
  177. console.error('上传失败:', error)
  178. }
  179. // 上传进度处理
  180. const handleUploadProgress = (event, file, uploadedFiles) => {
  181. console.log('上传进度:', event.percent)
  182. };
  183. const goBack = () => {
  184. router.back()
  185. }
  186. </script>
  187. <style lang="scss">
  188. .workflow-add{
  189. .payType{
  190. background: #EAF0FF;
  191. border-radius: 8px 8px 8px 8px;
  192. border: 1px solid transparent;
  193. padding: 20px 16px;
  194. &.active{
  195. background: #EAF0FF;
  196. border-color: $primary-color;
  197. .checkType{
  198. border-color: $primary-color;
  199. }
  200. }
  201. .checkType{
  202. width: 14px;
  203. height: 14px;
  204. border:4px solid transparent;
  205. border-radius: 50%;
  206. background-color: #ffffff;
  207. }
  208. }
  209. }
  210. </style>