index copy.vue 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428
  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="客户">
  11. <a-input v-model="searchForm.customerName" placeholder="请输入客户名称" 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" :columns="columns"
  31. :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" okText="确定审核"
  56. 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" @before-ok="submitCard"
  173. okText="确认" cancelText="取消">
  174. <a-textarea :auto-size="{
  175. minRows: 15,
  176. maxRows: 15
  177. }" v-model="cardNumber" max-length="1000" :show-word-limit="true" placeholder="请输入iccid,一行一个或者逗号分隔;不支持两种混合号码。"
  178. 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: '客户名称', dataIndex: 'customerName' },
  199. { title: '审核状态', dataIndex: 'auditStatus' },
  200. { title: '订单状态', dataIndex: 'orderStatus' },
  201. { title: '开卡张数', dataIndex: 'cardQuantity' },
  202. { title: '通道', dataIndex: 'source' },
  203. { title: '资费', dataIndex: 'money' },
  204. { title: '结算价/原价(元)', dataIndex: 'outMoney' },
  205. { title: '下单时间', dataIndex: 'orderTime' },
  206. { title: '操作', slotName: 'operate', align: 'center' },
  207. { title: '详情', slotName: 'detail', align: 'center' },
  208. ];
  209. const columnsDetail = [{ title: 'ICCID', dataIndex: 'iccid' },
  210. { title: '池名称及编号', dataIndex: 'nameAndId' },
  211. { title: '卡状态', dataIndex: 'status' },
  212. ]
  213. const dataDetail = ref([{
  214. iccid: '8986061800002054589N',
  215. nameAndId: '泰国监控40G共享/53357981207',
  216. status: '沉默期'
  217. },
  218. {
  219. iccid: '8986061800002054588N',
  220. nameAndId: '泰国监控40G共享/53357981207',
  221. status: '沉默期'
  222. }, {
  223. iccid: '8986061800002054587N',
  224. nameAndId: '泰国监控40G共享/53357981207',
  225. status: '沉默期'
  226. }, {
  227. iccid: '8986061800002054586N',
  228. nameAndId: '泰国监控40G共享/53357981207',
  229. status: '沉默期'
  230. },])
  231. const tableData = ref([
  232. {
  233. cardNumber: '13800138000',
  234. customerName: '张三',
  235. auditStatus: '1',
  236. orderStatus: '1',
  237. cardQuantity: 24,
  238. source: '联通',
  239. money: '100',
  240. outMoney: '10',
  241. orderTime: '2024-10-11'
  242. // operate:'上传合同'
  243. },
  244. {
  245. cardNumber: '13800138000',
  246. customerName: '李四',
  247. auditStatus: '1',
  248. orderStatus: '1',
  249. cardQuantity: 24,
  250. source: '联通',
  251. money: '100',
  252. outMoney: '10',
  253. orderTime: '2024-10-11'
  254. // operate:'上传合同'
  255. }, {
  256. cardNumber: '13800138000',
  257. customerName: '王五',
  258. auditStatus: '1',
  259. orderStatus: '1',
  260. cardQuantity: 24,
  261. source: '联通',
  262. money: '100',
  263. outMoney: '10',
  264. orderTime: '2024-10-11'
  265. // operate:'上传合同'
  266. },
  267. // 可以添加更多模拟数据...
  268. ]);
  269. // 上传合同的弹框
  270. const uploadContract = ref(false);
  271. const pagination = reactive({
  272. total: tableData.value.length,
  273. current: 1,
  274. pageSize: 10,
  275. });
  276. const openContract = (item) => {
  277. console.log(item, '???')
  278. uploadContract.value = true;
  279. formContract.customerName = item.customerName;
  280. formContract.orderNumber = item.cardNumber;
  281. };
  282. //订单详情的弹框
  283. const showDetail = ref(false);
  284. // 查看订单详情
  285. const openDetail = (item) => {
  286. showDetail.value = true;
  287. }
  288. const handleBeforeOk = (done) => {
  289. console.log(formContract)
  290. window.setTimeout(() => {
  291. done()
  292. // prevent close
  293. // done(false)
  294. }, 3000)
  295. };
  296. const handleCancel = () => {
  297. uploadContract.value = false;
  298. }
  299. const handleSearch = () => {
  300. console.log('Search form data:', searchForm);
  301. Message.success('执行搜索操作');
  302. };
  303. const resetSearch = () => {
  304. Object.keys(searchForm).forEach(key => {
  305. if (Array.isArray(searchForm[key])) {
  306. searchForm[key] = [];
  307. } else {
  308. searchForm[key] = null;
  309. }
  310. });
  311. Message.success('搜索条件已重置');
  312. };
  313. // 文件上传的列表
  314. const formContract = reactive({
  315. orderNumber: '',
  316. customerName: '',
  317. fileList: []
  318. })
  319. // 订单状态
  320. const options = [
  321. { label: '发货', value: '1' },
  322. { label: '退回', value: '2' },
  323. ];
  324. // 审核
  325. const showAudit = ref(false);
  326. const formAudit = reactive({
  327. customerName: '',
  328. cardType: '',
  329. money: '',
  330. orderStatus: '',
  331. auditOpinion: '',
  332. fileList: []
  333. })
  334. // 触发审核的弹框
  335. const openAudit = () => {
  336. showAudit.value = true;
  337. }
  338. // 确认审核
  339. const submitAudit = () => {
  340. console.log(formAudit, 'lll')
  341. window.setTimeout(() => {
  342. showAudit.value = false;
  343. }, 1000)
  344. }
  345. // 分配卡号的值
  346. const cardNumber = ref('');
  347. const showCard = ref(false);
  348. const submitCard = () => {
  349. }
  350. </script>
  351. <style scoped lang="less">
  352. .silent-expire-alarm {
  353. padding: 20px !important;
  354. // background: #fcf;
  355. }
  356. .search-section {
  357. margin-bottom: 20px;
  358. }
  359. .arco-table-th {
  360. white-space: nowrap;
  361. }
  362. .audit-txt {
  363. display: flex;
  364. justify-content: center;
  365. align-items: center;
  366. .audit-tag {
  367. margin-left: 20px;
  368. background: #63c2c6;
  369. color: #fff;
  370. font-size: 12px;
  371. display: flex;
  372. justify-content: center;
  373. align-items: center;
  374. padding: 0 10px;
  375. box-sizing: border-box;
  376. border-radius: 50px;
  377. }
  378. }
  379. .audit-btn {
  380. margin-bottom: 10px;
  381. }
  382. .detail-box {
  383. .detail-item-box {
  384. display: flex;
  385. justify-content: space-between;
  386. align-items: center;
  387. margin-bottom: 10px;
  388. .detail-item {
  389. //styleName: Body/Medium;
  390. font-family: PingFang SC;
  391. font-size: 14px;
  392. font-weight: 400;
  393. line-height: 22px;
  394. text-align: left;
  395. display: flex;
  396. align-items: center;
  397. min-width: 350px;
  398. .item-label {
  399. color: rgba(0, 0, 0, 0.4);
  400. width: 120px;
  401. text-align: right;
  402. margin-right: 10px;
  403. }
  404. .item-content {
  405. color: rgba(51, 51, 51, 1);
  406. }
  407. }
  408. }
  409. }
  410. .detail-table {
  411. margin-top: 20px;
  412. }
  413. </style>