|
@@ -5,7 +5,7 @@
|
|
<manage-tab @change="handleChange" />
|
|
<manage-tab @change="handleChange" />
|
|
|
|
|
|
<div v-if="listQuery.type === 5">
|
|
<div v-if="listQuery.type === 5">
|
|
- <el-tabs v-model="listQuery.type2">
|
|
|
|
|
|
+ <el-tabs v-model="listQuery.allStatus" @tab-click="handleChange(listQuery.type)">
|
|
<el-tab-pane label="企业话术" name="1" />
|
|
<el-tab-pane label="企业话术" name="1" />
|
|
<el-tab-pane label="个人话术" name="2" />
|
|
<el-tab-pane label="个人话术" name="2" />
|
|
</el-tabs>
|
|
</el-tabs>
|
|
@@ -14,16 +14,16 @@
|
|
<div class="filter-control">
|
|
<div class="filter-control">
|
|
<span>标题:</span>
|
|
<span>标题:</span>
|
|
<el-input
|
|
<el-input
|
|
- v-model="listQuery.name"
|
|
|
|
|
|
+ v-model="listQuery.title"
|
|
placeholder="标题"
|
|
placeholder="标题"
|
|
clearable
|
|
clearable
|
|
@keyup.enter.native="handleChange(listQuery.type)"
|
|
@keyup.enter.native="handleChange(listQuery.type)"
|
|
@clear="handleChange(listQuery.type)"
|
|
@clear="handleChange(listQuery.type)"
|
|
/>
|
|
/>
|
|
</div>
|
|
</div>
|
|
- <div v-if="listQuery.type !== 5" class="filter-control">
|
|
|
|
|
|
+ <div v-if="listQuery.allStatus !== '2'" class="filter-control">
|
|
<span>用户阶段:</span>
|
|
<span>用户阶段:</span>
|
|
- <el-select v-model="listQuery.userClass" placeholder="用户阶段" @change="handleChange(listQuery.type)">
|
|
|
|
|
|
+ <el-select v-model="listQuery.stageStatus" placeholder="用户阶段" @change="handleChange(listQuery.type)">
|
|
<el-option
|
|
<el-option
|
|
v-for="(i, index) in userClass"
|
|
v-for="(i, index) in userClass"
|
|
:key="index"
|
|
:key="index"
|
|
@@ -32,32 +32,25 @@
|
|
/>
|
|
/>
|
|
</el-select>
|
|
</el-select>
|
|
</div>
|
|
</div>
|
|
- <div v-if="listQuery.type !== 5" class="filter-control">
|
|
|
|
|
|
+ <div v-if="listQuery.allStatus !== '2'" class="filter-control">
|
|
<span>标签:</span>
|
|
<span>标签:</span>
|
|
- <el-select v-model="listQuery.userType" placeholder="标签" @change="handleChange(listQuery.type)">
|
|
|
|
- <el-option
|
|
|
|
- v-for="(i, index) in userType"
|
|
|
|
- :key="index"
|
|
|
|
- :label="i.value"
|
|
|
|
- :value="i.id"
|
|
|
|
- />
|
|
|
|
- </el-select>
|
|
|
|
|
|
+ <data-select :is-edit="false" :is-multiple="true" @handle-emit="handleSelect" />
|
|
</div>
|
|
</div>
|
|
- <div v-if="listQuery.type === 5" class="filter-control">
|
|
|
|
|
|
+ <div v-if="listQuery.allStatus === '2'" class="filter-control">
|
|
<span>上传者:</span>
|
|
<span>上传者:</span>
|
|
- <el-select v-model="listQuery.userClass" placeholder="上传者" @change="handleChange(listQuery.type)">
|
|
|
|
|
|
+ <el-select v-model="listQuery.spId" placeholder="上传者" @change="handleChange(listQuery.type)">
|
|
<el-option
|
|
<el-option
|
|
- v-for="(i, index) in userClass"
|
|
|
|
- :key="index"
|
|
|
|
- :label="i.value"
|
|
|
|
- :value="i.id"
|
|
|
|
|
|
+ v-for="item in sellerList"
|
|
|
|
+ :key="item.serviceProviderId"
|
|
|
|
+ :label="item.linkMan"
|
|
|
|
+ :value="item.serviceProviderId"
|
|
/>
|
|
/>
|
|
</el-select>
|
|
</el-select>
|
|
</div>
|
|
</div>
|
|
<div class="filter-control">
|
|
<div class="filter-control">
|
|
<el-button type="primary" @click="handleChange(listQuery.type)">查询</el-button>
|
|
<el-button type="primary" @click="handleChange(listQuery.type)">查询</el-button>
|
|
- <el-button v-if="listQuery.type !== 5" type="primary" @click="$router.push('/database/store-list/data-manage/edit?id=' + id + '&t=' + listQuery.type)">添加</el-button>
|
|
|
|
- <el-button v-if="listQuery.type !== 5" type="primary" @click="exportDialogVisible = true">删除</el-button>
|
|
|
|
|
|
+ <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>
|
|
|
|
+ <el-button v-if="listQuery.allStatus !== '2'" type="primary" @click="exportDialogVisible = true">删除</el-button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
|
|
@@ -67,50 +60,49 @@
|
|
:data="list"
|
|
:data="list"
|
|
border
|
|
border
|
|
>
|
|
>
|
|
- <!--<el-table-column type="selection" width="55" align="center" />-->
|
|
|
|
<el-table-column
|
|
<el-table-column
|
|
label="ID"
|
|
label="ID"
|
|
prop="id"
|
|
prop="id"
|
|
align="center"
|
|
align="center"
|
|
width="80"
|
|
width="80"
|
|
/>
|
|
/>
|
|
- <el-table-column prop="serviceLevel" label="标题" align="center" />
|
|
|
|
- <el-table-column prop="userClass" label="用户阶段" align="center">
|
|
|
|
|
|
+ <el-table-column prop="title" label="标题" align="center" />
|
|
|
|
+ <el-table-column prop="stageStatus" label="用户阶段" align="center">
|
|
<template slot-scope="scope">
|
|
<template slot-scope="scope">
|
|
<div>
|
|
<div>
|
|
- {{ scope.row.userClass | userStateFilter(userClass) }}
|
|
|
|
|
|
+ {{ scope.row.stageStatus | userStateFilter(userClass) }}
|
|
</div>
|
|
</div>
|
|
</template>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table-column>
|
|
- <el-table-column prop="userType" label="标签" align="center">
|
|
|
|
|
|
+ <el-table-column prop="labelIds" label="标签" align="center">
|
|
<template slot-scope="scope">
|
|
<template slot-scope="scope">
|
|
<div>
|
|
<div>
|
|
- {{ scope.row.userType | userTypeFilter(userType) }}
|
|
|
|
|
|
+ {{ scope.row.keywords }}
|
|
</div>
|
|
</div>
|
|
</template>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table-column>
|
|
- <el-table-column prop="contractStartDate" label="浏览量" align="center" />
|
|
|
|
- <el-table-column prop="contractStartDate" label="添加时间" align="center" />
|
|
|
|
- <el-table-column prop="contractStartDate" label="创建人" align="center" />
|
|
|
|
|
|
+ <el-table-column prop="pv" label="浏览量" align="center" />
|
|
|
|
+ <el-table-column prop="addTime" label="添加时间" align="center" />
|
|
|
|
+ <el-table-column prop="createBy" label="创建人" align="center" />
|
|
<el-table-column label="操作" align="center" width="250">
|
|
<el-table-column label="操作" align="center" width="250">
|
|
<template slot-scope="{ row }">
|
|
<template slot-scope="{ row }">
|
|
<div class="labelCenter">
|
|
<div class="labelCenter">
|
|
<el-button
|
|
<el-button
|
|
- v-if="listQuery.type2 === '1'"
|
|
|
|
|
|
+ v-if="listQuery.allStatus === '1'"
|
|
type="primary"
|
|
type="primary"
|
|
size="mini"
|
|
size="mini"
|
|
@click="$router.push('/database/store-list/data-manage/edit?id=' + id + '&t=' + listQuery.type + '&tId=' + row.id)"
|
|
@click="$router.push('/database/store-list/data-manage/edit?id=' + id + '&t=' + listQuery.type + '&tId=' + row.id)"
|
|
>编辑</el-button>
|
|
>编辑</el-button>
|
|
<el-button
|
|
<el-button
|
|
- v-if="listQuery.type2 === '1'"
|
|
|
|
|
|
+ v-if="listQuery.allStatus === '1'"
|
|
type="primary"
|
|
type="primary"
|
|
size="mini"
|
|
size="mini"
|
|
@click="
|
|
@click="
|
|
- handleDelete(row.id)
|
|
|
|
|
|
+ handleDelete({ ids: row.id, productArchiveId: id, type: listQuery.type.toString() })
|
|
"
|
|
"
|
|
>删除</el-button>
|
|
>删除</el-button>
|
|
<el-button
|
|
<el-button
|
|
- v-if="listQuery.type === 5 && listQuery.type2 === '2'"
|
|
|
|
|
|
+ v-if="listQuery.type === 5 && listQuery.allStatus === '2'"
|
|
type="primary"
|
|
type="primary"
|
|
size="mini"
|
|
size="mini"
|
|
@click="
|
|
@click="
|
|
@@ -133,6 +125,7 @@
|
|
<el-dialog title="选择商品" :visible.sync="exportDialogVisible" width="70%">
|
|
<el-dialog title="选择商品" :visible.sync="exportDialogVisible" width="70%">
|
|
<data-list-selector
|
|
<data-list-selector
|
|
v-if="exportDialogVisible"
|
|
v-if="exportDialogVisible"
|
|
|
|
+ :type-id="listQuery.type"
|
|
@cancel="onSelectorCancel"
|
|
@cancel="onSelectorCancel"
|
|
@confirm="onSelectorConfirm"
|
|
@confirm="onSelectorConfirm"
|
|
/>
|
|
/>
|
|
@@ -142,13 +135,16 @@
|
|
|
|
|
|
<script>
|
|
<script>
|
|
import ManageTab from '../../components/dataManageTab.vue'
|
|
import ManageTab from '../../components/dataManageTab.vue'
|
|
-import DataListSelector from '../../components/dialogTable.vue'
|
|
|
|
|
|
+import DataListSelector from '../../components/dialogTypeTable.vue'
|
|
import databaseMixin from '../../mixins/index'
|
|
import databaseMixin from '../../mixins/index'
|
|
|
|
+import { getContextList, deleteContext } from '@/api/contentLibrary/context'
|
|
|
|
+import dataSelect from '../../components/data-select.vue'
|
|
|
|
|
|
export default {
|
|
export default {
|
|
components: {
|
|
components: {
|
|
ManageTab,
|
|
ManageTab,
|
|
- DataListSelector
|
|
|
|
|
|
+ DataListSelector,
|
|
|
|
+ dataSelect
|
|
},
|
|
},
|
|
mixins: [databaseMixin],
|
|
mixins: [databaseMixin],
|
|
data() {
|
|
data() {
|
|
@@ -157,37 +153,79 @@ export default {
|
|
type: '',
|
|
type: '',
|
|
pageNum: 1,
|
|
pageNum: 1,
|
|
pageSize: 10,
|
|
pageSize: 10,
|
|
- userType: 0,
|
|
|
|
- userClass: 0,
|
|
|
|
- type2: '1'
|
|
|
|
|
|
+ labelIds: '',
|
|
|
|
+ stageStatus: '',
|
|
|
|
+ allStatus: '1',
|
|
|
|
+ spId: ''
|
|
},
|
|
},
|
|
- list: [
|
|
|
|
- {
|
|
|
|
- id: 1,
|
|
|
|
- userClass: 1,
|
|
|
|
- userType: 1
|
|
|
|
- }
|
|
|
|
- ],
|
|
|
|
|
|
+ list: [],
|
|
total: 0,
|
|
total: 0,
|
|
isLoading: false,
|
|
isLoading: false,
|
|
exportDialogVisible: false
|
|
exportDialogVisible: false
|
|
}
|
|
}
|
|
},
|
|
},
|
|
|
|
+ watch: {
|
|
|
|
+ 'listQuery.allStatus': {
|
|
|
|
+ handler(val) {
|
|
|
|
+ if (val) {
|
|
|
|
+ this.listQuery.labelIds = ''
|
|
|
|
+ this.listQuery.spId = ''
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ },
|
|
|
|
+ mounted() {
|
|
|
|
+ this.getServiceList()
|
|
|
|
+ },
|
|
methods: {
|
|
methods: {
|
|
- getInfo() {
|
|
|
|
|
|
+ async getInfo() {
|
|
|
|
+ this.isLoading = true
|
|
|
|
+ const { data } = await getContextList(Object.assign(this.listQuery, { productArchiveId: this.id, productId: this.pId || '' }))
|
|
|
|
+ this.list = data.results
|
|
|
|
+ this.total = data.totalRecord
|
|
this.isLoading = false
|
|
this.isLoading = false
|
|
},
|
|
},
|
|
|
|
+ handleSelect($event) {
|
|
|
|
+ this.listQuery.labelIds = $event.join(',')
|
|
|
|
+ this.handleChange(this.listQuery.type)
|
|
|
|
+ },
|
|
handleChange($event) {
|
|
handleChange($event) {
|
|
if (this.id && $event) {
|
|
if (this.id && $event) {
|
|
this.listQuery.type = Number($event)
|
|
this.listQuery.type = Number($event)
|
|
- this.listQuery.type2 = '1'
|
|
|
|
this.isLoading = true
|
|
this.isLoading = true
|
|
this.getInfo()
|
|
this.getInfo()
|
|
}
|
|
}
|
|
},
|
|
},
|
|
- handleDelete(val) {},
|
|
|
|
- onSelectorCancel() {},
|
|
|
|
- onSelectorConfirm() {}
|
|
|
|
|
|
+ handleDelete(val) {
|
|
|
|
+ this.$confirm(`是否删除该资料?`, '提示', {
|
|
|
|
+ confirmButtonText: '确定',
|
|
|
|
+ cancelButtonText: '取消',
|
|
|
|
+ type: 'warning'
|
|
|
|
+ }).then(async() => {
|
|
|
|
+ try {
|
|
|
|
+ const form = new FormData()
|
|
|
|
+ form.append('ids', val.ids)
|
|
|
|
+ form.append('type', val.type)
|
|
|
|
+ form.append('productArchiveId', val.productArchiveId)
|
|
|
|
+ await deleteContext(form)
|
|
|
|
+ this.$message({
|
|
|
|
+ message: '删除成功',
|
|
|
|
+ type: 'success'
|
|
|
|
+ })
|
|
|
|
+ this.handleChange(this.listQuery.type)
|
|
|
|
+ } catch (error) {
|
|
|
|
+ console.error(error)
|
|
|
|
+ }
|
|
|
|
+ })
|
|
|
|
+ },
|
|
|
|
+ onSelectorCancel() {
|
|
|
|
+ this.exportDialogVisible = false
|
|
|
|
+ },
|
|
|
|
+ onSelectorConfirm(row) {
|
|
|
|
+ console.log(row)
|
|
|
|
+ this.handleDelete({ ids: row.map(e => e.id).join(','), type: this.listQuery.type.toString(), productArchiveId: this.id })
|
|
|
|
+ this.exportDialogVisible = false
|
|
|
|
+ }
|
|
}
|
|
}
|
|
}
|
|
}
|
|
</script>
|
|
</script>
|