index.vue 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155
  1. <template>
  2. <div class="app-container">
  3. <!-- 搜索 -->
  4. <el-form inline size="mini">
  5. <el-form-item label="音频名称:">
  6. <el-input v-model="form.name" placeholder="请输入音频名称" clearable />
  7. </el-form-item>
  8. <el-form-item label="音频类型:">
  9. <el-select v-model="form.audioType" placeholder="请选择音频类型" clearable>
  10. <el-option v-for="item in audioTypeOptions" :key="item.value" :value="item.value" :label="item.label" />
  11. </el-select>
  12. </el-form-item>
  13. <el-form-item label="资源平台:">
  14. <el-select v-model="form.platformId" placeholder="请选择资源平台" clearable>
  15. <el-option v-for="item in platformOptions" :key="item.value" :value="item.value" :label="item.label" />
  16. </el-select>
  17. </el-form-item>
  18. <el-form-item>
  19. <el-button type="primary" icon="el-icon-search" @click="getSearch">搜索</el-button>
  20. <el-button icon="el-icon-refresh" @click="getRefresh">重置</el-button>
  21. </el-form-item>
  22. </el-form>
  23. <!-- 列表 -->
  24. <el-table :data="tableData" v-loading="loading">
  25. <el-table-column label="异常ID" prop="id" align="center" show-overflow-tooltip />
  26. <el-table-column label="音频ID" prop="audioId" align="center" show-overflow-tooltip />
  27. <el-table-column label="音频名称" prop="name" align="center" show-overflow-tooltip />
  28. <el-table-column label="音频类型" prop="audioType" align="center" :formatter="audioTypeFormatter" />
  29. <el-table-column label="资源平台" prop="platformId" align="center" :formatter="platformIdFormatter" />
  30. <el-table-column label="异常时间" align="center">
  31. <template slot-scope="scope">
  32. {{ parseTime(scope.row.abnormalTime, '{y}-{m}-{d} {h}:{i}:{s}') }}
  33. </template>
  34. </el-table-column>
  35. <el-table-column label="操作" align="center">
  36. <template slot-scope="scope">
  37. <el-button type="text" @click="getDialog(scope.row.id)">查看</el-button>
  38. </template>
  39. </el-table-column>
  40. </el-table>
  41. <pagination v-show="total > 0" :total="total" :page.sync="form.pageNum" :limit.sync="form.pageSize"
  42. @pagination="getList" />
  43. <!-- 弹窗 -->
  44. <el-dialog :visible.sync="dialogVisible" title="详情" width="1000px">
  45. <el-descriptions title="音频信息" :column="2">
  46. <el-descriptions-item label="音频ID">{{ dialogForm.audioId }}</el-descriptions-item>
  47. <el-descriptions-item label="音频名称">{{ dialogForm.name }}</el-descriptions-item>
  48. <el-descriptions-item label="音频类型">{{ this.selectDictLabel(this.audioOptions, dialogForm.audioType)
  49. }}</el-descriptions-item>
  50. <el-descriptions-item label="资源平台">{{ this.selectDictLabel(this.platformOptions, dialogForm.platformId)
  51. }}</el-descriptions-item>
  52. </el-descriptions>
  53. <el-descriptions title="异常信息" :column="2">
  54. <el-descriptions-item label="下线次数">{{ dialogForm.officialCount }}</el-descriptions-item>
  55. <el-descriptions-item label="码率">{{ dialogForm.dialogForm }}</el-descriptions-item>
  56. <el-descriptions-item label="异常ID">{{ dialogForm.id }}</el-descriptions-item>
  57. <el-descriptions-item label="异常时间">
  58. {{ parseTime(dialogForm.abnormalTime, '{y}-{m}-{d} {h}:{i}:{s}') }}
  59. </el-descriptions-item>
  60. </el-descriptions>
  61. </el-dialog>
  62. </div>
  63. </template>
  64. <script>
  65. import { platformMixin, audioMixin } from '@/mixin/index'
  66. import { list, detail } from '@/api/music/monitor'
  67. export default {
  68. mixins: [platformMixin, audioMixin],
  69. data() {
  70. return {
  71. // 遮罩层
  72. loading: false,
  73. // 表单
  74. form: {
  75. pageNum: 1,
  76. pageSize: 10
  77. },
  78. // 列表
  79. tableData: [],
  80. // 总数
  81. total: 0,
  82. // 弹窗
  83. dialogVisible: false,
  84. // 详情
  85. dialogForm: {}
  86. }
  87. },
  88. watch: {
  89. 'form.audioType'(val) {
  90. this.getPlatform(val ? { audioType: val } : {})
  91. },
  92. 'form.platformId'(val) {
  93. if (val) {
  94. this.getAudioType(val)
  95. } else {
  96. this.audioTypeOptions = this.audioOptions
  97. }
  98. }
  99. },
  100. mounted() {
  101. this.getPlatform({})
  102. this.audioTypeOptions = this.audioOptions
  103. this.getList()
  104. },
  105. methods: {
  106. // 列表
  107. getList() {
  108. this.loading = true
  109. list(this.form).then(res => {
  110. if (res.code === 0) {
  111. this.tableData = res.data.records
  112. this.total = res.data.total
  113. this.loading = false
  114. }
  115. })
  116. },
  117. // 搜索
  118. getSearch() {
  119. this.form.pageNum = 1
  120. this.getList()
  121. },
  122. // 重置
  123. getRefresh() {
  124. this.form = {
  125. pageNum: 1,
  126. pageSize: 10
  127. }
  128. this.getList()
  129. },
  130. // 弹窗
  131. getDialog(id) {
  132. this.dialogVisible = true
  133. detail(id).then(res => {
  134. if (res.code === 0) {
  135. this.dialogForm = res.data
  136. }
  137. })
  138. },
  139. // 翻译
  140. audioTypeFormatter(row) {
  141. return this.selectDictLabel(this.audioOptions, row.audioType)
  142. },
  143. platformIdFormatter(row) {
  144. return this.selectDictLabel(this.platformTypeOptions, row.platformId)
  145. }
  146. }
  147. }
  148. </script>
  149. <style lang="scss" scoped></style>