a.html 44 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta name="viewport"
  6. content="width=device-width, initial-scale=1, maximum-scale=1, minimum-scale=1, user-scalable=no" />
  7. <link rel="stylesheet" href="./resource/vantIndex.css" />
  8. <link rel="stylesheet" href="./vue-form-making/index.css">
  9. </head>
  10. <body>
  11. <style>
  12. :root:root {
  13. --van-nav-bar-background: rgb(21, 122, 44);
  14. --van-nav-bar-title-text-color: rgb(255, 255, 255);
  15. --van-nav-bar-icon-color: rgb(255, 255, 255);
  16. }
  17. .blank_adopzrdd {
  18. display: flex;
  19. align-items: center;
  20. margin-bottom: 10px;
  21. }
  22. .blank_adopzrdd>span {
  23. display: inline-block;
  24. width: 80px;
  25. }
  26. .seal-form-row {
  27. display: flex; align-items: center; padding: 10px 16px;
  28. border-bottom: 1px solid #ebedf0; background: #fff;
  29. }
  30. .seal-form-label { width: 100px; font-size: 14px; color: #646566; flex-shrink: 0; }
  31. .seal-form-val { flex: 1; font-size: 14px; color: #333; text-align: right; }
  32. .seal-form-arrow { font-size: 20px; color: #c8c9cc; margin-left: 8px; }
  33. .seal-form-input { flex: 1; border: none; font-size: 14px; text-align: right; outline: none; background: transparent; }
  34. .seal-card { background: #fff; border-radius: 8px; margin-bottom: 10px; overflow: hidden; box-shadow: 0 1px 4px rgba(0,0,0,.08); }
  35. .seal-card-header { display: flex; align-items: center; padding: 10px 12px; background: #f7f8fa; border-bottom: 1px solid #ebedf0; }
  36. .seal-card-index { font-size: 14px; font-weight: bold; color: #157A2C; margin-right: 8px; }
  37. .seal-card-type { flex: 1; font-size: 15px; font-weight: bold; color: #323233; }
  38. .seal-card-actions { display: flex; gap: 6px; flex-shrink: 0; }
  39. .seal-card-body { padding: 8px 12px; }
  40. .seal-card-row { display: flex; padding: 6px 0; font-size: 13px; }
  41. .seal-card-label { width: 42px; color: #969799; flex-shrink: 0; }
  42. .seal-card-value { flex: 1; color: #323233; word-break: break-all; }
  43. :root#app {
  44. background: #4298fd0d;
  45. }
  46. ::v-deep.fm-form-item {
  47. margin-bottom: 10px !important;
  48. }
  49. </style>
  50. <div id="app">
  51. <van-nav-bar height='100rpx;margin-top:100rpx' @click-left="onClickLeft"
  52. style="background-color: rgb(21, 122, 44);color: rgb(255, 255, 255);" :title="title" left-arrow
  53. :safe-area-inset-top='true' :placeholder='true' :fixed='true'></van-nav-bar>
  54. <fm-generate-vant-form style='height: 81vh !important;overflow: auto;background: #a3a6ad1c;margin-top:44px'
  55. v-if='isFlag' :data="jsonData" :value="form.valueJson" ref="generateForm" :edit='isEdit' @on-upload-local="handleUploadLocal">
  56. <!-- 费用报销 -->
  57. <template v-slot:blank_adopzrdd="scope">
  58. <div style="width: 100%;">
  59. <van-button type="primary" size="small" @click="addNewRow('blank_adopzrdd')"
  60. style="margin-bottom: 10px">添加报销事项</van-button>
  61. <div v-for="(item, index) in scope.model.blank_adopzrdd" :key="index" style="width: 100%;">
  62. <div class="blank_adopzrdd">
  63. <span>{{ index + 1 }}报销事项:</span>
  64. <van-field rows="1" v-model="scope.model.blank_adopzrdd[index].remark" type="textarea"
  65. autosize style="width: calc(100% - 80px)"></van-field>
  66. </div>
  67. <div class="blank_adopzrdd">
  68. <span>
  69. <!-- <van-icon @click="delNewRow('blank_adopzrdd', index)" name="delete"
  70. style="color: #f56c6c;"></van-icon> -->
  71. 金额:</span>
  72. <van-field v-model="scope.model.blank_adopzrdd[index].price" type="number"
  73. style="width: calc(100% - 80px)"
  74. @change="changePrice(scope.model.blank_adopzrdd)"></van-field>
  75. </div>
  76. <div class="blank_adopzrdd">
  77. <span>
  78. <van-icon @click="delNewRow('blank_adopzrdd', index, true)" name="delete"
  79. style="color: #f56c6c;"></van-icon>
  80. 附件:</span>
  81. <template v-if="item.files && item.files.length">
  82. <van-badge :content="item.files.length">
  83. <van-button type="primary" size="mini" @click="handleUploadLocal('blank_adopzrdd', index)">上传附件</van-button>
  84. </van-badge>
  85. </template>
  86. <van-button v-else type="primary" size="mini" @click="handleUploadLocal('blank_adopzrdd', index)">上传附件</van-button>
  87. </div>
  88. </div>
  89. </div>
  90. </template>
  91. <template v-slot:manage_workorder="scope">
  92. <van-field v-model="scope.model.manage_workorder.code" readonly @click="addWorkOrder()"></van-field>
  93. </template>
  94. <template v-slot:blank_use_seal="scope">
  95. <div style="width: 100%;">
  96. <!-- 列表项 -->
  97. <view v-for="(item, index) in scope.model.blank_use_seal" :key="index" class="seal-card">
  98. <div class="seal-card-header">
  99. <span class="seal-card-index">{{ index + 1 }}.</span>
  100. <span class="seal-card-type">{{ item.useSealType || '未选择类型' }}</span>
  101. <div class="seal-card-actions">
  102. <van-button size="mini" type="primary" plain @click="openSealEditDialog(scope, 'edit', index)">编辑</van-button>
  103. <van-button size="mini" type="danger" plain @click="delNewRow('blank_use_seal', index)">删除</van-button>
  104. </div>
  105. </div>
  106. <div class="seal-card-body">
  107. <div class="seal-card-row">
  108. <span class="seal-card-label">事由</span>
  109. <span class="seal-card-value">{{ item.useSealRemark || '未填写' }}</span>
  110. </div>
  111. <div class="seal-card-row">
  112. <span class="seal-card-label">印章</span>
  113. <span class="seal-card-value">{{ item.useSealName || '未选择' }}</span>
  114. </div>
  115. </div>
  116. </view>
  117. <van-button type="primary" size="small" block @click="openSealEditDialog(scope, 'add', scope.model.blank_use_seal?scope.model.blank_use_seal.length:0)" style="margin-bottom:10px">+ 添加印章使用</van-button>
  118. </div>
  119. </template>
  120. <template v-slot:blank_use_qualification="scope">
  121. <div style="width: 100%;">
  122. <view v-for="(item, index) in scope.model.blank_use_qualification" :key="index" class="seal-card">
  123. <div class="seal-card-header">
  124. <span class="seal-card-index">{{ index + 1 }}.</span>
  125. <span class="seal-card-type">{{ item.useQualificationType || '未选择类型' }}</span>
  126. <div class="seal-card-actions">
  127. <van-button size="mini" type="primary" plain @click="openQualEditDialog(scope, 'edit', index)">编辑</van-button>
  128. <van-button size="mini" type="danger" plain @click="delNewRow('blank_use_qualification', index)">删除</van-button>
  129. </div>
  130. </div>
  131. <div class="seal-card-body">
  132. <div class="seal-card-row">
  133. <span class="seal-card-label">事由</span>
  134. <span class="seal-card-value">{{ item.useQualificationRemark || '未填写' }}</span>
  135. </div>
  136. <div class="seal-card-row">
  137. <span class="seal-card-label">名称</span>
  138. <span class="seal-card-value">{{ item.useQualificationName || '未选择' }}</span>
  139. </div>
  140. </div>
  141. </view>
  142. <van-button type="primary" size="small" block @click="openQualEditDialog(scope, 'add', scope.model.blank_use_qualification?scope.model.blank_use_qualification.length:0)" style="margin-bottom:10px">+ 添加资质使用</van-button>
  143. </div>
  144. </template>
  145. <template v-slot:blank_application_component="scope">
  146. <div style="width: 100%;">
  147. <view v-for="(item, index) in scope.model.blank_application_component" :key="index" class="seal-card">
  148. <div class="seal-card-header">
  149. <span class="seal-card-index">{{ index + 1 }}.</span>
  150. <span class="seal-card-type">{{ item.productName || '未选择产品' }}</span>
  151. <div class="seal-card-actions">
  152. <van-button size="mini" type="primary" plain @click="openAppEditDialog(scope, 'edit', index)">编辑</van-button>
  153. <van-button size="mini" type="danger" plain @click="delNewRow('blank_application_component', index)">删除</van-button>
  154. </div>
  155. </div>
  156. <div class="seal-card-body">
  157. <div class="seal-card-row">
  158. <span class="seal-card-label">数量</span>
  159. <span class="seal-card-value">{{ item.quantity || '未填写' }}</span>
  160. </div>
  161. <div class="seal-card-row">
  162. <span class="seal-card-label">规格</span>
  163. <span class="seal-card-value">{{ item.specification || '未填写' }}</span>
  164. </div>
  165. </div>
  166. </view>
  167. <van-button type="primary" size="small" block @click="openAppEditDialog(scope, 'add', scope.model.blank_application_component?scope.model.blank_application_component.length:0)" style="margin-bottom:10px">+ 添加产品</van-button>
  168. </div>
  169. </template>
  170. <template v-slot:blank_business_trip="scope">
  171. <div style="width: 100%;">
  172. <view v-for="(item, index) in scope.model.blank_business_trip" :key="index" class="seal-card">
  173. <div class="seal-card-header">
  174. <span class="seal-card-index">{{ index + 1 }}.</span>
  175. <span class="seal-card-type">{{ item.transportation || '未知交通' }} {{ item.departureCity || '?' }}→{{ item.destinationCity || '?' }}</span>
  176. <div class="seal-card-actions">
  177. <van-button size="mini" type="primary" plain @click="openTripEditDialog(scope, 'edit', index)">编辑</van-button>
  178. <van-button size="mini" type="danger" plain @click="delNewRow('blank_business_trip', index);calcTripTotal(scope)">删除</van-button>
  179. </div>
  180. </div>
  181. <div class="seal-card-body">
  182. <div class="seal-card-row">
  183. <span class="seal-card-label">往返</span>
  184. <span class="seal-card-value">{{ item.isRoundTrip || '未填写' }}</span>
  185. </div>
  186. <div class="seal-card-row">
  187. <span class="seal-card-label">时间</span>
  188. <span class="seal-card-value">{{ item.startTime || '-' }} ~ {{ item.endTime || '-' }}</span>
  189. </div>
  190. <div class="seal-card-row">
  191. <span class="seal-card-label">时长</span>
  192. <span class="seal-card-value">{{ item.duration || '-' }}</span>
  193. </div>
  194. </div>
  195. </view>
  196. <van-button type="primary" size="small" block @click="openTripEditDialog(scope, 'add', scope.model.blank_business_trip?scope.model.blank_business_trip.length:0)" style="margin-bottom:10px">+ 添加行程</van-button>
  197. </div>
  198. </template>
  199. <template v-slot:blank_purchase_requisition="scope">
  200. <div style="width: 100%;">
  201. <view v-for="(item, index) in scope.model.blank_purchase_requisition" :key="index" class="seal-card">
  202. <div class="seal-card-header">
  203. <span class="seal-card-index">{{ index + 1 }}.</span>
  204. <span class="seal-card-type">{{ item.materialName || '未填写物料' }} ×{{ item.quantity||0 }}{{ item.unit||'' }}</span>
  205. <div class="seal-card-actions">
  206. <van-button size="mini" type="primary" plain @click="openPrEditDialog(scope, 'edit', index)">编辑</van-button>
  207. <van-button size="mini" type="danger" plain @click="delNewRow('blank_purchase_requisition', index)">删除</van-button>
  208. </div>
  209. </div>
  210. <div class="seal-card-body">
  211. <div class="seal-card-row">
  212. <span class="seal-card-label">规格</span>
  213. <span class="seal-card-value">{{ item.specification || '-' }}</span>
  214. </div>
  215. <div class="seal-card-row">
  216. <span class="seal-card-label">用途</span>
  217. <span class="seal-card-value">{{ item.purpose || '-' }}</span>
  218. </div>
  219. <div class="seal-card-row">
  220. <span class="seal-card-label">交付</span>
  221. <span class="seal-card-value">{{ item.expectedDeliveryDate || '-' }}</span>
  222. </div>
  223. <div class="seal-card-row" v-if="item.remark">
  224. <span class="seal-card-label">备注</span>
  225. <span class="seal-card-value">{{ item.remark }}</span>
  226. </div>
  227. </div>
  228. </view>
  229. <van-button type="primary" size="small" block @click="openPrEditDialog(scope, 'add', scope.model.blank_purchase_requisition?scope.model.blank_purchase_requisition.length:0)" style="margin-bottom:10px">+ 添加物料</van-button>
  230. </div>
  231. </template>
  232. </fm-generate-vant-form>
  233. <!-- 印章选择弹窗(根层级,避免被 form overflow 裁剪) -->
  234. <van-popup v-model:show="sealPopVisible" position="bottom" :style="{ height: '30%' }" teleport="body">
  235. <van-picker
  236. show-toolbar
  237. :title="sealPopType === 'type' ? '印章使用类型' : '印章名称'"
  238. :columns="sealPopType === 'type' ? useSealTypeList : useSealNameList"
  239. @confirm="onSealPopConfirm"
  240. @cancel="sealPopVisible = false"
  241. />
  242. </van-popup>
  243. <!-- 印章编辑弹窗 -->
  244. <van-popup v-model:show="sealEditVisible" position="bottom" :style="{ height: '55%' }" round>
  245. <div style="padding:16px">
  246. <h4 style="text-align:center;margin-bottom:12px">{{ sealEditTitle }}</h4>
  247. <!-- 印章使用类型 -->
  248. <div class="seal-form-row" @click="openSealPickerInEdit('type')">
  249. <span class="seal-form-label">印章使用类型</span>
  250. <span class="seal-form-val">{{ sealEditForm.useSealType || '请选择' }}</span>
  251. <span class="seal-form-arrow">›</span>
  252. </div>
  253. <!-- 印章使用事由 -->
  254. <div class="seal-form-row">
  255. <span class="seal-form-label">印章使用事由</span>
  256. <input class="seal-form-input" v-model="sealEditForm.useSealRemark" placeholder="请输入" />
  257. </div>
  258. <!-- 印章名称 -->
  259. <div class="seal-form-row" @click="openSealPickerInEdit('name')">
  260. <span class="seal-form-label">印章名称</span>
  261. <span class="seal-form-val">{{ sealEditForm.useSealName || '请选择' }}</span>
  262. <span class="seal-form-arrow">›</span>
  263. </div>
  264. <div style="display:flex;justify-content:space-between;padding:20px 0">
  265. <van-button style="width:48%" @click="sealEditVisible = false">取消</van-button>
  266. <van-button style="width:48%" type="primary" @click="onSealEditSave">保存</van-button>
  267. </div>
  268. </div>
  269. </van-popup>
  270. <!-- 资质选择弹窗 -->
  271. <van-popup v-model:show="qualPopVisible" position="bottom" :style="{ height: '30%' }">
  272. <van-picker
  273. show-toolbar
  274. :title="qualPopType === 'type' ? '资质类型' : '使用资质名称'"
  275. :columns="qualPopType === 'type' ? useQualificationTypeList : useQualificationNameList"
  276. @confirm="onQualPopConfirm"
  277. @cancel="qualPopVisible = false"
  278. />
  279. </van-popup>
  280. <!-- 资质编辑弹窗 -->
  281. <van-popup v-model:show="qualEditVisible" position="bottom" :style="{ height: '55%' }" round>
  282. <div style="padding:16px">
  283. <h4 style="text-align:center;margin-bottom:12px">{{ qualEditTitle }}</h4>
  284. <div class="seal-form-row" @click="openQualPickerInEdit('type')">
  285. <span class="seal-form-label">资质类型</span>
  286. <span class="seal-form-val">{{ qualEditForm.useQualificationType || '请选择' }}</span>
  287. <span class="seal-form-arrow">›</span>
  288. </div>
  289. <div class="seal-form-row">
  290. <span class="seal-form-label">资质使用事由</span>
  291. <input class="seal-form-input" v-model="qualEditForm.useQualificationRemark" placeholder="请输入" />
  292. </div>
  293. <div class="seal-form-row" @click="openQualPickerInEdit('name')">
  294. <span class="seal-form-label">使用资质名称</span>
  295. <span class="seal-form-val">{{ qualEditForm.useQualificationName || '请选择' }}</span>
  296. <span class="seal-form-arrow">›</span>
  297. </div>
  298. <div style="display:flex;justify-content:space-between;padding:20px 0">
  299. <van-button style="width:48%" @click="qualEditVisible = false">取消</van-button>
  300. <van-button style="width:48%" type="primary" @click="onQualEditSave">保存</van-button>
  301. </div>
  302. </div>
  303. </van-popup>
  304. <!-- 产品选择弹窗 -->
  305. <van-popup v-model:show="appPopVisible" position="bottom" :style="{ height: '45%' }">
  306. <van-picker
  307. show-toolbar
  308. title="选择产品名称"
  309. :columns="productNameList"
  310. @confirm="onAppPopConfirm"
  311. @cancel="appPopVisible = false"
  312. />
  313. </van-popup>
  314. <!-- 产品编辑弹窗 -->
  315. <van-popup v-model:show="appEditVisible" position="bottom" :style="{ height: '55%' }" round>
  316. <div style="padding:16px">
  317. <h4 style="text-align:center;margin-bottom:12px">{{ appEditTitle }}</h4>
  318. <div class="seal-form-row" @click="openAppPickerInEdit">
  319. <span class="seal-form-label">产品名称</span>
  320. <span class="seal-form-val">{{ appEditForm.productName || '请选择' }}</span>
  321. <span class="seal-form-arrow">›</span>
  322. </div>
  323. <div class="seal-form-row">
  324. <span class="seal-form-label">数量</span>
  325. <input class="seal-form-input" v-model="appEditForm.quantity" type="number" placeholder="请输入" />
  326. </div>
  327. <div class="seal-form-row">
  328. <span class="seal-form-label">规格型号</span>
  329. <input class="seal-form-input" v-model="appEditForm.specification" placeholder="请输入" />
  330. </div>
  331. <div style="display:flex;justify-content:space-between;padding:20px 0">
  332. <van-button style="width:48%" @click="appEditVisible = false">取消</van-button>
  333. <van-button style="width:48%" type="primary" @click="onAppEditSave">保存</van-button>
  334. </div>
  335. </div>
  336. </van-popup>
  337. <!-- 行程编辑弹窗 -->
  338. <van-popup v-model:show="tripEditVisible" position="bottom" :style="{ height: '70%' }" round>
  339. <div style="padding:16px">
  340. <h4 style="text-align:center;margin-bottom:12px">{{ tripEditTitle }}</h4>
  341. <div class="seal-form-row">
  342. <span class="seal-form-label">交通工具</span>
  343. <input class="seal-form-input" v-model="tripEditForm.transportation" placeholder="飞机/高铁/汽车" />
  344. </div>
  345. <div class="seal-form-row">
  346. <span class="seal-form-label">单程往返</span>
  347. <input class="seal-form-input" v-model="tripEditForm.isRoundTrip" placeholder="单程/往返" />
  348. </div>
  349. <div class="seal-form-row">
  350. <span class="seal-form-label">出发城市</span>
  351. <input class="seal-form-input" v-model="tripEditForm.departureCity" placeholder="请输入" />
  352. </div>
  353. <div class="seal-form-row">
  354. <span class="seal-form-label">目的城市</span>
  355. <input class="seal-form-input" v-model="tripEditForm.destinationCity" placeholder="请输入" />
  356. </div>
  357. <div class="seal-form-row">
  358. <span class="seal-form-label">开始时间</span>
  359. <input class="seal-form-input" type="datetime-local" v-model="tripEditForm.startTime" @change="calcTripDuration" />
  360. </div>
  361. <div class="seal-form-row">
  362. <span class="seal-form-label">结束时间</span>
  363. <input class="seal-form-input" type="datetime-local" v-model="tripEditForm.endTime" @change="calcTripDuration" />
  364. </div>
  365. <div class="seal-form-row">
  366. <span class="seal-form-label">时长</span>
  367. <span class="seal-form-val">{{ tripEditForm.duration || '自动计算' }}</span>
  368. </div>
  369. <div style="display:flex;justify-content:space-between;padding:20px 0">
  370. <van-button style="width:48%" @click="tripEditVisible = false">取消</van-button>
  371. <van-button style="width:48%" type="primary" @click="onTripEditSave">保存</van-button>
  372. </div>
  373. </div>
  374. </van-popup>
  375. <!-- 采购申请编辑弹窗 -->
  376. <van-popup v-model:show="prEditVisible" position="bottom" :style="{ height: '70%' }" round>
  377. <div style="padding:16px">
  378. <h4 style="text-align:center;margin-bottom:12px">{{ prEditTitle }}</h4>
  379. <div class="seal-form-row"><span class="seal-form-label">物料名称</span><input class="seal-form-input" v-model="prEditForm.materialName" placeholder="请输入" /></div>
  380. <div class="seal-form-row"><span class="seal-form-label">规格型号</span><input class="seal-form-input" v-model="prEditForm.specification" placeholder="请输入" /></div>
  381. <div class="seal-form-row"><span class="seal-form-label">单位</span><input class="seal-form-input" v-model="prEditForm.unit" placeholder="个/台/套" /></div>
  382. <div class="seal-form-row"><span class="seal-form-label">数量</span><input class="seal-form-input" type="number" v-model="prEditForm.quantity" placeholder="请输入" /></div>
  383. <div class="seal-form-row"><span class="seal-form-label">用途</span><input class="seal-form-input" v-model="prEditForm.purpose" placeholder="请输入" /></div>
  384. <div class="seal-form-row"><span class="seal-form-label">交付日期</span><input class="seal-form-input" type="datetime-local" v-model="prEditForm.expectedDeliveryDate" /></div>
  385. <div class="seal-form-row"><span class="seal-form-label">备注</span><input class="seal-form-input" v-model="prEditForm.remark" placeholder="请输入" /></div>
  386. <div style="display:flex;justify-content:space-between;padding:20px 0">
  387. <van-button style="width:48%" @click="prEditVisible = false">取消</van-button>
  388. <van-button style="width:48%" type="primary" @click="onPrEditSave">保存</van-button>
  389. </div>
  390. </div>
  391. </van-popup>
  392. <div>
  393. <div v-if='isEdit'
  394. style="display: flex;justify-content: space-between; padding: 30px 30px; position: fixed; bottom: 0; width: 100%; height: 80px;">
  395. <van-button style="width:48%" type="primary" :loading="loading" @click="handleAudit(1)">提交
  396. </van-button>
  397. <van-button style="width:48%" type="danger" :loading="loading" @click="onClickLeft">取消
  398. </van-button>
  399. </div>
  400. </div>
  401. </div>
  402. <script src="./resource/vue.global.prod.js"></script>
  403. <script src="./resource/vant.min.js"></script>
  404. <script src="./resource/axios.min.js"></script>
  405. <script src="./resource/uni.webview.js"></script>
  406. <script src="./vue-form-making/form-making-v3.umd.js"></script>
  407. <script>
  408. let EnvObj = {}
  409. uni.getEnv(function(res) {
  410. EnvObj = res;
  411. console.log('当前环境:' + JSON.stringify(res));
  412. });
  413. Vue.createApp({
  414. data() {
  415. return {
  416. loading: false,
  417. isFlag: false,
  418. isEdit: true,
  419. title: '',
  420. jsonData: {},
  421. editData: {},
  422. form: {},
  423. headers: {},
  424. APIUrl: '',
  425. type: 'add',
  426. selectFilesField: null,
  427. selectFilesRowIndex: null,
  428. // useSealTypeList: ['杭州', '宁波', '温州', '绍兴', '湖州', '嘉兴', '金华', '衢州'],
  429. // useSealNameList: ['公章', '合同章', '财务章', '法人章', '发票章', '部门章'],
  430. sealPopVisible: false, // 印章选择弹窗
  431. sealPopType: 'type', // 'type' | 'name'
  432. sealPopScope: null, // 弹窗对应的 scope(编辑模式为空)
  433. sealPopIndex: null, // 弹窗对应的行索引(编辑模式为当前行)
  434. sealPopIsEdit: false, // 是否来自编辑弹窗
  435. sealEditVisible: false, // 印章编辑弹窗
  436. sealEditTitle: '添加印章使用', // 编辑弹窗标题
  437. sealEditForm: { useSealType: '', useSealRemark: '', useSealName: '' },
  438. sealEditMode: 'add', // 'add' | 'edit'
  439. sealEditScope: null,
  440. sealEditIndex: null,
  441. useSealTypeList: [
  442. {
  443. value: '加盖',
  444. text: '加盖'
  445. },
  446. {
  447. value: '借用',
  448. text: '借用'
  449. },
  450. {
  451. value: '无',
  452. text: '无'
  453. },
  454. ],
  455. useSealNameList: [
  456. {
  457. value: '总公司公章',
  458. text: '总公司公章'
  459. },
  460. {
  461. value: '合同专用章',
  462. text: '合同专用章'
  463. },
  464. {
  465. value: '法人章',
  466. text: '法人章'
  467. },
  468. {
  469. value: '财务专用章',
  470. text: '财务专用章'
  471. },
  472. {
  473. value: '发票专用章',
  474. text: '发票专用章'
  475. },
  476. {
  477. value: '质检专用章',
  478. text: '质检专用章'
  479. },
  480. {
  481. value: '业务专用章',
  482. text: '业务专用章'
  483. },
  484. {
  485. value: '出库专用章',
  486. text: '出库专用章'
  487. },
  488. {
  489. value: '无',
  490. text: '无'
  491. },
  492. ],
  493. // 资质使用
  494. useQualificationTypeList: [
  495. { value: '原件', text: '原件' },
  496. { value: '复印件', text: '复印件' },
  497. { value: '扫描件', text: '扫描件' },
  498. { value: '无', text: '无' },
  499. ],
  500. useQualificationNameList: [
  501. {
  502. value: '营业执照正本(行政人事部)',
  503. text: '营业执照正本(行政人事部)'
  504. },
  505. {
  506. value: '营业执照副本(行政人事部)',
  507. text: '营业执照副本(行政人事部)'
  508. },
  509. {
  510. value: '第一类医疗器械生产备案凭证(行政人事部)',
  511. text: '第一类医疗器械生产备案凭证(行政人事部)'
  512. },
  513. {
  514. value: '开户许可证(行政人事部)',
  515. text: '开户许可证(行政人事部)'
  516. },
  517. {
  518. value: '医疗器械生产许可证(行政人事部)',
  519. text: '医疗器械生产许可证(行政人事部)'
  520. },
  521. {
  522. value: '医疗器械生产产品登记表(行政人事部)',
  523. text: '医疗器械生产产品登记表(行政人事部)'
  524. },
  525. {
  526. value: '专利证书(行政人事部)',
  527. text: '专利证书(行政人事部)'
  528. },
  529. {
  530. value: '二类注册证(注册法务部)',
  531. text: '二类注册证(注册法务部)'
  532. },
  533. {
  534. value: '无',
  535. text: '无'
  536. },
  537. ],
  538. qualPopVisible: false,
  539. qualPopType: 'type',
  540. qualEditVisible: false,
  541. qualEditTitle: '添加资质使用',
  542. qualEditForm: { useQualificationType: '', useQualificationRemark: '', useQualificationName: '' },
  543. qualEditMode: 'add',
  544. qualEditScope: null,
  545. qualEditIndex: null,
  546. qualPopIsEdit: true,
  547. // 产品申请
  548. productNameList: [
  549. { value: '一次性使用刀头', text: '一次性使用刀头' },
  550. { value: '一次性使用多功能引流管', text: '一次性使用多功能引流管' },
  551. { value: '强光手电筒+变径接头', text: '强光手电筒+变径接头' },
  552. { value: '手电筒充电器', text: '手电筒充电器' },
  553. { value: '医用冷敷贴疼痛型', text: '医用冷敷贴疼痛型' },
  554. { value: '医用冷敷凝胶防脱育发型', text: '医用冷敷凝胶防脱育发型' },
  555. { value: '医用冷敷凝胶痔疮型', text: '医用冷敷凝胶痔疮型' },
  556. { value: '医用冷敷凝胶皮肤瘙痒型', text: '医用冷敷凝胶皮肤瘙痒型' },
  557. { value: '医用透明质酸钠修复贴', text: '医用透明质酸钠修复贴' },
  558. { value: '一次性射频等离子手术电极', text: '一次性射频等离子手术电极' },
  559. { value: '一次性冲冼吸引器', text: '一次性冲冼吸引器' },
  560. { value: '一次性使用胃管', text: '一次性使用胃管' },
  561. { value: '笔记本套装', text: '笔记本套装' },
  562. ],
  563. appPopVisible: false,
  564. appEditVisible: false,
  565. appEditTitle: '添加产品',
  566. appEditForm: { productName: '', quantity: '', specification: '' },
  567. appEditMode: 'add',
  568. appEditScope: null,
  569. appEditIndex: null,
  570. // 行程出差
  571. tripEditVisible: false,
  572. tripEditTitle: '添加行程',
  573. tripEditForm: { transportation: '', isRoundTrip: '', departureCity: '', destinationCity: '', startTime: '', endTime: '', duration: '' },
  574. tripEditMode: 'add',
  575. tripEditScope: null,
  576. tripEditIndex: null,
  577. // 采购申请
  578. prEditVisible: false,
  579. prEditTitle: '添加物料',
  580. prEditForm: { materialName: '', specification: '', unit: '', quantity: '', purpose: '', expectedDeliveryDate: '', remark: '' },
  581. prEditMode: 'add',
  582. prEditScope: null,
  583. prEditIndex: null,
  584. }
  585. },
  586. created() {
  587. let _this = this
  588. window.x_sun = (e) => {
  589. _this.setSalesServiceWork(JSON.parse(e))
  590. }
  591. // 接收文件选择后的回调
  592. window.x_selectFiles = async (e) => {
  593. let data = JSON.parse(e)
  594. console.log('收到选中的文件:', data)
  595. if (_this.$refs.generateForm) {
  596. if (_this.selectFilesRowIndex != null && _this.selectFilesField) {
  597. // 数组行附件:更新 blank_adopzrdd[index].files
  598. let formData = await _this.$refs.generateForm.getData(false);
  599. var arr = formData[_this.selectFilesField] || []
  600. var row = arr[_this.selectFilesRowIndex]
  601. if (row) {
  602. row.files = data.files || []
  603. _this.$refs.generateForm.setData({
  604. [_this.selectFilesField]: arr
  605. })
  606. }
  607. _this.selectFilesRowIndex = null
  608. } else {
  609. // 普通表单字段
  610. _this.$refs.generateForm.setData({
  611. [data.field]: data.files
  612. })
  613. }
  614. }
  615. }
  616. this.headers = this.getQueryParams('headers');
  617. let params = this.getQueryParams('params');
  618. this.isEdit = params.isEdit || true
  619. this.type = params.type || 'add'
  620. this.APIUrl = this.headers.serverInfo || 'http://192.168.1.105:18086'
  621. axios({
  622. method: 'get',
  623. url: this.APIUrl + `/flowable/bpmcustomform/getById/${params.id}`,
  624. headers: this.headers,
  625. }).then((res) => {
  626. if (res.data.code != '-1') {
  627. this.form = res.data.data
  628. this.form.formId = res.data.data.id
  629. this.form.id = ''
  630. this.form.valueJson = {}
  631. this.title = this.form.name
  632. this.jsonData = JSON.parse(res.data.data.formJson.makingJson);
  633. this.jsonData.list.forEach(item => {
  634. item.options.headers = [{
  635. key: 'Authorization',
  636. value: this.headers.Authorization
  637. }]
  638. item.options.action = item.options.action && item.options.action.replace(
  639. '/api', this.APIUrl)
  640. if (item.type == "deptAndUserCascader") {
  641. item.type = 'cascader'
  642. }
  643. if (item.type == "deptCascader") {
  644. item.type = 'cascader'
  645. /* item.isPathValue = false */
  646. if (item.options.isDefaultLoginUser) {
  647. /* this.form.valueJson[item.model] = [1,1765997946953797633]; */
  648. this.form.valueJson[item.model] = params.userInfo.groupIdList;
  649. }
  650. }
  651. if (item.type == "userSelect") {
  652. item.type = 'select'
  653. if (item.options.isDefaultLoginUser) {
  654. this.form.valueJson[item.model] = params.userInfo.userId;
  655. }
  656. }
  657. })
  658. this.jsonData.config.dataSource && this.jsonData.config.dataSource.forEach(item => {
  659. item.headers = {
  660. Authorization: this.headers.Authorization
  661. }
  662. item.url = item.url && item.url.replace('/api', this.APIUrl)
  663. })
  664. this.isFlag = true
  665. this.$nextTick(() => {
  666. if (params.manage_workorder) {
  667. this.setSalesServiceWork(params.manage_workorder)
  668. }
  669. })
  670. }
  671. });
  672. // axios({
  673. // method: 'get',
  674. // url: this.APIUrl + `/bpm/task/list-by-process-instance-id?processInstanceId=${params.id}`,
  675. // headers: this.headers,
  676. // }).then((res) => {
  677. // console.log(res)
  678. // if (res.data.code != '-1') {
  679. // }
  680. // });
  681. },
  682. methods: {
  683. // ===== 印章编辑弹窗 =====
  684. openSealEditDialog(scope, mode, index) {
  685. this.sealEditVisible = true
  686. this.sealEditScope = scope
  687. this.sealEditIndex = index
  688. this.sealEditMode = mode
  689. if (mode === 'edit' && scope.model.blank_use_seal[index]) {
  690. var row = scope.model.blank_use_seal[index]
  691. this.sealEditForm = { useSealType: row.useSealType||'', useSealRemark: row.useSealRemark||'', useSealName: row.useSealName||'' }
  692. this.sealEditTitle = '编辑印章使用'
  693. } else {
  694. this.sealEditForm = { useSealType: '', useSealRemark: '', useSealName: '' }
  695. this.sealEditTitle = '添加印章使用'
  696. }
  697. },
  698. async onSealEditSave() {
  699. var scope = this.sealEditScope
  700. var idx = this.sealEditIndex
  701. var key = 'blank_use_seal'
  702. var data = await this.$refs.generateForm.getData(false);
  703. if (!data[key]) data[key] = []
  704. if (this.sealEditMode === 'edit') {
  705. data[key][idx] = JSON.parse(JSON.stringify(this.sealEditForm))
  706. } else {
  707. data[key].push(JSON.parse(JSON.stringify(this.sealEditForm)))
  708. }
  709. this.$refs.generateForm.setData({ [key]: data[key] })
  710. this.sealEditVisible = false
  711. },
  712. openSealPickerInEdit(fieldType) {
  713. this.sealPopType = fieldType
  714. this.sealPopScope = null
  715. this.sealPopIndex = null
  716. this.sealPopIsEdit = true
  717. this.sealPopVisible = true
  718. },
  719. openSealPicker(scope, index, fieldType) {
  720. this.sealPopScope = scope
  721. this.sealPopIndex = index
  722. this.sealPopType = fieldType || 'type'
  723. this.sealPopIsEdit = false
  724. this.sealPopVisible = true
  725. },
  726. onSealPopConfirm(picker) {
  727. var sel = (picker && picker.selectedOptions && picker.selectedOptions[0]) ? picker.selectedOptions[0].text : picker
  728. var field = this.sealPopType === 'name' ? 'useSealName' : 'useSealType'
  729. if (this.sealPopIsEdit) {
  730. // 编辑弹窗模式:回写到 sealEditForm
  731. this.sealEditForm[field] = sel
  732. } else {
  733. // 列表内联模式
  734. var scope = this.sealPopScope
  735. var idx = this.sealPopIndex
  736. if (scope && scope.model && scope.model.blank_use_seal && scope.model.blank_use_seal[idx]) {
  737. scope.model.blank_use_seal[idx][field] = sel
  738. }
  739. }
  740. this.sealPopVisible = false
  741. },
  742. // ===== 资质使用 =====
  743. openQualEditDialog(scope, mode, index) {
  744. this.qualEditScope = scope
  745. this.qualEditIndex = index
  746. this.qualEditMode = mode
  747. if (mode === 'edit' && scope.model.blank_use_qualification[index]) {
  748. var r = scope.model.blank_use_qualification[index]
  749. this.qualEditForm = { useQualificationType: r.useQualificationType||'', useQualificationRemark: r.useQualificationRemark||'', useQualificationName: r.useQualificationName||'' }
  750. this.qualEditTitle = '编辑资质使用'
  751. } else {
  752. this.qualEditForm = { useQualificationType: '', useQualificationRemark: '', useQualificationName: '' }
  753. this.qualEditTitle = '添加资质使用'
  754. }
  755. this.qualEditVisible = true
  756. },
  757. async onQualEditSave() {
  758. var scope = this.qualEditScope
  759. var idx = this.qualEditIndex
  760. var key = 'blank_use_qualification'
  761. var data = await this.$refs.generateForm.getData(false);
  762. if (!data[key]) data[key] = []
  763. if (this.qualEditMode === 'edit') {
  764. data[key][idx] = JSON.parse(JSON.stringify(this.qualEditForm))
  765. } else {
  766. data[key].push(JSON.parse(JSON.stringify(this.qualEditForm)))
  767. }
  768. this.$refs.generateForm.setData({ [key]: data[key] })
  769. this.qualEditVisible = false
  770. },
  771. openQualPickerInEdit(fieldType) {
  772. this.qualPopType = fieldType
  773. this.qualPopIsEdit = true
  774. this.qualPopVisible = true
  775. },
  776. onQualPopConfirm(picker) {
  777. var sel = (picker && picker.selectedOptions && picker.selectedOptions[0]) ? picker.selectedOptions[0].text : picker
  778. var field = this.qualPopType === 'name' ? 'useQualificationName' : 'useQualificationType'
  779. this.qualEditForm[field] = sel
  780. this.qualPopVisible = false
  781. },
  782. // ===== 产品申请 =====
  783. openAppEditDialog(scope, mode, index) {
  784. this.appEditScope = scope
  785. this.appEditIndex = index
  786. this.appEditMode = mode
  787. if (mode === 'edit' && scope.model.blank_application_component[index]) {
  788. var r = scope.model.blank_application_component[index]
  789. this.appEditForm = { productName: r.productName||'', quantity: r.quantity||'', specification: r.specification||'' }
  790. this.appEditTitle = '编辑产品'
  791. } else {
  792. this.appEditForm = { productName: '', quantity: '', specification: '' }
  793. this.appEditTitle = '添加产品'
  794. }
  795. this.appEditVisible = true
  796. },
  797. async onAppEditSave() {
  798. var scope = this.appEditScope
  799. var idx = this.appEditIndex
  800. var key = 'blank_application_component'
  801. var data = await this.$refs.generateForm.getData(false);
  802. if (!data[key]) data[key] = []
  803. if (this.appEditMode === 'edit') {
  804. data[key][idx] = JSON.parse(JSON.stringify(this.appEditForm))
  805. } else {
  806. data[key].push(JSON.parse(JSON.stringify(this.appEditForm)))
  807. }
  808. this.$refs.generateForm.setData({ [key]: data[key] })
  809. this.appEditVisible = false
  810. },
  811. openAppPickerInEdit() {
  812. this.appPopVisible = true
  813. },
  814. onAppPopConfirm(picker) {
  815. var sel = (picker && picker.selectedOptions && picker.selectedOptions[0]) ? picker.selectedOptions[0].text : picker
  816. this.appEditForm.productName = sel
  817. this.appPopVisible = false
  818. },
  819. // ===== 行程出差 =====
  820. openTripEditDialog(scope, mode, index) {
  821. this.tripEditScope = scope
  822. this.tripEditIndex = index
  823. this.tripEditMode = mode
  824. if (mode === 'edit' && scope.model.blank_business_trip[index]) {
  825. var r = scope.model.blank_business_trip[index]
  826. this.tripEditForm = {
  827. transportation: r.transportation||'', isRoundTrip: r.isRoundTrip||'',
  828. departureCity: r.departureCity||'', destinationCity: r.destinationCity||'',
  829. startTime: r.startTime||'', endTime: r.endTime||'', duration: r.duration||''
  830. }
  831. this.tripEditTitle = '编辑行程'
  832. } else {
  833. this.tripEditForm = { transportation: '', isRoundTrip: '', departureCity: '', destinationCity: '', startTime: '', endTime: '', duration: '' }
  834. this.tripEditTitle = '添加行程'
  835. }
  836. this.tripEditVisible = true
  837. },
  838. calcTripDuration() {
  839. var s = this.tripEditForm.startTime, e = this.tripEditForm.endTime
  840. if (!s || !e) { this.tripEditForm.duration = ''; return }
  841. var ds = new Date(s).getTime(), de = new Date(e).getTime()
  842. if (isNaN(ds) || isNaN(de) || de <= ds) { this.tripEditForm.duration = ''; return }
  843. var diff = Math.floor((de - ds) / 1000)
  844. var d = Math.floor(diff / 86400), h = Math.floor((diff % 86400) / 3600), m = Math.floor((diff % 3600) / 60), sec = diff % 60
  845. var parts = []
  846. if (d) parts.push(d + '天'); if (h) parts.push(h + '时'); if (m) parts.push(m + '分'); if (sec || !parts.length) parts.push(sec + '秒')
  847. this.tripEditForm.duration = parts.join('')
  848. },
  849. async onTripEditSave() {
  850. var scope = this.tripEditScope
  851. var idx = this.tripEditIndex
  852. var key = 'blank_business_trip'
  853. var data = await this.$refs.generateForm.getData(false);
  854. if (!data[key]) data[key] = []
  855. if (this.tripEditMode === 'edit') {
  856. data[key][idx] = JSON.parse(JSON.stringify(this.tripEditForm))
  857. } else {
  858. data[key].push(JSON.parse(JSON.stringify(this.tripEditForm)))
  859. }
  860. this.$refs.generateForm.setData({ [key]: data[key] })
  861. this.tripEditVisible = false
  862. this.calcTripTotal(scope)
  863. },
  864. calcTripTotal(scope) {
  865. var list = scope.model.blank_business_trip || []
  866. var totalSec = 0
  867. list.forEach(function(it) {
  868. var d = it.duration
  869. if (!d) return
  870. var match = { days: d.match(/(\d+)天/), hours: d.match(/(\d+)时/), minutes: d.match(/(\d+)分/), seconds: d.match(/(\d+)秒/) }
  871. totalSec += (parseInt(match.days&&match.days[1])||0)*86400 + (parseInt(match.hours&&match.hours[1])||0)*3600 + (parseInt(match.minutes&&match.minutes[1])||0)*60 + (parseInt(match.seconds&&match.seconds[1])||0)
  872. })
  873. if (totalSec > 0) {
  874. var dy = Math.floor(totalSec/86400), hr = Math.floor((totalSec%86400)/3600), mn = Math.floor((totalSec%3600)/60), sc = totalSec%60
  875. var parts = []
  876. if (dy) parts.push(dy+'天'); if (hr) parts.push(hr+'时'); if (mn) parts.push(mn+'分'); if (sc||!parts.length) parts.push(sc+'秒')
  877. this.$refs.generateForm.setData({ input_if1cav3p: parts.join('') })
  878. }
  879. },
  880. // ===== 采购申请 =====
  881. openPrEditDialog(scope, mode, index) {
  882. this.prEditScope = scope; this.prEditIndex = index; this.prEditMode = mode
  883. if (mode === 'edit' && scope.model.blank_purchase_requisition[index]) {
  884. var r = scope.model.blank_purchase_requisition[index]
  885. this.prEditForm = { materialName: r.materialName||'', specification: r.specification||'', unit: r.unit||'', quantity: r.quantity||'', purpose: r.purpose||'', expectedDeliveryDate: r.expectedDeliveryDate||'', remark: r.remark||'' }
  886. this.prEditTitle = '编辑物料'
  887. } else {
  888. this.prEditForm = { materialName: '', specification: '', unit: '', quantity: '', purpose: '', expectedDeliveryDate: '', remark: '' }
  889. this.prEditTitle = '添加物料'
  890. }
  891. this.prEditVisible = true
  892. },
  893. async onPrEditSave() {
  894. var scope = this.prEditScope, idx = this.prEditIndex, key = 'blank_purchase_requisition'
  895. var data = await this.$refs.generateForm.getData(false)
  896. if (!data[key]) data[key] = []
  897. if (this.prEditMode === 'edit') data[key][idx] = JSON.parse(JSON.stringify(this.prEditForm))
  898. else data[key].push(JSON.parse(JSON.stringify(this.prEditForm)))
  899. this.$refs.generateForm.setData({ [key]: data[key] })
  900. this.prEditVisible = false
  901. },
  902. async handleUploadLocal (model, rowIndex) {
  903. console.log('上传本地文件按钮被点击,字段模型:', model, '行索引:', rowIndex)
  904. let data = await this.$refs.generateForm.getData(false);
  905. let files = rowIndex != null && data[model] && data[model][rowIndex] ? (data[model][rowIndex].files || []) : (data[model] || [])
  906. this.selectFilesField = model
  907. this.selectFilesRowIndex = rowIndex != null ? rowIndex : null
  908. uni.postMessage({
  909. data: {
  910. type: 'selectFiles',
  911. field: model,
  912. files: files,
  913. isEdit: this.type || 'add'
  914. }
  915. });
  916. },
  917. addWorkOrder() {
  918. uni.postMessage({
  919. data: {
  920. type: 'selectWork',
  921. }
  922. });
  923. },
  924. async addNewRow(key) {
  925. console.log(key);
  926. let data = await this.$refs.generateForm.getData(false);
  927. data[key].push({
  928. price: '',
  929. remark: ''
  930. });
  931. this.$refs.generateForm.setData({
  932. key: data[key]
  933. });
  934. },
  935. async delNewRow(key, index, isChange) {
  936. let data = await this.$refs.generateForm.getData(false);
  937. data[key] = data[key].filter((item, index1) => index1 != index);
  938. this.$refs.generateForm.setData({
  939. [key]: data[key]
  940. });
  941. if (isChange) {
  942. this.changePrice(data[key])
  943. }
  944. },
  945. changePrice(data) {
  946. let num = 0;
  947. data.forEach((item) => {
  948. num += Number(item.price);
  949. });
  950. this.$refs.generateForm.setData({
  951. input_jd9ouzyh: num
  952. });
  953. },
  954. setSalesServiceWork(data) {
  955. this.$refs.generateForm.setData({
  956. manage_workorder: data
  957. });
  958. this.$refs.generateForm.setRules('manage_workorder', [{
  959. required: false,
  960. message: '必须填写'
  961. }])
  962. setTimeout(() => {
  963. this.$refs.generateForm.validate(['manage_workorder'])
  964. })
  965. },
  966. getQueryParams(queryName) {
  967. const urlSearchParams = new URLSearchParams(window.location.search);
  968. const query = urlSearchParams.get(queryName);
  969. console.log(query, 'query')
  970. return JSON.parse(query);
  971. },
  972. generateFormValid(validate = true) {
  973. return this.$refs.generateForm.getData(validate).then((data) => { //清空content
  974. for (key in data) {
  975. if (key.includes('fileupload')) {
  976. data[key].forEach(item => {
  977. item['content'] = ''
  978. })
  979. }
  980. }
  981. return data;
  982. });
  983. },
  984. async handleAudit(status) {
  985. this.loading = true;
  986. try {
  987. this.form.valueJson = await this.generateFormValid();
  988. } catch (error) {
  989. this.loading = false;
  990. return;
  991. }
  992. console.log(this.form.valueJson)
  993. this.form.processType = '1';
  994. let API = this.APIUrl + '/bpm/process-instance/create'
  995. axios({
  996. method: 'post',
  997. url: API,
  998. headers: this.headers,
  999. data: {
  1000. ...this.form,
  1001. }
  1002. }).then((res) => {
  1003. this.loading = false;
  1004. if (res.data.code != '-1') {
  1005. vant.showNotify({
  1006. type: 'success',
  1007. message: `提交成功!`,
  1008. duration: 1000,
  1009. });
  1010. setTimeout(() => {
  1011. this.onClickLeft()
  1012. }, 1000)
  1013. } else {
  1014. vant.showNotify({
  1015. type: 'danger',
  1016. message: `提交失败!${res.data.message}`,
  1017. duration: 1000,
  1018. });
  1019. }
  1020. }).catch((err) => {
  1021. vant.showNotify({
  1022. type: 'danger',
  1023. message: `提交失败!${err.message}`,
  1024. duration: 1000,
  1025. });
  1026. this.loading = false;
  1027. });
  1028. },
  1029. onClickLeft() {
  1030. uni.navigateBack({
  1031. delta: 1
  1032. });
  1033. }
  1034. }
  1035. }).use(vant).use(FormMakingV3).mount('#app')
  1036. </script>
  1037. </body>
  1038. </html>