You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
265 lines
6.9 KiB
265 lines
6.9 KiB
<template> |
|
<div class="wrap"> |
|
<div class="content"> |
|
<Breadcrumb ref="breadcrumb" :data.sync="routes"/> |
|
<div class="article"> |
|
<div class="left"> |
|
<h2>{{ form.title }}</h2> |
|
<div class="meta">{{$t('column.time')}}:{{ form.activityStartTime + ' ~ ' + form.activityEndTime }}</div> |
|
<div v-if="form.offlineLocation" class="meta">{{$t('column.address')}}:{{ form.offlineLocation }}</div> |
|
<div v-if="form.onlineLocation" class="meta">{{$t('column.online')}}:{{ form.onlineLocation }}</div> |
|
<div v-if="form.keynoteSpeaker" class="meta">{{$t('column.speaker')}}:{{ form.keynoteSpeaker }}</div> |
|
<div v-if="form.lectureSeries" class="meta">{{$t('column.series')}}:{{ form.lectureSeries }}</div> |
|
|
|
<h6>{{$t('column.content')}}</h6> |
|
<div v-html="form.mainBody"></div> |
|
<div v-if="form.fileList && form.fileList.length" class="annex"> |
|
<h6>{{$t('column.attachmentDownload')}}</h6> |
|
<ul class="files"> |
|
<li v-for="(file, i) in form.fileList" :key="i"> |
|
<span class="name">{{ file.fileName }}</span> |
|
<span class="download" @click="download(file)">{{$t('column.download')}}</span> |
|
</li> |
|
</ul> |
|
</div> |
|
</div> |
|
<div class="right"> |
|
<el-tree class="column" ref="column" :data="columns" highlight-current :expand-on-click-node="false" :props="defaultProps" node-key="id" @node-click="columnTo"></el-tree> |
|
|
|
<p class="l-title">{{$t('column.hot')}}</p> |
|
<ul class="list"> |
|
<li v-for="(item, i) in hots" :key="i" :title="item.title" @click="toArtice(item)"> |
|
<p class="text">{{ item.title }}</p> |
|
<span class="date">{{ item.releaseTime }}</span> |
|
</li> |
|
</ul> |
|
|
|
<p class="l-title">{{$t('column.latestNews')}}</p> |
|
<ul class="list"> |
|
<li v-for="(item, i) in news" :key="i" @click="toArtice(item)"> |
|
<p class="text">{{ item.title }}</p> |
|
<span class="date">{{ item.releaseTime }}</span> |
|
</li> |
|
</ul> |
|
</div> |
|
</div> |
|
</div> |
|
</div> |
|
</template> |
|
|
|
<script> |
|
import Setting from '@/setting' |
|
import Util from '@/libs/util' |
|
import Breadcrumb from '@/components/breadcrumb' |
|
import mixins from '@/mixins/article' |
|
export default { |
|
mixins: [mixins], |
|
data() { |
|
return { |
|
id: this.$route.query.articleId, |
|
columnId: '', |
|
routes: {}, |
|
form: {}, |
|
columnBanner: '', |
|
columns: [], |
|
defaultProps: { |
|
value: 'id', |
|
label: 'columnName' |
|
}, |
|
news: [], |
|
hots: [] |
|
} |
|
}, |
|
components: { |
|
Breadcrumb |
|
}, |
|
watch: { |
|
'$route'() { |
|
this.id = this.$route.query.articleId |
|
this.getInfo() |
|
} |
|
}, |
|
mounted() { |
|
this.getColumn() |
|
this.getArticle() |
|
}, |
|
methods: { |
|
// 获取文章详情 |
|
getInfo() { |
|
this.$post(`${this.api.findArticle}?id=${this.id}`).then(({ data }) => { |
|
// 设置面包屑 |
|
const { columnName, path, id } = this.$route.query |
|
this.routes = [ |
|
{ |
|
name: columnName || data.columnName, |
|
path: path ? '/' + path : '', |
|
query: { |
|
id: id || data.columnId |
|
} |
|
}, |
|
{ |
|
name: data.title |
|
} |
|
] |
|
this.form = data |
|
this.columnId = data.columnId |
|
data.bannerImg || this.getBanner(this.columns) |
|
if (this.columnBanner) this.form.bannerImg = this.columnBanner |
|
}).catch(err => {}) |
|
|
|
// 浏览量+1 |
|
this.$post(`${this.api.articlePreview}?contentId=${this.id}`).then(({ data }) => {}).catch(err => {}) |
|
}, |
|
// 获取banner 规则:当前文章有上传的,用上传的,没有上传的栏目有图片,读取上级栏目的(上级没有读上上级,以此类推)都没有的读取默认的 |
|
getBanner(data) { |
|
this.columnBanner = '' |
|
for (const e of data) { |
|
if (e.columnBanner) this.columnBanner = e.columnBanner |
|
if (e.id == this.columnId) { |
|
break |
|
} else { |
|
this.getBanner(e.children) |
|
} |
|
} |
|
}, |
|
// 资讯 |
|
getColumn() { |
|
this.$post(this.api.listWithTreeMenuVisible, { |
|
siteId: this.$route.query.siteId || this.$store.state.content.site, |
|
columnName: '', |
|
templateId: '', |
|
typeId : '', |
|
isSort: 1 |
|
}).then(({ data }) => { |
|
this.columns = data |
|
this.getInfo() |
|
}).catch(err => {}) |
|
|
|
this.$post(`${this.api.hotContent}?siteId=${this.$route.query.siteId || this.$store.state.content.site}`).then(({ data }) => { |
|
this.hots = Util.removeTag(data) |
|
}).catch(err => {}) |
|
}, |
|
// 最新资讯 |
|
getArticle() { |
|
this.$post(this.api.newlyPublishedArticles, { |
|
pageNum: 1, |
|
pageSize: 5, |
|
siteId: this.$route.query.siteId || this.$store.state.content.site |
|
}).then(({ data }) => { |
|
this.news = Util.removeTag(data.records) |
|
}).catch(res => {}) |
|
}, |
|
// 下载附件 |
|
download(e) { |
|
Util.downloadFile(e.fileName, e.filePath) |
|
} |
|
} |
|
}; |
|
</script> |
|
|
|
<style lang="scss" scoped> |
|
@import "./editor.css"; |
|
.content { |
|
width: 1400px; |
|
} |
|
.banner { |
|
height: 280px; |
|
padding: 123px 0 0 243px; |
|
font-size: 48px; |
|
color: #fff; |
|
background: url(../../assets/images/intro-bg.png) 0 0/100% 100% no-repeat; |
|
} |
|
.article { |
|
display: flex; |
|
justify-content: space-between; |
|
.left { |
|
width: 66%; |
|
} |
|
h2 { |
|
margin-bottom: 20px; |
|
font-size: 36px; |
|
color: #1C1C1C; |
|
} |
|
.meta { |
|
margin: 10px 0; |
|
font-size: 18px; |
|
font-weight: 600; |
|
color: #333; |
|
} |
|
/deep/.des { |
|
img { |
|
max-width: 100%; |
|
} |
|
} |
|
.annex { |
|
margin-top: 30px; |
|
h6 { |
|
padding-left: 8px; |
|
margin-bottom: 20px; |
|
font-size: 16px; |
|
font-family: PingFangSC-Medium, PingFang SC; |
|
font-weight: 500; |
|
line-height: 1; |
|
color: #333; |
|
border-left: 4px solid #1583FF; |
|
} |
|
li { |
|
display: flex; |
|
align-items: center; |
|
margin-bottom: 10px; |
|
} |
|
.name { |
|
margin-right: 8px; |
|
font-size: 14px; |
|
} |
|
.download { |
|
color: #1583FF; |
|
cursor: pointer; |
|
} |
|
} |
|
h6 { |
|
margin: 30px 0 10px; |
|
font-size: 18px; |
|
} |
|
.right { |
|
width: 20%; |
|
} |
|
.column { |
|
width: 100%; |
|
margin-bottom: 25px; |
|
} |
|
/deep/.el-tree-node__content { |
|
height: 44px; |
|
background-color: #E5EDF8; |
|
border-bottom: 2px solid #fff; |
|
} |
|
/deep/.el-tree--highlight-current .el-tree-node.is-current > .el-tree-node__content { |
|
color: #fff; |
|
background-color: #0f5698; |
|
} |
|
.list { |
|
margin-bottom: 20px; |
|
li { |
|
padding: 16px 0; |
|
border-bottom: 1px solid #D8D8D8; |
|
} |
|
.text { |
|
margin-bottom: 5px; |
|
font-size: 14px; |
|
cursor: pointer; |
|
&:hover { |
|
color: $main-color; |
|
} |
|
} |
|
.date { |
|
font-size: 12px; |
|
color: #999; |
|
} |
|
} |
|
} |
|
@media (max-width: 1420px) { |
|
.content { |
|
width: 98%; |
|
} |
|
} |
|
</style> |