Dialog.vue 61 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870
  1. <template>
  2. <el-dialog
  3. :visible.sync="visible"
  4. :title="dialogType === 'add' ? '新增票种' : '编辑票种'"
  5. width="85%"
  6. append-to-body
  7. @close="handleClose"
  8. >
  9. <el-scrollbar
  10. :style="{ height: 'calc(100vh - 160px)' }"
  11. class="dialog-scroll">
  12. <el-form
  13. inline
  14. :model="form"
  15. ref="form"
  16. class="form-wrap"
  17. label-width="160px"
  18. >
  19. <div
  20. class="dialog-info1"
  21. style="padding-bottom: 0;">
  22. <div class="block-title">
  23. 基本属性
  24. </div>
  25. <el-form-item
  26. verify
  27. label="票种分类"
  28. prop="category">
  29. <el-select
  30. value-key="id"
  31. v-model="form.category"
  32. placeholder="请选择">
  33. <el-option
  34. v-for="item in ticketCategory"
  35. :key="item.id"
  36. :value="item.id"
  37. :label="item.name">
  38. </el-option>
  39. </el-select>
  40. </el-form-item>
  41. <el-form-item
  42. verify
  43. label="票种名称"
  44. prop="name"
  45. >
  46. <el-input v-model="form.name"></el-input>
  47. </el-form-item>
  48. <el-form-item
  49. verify
  50. label="在售状态"
  51. prop="isSale"
  52. >
  53. <el-switch
  54. v-model="form.isSale"
  55. :active-value="1"
  56. :inactive-value="0"
  57. active-text="在售"
  58. inactive-text="禁售">
  59. </el-switch>
  60. </el-form-item>
  61. <!-- 新增开票状态 -->
  62. <el-form-item
  63. verify
  64. label="是否支持开票"
  65. prop="isSupportInvoice"
  66. >
  67. <el-switch
  68. v-model="form.isSupportInvoice"
  69. :active-value="1"
  70. :inactive-value="0"
  71. active-text="支持开票"
  72. inactive-text="不支持开票">
  73. </el-switch>
  74. </el-form-item>
  75. <el-form-item
  76. verify
  77. label="销售价格"
  78. prop="price"
  79. >
  80. <el-input v-model="form.price"></el-input>
  81. </el-form-item>
  82. <el-form-item
  83. label="团散"
  84. prop="teamIndividual"
  85. >
  86. <el-select v-model="form.teamIndividual">
  87. <el-option
  88. :value="0"
  89. label="不限"
  90. ></el-option>
  91. <el-option
  92. :value="1"
  93. label="散客"
  94. ></el-option>
  95. <el-option
  96. :value="2"
  97. label="团队"
  98. ></el-option>
  99. </el-select>
  100. </el-form-item>
  101. <!-- <el-form-item
  102. label="线上价格"
  103. prop="onlinePrice"
  104. >
  105. <el-input-number
  106. controls-position="right"
  107. v-model="form.onlinePrice"
  108. :min="0"
  109. :step="0.01"
  110. :precision="2"
  111. ></el-input-number>
  112. </el-form-item>
  113. <el-form-item
  114. label="虚拟高价"
  115. prop="highPrice"
  116. >
  117. <el-input-number
  118. controls-position="right"
  119. v-model="form.highPrice"
  120. :min="0"
  121. :step="0.01"
  122. :precision="2"
  123. ></el-input-number>
  124. </el-form-item> -->
  125. <el-form-item
  126. verify
  127. label="多日票类型"
  128. prop="useDaysDelayType"
  129. >
  130. <el-radio
  131. v-model="form.useDaysDelayType"
  132. :label="1">
  133. 按照游玩时间延长
  134. </el-radio>
  135. <el-radio
  136. v-model="form.useDaysDelayType"
  137. :label="2">
  138. 按照首次核销时间延长
  139. </el-radio>
  140. <el-tag type="warning" style="margin-left: 10px;">票种如果可以使用多天,按照哪种方式延长游玩天数</el-tag>
  141. </el-form-item>
  142. <el-form-item
  143. v-if="form.category !== 'member'"
  144. verify
  145. label="日期类型"
  146. prop="useDateType"
  147. >
  148. <el-radio
  149. v-model="form.useDateType"
  150. :label="1">
  151. 日历票
  152. </el-radio>
  153. <el-radio
  154. v-model="form.useDateType"
  155. :label="2">
  156. 期票,时间期限内有效
  157. </el-radio>
  158. </el-form-item>
  159. <!-- <el-form-item
  160. v-if="form.useDateType === 2"
  161. label="消费日期"
  162. prop="validityUseDays"
  163. >
  164. 自购买起
  165. <el-input-number
  166. controls-position="right"
  167. v-model="form.validityUseDays"
  168. :min="0"
  169. :step="1"
  170. ></el-input-number>
  171. 天内可用
  172. </el-form-item> -->
  173. <!-- <el-form-item
  174. label="是否限制使用日期"
  175. prop="isUseDateLimit"
  176. >
  177. <el-switch
  178. v-model="form.isUseDateLimit"
  179. :active-value="1"
  180. :inactive-value="0"
  181. active-text="限制"
  182. inactive-text="不限">
  183. </el-switch>
  184. </el-form-item> -->
  185. <el-form-item
  186. v-if="form.category === 'member'"
  187. verify
  188. label="会员时长类型"
  189. prop="memberUseDateType"
  190. >
  191. <el-radio
  192. v-model="form.memberUseDateType"
  193. :label="1">
  194. 【按天】:购买后多少天的有效期
  195. </el-radio>
  196. <el-radio
  197. v-model="form.memberUseDateType"
  198. :label="2">
  199. 【按照使用日期】:固定某个时间期内可以用
  200. </el-radio>
  201. </el-form-item>
  202. <el-form-item
  203. v-if="!(form.category === 'member' && form.memberUseDateType === 2)"
  204. verify
  205. label="使用天数"
  206. prop="useDays"
  207. >
  208. <el-input-number
  209. controls-position="right"
  210. v-model="form.useDays"
  211. :min="0"
  212. :step="1"
  213. ></el-input-number>
  214. </el-form-item>
  215. <el-form-item
  216. v-if="!(form.category === 'member' && form.memberUseDateType === 1)"
  217. verify
  218. label="使用日期"
  219. prop="useDateStart"
  220. >
  221. <el-date-picker
  222. :editable="false"
  223. :clearable="false"
  224. :picker-options="pickerOptions"
  225. v-model="form.useDateStart"
  226. type="date"
  227. placeholder="开始日期"
  228. >
  229. </el-date-picker>
  230. <span style="margin:0 10px">至</span>
  231. <el-date-picker
  232. :editable="false"
  233. :clearable="false"
  234. :picker-options="pickerOptions"
  235. v-model="form.useDateEnd"
  236. type="date"
  237. placeholder="结束日期"
  238. >
  239. </el-date-picker>
  240. </el-form-item>
  241. <el-form-item
  242. v-if="form.category === 'member'"
  243. verify
  244. label="激活方式"
  245. prop="memberActiveType"
  246. >
  247. <el-radio
  248. v-model="form.memberActiveType"
  249. :label="1">
  250. 【购买即激活】 该年卡购买了就开始递减天数
  251. </el-radio>
  252. <el-radio
  253. v-model="form.memberActiveType"
  254. :label="2">
  255. 【首次使用激活】:第一次用了之后才开始递减时间,示例值
  256. </el-radio>
  257. </el-form-item>
  258. <!-- <el-form-item
  259. label="是否实名制购票"
  260. prop="isRealName"
  261. >
  262. <el-switch
  263. v-model="form.isRealName"
  264. :active-value="1"
  265. :inactive-value="0"
  266. active-text="限制"
  267. inactive-text="不限">
  268. </el-switch>
  269. </el-form-item>
  270. <el-form-item
  271. label="实名要求"
  272. prop="realNameType"
  273. >
  274. <el-radio
  275. v-model="form.realNameType"
  276. :label="1">
  277. 一证一人
  278. </el-radio>
  279. <el-radio
  280. v-model="form.realNameType"
  281. :label="2">
  282. 一证多人
  283. </el-radio>
  284. </el-form-item>
  285. <el-form-item
  286. label="预订协议"
  287. prop="buyProtocol"
  288. >
  289. <el-input v-model="form.buyProtocol"></el-input>
  290. <el-checkbox
  291. v-model="form.isAgreeProtocol">
  292. <span style="color:#0075ff">是否必须同意预定协议才可以购买</span>
  293. </el-checkbox>
  294. </el-form-item> -->
  295. <!-- <el-form-item
  296. label="是否限制售卖日期"
  297. prop="isSaleDateLimit"
  298. >
  299. <el-switch
  300. v-model="form.isSaleDateLimit"
  301. :active-value="1"
  302. :inactive-value="0"
  303. active-text="限制"
  304. inactive-text="不限">
  305. </el-switch>
  306. </el-form-item> -->
  307. <el-form-item
  308. v-if="form.isSaleDateLimit === 1"
  309. verify
  310. label="售卖时间"
  311. prop="saleDateStart"
  312. >
  313. <el-date-picker
  314. :editable="false"
  315. :clearable="false"
  316. :picker-options="pickerOptions"
  317. v-model="form.saleDateStart"
  318. type="date"
  319. placeholder="开始日期"
  320. >
  321. </el-date-picker>
  322. <span style="margin:0 10px">至</span>
  323. <el-date-picker
  324. :editable="false"
  325. :clearable="false"
  326. :picker-options="pickerOptions"
  327. v-model="form.saleDateEnd"
  328. type="date"
  329. placeholder="结束日期"
  330. >
  331. </el-date-picker>
  332. </el-form-item>
  333. <!-- <el-form-item
  334. label="是否限制预售范围"
  335. prop="isSalePreLimit"
  336. >
  337. <el-switch
  338. v-model="form.isSalePreLimit"
  339. :active-value="1"
  340. :inactive-value="0"
  341. active-text="限制"
  342. inactive-text="不限">
  343. </el-switch>
  344. </el-form-item>
  345. <el-form-item
  346. label="预售范围"
  347. prop="saleMaxPreDays"
  348. >
  349. <div class="item">
  350. 最大预售
  351. <el-input-number
  352. controls-position="right"
  353. v-model="form.saleMaxPreDays"
  354. :min="0"
  355. :step="1"
  356. ></el-input-number>
  357. 天以内的
  358. </div>
  359. <div class="item">
  360. 最小需提前
  361. <el-input-number
  362. controls-position="right"
  363. v-model="form.saleMinPreDays"
  364. :min="0"
  365. :step="1"
  366. ></el-input-number>
  367. 天预定(0 代表可订当日)
  368. </div>
  369. </el-form-item>
  370. <el-form-item
  371. label="是否限制下单数量"
  372. prop="isSaleNumsLimit"
  373. >
  374. <el-switch
  375. v-model="form.isSaleNumsLimit"
  376. :active-value="1"
  377. :inactive-value="0"
  378. active-text="限制"
  379. inactive-text="不限">
  380. </el-switch>
  381. </el-form-item>
  382. <el-form-item
  383. label="起订数"
  384. prop="saleMinNums"
  385. >
  386. <div class="item">
  387. 单订单最小起订数
  388. <el-input-number
  389. controls-position="right"
  390. v-model="form.saleMinNums"
  391. :min="0"
  392. :step="1"
  393. ></el-input-number>
  394. </div>
  395. <div class="item">
  396. 单订单最大起订数
  397. <el-input-number
  398. controls-position="right"
  399. v-model="form.saleMaxNums"
  400. :min="0"
  401. :step="1"
  402. ></el-input-number>
  403. </div>
  404. </el-form-item> -->
  405. <el-form-item
  406. verify
  407. label="核销凭证"
  408. prop="checkType"
  409. >
  410. <el-checkbox-group v-model="form.checkType">
  411. <el-checkbox
  412. label="qrcode">
  413. 二维码
  414. </el-checkbox>
  415. <el-checkbox
  416. label="idcard">
  417. 证件号
  418. </el-checkbox>
  419. <el-checkbox
  420. label="face">
  421. 人脸
  422. </el-checkbox>
  423. <el-checkbox
  424. label="card">
  425. IC卡
  426. </el-checkbox>
  427. </el-checkbox-group>
  428. </el-form-item>
  429. <el-form-item
  430. verify
  431. label="核销规则"
  432. prop="checkRule"
  433. >
  434. <el-checkbox-group v-model="form.checkRule">
  435. <el-checkbox
  436. label="1">
  437. 人工,检票设备核销
  438. </el-checkbox>
  439. <el-checkbox
  440. label="2">
  441. 取票即核销
  442. </el-checkbox>
  443. <el-checkbox
  444. label="3">
  445. 购买即核销
  446. </el-checkbox>
  447. </el-checkbox-group>
  448. </el-form-item>
  449. <el-form-item
  450. verify
  451. label="批量核销"
  452. prop="batchCheckRule"
  453. >
  454. <el-radio
  455. v-model="form.batchCheckRule"
  456. label="single">
  457. 单次核销
  458. </el-radio>
  459. <el-radio
  460. v-model="form.batchCheckRule"
  461. label="batch">
  462. 当票可以使用多次时,一次核销完成
  463. </el-radio>
  464. </el-form-item>
  465. <el-form-item
  466. label="核销语音"
  467. prop="checkVoice"
  468. >
  469. <el-input v-model="form.checkVoice">
  470. </el-input>
  471. <el-tag type="warning" style="margin-left: 10px;">如果为空 默认播报票种名称</el-tag>
  472. </el-form-item>
  473. <el-form-item
  474. verify
  475. label="星期检票规则"
  476. prop="useDayOfWeek"
  477. >
  478. <el-checkbox-group v-model="form.useDayOfWeek">
  479. <el-checkbox label="2">
  480. 星期一
  481. </el-checkbox>
  482. <el-checkbox label="3">
  483. 星期二
  484. </el-checkbox>
  485. <el-checkbox label="4">
  486. 星期三
  487. </el-checkbox>
  488. <el-checkbox label="5">
  489. 星期四
  490. </el-checkbox>
  491. <el-checkbox label="6">
  492. 星期五
  493. </el-checkbox>
  494. <el-checkbox label="7">
  495. 星期六
  496. </el-checkbox>
  497. <el-checkbox label="1">
  498. 星期日
  499. </el-checkbox>
  500. </el-checkbox-group>
  501. </el-form-item>
  502. <el-form-item
  503. verify
  504. label="票种绑定的销售渠道"
  505. prop="source"
  506. >
  507. <el-checkbox-group v-model="form.source">
  508. <el-checkbox
  509. label="window">
  510. 窗口
  511. </el-checkbox>
  512. <el-checkbox
  513. label="term">
  514. 自助机
  515. </el-checkbox>
  516. </el-checkbox-group>
  517. </el-form-item>
  518. <el-form-item
  519. verify
  520. label="是否可以退订"
  521. prop="isAllowCancel"
  522. >
  523. <el-switch
  524. v-model="form.isAllowCancel"
  525. :active-value="1"
  526. :inactive-value="0"
  527. active-text="可以"
  528. inactive-text="不可以">
  529. </el-switch>
  530. </el-form-item>
  531. <el-form-item
  532. verify
  533. label="是否必须换票使用"
  534. prop="isNeedPrint"
  535. >
  536. <el-switch
  537. v-model="form.isNeedPrint"
  538. :active-value="1"
  539. :inactive-value="0"
  540. active-text="需要"
  541. inactive-text="不限">
  542. </el-switch>
  543. </el-form-item>
  544. <el-form-item
  545. verify
  546. label="过期操作"
  547. prop="outOfDateDeal"
  548. >
  549. <el-radio
  550. v-model="form.outOfDateDeal"
  551. :label="1">
  552. 人工处理
  553. </el-radio>
  554. <el-radio
  555. v-model="form.outOfDateDeal"
  556. :label="2">
  557. 自动核销
  558. </el-radio>
  559. </el-form-item>
  560. <el-form-item
  561. label="绑定打印模板"
  562. prop="printTemplateId">
  563. <el-select v-model="form.printTemplateId" placeholder="请选择打印模板">
  564. <el-option
  565. v-for="item in printTemplateList"
  566. :key="item.id"
  567. :value="item.id"
  568. :label="item.name">
  569. </el-option>
  570. </el-select>
  571. </el-form-item>
  572. <template v-if="form.category === 'batch' && dialogType !== 'add'">
  573. <div class="block-title">
  574. 时间场次
  575. </div>
  576. <div>
  577. <div class="btn-wrap-left">
  578. <!-- <el-button
  579. plain
  580. class="add-btn"
  581. type="primary"
  582. @click="handleAddBachConfig">
  583. 增加
  584. </el-button> -->
  585. </div>
  586. <div class="table-box">
  587. <el-tag type="warning">场次时间默认不限制为-1</el-tag>
  588. <el-table
  589. border
  590. stripe
  591. :data="form.batchConfigList">
  592. <el-table-column
  593. label="场次名称"
  594. prop="name">
  595. <!-- <template slot-scope="scope">
  596. <el-input
  597. v-model="scope.row.name"
  598. style="width: 95%"></el-input>
  599. </template> -->
  600. </el-table-column>
  601. <el-table-column
  602. label="开始时间"
  603. prop="startTime">
  604. <!-- <template slot-scope="scope">
  605. <el-time-picker
  606. arrow-control
  607. style="width: 95%"
  608. v-model="scope.row.startTime"
  609. format="HH:mm:ss"
  610. value-format="HH:mm:ss"
  611. placeholder="开始时间">
  612. </el-time-picker>
  613. </template> -->
  614. </el-table-column>
  615. <el-table-column
  616. label="结束时间"
  617. prop="endTime">
  618. <!-- <template slot-scope="scope">
  619. <el-time-picker
  620. arrow-control
  621. v-model="scope.row.endTime"
  622. style="width: 95%"
  623. format="HH:mm:ss"
  624. value-format="HH:mm:ss"
  625. placeholder="结束时间">
  626. </el-time-picker>
  627. </template> -->
  628. </el-table-column>
  629. <el-table-column
  630. label="开场后X分钟停止售票"
  631. prop="saleStopMinutes">
  632. <!-- <template slot-scope="scope">
  633. <el-input-number
  634. controls-position="right"
  635. style="width: 95%"
  636. :min="-1"
  637. :precision="0"
  638. v-model="scope.row.saleStopMinutes"
  639. ></el-input-number>
  640. </template> -->
  641. </el-table-column>
  642. <el-table-column
  643. label="开场前X分钟停止退票"
  644. prop="cancelStopBeforeStartMinutes"
  645. min-width="90">
  646. <!-- <template slot-scope="scope">
  647. <el-input-number
  648. controls-position="right"
  649. style="width: 95%"
  650. :min="-1"
  651. :precision="0"
  652. v-model="scope.row.cancelStopBeforeStartMinutes"
  653. ></el-input-number>
  654. </template> -->
  655. </el-table-column>
  656. <el-table-column
  657. label="开场后X分钟停止退票"
  658. prop="cancelStopAfterStartMinutes"
  659. min-width="90">
  660. <!-- <template slot-scope="scope">
  661. <el-input-number
  662. controls-position="right"
  663. style="width: 95%"
  664. :min="-1"
  665. :precision="0"
  666. v-model="scope.row.cancelStopAfterStartMinutes"
  667. ></el-input-number>
  668. </template> -->
  669. </el-table-column>
  670. <el-table-column
  671. label="开场前X分钟允许检票入场"
  672. prop="preCheckMinutes"
  673. min-width="90">
  674. <!-- <template slot-scope="scope">
  675. <el-input-number
  676. controls-position="right"
  677. style="width: 95%"
  678. :min="-1"
  679. :precision="0"
  680. v-model="scope.row.preCheckMinutes"
  681. ></el-input-number>
  682. </template> -->
  683. </el-table-column>
  684. <el-table-column
  685. label="开场后X分钟停止检票"
  686. prop="stopCheckMinutes"
  687. min-width="90">
  688. <!-- <template slot-scope="scope">
  689. <el-input-number
  690. controls-position="right"
  691. style="width: 95%"
  692. :min="-1"
  693. :precision="0"
  694. v-model="scope.row.stopCheckMinutes"
  695. ></el-input-number>
  696. </template> -->
  697. </el-table-column>
  698. <el-table-column
  699. label="无座位时的最大数量"
  700. prop="maxSaleNums"
  701. min-width="90">
  702. <!-- <template slot-scope="scope">
  703. <el-input-number
  704. controls-position="right"
  705. style="width: 95%"
  706. :min="-1"
  707. :precision="0"
  708. v-model="scope.row.maxSaleNums"
  709. ></el-input-number>
  710. </template> -->
  711. </el-table-column>
  712. <!-- <el-table-column
  713. width="110"
  714. class-name="align-item"
  715. label="操作">
  716. <template slot-scope="scope">
  717. <span
  718. class="el-button el-button--primary el-button--small"
  719. @click="deleteBachConfig(scope.$index, scope.row)">
  720. <i class="el-icon-delete"></i>
  721. 删除
  722. </span>
  723. </template>
  724. </el-table-column> -->
  725. </el-table>
  726. </div>
  727. </div>
  728. </template>
  729. <div class="block-title">
  730. 添加适用景点
  731. </div>
  732. <div>
  733. <el-tag type="warning" style="margin-left: 10px;">景点检票次数不限制为-1</el-tag>
  734. <div class="btn-wrap-left">
  735. <el-button
  736. plain
  737. class="add-btn"
  738. type="primary"
  739. @click="handleAdd">
  740. 添加单个
  741. </el-button>
  742. </div>
  743. <div class="table-box">
  744. <el-table
  745. border
  746. stripe
  747. :data="form.singleScenicList">
  748. <el-table-column
  749. label="适用景点">
  750. <template slot-scope="scope">
  751. <el-select
  752. v-model="scope.row.scenicId">
  753. <el-option
  754. v-for="item in localScenicList"
  755. :key="item.id"
  756. :label="item.name"
  757. :value="item.id"
  758. >
  759. </el-option>
  760. </el-select>
  761. </template>
  762. </el-table-column>
  763. <el-table-column
  764. label="检票次数"
  765. min-width="90">
  766. <template slot-scope="scope">
  767. <el-input-number
  768. controls-position="right"
  769. :min="-1"
  770. :precision="0"
  771. v-model="scope.row.checkLimitTimes"
  772. ></el-input-number>
  773. </template>
  774. </el-table-column>
  775. <el-table-column
  776. label="单日限制检票次数"
  777. min-width="90">
  778. <template slot-scope="scope">
  779. <el-input-number
  780. controls-position="right"
  781. :min="-1"
  782. :precision="0"
  783. v-model="scope.row.singleDayLimitTimes"
  784. ></el-input-number>
  785. </template>
  786. </el-table-column>
  787. <el-table-column
  788. width="90"
  789. class-name="align-item"
  790. label="操作">
  791. <template slot-scope="scope">
  792. <span
  793. class="el-button el-button--primary el-button--small"
  794. @click="delScenic(scope.$index)">
  795. <i class="el-icon-delete"></i>
  796. 删除
  797. </span>
  798. </template>
  799. </el-table-column>
  800. </el-table>
  801. </div>
  802. <div class="btn-wrap-left">
  803. <el-button
  804. plain
  805. class="add-btn"
  806. type="primary"
  807. @click="handleAdd('multiple')">
  808. 添加群组
  809. </el-button>
  810. </div>
  811. <div class="table-box">
  812. <el-table
  813. border
  814. stripe
  815. :data="form.groupScenicList">
  816. <el-table-column
  817. label="适用景点">
  818. <template slot-scope="scope">
  819. <el-select
  820. v-model="scope.row.scenicId"
  821. multiple>
  822. <el-option
  823. v-for="item in localScenicList"
  824. :key="item.id"
  825. :label="item.name"
  826. :value="item.id"
  827. >
  828. </el-option>
  829. </el-select>
  830. </template>
  831. </el-table-column>
  832. <el-table-column
  833. label="检票次数总和"
  834. min-width="90">
  835. <template slot-scope="scope">
  836. <el-input-number
  837. controls-position="right"
  838. :min="-1"
  839. :precision="0"
  840. v-model="scope.row.checkLimitTimes"
  841. ></el-input-number>
  842. </template>
  843. </el-table-column>
  844. <!-- <el-table-column
  845. label="单景点检票次数"
  846. min-width="90">
  847. <template slot-scope="scope">
  848. <el-input-number
  849. controls-position="right"
  850. :min="-1"
  851. :precision="0"
  852. v-model="scope.row.scenicLimitTimes"
  853. ></el-input-number>
  854. </template>
  855. </el-table-column> -->
  856. <el-table-column
  857. width="210"
  858. class-name="align-item"
  859. label="操作">
  860. <template slot-scope="scope">
  861. <div style="display:flex">
  862. <span
  863. class="el-button el-button--primary el-button--small"
  864. @click="setSceneTimes(scope.$index, scope.row)">
  865. <i class="el-icon-edit-outline"></i>
  866. 分配次数
  867. </span>
  868. <span
  869. class="el-button el-button--primary el-button--small"
  870. @click="delScenic(scope.$index, 'multiple')">
  871. <i class="el-icon-delete"></i>
  872. 删除
  873. </span>
  874. </div>
  875. </template>
  876. </el-table-column>
  877. </el-table>
  878. </div>
  879. </div>
  880. <div class="block-title">
  881. 添加工商银行子商户
  882. </div>
  883. <div>
  884. <div class="btn-wrap-left">
  885. <el-button
  886. plain
  887. class="add-btn"
  888. type="primary"
  889. @click="handleAddGhSubMerchant">
  890. 添加
  891. </el-button>
  892. </div>
  893. <div class="table-box">
  894. <el-table
  895. border
  896. stripe
  897. :data="form.payGonghangTicketTypeMerchantList">
  898. <el-table-column
  899. label="工行子商户">
  900. <template slot-scope="scope">
  901. <el-select
  902. v-model="scope.row.gonghangMerchantId">
  903. <el-option
  904. v-for="item in ghSubMerchantList"
  905. :key="item.id"
  906. :label="item.name"
  907. :value="item.id"
  908. >
  909. </el-option>
  910. </el-select>
  911. </template>
  912. </el-table-column>
  913. <el-table-column
  914. label="分账比例"
  915. min-width="90">
  916. <template slot-scope="scope">
  917. <el-input-number
  918. controls-position="right"
  919. :min="0"
  920. :max="100"
  921. v-model="scope.row.splitRatio"
  922. ></el-input-number>
  923. <span class="unit" style="margin-left: 20px; font-size: 16px;">{{ scope.row.splitRatio * 100 }}%</span>
  924. </template>
  925. </el-table-column>
  926. <el-table-column
  927. label="固定金额"
  928. min-width="90">
  929. <template slot-scope="scope">
  930. <el-input-number
  931. controls-position="right"
  932. :min="0"
  933. v-model="scope.row.fixedAmount"
  934. ></el-input-number>
  935. <Tip msg="避免小数点情况 优先按照固定金额计算分账金额否则按照分账比例" style="margin-left: 10px;"></Tip>
  936. </template>
  937. </el-table-column>
  938. <el-table-column
  939. width="90"
  940. class-name="align-item"
  941. label="操作">
  942. <template slot-scope="scope">
  943. <span
  944. class="el-button el-button--primary el-button--small"
  945. @click="delGhSubMerchant(scope.$index)">
  946. <i class="el-icon-delete"></i>
  947. 删除
  948. </span>
  949. </template>
  950. </el-table-column>
  951. </el-table>
  952. </div>
  953. </div>
  954. <div class="block-title">
  955. 添加发票销售方
  956. </div>
  957. <div>
  958. <div class="btn-wrap-left">
  959. <el-button
  960. plain
  961. class="add-btn"
  962. type="primary"
  963. @click="handleAddInvoiceSeller">
  964. 添加
  965. </el-button>
  966. </div>
  967. <div class="table-box">
  968. <el-table
  969. border
  970. stripe
  971. :data="form.ticketTypeInvoiceSellerList">
  972. <el-table-column
  973. label="销售方">
  974. <template slot-scope="scope">
  975. <el-select
  976. v-model="scope.row.invoiceSellerId">
  977. <el-option
  978. v-for="item in invoiceSellerList"
  979. :key="item.id"
  980. :label="item.invoiceSellerName"
  981. :value="item.id"
  982. >
  983. </el-option>
  984. </el-select>
  985. </template>
  986. </el-table-column>
  987. <el-table-column
  988. label="分账比例"
  989. min-width="90">
  990. <template slot-scope="scope">
  991. <el-input-number
  992. controls-position="right"
  993. :min="0"
  994. :max="1"
  995. v-model="scope.row.splitRatio"
  996. ></el-input-number>
  997. <span class="unit" style="margin-left: 20px; font-size: 16px;">{{ scope.row.splitRatio * 100 }}%</span>
  998. </template>
  999. </el-table-column>
  1000. <el-table-column
  1001. label="固定金额"
  1002. min-width="90">
  1003. <template slot-scope="scope">
  1004. <el-input-number
  1005. controls-position="right"
  1006. :min="0"
  1007. v-model="scope.row.fixedAmount"
  1008. ></el-input-number>
  1009. <Tip msg="避免小数点情况 优先按照固定金额计算分账金额否则按照分账比例" style="margin-left: 10px;"></Tip>
  1010. </template>
  1011. </el-table-column>
  1012. <el-table-column
  1013. width="90"
  1014. class-name="align-item"
  1015. label="操作">
  1016. <template slot-scope="scope">
  1017. <span
  1018. class="el-button el-button--primary el-button--small"
  1019. @click="delInvoiceSeller(scope.$index)">
  1020. <i class="el-icon-delete"></i>
  1021. 删除
  1022. </span>
  1023. </template>
  1024. </el-table-column>
  1025. </el-table>
  1026. </div>
  1027. </div>
  1028. <div class="block-title">
  1029. 添加分账子景点
  1030. </div>
  1031. <div>
  1032. <div class="btn-wrap-left">
  1033. <el-button
  1034. plain
  1035. class="add-btn"
  1036. type="primary"
  1037. @click="handleAddScenicSplit">
  1038. 添加
  1039. </el-button>
  1040. </div>
  1041. <div class="table-box">
  1042. <el-table
  1043. border
  1044. stripe
  1045. :data="form.ticketTypeScenicSplitRequests">
  1046. <el-table-column
  1047. label="适用景点">
  1048. <template slot-scope="scope">
  1049. <el-select
  1050. v-model="scope.row.scenicId">
  1051. <el-option
  1052. v-for="item in localScenicList"
  1053. :key="item.id"
  1054. :label="item.name"
  1055. :value="item.id"
  1056. >
  1057. </el-option>
  1058. </el-select>
  1059. </template>
  1060. </el-table-column>
  1061. <el-table-column
  1062. label="应分金额"
  1063. min-width="90">
  1064. <template slot-scope="scope">
  1065. <el-input-number
  1066. controls-position="right"
  1067. :min="0"
  1068. v-model="scope.row.price"
  1069. ></el-input-number>
  1070. </template>
  1071. </el-table-column>
  1072. <el-table-column
  1073. width="90"
  1074. class-name="align-item"
  1075. label="操作">
  1076. <template slot-scope="scope">
  1077. <span
  1078. class="el-button el-button--primary el-button--small"
  1079. @click="delScenicSplit(scope.$index)">
  1080. <i class="el-icon-delete"></i>
  1081. 删除
  1082. </span>
  1083. </template>
  1084. </el-table-column>
  1085. </el-table>
  1086. </div>
  1087. </div>
  1088. </div>
  1089. <div class="dialog-btn-wrap">
  1090. <el-button
  1091. @click="handleClose">
  1092. 取消
  1093. </el-button>
  1094. <el-button
  1095. @click="reset"
  1096. v-if="dialogType === 'add'">
  1097. 重置
  1098. </el-button>
  1099. <el-button
  1100. @click="submit"
  1101. type="primary">
  1102. 保存
  1103. </el-button>
  1104. </div>
  1105. </el-form>
  1106. </el-scrollbar>
  1107. <el-dialog
  1108. :visible.sync="setTimeVisible"
  1109. title="分配次数"
  1110. append-to-body
  1111. @close="handleGroupTimeClose">
  1112. <div class="table-box">
  1113. <el-table
  1114. border
  1115. stripe
  1116. :data="currGroupScenicInfo">
  1117. <el-table-column
  1118. label="景点">
  1119. <template slot-scope="scope">
  1120. {{ scope.row.scenicName }}
  1121. </template>
  1122. </el-table-column>
  1123. <el-table-column
  1124. label="单个景点的检票次数"
  1125. min-width="90">
  1126. <template slot-scope="scope">
  1127. <el-input-number
  1128. controls-position="right"
  1129. :min="-1"
  1130. :precision="0"
  1131. v-model="scope.row.scenicLimitTimes"
  1132. ></el-input-number>
  1133. </template>
  1134. </el-table-column>
  1135. <el-table-column
  1136. label="单日限制检票次数"
  1137. min-width="90">
  1138. <template slot-scope="scope">
  1139. <el-input-number
  1140. controls-position="right"
  1141. :min="-1"
  1142. :precision="0"
  1143. v-model="scope.row.singleDayLimitTimes"
  1144. ></el-input-number>
  1145. </template>
  1146. </el-table-column>
  1147. </el-table>
  1148. </div>
  1149. <div
  1150. slot="footer"
  1151. class="dialog-btn-wrap">
  1152. <el-button
  1153. @click="handleGroupTimeClose">
  1154. 取消
  1155. </el-button>
  1156. <el-button
  1157. @click="handleGroupTimeSubmit"
  1158. type="primary">
  1159. 确定
  1160. </el-button>
  1161. </div>
  1162. </el-dialog>
  1163. </el-dialog>
  1164. </template>
  1165. <script>
  1166. import { addTicket, updateTicket, queueList, batchUpdateTicketBatch, delTicketBatch, getScenic } from '@/api/ticketType'
  1167. import { getGhSubMerchantList } from '@/api/payChannel'
  1168. import { getInvoiceSellerList } from '@/api/invoice'
  1169. import { getTicketPrintModelList } from '@/api/printModal'
  1170. import { getLabelName } from '@/utils'
  1171. import { cloneDeep } from 'lodash'
  1172. import moment from 'moment'
  1173. const defaultForm = {
  1174. category: 'ticket', // 大类
  1175. name: '', // 名称
  1176. isSale: 1, // 在售状态 0为禁售 1为在售 默认为1
  1177. isSupportInvoice: 1, // 是否支持发票 0为不支持 1为支持 默认为1
  1178. price: '', // 窗口价格
  1179. onlinePrice: 0, // 线上价格
  1180. highPrice: 0, // 虚拟高价(划线价格)
  1181. memberUseDateType: 1, // 会员时长类型 1【按天】:购买后多少天的有效期 由票种字段use_days生效 。2【按照使用日期】:固定某个时间期内可以用
  1182. memberActiveType: 1, // 激活方式:【1:购买即激活】 该年卡购买了就开始递减天数。【2:首次使用激活】:第一次用了之后才开始递减时间,示例值(1)
  1183. useDays: 1, // 使用天数 默认为1天 如果是年卡次卡 且会员卡的时长类型是按天数的 该值代表会员卡的时长天数 比如365 该值必须大于1 否则该值为0
  1184. // validityUseDays: 0, // 期票模式下第一种情况 自购买日起X天内可使用 X必须大于0
  1185. // isUseDateLimit: 1, // 是否限制使用日期 0为不限 1为限制 默认为0 如果限制 必须指定使用日期 期票模式下且不是购买日情况下必须指定
  1186. useDateStart: moment().format('YYYY-MM-DD'), // 使用日期开始
  1187. useDateEnd: moment().add(10, 'years').format('YYYY-MM-DD'), // 使用日期结束
  1188. isRealName: 0, // 是否需要实名认证 0为不需要 1为需要 默认为0
  1189. realNameType: 1, // 在实名制购票下 1 【一证一人】:购买两张票需要两张实名。2【一证多人】:购买多张只需要一人实名
  1190. buyProtocol: '', // 预定协议 富文本
  1191. isAgreeProtocol: 0, // 是否必须同意预定协议才可以购买 开启为1 默认为0
  1192. isSaleDateLimit: 1, // 是否限制售卖日期 0为不限 1为限制 默认为0 如果限制 必须指定售卖时间
  1193. saleDateStart: moment().format('YYYY-MM-DD'), // 售卖时间开始
  1194. saleDateEnd: moment().add(10, 'years').format('YYYY-MM-DD'), // 售卖时间结束
  1195. isSalePreLimit: 0, // 是否限制预售范围 0为不限 1为限制 默认为0 如果限制 必须指定预售范围
  1196. saleMaxPreDays: 365, // 预售范围 最大预售X天以内的 默认为365 代表可预定一整年
  1197. saleMinPreDays: 0, // 预售范围 最小需提前X天预定 默认为0 代表可订当日
  1198. isSaleNumsLimit: 0, // 是否限制下单数量 0为不限 1为限制 默认为0 如果限制 必须指定下单数量
  1199. saleMinNums: 0, // 单订单最小起订数
  1200. saleMaxNums: 0, // 单订单最大起订数
  1201. checkType: ['qrcode', 'idcard'], // 核销凭证 qrcode 二维码 idcard 证件号 face 人脸 多选用逗号分隔,示例值(qrcode,idcard)
  1202. checkRule: ['1'], // 核销规则 1人工,检票设备核销 2取票即核销 3购买即核销 多选用逗号分隔,示例值(1,2)
  1203. batchCheckRule: 'single', // 批量核销规则 single-代表单次核销 batch-代表当票可以使用多次时,一次核销完
  1204. checkVoice: '', // 核销语音 如果为空 默认播报票种名称
  1205. useDayOfWeek: ['1', '2', '3', '4', '5', '6', '7'], // 指定周几可以用 逗号分隔 1表示周日,2表示周一 依次类推,示例值(1,2,3,4,5,6,7)
  1206. isAllowCancel: 1, // 是否允许取消订单 0为不允许 1为允许 默认为1
  1207. isNeedPrint: 0, // 是否必须换票使用 默认为0 不限 否则需要门票取票打印后才可以核销
  1208. outOfDateDeal: 1, // 过期操作 1人工处理 2自动核销 默认为1,示例值(1)
  1209. singleScenicList: [], // 包含项目-单个景点数组
  1210. groupScenicList: [], // 包含项目-组合景点数组 二维数组结构
  1211. batchConfigList: [], // 批次配置数组
  1212. ticketTypeScenicList: [], // 票种绑定的景点数组
  1213. source: ['window', 'term'], // 票种绑定的销售渠道 窗口:window ; 自助机:term,示例值([window])
  1214. useDateType: 1, // 使用日期类型 1日历票 2期票 默认为1
  1215. useDaysDelayType: 1, // 使用日期截止类型 1按使用日期截止 2按使用天数截止 默认为1
  1216. payGonghangTicketTypeMerchantList: [], // 工行子商户列表
  1217. ticketTypeInvoiceSellerList: [], // 发票销售方列表
  1218. ticketTypeScenicSplitRequests: [], // 子分账景点
  1219. teamIndividual: 0, // 团散:0-不限 1-散客 2-团队
  1220. printTemplateId: null // 绑定打印模板ID
  1221. }
  1222. export default {
  1223. computed: {
  1224. scenicName () {
  1225. return this.$localStore.get('scenicName') || this.$store.state.user.scenicName
  1226. },
  1227. ticketCategory () {
  1228. return this.$store.state.app.ticketCategory
  1229. }
  1230. },
  1231. props: {
  1232. memberTypeList: {
  1233. type: Array,
  1234. default: () => []
  1235. },
  1236. // ticketItem: {
  1237. // type: Object,
  1238. // default: () => {}
  1239. // },
  1240. // dialogType: {
  1241. // type: String,
  1242. // default: ''
  1243. // },
  1244. scenicList: {
  1245. type: Array,
  1246. default: () => []
  1247. },
  1248. ticketTagList: {
  1249. type: Array,
  1250. default: () => []
  1251. },
  1252. invoiceSeller: {
  1253. type: Array,
  1254. default: () => []
  1255. }
  1256. },
  1257. data () {
  1258. return {
  1259. ticketItem: {},
  1260. dialogType: 'add',
  1261. projectName: process.env.VUE_APP_PROJECT,
  1262. visible: false,
  1263. localScenicList: [],
  1264. pickerOptions: {
  1265. disabledDate: (theTime) => {
  1266. let startTime = moment().format('YYYY-MM-DD') + ' 00:00:00'
  1267. return moment(theTime).isBefore(startTime)
  1268. }
  1269. },
  1270. dialogVisible: false,
  1271. originRecord: {},
  1272. currentRecord: {},
  1273. man: 0, // 满x
  1274. jian: 0, // 减y
  1275. queueList: [],
  1276. inputVisible: false,
  1277. inputValue: [],
  1278. form: defaultForm,
  1279. batchConfig: {
  1280. name: '', // 批次名称
  1281. startTime: '', // 批次开始时间
  1282. endTime: '', // 批次结束时间
  1283. saleStopMinutes: -1, // 售卖截止时间
  1284. cancelStopBeforeStartMinutes: -1, // 取消截止时间
  1285. cancelStopAfterStartMinutes: -1, // 取消截止时间
  1286. preCheckMinutes: -1, // 预检时间
  1287. stopCheckMinutes: -1, // 停止检票时间
  1288. maxSaleNums: -1 // 最大售卖数量
  1289. },
  1290. setTimeVisible: false,
  1291. groupIndex: -1,
  1292. currGroupScenicInfo: [],
  1293. groupScenicMap: new Map(),
  1294. ghSubMerchantList: [], // 工行子商户列表
  1295. invoiceSellerList: [], // 发票销售方列表
  1296. printTemplateList: [] // 打印模板列表
  1297. }
  1298. },
  1299. watch: {
  1300. // 'form.memberType' (val) {
  1301. // console.log(val)
  1302. // this.form.name = val && val.name
  1303. // this.form.price = val && val.capital
  1304. // },
  1305. 'form.category' (val) {
  1306. if (val === 'member') {
  1307. this.form.useDays = 365
  1308. } else {
  1309. this.form.useDays = 1
  1310. }
  1311. },
  1312. // 满x减y
  1313. 'man': function (newVal, oldVal) {
  1314. this.updateDiscountRule()
  1315. },
  1316. 'jian': function (newVal, oldVal) {
  1317. this.updateDiscountRule()
  1318. }
  1319. },
  1320. methods: {
  1321. async show (ticketItem, type) {
  1322. // 每次打开时拉取最新景点列表
  1323. const res = await getScenic()
  1324. this.localScenicList = res?.data?.records || []
  1325. // this.reset()
  1326. this.ticketItem = ticketItem
  1327. this.dialogType = type
  1328. if (ticketItem) {
  1329. this.form = cloneDeep(ticketItem)
  1330. // 编辑时 batch 当做 ticket 处理
  1331. if (this.dialogType === 'edit' && this.form.category === 'batch') {
  1332. this.form.category = 'ticket'
  1333. }
  1334. this.form.source = ticketItem.source || []
  1335. this.form.useDayOfWeek = this.form.useDayOfWeek.split(',')
  1336. this.form.checkType = this.form.checkType.split(',')
  1337. this.form.checkRule = this.form.checkRule.split(',')
  1338. if (!this.form.source) {
  1339. this.form.source = []
  1340. }
  1341. if (!this.form.ticketTypeScenicList) {
  1342. this.form.ticketTypeScenicList = []
  1343. }
  1344. if (!this.form.singleScenicList) {
  1345. this.form.singleScenicList = []
  1346. }
  1347. if (!this.form.groupScenicList) {
  1348. this.form.groupScenicList = []
  1349. }
  1350. if (!this.form.batchConfigList) {
  1351. this.form.batchConfigList = []
  1352. }
  1353. if (!this.form.payGonghangTicketTypeMerchantList) {
  1354. this.form.payGonghangTicketTypeMerchantList = []
  1355. }
  1356. if (!this.form.ticketTypeInvoiceSellerList) {
  1357. this.form.ticketTypeInvoiceSellerList = []
  1358. }
  1359. if (!this.form.ticketTypeScenicSplitRequests) {
  1360. this.form.ticketTypeScenicSplitRequests = []
  1361. }
  1362. let groupFlag = ''
  1363. let groupIndex = 0
  1364. this.form.ticketTypeScenicList.forEach(item => {
  1365. if (!item.groupFlag) {
  1366. this.form.singleScenicList.push({
  1367. scenicId: item.scenicId,
  1368. checkLimitTimes: item.checkLimitTimes,
  1369. singleDayLimitTimes: item.singleDayLimitTimes
  1370. })
  1371. } else {
  1372. if (groupFlag !== item.groupFlag) {
  1373. groupFlag = item.groupFlag
  1374. groupIndex += 1
  1375. this.form.groupScenicList.push({
  1376. scenicId: [item.scenicId],
  1377. checkLimitTimes: item.checkLimitTimes,
  1378. scenicLimitTimes: item.scenicLimitTimes,
  1379. singleDayLimitTimes: item.singleDayLimitTimes
  1380. })
  1381. } else {
  1382. this.form.groupScenicList[groupIndex - 1].scenicId.push(item.scenicId)
  1383. }
  1384. }
  1385. })
  1386. }
  1387. // 复制票种功能
  1388. if (this.dialogType === 'add' && this.ticketItem) {
  1389. // '创建票种失败,名称或助记符重复' 需要在此之前去掉名称和助记符,待复制时用户填入
  1390. this.codeCopyFromVisibleEdit() // 执行与edit一样的操作,要确保传过来的ticketItem把ID信息去了
  1391. }
  1392. if (typeof this.form.requiredField === 'string') {
  1393. this.form.requiredField = JSON.parse(this.form.requiredField)
  1394. } else {
  1395. this.form.requiredField = []
  1396. }
  1397. if (this.form && this.form.discountRule) {
  1398. // 初始化满减
  1399. let result = this.parseDiscountRule(this.form.discountRule)
  1400. this.man = result ? result.man : this.man
  1401. this.jian = result ? result.jian : this.jian
  1402. }
  1403. if (this.projectName === 'hangzhousuodao') {
  1404. this.getQueue()
  1405. }
  1406. this.getGhSubMerchantList()
  1407. this.getInvoiceSellerList()
  1408. this.loadPrintTemplates()
  1409. this.visible = true
  1410. },
  1411. async getGhSubMerchantList () {
  1412. // 获取工行子商户列表
  1413. const res = await getGhSubMerchantList()
  1414. this.ghSubMerchantList = res.data || []
  1415. },
  1416. async getInvoiceSellerList () {
  1417. // 获取发票销售方列表
  1418. const res = await getInvoiceSellerList()
  1419. this.invoiceSellerList = res.data || []
  1420. },
  1421. async loadPrintTemplates () {
  1422. const res = await getTicketPrintModelList({ pageNum: 0, pageSize: -1 })
  1423. this.printTemplateList = res?.data?.records || []
  1424. if (this.printTemplateList.length > 0 && this.form.printTemplateId == null) {
  1425. this.form.printTemplateId = this.printTemplateList[0].id
  1426. }
  1427. },
  1428. updateDiscountRule: function () {
  1429. let man = parseInt(this.man)
  1430. let jian = parseInt(this.jian)
  1431. let form = this.form
  1432. form.discountRule = '满' + man + '减' + jian
  1433. },
  1434. // 从满10减1这种字符串里提取出10和1
  1435. parseDiscountRule (discountRule) {
  1436. let pattern = /满(\d+)减(\d+)/ // 定义正则表达式
  1437. let match = discountRule.match(pattern) // 使用 match() 方法匹配字符串
  1438. if (match) {
  1439. let man = parseInt(match[1]) // 第一个括号中的数字为满减条件
  1440. let jian = parseInt(match[2]) // 第二个括号中的数字为满减金额
  1441. return { man, jian }
  1442. }
  1443. return null // 如果匹配失败,则返回 null
  1444. },
  1445. getLabelName,
  1446. // isScenicDisabled (id) {
  1447. // return this.form.singleScenicList.some(s => s.scenicId === id)
  1448. // },
  1449. handleClose () {
  1450. this.visible = false
  1451. this.reset()
  1452. this.$emit('updateList')
  1453. },
  1454. reset () {
  1455. this.$refs.form.resetFields()
  1456. this.form = { ...defaultForm }
  1457. this.form.singleScenicList = []
  1458. this.form.groupScenicList = []
  1459. },
  1460. handleMemberChange (e) {
  1461. let target = this.memberTypeList.find(i => i.id === e)
  1462. this.form.price = target.capital
  1463. this.form.name = target.name
  1464. },
  1465. // 增加 适用景点-检票次数
  1466. handleAdd (type) {
  1467. if (type === 'multiple') {
  1468. this.form.groupScenicList.push({
  1469. scenicId: [],
  1470. checkLimitTimes: 1,
  1471. singleDayLimitTimes: -1,
  1472. scenicLimitTimes: -1
  1473. })
  1474. } else {
  1475. this.form.singleScenicList.push({
  1476. scenicId: '',
  1477. checkLimitTimes: 1,
  1478. singleDayLimitTimes: -1,
  1479. scenicLimitTimes: -1
  1480. })
  1481. }
  1482. },
  1483. handleAddGhSubMerchant () {
  1484. this.form.payGonghangTicketTypeMerchantList.push({
  1485. gonghangMerchantId: '',
  1486. splitRatio: 0,
  1487. fixedAmount: ''
  1488. })
  1489. },
  1490. delGhSubMerchant (index) {
  1491. this.form.payGonghangTicketTypeMerchantList.splice(index, 1)
  1492. },
  1493. handleAddInvoiceSeller () {
  1494. this.form.ticketTypeInvoiceSellerList.push({
  1495. invoiceSellerId: '',
  1496. splitRatio: 0,
  1497. fixedAmount: ''
  1498. })
  1499. },
  1500. delInvoiceSeller (index) {
  1501. this.form.ticketTypeInvoiceSellerList.splice(index, 1)
  1502. },
  1503. handleAddScenicSplit () {
  1504. this.form.ticketTypeScenicSplitRequests.push({
  1505. scenicId: '',
  1506. price: 0
  1507. })
  1508. },
  1509. delScenicSplit (index) {
  1510. this.form.ticketTypeScenicSplitRequests.splice(index, 1)
  1511. },
  1512. setSceneTimes (idx, item) {
  1513. if (!item || !item.scenicId || !item.scenicId.length) {
  1514. return this.$message.error('请先添加适用景点')
  1515. }
  1516. this.groupIndex = idx
  1517. const groupScenic = this.groupScenicMap.get(idx)
  1518. if (groupScenic) {
  1519. this.currGroupScenicInfo = groupScenic
  1520. } else {
  1521. this.currGroupScenicInfo = []
  1522. item.scenicId.forEach(id => {
  1523. const scene = this.localScenicList.find((scene) => scene.id === id)
  1524. if (scene) {
  1525. this.currGroupScenicInfo.push({
  1526. scenicId: scene.id,
  1527. scenicName: scene.name,
  1528. scenicLimitTimes: -1,
  1529. singleDayLimitTimes: -1,
  1530. checkLimitTimes: item.checkLimitTimes
  1531. })
  1532. }
  1533. })
  1534. }
  1535. this.setTimeVisible = true
  1536. },
  1537. handleGroupTimeClose () {
  1538. this.currGroupScenicInfo = []
  1539. this.setTimeVisible = false
  1540. },
  1541. handleGroupTimeSubmit () {
  1542. this.groupScenicMap.set(this.groupIndex, this.currGroupScenicInfo)
  1543. this.currGroupScenicInfo = []
  1544. this.setTimeVisible = false
  1545. },
  1546. // 删除 适用景点-检票次数
  1547. delScenic (index, type) {
  1548. if (type === 'multiple') {
  1549. this.form.groupScenicList.splice(index, 1)
  1550. } else {
  1551. this.form.singleScenicList.splice(index, 1)
  1552. }
  1553. },
  1554. isScenicValid () {
  1555. if (this.form.singleScenicList.length === 0 && this.form.groupScenicList.length === 0) {
  1556. this.$message.error('请添加适用景点')
  1557. return false
  1558. } else if (this.form.singleScenicList.some(item => !item.scenicId)) {
  1559. this.$message.error('适用景点信息错误')
  1560. return false
  1561. } else if (this.form.groupScenicList.some(item => !item.scenicId.length)) {
  1562. this.$message.error('适用景点信息错误')
  1563. return false
  1564. } else {
  1565. return true
  1566. }
  1567. },
  1568. handleAddBachConfig () {
  1569. this.form.batchConfigList.push({ ...this.batchConfig })
  1570. },
  1571. deleteBachConfig (index, row) {
  1572. if (row.id) {
  1573. this.$confirm('确定删除场次时间配置?', '提示', {
  1574. confirmButtonText: '确定',
  1575. cancelButtonText: '取消',
  1576. type: 'warning'
  1577. }).then(() => {
  1578. delTicketBatch([row.id]).then(res => {
  1579. if (res.code === '200') {
  1580. this.$message.success('删除成功')
  1581. this.form.batchConfigList.splice(index, 1)
  1582. }
  1583. })
  1584. }).catch(() => {})
  1585. } else {
  1586. this.form.batchConfigList.splice(index, 1)
  1587. }
  1588. },
  1589. async saveAllBatchConfig () {
  1590. const ticketTypeId = this.form.id
  1591. if (!ticketTypeId) {
  1592. return
  1593. }
  1594. batchUpdateTicketBatch(ticketTypeId, this.form.batchConfigList).then(res => {
  1595. if (res.code !== '200') {
  1596. this.$message.error('场次保存失败')
  1597. }
  1598. })
  1599. },
  1600. setGroupScenicConfig () {
  1601. const gsList = []
  1602. const { groupScenicList } = this.form
  1603. for (let i = 0; i < groupScenicList.length; i++) {
  1604. const item = groupScenicList[i]
  1605. const sList = this.groupScenicMap.get(i) || item.scenicId.map(scenicId => {
  1606. return {
  1607. scenicId,
  1608. checkLimitTimes: item.checkLimitTimes,
  1609. singleDayLimitTimes: item.singleDayLimitTimes || -1,
  1610. scenicLimitTimes: item.scenicLimitTimes || -1
  1611. }
  1612. })
  1613. gsList.push(sList)
  1614. }
  1615. this.form.groupScenicList = gsList
  1616. },
  1617. async submit () {
  1618. this.$refs.form.validate(valid => {
  1619. // 会员不检查景点
  1620. const {
  1621. price,
  1622. useDateStart,
  1623. useDateEnd,
  1624. isSaleDateLimit,
  1625. saleDateStart,
  1626. saleDateEnd
  1627. } = this.form
  1628. if (valid) {
  1629. if (isNaN(Number(price)) || price < 0) {
  1630. this.$message.error('请填写销售价格')
  1631. return
  1632. }
  1633. if (moment(useDateStart).isAfter(useDateEnd)) {
  1634. this.$message.error('游玩开始时间不可晚于游玩截止时间')
  1635. return
  1636. }
  1637. if (isSaleDateLimit === 1 && moment(saleDateStart).isAfter(saleDateEnd)) {
  1638. this.$message.error('起售时间不可晚于停售时间')
  1639. return
  1640. }
  1641. if (moment(useDateStart).isAfter(useDateEnd)) {
  1642. this.$message.error('游玩开始时间不可晚于游玩截止时间')
  1643. return
  1644. }
  1645. if (isSaleDateLimit === 1 && moment(saleDateEnd).isAfter(useDateEnd)) {
  1646. this.$message.error('停售时间不可晚于游玩截止时间')
  1647. return
  1648. }
  1649. if (isSaleDateLimit === 1 && moment(saleDateStart).isAfter(useDateStart)) {
  1650. this.$message.error('起售时间不可晚于游玩开始时间')
  1651. return
  1652. }
  1653. // if (category === 'batch') {
  1654. // if (batchConfigList.length === 0) {
  1655. // this.$message.error('请添加场次时间')
  1656. // return
  1657. // }
  1658. // if (batchConfigList.some(item => !item.name)) {
  1659. // this.$message.error('场次名称不能为空')
  1660. // return
  1661. // }
  1662. // if (batchConfigList.some(item => !item.startTime)) {
  1663. // this.$message.error('场次开始时间不能为空')
  1664. // return
  1665. // }
  1666. // if (batchConfigList.some(item => !item.endTime)) {
  1667. // this.$message.error('场次结束时间不能为空')
  1668. // return
  1669. // }
  1670. // }
  1671. if (!this.isScenicValid()) {
  1672. return
  1673. }
  1674. // this.saveAllBatchConfig()
  1675. // if (moment('2019-01-21 ' + this.form.useDateStart).isAfter('2019-01-21 ' + this.form.useDateEnd)) {
  1676. // this.$message.error('当日游玩开始时间不可晚于结束时间')
  1677. // return
  1678. // }
  1679. // this.form.saleDateStart = this.formatStartTime(this.form.saleDateStart)
  1680. // this.form.saleDateEnd = this.formatEndTime(this.form.saleDateEnd)
  1681. // this.form.useDateStart = this.formatStartTime(this.form.useDateStart)
  1682. // this.form.useDateEnd = this.formatEndTime(this.form.useDateEnd)
  1683. // this.form.requiredField = JSON.stringify(this.form.requiredField)
  1684. // form.useDayOfWeek.join is not a function"
  1685. this.form.price = Number(price)
  1686. this.form.useDayOfWeek = this.form.useDayOfWeek?.join(',')
  1687. this.form.checkRule = this.form.checkRule.join(',')
  1688. this.form.checkType = this.form.checkType.join(',')
  1689. this.setGroupScenicConfig()
  1690. switch (this.dialogType) {
  1691. case 'add':
  1692. this.addTicket()
  1693. break
  1694. case 'edit':
  1695. this.updateTicket()
  1696. break
  1697. }
  1698. } else {
  1699. console.log('error submit!!')
  1700. this.$message.error('请补充表单内容')
  1701. return false
  1702. }
  1703. })
  1704. },
  1705. addTicket () {
  1706. this.form.creator = this.$store.state.user.name
  1707. addTicket(this.form).then(res => {
  1708. if (res.code !== '200') {
  1709. this.$message.error(res.msg || '添加失败')
  1710. } else {
  1711. this.$message.success('添加成功')
  1712. this.reset()
  1713. this.handleClose()
  1714. this.$emit('updateList')
  1715. }
  1716. })
  1717. },
  1718. updateTicket () {
  1719. updateTicket(this.form).then(res => {
  1720. if (res.code !== '200') {
  1721. this.$message.error(res.msg || '保存失败')
  1722. } else {
  1723. this.$message.success('保存成功')
  1724. this.reset()
  1725. this.handleClose()
  1726. this.$emit('updateList')
  1727. }
  1728. })
  1729. },
  1730. showInput () {
  1731. this.inputVisible = true
  1732. },
  1733. handleInputConfirm () {
  1734. let inputValue = this.inputValue
  1735. if (inputValue.length) {
  1736. this.form.dateCheckRules.push({ useDateStart: inputValue[0], useDateEnd: inputValue[1] })
  1737. }
  1738. this.inputVisible = false
  1739. this.inputValue = []
  1740. },
  1741. getQueue () {
  1742. queueList({ pageNum: 1, pageSize: 9999 }).then(res => {
  1743. this.queueList = res?.data.list
  1744. })
  1745. },
  1746. formatStartTime (time) {
  1747. return moment(time).hour(0).minute(0).second(0).toDate()
  1748. },
  1749. formatEndTime (time) {
  1750. return moment(time).hour(23).minute(59).second(59).toDate()
  1751. },
  1752. // 从visible的edit那边抄过来的大段代码
  1753. codeCopyFromVisibleEdit () {
  1754. delete this.form.id
  1755. }
  1756. }
  1757. }
  1758. </script>
  1759. <style lang="scss">
  1760. .el-dialog {
  1761. margin-top: 5vh !important;
  1762. .form-wrap .el-input {
  1763. width: auto !important;
  1764. }
  1765. }
  1766. .el-scrollbar__wrap {
  1767. overflow-x: hidden;
  1768. }
  1769. </style>
  1770. <style scoped lang="scss">
  1771. .table-box{
  1772. width: calc(100% - 40px);
  1773. margin-top: 0;
  1774. }
  1775. .el-tag + .el-tag {
  1776. margin-left: 10px;
  1777. }
  1778. .button-new-tag {
  1779. margin-left: 10px;
  1780. height: 32px;
  1781. line-height: 30px;
  1782. padding-top: 0;
  1783. padding-bottom: 0;
  1784. }
  1785. .input-new-tag {
  1786. width: 90px;
  1787. margin-left: 10px;
  1788. vertical-align: bottom;
  1789. }
  1790. </style>