You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

index.vue 5.9 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194
  1. <template>
  2. <div>
  3. <div class="title"><span>资源池(队列)</span></div>
  4. <div class="tools-bar">
  5. <div>
  6. <el-select class="select" size="medium" :value="value1">
  7. <!-- <el-option v-for="item in sceneList" :key="item.k" :label="item.v" :value="item.k" /> -->
  8. </el-select>
  9. <el-select class="select" size="medium" :value="value1">
  10. <!-- <el-option v-for="item in pointActions" :key="item.k" :label="item.v" :value="item.k" /> -->
  11. </el-select>
  12. <el-select class="select" size="medium" :value="value1"></el-select>
  13. <el-select class="select" size="medium" :value="value1"></el-select>
  14. </div>
  15. <div>
  16. <el-button size="medium" icon="el-icon-refresh" @click="showDialog('edit', {x: 1, y: 2, z: 3})">同步智算网络</el-button>
  17. <el-button type="primary" icon="el-icon-plus" size="medium" @click="showDialog('add')">新增资源池</el-button>
  18. </div>
  19. </div>
  20. <div class="table-container">
  21. <div>
  22. <el-table border :data="tableData" style="width: 100%" v-loading="loading" stripe>
  23. <el-table-column prop="index" label="ID" align="center" header-align="center"></el-table-column>
  24. <el-table-column prop="userName" label="资源池(队列)名称" align="center" header-align="center">
  25. <template #default="scope">
  26. <a :href="`/${scope.row.userName}`">{{ scope.row.userName }}</a>
  27. </template>
  28. </el-table-column>
  29. <el-table-column prop="date" label="所属集群" align="center" header-align="center">
  30. </el-table-column>
  31. <el-table-column prop="scene" label="智算中心ID" align="center" header-align="center">
  32. </el-table-column>
  33. <el-table-column prop="pointAction" label="智算中心" align="left" header-align="center">
  34. </el-table-column>
  35. <el-table-column prop="remark" label="计算资源" align="left" header-align="center" min-width="200">
  36. <template #default="scope">
  37. <span v-html="scope.row.remark"></span>
  38. </template>
  39. </el-table-column>
  40. <el-table-column prop="operator" label="卡类型" align="center" header-align="center">
  41. </el-table-column>
  42. <el-table-column prop="amount" label="卡数 " align="center" header-align="center">
  43. <template #default="scope">
  44. {{ scope.row.amount }}
  45. </template>
  46. </el-table-column>
  47. <el-table-column prop="blance" label="最后更新时间" align="center" header-align="center">
  48. <template #default="scope">
  49. {{ scope.row.blance }}
  50. </template>
  51. </el-table-column>
  52. <el-table-column prop="blance" label="备注" align="center" header-align="center">
  53. <template #default="scope">
  54. {{ scope.row.blance }}
  55. </template>
  56. </el-table-column>
  57. <el-table-column prop="blance" label="操作" align="center" header-align="center">
  58. <template #default="scope">
  59. {{ scope.row.blance }}
  60. </template>
  61. </el-table-column>
  62. <template #empty>
  63. <span style="font-size: 12px">{{
  64. loading ? '加载中...' : '暂无数据'
  65. }}</span>
  66. </template>
  67. </el-table>
  68. </div>
  69. <div class="__r_p_pagination">
  70. <div style="margin-top: 2rem">
  71. <div class="center">
  72. <el-pagination background @current-change="currentChange" :current-page="pageInfo.curpage"
  73. :page-sizes="pageInfo.pageSizes" :page-size="pageInfo.pageSize"
  74. layout="total, sizes, prev, pager, next, jumper" :total="pageInfo.total">
  75. </el-pagination>
  76. </div>
  77. </div>
  78. </div>
  79. </div>
  80. <QueueDialog :visible.sync="queueDialogShow" :type="queueDialogType" :data="queueDialogData" @confirm="queueDialogConfirm"></QueueDialog>
  81. </div>
  82. </template>
  83. <script>
  84. import QueueDialog from '../components/QueueDialog.vue';
  85. export default {
  86. data() {
  87. return {
  88. value1: '1',
  89. searchVal: '',
  90. loading: false,
  91. tableData: [],
  92. pageInfo: {
  93. curpage: 1,
  94. pageSize: 10,
  95. pageSizes: [10],
  96. total: 0,
  97. },
  98. queueDialogShow: false,
  99. queueDialogType: 'add',
  100. queueDialogData: {},
  101. };
  102. },
  103. components: {
  104. QueueDialog
  105. },
  106. methods: {
  107. getTableData: function () {
  108. this.tableData = new Array(20).fill(0).map((_, index) => {
  109. return {
  110. index: index,
  111. };
  112. })
  113. },
  114. currentChange: function (val) {
  115. this.pageInfo.curpage = val;
  116. // this.getTableData();
  117. },
  118. showDialog(type, data) {
  119. this.queueDialogType = type;
  120. this.queueDialogData = data || {};
  121. this.queueDialogShow = true;
  122. },
  123. queueDialogConfirm() {
  124. this.queueDialogShow = false;
  125. }
  126. },
  127. mounted: function () {
  128. this.getTableData();
  129. },
  130. beforeDestroy: function () {
  131. },
  132. };
  133. </script>
  134. <style scoped lang="less">
  135. .title {
  136. height: 30px;
  137. display: flex;
  138. align-items: center;
  139. margin-bottom: 5px;
  140. span {
  141. font-weight: 700;
  142. font-size: 16px;
  143. color: rgb(16, 16, 16);
  144. }
  145. }
  146. .tools-bar {
  147. display: flex;
  148. align-items: center;
  149. justify-content: space-between;
  150. margin-bottom: 10px;
  151. .select {
  152. margin-right: 10px;
  153. /deep/ .el-input__inner {
  154. border-radius: 0;
  155. }
  156. }
  157. }
  158. .table-container {
  159. margin-bottom: 16px;
  160. /deep/ .el-table__header {
  161. th {
  162. background: rgb(245, 245, 246);
  163. font-size: 12px;
  164. color: rgb(36, 36, 36);
  165. }
  166. }
  167. /deep/ .el-table__body {
  168. td {
  169. font-size: 12px;
  170. }
  171. }
  172. .op-btn {
  173. cursor: pointer;
  174. font-size: 12px;
  175. color: rgb(25, 103, 252);
  176. margin: 0 5px;
  177. }
  178. }
  179. .center {
  180. display: flex;
  181. justify-content: center;
  182. }
  183. </style>