a.html 67 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578
  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).then(() => calcTripTotal())">删除</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. <template v-slot:blank_business_component="scope">
  233. <div style="width: 100%;">
  234. <view v-for="(item, index) in scope.model.blank_business_component" :key="index" class="seal-card">
  235. <div class="seal-card-header">
  236. <span class="seal-card-index">{{ index + 1 }}.</span>
  237. <span class="seal-card-type">{{ item.transportationWay || '未知交通' }} {{ item.startPlace || '?' }}→{{ item.endPlace || '?' }}</span>
  238. <div class="seal-card-actions">
  239. <van-button size="mini" type="primary" plain @click="openBusinessEditDialog(scope, 'edit', index)">编辑</van-button>
  240. <van-button size="mini" type="danger" plain @click="delNewRow('blank_business_component', index).then(() => calcBizTotal())">删除</van-button>
  241. </div>
  242. </div>
  243. <div class="seal-card-body">
  244. <div class="seal-card-row">
  245. <span class="seal-card-label">出发</span>
  246. <span class="seal-card-value">{{ item.startDate || '-' }}</span>
  247. </div>
  248. <div class="seal-card-row">
  249. <span class="seal-card-label">到达</span>
  250. <span class="seal-card-value">{{ item.endDate || '-' }}</span>
  251. </div>
  252. <div class="seal-card-row">
  253. <span class="seal-card-label">出发地</span>
  254. <span class="seal-card-value">{{ item.startPlace || '-' }}</span>
  255. </div>
  256. <div class="seal-card-row">
  257. <span class="seal-card-label">到达地</span>
  258. <span class="seal-card-value">{{ item.endPlace || '-' }}</span>
  259. </div>
  260. <div class="seal-card-row">
  261. <span class="seal-card-label">交通</span>
  262. <span class="seal-card-value">{{ item.transportationWay || '-' }}</span>
  263. </div>
  264. <div class="seal-card-row">
  265. <span class="seal-card-label">费用</span>
  266. <span class="seal-card-value">¥{{ item.price || '0' }}</span>
  267. </div>
  268. </div>
  269. </view>
  270. <van-button type="primary" size="small" block @click="openBusinessEditDialog(scope, 'add', scope.model.blank_business_component?scope.model.blank_business_component.length:0)" style="margin-bottom:10px">+ 添加交通费用</van-button>
  271. </div>
  272. </template>
  273. <template v-slot:blank_product_specification="scope">
  274. <div style="width: 100%;">
  275. <view v-for="(item, index) in scope.model.blank_product_specification" :key="index" class="seal-card">
  276. <div class="seal-card-header">
  277. <span class="seal-card-index">{{ index + 1 }}.</span>
  278. <span class="seal-card-type">{{ item.specification || '未填写规格' }}</span>
  279. <div class="seal-card-actions">
  280. <van-button size="mini" type="primary" plain @click="openSpecEditDialog(scope, 'edit', index)">编辑</van-button>
  281. <van-button size="mini" type="danger" plain @click="delNewRow('blank_product_specification', index)">删除</van-button>
  282. </div>
  283. </div>
  284. <div class="seal-card-body">
  285. <div class="seal-card-row">
  286. <span class="seal-card-label">规格</span>
  287. <span class="seal-card-value">{{ item.specification || '-' }}</span>
  288. </div>
  289. <div class="seal-card-row">
  290. <span class="seal-card-label">数量</span>
  291. <span class="seal-card-value">{{ item.num || '-' }}</span>
  292. </div>
  293. <div class="seal-card-row">
  294. <span class="seal-card-label">批号</span>
  295. <span class="seal-card-value">{{ item.batchNo || '-' }}</span>
  296. </div>
  297. </div>
  298. </view>
  299. <van-button type="primary" size="small" block @click="openSpecEditDialog(scope, 'add', scope.model.blank_product_specification?scope.model.blank_product_specification.length:0)" style="margin-bottom:10px">+ 添加产品规格</van-button>
  300. </div>
  301. </template>
  302. <template v-slot:blank_event_component="scope">
  303. <div style="width: 100%;">
  304. <view v-for="(item, index) in scope.model.blank_event_component" :key="index" class="seal-card">
  305. <div class="seal-card-header">
  306. <span class="seal-card-index">{{ index + 1 }}.</span>
  307. <span class="seal-card-type">{{ item.eventHospital || '未填写医院' }}</span>
  308. <div class="seal-card-actions">
  309. <van-button size="mini" type="primary" plain @click="openEventEditDialog(scope, 'edit', index)">编辑</van-button>
  310. <van-button size="mini" type="danger" plain @click="delNewRow('blank_event_component', index)">删除</van-button>
  311. </div>
  312. </div>
  313. <div class="seal-card-body">
  314. <div class="seal-card-row">
  315. <span class="seal-card-label">时间</span>
  316. <span class="seal-card-value">{{ item.eventTime || '-' }}</span>
  317. </div>
  318. <div class="seal-card-row">
  319. <span class="seal-card-label">描述</span>
  320. <span class="seal-card-value">{{ item.eventDesc || '-' }}</span>
  321. </div>
  322. <div class="seal-card-row">
  323. <span class="seal-card-label">附件</span>
  324. <div style="flex:1">
  325. <van-badge v-if="item.files && item.files.length" :content="item.files.length">
  326. <van-button size="small" type="primary" @click="handleUploadLocal('blank_event_component', index)">上传附件</van-button>
  327. </van-badge>
  328. <van-button v-else size="small" type="primary" @click="handleUploadLocal('blank_event_component', index)">上传附件</van-button>
  329. </div>
  330. </div>
  331. <div class="seal-card-row">
  332. <span class="seal-card-label">意见</span>
  333. <span class="seal-card-value">{{ item.eventOpinion || '-' }}</span>
  334. </div>
  335. </div>
  336. </view>
  337. <van-button type="primary" size="small" block @click="openEventEditDialog(scope, 'add', scope.model.blank_event_component?scope.model.blank_event_component.length:0)" style="margin-bottom:10px">+ 添加事件</van-button>
  338. </div>
  339. </template>
  340. <template v-slot:blank_reissue_component="scope">
  341. <div style="width: 100%;">
  342. <view v-for="(item, index) in scope.model.blank_reissue_component" :key="index" class="seal-card">
  343. <div class="seal-card-header">
  344. <span class="seal-card-index">{{ index + 1 }}.</span>
  345. <span class="seal-card-type">{{ item.reissueType || '未填写类型' }}</span>
  346. <div class="seal-card-actions">
  347. <van-button size="mini" type="primary" plain @click="openReissueEditDialog(scope, 'edit', index)">编辑</van-button>
  348. <van-button size="mini" type="danger" plain @click="delNewRow('blank_reissue_component', index)">删除</van-button>
  349. </div>
  350. </div>
  351. <div class="seal-card-body">
  352. <div class="seal-card-row">
  353. <span class="seal-card-label">规格</span>
  354. <span class="seal-card-value">{{ item.reissueOtherType || '-' }}</span>
  355. </div>
  356. <div class="seal-card-row">
  357. <span class="seal-card-label">收件</span>
  358. <span class="seal-card-value">{{ item.reissueContact || '-' }}</span>
  359. </div>
  360. <div class="seal-card-row">
  361. <span class="seal-card-label">要求</span>
  362. <span class="seal-card-value">{{ item.reissueOtherReq || '-' }}</span>
  363. </div>
  364. </div>
  365. </view>
  366. <van-button type="primary" size="small" block @click="openReissueEditDialog(scope, 'add', scope.model.blank_reissue_component?scope.model.blank_reissue_component.length:0)" style="margin-bottom:10px">+ 添加补发</van-button>
  367. </div>
  368. </template>
  369. </fm-generate-vant-form>
  370. <!-- 印章选择弹窗(根层级,避免被 form overflow 裁剪) -->
  371. <van-popup v-model:show="sealPopVisible" position="bottom" :style="{ height: '30%' }" teleport="body">
  372. <van-picker
  373. show-toolbar
  374. :title="sealPopType === 'type' ? '印章使用类型' : '印章名称'"
  375. :columns="sealPopType === 'type' ? useSealTypeList : useSealNameList"
  376. @confirm="onSealPopConfirm"
  377. @cancel="sealPopVisible = false"
  378. />
  379. </van-popup>
  380. <!-- 印章编辑弹窗 -->
  381. <van-popup v-model:show="sealEditVisible" position="bottom" :style="{ height: '55%' }" round>
  382. <div style="padding:16px">
  383. <h4 style="text-align:center;margin-bottom:12px">{{ sealEditTitle }}</h4>
  384. <!-- 印章使用类型 -->
  385. <div class="seal-form-row" @click="openSealPickerInEdit('type')">
  386. <span class="seal-form-label">印章使用类型</span>
  387. <span class="seal-form-val">{{ sealEditForm.useSealType || '请选择' }}</span>
  388. <span class="seal-form-arrow">›</span>
  389. </div>
  390. <!-- 印章使用事由 -->
  391. <div class="seal-form-row">
  392. <span class="seal-form-label">印章使用事由</span>
  393. <input class="seal-form-input" v-model="sealEditForm.useSealRemark" placeholder="请输入" />
  394. </div>
  395. <!-- 印章名称 -->
  396. <div class="seal-form-row" @click="openSealPickerInEdit('name')">
  397. <span class="seal-form-label">印章名称</span>
  398. <span class="seal-form-val">{{ sealEditForm.useSealName || '请选择' }}</span>
  399. <span class="seal-form-arrow">›</span>
  400. </div>
  401. <div style="display:flex;justify-content:space-between;padding:20px 0">
  402. <van-button style="width:48%" @click="sealEditVisible = false">取消</van-button>
  403. <van-button style="width:48%" type="primary" @click="onSealEditSave">保存</van-button>
  404. </div>
  405. </div>
  406. </van-popup>
  407. <!-- 资质选择弹窗 -->
  408. <van-popup v-model:show="qualPopVisible" position="bottom" :style="{ height: '30%' }">
  409. <van-picker
  410. show-toolbar
  411. :title="qualPopType === 'type' ? '资质类型' : '使用资质名称'"
  412. :columns="qualPopType === 'type' ? useQualificationTypeList : useQualificationNameList"
  413. @confirm="onQualPopConfirm"
  414. @cancel="qualPopVisible = false"
  415. />
  416. </van-popup>
  417. <!-- 资质编辑弹窗 -->
  418. <van-popup v-model:show="qualEditVisible" position="bottom" :style="{ height: '55%' }" round>
  419. <div style="padding:16px">
  420. <h4 style="text-align:center;margin-bottom:12px">{{ qualEditTitle }}</h4>
  421. <div class="seal-form-row" @click="openQualPickerInEdit('type')">
  422. <span class="seal-form-label">资质类型</span>
  423. <span class="seal-form-val">{{ qualEditForm.useQualificationType || '请选择' }}</span>
  424. <span class="seal-form-arrow">›</span>
  425. </div>
  426. <div class="seal-form-row">
  427. <span class="seal-form-label">资质使用事由</span>
  428. <input class="seal-form-input" v-model="qualEditForm.useQualificationRemark" placeholder="请输入" />
  429. </div>
  430. <div class="seal-form-row" @click="openQualPickerInEdit('name')">
  431. <span class="seal-form-label">使用资质名称</span>
  432. <span class="seal-form-val">{{ qualEditForm.useQualificationName || '请选择' }}</span>
  433. <span class="seal-form-arrow">›</span>
  434. </div>
  435. <div style="display:flex;justify-content:space-between;padding:20px 0">
  436. <van-button style="width:48%" @click="qualEditVisible = false">取消</van-button>
  437. <van-button style="width:48%" type="primary" @click="onQualEditSave">保存</van-button>
  438. </div>
  439. </div>
  440. </van-popup>
  441. <!-- 产品选择弹窗 -->
  442. <van-popup v-model:show="appPopVisible" position="bottom" :style="{ height: '45%' }">
  443. <van-picker
  444. show-toolbar
  445. title="选择产品名称"
  446. :columns="productNameList"
  447. @confirm="onAppPopConfirm"
  448. @cancel="appPopVisible = false"
  449. />
  450. </van-popup>
  451. <!-- 产品编辑弹窗 -->
  452. <van-popup v-model:show="appEditVisible" position="bottom" :style="{ height: '55%' }" round>
  453. <div style="padding:16px">
  454. <h4 style="text-align:center;margin-bottom:12px">{{ appEditTitle }}</h4>
  455. <div class="seal-form-row" @click="openAppPickerInEdit">
  456. <span class="seal-form-label">产品名称</span>
  457. <span class="seal-form-val">{{ appEditForm.productName || '请选择' }}</span>
  458. <span class="seal-form-arrow">›</span>
  459. </div>
  460. <div class="seal-form-row">
  461. <span class="seal-form-label">数量</span>
  462. <input class="seal-form-input" v-model="appEditForm.quantity" type="number" placeholder="请输入" />
  463. </div>
  464. <div class="seal-form-row">
  465. <span class="seal-form-label">规格型号</span>
  466. <input class="seal-form-input" v-model="appEditForm.specification" placeholder="请输入" />
  467. </div>
  468. <div style="display:flex;justify-content:space-between;padding:20px 0">
  469. <van-button style="width:48%" @click="appEditVisible = false">取消</van-button>
  470. <van-button style="width:48%" type="primary" @click="onAppEditSave">保存</van-button>
  471. </div>
  472. </div>
  473. </van-popup>
  474. <!-- 行程编辑弹窗 -->
  475. <van-popup v-model:show="tripEditVisible" position="bottom" :style="{ height: '70%' }" round>
  476. <div style="padding:16px">
  477. <h4 style="text-align:center;margin-bottom:12px">{{ tripEditTitle }}</h4>
  478. <div class="seal-form-row">
  479. <span class="seal-form-label">交通工具</span>
  480. <input class="seal-form-input" v-model="tripEditForm.transportation" placeholder="请输入" />
  481. </div>
  482. <div class="seal-form-row">
  483. <span class="seal-form-label">单程往返</span>
  484. <input class="seal-form-input" v-model="tripEditForm.isRoundTrip" placeholder="请输入" />
  485. </div>
  486. <div class="seal-form-row">
  487. <span class="seal-form-label">出发城市</span>
  488. <input class="seal-form-input" v-model="tripEditForm.departureCity" placeholder="请输入" />
  489. </div>
  490. <div class="seal-form-row">
  491. <span class="seal-form-label">目的城市</span>
  492. <input class="seal-form-input" v-model="tripEditForm.destinationCity" placeholder="请输入" />
  493. </div>
  494. <div class="seal-form-row">
  495. <span class="seal-form-label">开始时间</span>
  496. <input class="seal-form-input" type="datetime-local" v-model="tripEditForm.startTime" @change="calcTripDuration" />
  497. </div>
  498. <div class="seal-form-row">
  499. <span class="seal-form-label">结束时间</span>
  500. <input class="seal-form-input" type="datetime-local" v-model="tripEditForm.endTime" @change="calcTripDuration" />
  501. </div>
  502. <div class="seal-form-row">
  503. <span class="seal-form-label">时长</span>
  504. <span class="seal-form-val">{{ tripEditForm.duration || '自动计算' }}</span>
  505. </div>
  506. <div style="display:flex;justify-content:space-between;padding:20px 0">
  507. <van-button style="width:48%" @click="tripEditVisible = false">取消</van-button>
  508. <van-button style="width:48%" type="primary" @click="onTripEditSave">保存</van-button>
  509. </div>
  510. </div>
  511. </van-popup>
  512. <!-- 采购申请编辑弹窗 -->
  513. <van-popup v-model:show="prEditVisible" position="bottom" :style="{ height: '70%' }" round>
  514. <div style="padding:16px">
  515. <h4 style="text-align:center;margin-bottom:12px">{{ prEditTitle }}</h4>
  516. <div class="seal-form-row"><span class="seal-form-label">物料名称</span><input class="seal-form-input" v-model="prEditForm.materialName" placeholder="请输入" /></div>
  517. <div class="seal-form-row"><span class="seal-form-label">规格型号</span><input class="seal-form-input" v-model="prEditForm.specification" placeholder="请输入" /></div>
  518. <div class="seal-form-row"><span class="seal-form-label">单位</span><input class="seal-form-input" v-model="prEditForm.unit" placeholder="个/台/套" /></div>
  519. <div class="seal-form-row"><span class="seal-form-label">数量</span><input class="seal-form-input" type="number" v-model="prEditForm.quantity" placeholder="请输入" /></div>
  520. <div class="seal-form-row"><span class="seal-form-label">用途</span><input class="seal-form-input" v-model="prEditForm.purpose" placeholder="请输入" /></div>
  521. <div class="seal-form-row"><span class="seal-form-label">交付日期</span><input class="seal-form-input" type="datetime-local" v-model="prEditForm.expectedDeliveryDate" /></div>
  522. <div class="seal-form-row"><span class="seal-form-label">备注</span><input class="seal-form-input" v-model="prEditForm.remark" placeholder="请输入" /></div>
  523. <div style="display:flex;justify-content:space-between;padding:20px 0">
  524. <van-button style="width:48%" @click="prEditVisible = false">取消</van-button>
  525. <van-button style="width:48%" type="primary" @click="onPrEditSave">保存</van-button>
  526. </div>
  527. </div>
  528. </van-popup>
  529. <!-- 交通费用编辑弹窗 -->
  530. <van-popup v-model:show="businessEditVisible" position="bottom" :style="{ height: '75%' }" round>
  531. <div style="padding:16px">
  532. <h4 style="text-align:center;margin-bottom:12px">{{ businessEditTitle }}</h4>
  533. <div class="seal-form-row">
  534. <span class="seal-form-label">出发日期</span>
  535. <input class="seal-form-input" type="datetime-local" v-model="businessEditForm.startDate" />
  536. </div>
  537. <div class="seal-form-row">
  538. <span class="seal-form-label">到达日期</span>
  539. <input class="seal-form-input" type="datetime-local" v-model="businessEditForm.endDate" />
  540. </div>
  541. <div class="seal-form-row">
  542. <span class="seal-form-label">出发地</span>
  543. <input class="seal-form-input" v-model="businessEditForm.startPlace" placeholder="请输入" />
  544. </div>
  545. <div class="seal-form-row">
  546. <span class="seal-form-label">到达地</span>
  547. <input class="seal-form-input" v-model="businessEditForm.endPlace" placeholder="请输入" />
  548. </div>
  549. <div class="seal-form-row" @click="businessTransportPopVisible = true">
  550. <span class="seal-form-label">交通方式</span>
  551. <span class="seal-form-val">{{ businessEditForm.transportationWay || '请选择' }}</span>
  552. <span class="seal-form-arrow">›</span>
  553. </div>
  554. <div class="seal-form-row">
  555. <span class="seal-form-label">交通费用</span>
  556. <input class="seal-form-input" type="number" v-model="businessEditForm.price" placeholder="请输入" />
  557. </div>
  558. <div style="display:flex;justify-content:space-between;padding:20px 0">
  559. <van-button style="width:48%" @click="businessEditVisible = false">取消</van-button>
  560. <van-button style="width:48%" type="primary" @click="onBusinessEditSave">保存</van-button>
  561. </div>
  562. </div>
  563. </van-popup>
  564. <!-- 交通方式选择弹窗 -->
  565. <van-popup v-model:show="businessTransportPopVisible" position="bottom" :style="{ height: '30%' }">
  566. <van-picker
  567. show-toolbar
  568. title="选择交通方式"
  569. :columns="transportationWayList"
  570. @confirm="onBusinessTransportConfirm"
  571. @cancel="businessTransportPopVisible = false"
  572. />
  573. </van-popup>
  574. <!-- 产品规格编辑弹窗 -->
  575. <van-popup v-model:show="specEditVisible" position="bottom" :style="{ height: '60%' }" round>
  576. <div style="padding:16px">
  577. <h4 style="text-align:center;margin-bottom:12px">{{ specEditTitle }}</h4>
  578. <div class="seal-form-row">
  579. <span class="seal-form-label">产品规格型号</span>
  580. <input class="seal-form-input" v-model="specEditForm.specification" placeholder="请输入" />
  581. </div>
  582. <div class="seal-form-row">
  583. <span class="seal-form-label">数量</span>
  584. <input class="seal-form-input" v-model="specEditForm.num" placeholder="请输入" />
  585. </div>
  586. <div class="seal-form-row">
  587. <span class="seal-form-label">批号</span>
  588. <input class="seal-form-input" v-model="specEditForm.batchNo" placeholder="请输入" />
  589. </div>
  590. <div style="display:flex;justify-content:space-between;padding:20px 0">
  591. <van-button style="width:48%" @click="specEditVisible = false">取消</van-button>
  592. <van-button style="width:48%" type="primary" @click="onSpecEditSave">保存</van-button>
  593. </div>
  594. </div>
  595. </van-popup>
  596. <!-- 事件编辑弹窗 -->
  597. <van-popup v-model:show="eventEditVisible" position="bottom" :style="{ height: '75%' }" round>
  598. <div style="padding:16px">
  599. <h4 style="text-align:center;margin-bottom:12px">{{ eventEditTitle }}</h4>
  600. <div class="seal-form-row">
  601. <span class="seal-form-label">发生时间</span>
  602. <input class="seal-form-input" type="datetime-local" v-model="eventEditForm.eventTime" />
  603. </div>
  604. <div class="seal-form-row">
  605. <span class="seal-form-label">医院及科室</span>
  606. <input class="seal-form-input" v-model="eventEditForm.eventHospital" placeholder="请输入" />
  607. </div>
  608. <div class="seal-form-row">
  609. <span class="seal-form-label">详细描述</span>
  610. <input class="seal-form-input" v-model="eventEditForm.eventDesc" placeholder="请输入" />
  611. </div>
  612. <div class="seal-form-row">
  613. <span class="seal-form-label">图片上传</span>
  614. <div style="flex:1;text-align:right">
  615. <van-badge v-if="eventEditForm.files && eventEditForm.files.length" :content="eventEditForm.files.length">
  616. <van-button size="small" type="primary" @click="handleUploadLocal('blank_event_component', eventEditIndex)">上传图片</van-button>
  617. </van-badge>
  618. <van-button v-else size="small" type="primary" @click="handleUploadLocal('blank_event_component', eventEditIndex)">上传图片</van-button>
  619. </div>
  620. </div>
  621. <div class="seal-form-row">
  622. <span class="seal-form-label">其他意见</span>
  623. <input class="seal-form-input" v-model="eventEditForm.eventOpinion" placeholder="请输入" />
  624. </div>
  625. <div style="display:flex;justify-content:space-between;padding:20px 0">
  626. <van-button style="width:48%" @click="eventEditVisible = false">取消</van-button>
  627. <van-button style="width:48%" type="primary" @click="onEventEditSave">保存</van-button>
  628. </div>
  629. </div>
  630. </van-popup>
  631. <!-- 补发编辑弹窗 -->
  632. <van-popup v-model:show="reissueEditVisible" position="bottom" :style="{ height: '65%' }" round>
  633. <div style="padding:16px">
  634. <h4 style="text-align:center;margin-bottom:12px">{{ reissueEditTitle }}</h4>
  635. <div class="seal-form-row" @click="reissueTypePopVisible = true">
  636. <span class="seal-form-label">补发型号规格</span>
  637. <span class="seal-form-val">{{ reissueEditForm.reissueType || '请选择' }}</span>
  638. <span class="seal-form-arrow">›</span>
  639. </div>
  640. <div class="seal-form-row">
  641. <span class="seal-form-label">其他规格型号</span>
  642. <input class="seal-form-input" v-model="reissueEditForm.reissueOtherType" placeholder="请输入" />
  643. </div>
  644. <div class="seal-form-row">
  645. <span class="seal-form-label">收件地址</span>
  646. <input class="seal-form-input" v-model="reissueEditForm.reissueContact" placeholder="地址/联系人/电话" />
  647. </div>
  648. <div class="seal-form-row">
  649. <span class="seal-form-label">其他要求</span>
  650. <input class="seal-form-input" v-model="reissueEditForm.reissueOtherReq" placeholder="请输入" />
  651. </div>
  652. <div style="display:flex;justify-content:space-between;padding:20px 0">
  653. <van-button style="width:48%" @click="reissueEditVisible = false">取消</van-button>
  654. <van-button style="width:48%" type="primary" @click="onReissueEditSave">保存</van-button>
  655. </div>
  656. </div>
  657. </van-popup>
  658. <!-- 补发型号规格选择弹窗 -->
  659. <van-popup v-model:show="reissueTypePopVisible" position="bottom" :style="{ height: '30%' }">
  660. <van-picker
  661. show-toolbar
  662. title="选择补发型号规格"
  663. :columns="reissueTypeList"
  664. @confirm="onReissueTypeConfirm"
  665. @cancel="reissueTypePopVisible = false"
  666. />
  667. </van-popup>
  668. <div>
  669. <div v-if='isEdit'
  670. style="display: flex;justify-content: space-between; padding: 30px 30px; position: fixed; bottom: 0; width: 100%; height: 80px;">
  671. <van-button style="width:48%" type="primary" :loading="loading" @click="handleAudit(1)">提交
  672. </van-button>
  673. <van-button style="width:48%" type="danger" :loading="loading" @click="onClickLeft">取消
  674. </van-button>
  675. </div>
  676. </div>
  677. </div>
  678. <script src="./resource/vue.global.prod.js"></script>
  679. <script src="./resource/vant.min.js"></script>
  680. <script src="./resource/axios.min.js"></script>
  681. <script src="./resource/uni.webview.js"></script>
  682. <script src="./vue-form-making/form-making-v3.umd.js"></script>
  683. <script>
  684. let EnvObj = {}
  685. uni.getEnv(function(res) {
  686. EnvObj = res;
  687. console.log('当前环境:' + JSON.stringify(res));
  688. });
  689. Vue.createApp({
  690. data() {
  691. return {
  692. loading: false,
  693. isFlag: false,
  694. isEdit: true,
  695. title: '',
  696. jsonData: {},
  697. editData: {},
  698. form: {},
  699. headers: {},
  700. APIUrl: '',
  701. type: 'add',
  702. selectFilesField: null,
  703. selectFilesRowIndex: null,
  704. // useSealTypeList: ['杭州', '宁波', '温州', '绍兴', '湖州', '嘉兴', '金华', '衢州'],
  705. // useSealNameList: ['公章', '合同章', '财务章', '法人章', '发票章', '部门章'],
  706. sealPopVisible: false, // 印章选择弹窗
  707. sealPopType: 'type', // 'type' | 'name'
  708. sealPopScope: null, // 弹窗对应的 scope(编辑模式为空)
  709. sealPopIndex: null, // 弹窗对应的行索引(编辑模式为当前行)
  710. sealPopIsEdit: false, // 是否来自编辑弹窗
  711. sealEditVisible: false, // 印章编辑弹窗
  712. sealEditTitle: '添加印章使用', // 编辑弹窗标题
  713. sealEditForm: { useSealType: '', useSealRemark: '', useSealName: '' },
  714. sealEditMode: 'add', // 'add' | 'edit'
  715. sealEditScope: null,
  716. sealEditIndex: null,
  717. useSealTypeList: [
  718. {
  719. value: '加盖',
  720. text: '加盖'
  721. },
  722. {
  723. value: '借用',
  724. text: '借用'
  725. },
  726. {
  727. value: '无',
  728. text: '无'
  729. },
  730. ],
  731. useSealNameList: [
  732. {
  733. value: '总公司公章',
  734. text: '总公司公章'
  735. },
  736. {
  737. value: '合同专用章',
  738. text: '合同专用章'
  739. },
  740. {
  741. value: '法人章',
  742. text: '法人章'
  743. },
  744. {
  745. value: '财务专用章',
  746. text: '财务专用章'
  747. },
  748. {
  749. value: '发票专用章',
  750. text: '发票专用章'
  751. },
  752. {
  753. value: '质检专用章',
  754. text: '质检专用章'
  755. },
  756. {
  757. value: '业务专用章',
  758. text: '业务专用章'
  759. },
  760. {
  761. value: '出库专用章',
  762. text: '出库专用章'
  763. },
  764. {
  765. value: '无',
  766. text: '无'
  767. },
  768. ],
  769. // 资质使用
  770. useQualificationTypeList: [
  771. { value: '原件', text: '原件' },
  772. { value: '复印件', text: '复印件' },
  773. { value: '扫描件', text: '扫描件' },
  774. { value: '无', text: '无' },
  775. ],
  776. useQualificationNameList: [
  777. {
  778. value: '营业执照正本(行政人事部)',
  779. text: '营业执照正本(行政人事部)'
  780. },
  781. {
  782. value: '营业执照副本(行政人事部)',
  783. text: '营业执照副本(行政人事部)'
  784. },
  785. {
  786. value: '第一类医疗器械生产备案凭证(行政人事部)',
  787. text: '第一类医疗器械生产备案凭证(行政人事部)'
  788. },
  789. {
  790. value: '开户许可证(行政人事部)',
  791. text: '开户许可证(行政人事部)'
  792. },
  793. {
  794. value: '医疗器械生产许可证(行政人事部)',
  795. text: '医疗器械生产许可证(行政人事部)'
  796. },
  797. {
  798. value: '医疗器械生产产品登记表(行政人事部)',
  799. text: '医疗器械生产产品登记表(行政人事部)'
  800. },
  801. {
  802. value: '专利证书(行政人事部)',
  803. text: '专利证书(行政人事部)'
  804. },
  805. {
  806. value: '二类注册证(注册法务部)',
  807. text: '二类注册证(注册法务部)'
  808. },
  809. {
  810. value: '无',
  811. text: '无'
  812. },
  813. ],
  814. qualPopVisible: false,
  815. qualPopType: 'type',
  816. qualEditVisible: false,
  817. qualEditTitle: '添加资质使用',
  818. qualEditForm: { useQualificationType: '', useQualificationRemark: '', useQualificationName: '' },
  819. qualEditMode: 'add',
  820. qualEditScope: null,
  821. qualEditIndex: null,
  822. qualPopIsEdit: true,
  823. // 产品申请
  824. productNameList: [
  825. { value: '一次性使用刀头', text: '一次性使用刀头' },
  826. { value: '一次性使用多功能引流管', text: '一次性使用多功能引流管' },
  827. { value: '强光手电筒+变径接头', text: '强光手电筒+变径接头' },
  828. { value: '手电筒充电器', text: '手电筒充电器' },
  829. { value: '医用冷敷贴疼痛型', text: '医用冷敷贴疼痛型' },
  830. { value: '医用冷敷凝胶防脱育发型', text: '医用冷敷凝胶防脱育发型' },
  831. { value: '医用冷敷凝胶痔疮型', text: '医用冷敷凝胶痔疮型' },
  832. { value: '医用冷敷凝胶皮肤瘙痒型', text: '医用冷敷凝胶皮肤瘙痒型' },
  833. { value: '医用透明质酸钠修复贴', text: '医用透明质酸钠修复贴' },
  834. { value: '一次性射频等离子手术电极', text: '一次性射频等离子手术电极' },
  835. { value: '一次性冲冼吸引器', text: '一次性冲冼吸引器' },
  836. { value: '一次性使用胃管', text: '一次性使用胃管' },
  837. { value: '笔记本套装', text: '笔记本套装' },
  838. ],
  839. appPopVisible: false,
  840. appEditVisible: false,
  841. appEditTitle: '添加产品',
  842. appEditForm: { productName: '', quantity: '', specification: '' },
  843. appEditMode: 'add',
  844. appEditScope: null,
  845. appEditIndex: null,
  846. // 行程出差
  847. tripEditVisible: false,
  848. tripEditTitle: '添加行程',
  849. tripEditForm: { transportation: '', isRoundTrip: '', departureCity: '', destinationCity: '', startTime: '', endTime: '', duration: '' },
  850. tripEditMode: 'add',
  851. tripEditScope: null,
  852. tripEditIndex: null,
  853. // 采购申请
  854. prEditVisible: false,
  855. prEditTitle: '添加物料',
  856. prEditForm: { materialName: '', specification: '', unit: '', quantity: '', purpose: '', expectedDeliveryDate: '', remark: '' },
  857. prEditMode: 'add',
  858. prEditScope: null,
  859. prEditIndex: null,
  860. // 交通费用
  861. transportationWayList: [
  862. {
  863. value: '火车',
  864. text: '火车'
  865. },
  866. {
  867. value: '飞机',
  868. text: '飞机'
  869. },
  870. {
  871. value: '高铁',
  872. text: '高铁'
  873. },
  874. {
  875. value: '公车',
  876. text: '公车'
  877. },
  878. {
  879. value: '私车',
  880. text: '私车'
  881. },
  882. {
  883. value: '大巴',
  884. text: '大巴'
  885. },
  886. {
  887. value: '顺风车',
  888. text: '顺风车'
  889. },
  890. {
  891. value: '滴滴',
  892. text: '滴滴'
  893. }
  894. ],
  895. businessEditVisible: false,
  896. businessEditTitle: '添加交通费用',
  897. businessEditForm: { startDate: '', endDate: '', startPlace: '', endPlace: '', transportationWay: '', price: '' },
  898. businessEditMode: 'add',
  899. businessEditScope: null,
  900. businessEditIndex: null,
  901. businessTransportPopVisible: false,
  902. // 产品规格
  903. specEditVisible: false,
  904. specEditTitle: '添加产品规格',
  905. specEditForm: { specification: '', num: '', batchNo: '' },
  906. specEditMode: 'add',
  907. specEditScope: null,
  908. specEditIndex: null,
  909. // 事件
  910. eventEditVisible: false,
  911. eventEditTitle: '添加事件',
  912. eventEditForm: { eventTime: '', eventHospital: '', eventDesc: '', files: [], eventOpinion: '' },
  913. eventEditMode: 'add',
  914. eventEditScope: null,
  915. eventEditIndex: null,
  916. // 补发
  917. reissueEditVisible: false,
  918. reissueEditTitle: '添加补发',
  919. reissueEditForm: { reissueType: '', reissueOtherType: '', reissueContact: '', reissueOtherReq: '' },
  920. reissueEditMode: 'add',
  921. reissueEditScope: null,
  922. reissueEditIndex: null,
  923. reissueTypeList: [
  924. { value: '同规格型号', text: '同规格型号' },
  925. { value: '其他规格型号', text: '其他规格型号' },
  926. { value: '无', text: '无' },
  927. ],
  928. reissueTypePopVisible: false,
  929. }
  930. },
  931. created() {
  932. let _this = this
  933. window.x_sun = (e) => {
  934. _this.setSalesServiceWork(JSON.parse(e))
  935. }
  936. // 接收文件选择后的回调
  937. window.x_selectFiles = async (e) => {
  938. let data = JSON.parse(e)
  939. console.log('收到选中的文件:', data)
  940. if (_this.$refs.generateForm) {
  941. if (_this.selectFilesRowIndex != null && _this.selectFilesField) {
  942. // 数组行附件:更新 blank_adopzrdd[index].files
  943. let formData = await _this.$refs.generateForm.getData(false);
  944. var arr = formData[_this.selectFilesField] || []
  945. var row = arr[_this.selectFilesRowIndex]
  946. if (row) {
  947. row.files = data.files || []
  948. _this.$refs.generateForm.setData({
  949. [_this.selectFilesField]: arr
  950. })
  951. }
  952. _this.selectFilesRowIndex = null
  953. } else {
  954. // 普通表单字段
  955. _this.$refs.generateForm.setData({
  956. [data.field]: data.files
  957. })
  958. }
  959. }
  960. }
  961. this.headers = this.getQueryParams('headers');
  962. let params = this.getQueryParams('params');
  963. this.isEdit = params.isEdit || true
  964. this.type = params.type || 'add'
  965. this.APIUrl = this.headers.serverInfo || 'http://192.168.1.105:18086'
  966. axios({
  967. method: 'get',
  968. url: this.APIUrl + `/flowable/bpmcustomform/getById/${params.id}`,
  969. headers: this.headers,
  970. }).then((res) => {
  971. if (res.data.code != '-1') {
  972. this.form = res.data.data
  973. this.form.formId = res.data.data.id
  974. this.form.id = ''
  975. this.form.valueJson = {}
  976. this.title = this.form.name
  977. this.jsonData = JSON.parse(res.data.data.formJson.makingJson);
  978. this.jsonData.list.forEach(item => {
  979. item.options.headers = [{
  980. key: 'Authorization',
  981. value: this.headers.Authorization
  982. }]
  983. item.options.action = item.options.action && item.options.action.replace(
  984. '/api', this.APIUrl)
  985. if (item.type == "deptAndUserCascader") {
  986. item.type = 'cascader'
  987. }
  988. if (item.type == "deptCascader") {
  989. item.type = 'cascader'
  990. /* item.isPathValue = false */
  991. if (item.options.isDefaultLoginUser) {
  992. /* this.form.valueJson[item.model] = [1,1765997946953797633]; */
  993. this.form.valueJson[item.model] = params.userInfo.groupIdList;
  994. }
  995. }
  996. if (item.type == "userSelect") {
  997. item.type = 'select'
  998. if (item.options.isDefaultLoginUser) {
  999. this.form.valueJson[item.model] = params.userInfo.userId;
  1000. }
  1001. }
  1002. })
  1003. this.jsonData.config.dataSource && this.jsonData.config.dataSource.forEach(item => {
  1004. item.headers = {
  1005. Authorization: this.headers.Authorization
  1006. }
  1007. item.url = item.url && item.url.replace('/api', this.APIUrl)
  1008. })
  1009. this.isFlag = true
  1010. this.$nextTick(() => {
  1011. if (params.manage_workorder) {
  1012. this.setSalesServiceWork(params.manage_workorder)
  1013. }
  1014. })
  1015. }
  1016. });
  1017. // axios({
  1018. // method: 'get',
  1019. // url: this.APIUrl + `/bpm/task/list-by-process-instance-id?processInstanceId=${params.id}`,
  1020. // headers: this.headers,
  1021. // }).then((res) => {
  1022. // console.log(res)
  1023. // if (res.data.code != '-1') {
  1024. // }
  1025. // });
  1026. },
  1027. methods: {
  1028. // ===== 印章编辑弹窗 =====
  1029. openSealEditDialog(scope, mode, index) {
  1030. this.sealEditVisible = true
  1031. this.sealEditScope = scope
  1032. this.sealEditIndex = index
  1033. this.sealEditMode = mode
  1034. if (mode === 'edit' && scope.model.blank_use_seal[index]) {
  1035. var row = scope.model.blank_use_seal[index]
  1036. this.sealEditForm = { useSealType: row.useSealType||'', useSealRemark: row.useSealRemark||'', useSealName: row.useSealName||'' }
  1037. this.sealEditTitle = '编辑印章使用'
  1038. } else {
  1039. this.sealEditForm = { useSealType: '', useSealRemark: '', useSealName: '' }
  1040. this.sealEditTitle = '添加印章使用'
  1041. }
  1042. },
  1043. async onSealEditSave() {
  1044. var scope = this.sealEditScope
  1045. var idx = this.sealEditIndex
  1046. var key = 'blank_use_seal'
  1047. var data = await this.$refs.generateForm.getData(false);
  1048. if (!data[key]) data[key] = []
  1049. if (this.sealEditMode === 'edit') {
  1050. data[key][idx] = JSON.parse(JSON.stringify(this.sealEditForm))
  1051. } else {
  1052. data[key].push(JSON.parse(JSON.stringify(this.sealEditForm)))
  1053. }
  1054. this.$refs.generateForm.setData({ [key]: data[key] })
  1055. this.sealEditVisible = false
  1056. },
  1057. openSealPickerInEdit(fieldType) {
  1058. this.sealPopType = fieldType
  1059. this.sealPopScope = null
  1060. this.sealPopIndex = null
  1061. this.sealPopIsEdit = true
  1062. this.sealPopVisible = true
  1063. },
  1064. openSealPicker(scope, index, fieldType) {
  1065. this.sealPopScope = scope
  1066. this.sealPopIndex = index
  1067. this.sealPopType = fieldType || 'type'
  1068. this.sealPopIsEdit = false
  1069. this.sealPopVisible = true
  1070. },
  1071. onSealPopConfirm(picker) {
  1072. var sel = (picker && picker.selectedOptions && picker.selectedOptions[0]) ? picker.selectedOptions[0].text : picker
  1073. var field = this.sealPopType === 'name' ? 'useSealName' : 'useSealType'
  1074. if (this.sealPopIsEdit) {
  1075. // 编辑弹窗模式:回写到 sealEditForm
  1076. this.sealEditForm[field] = sel
  1077. } else {
  1078. // 列表内联模式
  1079. var scope = this.sealPopScope
  1080. var idx = this.sealPopIndex
  1081. if (scope && scope.model && scope.model.blank_use_seal && scope.model.blank_use_seal[idx]) {
  1082. scope.model.blank_use_seal[idx][field] = sel
  1083. }
  1084. }
  1085. this.sealPopVisible = false
  1086. },
  1087. // ===== 资质使用 =====
  1088. openQualEditDialog(scope, mode, index) {
  1089. this.qualEditScope = scope
  1090. this.qualEditIndex = index
  1091. this.qualEditMode = mode
  1092. if (mode === 'edit' && scope.model.blank_use_qualification[index]) {
  1093. var r = scope.model.blank_use_qualification[index]
  1094. this.qualEditForm = { useQualificationType: r.useQualificationType||'', useQualificationRemark: r.useQualificationRemark||'', useQualificationName: r.useQualificationName||'' }
  1095. this.qualEditTitle = '编辑资质使用'
  1096. } else {
  1097. this.qualEditForm = { useQualificationType: '', useQualificationRemark: '', useQualificationName: '' }
  1098. this.qualEditTitle = '添加资质使用'
  1099. }
  1100. this.qualEditVisible = true
  1101. },
  1102. async onQualEditSave() {
  1103. var scope = this.qualEditScope
  1104. var idx = this.qualEditIndex
  1105. var key = 'blank_use_qualification'
  1106. var data = await this.$refs.generateForm.getData(false);
  1107. if (!data[key]) data[key] = []
  1108. if (this.qualEditMode === 'edit') {
  1109. data[key][idx] = JSON.parse(JSON.stringify(this.qualEditForm))
  1110. } else {
  1111. data[key].push(JSON.parse(JSON.stringify(this.qualEditForm)))
  1112. }
  1113. this.$refs.generateForm.setData({ [key]: data[key] })
  1114. this.qualEditVisible = false
  1115. },
  1116. openQualPickerInEdit(fieldType) {
  1117. this.qualPopType = fieldType
  1118. this.qualPopIsEdit = true
  1119. this.qualPopVisible = true
  1120. },
  1121. onQualPopConfirm(picker) {
  1122. var sel = (picker && picker.selectedOptions && picker.selectedOptions[0]) ? picker.selectedOptions[0].text : picker
  1123. var field = this.qualPopType === 'name' ? 'useQualificationName' : 'useQualificationType'
  1124. this.qualEditForm[field] = sel
  1125. this.qualPopVisible = false
  1126. },
  1127. // ===== 产品申请 =====
  1128. openAppEditDialog(scope, mode, index) {
  1129. this.appEditScope = scope
  1130. this.appEditIndex = index
  1131. this.appEditMode = mode
  1132. if (mode === 'edit' && scope.model.blank_application_component[index]) {
  1133. var r = scope.model.blank_application_component[index]
  1134. this.appEditForm = { productName: r.productName||'', quantity: r.quantity||'', specification: r.specification||'' }
  1135. this.appEditTitle = '编辑产品'
  1136. } else {
  1137. this.appEditForm = { productName: '', quantity: '', specification: '' }
  1138. this.appEditTitle = '添加产品'
  1139. }
  1140. this.appEditVisible = true
  1141. },
  1142. async onAppEditSave() {
  1143. var scope = this.appEditScope
  1144. var idx = this.appEditIndex
  1145. var key = 'blank_application_component'
  1146. var data = await this.$refs.generateForm.getData(false);
  1147. if (!data[key]) data[key] = []
  1148. if (this.appEditMode === 'edit') {
  1149. data[key][idx] = JSON.parse(JSON.stringify(this.appEditForm))
  1150. } else {
  1151. data[key].push(JSON.parse(JSON.stringify(this.appEditForm)))
  1152. }
  1153. this.$refs.generateForm.setData({ [key]: data[key] })
  1154. this.appEditVisible = false
  1155. },
  1156. openAppPickerInEdit() {
  1157. this.appPopVisible = true
  1158. },
  1159. onAppPopConfirm(picker) {
  1160. var sel = (picker && picker.selectedOptions && picker.selectedOptions[0]) ? picker.selectedOptions[0].text : picker
  1161. this.appEditForm.productName = sel
  1162. this.appPopVisible = false
  1163. },
  1164. // ===== 行程出差 =====
  1165. openTripEditDialog(scope, mode, index) {
  1166. this.tripEditScope = scope
  1167. this.tripEditIndex = index
  1168. this.tripEditMode = mode
  1169. if (mode === 'edit' && scope.model.blank_business_trip[index]) {
  1170. var r = scope.model.blank_business_trip[index]
  1171. this.tripEditForm = {
  1172. transportation: r.transportation||'', isRoundTrip: r.isRoundTrip||'',
  1173. departureCity: r.departureCity||'', destinationCity: r.destinationCity||'',
  1174. startTime: r.startTime||'', endTime: r.endTime||'', duration: r.duration||''
  1175. }
  1176. this.tripEditTitle = '编辑行程'
  1177. } else {
  1178. this.tripEditForm = { transportation: '', isRoundTrip: '', departureCity: '', destinationCity: '', startTime: '', endTime: '', duration: '' }
  1179. this.tripEditTitle = '添加行程'
  1180. }
  1181. this.tripEditVisible = true
  1182. },
  1183. calcTripDuration() {
  1184. var s = this.tripEditForm.startTime, e = this.tripEditForm.endTime
  1185. if (!s || !e) { this.tripEditForm.duration = ''; return }
  1186. var ds = new Date(s).getTime(), de = new Date(e).getTime()
  1187. if (isNaN(ds) || isNaN(de) || de <= ds) { this.tripEditForm.duration = ''; return }
  1188. var diff = Math.floor((de - ds) / 1000)
  1189. var d = Math.floor(diff / 86400), h = Math.floor((diff % 86400) / 3600), m = Math.floor((diff % 3600) / 60), sec = diff % 60
  1190. var parts = []
  1191. if (d) parts.push(d + '天'); if (h) parts.push(h + '时'); if (m) parts.push(m + '分'); if (sec || !parts.length) parts.push(sec + '秒')
  1192. this.tripEditForm.duration = parts.join('')
  1193. },
  1194. async onTripEditSave() {
  1195. var scope = this.tripEditScope
  1196. var idx = this.tripEditIndex
  1197. var key = 'blank_business_trip'
  1198. var data = await this.$refs.generateForm.getData(false);
  1199. if (!data[key]) data[key] = []
  1200. if (this.tripEditMode === 'edit') {
  1201. data[key][idx] = JSON.parse(JSON.stringify(this.tripEditForm))
  1202. } else {
  1203. data[key].push(JSON.parse(JSON.stringify(this.tripEditForm)))
  1204. }
  1205. await this.$refs.generateForm.setData({ [key]: data[key] })
  1206. this.tripEditVisible = false
  1207. await this.calcTripTotal()
  1208. },
  1209. async calcTripTotal() {
  1210. var data = await this.$refs.generateForm.getData(false);
  1211. var list = data.blank_business_trip || []
  1212. var totalSec = 0
  1213. console.log('calcTripTotal', data, list)
  1214. list.forEach(function(it) {
  1215. var d = it.duration
  1216. if (!d) return
  1217. var match = { days: d.match(/(\d+)天/), hours: d.match(/(\d+)时/), minutes: d.match(/(\d+)分/), seconds: d.match(/(\d+)秒/) }
  1218. 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)
  1219. })
  1220. if (totalSec > 0) {
  1221. var dy = Math.floor(totalSec/86400), hr = Math.floor((totalSec%86400)/3600), mn = Math.floor((totalSec%3600)/60), sc = totalSec%60
  1222. var parts = []
  1223. if (dy) parts.push(dy+'天'); if (hr) parts.push(hr+'时'); if (mn) parts.push(mn+'分'); if (sc||!parts.length) parts.push(sc+'秒')
  1224. this.$refs.generateForm.setData({ input_if1cav3p: parts.join('') })
  1225. }
  1226. },
  1227. // ===== 采购申请 =====
  1228. openPrEditDialog(scope, mode, index) {
  1229. this.prEditScope = scope; this.prEditIndex = index; this.prEditMode = mode
  1230. if (mode === 'edit' && scope.model.blank_purchase_requisition[index]) {
  1231. var r = scope.model.blank_purchase_requisition[index]
  1232. this.prEditForm = { materialName: r.materialName||'', specification: r.specification||'', unit: r.unit||'', quantity: r.quantity||'', purpose: r.purpose||'', expectedDeliveryDate: r.expectedDeliveryDate||'', remark: r.remark||'' }
  1233. this.prEditTitle = '编辑物料'
  1234. } else {
  1235. this.prEditForm = { materialName: '', specification: '', unit: '', quantity: '', purpose: '', expectedDeliveryDate: '', remark: '' }
  1236. this.prEditTitle = '添加物料'
  1237. }
  1238. this.prEditVisible = true
  1239. },
  1240. async onPrEditSave() {
  1241. var scope = this.prEditScope, idx = this.prEditIndex, key = 'blank_purchase_requisition'
  1242. var data = await this.$refs.generateForm.getData(false)
  1243. if (!data[key]) data[key] = []
  1244. if (this.prEditMode === 'edit') data[key][idx] = JSON.parse(JSON.stringify(this.prEditForm))
  1245. else data[key].push(JSON.parse(JSON.stringify(this.prEditForm)))
  1246. this.$refs.generateForm.setData({ [key]: data[key] })
  1247. this.prEditVisible = false
  1248. },
  1249. // ===== 交通费用 =====
  1250. openBusinessEditDialog(scope, mode, index) {
  1251. this.businessEditScope = scope
  1252. this.businessEditIndex = index
  1253. this.businessEditMode = mode
  1254. if (mode === 'edit' && scope.model.blank_business_component[index]) {
  1255. var r = scope.model.blank_business_component[index]
  1256. this.businessEditForm = { startDate: r.startDate||'', endDate: r.endDate||'', startPlace: r.startPlace||'', endPlace: r.endPlace||'', transportationWay: r.transportationWay||'', price: r.price||'' }
  1257. this.businessEditTitle = '编辑交通费用'
  1258. } else {
  1259. this.businessEditForm = { startDate: '', endDate: '', startPlace: '', endPlace: '', transportationWay: '', price: '' }
  1260. this.businessEditTitle = '添加交通费用'
  1261. }
  1262. this.businessEditVisible = true
  1263. },
  1264. async onBusinessEditSave() {
  1265. var scope = this.businessEditScope, idx = this.businessEditIndex, key = 'blank_business_component'
  1266. var data = await this.$refs.generateForm.getData(false)
  1267. if (!data[key]) data[key] = []
  1268. if (this.businessEditMode === 'edit') data[key][idx] = JSON.parse(JSON.stringify(this.businessEditForm))
  1269. else data[key].push(JSON.parse(JSON.stringify(this.businessEditForm)))
  1270. await this.$refs.generateForm.setData({ [key]: data[key] })
  1271. this.businessEditVisible = false
  1272. await this.calcBizTotal()
  1273. },
  1274. onBusinessTransportConfirm(picker) {
  1275. var sel = (picker && picker.selectedOptions && picker.selectedOptions[0]) ? picker.selectedOptions[0].text : picker
  1276. this.businessEditForm.transportationWay = sel
  1277. this.businessTransportPopVisible = false
  1278. },
  1279. async calcBizTotal() {
  1280. var data = await this.$refs.generateForm.getData(false)
  1281. var list = data.blank_business_component || []
  1282. var totalPrice = 0
  1283. list.forEach(function(it) {
  1284. totalPrice += Number(it.price) || 0
  1285. })
  1286. // 其他费用字段(住宿费、市内交通平台、餐费补贴、市内交通费、招待费、其他费用)
  1287. var zsf = Number(data.number_uyuxcowe) || 0
  1288. var snjtpt = Number(data.number_0zw5q8y9) || 0
  1289. var cfbt = Number(data.number_fyl8n1lm) || 0
  1290. var snjtf = Number(data.number_p093shsw) || 0
  1291. var zdf = Number(data.number_uiv62o0r) || 0
  1292. var qtfy = Number(data.number_i5y1dk9x) || 0
  1293. this.$refs.generateForm.setData({
  1294. number_06fgz5gs: totalPrice + zsf + snjtpt + cfbt + snjtf + zdf + qtfy
  1295. })
  1296. },
  1297. // ===== 产品规格 =====
  1298. openSpecEditDialog(scope, mode, index) {
  1299. this.specEditScope = scope
  1300. this.specEditIndex = index
  1301. this.specEditMode = mode
  1302. if (mode === 'edit' && scope.model.blank_product_specification[index]) {
  1303. var r = scope.model.blank_product_specification[index]
  1304. this.specEditForm = { specification: r.specification||'', num: r.num||'', batchNo: r.batchNo||'' }
  1305. this.specEditTitle = '编辑产品规格'
  1306. } else {
  1307. this.specEditForm = { specification: '', num: '', batchNo: '' }
  1308. this.specEditTitle = '添加产品规格'
  1309. }
  1310. this.specEditVisible = true
  1311. },
  1312. async onSpecEditSave() {
  1313. var scope = this.specEditScope, idx = this.specEditIndex, key = 'blank_product_specification'
  1314. var data = await this.$refs.generateForm.getData(false)
  1315. if (!data[key]) data[key] = []
  1316. if (this.specEditMode === 'edit') data[key][idx] = JSON.parse(JSON.stringify(this.specEditForm))
  1317. else data[key].push(JSON.parse(JSON.stringify(this.specEditForm)))
  1318. await this.$refs.generateForm.setData({ [key]: data[key] })
  1319. this.specEditVisible = false
  1320. },
  1321. // ===== 事件 =====
  1322. openEventEditDialog(scope, mode, index) {
  1323. this.eventEditScope = scope
  1324. this.eventEditIndex = index
  1325. this.eventEditMode = mode
  1326. if (mode === 'edit' && scope.model.blank_event_component[index]) {
  1327. var r = scope.model.blank_event_component[index]
  1328. this.eventEditForm = { eventTime: r.eventTime||'', eventHospital: r.eventHospital||'', eventDesc: r.eventDesc||'', files: r.files||[], eventOpinion: r.eventOpinion||'' }
  1329. this.eventEditTitle = '编辑事件'
  1330. } else {
  1331. this.eventEditForm = { eventTime: '', eventHospital: '', eventDesc: '', files: [], eventOpinion: '' }
  1332. this.eventEditTitle = '添加事件'
  1333. }
  1334. this.eventEditVisible = true
  1335. },
  1336. async onEventEditSave() {
  1337. var scope = this.eventEditScope, idx = this.eventEditIndex, key = 'blank_event_component'
  1338. var data = await this.$refs.generateForm.getData(false)
  1339. if (!data[key]) data[key] = []
  1340. if (this.eventEditMode === 'edit') data[key][idx] = JSON.parse(JSON.stringify(this.eventEditForm))
  1341. else data[key].push(JSON.parse(JSON.stringify(this.eventEditForm)))
  1342. await this.$refs.generateForm.setData({ [key]: data[key] })
  1343. this.eventEditVisible = false
  1344. },
  1345. // ===== 补发 =====
  1346. openReissueEditDialog(scope, mode, index) {
  1347. this.reissueEditScope = scope
  1348. this.reissueEditIndex = index
  1349. this.reissueEditMode = mode
  1350. if (mode === 'edit' && scope.model.blank_reissue_component[index]) {
  1351. var r = scope.model.blank_reissue_component[index]
  1352. this.reissueEditForm = { reissueType: r.reissueType||'', reissueOtherType: r.reissueOtherType||'', reissueContact: r.reissueContact||'', reissueOtherReq: r.reissueOtherReq||'' }
  1353. this.reissueEditTitle = '编辑补发'
  1354. } else {
  1355. this.reissueEditForm = { reissueType: '', reissueOtherType: '', reissueContact: '', reissueOtherReq: '' }
  1356. this.reissueEditTitle = '添加补发'
  1357. }
  1358. this.reissueEditVisible = true
  1359. },
  1360. async onReissueEditSave() {
  1361. var scope = this.reissueEditScope, idx = this.reissueEditIndex, key = 'blank_reissue_component'
  1362. var data = await this.$refs.generateForm.getData(false)
  1363. if (!data[key]) data[key] = []
  1364. if (this.reissueEditMode === 'edit') data[key][idx] = JSON.parse(JSON.stringify(this.reissueEditForm))
  1365. else data[key].push(JSON.parse(JSON.stringify(this.reissueEditForm)))
  1366. await this.$refs.generateForm.setData({ [key]: data[key] })
  1367. this.reissueEditVisible = false
  1368. },
  1369. onReissueTypeConfirm(picker) {
  1370. var sel = (picker && picker.selectedOptions && picker.selectedOptions[0]) ? picker.selectedOptions[0].text : picker
  1371. this.reissueEditForm.reissueType = sel
  1372. this.reissueTypePopVisible = false
  1373. },
  1374. async handleUploadLocal (model, rowIndex) {
  1375. console.log('上传本地文件按钮被点击,字段模型:', model, '行索引:', rowIndex)
  1376. let data = await this.$refs.generateForm.getData(false);
  1377. let files = rowIndex != null && data[model] && data[model][rowIndex] ? (data[model][rowIndex].files || []) : (data[model] || [])
  1378. this.selectFilesField = model
  1379. this.selectFilesRowIndex = rowIndex != null ? rowIndex : null
  1380. uni.postMessage({
  1381. data: {
  1382. type: 'selectFiles',
  1383. field: model,
  1384. files: files,
  1385. isEdit: this.type || 'add'
  1386. }
  1387. });
  1388. },
  1389. addWorkOrder() {
  1390. uni.postMessage({
  1391. data: {
  1392. type: 'selectWork',
  1393. }
  1394. });
  1395. },
  1396. async addNewRow(key) {
  1397. console.log(key);
  1398. let data = await this.$refs.generateForm.getData(false);
  1399. data[key].push({
  1400. price: '',
  1401. remark: ''
  1402. });
  1403. this.$refs.generateForm.setData({
  1404. key: data[key]
  1405. });
  1406. },
  1407. async delNewRow(key, index, isChange) {
  1408. let data = await this.$refs.generateForm.getData(false);
  1409. data[key] = data[key].filter((item, index1) => index1 != index);
  1410. await this.$refs.generateForm.setData({
  1411. [key]: data[key]
  1412. });
  1413. if (isChange) {
  1414. this.changePrice(data[key])
  1415. }
  1416. },
  1417. changePrice(data) {
  1418. let num = 0;
  1419. data.forEach((item) => {
  1420. num += Number(item.price);
  1421. });
  1422. this.$refs.generateForm.setData({
  1423. input_jd9ouzyh: num
  1424. });
  1425. },
  1426. setSalesServiceWork(data) {
  1427. this.$refs.generateForm.setData({
  1428. manage_workorder: data
  1429. });
  1430. this.$refs.generateForm.setRules('manage_workorder', [{
  1431. required: false,
  1432. message: '必须填写'
  1433. }])
  1434. setTimeout(() => {
  1435. this.$refs.generateForm.validate(['manage_workorder'])
  1436. })
  1437. },
  1438. getQueryParams(queryName) {
  1439. const urlSearchParams = new URLSearchParams(window.location.search);
  1440. const query = urlSearchParams.get(queryName);
  1441. console.log(query, 'query')
  1442. return JSON.parse(query);
  1443. },
  1444. generateFormValid(validate = true) {
  1445. return this.$refs.generateForm.getData(validate).then((data) => { //清空content
  1446. for (key in data) {
  1447. if (key.includes('fileupload')) {
  1448. data[key].forEach(item => {
  1449. item['content'] = ''
  1450. })
  1451. }
  1452. }
  1453. return data;
  1454. });
  1455. },
  1456. async handleAudit(status) {
  1457. console.log(1111111, status)
  1458. let formData = await this.$refs.generateForm.getData(false);
  1459. console.log('formData~~~~', formData)
  1460. this.loading = true;
  1461. console.log(this.loading)
  1462. try {
  1463. this.form.valueJson = await this.generateFormValid();
  1464. } catch (error) {
  1465. console.log(22222, error)
  1466. this.loading = false;
  1467. return;
  1468. }
  1469. console.log(this.form.valueJson)
  1470. this.form.processType = '1';
  1471. let API = this.APIUrl + '/bpm/process-instance/create'
  1472. axios({
  1473. method: 'post',
  1474. url: API,
  1475. headers: this.headers,
  1476. data: {
  1477. ...this.form,
  1478. }
  1479. }).then((res) => {
  1480. this.loading = false;
  1481. if (res.data.code != '-1') {
  1482. vant.showNotify({
  1483. type: 'success',
  1484. message: `提交成功!`,
  1485. duration: 1000,
  1486. });
  1487. setTimeout(() => {
  1488. this.onClickLeft()
  1489. }, 1000)
  1490. } else {
  1491. vant.showNotify({
  1492. type: 'danger',
  1493. message: `提交失败!${res.data.message}`,
  1494. duration: 1000,
  1495. });
  1496. }
  1497. }).catch((err) => {
  1498. vant.showNotify({
  1499. type: 'danger',
  1500. message: `提交失败!${err.message}`,
  1501. duration: 1000,
  1502. });
  1503. this.loading = false;
  1504. });
  1505. },
  1506. onClickLeft() {
  1507. uni.navigateBack({
  1508. delta: 1
  1509. });
  1510. }
  1511. }
  1512. }).use(vant).use(FormMakingV3).mount('#app')
  1513. </script>
  1514. </body>
  1515. </html>