OpAirTicketRes.vue 49 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056
  1. <template>
  2. <div class="car_add">
  3. <div>
  4. <div class="communal-title">
  5. <div>{{ title }}</div>
  6. </div>
  7. </div>
  8. <div style="display: flex;">
  9. <div style="text-align:left;font-size: 17px;font-weight: 600;color: #555;">
  10. 团组成本预算 - 机票的预算:
  11. </div>
  12. <div style="margin-left:20px;color: #555;" v-if="airGroupCostParameter != null">
  13. 经济舱: {{ airGroupCostParameter.jjccb }}元/人 {{ airGroupCostParameter.jjcrs }}人
  14. 共:{{ airGroupCostParameter.jjccb * airGroupCostParameter.jjcrs
  15. }}元&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
  16. 公务舱: {{ airGroupCostParameter.gwccb }}元/人 {{ airGroupCostParameter.gwcrs }}人
  17. 共:{{ airGroupCostParameter.gwccb * airGroupCostParameter.gwcrs
  18. }}元&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
  19. </div>
  20. <div style="margin-left:20px;" v-else>
  21. 团组成本暂未开放此团数据!
  22. </div>
  23. </div>
  24. <hr style='background-color:#5555; height:1px; border:none;' />
  25. <div>
  26. <el-form :model="delegationInfo" label-width="100px" class="demo-ruleForm">
  27. <div style="display: flex;">
  28. <div style="width: 25%;">
  29. <el-form-item label="团组名称:" label-width="160px">
  30. <el-select v-model="DiIdSelect" clearable filterable placeholder="团组选择"
  31. @change="AirTicketResChange" :disabled="isShow" style="width: 100%;">
  32. <el-option v-for="item in AirTicketResSelectData" :key="item.id" :label="item.groupName"
  33. :value="item.id">
  34. </el-option>
  35. </el-select>
  36. </el-form-item>
  37. </div>
  38. <div style="width: 25%;">
  39. <el-form-item label="团 号:" prop="tourCode" label-width="160px">
  40. <el-input placeholder="团号" v-model="delegationInfo.tourCode" :disabled="true">
  41. </el-input>
  42. </el-form-item>
  43. </div>
  44. <div style="width: 25%;">
  45. <el-form-item label="客户:" prop="clientName" label-width="160px">
  46. <el-input placeholder="客户" v-model="delegationInfo.clientName" :disabled="true">
  47. </el-input>
  48. </el-form-item>
  49. </div>
  50. </div>
  51. <div style="display: flex;">
  52. <div style="width: 25%;">
  53. <el-form-item label="出访国家:" prop="visitCountry" label-width="160px">
  54. <el-input placeholder="出访国家" v-model="delegationInfo.visitCountry" :disabled="true">
  55. </el-input>
  56. </el-form-item>
  57. </div>
  58. </div>
  59. </el-form>
  60. <el-form :model="airTicketResOpData" :rules="airTicketResRules" ref="airTicketResOpData" label-width="100px"
  61. class="demo-ruleForm">
  62. <div style="display: flex;">
  63. <div style="width: 25%;">
  64. <el-form-item label="舱类型:" label-width="160px" prop="cType">
  65. <el-select v-model="airTicketResOpData.cType" placeholder="舱类型" style="width: 100%;"
  66. @change="tankTypeChange">
  67. <el-option v-for="item in ticketClass" :key="item.id" :label="item.name" :value="item.id">
  68. </el-option>
  69. </el-select>
  70. </el-form-item>
  71. </div>
  72. <div style="width: 25%;">
  73. <el-form-item label="机票单价:" prop="prePrice" label-width="160px">
  74. <el-input placeholder="机票单价" v-model="airTicketResOpData.prePrice" style="width: 58%;"
  75. @input="peiceinput">
  76. </el-input>
  77. <el-select v-model="airTicketResOpData.preCurrency" style="width: 35%;"
  78. @change="currencyChange">
  79. <el-option key="48" label="CNY" :value="48"></el-option>
  80. <el-option key="49" label="USD" :value="49"></el-option>
  81. <el-option key="51" label="EUR" :value="51"></el-option>
  82. </el-select>
  83. </el-form-item>
  84. </div>
  85. <div style="width: 25%;">
  86. <el-form-item label="机票总价:" prop="price" label-width="160px">
  87. <el-input placeholder="机票总价" v-model="airTicketResOpData.price" style="width: 58%;"
  88. :disabled="true">
  89. </el-input>
  90. <el-select v-model="airTicketResOpData.currency" style="width: 40%;" :disabled="true">
  91. <el-option key="48" label="CNY" :value="48"></el-option>
  92. <el-option key="49" label="USD" :value="49"></el-option>
  93. <el-option key="51" label="EUR" :value="51"></el-option>
  94. </el-select>
  95. </el-form-item>
  96. </div>
  97. </div>
  98. <div style="display: flex;">
  99. <div style="width: 25%;">
  100. <el-form-item label="机票编号:" label-width="160px" prop="ticketNumber">
  101. <el-input placeholder="机票编号" v-model="airTicketResOpData.ticketNumber">
  102. </el-input>
  103. </el-form-item>
  104. </div>
  105. <div style="width: 25%;">
  106. <el-form-item label="机票票号:" label-width="160px" prop="ticketCode">
  107. <el-input placeholder="机票票号" v-model="airTicketResOpData.ticketCode">
  108. </el-input>
  109. </el-form-item>
  110. </div>
  111. </div>
  112. <div style="display: flex;">
  113. <div style="width: 100%;">
  114. <el-form-item label="航班描述:" prop="flightsDescription" label-width="160px">
  115. <el-input type="textarea" :rows="5"
  116. placeholder="请严格遵守此格式!!! 1. EK363 R1 WE08MAR CANDXB HK7 0015 0515 SEAME 2 3 (注意空格以及多条数据换行)"
  117. v-model="airTicketResOpData.flightsDescription" @change="flightsCodeChange"></el-input>
  118. </el-form-item>
  119. </div>
  120. </div>
  121. <div style="display: flex;">
  122. <div style="width: 25%;">
  123. <el-form-item label="航班简述:" label-width="160px" prop="flightsCode">
  124. <el-input placeholder="航班简述" v-model="airTicketResOpData.flightsCode">
  125. </el-input>
  126. </el-form-item>
  127. </div>
  128. <div style="width: 25%;">
  129. <el-form-item label="城 市:" prop="flightsCity" label-width="160px">
  130. <el-input placeholder="城市" v-model="airTicketResOpData.flightsCity">
  131. </el-input>
  132. </el-form-item>
  133. </div>
  134. <div style="width: 25%;">
  135. <el-form-item label="航班日期:" prop="flightsDate" label-width="160px">
  136. <el-date-picker v-model="airTicketResOpData.flightsDate" type="date" placeholder="航班日期">
  137. </el-date-picker>
  138. </el-form-item>
  139. </div>
  140. <div style="width: 25%;">
  141. <el-form-item label="航班时间:" prop="flightsTime" label-width="160px">
  142. <el-time-select v-model="airTicketResOpData.flightsTime" placeholder="航班时间">
  143. </el-time-select>
  144. </el-form-item>
  145. </div>
  146. </div>
  147. <div style="display: flex;">
  148. <div style="width: 25%;">
  149. <el-form-item label="此舱位客人名称:" prop="clientName" label-width="160px">
  150. <el-select v-model="airTicketResOpData.clientName" placeholder="此舱位客人名称" multiple clearable
  151. filterable @change="clientNamechange">
  152. <el-option v-for="item in clientNameId" :key="item.id"
  153. :label="item.pinyin + '(' + item.name + ')'" :value="item.id">
  154. </el-option>
  155. </el-select>
  156. </el-form-item>
  157. </div>
  158. <div style="width: 25%;">
  159. <el-form-item label="此舱位人数:" prop="clientNum" label-width="160px">
  160. <el-input placeholder="此舱位人数" v-model="airTicketResOpData.clientNum" @input="peiceinput">
  161. </el-input>
  162. </el-form-item>
  163. </div>
  164. <div style="width: 25%;">
  165. <el-form-item label="是否值机: " label-width="160px">
  166. <el-radio-group v-model="airTicketResOpData.isCheckIn">
  167. <el-radio :label=1>是</el-radio>
  168. <el-radio :label=0>否</el-radio>
  169. </el-radio-group>
  170. </el-form-item>
  171. </div>
  172. <div style="width: 25%;">
  173. <el-form-item label="是否选座:" label-width="160px">
  174. <el-radio-group v-model="airTicketResOpData.isSetSeat">
  175. <el-radio :label=1>是</el-radio>
  176. <el-radio :label=0>否</el-radio>
  177. </el-radio-group>
  178. </el-form-item>
  179. </div>
  180. </div>
  181. <div style="display: flex;">
  182. <div style="width: 25%;">
  183. <el-form-item label="是否购买行李:" label-width="160px">
  184. <el-radio-group v-model="airTicketResOpData.isPackage">
  185. <el-radio :label=1>是</el-radio>
  186. <el-radio :label=0>否</el-radio>
  187. </el-radio-group>
  188. </el-form-item>
  189. </div>
  190. <div style="width: 25%;">
  191. <el-form-item label="是否行李直挂:" label-width="160px">
  192. <el-radio-group v-model="airTicketResOpData.isBagHandle">
  193. <el-radio :label=1>是</el-radio>
  194. <el-radio :label=0>否</el-radio>
  195. </el-radio-group>
  196. </el-form-item>
  197. </div>
  198. <div style="width: 25%;">
  199. <el-form-item label="是否火车票出票选座:" label-width="160px">
  200. <el-radio-group v-model="airTicketResOpData.isTrain">
  201. <el-radio :label=1>是</el-radio>
  202. <el-radio :label=0>否</el-radio>
  203. </el-radio-group>
  204. </el-form-item>
  205. </div>
  206. </div>
  207. <div style="display: flex;">
  208. </div>
  209. <div style="display: flex;">
  210. <div style="width: 100%;">
  211. <el-form-item label="费用描述:" prop="priceDescription" label-width="160px">
  212. <el-input type="textarea" :rows="3" placeholder="费用描述"
  213. v-model="airTicketResOpData.priceDescription"></el-input>
  214. </el-form-item>
  215. </div>
  216. </div>
  217. <div style="display: flex;">
  218. <div style="width: 100%;">
  219. <el-form-item label="备 注:" prop="Remark" label-width="160px">
  220. <el-input type="textarea" :rows="3" placeholder="备注"
  221. v-model="airTicketResOpData.remark"></el-input>
  222. </el-form-item>
  223. </div>
  224. </div>
  225. </el-form>
  226. <div style="margin-top: 20px;">
  227. <div class="communal-title">付款申请</div>
  228. <hr style='background-color:#5555; height:1px; border:none;margin-top: 10px;' />
  229. </div>
  230. <el-form :model="cardPaymentOpData" ref="cardPaymentOpData" :rules="cardPaymentRules" label-width="130px"
  231. class="demo-ruleForm">
  232. <div style="display: flex;">
  233. <div style="width: 25%;">
  234. <el-form-item label="支付方式:" prop="payDId">
  235. <el-select v-model="cardPaymentOpData.payDId" placeholder="支付方式" style="width: 100%;"
  236. @change="payChange">
  237. <el-option v-for="item in payment" :key="item.id" :label="item.name" :value="item.id">
  238. </el-option>
  239. </el-select>
  240. </el-form-item>
  241. </div>
  242. <div style="width: 25%;">
  243. <el-form-item label="消费方式:" prop="consumptionPatterns">
  244. <el-input placeholder="消费方式" v-model="cardPaymentOpData.consumptionPatterns">
  245. </el-input>
  246. </el-form-item>
  247. </div>
  248. <div style="width: 25%;">
  249. <el-form-item label="消费日期:" prop="visitCountry">
  250. <el-date-picker v-model="cardPaymentOpData.consumptionDate" placeholder="消费日期" type="date">
  251. </el-date-picker>
  252. </el-form-item>
  253. </div>
  254. <div style="width: 25%;">
  255. <el-form-item label="付款金额:" prop="payMoney">
  256. <el-input placeholder="付款金额" v-model="cardPaymentOpData.payMoney" style="width: 52%;"
  257. :disabled="true">
  258. </el-input>
  259. <el-select v-model="cardPaymentOpData.paymentCurrency" style="width: 45%;" :disabled="true">
  260. <el-option key="48" label="CNY" :value="48"></el-option>
  261. <el-option key="49" label="USD" :value="49"></el-option>
  262. <el-option key="51" label="EUR" :value="51"></el-option>
  263. </el-select>
  264. </el-form-item>
  265. </div>
  266. </div>
  267. <div v-if="cardPaymentOpData.payDId == 72">
  268. <div style="display: flex;">
  269. <div style="width: 25%;">
  270. <el-form-item label="卡类型:" prop="ctdId">
  271. <el-select v-model="cardPaymentOpData.ctdId" placeholder="卡类型" style="width: 100%;"
  272. @change="ctdChange">
  273. <el-option v-for="item in cardType" :key="item.id" :label="item.name" :value="item.id">
  274. </el-option>
  275. </el-select>
  276. </el-form-item>
  277. </div>
  278. <div style="width: 25%;">
  279. <el-form-item label="银行卡号:" prop="bankNo">
  280. <el-input placeholder="银行卡号" v-model="cardPaymentOpData.bankNo" :disabled="true">
  281. </el-input>
  282. </el-form-item>
  283. </div>
  284. <div style="width: 25%;">
  285. <el-form-item label="持卡人姓名:" prop="cardholderName">
  286. <el-input placeholder="持卡人姓名" v-model="cardPaymentOpData.cardholderName" :disabled="true">
  287. </el-input>
  288. </el-form-item>
  289. </div>
  290. </div>
  291. </div>
  292. <div v-else-if="cardPaymentOpData.payDId == 73">
  293. <div style="display: flex;">
  294. <div style="width: 25%;">
  295. <el-form-item label="公司银行账号:">
  296. <el-input placeholder="公司银行账号" v-model="cardPaymentOpData.companyBankNo">
  297. </el-input>
  298. </el-form-item>
  299. </div>
  300. <div style="width: 25%;">
  301. <el-form-item label="对方开户行:" prop="otherBankName">
  302. <el-input placeholder="对方开户行:" v-model="cardPaymentOpData.otherBankName">
  303. </el-input>
  304. </el-form-item>
  305. </div>
  306. <div style="width: 25%;">
  307. <el-form-item label="对方银行卡号:" prop="otherSideNo">
  308. <el-input placeholder="对方银行卡号" v-model="cardPaymentOpData.otherSideNo">
  309. </el-input>
  310. </el-form-item>
  311. </div>
  312. <div style="width: 25%;">
  313. <el-form-item label="对方姓名:" prop="otherSideName">
  314. <el-input placeholder="对方姓名" v-model="cardPaymentOpData.otherSideName">
  315. </el-input>
  316. </el-form-item>
  317. </div>
  318. </div>
  319. </div>
  320. <div v-else-if="cardPaymentOpData.payDId == 83">
  321. <div style="display: flex;">
  322. <div style="width: 25%;">
  323. <el-form-item label="对方开户行:" prop="otherBankName">
  324. <el-input placeholder="对方开户行" v-model="cardPaymentOpData.otherBankName">
  325. </el-input>
  326. </el-form-item>
  327. </div>
  328. <div style="width: 25%;">
  329. <el-form-item label="对方银行卡号:" prop="otherSideNo">
  330. <el-input placeholder="对方银行卡号" v-model="cardPaymentOpData.otherSideNo">
  331. </el-input>
  332. </el-form-item>
  333. </div>
  334. <div style="width: 25%;">
  335. <el-form-item label="对方姓名:" prop="otherSideName">
  336. <el-input placeholder="对方姓名" v-model="cardPaymentOpData.otherSideName">
  337. </el-input>
  338. </el-form-item>
  339. </div>
  340. </div>
  341. </div>
  342. <div v-else></div>
  343. <div style="display:flex;">
  344. <div style="width: 25%;">
  345. <el-form-item label="收款方:" prop="payee">
  346. <el-input placeholder="对方姓名:" v-model="cardPaymentOpData.payee">
  347. </el-input>
  348. </el-form-item>
  349. </div>
  350. <div style="width: 25%;">
  351. <el-form-item label="费用标识:" prop="orbitalPrivateTransfer">
  352. <el-select v-model="cardPaymentOpData.orbitalPrivateTransfer" placeholder="费用标识"
  353. style="width: 100%;">
  354. <el-option key="0" label="公转" :value=0>
  355. </el-option>
  356. <el-option key="1" label="私转" :value=1>
  357. </el-option>
  358. </el-select>
  359. </el-form-item>
  360. </div>
  361. <div style="width: 25%;">
  362. <el-form-item label="出票方合作方资料:" prop="visitCountry">
  363. <el-select v-model="airTicketAgentsId" placeholder="出票方合作方资料" style="width: 100%;"
  364. @change="Agents">
  365. <el-option v-for="item in airTicketAgents" :key="item.id" :label="item.name"
  366. :value="item.id">
  367. </el-option>
  368. </el-select>
  369. </el-form-item>
  370. </div>
  371. </div>
  372. <div style="display: flex;">
  373. <div style="width: 100%;">
  374. <el-form-item label="备 注:" prop="Remark">
  375. <el-input type="textarea" :rows="5" placeholder="备注"
  376. v-model="cardPaymentOpData.remark"></el-input>
  377. </el-form-item>
  378. </div>
  379. </div>
  380. <el-form-item>
  381. <div style="margin-left: 60%;">
  382. <el-button type="primary" @click="addBtn">保存</el-button>
  383. <router-link to='/home/AirTicketRes'>
  384. <el-button>取消</el-button>
  385. </router-link>
  386. </div>
  387. </el-form-item>
  388. </el-form>
  389. </div>
  390. </div>
  391. </template>
  392. <script>
  393. export default {
  394. data() {
  395. return {
  396. airTicketResRules: {
  397. cType: [
  398. { required: true, message: '请选择舱位类型', trigger: ['blur', 'change'] }
  399. ],
  400. prePrice: [
  401. { required: true, message: '请输入机票单价', trigger: ['blur', 'change'] },
  402. { pattern: /^(([1-9]?\d{0,8}(\.\d{1,2})?)|999999999|999999999\.(0){1,2})$/, message: '请输入正确的金额(最多2位小数)' }
  403. ],
  404. clientNum: [
  405. { required: true, message: '请输入舱位人数', trigger: ['blur', 'change'] },
  406. ],
  407. flightsCode: [
  408. { required: true, message: '请输入航班描述', trigger: ['blur', 'change'] },
  409. ],
  410. flightsCity: [
  411. { required: true, message: '请输入城市', trigger: ['blur', 'change'] },
  412. ],
  413. clientName: [
  414. { type: "array", required: true, message: '请选择责任人', trigger: ['blur', ['blur', 'change']] }
  415. ],
  416. flightsDescription: [
  417. { required: true, message: '请严格遵守格式,正确填写', trigger: ['blur', 'change'] },
  418. ],
  419. },
  420. cardPaymentRules: {
  421. payDId: [
  422. { required: true, message: '请选择支付方式', trigger: ['blur', 'change'] },
  423. ],
  424. consumptionPatterns: [
  425. { required: true, message: '请输入消费方式', trigger: ['blur', 'change'] },
  426. ],
  427. payee: [
  428. { required: true, message: '请输入收款方', trigger: ['blur', 'change'] },
  429. ],
  430. orbitalPrivateTransfer: [
  431. { required: true, message: '请选择费用表示', trigger: ['blur', 'change'] },
  432. ],
  433. // ctdId: [
  434. // { required: true, message: '请选择卡类型', trigger: ['blur', 'change'] },
  435. // ]
  436. },
  437. title: "新增机票费用录入",
  438. token: '',
  439. userId: 0,
  440. id: '',
  441. DiId: '',
  442. isShow: false,
  443. DiIdSelect: '',
  444. delegationInfo: {},
  445. AirTicketResSelectData: [],//团组下拉框
  446. ticketClass: [],//舱位下拉框
  447. payment: [],//支付方式下拉框
  448. cardType: [],//卡类型下拉框
  449. airTicketAgents: [],//合作的代理资料
  450. airTicketAgentsId: '',
  451. clientNameId: [],//客人姓名
  452. clientNameList: [],
  453. airGroupCostParameter: {},//机票成本预算
  454. status: 0,
  455. airTicketResOpData: {
  456. id: 0,
  457. diId: 0,
  458. cType: 460,
  459. prePrice: 0,
  460. preCurrency: 48,
  461. price: 0,
  462. currency: 48,
  463. clientNum: 0,
  464. clientName: [],
  465. isCheckIn: 0,
  466. isSetSeat: 0,
  467. isPackage: 0,
  468. isBagHandle: 0,
  469. isTrain: 0,
  470. flightsCode: '',
  471. flightsDate: '',
  472. flightsTime: '',
  473. flightsCity: '',
  474. flightsDescription: '',
  475. priceDescription: '',
  476. ticketNumber: '',
  477. ticketCode: '',
  478. createUserId: 0,
  479. remark: ''
  480. },
  481. cardPaymentOpData: {
  482. id: 0,
  483. payDId: 72,
  484. consumptionPatterns: '',
  485. consumptionDate: this.transformDateFormat(new Date()),
  486. ctdId: '',
  487. bankNo: '',
  488. cardholderName: 'Zhang Hailin',
  489. payMoney: 0,
  490. paymentCurrency: 48,
  491. companyBankNo: '',
  492. otherBankName: '',
  493. otherSideNo: '',
  494. otherSideName: '',
  495. mfOperator: 0,
  496. mfOperatorDate: this.transformDateFormat(new Date()),
  497. diId: this.DiId,
  498. payThenMoney: 0,
  499. payee: '',
  500. createUserId: 0,
  501. orbitalPrivateTransfer: '',
  502. remark: ''
  503. },
  504. IsAuditGM: 0,
  505. }
  506. },
  507. methods: {
  508. clientNamechange(val) {
  509. console.log(val.length)
  510. this.airTicketResOpData.clientNum = val.length;
  511. this.cardPaymentOpData.payMoney = parseFloat(parseFloat(this.airTicketResOpData.prePrice) * parseFloat(this.airTicketResOpData.clientNum)).toFixed(2)
  512. this.cardPaymentOpData.payThenMoney = this.cardPaymentOpData.payMoney
  513. this.airTicketResOpData.price = parseFloat(parseFloat(this.airTicketResOpData.prePrice) * parseFloat(this.airTicketResOpData.clientNum)).toFixed(2)
  514. },
  515. //团组下拉框
  516. AirTicketResSelect() {
  517. var url = "/api/Groups/AirTicketResSelect"
  518. var that = this
  519. this.$axios({
  520. method: 'post',
  521. url: url,
  522. headers: {
  523. Authorization: 'Bearer ' + this.token
  524. },
  525. data: {
  526. userId: that.userId
  527. }
  528. }).then(function (res) {
  529. if (res.data.code == 200) {
  530. that.AirTicketResSelectData = res.data.data.groupName;
  531. that.ticketClass = res.data.data.ticketClass;//舱位下拉框
  532. that.payment = res.data.data.payment;//支付方式下拉框
  533. that.cardType = res.data.data.cardType;//卡类型下拉框
  534. that.airTicketAgents = res.data.data.airTicketAgents//合作方资料下拉框
  535. that.DiIdSelect = parseInt(that.DiId)
  536. that.QueryTankType();
  537. }
  538. })
  539. },
  540. AirTicketResChange() {
  541. this.AirTicketResList();
  542. },
  543. AirTicketResList() {
  544. var url = "/api/Groups/AirTicketResList"
  545. var that = this
  546. this.$axios({
  547. method: 'post',
  548. url: url,
  549. headers: {
  550. Authorization: 'Bearer ' + this.token
  551. },
  552. data: {
  553. userId: that.userId,
  554. portType: 1,
  555. diId: that.DiIdSelect
  556. }
  557. }).then(function (res) {
  558. if (res.data.code == 200) {
  559. that.delegationInfo = res.data.data.delegationInfo
  560. that.airGroupCostParameter = res.data.data.airGroupCostParameter
  561. }
  562. })
  563. },
  564. QueryTankType() {
  565. var url = "/api/Groups/tankType"
  566. var that = this
  567. this.$axios({
  568. method: 'post',
  569. url: url,
  570. headers: {
  571. Authorization: 'Bearer ' + that.token
  572. },
  573. data: {
  574. id: that.airTicketResOpData.cType
  575. }
  576. }).then(function (res) {
  577. if (res.data.code == 200) {
  578. that.clientNameId = res.data.data
  579. that.AirTicketResList()
  580. }
  581. })
  582. },
  583. tankTypeChange() {
  584. this.QueryTankType();
  585. },
  586. //点击保存事件
  587. addBtn() {
  588. if (this.IsAuditGM == 1) {
  589. var ss = this.airTicketResOpData.clientName.split(',')
  590. this.airTicketResOpData.clientName = [];
  591. ss.forEach(function (item) {
  592. that.airTicketResOpData.clientName.push(parseInt(item))
  593. });
  594. this.$message.error('审核已通过,不可修改!');
  595. } else {
  596. if (this.DiId == null && this.DiId == undefined && this.DiId == "") {
  597. this.$message.error("请选择团组名称");
  598. var ss = this.airTicketResOpData.clientName.split(',')
  599. this.airTicketResOpData.clientName = [];
  600. ss.forEach(function (item) {
  601. that.airTicketResOpData.clientName.push(parseInt(item))
  602. });
  603. return;
  604. }
  605. const that = this;
  606. let formArr = ['airTicketResOpData', 'cardPaymentOpData']//三个form表单的ref
  607. var resultArr = [] //用来接受返回结果的数组
  608. function checkForm(formName) { //封装验证表单的函数
  609. var result = new Promise(function (resolve, reject) {
  610. that.$refs[formName].validate((valid) => {
  611. if (valid) {
  612. resolve();
  613. } else { reject() }
  614. })
  615. })
  616. resultArr.push(result) //push 得到promise的结果
  617. }
  618. formArr.forEach(item => { //根据表单的ref校验
  619. checkForm(item)
  620. })
  621. Promise.all(resultArr).then(values => {
  622. that.airTicketResOpData.diId = parseInt(that.DiId);
  623. that.airTicketResOpData.createUserId = that.userId;
  624. var clientNameStr = ''
  625. that.airTicketResOpData.clientName.forEach(function (item) {
  626. clientNameStr += item + ","
  627. });
  628. that.airTicketResOpData.clientName = clientNameStr.substring(0, clientNameStr.length - 1)
  629. that.cardPaymentOpData.createUserId = that.userId;
  630. that.cardPaymentOpData.diId = parseInt(that.DiId);
  631. if (that.cardPaymentOpData.ctdId == '') {
  632. that.cardPaymentOpData.ctdId = 0;
  633. }
  634. var url = "/api/Groups/OpAirTicketRes"
  635. that.$axios({
  636. method: 'post',
  637. url: url,
  638. headers: {
  639. Authorization: 'Bearer ' + that.token
  640. },
  641. data: {
  642. status: that.status,
  643. airTicketResOpData: that.airTicketResOpData,
  644. cardPaymentOpData: that.cardPaymentOpData
  645. }
  646. }).then(function (res) {
  647. if (res.data.code == 200) {
  648. that.$message({
  649. message: res.data.msg,
  650. type: 'success'
  651. });
  652. that.loading = true;
  653. var ss = that.airTicketResOpData.clientName.split(',')
  654. that.airTicketResOpData.clientName = [];
  655. ss.forEach(function (item) {
  656. that.airTicketResOpData.clientName.push(parseInt(item))
  657. });
  658. setTimeout(() => {
  659. that.$router.push('/home/AirTicketRes')
  660. }, 3000);
  661. } else {
  662. var ss = that.airTicketResOpData.clientName.split(',')
  663. that.airTicketResOpData.clientName = [];
  664. ss.forEach(function (item) {
  665. that.airTicketResOpData.clientName.push(parseInt(item))
  666. });
  667. that.$message.error(res.data.msg);
  668. }
  669. }).catch(function (error) {
  670. console.log(error)
  671. })// 此时必填完成,做保存后的业务操作
  672. }).catch(_ => {
  673. var ss = this.airTicketResOpData.clientName.split(',')
  674. this.airTicketResOpData.clientName = [];
  675. ss.forEach(function (item) {
  676. that.airTicketResOpData.clientName.push(parseInt(item))
  677. });
  678. this.$message.error('请完善信息在保存!');
  679. return false;
  680. })
  681. }
  682. },
  683. //根据机票费用录入Id查询c表和机票费用信息
  684. AirTicketResById() {
  685. var url = "/api/Groups/AirTicketResById"
  686. var that = this
  687. this.$axios({
  688. method: 'post',
  689. url: url,
  690. headers: {
  691. Authorization: 'Bearer ' + this.token
  692. },
  693. data: {
  694. id: this.id
  695. }
  696. }).then(function (res) {
  697. if (res.data.code == 200) {
  698. var airData = res.data.data.airTicket
  699. that.airTicketResOpData.id = airData.id
  700. that.airTicketResOpData.diId = airData.diId
  701. that.airTicketResOpData.cType = airData.cType
  702. that.airTicketResOpData.prePrice = airData.prePrice
  703. that.airTicketResOpData.preCurrency = airData.preCurrency
  704. that.airTicketResOpData.price = airData.price
  705. that.airTicketResOpData.currency = airData.currency
  706. that.airTicketResOpData.clientNum = airData.clientNum
  707. that.airTicketResOpData.isCheckIn = airData.isCheckIn
  708. that.airTicketResOpData.isSetSeat = airData.isSetSeat
  709. that.airTicketResOpData.isPackage = airData.isPackage
  710. that.airTicketResOpData.isBagHandle = airData.isBagHandle
  711. that.airTicketResOpData.isTrain = airData.isTrain
  712. that.airTicketResOpData.flightsCode = airData.flightsCode
  713. that.airTicketResOpData.flightsDate = airData.flightsDate
  714. that.airTicketResOpData.flightsTime = airData.flightsTime
  715. that.airTicketResOpData.flightsCity = airData.flightsCity
  716. that.airTicketResOpData.flightsDescription = airData.flightsDescription
  717. that.airTicketResOpData.priceDescription = airData.priceDescription
  718. that.airTicketResOpData.ticketNumber = airData.ticketNumber
  719. that.airTicketResOpData.ticketCode = airData.ticketCode
  720. that.airTicketResOpData.createUserId = airData.createUserId
  721. that.airTicketResOpData.remark = airData.remark
  722. var ss = airData.clientName.split(',')
  723. that.airTicketResOpData.clientName = [];
  724. ss.forEach(function (item) {
  725. that.airTicketResOpData.clientName.push(parseInt(item))
  726. });
  727. that.prePrice = res.data.data.airTicket.prePrice
  728. that.currencyId = res.data.data.airTicket.preCurrency
  729. that.clientNum = res.data.data.airTicket.clientNum
  730. var creData = res.data.data.creditCard;
  731. that.cardPaymentOpData.id = creData.id
  732. that.cardPaymentOpData.payDId = creData.payDId
  733. that.cardPaymentOpData.consumptionPatterns = creData.consumptionPatterns
  734. that.cardPaymentOpData.consumptionDate = creData.consumptionDate
  735. that.cardPaymentOpData.bankNo = creData.bankNo
  736. that.cardPaymentOpData.cardholderName = creData.cardholderName
  737. that.cardPaymentOpData.payMoney = creData.payMoney
  738. that.cardPaymentOpData.paymentCurrency = creData.paymentCurrency
  739. that.cardPaymentOpData.companyBankNo = creData.companyBankNo
  740. that.cardPaymentOpData.otherBankName = creData.otherBankName
  741. that.cardPaymentOpData.otherSideNo = creData.otherSideNo
  742. that.cardPaymentOpData.otherSideName = creData.otherSideName
  743. that.cardPaymentOpData.mfOperator = creData.mfOperator
  744. that.cardPaymentOpData.mfOperatorDate = creData.mfOperatorDate
  745. that.cardPaymentOpData.diId = creData.diId
  746. that.cardPaymentOpData.payThenMoney = creData.payThenMoney
  747. that.cardPaymentOpData.payee = creData.payee
  748. that.cardPaymentOpData.createUserId = creData.createUserId
  749. that.cardPaymentOpData.orbitalPrivateTransfer = creData.orbitalPrivateTransfer
  750. that.cardPaymentOpData.remark = creData.remark
  751. that.IsAuditGM = creData.isAuditGM
  752. if (creData.ctdId == 0) {
  753. that.cardPaymentOpData.ctdId = ""
  754. } else {
  755. that.cardPaymentOpData.ctdId = parseInt(creData.ctdId)
  756. }
  757. that.cardPaymentOpData.orbitalPrivateTransfer = parseInt(creData.orbitalPrivateTransfer)
  758. }
  759. })
  760. },
  761. //支付方式change事件
  762. payChange() {
  763. this.cardPaymentOpData.ctdId = '';
  764. this.cardPaymentOpData.bankNo = '';
  765. this.cardPaymentOpData.cardholderName = 'Zhang Hailin';
  766. this.cardPaymentOpData.companyBankNo = '';
  767. this.cardPaymentOpData.otherBankName = '';
  768. this.cardPaymentOpData.otherSideNo = '';
  769. this.cardPaymentOpData.otherSideName = '';
  770. this.cardPaymentOpData.mfOperator = '';
  771. this.cardPaymentOpData.payee = '';
  772. this.cardPaymentOpData.orbitalPrivateTransfer = '';
  773. this.cardPaymentOpData.remark = ''
  774. },
  775. //合作方下拉选择事件
  776. Agents(Id) {
  777. for (var i = 0; i < this.airTicketAgents.length; i++) {
  778. if (this.airTicketAgents[i].id == parseInt(Id)) {
  779. this.cardPaymentOpData.payee = this.airTicketAgents[i].name
  780. this.cardPaymentOpData.otherBankName = this.airTicketAgents[i].bank
  781. this.cardPaymentOpData.otherSideNo = this.airTicketAgents[i].account
  782. }
  783. }
  784. },
  785. //卡类型选择事件
  786. ctdChange(id) {
  787. this.airTicketAgentsId = '';
  788. for (var i = 0; i < this.cardType.length; i++) {
  789. if (this.cardType[i].id == parseInt(id)) {
  790. this.cardPaymentOpData.bankNo = this.cardType[i].remark
  791. }
  792. }
  793. },
  794. //单价值改变事件
  795. peiceinput() {
  796. this.cardPaymentOpData.payMoney = parseFloat(parseFloat(this.airTicketResOpData.prePrice) * parseFloat(this.airTicketResOpData.clientNum)).toFixed(2)
  797. this.cardPaymentOpData.payThenMoney = this.cardPaymentOpData.payMoney
  798. this.airTicketResOpData.price = parseFloat(parseFloat(this.airTicketResOpData.prePrice) * parseFloat(this.airTicketResOpData.clientNum)).toFixed(2)
  799. },
  800. currencyChange(Id) {
  801. this.cardPaymentOpData.paymentCurrency = Id;
  802. this.airTicketResOpData.preCurrency = Id;
  803. this.airTicketResOpData.currency = Id;
  804. },
  805. //航班描述值改变事件
  806. flightsCodeChange(val) {
  807. var reg = /[\r\n]+/g;
  808. var that = this;
  809. that.airTicketResOpData.flightsCode = ''
  810. that.airTicketResOpData.flightsCity = ''
  811. var dateTime = [];
  812. if (reg.test(val)) {
  813. var attrsList = val.split(reg)
  814. attrsList.forEach(function (item, index) {
  815. var ss = item.split(' ')
  816. for (var i = 0; i < ss.length; i++) {
  817. ss[i] = ss[i].trim();
  818. if (!ss[i]) {
  819. ss.splice(i, 1);
  820. i--;
  821. }
  822. }
  823. ss = ss;
  824. that.airTicketResOpData.flightsCode += ss[1] + '/'//航班号
  825. that.airTicketResOpData.flightsCity += ss[4].substring(0, 3) + '-' + ss[4].substring(3) + '/'//城市
  826. var dateStr = ss[3].substring(4)
  827. switch (dateStr) {
  828. case "JAN":
  829. dateStr = "01";
  830. break;
  831. case "FEB":
  832. dateStr = "02";
  833. break;
  834. case "MAR":
  835. dateStr = "03";
  836. break;
  837. case "APR":
  838. dateStr = "04";
  839. break;
  840. case "MAY":
  841. dateStr = "05";
  842. break;
  843. case "JUN":
  844. dateStr = "06";
  845. break;
  846. case "JUL":
  847. dateStr = "07";
  848. break;
  849. case "AUG":
  850. dateStr = "08";
  851. break;
  852. case "SEP":
  853. dateStr = "09";
  854. break;
  855. case "OCT":
  856. dateStr = "10";
  857. break;
  858. case "NOV":
  859. dateStr = "11";
  860. break;
  861. case "DEC":
  862. dateStr = "12";
  863. break;
  864. }
  865. dateTime.push({
  866. date: new Date(new Date().getFullYear() + '-' + dateStr + '-' + ss[3].substring(2, 4)),
  867. time: ss[6].substring(0, 2) + ':' + ss[6].substring(2)
  868. })//日期
  869. });
  870. that.airTicketResOpData.flightsCode = that.airTicketResOpData.flightsCode.substring(0, that.airTicketResOpData.flightsCode.length - 1)//航班号
  871. that.airTicketResOpData.flightsCity = that.airTicketResOpData.flightsCity.substring(0, that.airTicketResOpData.flightsCity.length - 1)//城市
  872. var compare = function (obj1, obj2) {
  873. var val1 = obj1.date;
  874. var val2 = obj2.date;
  875. if (val1 < val2) {
  876. return -1;
  877. } else if (val1 > val2) {
  878. return 1;
  879. } else {
  880. return 0;
  881. }
  882. }
  883. debugger
  884. dateTime = dateTime.sort(compare);
  885. that.airTicketResOpData.flightsTime = dateTime[0].time
  886. that.airTicketResOpData.flightsDate = dateTime[0].date
  887. } else {
  888. var ss = val.split(' ')
  889. for (var i = 0; i < ss.length; i++) {
  890. ss[i] = ss[i].trim();
  891. if (!ss[i]) {
  892. ss.splice(i, 1);
  893. i--;
  894. }
  895. }
  896. ss = ss;
  897. that.airTicketResOpData.flightsCode = ss[1]//航班号
  898. that.airTicketResOpData.flightsCity += ss[4].substring(0, 3) + '-' + ss[4].substring(3)//城市
  899. that.airTicketResOpData.flightsTime = ss[6].substring(0, 2) + ':' + ss[6].substring(2)//时间
  900. var dateStr = ss[3].substring(4)
  901. switch (dateStr) {
  902. case "JAN":
  903. dateStr = "01";
  904. break;
  905. case "FEB":
  906. dateStr = "02";
  907. break;
  908. case "MAR":
  909. dateStr = "03";
  910. break;
  911. case "APR":
  912. dateStr = "04";
  913. break;
  914. case "MAY":
  915. dateStr = "05";
  916. break;
  917. case "JUN":
  918. dateStr = "06";
  919. break;
  920. case "JUL":
  921. dateStr = "07";
  922. break;
  923. case "AUG":
  924. dateStr = "08";
  925. break;
  926. case "SEP":
  927. dateStr = "09";
  928. break;
  929. case "OCT":
  930. dateStr = "10";
  931. break;
  932. case "NOV":
  933. dateStr = "11";
  934. break;
  935. case "DEC":
  936. dateStr = "12";
  937. break;
  938. }
  939. that.airTicketResOpData.flightsDate = new Date().getFullYear() + '-' + dateStr + '-' + ss[3].substring(2, 4)
  940. }
  941. },
  942. },
  943. mounted() {
  944. this.token = JSON.parse(localStorage.getItem('userinif')).token;
  945. this.userId = JSON.parse(localStorage.getItem('userinif')).userInfo.userId
  946. this.id = this.$route.query.id
  947. this.DiId = this.$route.query.DiId
  948. this.AirTicketResSelect()
  949. var that = this
  950. if (that.DiId != undefined && that.id != undefined) {
  951. that.status = 2;
  952. that.isShow = true
  953. that.AirTicketResById();
  954. } else {
  955. that.isShow = false
  956. that.status = 1;
  957. }
  958. }
  959. }
  960. </script>
  961. <style>
  962. .communal-list {
  963. background-color: #fff;
  964. padding: 10px;
  965. box-shadow: 0 0 5px #0005;
  966. border-radius: 10px;
  967. }
  968. .car_add .communal-title {
  969. display: flex;
  970. font-size: 17px;
  971. font-weight: 600;
  972. color: #555;
  973. margin-bottom: 20px;
  974. justify-content: space-between;
  975. align-items: center;
  976. }
  977. .appraise-box {
  978. display: flex;
  979. flex-wrap: wrap;
  980. justify-content: space-between;
  981. margin: 50px 0;
  982. }
  983. .appraise-box>div {
  984. width: 30%;
  985. }
  986. .communal-box {
  987. display: flex;
  988. }
  989. .communal-box>button {
  990. margin-left: 10px;
  991. padding: 8px 20px;
  992. }
  993. .car_add {
  994. background-color: #fff;
  995. padding: 20px;
  996. box-shadow: 0 0 5px #0005;
  997. border-radius: 10px;
  998. }
  999. @media screen and (max-width: 1700px) {
  1000. .appraise-box>div {
  1001. width: 48%;
  1002. }
  1003. .appraise-box>div el-form-item__content {
  1004. width: 260px !important;
  1005. }
  1006. }
  1007. </style>