|
|
|
import Util from '@/libs/util'
|
|
|
|
export default {
|
|
|
|
data () {
|
|
|
|
return {
|
|
|
|
id: this.$route.query.id,
|
|
|
|
preview: this.$route.query.preview,
|
|
|
|
listPreview: this.$route.query.listPreview,
|
|
|
|
modules: [],
|
|
|
|
articles: []
|
|
|
|
}
|
|
|
|
},
|
|
|
|
computed: {
|
|
|
|
site () {
|
|
|
|
return this.$route.query.siteId || this.$store.state.content.site
|
|
|
|
}
|
|
|
|
},
|
|
|
|
mounted () {
|
|
|
|
this.getInfo && this.$route.query.id && this.init()
|
|
|
|
},
|
|
|
|
methods: {
|
|
|
|
// 初始化
|
|
|
|
async init () {
|
|
|
|
// 预览直接可以看长页
|
|
|
|
if (this.listPreview || this.preview) {
|
|
|
|
this.getInfo()
|
|
|
|
} else {
|
|
|
|
// 前台正常进入长页,则需要先判断该长页的导航菜单字段是否被禁用
|
|
|
|
const { data } = await this.$post(`${this.api.findColumn}?id=${this.id}`)
|
|
|
|
data.menuVisible || this.getInfo()
|
|
|
|
}
|
|
|
|
},
|
|
|
|
// 打开链接
|
|
|
|
async openLink (item) {
|
|
|
|
const { link } = item
|
|
|
|
if (link.linkName === '无' || link.linkName === '') return false
|
|
|
|
let href = link.linkAddress
|
|
|
|
const type = link.connectionType
|
|
|
|
if (type === 1) { // 站内链接
|
|
|
|
if (link.articleId) { // 文章
|
|
|
|
// 查询文章详情。禁用的文章要提示
|
|
|
|
const data = await this.$post(`${this.api.findArticle}?id=${link.articleId}`)
|
|
|
|
if (data.data.isDisable) {
|
|
|
|
return Util.errorMsg('该文章已禁用!')
|
|
|
|
} else {
|
|
|
|
href = '/article?articleId=' + link.articleId
|
|
|
|
}
|
|
|
|
} else { // 栏目
|
|
|
|
href = '/column?id=' + link.columnId[link.columnId.length - 1]
|
|
|
|
}
|
|
|
|
href += '&siteId=' + (this.site)
|
|
|
|
if (!link.articleId) href = this.$router.resolve(href).href
|
|
|
|
} else if (type === 3) { // 站外链接
|
|
|
|
if (link.otherArticleId) { // 文章
|
|
|
|
// 查询文章详情。禁用的文章要提示
|
|
|
|
const data = await this.$post(`${this.api.findArticle}?id=${link.otherArticleId}`)
|
|
|
|
if (data.data.isDisable) {
|
|
|
|
return Util.errorMsg('该文章已禁用!')
|
|
|
|
} else {
|
|
|
|
href = '/article?articleId=' + link.otherArticleId
|
|
|
|
}
|
|
|
|
} else { // 栏目
|
|
|
|
href = '/column?id=' + link.otherColumnId[link.otherColumnId.length - 1]
|
|
|
|
}
|
|
|
|
href += '&siteId=' + link.site
|
|
|
|
if (!link.otherArticleId) href = this.$router.resolve(href).href
|
|
|
|
}
|
|
|
|
// 如果是站内/站外链接,并且选择的是文章,则要获取当前长页名称传到文章详情里,面包屑点返回的时候需要返回到当前长页
|
|
|
|
if ((type === 1 && link.articleId) || (type === 3 && link.otherArticleId)) {
|
|
|
|
this.$post(`${this.api.findColumn}?id=${this.id}`).then(({ data }) => {
|
|
|
|
href = this.$router.resolve(href + '&id=' + this.id + '&columnName=' + data.columnName + '&path=' + this.$route.path.replace('/', '')).href
|
|
|
|
this.toHref(link.isOpen, href)
|
|
|
|
}).catch(res => { })
|
|
|
|
} else {
|
|
|
|
this.toHref(link.isOpen, href)
|
|
|
|
}
|
|
|
|
},
|
|
|
|
// 跳转地址
|
|
|
|
toHref (isOpen, href) {
|
|
|
|
if (isOpen) {
|
|
|
|
var userAgent = navigator.userAgent;
|
|
|
|
var isSafari = /Safari/.test(userAgent) && !/Chrome/.test(userAgent);
|
|
|
|
if (isSafari) {
|
|
|
|
window.location.href = href
|
|
|
|
} else {
|
|
|
|
window.open(href)
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
|
|
|
|
window.location.href = href
|
|
|
|
}
|
|
|
|
},
|
|
|
|
// 跳转文章页面
|
|
|
|
toArtice (item, form) {
|
|
|
|
if (item.articleTemplate === 24) { // 链接
|
|
|
|
let href = item.linkAddress
|
|
|
|
const cType = item.connectionType
|
|
|
|
if (cType !== 2) { // 非站外链接
|
|
|
|
const ids = href.split('-') // 栏目文章是用-分割的,栏目是必选,文章不是必选。选择了文章则跳转到文章页,否则跳转到栏目页
|
|
|
|
// 站点id:站内链接取当前站点,其他站点链接取siteSelection
|
|
|
|
const site = cType === 1 ?
|
|
|
|
(this.site) :
|
|
|
|
item.siteSelection
|
|
|
|
if (ids[1]) { // 文章
|
|
|
|
href = '/article?articleId=' + ids[1]
|
|
|
|
} else { // 栏目
|
|
|
|
const columnIds = ids[0].split(',')
|
|
|
|
href = '/column?id=' + columnIds[columnIds.length - 1]
|
|
|
|
}
|
|
|
|
href = this.$router.resolve(href + '&siteId=' + site).href
|
|
|
|
}
|
|
|
|
this.toHref(item.isOpen, href)
|
|
|
|
} else if (item.listStyleId === 73) { // 长页模板为产品中心的,该栏目下的文章全部跳产品详情页
|
|
|
|
this.$router.push(`/index/show?id=${item.id}`)
|
|
|
|
} else {
|
|
|
|
let href = `/article?articleId=${item.id}&siteId=${this.site}&id=${this.id}`
|
|
|
|
if (form) href += `&columnName=${form.columnTitle === 2 ? form.columnTitleCustom : form.columnName}&path=${this.$route.path.replace('/', '')}`
|
|
|
|
this.$router.push(href)
|
|
|
|
}
|
|
|
|
},
|
|
|
|
// 关联栏目的查看全部跳转
|
|
|
|
toAll (form) {
|
|
|
|
this.$router.push(`/column?id=${form.column[form.column.length - 1]}&siteId=${form.site}`)
|
|
|
|
},
|
|
|
|
// 判断是否有添加链接
|
|
|
|
isLink (linkName) {
|
|
|
|
return linkName !== '无' && linkName !== ''
|
|
|
|
},
|
|
|
|
// 关联栏目专用,获取栏目标题
|
|
|
|
getColumnTitle (form) {
|
|
|
|
return form.columnTitle == 1 ? form.columnName : form.columnTitleCustom
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|