TransportationExpenseStandard.vue 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593
  1. <template>
  2. <div>
  3. <div class="standards-all">
  4. <div class="standards-head">
  5. <div class="standards-head-li">
  6. <div>
  7. <label>搜索:</label>
  8. <el-input style="width: 220px;margin-left: 10px;" v-model="input" placeholder="请输入内容"></el-input>
  9. <el-button @click="OverseaVehicleList" type="primary">搜 索</el-button>
  10. </div>
  11. </div>
  12. <div class="standards-head-li">
  13. <!-- <el-button type="primary">查 询</el-button> -->
  14. <el-button @click="addclick('新增')" type="primary">新 增</el-button>
  15. </div>
  16. </div>
  17. <div class="standards-table">
  18. <el-table
  19. :data="tableData"
  20. border
  21. style="width: 100%">
  22. <el-table-column
  23. type="index"
  24. label="序号"
  25. width="55">
  26. </el-table-column>
  27. <el-table-column
  28. prop="continentName"
  29. label="洲"
  30. width="80">
  31. </el-table-column>
  32. <el-table-column
  33. prop="countryName"
  34. label="国家/地区"
  35. width="100">
  36. </el-table-column>
  37. <el-table-column
  38. prop="cityName"
  39. label="城市"
  40. width="180">
  41. </el-table-column>
  42. <el-table-column
  43. prop="currency"
  44. label="币种"
  45. width="80">
  46. </el-table-column>
  47. <el-table-column
  48. prop="guidePrice"
  49. label="导游费用"
  50. width="120">
  51. </el-table-column>
  52. <el-table-column
  53. prop="otherPrice1"
  54. label="举牌接机"
  55. width="120">
  56. </el-table-column>
  57. <el-table-column
  58. prop="otherPrice2"
  59. label="送机协助值机"
  60. width="120">
  61. </el-table-column>
  62. <el-table-column
  63. prop="otherPrice3"
  64. label="其他费用"
  65. width="120">
  66. </el-table-column>
  67. <el-table-column
  68. prop="lastUpdateUserName"
  69. label="最后操作人"
  70. width="100">
  71. </el-table-column>
  72. <el-table-column
  73. prop="lastUpdateTime"
  74. label="最后操作时间"
  75. width="180">
  76. </el-table-column>
  77. <el-table-column
  78. prop="remark"
  79. label="备注"
  80. >
  81. </el-table-column>
  82. <el-table-column
  83. prop="address"
  84. label="操作"
  85. width="125">
  86. <template slot-scope="scope">
  87. <el-button
  88. @click.native.prevent="addclick('修改', scope.row)"
  89. size="mini">
  90. 修 改
  91. </el-button>
  92. <el-button
  93. style="margin-left: 0px;margin-top: 4px;"
  94. @click.native.prevent="deleteRow(scope.$index, tableData,scope.row)"
  95. type="danger"
  96. size="mini">
  97. 移 除
  98. </el-button>
  99. </template>
  100. </el-table-column>
  101. </el-table>
  102. <div class="block">
  103. <el-pagination
  104. @size-change="handleSizeChange"
  105. @current-change="handleCurrentChange"
  106. :current-page="currentPage4"
  107. :page-sizes="[14, 10, 18, 22]"
  108. :page-size="100"
  109. layout="total, sizes, prev, pager, next, jumper"
  110. :total="count">
  111. </el-pagination>
  112. </div>
  113. </div>
  114. <el-dialog :close-on-click-modal="false" width="1315px" title="编辑三公费用标准" :visible.sync="AdditionalFees">
  115. <el-form :model="addfees" ref="addfees" :rules="addfeesrules">
  116. <div class="standards-inif">
  117. <el-form-item label="洲" prop="continent" :label-width="formLabelWidth">
  118. <el-input size="medium" :controls="false" v-model="addfees.continent"></el-input>
  119. </el-form-item>
  120. <el-form-item label="国家" prop="country" :label-width="formLabelWidth">
  121. <el-input size="medium" :controls="false" v-model="addfees.country"></el-input>
  122. </el-form-item>
  123. <el-form-item label="城市" prop="city" :label-width="formLabelWidth">
  124. <el-input size="medium" :controls="false" v-model="addfees.city"></el-input>
  125. </el-form-item>
  126. <el-form-item label="币种" prop="currency" :label-width="formLabelWidth">
  127. <el-select size="medium" style="height:36px"
  128. v-model="addfees.currency" filterable placeholder="请选择">
  129. <el-option v-for="item in currencyDatas" :key="item.id" :label="item.name" :value="item.id">
  130. </el-option>
  131. </el-select>
  132. </el-form-item>
  133. <el-form-item label="导游费用" prop="roomCost" :label-width="formLabelWidth">
  134. <el-input-number :precision="2" size="medium" :controls="false" v-model="addfees.guidePrice"></el-input-number>
  135. </el-form-item>
  136. <el-form-item label="举牌接机" prop="foodCost" :label-width="formLabelWidth">
  137. <el-input-number :precision="2" size="medium" :controls="false" v-model="addfees.otherPrice1"></el-input-number>
  138. </el-form-item>
  139. <el-form-item label="送机协助值机" prop="publicCost" :label-width="formLabelWidth">
  140. <el-input-number :precision="2" size="medium" :controls="false" v-model="addfees.otherPrice2"></el-input-number>
  141. </el-form-item>
  142. <el-form-item label="其他费用" prop="trainCost" :label-width="formLabelWidth">
  143. <el-input-number :precision="2" size="medium" :controls="false" v-model="addfees.otherPrice3"></el-input-number>
  144. </el-form-item>
  145. </div>
  146. <div class="remark-box">
  147. <el-form-item label="备注" :label-width="formLabelWidth">
  148. <el-input :rows="2" type="textarea" v-model="addfees.remark"></el-input>
  149. </el-form-item>
  150. </div>
  151. <div>
  152. <div style="display: flex;align-items: center;justify-content: space-between;margin-bottom: 5px;">
  153. <label style="font-weight: 600;">具体车型</label>
  154. <el-button @click="caraddYH" size="mini" type="primary">添 加</el-button>
  155. </div>
  156. <el-table border :data="addfees.carInfos">
  157. <el-table-column label="车型名称" width="200">
  158. <template slot-scope="scope">
  159. <el-input size="mini" :controls="false" v-model="scope.row.carTypeName"></el-input>
  160. </template>
  161. </el-table-column>
  162. <el-table-column label="服务类型" width="180">
  163. <template slot-scope="scope ">
  164. <el-select size="mini" v-model="scope.row.serviceType" filterable
  165. placeholder="请选择">
  166. <el-option v-for="item in serviceTypeDatas" :key="item.value" :label="item.text"
  167. :value="item.value">
  168. </el-option>
  169. </el-select>
  170. </template>
  171. </el-table-column>
  172. <el-table-column label="价格" width="180">
  173. <template slot-scope="scope ">
  174. <el-input-number style="width:100%" size="mini" :precision="2" :controls="false" v-model="scope.row.price"></el-input-number>
  175. </template>
  176. </el-table-column>
  177. <el-table-column label="备注">
  178. <template slot-scope="scope">
  179. <el-input size="mini" :rows="1" type="textarea" v-model="scope.row.remark"></el-input>
  180. </template>
  181. </el-table-column>
  182. <el-table-column label="操作" width="100">
  183. <template slot-scope="scope">
  184. <el-button size="mini"
  185. @click.native.prevent="carRemove(scope.$index, addfees.carInfos, scope.row)"
  186. type="danger">移除</el-button>
  187. </template>
  188. </el-table-column>
  189. </el-table>
  190. </div>
  191. </el-form>
  192. <div slot="footer" class="dialog-footer">
  193. <el-button type="primary" @click="addsbtn('addfees')">保 存</el-button>
  194. <el-button @click="AdditionalFees = false">取 消</el-button>
  195. </div>
  196. </el-dialog>
  197. </div>
  198. </div>
  199. </template>
  200. <script>
  201. import { el } from '@fullcalendar/core/internal-common'
  202. export default {
  203. data() {
  204. return {
  205. loginuserid:'',
  206. input:'',
  207. tableData: [],
  208. currentPage4: 1,
  209. count:0,
  210. pageSize:14,
  211. pageIndex:1,
  212. AdditionalFees:false,
  213. //新增
  214. addfees:{
  215. id:0,
  216. continent:'',//洲
  217. country:'', //国家
  218. city:'',//城市
  219. currency:807,//币种
  220. guidePrice:0,//导游费用
  221. otherPrice1:0,//举牌接机
  222. otherPrice2:0,//送机协助值机
  223. otherPrice3:0,//其他费用
  224. remark:'',//备注
  225. carInfos:[
  226. {
  227. carTypeName:'',
  228. serviceType:'',
  229. price:'',
  230. id:0,
  231. remark:''
  232. }
  233. ]
  234. },
  235. formLabelWidth:'100px',
  236. addfeesrules:{
  237. continent: [
  238. { required: true, trigger: 'change',message:'请填写洲' }
  239. ],
  240. country: [
  241. {required: true, trigger: 'change',message:'请填写国家' }
  242. ],
  243. city: [
  244. { required: true, trigger: 'change',message:'请填写城市' }
  245. ],
  246. currency: [
  247. { required: true, trigger: 'blur',message:'请选择币种' }
  248. ],
  249. guidePrice: [
  250. { required: true, trigger: 'change' ,message:'请填写导游费用'},
  251. ],
  252. otherPrice1: [
  253. { required: true, trigger: 'change',message:'请填写举牌接机' },
  254. ],
  255. otherPrice2: [
  256. { required: true, trigger: 'change',message:'请填写送机协助值机' },
  257. ],
  258. otherPrice3: [
  259. { required: true, trigger: 'change',message:'请填写其他费用' },
  260. ],
  261. },
  262. serviceTypeDatas:[],
  263. currencyDatas:[]
  264. }
  265. },
  266. methods:{
  267. //获取基础数据
  268. OverseaVehicleInit(){
  269. var url = "/api/Resource/OverseaVehicleInit"
  270. var that = this
  271. this.$axios({
  272. method: 'get',
  273. url: url,
  274. headers: {
  275. Authorization: 'Bearer ' + this.token
  276. },
  277. }).then(function (res) {
  278. that.serviceTypeDatas=[];
  279. that.currencyDatas=[];
  280. if(res.data.code==200){
  281. that.serviceTypeDatas= res.data.data.serviceTypeDatas;
  282. that.currencyDatas= res.data.data.currencyDatas;
  283. }
  284. })
  285. },
  286. //添加具体车型
  287. caraddYH(){
  288. this.addfees.carInfos.push({
  289. carTypeName:'',
  290. serviceType:'',
  291. price:'',
  292. id:0,
  293. remark:''
  294. })
  295. },
  296. //移除具体车型
  297. carRemove(index, rows,inif){
  298. rows.splice(index, 1)
  299. },
  300. //获取标准列表
  301. OverseaVehicleList(){
  302. var url = "/api/Resource/OverseaVehicleList"
  303. var that = this
  304. this.$axios({
  305. method: 'post',
  306. url: url,
  307. headers: {
  308. Authorization: 'Bearer ' + this.token
  309. },
  310. data:{
  311. portType: 1,
  312. pageIndex:that.pageIndex,
  313. pageSize:that.pageSize,
  314. search:that.input,
  315. }
  316. }).then(function (res) {
  317. if(res.data.code==200){
  318. that.tableData= res.data.data;
  319. that.count= res.data.count;
  320. }
  321. }).catch(()=>{})
  322. },
  323. //获取详情
  324. OverseaVehicleInfo(val){
  325. var url = "/api/Resource/OverseaVehicleInfo/"+val
  326. var that = this
  327. this.$axios({
  328. method: 'get',
  329. url: url,
  330. headers: {
  331. Authorization: 'Bearer ' + this.token
  332. }
  333. }).then(function (res) {
  334. if(res.data.code==200){
  335. return res.data.data;
  336. }else{
  337. that.$message.error(res.data.msg);
  338. }
  339. })
  340. },
  341. //新增按钮
  342. addclick(text,val){
  343. if (this.$refs.addfees){
  344. this.$nextTick(() => {
  345. this.$refs['addfees'].clearValidate();
  346. })
  347. }
  348. this.AdditionalFees=true;
  349. var that = this
  350. if(text=='修改'){
  351. new Promise(function (resolve, reject) {
  352. var url = "/api/Resource/OverseaVehicleInfo/" + val.id
  353. that.$axios({
  354. method: 'get',
  355. url: url,
  356. headers: {
  357. Authorization: 'Bearer ' + that.token
  358. }
  359. }).then(function (res) {
  360. var vals=[];
  361. if (res.data.code == 200) {
  362. vals = res.data.data;
  363. that.addfees.id = vals.id;
  364. that.addfees.continent = vals.continentName;
  365. that.addfees.country = vals.countryName;
  366. that.addfees.city = vals.cityName;
  367. that.addfees.currency = vals.currency;
  368. that.addfees.guidePrice = vals.guidePrice;
  369. that.addfees.otherPrice1 = vals.otherPrice1;
  370. that.addfees.otherPrice2 = vals.otherPrice2;
  371. that.addfees.otherPrice3 = vals.otherPrice3;
  372. that.addfees.trainCost = vals.trainCost;
  373. that.addfees.carInfos = vals.carInfos;
  374. that.addfees.remark = vals.remark;
  375. return resolve();
  376. } else {
  377. that.$message.error(res.data.msg);
  378. }
  379. })
  380. }).then(() => {
  381. that.OverseaVehicleInit();
  382. });
  383. }else{
  384. this.OverseaVehicleInit();
  385. this.addfees = {
  386. id: 0,
  387. continent: '',//洲
  388. country: '', //国家
  389. city: '',//城市
  390. currency: 807,//币种
  391. guidePrice: 0,//导游费用
  392. otherPrice1: 0,//举牌接机
  393. otherPrice2: 0,//送机协助值机
  394. otherPrice3: 0,//其他费用
  395. carInfos: [
  396. {
  397. carTypeName: '',
  398. serviceType: '',
  399. price: '',
  400. id: 0,
  401. remark: ''
  402. }
  403. ],
  404. trainCost: 0,//培训费
  405. remark: '',//备注
  406. }
  407. }
  408. },
  409. handleSizeChange(val) {
  410. this.pageSize=val;
  411. this.OverseaVehicleList();
  412. },
  413. handleCurrentChange(val) {
  414. this.pageIndex=val;
  415. this.OverseaVehicleList()
  416. },
  417. //新增,修改api
  418. OverseaVehicleAddOrEdit(){
  419. var that = this
  420. new Promise(function (resolve, reject) {
  421. //验证具体车型
  422. if (that.addfees.carInfos.length==0){
  423. that.$message.error('请添加具体车型信息');
  424. return;
  425. }
  426. for(var i=0;i<that.addfees.carInfos.length;i++){
  427. if(that.addfees.carInfos[i].carTypeName==''){
  428. that.$message.error('请填写具体车型名称');
  429. return;
  430. }
  431. if(that.addfees.carInfos[i].serviceType==''){
  432. that.$message.error('请选择具体车型服务类型');
  433. return;
  434. }
  435. if(that.addfees.carInfos[i].price==''||that.addfees.carInfos[i].price==null){
  436. that.$message.error('请填写具体车型价格');
  437. return;
  438. }
  439. }
  440. var url = "/api/Resource/OverseaVehicleAddOrEdit"
  441. that.$axios({
  442. method: 'post',
  443. url: url,
  444. headers: {
  445. Authorization: 'Bearer ' + that.token
  446. },
  447. data: {
  448. id: that.addfees.id,
  449. continentName: that.addfees.continent,
  450. countryName: that.addfees.country,
  451. cityName: that.addfees.city,
  452. guidePrice: that.addfees.guidePrice,
  453. otherPrice1: that.addfees.otherPrice1,
  454. otherPrice2: that.addfees.otherPrice2,
  455. otherPrice3: that.addfees.otherPrice3,
  456. currency: that.addfees.currency,
  457. carInfos: that.addfees.carInfos,
  458. remark: that.addfees.remark,
  459. currUserId: that.loginuserid,
  460. }
  461. }).then(function (res) {
  462. if (res.data.code == 200) {
  463. that.$message({
  464. type: 'success',
  465. message: res.data.msg
  466. });
  467. that.AdditionalFees = false
  468. return resolve();
  469. } else {
  470. that.$message.error(res.data.msg);
  471. }
  472. })
  473. }).then(() => {
  474. that.OverseaVehicleList();
  475. });
  476. },
  477. //新增-修改
  478. addsbtn(formName){
  479. this.$refs[formName].validate((valid) => {
  480. if (valid) {
  481. this.OverseaVehicleAddOrEdit()
  482. } else {
  483. this.$message.error('请将红框内容补全!');
  484. return false;
  485. }
  486. });
  487. },
  488. //删除
  489. deleteRow(index, rows,inif){
  490. this.$confirm('此操作将永久删除该数据, 是否继续?', '提示', {
  491. confirmButtonText: '确定',
  492. cancelButtonText: '取消',
  493. type: 'warning',
  494. center: true
  495. }).then(() => {
  496. var url = "/api/Resource/OverseaVehicleDel"
  497. var that = this
  498. new Promise(function (resolve, reject) {
  499. that.$axios({
  500. method: 'post',
  501. url: url,
  502. headers: {
  503. Authorization: 'Bearer ' + that.token
  504. },
  505. data:{
  506. id: inif.id,
  507. currUserId:that.loginuserid,
  508. }
  509. }).then(function (res) {
  510. if(res.data.code==200){
  511. that.$message({
  512. type: 'success',
  513. message: res.data.msg
  514. });
  515. return resolve();
  516. }else{
  517. that.$message.error(res.data.msg);
  518. }
  519. })
  520. }).then(() => {
  521. that.OverseaVehicleList();
  522. });
  523. }).catch(() => {
  524. this.$message({
  525. type: 'info',
  526. message: '已取消删除'
  527. });
  528. });
  529. },
  530. },
  531. mounted(){
  532. this.loginuserid=JSON.parse(localStorage.getItem('userinif')).userInfo.userId;
  533. this.OverseaVehicleList();
  534. }
  535. }
  536. </script>
  537. <style>
  538. .standards-all{
  539. background-color: #fff;
  540. padding: 10px;
  541. box-shadow: 0 0 5px #0005;
  542. border-radius: 10px;
  543. min-height: 830px;
  544. }
  545. .standards-head-li{
  546. display: flex;
  547. }
  548. .standards-head-li div{
  549. margin-right: 10px;
  550. }
  551. .standards-head-li label{
  552. color: #606266;
  553. font-size: 15px;
  554. font-weight: 600;
  555. }
  556. .standards-head{
  557. display: flex;
  558. justify-content: space-between;
  559. }
  560. .standards-table{
  561. margin-top: 20px;
  562. }
  563. .standards-table .block{
  564. margin-top: 10px;
  565. text-align: center;
  566. }
  567. .standards-inif{
  568. display: flex;
  569. flex-wrap:wrap ;
  570. }
  571. .standards-inif .el-input--medium {
  572. width: 218px;
  573. }
  574. .standards-inif .el-input-number--medium{
  575. width: 218px;
  576. }
  577. .carinfo>div{
  578. display: flex;
  579. }
  580. .carinfo .el-input--medium {
  581. width: 218px;
  582. }
  583. .carinfo .standards-inif .el-input-number--medium{
  584. width: 218px;
  585. }
  586. .remark-box .el-textarea__inner{
  587. width: 100%;
  588. }
  589. </style>