AdminDubboService.vue 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  1. <template>
  2. <el-container>
  3. <el-header height="220">
  4. <el-row style="margin-top: 10px">
  5. <el-select
  6. v-model="queryInfo.path"
  7. clearable
  8. placeholder="查询条件"
  9. style="margin-left: 5px"
  10. @change="onSelectChange"
  11. >
  12. <el-option v-for="(item, index) in tableList" :key="index" :label="item" :value="item" />
  13. </el-select>
  14. </el-row>
  15. <el-row style="margin-top: 10px">
  16. <el-tag v-for="(item, index) in tableList" :key="index" style="margin-left: 5px" :type="'warning'" disable-transitions>
  17. {{ item }}
  18. </el-tag>
  19. </el-row>
  20. </el-header>
  21. <el-main>
  22. <el-table
  23. :data="dataList"
  24. border
  25. style="width: 100%"
  26. >
  27. <el-table-column
  28. fixed="left"
  29. label="No"
  30. type="index"
  31. />
  32. <el-table-column
  33. prop="application"
  34. label="应用"
  35. />
  36. <el-table-column
  37. prop="total"
  38. label="节点数量"
  39. />
  40. <el-table-column
  41. prop="hostPorts"
  42. label="节点地址"
  43. />
  44. <el-table-column
  45. prop="role"
  46. label="角色"
  47. />
  48. <el-table-column
  49. fixed="right"
  50. label="操作"
  51. width="280"
  52. >
  53. <template slot-scope="scope">
  54. <el-button
  55. size="mini"
  56. @click="handleEdit(scope.$index, scope.row)"
  57. >编辑</el-button>
  58. <el-button
  59. size="mini"
  60. type="danger"
  61. @click="handleDelete(scope.$index, scope.row)"
  62. >删除</el-button>
  63. </template>
  64. </el-table-column>
  65. </el-table>
  66. </el-main>
  67. <el-dialog
  68. append-to-body
  69. :visible.sync="showEditScopeDialog"
  70. width="30%"
  71. center
  72. >
  73. <el-card class="box-card">
  74. <div slot="header" class="clearfix">
  75. <span>修改视频可见范围</span>
  76. <el-button style="float: right; padding: 3px 0" type="text" @click="onUpdateScope">更新</el-button>
  77. </div>
  78. <div class="text item">
  79. <el-select v-model="form.scope" placeholder="选择可见范围">
  80. <el-option label="本人可见" value="1" />
  81. <el-option label="所有人可见" value="2" />
  82. <el-option label="VIP 可见" value="3" />
  83. <el-option label="验证码可见" value="4" />
  84. </el-select>
  85. </div>
  86. </el-card>
  87. </el-dialog>
  88. </el-container>
  89. </template>
  90. <script>
  91. import { getDubboList, getZkList, getZkService } from '@/api/tnb'
  92. export default {
  93. name: 'AdminDubboService',
  94. data() {
  95. return {
  96. queryInfo: {
  97. path: null
  98. },
  99. // 屏幕宽度, 为了控制分页条的大小
  100. screenWidth: document.body.clientWidth,
  101. currentPage: 1,
  102. pageSize: 12,
  103. totalSize: 0,
  104. dataList: [],
  105. nextId: 0,
  106. tableList: [],
  107. // **********************************************************************
  108. showEditScopeDialog: false,
  109. form: {
  110. videoId: null,
  111. scope: 1
  112. }
  113. }
  114. },
  115. created() {
  116. document.title = 'Dubbo 服务'
  117. this.getData()
  118. },
  119. methods: {
  120. getData() {
  121. this.dataList = []
  122. getZkList().then(resp => {
  123. if (resp.code === 0) {
  124. this.tableList = resp.data
  125. } else {
  126. this.$message.error(resp.msg)
  127. }
  128. })
  129. getDubboList().then(resp => {
  130. if (resp.code === 0) {
  131. this.dataList = resp.data
  132. } else {
  133. this.$message.error(resp.msg)
  134. }
  135. })
  136. },
  137. onRefresh() {
  138. this.getData()
  139. },
  140. handleCurrentChange(pageNumber) {
  141. this.currentPage = pageNumber
  142. this.getData()
  143. // 回到顶部
  144. scrollTo(0, 0)
  145. },
  146. handleEdit(index, row) {
  147. this.$message.info('handleEdit')
  148. },
  149. handleDelete(index, row) {
  150. this.$confirm('确定要删除 ' + row.title + '?', '提示', {
  151. confirmButtonText: '确定',
  152. cancelButtonText: '取消',
  153. type: 'warning'
  154. }).then(() => {
  155. this.$message.info('handleDelete')
  156. }).catch(() => {
  157. this.$message({
  158. type: 'info',
  159. message: '已取消'
  160. })
  161. })
  162. },
  163. onUpdateScope() {
  164. this.showEditScopeDialog = false
  165. },
  166. onSelectChange() {
  167. this.dataList = []
  168. getZkService(this.queryInfo).then(resp => {
  169. if (resp.code === 0) {
  170. this.dataList = resp.data
  171. } else {
  172. this.$message.error(resp.msg)
  173. }
  174. })
  175. },
  176. handleClose() {
  177. }
  178. }
  179. }
  180. </script>
  181. <style>
  182. </style>