Currency.vue 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  1. <template>
  2. <div>
  3. <div class="currency-all">
  4. <div class="currency-head">
  5. <div class="head-ipt">
  6. <div class="name-ipt">
  7. <label>团组名称:</label>
  8. <el-select v-model="state1" filterable placeholder="请选择">
  9. <el-option
  10. v-for="item in restaurants"
  11. :key="item.id"
  12. :label="item.groupName"
  13. :value="item.id">
  14. </el-option>
  15. </el-select>
  16. </div>
  17. <div class="preserve-btn">
  18. <el-button class="preserve" type="primary">保存数据</el-button>
  19. </div>
  20. </div>
  21. <div class="currency-info">
  22. <div class="currency-info-li">
  23. <label>团 号:</label>
  24. <span>9XGYL</span>
  25. </div>
  26. <div class="currency-info-li">
  27. <label>客 户:</label>
  28. <span>小熟悉熟悉</span>
  29. </div>
  30. <div class="currency-info-li">
  31. <label>出访国家:</label>
  32. <span>新加坡</span>
  33. </div>
  34. <div class="currency-info-li">
  35. <label>起止日期:</label>
  36. <span>2023-05-18 ~ 2023-05-27</span>
  37. </div>
  38. <div class="currency-info-li">
  39. <label>天数/人数:</label>
  40. <span>10天/6人</span>
  41. </div>
  42. </div>
  43. </div>
  44. <div class="currency-com">
  45. <el-tabs v-model="activeName" @tab-click="handleClick">
  46. <el-tab-pane label="酒店预订" name="hotel">
  47. <div class="ipt-inif">
  48. <div class="ipt" v-for="(item,index) in currencyArr" :key="index">
  49. <label>{{item.remark}}({{item.name}}):</label>
  50. <el-input v-model="item.rate" oninput="value=value.replace(/[^\d.]/g,'')" placeholder="请输入内容"></el-input>
  51. </div>
  52. </div>
  53. </el-tab-pane>
  54. <el-tab-pane label="行程" name="itinerary">行程</el-tab-pane>
  55. <el-tab-pane label="车/导游地接" name="guide">车/导游地接</el-tab-pane>
  56. <el-tab-pane label="签证" name="visa">签证</el-tab-pane>
  57. <el-tab-pane label="邀请/公务活动" name="business">邀请/公务活动</el-tab-pane>
  58. <el-tab-pane label="团组客户保险" name="insurance">团组客户保险</el-tab-pane>
  59. <el-tab-pane label="机票预订" name="ticket">机票预订</el-tab-pane>
  60. <el-tab-pane label="团组增减款项" name="payments">团组增减款项</el-tab-pane>
  61. <el-tab-pane label="酒店早餐" name="breakfast">酒店早餐</el-tab-pane>
  62. </el-tabs>
  63. </div>
  64. </div>
  65. </div>
  66. </template>
  67. <script>
  68. export default {
  69. data() {
  70. return {
  71. restaurants: [],
  72. state1: '',
  73. activeName: 'hotel',
  74. currencyArr:[]
  75. };
  76. },
  77. methods: {
  78. //面包页
  79. handleClick(tab, event) {
  80. console.log(tab, event);
  81. },
  82. //获取团组汇率
  83. GetCurrency(){
  84. var url = "/api/Financial/GetGroupRateDataSources"
  85. var that = this
  86. this.$axios({
  87. method: 'post',
  88. url: url,
  89. headers: {
  90. Authorization: 'Bearer ' + this.token
  91. },
  92. data: {
  93. portType: 1,
  94. pageIndex: 0,
  95. pageSize: 0,
  96. }
  97. }).then(function (res) {
  98. console.log(res)
  99. that.restaurants = res.data.data.groupData
  100. that.currencyArr = res.data.data.teamRateData
  101. for (let i = 0; i < that.currencyArr.length; i++) {
  102. that.currencyArr[i]["rate"] = "0.0000";
  103. }
  104. console.log(that.currencyArr)
  105. })
  106. }
  107. },
  108. mounted() {
  109. this.GetCurrency();
  110. }
  111. }
  112. </script>
  113. <style>
  114. .currency-all{
  115. background-color: #fff;
  116. padding: 10px;
  117. box-shadow: 0 0 5px #0005;
  118. border-radius: 10px;
  119. height: 100%;
  120. }
  121. .currency-info{
  122. display: flex;
  123. }
  124. .currency-info-li{
  125. margin-right: 30px;
  126. }
  127. .currency-info-li label{
  128. color: #606266;
  129. font-size: 15px;
  130. font-weight: 600;
  131. }
  132. .currency-info-li span{
  133. color: #606266;
  134. font-size: 14px;
  135. }
  136. .name-ipt label{
  137. color: #606266;
  138. font-size: 15px;
  139. font-weight: 600;
  140. }
  141. .head-ipt{
  142. display: flex;
  143. justify-content: space-between;
  144. margin-bottom: 10px;
  145. }
  146. .currency-head{
  147. margin-bottom: 10px;
  148. }
  149. .ipt-inif{
  150. display: flex;
  151. flex-wrap: wrap;
  152. }
  153. .ipt-inif .el-input__inner{
  154. width: 150px;
  155. }
  156. .ipt{
  157. display: flex;
  158. align-items: center;
  159. margin-bottom: 10px;
  160. }
  161. .ipt label{
  162. width: 150px;
  163. text-align: end;
  164. font-size: 12px;
  165. font-weight: 600;
  166. }
  167. .ipt .el-input{
  168. width: 150px;
  169. }
  170. </style>