| 1 |
- {"remainingRequest":"C:\\Users\\Administrator\\Desktop\\crmeb5.0\\template\\admin\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!C:\\Users\\Administrator\\Desktop\\crmeb5.0\\template\\admin\\src\\pages\\cms\\article\\index.vue?vue&type=style&index=0&id=316a1642&lang=scss&scoped=true","dependencies":[{"path":"C:\\Users\\Administrator\\Desktop\\crmeb5.0\\template\\admin\\src\\pages\\cms\\article\\index.vue","mtime":1761185180079},{"path":"C:\\Users\\Administrator\\Desktop\\crmeb5.0\\template\\admin\\node_modules\\css-loader\\index.js","mtime":499162500000},{"path":"C:\\Users\\Administrator\\Desktop\\crmeb5.0\\template\\admin\\node_modules\\vue-loader\\lib\\loaders\\stylePostLoader.js","mtime":499162500000},{"path":"C:\\Users\\Administrator\\Desktop\\crmeb5.0\\template\\admin\\node_modules\\postcss-loader\\src\\index.js","mtime":499162500000},{"path":"C:\\Users\\Administrator\\Desktop\\crmeb5.0\\template\\admin\\node_modules\\sass-loader\\dist\\cjs.js","mtime":499162500000},{"path":"C:\\Users\\Administrator\\Desktop\\crmeb5.0\\template\\admin\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"C:\\Users\\Administrator\\Desktop\\crmeb5.0\\template\\admin\\node_modules\\vue-loader\\lib\\index.js","mtime":499162500000}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:DQoudHJlZVNlbCA6OnYtZGVlcCAuaXZ1LXNlbGVjdC1kcm9wZG93bi1saXN0IHsNCiAgcGFkZGluZzogMCAxMHB4ICFpbXBvcnRhbnQ7DQogIGJveC1zaXppbmc6IGJvcmRlci1ib3g7DQp9DQoudGFiQm94X2ltZyB7DQogIHdpZHRoOiAzNnB4Ow0KICBoZWlnaHQ6IDM2cHg7DQogIGJvcmRlci1yYWRpdXM6IDRweDsNCiAgY3Vyc29yOiBwb2ludGVyOw0KDQogIGltZyB7DQogICAgd2lkdGg6IDEwMCU7DQogICAgaGVpZ2h0OiAxMDAlOw0KICB9DQp9DQo="},{"version":3,"sources":["index.vue"],"names":[],"mappings":";AAuTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA","file":"index.vue","sourceRoot":"src/pages/cms/article","sourcesContent":["<template>\r\n <div>\r\n <el-card :bordered=\"false\" shadow=\"never\" class=\"ivu-mb-16\" :body-style=\"{ padding: 0 }\">\r\n <div class=\"padding-add\">\r\n <el-form\r\n ref=\"artFrom\"\r\n :model=\"artFrom\"\r\n :label-width=\"labelWidth\"\r\n label-position=\"right\"\r\n @submit.native.prevent\r\n inline\r\n >\r\n <el-form-item label=\"文章分类:\" label-for=\"pid\">\r\n <el-cascader\r\n v-model=\"artFrom.pid\"\r\n placeholder=\"请选择\"\r\n class=\"treeSel\"\r\n @change=\"handleCheckChange\"\r\n :options=\"treeData\"\r\n :props=\"props\"\r\n style=\"width: 250px\"\r\n >\r\n </el-cascader>\r\n </el-form-item>\r\n <el-form-item label=\"文章搜索:\" label-for=\"title\">\r\n <el-input clearable placeholder=\"请输入\" v-model=\"artFrom.title\" class=\"form_content_width\" />\r\n </el-form-item>\r\n <el-form-item>\r\n <el-button type=\"primary\" v-db-click @click=\"userSearchs\">查询</el-button>\r\n </el-form-item>\r\n </el-form>\r\n </div>\r\n </el-card>\r\n <el-card :bordered=\"false\" shadow=\"never\" class=\"ivu-mt\">\r\n <router-link :to=\"$routeProStr + '/cms/article/add_article'\" v-auth=\"['cms-article-creat']\"\r\n ><el-button type=\"primary\" class=\"bnt\">添加文章</el-button></router-link\r\n >\r\n <el-table\r\n :data=\"cmsList\"\r\n ref=\"table\"\r\n class=\"mt14\"\r\n v-loading=\"loading\"\r\n highlight-current-row\r\n no-userFrom-text=\"暂无数据\"\r\n no-filtered-userFrom-text=\"暂无筛选结果\"\r\n >\r\n <el-table-column label=\"ID\" width=\"80\">\r\n <template slot-scope=\"scope\">\r\n <span>{{ scope.row.id }}</span>\r\n </template>\r\n </el-table-column>\r\n <el-table-column label=\"文章图片\" min-width=\"90\">\r\n <template slot-scope=\"scope\">\r\n <div v-if=\"scope.row.image_input.length !== 0\" v-viewer>\r\n <div class=\"tabBox_img\" v-for=\"(item, index) in scope.row.image_input\" :key=\"index\">\r\n <img v-lazy=\"item\" />\r\n </div>\r\n </div>\r\n </template>\r\n </el-table-column>\r\n <el-table-column label=\"文章名称\" min-width=\"130\">\r\n <template slot-scope=\"scope\">\r\n <el-tooltip placement=\"top\" :open-delay=\"600\">\r\n <div slot=\"content\">{{ ' [ ' + scope.row.catename + ' ] ' + scope.row.title }}</div>\r\n <span class=\"line2\">{{ scope.row.title }}</span>\r\n </el-tooltip>\r\n </template>\r\n </el-table-column>\r\n <el-table-column label=\"关联商品\" min-width=\"130\">\r\n <template slot-scope=\"scope\">\r\n <span>{{ scope.row.store_name }}</span>\r\n </template>\r\n </el-table-column>\r\n <el-table-column label=\"浏览量\" min-width=\"80\">\r\n <template slot-scope=\"scope\">\r\n <span>{{ scope.row.visit }}</span>\r\n </template>\r\n </el-table-column>\r\n <el-table-column label=\"时间\" min-width=\"130\">\r\n <template slot-scope=\"scope\">\r\n <span>{{ scope.row.add_time | formatDate }}</span>\r\n </template>\r\n </el-table-column>\r\n <el-table-column label=\"操作\" fixed=\"right\" width=\"210\">\r\n <template slot-scope=\"scope\">\r\n <a v-db-click @click=\"edit(scope.row)\">编辑</a>\r\n <el-divider direction=\"vertical\"></el-divider>\r\n <a v-db-click @click=\"artRelation(scope.row, '取消关联', index)\">{{\r\n scope.row.product_id === 0 ? '关联' : '取消关联'\r\n }}</a>\r\n <el-divider direction=\"vertical\"></el-divider>\r\n <a v-db-click @click=\"del(scope.row, '删除文章', scope.$index)\">删除</a>\r\n <el-divider direction=\"vertical\"></el-divider>\r\n <el-dropdown size=\"small\" @command=\"onCopy(scope.row, $event)\" :transfer=\"true\">\r\n <span class=\"el-dropdown-link\">复制链接<i class=\"el-icon-arrow-down el-icon--right\"></i></span>\r\n <el-dropdown-menu slot=\"dropdown\">\r\n <el-dropdown-item command=\"1\">移动端链接</el-dropdown-item>\r\n <el-dropdown-item command=\"2\">PC端链接</el-dropdown-item>\r\n </el-dropdown-menu>\r\n </el-dropdown>\r\n </template>\r\n </el-table-column>\r\n </el-table>\r\n <div class=\"acea-row row-right page\">\r\n <pagination\r\n v-if=\"total\"\r\n :total=\"total\"\r\n :page.sync=\"artFrom.page\"\r\n :limit.sync=\"artFrom.limit\"\r\n @pagination=\"getList\"\r\n />\r\n </div>\r\n </el-card>\r\n <!--关联-->\r\n <el-dialog :visible.sync=\"modals\" title=\"商品列表\" class=\"paymentFooter\" width=\"1000px\" @closed=\"cancel\">\r\n <goods-list ref=\"goodslist\" @getProductId=\"getProductId\" v-if=\"modals\"></goods-list>\r\n </el-dialog>\r\n </div>\r\n</template>\r\n\r\n<script>\r\nimport { mapState } from 'vuex';\r\nimport { cmsListApi, categoryListApi, relationApi } from '@/api/cms';\r\nimport relationList from './relation';\r\nimport { formatDate } from '@/utils/validate';\r\nimport goodsList from '@/components/goodsList/index';\r\nexport default {\r\n name: 'cms_article',\r\n data() {\r\n return {\r\n modalTitleSs: '',\r\n loading: false,\r\n artFrom: {\r\n pid: 0,\r\n title: '',\r\n page: 1,\r\n limit: 20,\r\n },\r\n total: 0,\r\n cmsList: [],\r\n treeData: [],\r\n list: [],\r\n cid: 0, // 移动分类id\r\n cmsId: 0,\r\n formValidate: {\r\n type: 1,\r\n },\r\n rows: {},\r\n modal_loading: false,\r\n modals: false,\r\n props: {\r\n value: 'id',\r\n label: 'title',\r\n emitPath: false,\r\n },\r\n };\r\n },\r\n components: {\r\n relationList,\r\n goodsList,\r\n },\r\n computed: {\r\n ...mapState('media', ['isMobile']),\r\n labelWidth() {\r\n return this.isMobile ? undefined : '80px';\r\n },\r\n labelPosition() {\r\n return this.isMobile ? 'top' : 'right';\r\n },\r\n },\r\n filters: {\r\n formatDate(time) {\r\n if (time !== 0) {\r\n let date = new Date(time * 1000);\r\n return formatDate(date, 'yyyy-MM-dd hh:mm');\r\n }\r\n },\r\n },\r\n created() {},\r\n activated() {\r\n this.artFrom.pid = this.$route.query.id ? this.$route.query.id : 0;\r\n this.getList();\r\n this.getClass();\r\n },\r\n methods: {\r\n // 关联成功\r\n getProductId(row) {\r\n let data = {\r\n product_id: row.id,\r\n };\r\n relationApi(data, this.rows.id)\r\n .then(async (res) => {\r\n this.$message.success(res.msg);\r\n row.id = 0;\r\n this.modal_loading = false;\r\n this.modals = false;\r\n setTimeout(() => {\r\n this.getList();\r\n }, 500);\r\n })\r\n .catch((res) => {\r\n this.modal_loading = false;\r\n this.loading = false;\r\n this.$message.error(res.msg);\r\n });\r\n },\r\n cancel() {\r\n this.modals = false;\r\n },\r\n // 等级列表\r\n getList() {\r\n this.loading = true;\r\n cmsListApi(this.artFrom)\r\n .then(async (res) => {\r\n let data = res.data;\r\n this.cmsList = data.list;\r\n this.total = data.count;\r\n this.loading = false;\r\n })\r\n .catch((res) => {\r\n this.loading = false;\r\n this.$message.error(res.msg);\r\n });\r\n },\r\n // 分类\r\n getClass() {\r\n categoryListApi(this.formValidate)\r\n .then(async (res) => {\r\n let data = res.data;\r\n this.treeData = data;\r\n let obj = {\r\n id: 0,\r\n title: '全部',\r\n };\r\n this.treeData.unshift(obj);\r\n })\r\n .catch((res) => {\r\n this.$message.error(res.msg);\r\n });\r\n },\r\n // 下拉树\r\n handleCheckChange(data) {\r\n this.artFrom.pid = data ? data : 0;\r\n this.artFrom.page = 1;\r\n this.getList();\r\n },\r\n // 编辑\r\n edit(row) {\r\n this.$router.push({ path: this.$routeProStr + '/cms/article/add_article/' + row.id });\r\n },\r\n // 关联\r\n artRelation(row, tit, num) {\r\n this.rows = row;\r\n if (row.product_id === 0) {\r\n this.modals = true;\r\n } else {\r\n let delfromData = {\r\n title: tit,\r\n num: num,\r\n url: `/cms/cms/unrelation/${row.id}`,\r\n method: 'PUT',\r\n ids: '',\r\n };\r\n this.$modalSure(delfromData)\r\n .then((res) => {\r\n this.$message.success(res.msg);\r\n this.getList();\r\n })\r\n .catch((res) => {\r\n this.$message.error(res.msg);\r\n });\r\n }\r\n },\r\n // 删除\r\n del(row, tit, num) {\r\n let delfromData = {\r\n title: tit,\r\n num: num,\r\n url: `cms/cms/${row.id}`,\r\n method: 'DELETE',\r\n ids: '',\r\n };\r\n this.$modalSure(delfromData)\r\n .then((res) => {\r\n this.$message.success(res.msg);\r\n this.cmsList.splice(num, 1);\r\n })\r\n .catch((res) => {\r\n this.$message.error(res.msg);\r\n });\r\n },\r\n // 表格搜索\r\n userSearchs() {\r\n this.artFrom.page = 1;\r\n this.getList();\r\n },\r\n onCopy(row, type) {\r\n let copy_url = type == 1 ? row.copy_url : row.copy_url_pc;\r\n this.$copyText(copy_url)\r\n .then((message) => {\r\n this.$message.success('复制成功');\r\n })\r\n .catch((err) => {\r\n this.$message.error('复制失败');\r\n });\r\n },\r\n },\r\n};\r\n</script>\r\n\r\n<style lang=\"scss\" scoped>\r\n.treeSel ::v-deep .ivu-select-dropdown-list {\r\n padding: 0 10px !important;\r\n box-sizing: border-box;\r\n}\r\n.tabBox_img {\r\n width: 36px;\r\n height: 36px;\r\n border-radius: 4px;\r\n cursor: pointer;\r\n\r\n img {\r\n width: 100%;\r\n height: 100%;\r\n }\r\n}\r\n</style>\r\n"]}]}
|