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 9.7 kB

3 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284
  1. <template>
  2. <div>
  3. <div class="title"><span>{{ $t('resourcesManagement.resQueue') }}</span></div>
  4. <div class="tools-bar">
  5. <div>
  6. <el-select class="select" size="medium" v-model="selCluster" @change="selectChange">
  7. <el-option v-for="item in clusterList" :key="item.k" :label="item.v" :value="item.k" />
  8. </el-select>
  9. <el-select class="select" size="medium" v-model="selComputingCenter" @change="selectChange">
  10. <el-option v-for="item in computingCenterList" :key="item.k" :label="item.v" :value="item.k" />
  11. </el-select>
  12. <el-select class="select" size="medium" v-model="selComputingType" @change="selectChange">
  13. <el-option v-for="item in computingTypeList" :key="item.k" :label="item.v" :value="item.k" />
  14. </el-select>
  15. <el-select class="select" size="medium" v-model="selCardType" @change="selectChange">
  16. <el-option v-for="item in cardTypeList" :key="item.k" :label="item.v" :value="item.k" />
  17. </el-select>
  18. </div>
  19. <div>
  20. <el-button size="medium" icon="el-icon-refresh" @click="syncComputerNetwork" v-loading="syncLoading">
  21. {{ $t('resourcesManagement.syncAiNetwork') }}</el-button>
  22. <el-button type="primary" icon="el-icon-plus" size="medium" @click="showDialog('add')">
  23. {{ $t('resourcesManagement.addResQueueBtn') }}</el-button>
  24. </div>
  25. </div>
  26. <div class="table-container">
  27. <div style="min-height:600px;">
  28. <el-table border :data="tableData" style="width: 100%" v-loading="loading" stripe>
  29. <el-table-column prop="ID" label="ID" align="center" header-align="center" width="80"></el-table-column>
  30. <el-table-column prop="QueueCode" :label="$t('resourcesManagement.resQueueName')" align="center"
  31. header-align="center"></el-table-column>
  32. <el-table-column prop="ClusterName" :label="$t('resourcesManagement.whichCluster')" align="center"
  33. header-align="center">
  34. <template slot-scope="scope">
  35. <span :title="scope.row.Cluster">{{ scope.row.ClusterName }}</span>
  36. </template>
  37. </el-table-column>
  38. <el-table-column prop="AiCenterCode" :label="$t('resourcesManagement.aiCenterID')" align="center"
  39. header-align="center"></el-table-column>
  40. <el-table-column prop="AiCenterName" :label="$t('resourcesManagement.aiCenter')" align="center"
  41. header-align="center"></el-table-column>
  42. <el-table-column prop="ComputeResourceName" :label="$t('resourcesManagement.computeResource')" align="center"
  43. header-align="center">
  44. </el-table-column>
  45. <el-table-column prop="AccCardTypeName" :label="$t('resourcesManagement.accCardType')" align="center"
  46. header-align="center"></el-table-column>
  47. <el-table-column prop="CardsTotalNum" :label="$t('resourcesManagement.cardsTotalNum')" align="center"
  48. header-align="center"></el-table-column>
  49. <el-table-column prop="UpdatedTimeStr" :label="$t('resourcesManagement.lastUpdateTime')" align="center"
  50. header-align="center"></el-table-column>
  51. <el-table-column prop="Remark" :label="$t('resourcesManagement.remark')" align="left" header-align="center"
  52. min-width="160">
  53. </el-table-column>
  54. <el-table-column :label="$t('operation')" align="center" header-align="center" width="80">
  55. <template slot-scope="scope">
  56. <span v-if="scope.row.Cluster !== 'C2Net'" class="op-btn" @click="showDialog('edit', scope.row)">{{
  57. $t('edit')
  58. }}</span>
  59. <span v-else class="op-btn" style="color:rgb(187, 187, 187);cursor:not-allowed">{{
  60. $t('edit')
  61. }}</span>
  62. </template>
  63. </el-table-column>
  64. <template slot="empty">
  65. <span style="font-size: 12px">{{
  66. loading ? $t('loading') : $t('noData')
  67. }}</span>
  68. </template>
  69. </el-table>
  70. </div>
  71. <div class="__r_p_pagination">
  72. <div style="margin-top: 2rem">
  73. <div class="center">
  74. <el-pagination background @current-change="currentChange" :current-page="pageInfo.curpage"
  75. :page-sizes="pageInfo.pageSizes" :page-size="pageInfo.pageSize"
  76. layout="total, sizes, prev, pager, next, jumper" :total="pageInfo.total">
  77. </el-pagination>
  78. </div>
  79. </div>
  80. </div>
  81. </div>
  82. <QueueDialog :visible.sync="queueDialogShow" :type="queueDialogType" :data="queueDialogData"
  83. @confirm="queueDialogConfirm"></QueueDialog>
  84. </div>
  85. </template>
  86. <script>
  87. import QueueDialog from '../components/QueueDialog.vue';
  88. import { getAiCenterList, getResQueueList, addResQueue, updateResQueue, syncResQueue } from '~/apis/modules/resources';
  89. import { CLUSTERS, COMPUTER_RESOURCES, ACC_CARD_TYPE } from '~/const';
  90. import { getListValueWithKey } from '~/utils';
  91. import { formatDate } from 'element-ui/lib/utils/date-util';
  92. export default {
  93. data() {
  94. return {
  95. selCluster: '',
  96. clusterList: [{ k: '', v: this.$t('resourcesManagement.allCluster') }, ...CLUSTERS],
  97. selComputingCenter: '',
  98. computingCenterList: [{ k: '', v: this.$t('resourcesManagement.allAiCenter') }],
  99. selComputingType: '',
  100. computingTypeList: [{ k: '', v: this.$t('resourcesManagement.allComputeResource') }, ...COMPUTER_RESOURCES],
  101. selCardType: '',
  102. cardTypeList: [{ k: '', v: this.$t('resourcesManagement.allAccCardType') }, ...ACC_CARD_TYPE],
  103. syncLoading: false,
  104. loading: false,
  105. tableData: [],
  106. pageInfo: {
  107. curpage: 1,
  108. pageSize: 10,
  109. pageSizes: [10],
  110. total: 0,
  111. },
  112. queueDialogShow: false,
  113. queueDialogType: 'add',
  114. queueDialogData: {},
  115. };
  116. },
  117. components: { QueueDialog },
  118. methods: {
  119. getAiCenterList() {
  120. getAiCenterList().then(res => {
  121. res = res.data;
  122. if (res.Code === 0) {
  123. const list = res.Data;
  124. const data = list.map(item => {
  125. return {
  126. k: item.AiCenterCode,
  127. v: item.AiCenterName
  128. };
  129. });
  130. this.computingCenterList.splice(1, Infinity, ...data);
  131. }
  132. }).catch(err => {
  133. console.log(err);
  134. });
  135. },
  136. getTableData() {
  137. const params = {
  138. cluster: this.selCluster,
  139. center: this.selComputingCenter,
  140. resource: this.selComputingType,
  141. card: this.selCardType,
  142. page: this.pageInfo.curpage,
  143. pagesize: this.pageInfo.pageSize,
  144. };
  145. this.loading = true;
  146. getResQueueList(params).then(res => {
  147. this.loading = false;
  148. res = res.data;
  149. if (res.Code === 0) {
  150. const list = res.Data.List;
  151. const data = list.map((item) => {
  152. return {
  153. ...item,
  154. QueueCode: item.QueueCode || '--',
  155. ClusterName: getListValueWithKey(this.clusterList, item.Cluster),
  156. ComputeResourceName: getListValueWithKey(this.computingTypeList, item.ComputeResource),
  157. AccCardTypeName: getListValueWithKey(this.cardTypeList, item.AccCardType),
  158. UpdatedTimeStr: formatDate(new Date(item.UpdatedTime * 1000), 'yyyy-MM-dd HH:mm:ss'),
  159. }
  160. });
  161. this.tableData = data;
  162. this.pageInfo.total = res.Data.TotalSize;
  163. }
  164. }).catch(err => {
  165. console.log(err);
  166. this.loading = false;
  167. });
  168. },
  169. syncComputerNetwork() {
  170. this.syncLoading = true;
  171. syncResQueue().then(res => {
  172. this.syncLoading = false;
  173. res = res.data;
  174. if (res.Code === 0) {
  175. this.$message({
  176. type: 'success',
  177. message: this.$t('submittedSuccessfully')
  178. });
  179. this.getAiCenterList();
  180. this.getTableData();
  181. } else {
  182. this.$message({
  183. type: 'error',
  184. message: this.$t('submittedFailed')
  185. });
  186. }
  187. }).catch(err => {
  188. console.log(err);
  189. this.syncLoading = false;
  190. this.$message({
  191. type: 'error',
  192. message: this.$t('submittedFailed')
  193. });
  194. });
  195. },
  196. selectChange() {
  197. this.pageInfo.curpage = 1;
  198. this.getTableData();
  199. },
  200. currentChange(val) {
  201. this.pageInfo.curpage = val;
  202. this.getTableData();
  203. },
  204. showDialog(type, data) {
  205. this.queueDialogType = type;
  206. this.queueDialogData = data ? { ...data } : {};
  207. this.queueDialogShow = true;
  208. },
  209. queueDialogConfirm() {
  210. this.queueDialogShow = false;
  211. this.getAiCenterList();
  212. this.getTableData();
  213. }
  214. },
  215. mounted() {
  216. this.getAiCenterList();
  217. this.getTableData();
  218. },
  219. beforeDestroy() {
  220. },
  221. };
  222. </script>
  223. <style scoped lang="less">
  224. .title {
  225. height: 30px;
  226. display: flex;
  227. align-items: center;
  228. margin-bottom: 5px;
  229. span {
  230. font-weight: 700;
  231. font-size: 16px;
  232. color: rgb(16, 16, 16);
  233. }
  234. }
  235. .tools-bar {
  236. display: flex;
  237. align-items: center;
  238. justify-content: space-between;
  239. margin-bottom: 10px;
  240. .select {
  241. margin-right: 10px;
  242. /deep/ .el-input__inner {
  243. border-radius: 0;
  244. }
  245. }
  246. }
  247. .table-container {
  248. margin-bottom: 16px;
  249. /deep/ .el-table__header {
  250. th {
  251. background: rgb(245, 245, 246);
  252. font-size: 12px;
  253. color: rgb(36, 36, 36);
  254. }
  255. }
  256. /deep/ .el-table__body {
  257. td {
  258. font-size: 12px;
  259. }
  260. }
  261. .op-btn {
  262. cursor: pointer;
  263. font-size: 12px;
  264. color: rgb(25, 103, 252);
  265. margin: 0 5px;
  266. }
  267. }
  268. .center {
  269. display: flex;
  270. justify-content: center;
  271. }
  272. </style>