index.vue 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395
  1. <!-- 套餐充值订单 -->
  2. <template>
  3. <div class="silent-expire-alarm">
  4. <!-- 搜索条件区 -->
  5. <div class="search-section">
  6. <a-form :model="searchForm" layout="inline">
  7. <a-form-item field="cardNumber" label="订单编号">
  8. <a-input v-model="searchForm.orderNumber" placeholder="请输入订单编号" allow-clear />
  9. </a-form-item>
  10. <a-form-item field="customerName" label="ICCID">
  11. <a-input v-model="searchForm.customerName" placeholder="请输入ICCID" allow-clear />
  12. </a-form-item>
  13. <a-form-item>
  14. <a-space>
  15. <a-button type="primary" @click="handleSearch">搜索</a-button>
  16. <a-button @click="resetSearch">重置</a-button>
  17. </a-space>
  18. </a-form-item>
  19. </a-form>
  20. </div>
  21. <div class="audit-btn">
  22. <a-button @click="openAudit" type="text">
  23. <template #icon>
  24. <icon-plus-circle />
  25. </template>
  26. <template #default>审核</template>
  27. </a-button>
  28. </div>
  29. <!-- 数据表格 -->
  30. <a-table row-key="customerName" v-model:selectedKeys="selectedKeys" :row-selection="rowSelection"
  31. :columns="columns" :data="tableData" :pagination="pagination" :scroll="{ x: '100%', y: '400px' }">
  32. <template #operate="{ record }">
  33. <a-button @click="openContract(record)" type="text">上传合同</a-button>
  34. </template>
  35. <template #detail="{ record }">
  36. <a-button @click="openDetail(record)" type="text">订单详情</a-button>
  37. </template>
  38. </a-table>
  39. <a-modal v-model:visible="uploadContract" title="上传合同" @cancel="handleCancel" @before-ok="handleBeforeOk"
  40. okText="保存" cancelText="关闭">
  41. <a-form :model="formContract" auto-label-width>
  42. <a-form-item field="orderNumber" label="单号">
  43. <!-- <a-input v-model="formContract.orderNumber" disabled placeholder="请输入单号" /> -->
  44. <div class="audit-txt">{{ formContract.orderNumber }}</div>
  45. </a-form-item>
  46. <a-form-item field="customerName" label="客户">
  47. <!-- <a-input v-model="formContract.customerName" disabled placeholder="请输入客户" /> -->
  48. <div class="audit-txt" style="color:#418035;">{{ formContract.customerName }}</div>
  49. </a-form-item>
  50. <a-form-item field="fileList" label="销售合同">
  51. <a-upload action="/" :default-file-list="formContract.fileList" />
  52. </a-form-item>
  53. </a-form>
  54. </a-modal>
  55. <a-modal v-model:visible="showAudit" title="审核" @cancel="showAudit = false" @before-ok="submitAudit"
  56. okText="确定审核" cancelText="关闭">
  57. <a-form :model="formAudit" auto-label-width>
  58. <a-form-item field="customerName" label="客户">
  59. <!-- <a-input v-model="formAudit.customerName" placeholder="请输入客户" /> -->
  60. <div class="audit-txt" style="color:#418035;">演示账号02</div>
  61. </a-form-item>
  62. <a-form-item field="cardType" label="卡类型">
  63. <!-- <a-input v-model="formAudit.cardType" placeholder="请输入单号" /> -->
  64. <div class="audit-txt">普通卡切卡普通卡MP1,1元/涨<div class="audit-tag">共1张卡</div>
  65. </div>
  66. </a-form-item>
  67. <a-form-item field="money" label="资费">
  68. <!-- <a-input v-model="formAudit.money" placeholder="请输入单号" /> -->
  69. <div class="audit-txt">“移动100M月包” <div class="audit-tag">订购12个月</div>
  70. </div>
  71. </a-form-item>
  72. <a-form-item field="orderStatus" label="订单状态">
  73. <!-- <a-input v-model="formAudit.orderStatus" placeholder="请输入单号" /> -->
  74. <a-radio-group v-model="formAudit.orderStatus" :options="options" />
  75. </a-form-item>
  76. <a-form-item field="auditOpinion" label="审核意见">
  77. <!-- <a-input v-model="formAudit.auditOpinion" placeholder="请输入单号" /> -->
  78. <a-textarea placeholder="您填写的审核意见会直接投送给用户,请认真填写!" v-model="formAudit.auditOpinion" allow-clear />
  79. </a-form-item>
  80. <a-form-item field="fileList" label="销售合同">
  81. <a-upload action="/" :default-file-list="formAudit.fileList" />
  82. </a-form-item>
  83. </a-form>
  84. </a-modal>
  85. <a-modal v-model:visible="showDetail" width="800px" title="订单详情" :hide-cancel="true" @cancel="detailCancel">
  86. <div class="detail-box">
  87. <div class="detail-item-box">
  88. <div class="detail-item">
  89. <div class="item-label">订单编号</div>
  90. <div class="item-content">53357981207</div>
  91. </div>
  92. <div class="detail-item">
  93. <div class="item-label">订单状态</div>
  94. <div class="item-content">已发货</div>
  95. </div>
  96. </div>
  97. <div class="detail-item-box">
  98. <div class="detail-item">
  99. <div class="item-label">发货日期</div>
  100. <div class="item-content">2024-10-24 17:46:33</div>
  101. </div>
  102. </div>
  103. <div class="detail-item-box">
  104. <div class="detail-item">
  105. <div class="item-label">运营商</div>
  106. <div class="item-content">泰国AIS</div>
  107. </div>
  108. <div class="detail-item">
  109. <div class="item-label">资费信息</div>
  110. <div class="item-content">1.0G/月</div>
  111. </div>
  112. </div>
  113. <div class="detail-item-box">
  114. <div class="detail-item">
  115. <div class="item-label">最短订阅周期</div>
  116. <div class="item-content">3个月</div>
  117. </div>
  118. <div class="detail-item">
  119. <div class="item-label">最长订阅周期</div>
  120. <div class="item-content">--</div>
  121. </div>
  122. </div>
  123. <div class="detail-item-box">
  124. <div class="detail-item">
  125. <div class="item-label">流量结算方式</div>
  126. <div class="item-content">按单流量消耗计费</div>
  127. </div>
  128. <div class="detail-item">
  129. <div class="item-label">结算周期</div>
  130. <div class="item-content">月</div>
  131. </div>
  132. </div>
  133. <div class="detail-item-box">
  134. <div class="detail-item">
  135. <div class="item-label">流量资费计费</div>
  136. <div class="item-content">0.8美金/G;MRC:0元;网络接入0元</div>
  137. </div>
  138. </div>
  139. <div class="detail-item-box">
  140. <div class="detail-item">
  141. <div class="item-label">卡类型</div>
  142. <div class="item-content">工业级PlugIn</div>
  143. </div>
  144. <div class="detail-item">
  145. <div class="item-label">卡板费</div>
  146. <div class="item-content">1美金</div>
  147. </div>
  148. </div>
  149. <div class="detail-item-box">
  150. <div class="detail-item">
  151. <div class="item-label">流量池</div>
  152. <div class="item-content">组池</div>
  153. </div>
  154. <div class="detail-item">
  155. <div class="item-label">沉默期</div>
  156. <div class="item-content">6个月</div>
  157. </div>
  158. </div>
  159. <div class="detail-item-box">
  160. <div class="detail-item">
  161. <div class="item-label">卡数量</div>
  162. <div class="item-content">10000;已分配0,已退回0,已转移0
  163. <a-button type="primary" @click="showCard = true" style="margin-left:10px;">分配卡号</a-button>
  164. </div>
  165. </div>
  166. </div>
  167. </div>
  168. <div class="detail-table">
  169. <a-table :columns="columnsDetail" :data="dataDetail" />
  170. </div>
  171. </a-modal>
  172. <a-modal v-model:visible="showCard" width="800px" title="分配卡号" @cancel="showCard = false"
  173. @before-ok="submitCard" okText="确认" cancelText="取消">
  174. <a-textarea :auto-size="{
  175. minRows: 15,
  176. maxRows: 15
  177. }" v-model="cardNumber" max-length="1000" :show-word-limit="true"
  178. placeholder="请输入iccid,一行一个或者逗号分隔;不支持两种混合号码。" allow-clear />
  179. </a-modal>
  180. </div>
  181. </template>
  182. <script setup>
  183. import { ref, reactive } from 'vue';
  184. import { Message } from '@arco-design/web-vue';
  185. const selectedKeys = ref([]);
  186. const rowSelection = reactive({
  187. type: 'checkbox',
  188. showCheckedAll: true,
  189. onlyCurrent: false,
  190. });
  191. const searchForm = reactive({
  192. cardNumber: '',
  193. customerName: '',
  194. });
  195. const columns = [
  196. { title: '序号', dataIndex: 'index', align: 'center', render: ({ rowIndex }) => rowIndex + 1 },
  197. { title: '订单编号', dataIndex: 'cardNumber' },
  198. { title: 'ICCID', dataIndex: 'customerName' },
  199. { title: 'MSISDN', dataIndex: 'msisdn' },
  200. { title: '订单类型', dataIndex: 'orderStatus' },
  201. { title: '运营商名称', dataIndex: 'cardQuantity' },
  202. { title: '购买套餐', dataIndex: 'source' },
  203. { title: '套餐类型', dataIndex: 'packageStatus' },
  204. { title: '订购时长', dataIndex: 'money' },
  205. { title: '套餐价格', dataIndex: 'outMoney' },
  206. { title: '支付状态', dataIndex: 'payStatus' },
  207. { title: '支付价格', dataIndex: 'payMoney' },
  208. { title: '支付时间', dataIndex: 'orderTime' },
  209. // { title: '操作', slotName: 'operate', align: 'center' },
  210. { title: '详情', slotName: 'detail', align: 'center' },
  211. ];
  212. const columnsDetail = [{ title: 'ICCID', dataIndex: 'iccid' },
  213. { title: '池名称及编号', dataIndex: 'nameAndId' },
  214. { title: '卡状态', dataIndex: 'status' },
  215. ]
  216. const dataDetail = ref([{
  217. iccid: '8986061800002054589N',
  218. nameAndId: '泰国监控40G共享/53357981207',
  219. status: '沉默期'
  220. },
  221. {
  222. iccid: '8986061800002054588N',
  223. nameAndId: '泰国监控40G共享/53357981207',
  224. status: '沉默期'
  225. }, {
  226. iccid: '8986061800002054587N',
  227. nameAndId: '泰国监控40G共享/53357981207',
  228. status: '沉默期'
  229. }, {
  230. iccid: '8986061800002054586N',
  231. nameAndId: '泰国监控40G共享/53357981207',
  232. status: '沉默期'
  233. },])
  234. const tableData = ref([]);
  235. // 上传合同的弹框
  236. const uploadContract = ref(false);
  237. const pagination = reactive({
  238. total: tableData.value.length,
  239. current: 1,
  240. pageSize: 10,
  241. });
  242. const openContract = (item) => {
  243. console.log(item, '???')
  244. uploadContract.value = true;
  245. formContract.customerName = item.customerName;
  246. formContract.orderNumber = item.cardNumber;
  247. };
  248. //订单详情的弹框
  249. const showDetail = ref(false);
  250. // 查看订单详情
  251. const openDetail = (item) => {
  252. showDetail.value = true;
  253. }
  254. const handleBeforeOk = (done) => {
  255. console.log(formContract)
  256. window.setTimeout(() => {
  257. done()
  258. // prevent close
  259. // done(false)
  260. }, 3000)
  261. };
  262. const handleCancel = () => {
  263. uploadContract.value = false;
  264. }
  265. const handleSearch = () => {
  266. console.log('Search form data:', searchForm);
  267. Message.success('执行搜索操作');
  268. };
  269. const resetSearch = () => {
  270. Object.keys(searchForm).forEach(key => {
  271. if (Array.isArray(searchForm[key])) {
  272. searchForm[key] = [];
  273. } else {
  274. searchForm[key] = null;
  275. }
  276. });
  277. Message.success('搜索条件已重置');
  278. };
  279. // 文件上传的列表
  280. const formContract = reactive({
  281. orderNumber: '',
  282. customerName: '',
  283. fileList: []
  284. })
  285. // 订单状态
  286. const options = [
  287. { label: '发货', value: '1' },
  288. { label: '退回', value: '2' },
  289. ];
  290. // 审核
  291. const showAudit = ref(false);
  292. const formAudit = reactive({
  293. customerName: '',
  294. cardType: '',
  295. money: '',
  296. orderStatus: '',
  297. auditOpinion: '',
  298. fileList: []
  299. })
  300. // 触发审核的弹框
  301. const openAudit = () => {
  302. showAudit.value = true;
  303. }
  304. // 确认审核
  305. const submitAudit = () => {
  306. console.log(formAudit, 'lll')
  307. window.setTimeout(() => {
  308. showAudit.value = false;
  309. }, 1000)
  310. }
  311. // 分配卡号的值
  312. const cardNumber = ref('');
  313. const showCard = ref(false);
  314. const detailCancel = () => {
  315. }
  316. const submitCard = () => {
  317. }
  318. </script>
  319. <style scoped lang="less">
  320. .silent-expire-alarm {
  321. padding: 20px !important;
  322. // background: #fcf;
  323. }
  324. .search-section {
  325. margin-bottom: 20px;
  326. }
  327. .arco-table-th {
  328. white-space: nowrap;
  329. }
  330. .audit-txt {
  331. display: flex;
  332. justify-content: center;
  333. align-items: center;
  334. .audit-tag {
  335. margin-left: 20px;
  336. background: #63c2c6;
  337. color: #fff;
  338. font-size: 12px;
  339. display: flex;
  340. justify-content: center;
  341. align-items: center;
  342. padding: 0 10px;
  343. box-sizing: border-box;
  344. border-radius: 50px;
  345. }
  346. }
  347. .audit-btn {
  348. margin-bottom: 10px;
  349. }
  350. .detail-box {
  351. .detail-item-box {
  352. display: flex;
  353. justify-content: space-between;
  354. align-items: center;
  355. margin-bottom: 10px;
  356. .detail-item {
  357. //styleName: Body/Medium;
  358. font-family: PingFang SC;
  359. font-size: 14px;
  360. font-weight: 400;
  361. line-height: 22px;
  362. text-align: left;
  363. display: flex;
  364. align-items: center;
  365. min-width: 350px;
  366. .item-label {
  367. color: rgba(0, 0, 0, 0.4);
  368. width: 120px;
  369. text-align: right;
  370. margin-right: 10px;
  371. }
  372. .item-content {
  373. color: rgba(51, 51, 51, 1);
  374. }
  375. }
  376. }
  377. }
  378. .detail-table {
  379. margin-top: 20px;
  380. }
  381. </style>