123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142 |
- <template>
- <div id="talk">
- <talk-detail :menuList="menu" :sideMenu="sideMenu" :info="site" :backColor="backColor" :Color="Color" :talkInfo="talkInfo" :jobList="jobList"></talk-detail>
- </div>
- </template>
- <script>
- import talkDetail from '@/components/talk.vue';
- import { mapActions, mapState } from 'vuex';
- import _ from 'lodash';
- export default {
- metaInfo() {
- return {
- title: this.siteTitle ? this.siteTitle : '就业信息网',
- };
- },
- name: 'talk',
- props: {},
- components: {
- talkDetail,
- },
- data: () => ({
- info: {
- src: require('@/assets/logo.png'),
- phone: '0431-12345678',
- banner: require('@/assets/banner.png'),
- address: '办公地址:长春市经济技术开发区金川街151号吉林省高等学校毕业生就业指导中心2楼一站式办公大厅',
- email: '邮编:130012',
- gongjiao: '公交线路:乘坐120路、227路、20路、260路、80路、130路、281路、154路、190路、125路公交北方市场下车,北方市场南门南行200米。',
- mobile: '业务咨询电话:0431-84657570 0431-84657571;',
- date: '办公时间:周一至周五,法定假日不对外办公。',
- copyright: '吉ICP备09006292号-1 Copyright 2013 版权所有 吉林省高等学校毕业生就业指导中心 All Rights Reserved',
- },
- talkInfo: {},
- jobList: [],
- menu: [],
- site: {},
- sideMenu: [],
- siteTitle: '',
- backColor: '#0457c7',
- Color: '#0457c7',
- }),
- async created() {
- await this.toGetSite(); //获取主站信息
- await this.loadMenu(); //获取菜单信息
- this.search();
- },
- computed: {},
- methods: {
- ...mapActions(['getSite', 'getMenu', 'getColumn', 'getTalk', 'getPosts']),
- async search() {
- //1直接拿着参数发送请求
- let result = await this.getTalk({ type: 'fetch', data: { id: this.$route.query.id } });
- if (`${result.errcode}` === '0') {
- this.$set(this, `talkInfo`, result.data);
- this.searchJobs();
- } else {
- this.$message.error(result.errmsg ? result.errmsg : 'error');
- }
- },
- async searchJobs() {
- let jobs = this.talkInfo.jobs;
- if (jobs.length > 0) {
- jobs.map(async item => {
- let result = await this.postOperation({ type: 'search', data: { id: item } });
- if (`${result.errcode}` === '0') {
- result.data ? this.jobList.push(result.data) : '';
- }
- });
- }
- },
- //站点信息
- async toGetSite() {
- let site = sessionStorage.getItem('site');
- if (site) {
- this.$set(this, `site`, JSON.parse(site));
- this.$set(this, `siteTitle`, this.site.name);
- } else {
- let result = await this.getSite({ type: 'search' });
- if (result.errcode === 0) {
- sessionStorage.setItem('site', JSON.stringify(result.data));
- if (_.get(result.data, `custom`)) {
- let item = result.custom;
- }
- this.$set(this, `site`, result.data);
- this.$set(this, `siteTitle`, this.site.name);
- }
- }
- },
- //菜单
- async loadMenu() {
- let menu = sessionStorage.getItem('menu');
- if (menu) {
- this.$set(this, `menu`, JSON.parse(menu));
- await this.finishedMenu();
- } else this.toGetMenu();
- },
- async toGetMenu() {
- let result = await this.getMenu({ type: `list` });
- if (result.errcode === 0) {
- sessionStorage.setItem('menu', JSON.stringify(result.data));
- this.$set(this, `menu`, result.data);
- this.finishedMenu();
- }
- },
- async finishedMenu() {
- let menus = JSON.parse(JSON.stringify(this.menu));
- for (const item of menus) {
- if (item.type === 'content') {
- item.path = `/detail/${item.content_id}`;
- } else if (item.type !== 'url') {
- let res = await this.completeMenu(item);
- item.children = res;
- }
- }
- this.$set(this, `menu`, menus);
- },
- async completeMenu(item) {
- let result = await this.getColumn({
- type: `list`,
- data: { parent_id: item.id },
- });
- if (result.errcode === 0) {
- let columns = result.data;
- for (const col of columns) {
- if (col.type === 'content') {
- col.path = `/detail/${col.content_id}`;
- } else if (col.type !== 'url') {
- col.path = `/newsList/menu/${col.id}?title=${col.title}`;
- if (col.parent.includes('党员')) {
- col.path = `/memberList/menu/${col.id}?title=${col.title}`;
- }
- }
- }
- return columns;
- }
- },
- },
- };
- </script>
- <style lang="less" scoped></style>
|