Browse Source

h5分享浏览页面

lipengtao 6 years ago
parent
commit
67d4d84989

+ 38 - 2
src/components/BeyondTo/index.vue

@ -1,5 +1,5 @@
1 1
<template>
2
  <div class="beyond-block">
2
  <div class="beyond-block" :class="styFlag?'beyond-h5':''">
3 3
    <div class="expert-block" v-if="ownerType==='1'">
4 4
      <div class="show-head" :style="{backgroundImage:'url('+ ownerInfo.img +')'}"></div>
5 5
      <div class="show-info">
@ -17,7 +17,7 @@
17 17
        <div class="info-desc">{{ownerInfo.title}}</div>
18 18
      </div>
19 19
    </div>
20
    <div class="goSpan">
20
    <div class="goSpan" v-if="!styFlag">
21 21
      <collectCo v-if="ownerType==='1'" :watchOptions="{oid: ownerId, type: 1}"></collectCo>
22 22
      <contactChat v-if="ownerType==='1'" :contactOptions="{oid: ownerId}"></contactChat>
23 23
      <collectCo v-if="ownerType==='2'" :watchOptions="{oid: ownerId, type: 2}"></collectCo>
@ -37,6 +37,10 @@
37 37
      },
38 38
      ownerType: {
39 39
        type: String
40
      },
41
      styFlag: {
42
        type:Boolean,
43
        default: false
40 44
      }
41 45
    },
42 46
    data() {
@ -155,4 +159,36 @@
155 159
  display: flex;
156 160
  justify-content: center;
157 161
}
162
163
164
.beyond-h5 .expert-block{
165
  display:flex;
166
}
167
.beyond-h5 .show-head{
168
  width: 50px;
169
  height: 50px;
170
}
171
.beyond-h5 .show-head.orgimg-box{
172
  width: 50px;
173
  height: 40px; 
174
}
175
.beyond-h5 .show-head.orgimg-box img{
176
  max-width: 50px;
177
}
178
.beyond-h5 .show-info{
179
  line-height: 18px;
180
  flex:1 0 80px;
181
  padding-left:15px;
182
  width: 118px;
183
  text-align: left;
184
}
185
.beyond-h5 .show-info .info-tit{
186
  font-size: 16px;
187
}
188
.beyond-h5 .show-info .info-tag{
189
  font-size: 14px;
190
}
191
.beyond-h5 .show-info .info-desc{
192
  font-size: 13px;
193
}
158 194
</style>

+ 40 - 0
src/pages/h5/router/index.js

@ -50,6 +50,46 @@ const constantRouterMap = [
50 50
      name: 'org',
51 51
      meta: { title: '机构' }
52 52
    }]
53
  }, 
54
  {
55
    path: '',
56
    component: Layout,
57
    children: [{
58
      path: '/expert',
59
      component: (resolve) => require(['../views/expert/expert.vue'], resolve),
60
      name: 'expert',
61
      meta: { title: '专家' }
62
    }]
63
  }, 
64
  {
65
    path: '',
66
    component: Layout,
67
    children: [{
68
      path: '/service',
69
      component: (resolve) => require(['../views/service/service.vue'], resolve),
70
      name: 'service',
71
      meta: { title: '服务' }
72
    }]
73
  }, 
74
  {
75
    path: '',
76
    component: Layout,
77
    children: [{
78
      path: '/resource',
79
      component: (resolve) => require(['../views/resource/resource.vue'], resolve),
80
      name: 'resource',
81
      meta: { title: '资源' }
82
    }]
83
  }, 
84
  {
85
    path: '',
86
    component: Layout,
87
    children: [{
88
      path: '/product',
89
      component: (resolve) => require(['../views/product/product.vue'], resolve),
90
      name: 'product',
91
      meta: { title: '产品' }
92
    }]
53 93
  }
54 94
];
55 95

+ 212 - 0
src/pages/h5/views/Result/result.vue

@ -0,0 +1,212 @@
1
<template>
2
  <div class="browse-main">
3
    <div class="block-wrapper">
4
      <div class="left-main">
5
        <div class="content-wrapper">
6
          <div class="inner-wrapper">
7
            <div class="headcon-box detail-box">
8
              <div class="show-info">
9
                <div class="info-tit info-tit-big">{{patentInfo.name}}</div>
10
              </div>
11
            </div>
12
          </div>
13
          <div class="inner-wrapper">
14
            <div class="content">
15
              <el-row :gutter="12" class="rel-detail">
16
                <el-col :span="24" v-if="patentInfo.code">
17
                  <el-col :span="6">专利号:</el-col>
18
                  <el-col :span="18">{{patentInfo.code}}</el-col>
19
                </el-col>
20
                <el-col :span="24" v-if="patentInfo.pubDay">
21
                  <el-col :span="6">公开日:</el-col>
22
                  <el-col :span="18">{{patentInfo.pubDay}}</el-col>
23
                </el-col>
24
                <el-col :span="24" v-if="patentInfo.reqCode">
25
                  <el-col :span="6">申请号:</el-col>
26
                  <el-col :span="18">{{patentInfo.reqCode}}</el-col>
27
                </el-col>
28
                <el-col :span="24" v-if="patentInfo.pubDay">
29
                  <el-col :span="6">申请日:</el-col>
30
                  <el-col :span="18">{{patentInfo.pubDay}}</el-col>
31
                </el-col>
32
                <el-col :span="24" v-if="patentInfo.reqPerson">
33
                  <el-col :span="6">申请人:</el-col>
34
                  <el-col :span="18">{{patentInfo.reqPerson}}</el-col>
35
                </el-col>
36
                <el-col :span="24" v-if="patentInfo.summary">
37
                  <el-col :span="24">摘要:</el-col>
38
                  <el-col :span="24" v-html="patentInfo.summary"></el-col>
39
                </el-col>
40
                <el-col :span="24" v-if="patentInfo.cooperation">
41
                  <el-col :span="24">合作备注:</el-col>
42
                  <el-col :span="24" v-html="patentInfo.cooperation"></el-col>
43
                </el-col>
44
                <el-col :span="24" v-if="patentInfo.keywords && patentInfo.keywords.length">
45
                  <el-row class="tag-item">
46
                    <el-tag v-for="sub in patentInfo.keywords" :key="sub.index">{{sub}}</el-tag>
47
                  </el-row>
48
                </el-col>
49
              </el-row>
50
            </div>
51
          </div>
52
          <div class="inner-wrapper" v-if="patentAuthors && patentAuthors.length">
53
            <div class="content-title">
54
              <span>发明人{{authorCount > 0 ? `(${authorCount})` : ''}}</span>
55
            </div>
56
            <div class="content">
57
              <el-row :gutter="10" style="width:100%">
58
                <el-col :span="24" class="item-col" v-for="item in patentAuthors" :key="item.index">
59
                  <div v-if="item.professorId.substring(0, 1) !== '#' && item.owner" class="list-item">
60
                    <a :href="'expert.html?id='+item.professorId" target="_blank">
61
                      <div class="list-head" style="border-radius:50%" :style="{backgroundImage: 'url(' + item.owner.img + ')'}"></div>
62
                    </a>
63
                    <div class="list-info">
64
                      <div class="list-tit">{{item.owner.name}}</div>
65
                      <div class="list-desc">{{item.owner.title}}</div>
66
                    </div>
67
                    <div class="list-link" style="right: 0">
68
                      <contactChat :contactOptions="{oid: item.professorId }"></contactChat>
69
                    </div>
70
                  </div>
71
                  <div class="list-item" v-else>
72
                    <div class="list-head" style="border-radius:50%" :style="{backgroundImage: 'url(' + defaultExpertImg + ')'}"></div>
73
                    <div class="list-info">
74
                      <div class="list-tit">{{item.name}}</div>
75
                    </div>
76
                  </div>
77
                </el-col>
78
              </el-row>
79
            </div>
80
          </div>
81
          <div class="inner-wrapper" v-if="likePatents && likePatents.length">
82
            <div class="content-title">
83
              <span>您可能感兴趣的专利</span>
84
            </div>
85
            <div class="content content-nf">
86
              <baseResult v-for="item in likePatents" :key="item.index" :itemSingle="item" :noBlank="true"></baseResult>
87
            </div>
88
          </div>
89
        </div>
90
      </div>
91
    </div>
92
  </div>
93
</template>
94
95
<script>
96
  import { urlParse, ImageUrl, defaultSet, strToArr, TimeTr } from '@/libs/util';
97
  import collectCo from '@/components/CollectCo';
98
  import contactChat from '@/components/ContactChat';
99
100
  import baseResult from '@/components/subTemplate/BaseResult';
101
  import queryBase from '@/libs/queryBase';
102
103
  export default {
104
    data() {
105
      return {
106
        /* eslint-disable no-undef */
107
        activeName: 'first',
108
        patentInfo: '',
109
        patentId: '',
110
        elurl: '',
111
        likePatents: '',
112
        patentAuthors: '',
113
        defaultExpertImg: defaultSet.img.expert
114
      };
115
    },
116
    created() {
117
      this.patentId = urlParse('id');
118
      this.elurl = window.location.href;
119
      this.getPatentInfo();
120
      this.getLikePatents();
121
      this.getPatentAuthors();
122
    },
123
    components: {
124
      collectCo,
125
      contactChat,
126
      baseResult
127
    },
128
    methods: {
129
      getPatentInfo() {
130
        this.$axios.getk('/ajax/ppatent/qo', {
131
          id: this.patentId
132
        }, (res) => {
133
          if (res.success) {
134
            var $info = res.data;
135
            if ($info.keywords) {
136
              $info.keywords = strToArr($info.keywords);
137
            }
138
            if ($info.reqDay) {
139
              $info.reqDay = TimeTr($info.reqDay);
140
            }
141
            if ($info.pubDay) {
142
              $info.pubDay = TimeTr($info.pubDay);
143
            }
144
            document.title = $info.name + '-' + PLAT.info.title
145
            this.patentInfo = $info;
146
          };
147
        });
148
      },
149
      getPatentAuthors() {
150
        var that = this
151
        that.$axios.getk('/ajax/ppatent/authors', {
152
          id: that.patentId
153
        }, function (res) {
154
          if (res.success && res.data) {
155
            const $data = res.data
156
            if ($data.length > 0) {
157
              that.authorCount = $data.length
158
              for (let i = 0; i < $data.length; ++i) {
159
                if ($data[i].professorId.substring(0, 1) !== '#') {
160
                  queryBase.getProfessor($data[i].professorId, function (sc, value) {
161
                    if (sc) {
162
                      if (value.hasHeadImage) {
163
                        value.img = ImageUrl(('head/' + value.id + '_l.jpg'), true)
164
                      } else {
165
                        value.img = defaultSet.img.expert
166
                      }
167
                      $data[i].owner = value
168
                      that.$forceUpdate();
169
                    }
170
                  });
171
                }
172
              }
173
              that.patentAuthors = $data
174
            }
175
          }
176
        })
177
      },
178
      getLikePatents() {
179
        var that = this
180
        that.$axios.getk('/ajax/ppatent/ralatePatents', {
181
          patentId: that.patentId
182
        }, function (res) {
183
          if (res.success && res.data) {
184
            const $data = res.data
185
            that.likePatents = $data
186
          }
187
        })
188
      }
189
    }
190
  };
191
</script>
192
193
<style lang="scss" rel="stylesheet/scss">
194
@import '../../style/index';
195
  .browse-main .block-wrapper .left-main .inner-wrapper .content .item-col {
196
    margin-bottom: 10px;
197
198
    .list-item {
199
      border: 1px solid #eaeaea;
200
      padding: 10px 16px;
201
202
      .list-head {
203
        @include center-items(50px, 50px);
204
      }
205
206
      .list-info {
207
        flex: 1 1 60px;
208
        padding-left: 10px;
209
      }
210
    }
211
  }
212
</style>

+ 5 - 5
src/pages/h5/views/company/company.vue

@ -54,18 +54,18 @@
54 54
            <span>相关文章</span>
55 55
          </div>
56 56
          <div class="content content-nf" v-if="compContents.length">
57
              <baseContent v-for="item in compContents" :key="item.index" :itemSingle="item" :noBlank="true"></baseContent>
58
            </div>
57
            <baseContent v-for="item in compContents" :key="item.index" :itemSingle="item" :noBlank="true"></baseContent>
58
          </div>
59 59
        </div>
60 60
      </div>
61 61
    </div>
62 62
  </div>
63 63
</template>
64
64 65
<script>
65 66
  import { urlParse, defaultSet, commenTime } from '@/libs/util';
66 67
  import queryDict from '@/libs/queryDict';
67 68
  import baseContent from '@/components/subTemplate/BaseContent';
68
  import shareOut from '@/components/ShareOut';
69 69
  import baseProduct from '@/components/subTemplate/BaseProduct';
70 70
71 71
  export default {
@ -93,7 +93,6 @@
93 93
      this.getCompContent();
94 94
    },
95 95
    components: {
96
      shareOut,
97 96
      baseProduct,
98 97
      baseContent
99 98
    },
@ -217,6 +216,7 @@
217 216
    }
218 217
  };
219 218
</script>
219
220 220
<style lang="scss" rel="stylesheet/scss">
221 221
  @import '../../style/index';
222
</style>
222
</style>

+ 48 - 0
src/pages/h5/views/components/swiperImg.vue

@ -0,0 +1,48 @@
1
<template>
2
  <div class="swiper-container" ref="swiperAuto">
3
    <div class="swiper-wrapper">
4
      <div class="swiper-slide" v-for="item in previewImg" :key="item.index">
5
        <img :src="item" alt="">
6
      </div>
7
    </div>
8
    <div class="swiper-pagination" ref="swiperPage"></div>
9
  </div>
10
</template>
11
12
<script>
13
  export default {
14
    props: ['previewImg'],
15
    mounted() {
16
      let that = this;
17
      var mySwiper = new Swiper(this.$refs.swiperAuto, {
18
        pagination: {
19
          el: that.$refs.swiperPage,
20
          bulletElement: 'li'
21
        }
22
      })
23
    }
24
  }
25
</script>
26
27
<style lang="scss" rel="stylesheet/scss">
28
  .swiper-container {
29
    background: #f0f0f0;
30
    height: 200px;
31
    width: 100%;
32
    .swiper-wrapper {
33
      width: 100%;
34
      .swiper-slide {
35
        overflow: hidden;
36
        display: flex;
37
        align-items: center;
38
        justify-content: center;
39
        img {
40
          overflow: hidden;
41
          max-width: 100%;
42
          max-height: 200px;
43
          vertical-align: middle;
44
        }
45
      }
46
    }
47
  }
48
</style>

+ 14 - 14
src/pages/h5/views/content/content.vue

@ -55,18 +55,18 @@
55 55
            </a>
56 56
          </div>
57 57
          <div class="inner-wrapper" v-if="paltNews && paltNews.length">
58
              <div class="content-title">
59
                <span>最新文章</span>
60
              </div>
61
              <div class="content content-nf">
62
                  <baseContent v-for="item in paltNews" :key="item.index" :itemSingle="item" :showOwner="false" :noBlank="true"></baseContent>
63
              </div>
58
            <div class="content-title">
59
              <span>最新文章</span>
64 60
            </div>
65
            <div class="block-wrapper" v-if="adinfo.shareAdBottom.length">
66
                <a class="ad-wrapper" v-for="item in adinfo.shareAdBottom" :key="item.index" :href="item.adUrl" target="_blank">
67
                  <img :src="item.imgUrl" width="100%">
68
                </a>
69
              </div>
61
            <div class="content content-nf">
62
              <baseContent v-for="item in paltNews" :key="item.index" :itemSingle="item" :showOwner="false" :noBlank="true"></baseContent>
63
            </div>
64
          </div>
65
          <div class="block-wrapper" v-if="adinfo.shareAdBottom.length">
66
            <a class="ad-wrapper" v-for="item in adinfo.shareAdBottom" :key="item.index" :href="item.adUrl" target="_blank">
67
              <img :src="item.imgUrl" width="100%">
68
            </a>
69
          </div>
70 70
        </div>
71 71
      </div>
72 72
    </div>
@ -119,8 +119,8 @@
119 119
            var $info = res.data.data;
120 120
            if ($info.length > 0) {
121 121
              for (let i = 0; i < $info.length; ++i) {
122
                if($info[i].id === this.contentId) {
123
                  $info.splice(i,1)
122
                if ($info[i].id === this.contentId) {
123
                  $info.splice(i, 1)
124 124
                  i--
125 125
                  continue
126 126
                }
@ -128,7 +128,7 @@
128 128
                  $info[i].modifyTime = commenTime($info[i].modifyTime, true)
129 129
                }
130 130
              }
131
              this.paltNews = $info.slice(0,5)
131
              this.paltNews = $info.slice(0, 5)
132 132
            }
133 133
          };
134 134
        });

+ 418 - 0
src/pages/h5/views/expert/expert.vue

@ -0,0 +1,418 @@
1
<template>
2
  <div class="browse-main">
3
    <div class="header-box">
4
      <div class="header_content">
5
        <div class="header_content_top">
6
          <div class="show-head headimg-box" :style="{backgroundImage:'url('+ expertInfo.img +')'}"></div>
7
        </div>
8
        <div class="header_content-footer">
9
          <p>
10
            <span class="cmpName">{{expertInfo.name}}</span>
11
            <em class="authicon" :class="headIcon(expertInfo)"></em>
12
          </p>
13
          <p class="industry" v-if="expertInfo.title">{{expertInfo.title}}</p>
14
          <p class="addressbox">
15
            <em class="address"></em> {{expertInfo.address}}</p>
16
        </div>
17
      </div>
18
    </div>
19
    <div class="block-wrapper">
20
      <div class="left-main">
21
        <div class="content-wrapper split-other" v-if="platServices && platServices.length">
22
          <div class="inner-wrapper">
23
            <div class="content-title">
24
              <span>可提供服务</span>
25
            </div>
26
            <div class="content content-nf" v-if="platServices.length">
27
              <baseService v-for="item in platServices" :key="item.index" :itemSingle="item"></baseService>
28
              <p class="moretype" @click="moreService" v-show="loadingModalShow">查看更多服务</p>
29
            </div>
30
          </div>
31
        </div>
32
        <div class="content-wrapper">
33
          <div class="inner-wrapper" v-if="expertInfo.descp">
34
            <div class="content-title">
35
              <span>个人简介</span>
36
            </div>
37
            <div class="content">{{expertInfo.descp}}</div>
38
          </div>
39
          <div class="inner-wrapper" v-if="expertInfo.subject && expertInfo.subject.length">
40
            <div class="content-title">
41
              <span>学术领域</span>
42
            </div>
43
            <div class="content">
44
              <el-row class="tag-item">
45
                <el-tag v-for="sub in expertInfo.subject" :key="sub.index">{{sub}}</el-tag>
46
              </el-row>
47
            </div>
48
          </div>
49
          <div class="inner-wrapper" v-if="expertInfo.resAreas && expertInfo.resAreas.length">
50
            <div class="content-title">
51
              <span>研究方向</span>
52
            </div>
53
            <div class="content">
54
              <el-row class="tag-item">
55
                <el-col :span="24" v-for="sub in expertInfo.resAreas" :key="sub.index">
56
                  <el-tag>{{sub}}</el-tag>
57
                </el-col>
58
              </el-row>
59
            </div>
60
          </div>
61
          <div class="inner-wrapper" v-if="expertInfo.industry && expertInfo.industry.length">
62
            <div class="content-title">
63
              <span>行业领域</span>
64
            </div>
65
            <div class="content">
66
              <el-row class="tag-item">
67
                <el-tag v-for="sub in expertInfo.industry" :key="sub.index">{{sub}}</el-tag>
68
              </el-row>
69
            </div>
70
          </div>
71
          <div class="inner-wrapper" v-if="platPatents && platPatents.length">
72
            <div class="content-title">
73
              <span>专利</span>
74
            </div>
75
            <div class="content" v-if="platPatents.length">
76
              <baseResult v-for="item in platPatents" :key="item.index" :itemSingle="item"></baseResult>
77
              <p class="moretype" @click="morePatent" v-show="loadingModalShow2">查看更多服务</p>
78
            </div>
79
          </div>
80
        </div>
81
        <div class="content-wrapper" v-if="coopExperts && coopExperts.length">
82
          <div class="content-title">
83
            <span>合作专家</span>
84
          </div>
85
          <div class="content">
86
            <BaseExpert v-for="item in coopExperts" :key="item.index" :itemSingle="item"></BaseExpert>
87
          </div>
88
        </div>
89
        <div class="content-wrapper" v-if="expContents && expContents.length">
90
          <div class="content-title">
91
            <span>相关文章</span>
92
          </div>
93
          <div class="content content-nf">
94
            <baseContent v-for="item in expContents" :key="item.index" :itemSingle="item" :showOwner="false" :noBlank="true"></baseContent>
95
          </div>
96
        </div>
97
        <div class="content-wrapper" v-if="likeExperts && likeExperts.length">
98
          <div class="content-title">
99
            <span>您可能感兴趣的专家</span>
100
          </div>
101
          <div class="content">
102
            <BaseExpert v-for="item in likeExperts" :key="item.index" :itemSingle="item"></BaseExpert>
103
          </div>
104
        </div>
105
      </div>
106
    </div>
107
  </div>
108
</template>
109
110
<script>
111
  import { urlParse, ImageUrl, defaultSet, strToArr, formatOfft, autho } from '@/libs/util';
112
  import queryBase from '@/libs/queryBase';
113
  import baseService from '@/components/subTemplate/BaseService';
114
  import baseContent from '@/components/subTemplate/BaseContent';
115
  import baseResult from '@/components/subTemplate/BaseResult';
116
  import BaseExpert from '@/components/subTemplate/BaseExpert';
117
118
  export default {
119
    data() {
120
      return {
121
        activeIndex: '1',
122
        activeName: 'first',
123
        expertInfo: '',
124
        expertId: '',
125
        platServices: [],
126
        serCount: 0,
127
        loadingModalShow: true, // 是否显示按钮
128
        loadingComplete: false, // 是否全部加载
129
        isFormSearch: false, // 数据加载
130
        isLoading: false, // button style...
131
        ifDefault: false, // 是否缺省
132
        platPatents: [],
133
        patCount: 0,
134
        loadingModalShow2: true,
135
        loadingComplete2: false,
136
        isFormSearch2: false,
137
        isLoading2: false,
138
        ifDefault2: false,
139
        dataO: {
140
          serModifyTime: '',
141
          patTime: '',
142
          patId: ''
143
        },
144
        rows: 2,
145
        expContents: '',
146
        likeExperts: '',
147
        coopExperts: ''
148
      };
149
    },
150
    created() {
151
      this.expertId = urlParse('id');
152
      this.getExpertInfo();
153
      this.getExpertWave();
154
      this.getExpertPatent();
155
      this.queryPubCount();
156
      this.getExpContent();
157
      this.getLikeExperts();
158
      this.getCoopExperts();
159
    },
160
    components: {
161
      baseService,
162
      baseResult,
163
      baseContent,
164
      BaseExpert
165
    },
166
    methods: {
167
      morePatent() {
168
        this.getExpertPatent();
169
      },
170
      moreService() {
171
        this.getExpertWave();
172
      },
173
      getExpertInfo() {
174
        this.$axios.getk('/ajax/professor/info/' + this.expertId, {
175
        }, (res) => {
176
          if (res.success) {
177
            var $info = res.data;
178
            $info.offt = formatOfft($info);
179
            if ($info.subject) {
180
              $info.subject = strToArr($info.subject);
181
            }
182
            if ($info.industry) {
183
              $info.industry = strToArr($info.industry);
184
            }
185
            if ($info.hasHeadImage) {
186
              $info.img = ImageUrl(('head/' + $info.id + '_l.jpg'), true)
187
            } else {
188
              $info.img = defaultSet.img.expert
189
            }
190
            $info.resAreas = [];
191
            if ($info.researchAreas && $info.researchAreas.length > 0) {
192
              for (let i = 0; i < $info.researchAreas.length; ++i) {
193
                $info.resAreas.push($info.researchAreas[i].caption);
194
              }
195
            }
196
            document.title = $info.name + '-' + PLAT.info.title
197
            this.expertInfo = $info;
198
          };
199
        });
200
      },
201
      getExpertWave() {
202
        this.$axios.getk('/ajax/ware/publish', {
203
          category: '1',
204
          owner: this.expertId,
205
          modifyTime: this.dataO.serModifyTime,
206
          rows: this.rows
207
        }, (res) => {
208
          if (res.success) {
209
            var $info = res.data;
210
            if ($info.length > 0) {
211
              this.dataO.serModifyTime = $info[$info.length - 1].modifyTime;
212
              this.platServices = this.isFormSearch ? this.platServices.concat($info) : $info;
213
              this.isFormSearch = true;
214
              if ($info.length < this.rows) {
215
                this.loadingModalShow = false;
216
                this.isFormSearch = false;
217
              };
218
            } else {
219
              this.loadingModalShow = false;
220
              this.isFormSearch = false;
221
            };
222
            var liLen = this.platServices.length;
223
            if ($info.length === 0 && liLen === 0) {
224
              this.ifDefault = true;
225
            };
226
          };
227
        });
228
      },
229
      searchLower() {
230
        if (this.loadingModalShow && !this.isLoading) {
231
          this.getExpertWave();
232
        }
233
      },
234
      getExpertPatent() {
235
        this.$axios.getk('/ajax/ppatent/professor', {
236
          owner: this.expertId,
237
          assTime: this.dataO.patTime,
238
          id: this.dataO.patId,
239
          rows: this.rows
240
        }, (res) => {
241
          if (res.success) {
242
            var $info = res.data;
243
            if ($info.length > 0) {
244
              this.dataO.patTime = $info[$info.length - 1].assTime;
245
              this.dataO.patId = $info[$info.length - 1].id;
246
              for (let i = 0; i < $info.length; i++) {
247
                $info[i].authors = $info[i].authors.substr(0, $info[i].authors.length - 1);
248
              }
249
              this.platPatents = this.isFormSearch2 ? this.platPatents.concat($info) : $info;
250
              this.isFormSearch2 = true;
251
              if ($info.length < this.rows) {
252
                this.loadingModalShow2 = false;
253
                this.isFormSearch2 = false;
254
              };
255
            } else {
256
              this.loadingModalShow2 = false;
257
              this.isFormSearch2 = false;
258
            };
259
            var liLen = this.platPatents.length;
260
            if ($info.length === 0 && liLen === 0) {
261
              this.ifDefault2 = true;
262
            };
263
          };
264
        });
265
      },
266
      searchLower2() {
267
        if (this.loadingModalShow2 && !this.isLoading2) {
268
          this.getExpertPatent();
269
        }
270
      },
271
      queryPubCount() {
272
        var that = this
273
        this.$axios.getk('/ajax/ware/count/publish', {
274
          owner: that.expertId,
275
          category: '1'
276
        }, function (data) {
277
          if (data.data > 0 && data.data < 99) {
278
            that.serCount = data.data;
279
          }
280
          if (data.data > 99) {
281
            that.serCount = '99+';
282
          }
283
        });
284
        this.$axios.getk('/ajax/ppatent/count/publish', {
285
          owner: that.expertId
286
        }, function (data) {
287
          if (data.data > 0 && data.data < 99) {
288
            that.patCount = data.data;
289
          }
290
          if (data.data > 99) {
291
            that.patCount = '99+';
292
          }
293
        });
294
      },
295
      headIcon(item) {
296
        return autho(item.authType, item.orgAuth, item.authStatus);
297
      },
298
      getExpContent() {
299
        var that = this
300
        this.$axios.get('/ajax/article/lq/with/professor', {
301
          pid: this.expertId
302
        }, (res) => {
303
          if (res.success) {
304
            var $info = res.data;
305
            if ($info.length > 0) {
306
              let j = 0;
307
              for (let i = 0; i < $info.length; ++i) {
308
                j++
309
                that.$axios.get('/ajax/article/qo', {
310
                  id: $info[i].id
311
                }, (data) => {
312
                  j--
313
                  if (data.success) {
314
                    $info[i].title = data.data.title
315
                    if (j === 0) {
316
                      that.expContents = $info;
317
                    }
318
                  };
319
                });
320
              }
321
322
            };
323
          };
324
        });
325
      },
326
      getLikeExperts() {
327
        var that = this
328
        this.$axios.getk('/ajax/professor/ralateProfessors', {
329
          professorId: this.expertId
330
        }, (res) => {
331
          if (res.success) {
332
            var $data = res.data;
333
            var arr = []
334
            var hdata = { num: 1, data: $data }
335
            if ($data.length > 0) {
336
              for (let i in $data) {
337
                hdata.num++
338
                arr[i] = $data[i].id;
339
                hdata.num--
340
              }
341
              hdata.num--
342
              if (hdata.num === 0 && arr.length) {
343
                that.$axios.getk('/ajax/professor/qm', {
344
                  id: arr
345
                }, function (data) {
346
                  if (data.success && data.data) {
347
                    var obj = data.data
348
                    if (obj.length > 0) {
349
                      for (let m = 0; m < obj.length; ++m) {
350
                        obj[m].img = defaultSet.img.expert
351
                        if (obj[m].hasHeadImage) {
352
                          obj[m].img = ImageUrl(('head/' + obj[m].id + '_l.jpg'), true)
353
                        }
354
                        obj[m].auth = autho(obj[m].authType, obj[m].orgAuth, obj[m].authStatus)
355
                        obj[m].offt = formatOfft(obj[m], true)
356
                      }
357
                      setTimeout(() => {
358
                        that.likeExperts = obj
359
                      }, 1000);
360
                    }
361
                  }
362
                })
363
              }
364
            };
365
          };
366
        });
367
      },
368
      getCoopExperts() {
369
        var that = this
370
        this.$axios.getk('/ajax/professor/coadjutant', {
371
          id: this.expertId
372
        }, (res) => {
373
          if (res.success) {
374
            var $info = res.data;
375
            if ($info.length > 0) {
376
              let j = 0;
377
              for (let i = 0; i < $info.length; ++i) {
378
                j++;
379
                $info[i].id = $info[i].professorId
380
                queryBase.getProfessor($info[i].professorId, function (sc, value) {
381
                  j--
382
                  if (sc) {
383
                    $info[i].name = value.name
384
                    $info[i].title = value.title
385
                    $info[i].hasHeadImage = value.hasHeadImage
386
                    if (j === 0) {
387
                      that.coopExperts = $info;
388
                    }
389
                  }
390
                })
391
              }
392
            }
393
          };
394
        });
395
      }
396
    }
397
  };
398
</script>
399
400
<style lang="scss" rel="stylesheet/scss">
401
  @import '../../style/index';
402
403
  .header-box {
404
    background-image: url('../../image/personal_bg.png');
405
  }
406
407
  .show-head {
408
    height: 80px;
409
    width: 80px;
410
    border-radius: 50%;
411
    background-size: cover;
412
    margin: auto;
413
  }
414
415
  .content .list-item .list-head.list-circular-head {
416
    border-radius: 50%;
417
  }
418
</style>

+ 4 - 16
src/pages/h5/views/org/org.vue

@ -69,13 +69,7 @@
69 69
        <span>您可能感兴趣的机构</span>
70 70
      </div>
71 71
      <div class="content">
72
        <a v-for="item in likeOrgs" :key="item.index" class="list-item" :href="'org.html?id='+item.id">
73
          <div class="list-head" :style="{backgroundImage: 'url(' + item.logo + ')'}"></div>
74
          <div class="list-info">
75
            <div class="list-owner">{{item.name}}</div>
76
            <div class="list-desc">{{item.compType}}</div>
77
          </div>
78
        </a>
72
        <BaseOrg v-for="item in likeOrgs" :key="item.index" :itemSingle="item" :noBlank="true"></BaseOrg>>
79 73
      </div>
80 74
    </div>
81 75
  </div>
@ -85,12 +79,10 @@
85 79
  import queryDict from '@/libs/queryDict';
86 80
  import queryBase from '@/libs/queryBase';
87 81
88
  import shareOut from '@/components/ShareOut';
89
  import collectCo from '@/components/CollectCo';
90
  import contactChat from '@/components/ContactChat';
91 82
  import baseService from '@/components/subTemplate/BaseService';
92 83
  import baseResource from '@/components/subTemplate/BaseResource';
93 84
  import baseContent from '@/components/subTemplate/BaseContent';
85
  import BaseOrg from '@/components/subTemplate/BaseOrg';
94 86
95 87
  export default {
96 88
    data() {
@ -100,7 +92,6 @@
100 92
        compType: [],
101 93
        orgInfo: '',
102 94
        orgId: '',
103
        elurl: '',
104 95
        platServices: [],
105 96
        serCount: 0,
106 97
        loadingModalShow: false, // 是否显示按钮
@ -127,7 +118,6 @@
127 118
    },
128 119
    created() {
129 120
      this.orgId = urlParse('id');
130
      this.elurl = window.location.href;
131 121
      this.getDictoryData();
132 122
      this.getorgInfo();
133 123
      this.getOrgWave();
@ -137,12 +127,10 @@
137 127
      this.getLikeOrgs();
138 128
    },
139 129
    components: {
140
      shareOut,
141
      collectCo,
142
      contactChat,
143 130
      baseService,
144 131
      baseResource,
145
      baseContent
132
      baseContent,
133
      BaseOrg
146 134
    },
147 135
    methods: {
148 136
      moreService() {

+ 166 - 0
src/pages/h5/views/product/product.vue

@ -0,0 +1,166 @@
1
<template>
2
  <div class="browse-main">
3
    <div class="block-wrapper">
4
        <div style="width:100%">
5
            <div class="content-wrapper" style="padding:0">
6
                <div class="content-wrapper" style="padding:0">
7
                    <previewMagnify v-if="productInfo.img && productInfo.img.length" :previewImg="productInfo.img"></previewMagnify>
8
                  </div>
9
                  <div class="content-wrapper">
10
                      <div class="show-info">
11
                          <div class="info-tit info-tit-big" style="font-size: 20px; line-height:30px; margin-bottom: 4px;">{{productInfo.name}}</div>
12
                          <div class="info-tag">简介:{{productInfo.cnt}}</div>
13
                        </div>
14
                  </div>
15
            </div>
16
            <div class="content-wrapper">
17
                <beyondTo v-if="companyId" :ownerId="companyId" :ownerType="'00'" :styFlag="true"></beyondTo>
18
            </div>
19
        <div class="content-wrapper">
20
          
21
            <el-row :gutter="10" class="rel-detail">
22
              <el-col class="rel-item" :span="24" v-if="productInfo.spec">
23
                <div class="rel-tit">厂商型号:</div>
24
                <div>{{productInfo.spec}}</div>
25
              </el-col>
26
              <el-col class="rel-item" :span="24" v-if="productInfo.producingArea">
27
                <div class="rel-tit">产地:</div>
28
                <div>{{productInfo.producingArea}}</div>
29
              </el-col>
30
              <el-col class="rel-item" :span="24" v-if="productInfo.price">
31
                <div class="rel-tit">官方价格:</div>
32
                <div>{{productInfo.price}}</div>
33
              </el-col>
34
              <el-col class="rel-item" :span="24" v-if="productInfo.parameter">
35
                <div class="rel-tit">性能参数:</div>
36
                <div v-html="productInfo.parameter"></div>
37
              </el-col>
38
              <el-col class="rel-item" :span="24" v-if="productInfo.descp">
39
                <div class="rel-tit">详细介绍:</div>
40
                <div v-html="productInfo.descp"></div>
41
              </el-col>
42
              <el-col class="rel-item" :span="24" v-if="keywords && keywords.length">
43
                <el-row class="tag-item">
44
                  <el-tag v-for="sub in keywords" :key="sub.index">{{sub}}</el-tag>
45
                </el-row>
46
              </el-col>
47
            </el-row>
48
          
49
        </div>
50
        <div class="content-wrapper" v-if="otherProducts && otherProducts.length">
51
            <div class="content-title">
52
              <span>其他产品</span>
53
            </div>
54
            <div class="content">
55
              <BaseProduct v-for="item in otherProducts" :key="item.index" :itemSingle="item" :noBlank="true"></BaseProduct>
56
            </div>
57
          </div>
58
      </div>
59
    </div>
60
    
61
  </div>
62
</template>
63
64
<script>
65
  import { urlParse, strToArr, defaultSet } from '@/libs/util';
66
67
  import previewMagnify from '../components/swiperImg';
68
  import beyondTo from '@/components/BeyondTo';
69
  import BaseProduct from '@/components/subTemplate/BaseProduct';
70
71
  export default {
72
    data() {
73
      return {
74
        productInfo: '',
75
        companyId: '',
76
        keywords: '',
77
        tPosition: 'top-start',
78
        otherProducts: ''
79
      };
80
    },
81
    created() {
82
      this.productId = urlParse('id');
83
      this.getproductInfo();
84
      this.getProductKeyword();
85
    },
86
    components: {
87
      previewMagnify,
88
      beyondTo,
89
      BaseProduct
90
    },
91
    methods: {
92
      getproductInfo() {
93
        this.$axios.get('/ajax/product/qo', {
94
          id: this.productId
95
        }, (res) => {
96
          if (res.success) {
97
            var $info = res.data;
98
            if ($info.img) {
99
              $info.img = strToArr($info.img);
100
            }
101
            document.title = $info.name + '-' + PLAT.info.title
102
            this.companyId = $info.companyId;
103
            this.productInfo = $info;
104
            this.getOtherProducts($info.companyId);
105
          };
106
        });
107
      },
108
      getProductKeyword() {
109
        var that = this
110
        that.$axios.get('/ajax/product/qo/keyword', {
111
          id: that.productId
112
        }, function (res) {
113
          if (res.success && res.data) {
114
            const str = res.data
115
            var objKey = []
116
            if (str.length > 0) {
117
              str.map(item => {
118
                objKey.push(item.keyword)
119
              })
120
            }
121
            that.keywords = objKey
122
          }
123
        })
124
      },
125
      getOtherProducts(id) {
126
        var that = this
127
        that.$axios.get('/ajax/product/pq', {
128
          companyId: id,
129
          pageSize: 6,
130
          pageNo: 1
131
        }, function (res) {
132
          if (res.success && res.data) {
133
            const obj = res.data.data
134
            if (obj.length > 0) {
135
              var arr = []
136
              for (let i = 0; i < obj.length; ++i) {
137
                if (obj[i].id !== that.productId) {
138
                  if (obj[i].img) {
139
                    obj[i].img = strToArr(obj[i].img)[0]
140
                  } else {
141
                    obj[i].img = defaultSet.img.product
142
                  }
143
                  arr.push(obj[i])
144
                }
145
              }
146
            }
147
            if (arr.length > 5) {
148
              arr.splice(5)
149
            }
150
            that.otherProducts = arr
151
          }
152
        })
153
      }
154
    }
155
  };
156
</script>
157
158
<style lang="scss" rel="stylesheet/scss">
159
  @import '../../style/index';
160
  .browse-main .block-wrapper .content-wrapper{
161
    padding: 8px 20px;
162
  }
163
  .browse-main .block-wrapper .content-wrapper .content{
164
    margin:-20px;
165
  }
166
</style>

+ 211 - 0
src/pages/h5/views/resource/resource.vue

@ -0,0 +1,211 @@
1
<template>
2
  <div class="browse-main">
3
    <div class="block-wrapper">
4
        <div style="width:100%">
5
        <div class="content-wrapper" style="padding:0">
6
            <div class="content-wrapper" style="padding:0">
7
                <previewMagnify v-if="resourceInfo.img && resourceInfo.img.length" :previewImg="resourceInfo.img"></previewMagnify>
8
              </div>
9
              <div class="content-wrapper">
10
                  <div class="show-info">
11
                      <div class="info-tit info-tit-big" style="font-size: 20px; line-height:30px; margin-bottom: 4px;">{{resourceInfo.resourceName}}</div>
12
                      <div class="info-tag">应用用途:{{resourceInfo.supportedServices}}</div>
13
                    </div>
14
              </div>
15
        </div>
16
        <div class="content-wrapper">
17
            <beyondTo v-if="owner.id" :ownerId="owner.id" :ownerType="owner.type" :styFlag="true"></beyondTo>
18
        </div>
19
        
20
        <div class="content-wrapper">
21
            <el-row :gutter="10" class="rel-detail">
22
              <el-col class="rel-item" :span="24" v-if="resourceInfo.orgName">
23
                <div class="rel-tit">所属机构:</div>
24
                <div>{{resourceInfo.orgName}}</div>
25
              </el-col>
26
              <el-col class="rel-item" :span="24" v-if="resourceInfo.spec">
27
                <div class="rel-tit">厂商型号:</div>
28
                <div>{{resourceInfo.spec}}</div>
29
              </el-col>
30
              <el-col class="rel-item" :span="24" v-if="resourceInfo.parameter">
31
                <div class="rel-tit">性能参数:</div>
32
                <div v-html="resourceInfo.parameter"></div>
33
              </el-col>
34
              <el-col class="rel-item" :span="24" v-if="resourceInfo.cooperationNotes">
35
                <div class="rel-tit">合作备注:</div>
36
                <div v-html="resourceInfo.cooperationNotes"></div>
37
              </el-col>
38
              <el-col class="rel-item" :span="24" v-if="resourceInfo.descp">
39
                <div class="rel-tit">详细介绍:</div>
40
                <div v-html="resourceInfo.descp"></div>
41
              </el-col>
42
              <el-col class="rel-item" :span="24" v-if="resourceInfo.subject && resourceInfo.subject.length">
43
                <el-row class="tag-item">
44
                  <el-tag v-for="sub in resourceInfo.subject" :key="sub.index">{{sub}}</el-tag>
45
                </el-row>
46
              </el-col>
47
            </el-row>
48
        </div>
49
        <div class="content-wrapper" v-if="likeResources && likeResources.length">
50
          <div class="content-title">
51
            <span>您可能感兴趣的资源</span>
52
          </div>
53
          <div class="content content-nf">
54
            <baseResource v-for="item in likeResources" :key="item.index" :itemSingle="item" :noBlank="true"></baseResource>
55
          </div>
56
        </div>
57
        <div class="content-wrapper" v-if="hotResources && hotResources.length">
58
            <div class="content-title">
59
              <span>热门资源</span>
60
            </div>
61
            <div class="content">
62
                <baseResource v-for="item in hotResources" :key="item.index" :itemSingle="item" :noBlank="true"></baseResource>
63
            </div>
64
          </div>
65
      </div>
66
    </div>
67
  </div>
68
</template>
69
70
<script>
71
  import { urlParse, ImageUrl, defaultSet, strToArr } from '@/libs/util';
72
73
  import previewMagnify from '../components/swiperImg';
74
  import beyondTo from '@/components/BeyondTo';
75
  import contactChat from '@/components/ContactChat';
76
  import baseResource from '@/components/subTemplate/BaseResource';
77
78
  export default {
79
    data() {
80
      return {
81
        resourceInfo: '',
82
        resourceId: '',
83
        elurl: '',
84
        tPosition: 'top-start',
85
        owner: {
86
          id: '',
87
          type: ''
88
        },
89
        hotResources: '',
90
        likeResources: '',
91
        reslinkmans: []
92
      };
93
    },
94
    created() {
95
      this.resourceId = urlParse('id');
96
      this.elurl = window.location.href;
97
      this.getResourceInfo();
98
      this.getLikeResources();
99
      this.getLinkmans();
100
    },
101
    components: {
102
      previewMagnify,
103
      beyondTo,
104
      contactChat,
105
      baseResource
106
    },
107
    methods: {
108
      getResourceInfo() {
109
        var that = this
110
        this.$axios.getk('/ajax/resource/queryOne', {
111
          resourceId: that.resourceId
112
        }, (res) => {
113
          if (res.success) {
114
            var $info = res.data;
115
            if ($info.subject) {
116
              $info.subject = strToArr($info.subject);
117
            }
118
            var ImgUrl = []
119
            if ($info.images && $info.images.length) {
120
              for (let i = 0; i < $info.images.length; ++i) {
121
                ImgUrl.push(ImageUrl('resource/' + $info.images[i].imageSrc))
122
              }
123
            } else {
124
              ImgUrl.push(defaultSet.img.resource)
125
            }
126
            $info.img = ImgUrl
127
            if ($info.resourceType === '1') {
128
              that.owner = {
129
                id: $info.professorId,
130
                type: $info.resourceType
131
              };
132
              that.getHotResources({ 'professorId': $info.professorId })
133
            } else if ($info.resourceType === '2') {
134
              that.owner = {
135
                id: $info.orgId,
136
                type: $info.resourceType
137
              };
138
              that.getHotResources({ 'orgId': $info.orgId }, true)
139
            }
140
            document.title = $info.resourceName + '-' + PLAT.info.title
141
            that.resourceInfo = $info;
142
          };
143
        });
144
      },
145
      getHotResources(obj, num) {
146
        var that = this
147
        var ourl = num ? '/ajax/resource/qaOrgPublish' : '/ajax/resource/qaProPublish'
148
        that.$axios.getk(ourl, obj, function (res) {
149
          if (res.success && res.data) {
150
            const $data = res.data
151
            var hotRes = []
152
            if ($data.length > 1) {
153
              for (var i = 0; i < $data.length; i++) {
154
                if ($data[i].images && $data[i].images.length) {
155
                  $data[i].img = ImageUrl('resource/' + $data[i].images[0].imageSrc)
156
                } else {
157
                  $data[i].img = defaultSet.img.resource
158
                }
159
                if (that.resourceId !== $data[i].resourceId) {
160
                  hotRes.push($data[i])
161
                }
162
              }
163
            }
164
            hotRes.splice(5)
165
            that.hotResources = hotRes
166
          }
167
        })
168
      },
169
      getLikeResources() {
170
        var that = this
171
        that.$axios.getk('/ajax/resource/ralateResources', {
172
          resourceId: that.resourceId
173
        }, function (res) {
174
          if (res.success && res.data) {
175
            const $data = res.data
176
            that.likeResources = $data
177
          }
178
        })
179
      },
180
      getLinkmans() {
181
        var that = this
182
        this.$axios.getk('/ajax/resource/qaLinkman', {
183
          resourceId: that.resourceId
184
        }, function (data) {
185
          if (data.success) {
186
            var $data = data.data;
187
            if ($data.length > 0) {
188
              for (var i = 0; i < $data.length; i++) {
189
                if ($data[i].professor.hasHeadImage) {
190
                  $data[i].uimg = ImageUrl(('head/' + $data[i].professorId + '_l.jpg'), true)
191
                } else {
192
                  $data[i].uimg = defaultSet.img.expert
193
                }
194
              }
195
              that.reslinkmans = $data
196
            }
197
          }
198
        })
199
      }
200
    }
201
  };
202
</script>
203
<style lang="scss" rel="stylesheet/scss">
204
  @import '../../style/index';
205
  .browse-main .block-wrapper .content-wrapper{
206
    padding: 8px 20px;
207
  }
208
  .browse-main .block-wrapper .content-wrapper .content{
209
    margin:-20px;
210
  }
211
</style>

+ 224 - 0
src/pages/h5/views/service/service.vue

@ -0,0 +1,224 @@
1
<template>
2
  <div class="browse-main">
3
    <div class="block-wrapper">
4
      <div style="width:100%">
5
          <div class="content-wrapper" style="padding:0">
6
            <previewMagnify v-if="serveInfo.img && serveInfo.img.length" :previewImg="serveInfo.img"></previewMagnify>
7
          </div>
8
            <div class="content-wrapper">
9
            <div class="show-info">
10
                <div class="info-tit info-tit-big" style="font-size: 20px; line-height:30px; margin-bottom: 4px;">{{serveInfo.name}}</div>
11
                <div class="info-tag">内容:{{serveInfo.cnt}}</div>
12
              </div>
13
        </div>
14
        <div class="content-wrapper">
15
            <beyondTo v-if="ownerB.id" :ownerId="ownerB.id" :ownerType="ownerB.type" :styFlag="true"></beyondTo>
16
        </div>
17
        <div class="content-wrapper">
18
            <el-row :gutter="10" class="rel-detail">
19
              <el-col class="rel-item" :span="24" v-if="serveInfo.cooperation">
20
                <div class="rel-tit">合作备注:</div>
21
                <div v-html="serveInfo.cooperation"></div>
22
              </el-col>
23
              <el-col class="rel-item" :span="24" v-if="serveInfo.descp">
24
                <div class="rel-tit">详细介绍:</div>
25
                <div v-html="serveInfo.descp"></div>
26
              </el-col>
27
              <el-col class="rel-item" :span="24" v-if="serveInfo.keywords && serveInfo.keywords.length">
28
                <el-row class="tag-item">
29
                  <el-tag v-for="sub in serveInfo.keywords" :key="sub.index">{{sub}}</el-tag>
30
                </el-row>
31
              </el-col>
32
            </el-row>
33
        </div>
34
        <div class="content-wrapper" v-if="likeserves && likeserves.length">
35
          <div class="content-title">
36
            <span>您可能感兴趣的服务</span>
37
          </div>
38
          <div class="content content-nf">
39
            <baseService v-for="item in likeserves" :key="item.index" :itemSingle="item" :noBlank="true"></baseService>
40
          </div>
41
        </div>
42
        <div class="content-wrapper" v-if="hotserves && hotserves.length">
43
            <div class="content-title">
44
              <span>热门服务</span>
45
            </div>
46
            <div class="content content-nf">
47
                <baseService v-for="item in hotserves" :key="item.index" :itemSingle="item" :noBlank="true"></baseService>
48
            </div>
49
          </div>
50
        </div>
51
    </div>
52
  </div>
53
</template>
54
55
<script>
56
  import { urlParse, ImageUrl, defaultSet, strToArr } from '@/libs/util';
57
58
  import previewMagnify from '../components/swiperImg';
59
  import collectCo from '@/components/CollectCo';
60
  import beyondTo from '@/components/BeyondTo';
61
  import contactChat from '@/components/ContactChat';
62
63
  import baseService from '@/components/subTemplate/BaseService';
64
65
  export default {
66
    data() {
67
      return {
68
        serveInfo: '',
69
        serveId: '',
70
        elurl: '',
71
        tPosition: 'top-start',
72
        ownerB: {
73
          id: '',
74
          type: ''
75
        },
76
        hotserves: '',
77
        likeserves: '',
78
        reslinkmans: []
79
      };
80
    },
81
    created() {
82
      this.serveId = urlParse('id');
83
      this.elurl = window.location.href;
84
      this.getserveInfo();
85
      this.getLikeserves();
86
      this.getLinkmans();
87
    },
88
    components: {
89
      previewMagnify,
90
      collectCo,
91
      beyondTo,
92
      contactChat,
93
      baseService
94
    },
95
    methods: {
96
      getserveInfo() {
97
        this.$axios.getk('/ajax/ware/qo', {
98
          id: this.serveId
99
        }, (res) => {
100
          if (res.success) {
101
            var $info = res.data;
102
            if ($info.keywords) {
103
              $info.keywords = strToArr($info.keywords);
104
            }
105
            var arr = []
106
            if ($info.images) {
107
              arr = strToArr($info.images)
108
              for (let i = 0; i < arr.length; ++i) {
109
                arr[i] = ImageUrl('ware' + arr[i])
110
              }
111
              $info.img = arr
112
            } else {
113
              arr[0] = defaultSet.img.service
114
              $info.img = arr
115
            }
116
            if ($info.category) {
117
              this.ownerB = {
118
                id: $info.owner,
119
                type: $info.category
120
              }
121
              this.getHotserves($info.category, $info.owner)
122
            }
123
            document.title = $info.name + '-' + PLAT.info.title
124
            this.serveInfo = $info
125
          };
126
        });
127
      },
128
      getHotserves(catagory, owner) {
129
        var that = this
130
        that.$axios.getk('/ajax/ware/byOwnerWithPageViews', {
131
          id: that.serveId,
132
          category: catagory,
133
          owner: owner,
134
          rows: 5
135
        }, function (res) {
136
          if (res.success && res.data) {
137
            const $data = res.data
138
            var hotRes = []
139
            if ($data.length > 1) {
140
              for (var i = 0; i < $data.length; i++) {
141
                if ($data[i].images) {
142
                  $data[i].img = ImageUrl('ware/' + strToArr($data[i].images)[0])
143
                } else {
144
                  $data[i].img = defaultSet.img.service
145
                }
146
                if (that.serveId !== $data[i].id) {
147
                  hotRes.push($data[i])
148
                }
149
              }
150
            }
151
            hotRes.splice(5)
152
            that.hotserves = hotRes
153
          }
154
        })
155
      },
156
      getLikeserves() {
157
        var that = this
158
        that.$axios.getk('/ajax/ware/ralateWare', {
159
          id: that.serveId,
160
          rows: 5
161
        }, function (res) {
162
          if (res.success && res.data) {
163
            const $data = res.data
164
            var arr = [];
165
            for (var i = 0; i < $data.length; i++) {
166
              arr.push($data[i].id)
167
            }
168
            if (arr.length) {
169
              that.$axios.getk('/ajax/ware/qm', {
170
                id: arr
171
              }, function (data) {
172
                that.likeserves = data.data
173
              })
174
            }
175
          }
176
        })
177
      },
178
      getLinkmans() {
179
        var that = this
180
        this.$axios.getk('/ajax/ware/pro', {
181
          id: that.serveId
182
        }, function (res) {
183
          if (res.success) {
184
            var $data = res.data;
185
            var arr = []
186
            if ($data.length > 0) {
187
              for (var i = 0; i < $data.length; i++) {
188
                arr.push($data[i].professor)
189
              }
190
              if (arr.length) {
191
                that.$axios.getk('/ajax/professor/qm', {
192
                  id: arr
193
                }, function (data) {
194
                  if (data.success && data.data) {
195
                    if (data.data.length > 0) {
196
                      var str = data.data
197
                      for (var j = 0; j < str.length; j++) {
198
                        if (str[j].hasHeadImage) {
199
                          str[j].img = ImageUrl(('head/' + str[j].id + '_l.jpg'), true)
200
                        } else {
201
                          str[j].img = defaultSet.img.expert
202
                        }
203
                      }
204
                      that.reslinkmans = data.data
205
                    }
206
                  }
207
                })
208
              }
209
            }
210
          }
211
        })
212
      }
213
    }
214
  }
215
</script>
216
<style lang="scss" rel="stylesheet/scss">
217
  @import '../../style/index';
218
  .browse-main .block-wrapper .content-wrapper{
219
    padding: 8px 20px;
220
  }
221
  .browse-main .block-wrapper .content-wrapper .content{
222
    margin:-20px;
223
  }
224
</style>

+ 1 - 0
src/styles/browse.scss

@ -22,6 +22,7 @@
22 22
          font-size:15px;
23 23
          line-height:26px;
24 24
          width:100%;
25
          word-break: break-word;
25 26
          .rel-item{
26 27
            margin-bottom:15px;
27 28
            &:last-child{