list.vue 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237
  1. <template>
  2. <div class="app-container">
  3. <!-- 顶部操作区域 -->
  4. <div class="filter-container">
  5. <manage-tab @change="handleChange" />
  6. <div v-if="listQuery.type === 5">
  7. <el-tabs v-model="listQuery.allStatus" @tab-click="handleChange(listQuery.type)">
  8. <el-tab-pane label="企业话术" name="1" />
  9. <el-tab-pane label="个人话术" name="2" />
  10. </el-tabs>
  11. </div>
  12. <div class="filter-control">
  13. <span>标题:</span>
  14. <el-input
  15. v-model="listQuery.title"
  16. placeholder="标题"
  17. clearable
  18. @keyup.enter.native="handleChange(listQuery.type)"
  19. @clear="handleChange(listQuery.type)"
  20. />
  21. </div>
  22. <div v-if="listQuery.allStatus !== '2'" class="filter-control">
  23. <span>用户阶段:</span>
  24. <el-select v-model="listQuery.stageStatus" placeholder="用户阶段" @change="handleChange(listQuery.type)">
  25. <el-option
  26. v-for="(i, index) in userClass"
  27. :key="index"
  28. :label="i.value"
  29. :value="i.id"
  30. />
  31. </el-select>
  32. </div>
  33. <div v-if="listQuery.allStatus !== '2'" class="filter-control">
  34. <span>标签:</span>
  35. <data-select :is-edit="false" :is-multiple="true" @handle-emit="handleSelect" />
  36. </div>
  37. <div v-if="listQuery.allStatus === '2'" class="filter-control">
  38. <span>上传者:</span>
  39. <el-select v-model="listQuery.spId" placeholder="上传者" @change="handleChange(listQuery.type)">
  40. <el-option
  41. v-for="item in sellerList"
  42. :key="item.serviceProviderId"
  43. :label="item.linkMan"
  44. :value="item.serviceProviderId"
  45. />
  46. </el-select>
  47. </div>
  48. <div class="filter-control">
  49. <el-button type="primary" @click="handleChange(listQuery.type)">查询</el-button>
  50. <el-button v-if="listQuery.allStatus !== '2'" type="primary" @click="$router.push('/database/store-list/data-manage/edit?id=' + id + '&t=' + listQuery.type)">添加</el-button>
  51. <el-button v-if="listQuery.allStatus !== '2'" type="primary" @click="exportDialogVisible = true">删除</el-button>
  52. </div>
  53. </div>
  54. <el-table
  55. ref="table"
  56. v-loading="isLoading"
  57. :data="list"
  58. border
  59. >
  60. <el-table-column
  61. label="ID"
  62. prop="id"
  63. align="center"
  64. width="80"
  65. />
  66. <el-table-column prop="title" label="标题" align="center" />
  67. <el-table-column prop="stageStatus" label="用户阶段" align="center">
  68. <template slot-scope="scope">
  69. <div>
  70. {{ scope.row.stageStatus | userStateFilter(userClass) }}
  71. </div>
  72. </template>
  73. </el-table-column>
  74. <el-table-column prop="labelIds" label="标签" align="center">
  75. <template slot-scope="scope">
  76. <div>
  77. {{ scope.row.keywords }}
  78. </div>
  79. </template>
  80. </el-table-column>
  81. <el-table-column prop="pv" label="浏览量" align="center" />
  82. <el-table-column prop="addTime" label="添加时间" align="center" />
  83. <el-table-column prop="createBy" label="创建人" align="center" />
  84. <el-table-column label="操作" align="center" width="250">
  85. <template slot-scope="{ row }">
  86. <div class="labelCenter">
  87. <el-button
  88. v-if="listQuery.allStatus === '1'"
  89. type="primary"
  90. size="mini"
  91. @click="$router.push('/database/store-list/data-manage/edit?id=' + id + '&t=' + listQuery.type + '&tId=' + row.id)"
  92. >编辑</el-button>
  93. <el-button
  94. v-if="listQuery.allStatus === '1'"
  95. type="primary"
  96. size="mini"
  97. @click="
  98. handleDelete({ ids: row.id, productArchiveId: id, type: listQuery.type.toString() })
  99. "
  100. >删除</el-button>
  101. <el-button
  102. v-if="listQuery.type === 5 && listQuery.allStatus === '2'"
  103. type="primary"
  104. size="mini"
  105. @click="
  106. $router.push('/database/store-list/data-manage/edit?id=' + row.id)
  107. "
  108. >查看</el-button>
  109. </div>
  110. </template>
  111. </el-table-column>
  112. </el-table>
  113. <!-- 页码 -->
  114. <pagination
  115. :total="total"
  116. :page.sync="listQuery.pageNum"
  117. :limit.sync="listQuery.pageSize"
  118. @pagination="handleChange(listQuery.type)"
  119. />
  120. <el-dialog title="选择商品" :visible.sync="exportDialogVisible" width="70%">
  121. <data-list-selector
  122. v-if="exportDialogVisible"
  123. :type-id="listQuery.type"
  124. @cancel="onSelectorCancel"
  125. @confirm="onSelectorConfirm"
  126. />
  127. </el-dialog>
  128. </div>
  129. </template>
  130. <script>
  131. import ManageTab from '../../components/dataManageTab.vue'
  132. import DataListSelector from '../../components/dialogTypeTable.vue'
  133. import databaseMixin from '../../mixins/index'
  134. import { getContextList, deleteContext } from '@/api/contentLibrary/context'
  135. import dataSelect from '../../components/data-select.vue'
  136. export default {
  137. components: {
  138. ManageTab,
  139. DataListSelector,
  140. dataSelect
  141. },
  142. mixins: [databaseMixin],
  143. data() {
  144. return {
  145. listQuery: {
  146. type: '',
  147. pageNum: 1,
  148. pageSize: 10,
  149. labelIds: '',
  150. stageStatus: '',
  151. allStatus: '1',
  152. spId: ''
  153. },
  154. list: [],
  155. total: 0,
  156. isLoading: false,
  157. exportDialogVisible: false
  158. }
  159. },
  160. watch: {
  161. 'listQuery.allStatus': {
  162. handler(val) {
  163. if (val) {
  164. this.listQuery.labelIds = ''
  165. this.listQuery.spId = ''
  166. }
  167. }
  168. }
  169. },
  170. mounted() {
  171. this.getServiceList()
  172. },
  173. methods: {
  174. async getInfo() {
  175. this.isLoading = true
  176. const { data } = await getContextList(Object.assign(this.listQuery, { productArchiveId: this.id, productId: this.pId || '' }))
  177. this.list = data.results
  178. this.total = data.totalRecord
  179. this.isLoading = false
  180. },
  181. handleSelect($event) {
  182. this.listQuery.labelIds = $event.join(',')
  183. this.handleChange(this.listQuery.type)
  184. },
  185. handleChange($event) {
  186. if (this.id && $event) {
  187. this.listQuery.type = Number($event)
  188. this.isLoading = true
  189. this.getInfo()
  190. }
  191. },
  192. handleDelete(val) {
  193. this.$confirm(`是否删除该资料?`, '提示', {
  194. confirmButtonText: '确定',
  195. cancelButtonText: '取消',
  196. type: 'warning'
  197. }).then(async() => {
  198. try {
  199. const form = new FormData()
  200. form.append('ids', val.ids)
  201. form.append('type', val.type)
  202. form.append('productArchiveId', val.productArchiveId)
  203. await deleteContext(form)
  204. this.$message({
  205. message: '删除成功',
  206. type: 'success'
  207. })
  208. this.handleChange(this.listQuery.type)
  209. } catch (error) {
  210. console.error(error)
  211. }
  212. })
  213. },
  214. onSelectorCancel() {
  215. this.exportDialogVisible = false
  216. },
  217. onSelectorConfirm(row) {
  218. console.log(row)
  219. this.handleDelete({ ids: row.map(e => e.id).join(','), type: this.listQuery.type.toString(), productArchiveId: this.id })
  220. this.exportDialogVisible = false
  221. }
  222. }
  223. }
  224. </script>
  225. <style lang="scss" scoped>
  226. ::v-deep .el-tabs__nav-wrap::after {
  227. background: none;
  228. }
  229. </style>