ticon octicon-issue-opened"> Issues 0 Pull-Requests 0 Commits 79 Releases 0 Wiki
Quellcode durchsuchen

plat首页.浏览页面

luyanan vor 6 Jahren
Ursprung
Commit
1183785405
49 geänderte Dateien mit 2382 neuen und 672 gelöschten Zeilen
  1. 1 1
      package.json
  2. 133 157
      src/common/stylus/browse.styl
  3. 1 3
      src/common/stylus/common.styl
  4. 27 2
      src/libs/axios.js
  5. 10 1
      src/libs/http.js
  6. 124 17
      src/libs/util.js
  7. 147 175
      src/router/index.js
  8. 22 34
      src/views/frontviews/Dashboard.vue
  9. 2 4
      src/views/frontviews/ViewAboutUs.vue
  10. 0 0
      src/views/frontviews/ViewExpertPool/list.vue
  11. 14 0
      src/views/frontviews/ViewFindResource/index.vue
  12. 6 8
      src/views/frontviews/ViewFindResource.vue
  13. 14 0
      src/views/frontviews/ViewFindResult/index.vue
  14. 7 9
      src/views/frontviews/ViewFindResult.vue
  15. 14 0
      src/views/frontviews/ViewFindServe/index.vue
  16. 29 31
      src/views/frontviews/ViewFindServe.vue
  17. 5 0
      src/views/frontviews/ViewOrganization/index.vue
  18. 0 0
      src/views/frontviews/ViewOrganization/list.vue
  19. 5 0
      src/views/frontviews/ViewRegCompany/index.vue
  20. 4 3
      src/views/frontviews/ViewRegAgency.vue
  21. 7 1
      src/views/frontviews/platTrend/ViewPlatTrend.vue
  22. 7 9
      src/views/frontviews/platTrend/ViewPlatTrendNews.vue
  23. 5 7
      src/views/frontviews/platTrend/ViewPlatTrendTrends.vue
  24. 201 0
      src/views/infoshow/compShow/comp.vue
  25. 9 0
      src/views/infoshow/compShow/index.vue
  26. 141 0
      src/views/infoshow/compShow/product.vue
  27. 107 0
      src/views/infoshow/components/BeyondTo/index.vue
  28. BIN
      src/views/infoshow/components/CollectCo/img/icon_shoucang_hig.png
  29. BIN
      src/views/infoshow/components/CollectCo/img/icon_shoucang_nor.png
  30. 38 0
      src/views/infoshow/components/CollectCo/index.vue
  31. BIN
      src/views/infoshow/components/PreviewMagnify/img/mask.png
  32. 208 0
      src/views/infoshow/components/PreviewMagnify/index.vue
  33. 65 64
      src/views/infoshow/components/ShareOut/index.vue
  34. 200 37
      src/views/infoshow/expertShow/index.vue
  35. 199 40
      src/views/infoshow/orgShow/index.vue
  36. 142 0
      src/views/infoshow/resourceShow/index.vue
  37. 14 0
      src/views/infoshow/resultShow/index.vue
  38. 156 0
      src/views/infoshow/resultShow/patent.vue
  39. 141 0
      src/views/infoshow/serviceShow/index.vue
  40. 1 1
      src/views/layout/components/Navbar.vue
  41. 6 24
      src/views/layout/components/TheHeader.vue
  42. 7 12
      src/views/sub-component/BaseAgency.vue
  43. 4 6
      src/views/sub-component/BaseArticle.vue
  44. 83 0
      src/views/sub-component/BaseCompany.vue
  45. 8 13
      src/views/sub-component/BaseExpert.vue
  46. 5 5
      src/views/sub-component/BaseResource.vue
  47. 57 0
      src/views/sub-component/BaseResult.vue
  48. 4 4
      src/views/sub-component/BaseService.vue
  49. 2 4
      src/views/sub-component/DynamicTags.vue

+ 1 - 1
package.json

@ -19,7 +19,7 @@
19 19
    "axios": "^0.17.1",
20 20
    "babel-polyfill": "^6.26.0",
21 21
    "element-ui": "^2.3.8",
22
    "qrcode": "^1.3.2",
22
    "qrcodejs2": "0.0.2",
23 23
    "style-loader": "^0.20.3",
24 24
    "stylus": "^0.54.5",
25 25
    "swiper": "^4.2.6",

+ 133 - 157
src/common/stylus/browse.styl

@ -1,47 +1,3 @@
1
2
3
4
/*.bottomShow .shareCode{bottom:auto;top:30px;}
5
.bottomShow .shareCode:after{border:12px solid transparent;border-bottom-color:rgba(0,0,0,.6);top:-24px;left:22px;bottom:auto;}*/
6
7
.headconBox .cmpimgBox{width:210px;border-radius:0;background:#fff;}
8
.headconBox .cmpimgBox .boxBlock{width:210px;}
9
.headconBox .reInfoBlock{width:100%;padding-left:170px;}
10
.headconBox .reInfoBlock .h1Font{font-size: 18px;color:#666;margin-bottom:10px;}
11
.headconBox .reInfoBlock .h2Font{font-size: 16px;color:#666;margin-bottom:8px;}
12
.headconBox .reInfoBlock .h3Font{font-size: 14px;color:#999;line-height: 20px;}
13
.headconBox .reInfoBlock.head-center{}
14
.headconBox .head-center .h1Font{margin-bottom:0;}
15
.headconBox .head-center .h2Font{margin-bottom:0;}
16
.headconBox .head-center .proEdit{font-size: 14px;padding-left:24px;right: 34px;top:40px;}
17
.headconBox .goSpan{position: absolute;right: 30px;top:50%;margin-top:-35px;}
18
.operateBlock{font-size: 14px;color:#999;}
19
.operateBlock>ul>li{float: left;font-size: 14px;color:#999;min-height: 24px;margin-right: 20px;}
20
.operateBlock>ul>li .operateicon{margin-left:5px;cursor: pointer;}
21
.operateBlock>ul>li>span{position: relative;top:-2px;font-size: 14px;}
22
.headconBox .operateBlock>ul>li{margin-right:0;}
23
/*
24
.navconBox{padding:0 30px;background: #fff;border-bottom: 20px #f4f6f8 solid;position: relative;}
25
.navconBox .rightbtn{position: relative;top:0;width:54px;}
26
.navconBox .rightbtn .foldtr {top: 26px;right:32px;}
27
.navconBox .rightbtn .foldtr:before{border-top-color:#666;}
28
.navconBox>ul{position: relative}
29
.navconBox>ul>li{position:relative;float: left;padding:20px 0;cursor:pointer;margin-right:36px;font-size: 16px;color: #999;}
30
.navconBox>ul>li:last-child{margin-right: 0;}
31
.navconBox>ul>li>.counts{font-size: 15px;}
32
.navconBox>ul>li.liNow:after{position: absolute;left: 0;bottom: 0;content:"";height:3px;background:#000;width: 100%;}
33
.navconBox>ul>li.liNow{color: #000;}
34
.navconBox .moreNav{display:none;border-top: 1px solid #E5E5E5;margin:0 -30px;padding:0 30px}
35
.navconBox .moreNav .moreNavUl{}
36
.navconBox .moreNav .moreNavUl>li{position: relative;float: left;padding: 20px 0;cursor: pointer;margin-right: 60px; font-size: 16px;color: #999;}
37
.navconBox .moreNav .moreNavUl>li:last-child{margin-right: 0;}
38
.navconBox .moreNav .moreNavUl>li.liNow{color: #000;}
39
.navconBox .moreNav .moreNavUl .rightbtn{width:110px;}
40
.navconBox .moreNav .table-drop{height:auto;top:50px;right:-8px;width:140px;}
41
.navconBox .moreNav .table-drop>li{position: relative;padding:10px 0;text-align:center;cursor: pointer;font-size: 16px;color: #999;}
42
.navconBox .moreNav .table-drop>li.liNow{color: #000;}
43
.navconBox .moreNav .moreNavUl .rightbtn .foldtr{right:24px;}*/
44
45 1
  .browse-main
46 2
    .block-wrapper
47 3
      display: flex
@ -50,12 +6,34 @@
50 6
      .content-wrapper
51 7
        width:100%
52 8
        box-sizing:border-box
9
        text-align:justify
10
        .tag-item
11
          margin: 10px 0
12
          .el-tag
13
            margin:5px
14
            &.tag-line
15
              display:inline-block
16
              width:auto
17
        .rel-detail
18
          font-size:15px
19
          line-height:26px
20
          .rel-item
21
            margin-bottom:15px
22
            &:last-child
23
              margin-bottom:0
24
            .rel-tit
25
              font-size: 16px
26
              line-height:30px
27
      .split-other
28
        margin-bottom:20px
53 29
      .headcon-box
54 30
        min-height:160px
55 31
        background: #fff
56 32
        position: relative
57 33
        display:flex
58 34
        align-items: center
35
        &.detail-box
36
          min-height:auto
59 37
        .headimg-box
60 38
          position:absolute
61 39
          top:50%
@ -66,130 +44,128 @@
66 44
          border:1px solid #E5E5E5
67 45
          border-radius:50%
68 46
          background-size: cover
69
        .reInfo-box
47
        .zoom-box
48
          width: 362px
49
        .show-info
70 50
          width:100%
71
          padding-left:170px
51
          &.reInfo-box
52
            padding-left:170px
72 53
          .info-tit
73 54
            font-size: 18px
74
            color:#666
55
            color:$commonFont
75 56
            margin-bottom:10px
57
            &.info-tit-big
58
              font-size: 22px
59
              line-height: 32px
76 60
          .info-tag
77 61
            font-size: 16px
78
            color:#666
79
            margin-bottom:8px
80
          .h3Font{font-size: 14px;color:#999;line-height: 20px;}
62
            color:$commonFont
63
            margin-bottom:10px
64
          .info-operate
65
            display:flex
66
            color:$secondaryFont
67
            .addr
68
              margin-right: 10px
69
        .goSpan
70
          min-width: 180px
71
        &.org-head
72
          .headimg-box
73
            border-radius(4px)
74
            center-items(200px, 140px)
75
          .reInfo-box
76
            padding-left:230px
77
        &.hdetail-box
78
          align-items:flex-start
79
          .reInfo-box
80
            padding-left:15px
81
            position: relative
82
            min-height: 270px
83
            padding-bottom: 24px
84
            .zoom-operate
85
              position:absolute
86
              bottom:0
81 87
      .wrapper-left
82 88
        padding: 0
83 89
        display: flex
84 90
        flex-direction: column
85
        justify-content: space-between
91
        .el-menu-demo
92
         margin-bottom:20px
86 93
      .wrapper-right
87 94
        width: 280px
88
        height: 280px
89
        .info-main
90
          font-size: 24px
91
          line-height: 34px
92
          color:$mainFont
93
        .info-tip
94
          margin-top:12px
95
          font-size: 14px
96
          line-height: 22px
97
          color:$secondaryFont
98
      .plat-news
95
        .content-wrapper
96
          width: 100%
97
          box-sizing: border-box
98
          margin-bottom: 20px
99
          .right-split
100
            margin-top: 20px
101
            padding-top: 10px
102
            position: relative
103
            &::before
104
              position: absolute
105
              right: 0
106
              left: 0
107
              top: 0
108
              content:''
109
              border-top:1px solid #dadada
110
            &:first-child
111
              margin-top: 0
112
              padding-top: 0
113
              &::before
114
                content: none
115
          .info-main
116
            font-size: 24px
117
            line-height: 34px
118
            color:$mainFont
119
          .info-tip
120
            margin-top:12px
121
            font-size: 14px
122
            line-height: 22px
123
            color:$secondaryFont
124
      .left-main
99 125
        width:800px
100
        height:210px
101
        .content-title
102
          .el-tabs__item
103
            font-size:16px
104
            font-weight:bold
105
          .el-tabs__item.is-active
106
            background:$mainColor
107
            color:#ffffff
108
          .el-tabs--top .el-tabs__item.is-top:nth-child(2)
109
            padding-left:20px
110
          .el-tabs--top .el-tabs__item.is-top:last-child
111
            padding-right:20px
112
        .content
113
          display: flex
114
          font-size: 15px
115
          line-height: 30px
116
          font-weight:normal
117
          .pictures
118
            center-items()
119
          .maincon.maincon2
120
            flex:1 0 180px
121
            padding-left:15px
122
            height:120px
123
            overflow:hidden
124
            li>a
125
              display: flex
126
              justify-content: space-between
127
              line-height:30px
128
              .topic
129
                display:inline-block
130
                width:400px
131
                text-ellipsis()
132
              .time
133
                width: 100px
134
                text-align: right
135
                color:$secondaryFont
136
            &.maincon2
126
        .el-tabs__nav-wrap.is-top
127
          background-color: #ffffff
128
          border:none
129
          padding:10px 20px
130
          &::after
131
            content:none
132
        .el-tabs__item
133
          font-size:15px
134
        .el-tabs__header
135
          margin-bottom:20px
136
        .inner-wrapper
137
          margin-bottom:20px
138
          &:last-child
139
            margin-bottom:0
140
          .content-title
141
            margin-bottom:2px
142
          .content
143
            display: flex
144
            font-size: 15px
145
            line-height: 30px
146
            font-weight:normal
147
            word-break: break-all
148
            .ulM
137 149
              width:100%
138
              padding:0
139
              .owner
140
                display:inline-block
141
                width:180px
142
                text-ellipsis()
143
      .about-us
144
        width:280px
145
        height:470px
146
        .content
147
          text-ellipsis-n(12,28px)
148
      .full-wrapper
149
        width:100%
150
        .content-title
151
          .content-search
152
            display:flex
153
            align-items:center
154
            .search-wrapper
155
              display:flex
156
              margin-left:15px
157
              .el-input__inner
158
                line-height:32px
159
                height:32px
160
                border-top-right-radius:0
161
                border-bottom-right-radius:0
162
              .el-button
163
                padding:8px 10px
164
                border-top-left-radius:0
165
                border-bottom-left-radius:0
166
          .content-more
167
          .item-more
168
            display:inline-block
169
            padding-left:20px
170
            color:$secondaryFont
171
        .item-block
172
          width:182px
173
          overflow:hidden
174
          .item-pic
175
            center-items()
176
          .item-text
177
            margin-top:6px
178
            line-height:30px
179
            &.item-left
180
              text-align:center
181
              text-ellipsis()
182
            .title
183
              color:$mainFont
184
              text-ellipsis()
185
            .desc
186
              margin-top:3px
187
              color:$commonFont
188
              text-ellipsis-n(2,20px)
189
              height:40px
190
            .owner
191
              margin-top:10px
192
              color:$secondaryFont
193
              text-ellipsis()
194
195
150
              .liM
151
                padding-left:15px
152
                margin-bottom:6px
153
                &:last-child
154
                  margin-bottom:0
155
                .liM-tit
156
                  position:relative
157
                  color:$mainFont
158
                  small
159
                    margin-left:10px
160
                    color:$secondaryFont
161
                  &::before
162
                    content:''
163
                    position: absolute
164
                    left:-12px
165
                    top:13px
166
                    width:6px
167
                    height:6px
168
                    background:$mainColor
169
                    border-radius: 50%
170
                .liM-con
171
                  color:$commonFont

+ 1 - 3
src/common/stylus/common.styl

@ -64,6 +64,7 @@ a
64 64
    line-height: 40px*/
65 65
  .content-more
66 66
    font-size:13px
67
    cursor:pointer
67 68
    color:$secondaryFont
68 69
    position:absolute
69 70
    right: 0
@ -89,7 +90,4 @@ a
89 90
  &.icon-real
90 91
    width:24px
91 92
    bg-image('/static/comimg/porfile_icon_shimin_nor.png')
92
93
94
95 93
  

+ 27 - 2
src/libs/axios.js

@ -50,9 +50,34 @@ axiosUtil.interceptors.response.use(function (response) {
50 50
    return Promise.reject(error);
51 51
});
52 52
53
var ret = {
54
  get: function(url, data, sh, eh) {
55
    axiosUtil({
56
      method: 'get',
57
      url: url,
58
      params: data
59
    }).then(res => {
60
      sh(res);
61
    }).catch(err => {
62
      if (eh) eh(err);
63
    });
64
  },
65
  post: function(url, data, sh, eh) {
66
    axiosUtil({
67
      method: 'post',
68
      url: url,
69
      data: data
70
    }).then(res => {
71
      sh(res);
72
    }).catch(err => {
73
      if (eh) eh(err);
74
    });
75
  }
76
};
77
53 78
export default {
54 79
  install () {
55
    Vue.prototype.$axios = axiosUtil;
56
    Vue.axios = axiosUtil;
80
    Vue.prototype.$axios = ret;
81
    Vue.axios = ret;
57 82
  }
58 83
};

+ 10 - 1
src/libs/http.js

@ -79,12 +79,21 @@ http.kxQurey = {
79 79
      query: '/ajax/article/query', // 文章详细内容
80 80
      pqpublish: '/ajax/article/pqpublish' // 已发布的文章列表
81 81
    },
82
    resource: {
83
      query: '/ajax/resource/queryOne'
84
    },
85
    patent: {
86
      query: '/ajax/ppatent/qo',
87
      author: '/ajax/ppatent/authors'
88
    },
82 89
    professor: {
83 90
      query: '/ajax/professor/baseInfo/', // 专家基础信息
91
      query2: '/ajax/professor/info/',
84 92
      researchArea: '/ajax/researchArea/' // 研究方向
85 93
    },
86 94
    org: {
87
      query: '/ajax/org/' // 企业基础信息
95
      query: '/ajax/org/', // 企业基础信息
96
      reg: '/ajax/org/regInfo' // 机构资质
88 97
    },
89 98
    leaveMsg: {
90 99
      count: '/ajax/leavemsg/count' // 留言数量

+ 124 - 17
src/libs/util.js

@ -120,6 +120,31 @@ util.Dictionary = {
120 120
    }]
121 121
};
122 122
123
// 企业规模
124
util.orgSizeShow = {
125
  '1': '50人以内',
126
  '2': '50-100人',
127
  '3': '100-200人',
128
  '4': '200-500人',
129
  '5': '500-1000人',
130
  '6': '1000人以上'
131
};
132
133
// 企业类型
134
util.orgTypeShow = {
135
  '2': '上市企业',
136
  '3': '外资企业',
137
  '4': '合资企业',
138
  '5': '独资企业',
139
  '6': '个体经营',
140
  '7': '政府机构',
141
  '8': '公益组织',
142
  '9': '协会学会',
143
  '10': '新闻媒体',
144
  '11': '教育机构',
145
  'undefined': ''
146
};
147
123 148
/**
124 149
 * 数据字典
125 150
 */
@ -196,7 +221,64 @@ util.urlParse = function (name) {
196 221
 * 拼接图片链接地址
197 222
 */
198 223
util.ImageUrl = function (str, bol) {
199
    return bol ? (ekexiuUrl + '/images/' + str) : (ekexiuUrl + '/data/' + str);
224
  return bol ? (ekexiuUrl + '/images/' + str) : (ekexiuUrl + '/data/' + str);
225
};
226
227
/**
228
 * 拼接用户-所在机构,所属部门,职位
229
 * 拼接用户-职称/职位,所在机构 bol
230
 */
231
util.formatOfft = function (str, bol) {
232
  var proOther = '';
233
  var proOtherBol = '';
234
  if (!bol) {
235
    if (str.orgName) {
236
      if (str.department) {
237
        if (str.office) {
238
          proOther = str.orgName + ',' + str.department + ',' + str.office;
239
        } else {
240
          proOther = str.orgName + ',' + str.department;
241
        };
242
      } else {
243
        if (str.office) {
244
          proOther = str.orgName + ',' + str.office;
245
        } else {
246
          proOther = str.orgName;
247
        };
248
      };
249
    } else {
250
      if (str.department) {
251
        if (str.office) {
252
          proOther = str.department + ',' + str.office;
253
        } else {
254
          proOther = str.department;
255
        };
256
      } else {
257
        if (str.office) {
258
          proOther = str.office;
259
        };
260
      };
261
    };
262
  } else {
263
    if (str.title) {
264
      if (str.orgName) {
265
        proOtherBol = str.title + ',' + str.orgName;
266
      } else {
267
        proOtherBol = str.title;
268
      }
269
    } else {
270
      if (str.office) {
271
        if (str.orgName) {
272
          proOtherBol = str.office + ',' + str.orgName;
273
        } else {
274
          proOtherBol = str.office;
275
        }
276
      } else {
277
        proOtherBol = '';
278
      }
279
    }
280
  }
281
  return bol ? proOtherBol : proOther;
200 282
};
201 283
202 284
// util.cutOutUrl = function (str) {
@ -208,28 +290,28 @@ util.ImageUrl = function (str, bol) {
208 290
/**
209 291
 * String与Array之间的转换
210 292
 */
211
// util.strToArr = function (str) {
212
//     if (str) {
213
//         var subs = new Array();
214
//         if (subs.indexOf(',')) {
215
//             subs = str.split(',');
216
//         } else {
217
//             subs[0] = str;
218
//         }
219
//         return subs;
220
//     }
221
// };
222
// util.arrToStr = function (arr) {
223
//     var newStr = arr.join(',');
224
//     return newStr;
225
// };
293
util.strToArr = function (str) {
294
  if (str) {
295
    var subs = [];
296
    if (str.indexOf(',')) {
297
        subs = str.split(',');
298
    } else {
299
        subs[0] = str;
300
    }
301
    return subs;
302
  }
303
};
304
util.arrToStr = function (arr) {
305
  var newStr = arr.join(',');
306
  return newStr;
307
};
226 308
227 309
/*
228 310
 * 根据Value格式化为带有换行、空格格式的HTML代码
229 311
 * @param strValue {String} 需要转换的值
230 312
 * @return  {String}转换后的HTML代码
231 313
 * @example
232
 * getFormatCode("测\r\n\s试")  =>  “测<br/> 试”
314
 * getFormatCode('测\r\n\s试')  =>  “测<br/> 试”
233 315
 */
234 316
util.getFormatCode = function(strValue) {
235 317
  return strValue.replace(/\r\n/g, '<br/>').replace(/\n/g, '<br/>').replace(/\s/g, ' ');
@ -309,4 +391,29 @@ util.dateChange = function(startTime) { // 默认返回yyyy月MM日dd HH:mm
309 391
    }
310 392
};
311 393
394
util.TimeTr = function(dealtime) {
395
  var myDate = new Date();
396
  var s = dealtime;
397
  var y = s.substr(0, 4);
398
  var m = s.substr(4, 2);
399
  var d = s.substr(6, 2);
400
  var h = s.substr(8, 2);
401
  var minute = s.substr(10, 2);
402
  var formatTime;
403
  if (s.length <= 6) {
404
    formatTime = y + '年' + m.replace(/\b(0+)/gi, '') + '月';
405
  } else if (s.length > 6 && s.length <= 8) {
406
    formatTime = m.replace(/\b(0+)/gi, '') + '月' + d.replace(/\b(0+)/gi, '') + '日 ';
407
    if (y !== myDate.getFullYear()) {
408
      formatTime = y + '年' + m.replace(/\b(0+)/gi, '') + '月' + d.replace(/\b(0+)/gi, '') + '日 ';
409
    }
410
  } else {
411
    formatTime = m.replace(/\b(0+)/gi, '') + '月' + d.replace(/\b(0+)/gi, '') + '日 ' + h + ':' + minute;
412
    if (y !== myDate.getFullYear()) {
413
      formatTime = y + '年' + m.replace(/\b(0+)/gi, '') + '月' + d.replace(/\b(0+)/gi, '') + '日 ' + h + ':' + minute;
414
    }
415
  }
416
  return formatTime;
417
};
418
312 419
export default util;

+ 147 - 175
src/router/index.js

@ -1,135 +1,3 @@
1
// import Main from '@/components/Main.vue';
2
// import WorkMain from '@/components/bench-views/WorkCommon.vue';
3
// // 全屏展示页面
4
// export const loginRouter = {
5
//     path: '/loginPlat',
6
//     name: 'loginPlat',
7
//     meta: {
8
//         title: 'Login-登录'
9
//     },
10
//     component: () => import('@/components/form-views/loginPlat.vue')
11
// };
12
// export const pwdRouter = {
13
//     path: '/findPwd',
14
//     name: 'findPwd',
15
//     meta: {
16
//         title: '找回密码'
17
//     },
18
//     component: () => import('@/components/form-views/findPwd.vue')
19
// };
20
// export const upMail = {
21
//     path: '/upMail',
22
//     name: 'upMail',
23
//     meta: {
24
//         title: '邮箱更换'
25
//     },
26
//     component: () => import('@/components/form-views/upMail.vue')
27
// };
28
29
// // 作为Main组件的子页面展示
30
// export const otherRouter = {
31
//   path: '/',
32
//   name: 'otherRouter',
33
//   redirect: 'home',
34
//   component: Main,
35
//   children: [
36
//     { path: 'home',
37
//       title: '首页',
38
//       name: 'home_index',
39
//       component: () => import('@/components/main-views/ViewHome.vue')
40
//     },
41
//     { path: 'platTrends',
42
//       title: '平台动态',
43
//       name: 'platTrends',
44
//       component: () => import('@/components/main-views/ViewPlatTrend.vue')
45
//     },
46
//     { path: 'findServe',
47
//       title: '找服务',
48
//       name: 'findServe',
49
//       component: () => import('@/components/main-views/ViewFindServe.vue')
50
//     },
51
//     { path: 'findResource',
52
//       title: '找资源',
53
//       name: 'findResource',
54
//       component: () => import('@/components/main-views/ViewFindResource.vue')
55
//     },
56
//     { path: 'expertPool',
57
//       title: '专家顾问',
58
//       name: 'expertPool',
59
//       component: () => import('@/components/main-views/ViewExpertPool.vue')
60
//     },
61
//     { path: 'cooperationAgency',
62
//       title: '合作机构',
63
//       name: 'cooperationAgency',
64
//       component: () => import('@/components/main-views/ViewCooperationAgency.vue')
65
//     },
66
//     { path: 'about',
67
//       title: '关于我们',
68
//       name: 'about',
69
//       component: () => import('@/components/main-views/ViewAboutUs.vue')
70
//     }
71
//   ]
72
// };
73
74
// // 作为工作台bench子页面展示
75
// export const appRouter = {
76
//   path: '',
77
//   name: 'appRouter',
78
//   component: WorkMain,
79
//   children: [
80
//     {
81
//       path: 'WorkHome',
82
//       titile: '平台主页',
83
//       component: () => import('@/components/bench-views/WorkHome.vue')
84
//     },
85
//     {
86
//       path: 'UpdateInfo',
87
//       titile: '修改资料',
88
//       component: () => import('@/components/form-views/UpdateInfo.vue')
89
//     },
90
//     {
91
//       path: 'ContentManagement',
92
//       titile: '内容管理',
93
//       component: () => import('@/components/bench-views/contentManagement/ContentManagement.vue')
94
//     },
95
//     {
96
//       path: 'PublishArticle',
97
//       titile: '文章发布及修改',
98
//       component: () => import('@/components/bench-views/contentManagement/PublishArticle.vue')
99
//     },
100
//     {
101
//       path: 'PreviewArticle',
102
//       titile: '文章预览',
103
//       component: () => import('@/components/bench-views/contentManagement/PreviewArticle.vue')
104
//     },
105
//     {
106
//       path: 'BusinessManagement',
107
//       titile: '企业管理',
108
//       component: () => import('@/components/bench-views/businessManagement/EnterBusiness.vue')
109
//     },
110
//     {
111
//       path: 'DemandSearch',
112
//       titile: '需求查询',
113
//       component: () => import('@/components/bench-views/demandSearch/DemandSearch.vue')
114
//     },
115
//     {
116
//       path: 'ButtService',
117
//       titile: '对接服务',
118
//       component: () => import('@/components/bench-views/abutmentService/ButtService.vue')
119
//     },
120
//     {
121
//       path: 'AccountSettings',
122
//       titile: '账户设置',
123
//       component: () => import('@/components/form-views/AccountSettings.vue')
124
//     },
125
//     {
126
//       path: 'BindAccount',
127
//       titile: '账号绑定',
128
//       component: () => import('@/components/form-views/BindAccount.vue')
129
//     }
130
//   ]
131
// };
132
133 1
import Vue from 'vue';
134 2
import Router from 'vue-router';
135 3
import Layout from '@/views/layout/Layout';
@ -161,53 +29,111 @@ const constantRouterMap = [
161 29
    }]
162 30
  },
163 31
  {
164
    path: '/findServe',
32
    path: '',
165 33
    component: Layout,
166
    children: [{
167
      path: '',
168
      component: () => import('@/views/frontviews/ViewFindServe'),
169
      name: 'findServe',
170
      meta: { title: '找服务' }
171
    }]
34
    children: [
35
      {
36
        name: 'findServe',
37
        path: '/findServe',
38
        redirect: { name: 'serve_list' },
39
        component: () => import('@/views/frontviews/ViewFindServe/index'),
40
        meta: { title: '找服务' },
41
        children: [
42
          {
43
            name: 'serve_list',
44
            path: '/serve_list',
45
            component: () => import('@/views/frontviews/ViewFindServe/list')
46
          },
47
          {
48
            path: '/serve_show',
49
            name: 'serve_show',
50
            component: () => import('@/views/infoshow/serviceShow'),
51
            meta: { title: '服务名称' }
52
          }
53
        ]
54
      }
55
    ]
172 56
  },
173 57
  {
174
    path: '/findResource',
58
    path: '',
175 59
    component: Layout,
176
    children: [{
177
      path: '',
178
      component: () => import('@/views/frontviews/ViewFindResource'),
179
      name: 'findResource',
180
      meta: { title: '找资源' }
181
    }]
60
    children: [
61
      {
62
        name: 'findResource',
63
        path: '/findResource',
64
        redirect: { name: 'reso_list' },
65
        component: () => import('@/views/frontviews/ViewFindResource/index'),
66
        meta: { title: '找资源' },
67
        children: [
68
          {
69
            name: 'reso_list',
70
            path: '/reso_list',
71
            component: () => import('@/views/frontviews/ViewFindResource/list')
72
          },
73
          {
74
            path: '/reso_show',
75
            name: 'reso_show',
76
            component: () => import('@/views/infoshow/resourceShow'),
77
            meta: { title: '资源名称' }
78
          }
79
        ]
80
      }
81
    ]
182 82
  },
183 83
  {
184
    path: '/findResult',
84
    path: '',
185 85
    component: Layout,
186
    children: [{
187
      path: '',
188
      component: () => import('@/views/frontviews/ViewFindResult'),
189
      name: 'findResult',
190
      meta: { title: '找成果' }
191
    }]
86
    children: [
87
      {
88
        name: 'findResult',
89
        path: '/findResult',
90
        redirect: { name: 'resu_list' },
91
        component: () => import('@/views/frontviews/ViewFindResult/index'),
92
        meta: { title: '找成果' },
93
        children: [
94
          {
95
            name: 'resu_list',
96
            path: '/resu_list',
97
            component: () => import('@/views/frontviews/ViewFindResult/list')
98
          },
99
          {
100
            name: 'resu_result',
101
            path: 'resu_result',
102
            redirect: { name: 'resu_patent' },
103
            component: () => import('@/views/infoshow/resultShow/index'),
104
            meta: { title: '专利' },
105
            children: [
106
              {
107
                path: '/resu_patent',
108
                name: 'resu_patent',
109
                component: () => import('@/views/infoshow/resultShow/patent'),
110
                meta: { title: '专利名称' }
111
              }
112
            ]
113
          }
114
        ]
115
      }
116
    ]
192 117
  },
193 118
  {
194 119
    path: '',
195 120
    component: Layout,
196 121
    children: [
197 122
      {
198
        path: '',
123
        path: '/expertPool',
199 124
        name: 'expertPool',
200
        redirect: '/expertPool',
125
        redirect: { name: 'exp_list' },
201 126
        component: () => import('@/views/frontviews/ViewExpertPool/index'),
202 127
        meta: { title: '专家库' },
203 128
        children: [
204 129
          {
205
            path: 'expertPool',
206
            component: () => import('@/views/frontviews/ViewExpertPool/expert')
130
            path: '/exp_list',
131
            name: 'exp_list',
132
            component: () => import('@/views/frontviews/ViewExpertPool/list')
207 133
          },
208 134
          {
209
            path: 'expertShow',
210
            name: 'expertShow',
135
            path: '/exp_show',
136
            name: 'exp_show',
211 137
            component: () => import('@/views/infoshow/expertShow'),
212 138
            meta: { title: '专家姓名' }
213 139
          }
@ -216,30 +142,76 @@ const constantRouterMap = [
216 142
    ]
217 143
  },
218 144
  {
219
    path: '/cooperationAgency',
145
    path: '',
220 146
    component: Layout,
221
    children: [{
222
      path: '',
223
      component: () => import('@/views/frontviews/ViewCooperationAgency'),
224
      name: 'cooperationAgency',
225
      meta: { title: '服务机构' }
226
    }]
147
    children: [
148
      {
149
        path: '/CoAgency',
150
        name: 'CoAgency',
151
        redirect: { name: 'org_list' },
152
        component: () => import('@/views/frontviews/ViewOrganization/index'),
153
        meta: { title: '服务机构' },
154
        children: [
155
          {
156
            path: '/org_list',
157
            name: 'org_list',
158
            component: () => import('@/views/frontviews/ViewOrganization/list')
159
          },
160
          {
161
            path: '/org_show',
162
            name: 'org_show',
163
            component: () => import('@/views/infoshow/orgShow'),
164
            meta: { title: '机构名称' }
165
          }
166
        ]
167
      }
168
    ]
227 169
  },
228 170
  {
229
    path: '/regAgency',
171
    path: '',
230 172
    component: Layout,
231
    children: [{
232
      path: '',
233
      component: () => import('@/views/frontviews/ViewRegAgency'),
234
      name: 'regAgency',
235
      meta: { title: '入驻企业' }
236
    }]
173
    children: [
174
      {
175
        path: '/regCompany',
176
        name: 'regCompany',
177
        redirect: { name: 'comp_list' },
178
        component: () => import('@/views/frontviews/ViewRegCompany/index'),
179
        meta: { title: '入驻企业' },
180
        children: [
181
          {
182
            path: '/comp_list',
183
            name: 'comp_list',
184
            component: () => import('@/views/frontviews/ViewRegCompany/list')
185
          },
186
          {
187
            path: 'comp_home',
188
            name: 'comp_home',
189
            redirect: { name: 'comp_show' },
190
            component: () => import('@/views/infoshow/compShow/index'),
191
            meta: { title: '企业名称' },
192
            children: [
193
              {
194
                path: '/comp_show',
195
                name: 'comp_show',
196
                component: () => import('@/views/infoshow/compShow/comp')
197
              },
198
              {
199
                path: '/comp_product',
200
                name: 'comp_product',
201
                component: () => import('@/views/infoshow/compShow/product'),
202
                meta: { title: '产品名称' }
203
              }
204
            ]
205
          }
206
        ]
207
      }
208
    ]
237 209
  },
238 210
  {
239
    path: '/about',
211
    path: '',
240 212
    component: Layout,
241 213
    children: [{
242
      path: '',
214
      path: '/about',
243 215
      component: () => import('@/views/frontviews/ViewAboutUs'),
244 216
      name: 'about',
245 217
      meta: { title: '关于平台' }

+ 22 - 34
src/views/frontviews/Dashboard.vue

@ -344,13 +344,11 @@
344 344
      // },
345 345
      queryPaltNews(id) {
346 346
        this.$axios.get(httpUrl.hQuery.platNews.nopq, {
347
          params: {
348
            ownerId: id,
349
            articleType: '3',
350
            status: 1,
351
            rows: 4
352
          }
353
        }).then((res) => {
347
          ownerId: id,
348
          articleType: '3',
349
          status: 1,
350
          rows: 4
351
        }, (res) => {
354 352
          if (res.success) {
355 353
            var $info = res.data;
356 354
            this.paltNews = $info;
@ -359,11 +357,9 @@
359 357
      },
360 358
      queryOrgTrends(id) {
361 359
        this.$axios.get(httpUrl.hQuery.orgTrends.nopq, {
362
          params: {
363
            pid: id,
364
            rows: 4
365
          }
366
        }).then((res) => {
360
          pid: id,
361
          rows: 4
362
        }, (res) => {
367 363
          if (res.success) {
368 364
            var _this = this;
369 365
            var $info = res.data;
@ -378,11 +374,9 @@
378 374
      },
379 375
      queryResidentOrgs(id) {
380 376
        this.$axios.get(httpUrl.hQuery.residentOrgs.nopq, {
381
          params: {
382
            pid: id,
383
            rows: this.rows
384
          }
385
        }).then((res) => {
377
          pid: id,
378
          rows: this.rows
379
        }, (res) => {
386 380
          if (res.success) {
387 381
            var $info = res.data;
388 382
            this.residentOrgs = $info;
@ -391,11 +385,9 @@
391 385
      },
392 386
      queryPlatResources(id) {
393 387
        this.$axios.get(httpUrl.hQuery.queryResource, {
394
          params: {
395
            pid: id,
396
            rows: this.rows
397
          }
398
        }).then((res) => {
388
          pid: id,
389
          rows: this.rows
390
        }, (res) => {
399 391
          var _this = this;
400 392
          if (res.success) {
401 393
            var $info = res.data;
@ -410,11 +402,9 @@
410 402
      },
411 403
      queryPlatWares(id) {
412 404
        this.$axios.get(httpUrl.hQuery.queryWare, {
413
          params: {
414
            pid: id,
415
            rows: this.rows
416
          }
417
        }).then((res) => {
405
          pid: id,
406
          rows: this.rows
407
        }, (res) => {
418 408
          var _this = this;
419 409
          if (res.success) {
420 410
            var $info = res.data;
@ -453,10 +443,8 @@
453 443
      },
454 444
      getAboutUs(id) {
455 445
        this.$axios.get(httpUrl.hQuery.baseInfo.query, {
456
          params: {
457
            id: id
458
          }
459
        }).then((res) => {
446
          id: id
447
        }, (res) => {
460 448
          if (res.data) {
461 449
            if (res.data.descp) {
462 450
              this.aboutUs = res.data.descp;
@ -499,7 +487,7 @@
499 487
        };
500 488
        if (type === '1') {
501 489
          _this.$axios.get(httpUrl.kxQurey.professor.query + id, {
502
            }).then((res) => {
490
            }, (res) => {
503 491
            if (res.success) {
504 492
              let $info = res.data;
505 493
              item.ownerName = $info.name;
@ -508,7 +496,7 @@
508 496
          });
509 497
        } else if (type === '2') {
510 498
          _this.$axios.get(httpUrl.kxQurey.org.query + id, {
511
            }).then((res) => {
499
            }, (res) => {
512 500
            if (res.success) {
513 501
              let $info = res.data;
514 502
              item.ownerName = $info.forShort ? $info.forShort : $info.name;
@ -612,7 +600,7 @@
612 600
        width:280px
613 601
        height:470px
614 602
        .content
615
          text-ellipsis-n(12,28px)
603
          text-ellipsis-n(14,28px)
616 604
      .full-wrapper
617 605
        width:100%
618 606
        .swiper-container:hover

+ 2 - 4
src/views/frontviews/ViewAboutUs.vue

@ -25,10 +25,8 @@
25 25
    methods: {
26 26
      getAboutUs(id) {
27 27
        this.$axios.get(httpUrl.hQuery.baseInfo.query, {
28
          params: {
29
            id: id
30
          }
31
        }).then((res) => {
28
          id: id
29
        }, (res) => {
32 30
          this.aboutUs = util.getFormatCode(res.data.descp);
33 31
        });
34 32
      }

src/views/frontviews/ViewExpertPool/expert.vue → src/views/frontviews/ViewExpertPool/list.vue


+ 14 - 0
src/views/frontviews/ViewFindResource/index.vue

@ -0,0 +1,14 @@
1
<template>
2
  <div>
3
    <router-view :plat="plat"></router-view>
4
  </div>
5
</template>
6
<script>
7
  export default {
8
    props: {
9
      plat: {
10
        type: Object
11
      }
12
    }
13
  };
14
</script>

+ 6 - 8
src/views/frontviews/ViewFindResource.vue

@ -72,14 +72,12 @@
72 72
    methods: {
73 73
      searchResource() {
74 74
        this.$axios.get(httpUrl.hQuery.queryResource, {
75
          params: {
76
            key: this.keyVal,
77
            pid: this.platId,
78
            shareId: this.dataO.bShareId,
79
            time: this.dataO.bTime,
80
            rows: this.rows
81
          }
82
        }).then((res) => {
75
          key: this.keyVal,
76
          pid: this.platId,
77
          shareId: this.dataO.bShareId,
78
          time: this.dataO.bTime,
79
          rows: this.rows
80
        }, (res) => {
83 81
          if (res.success) {
84 82
            var $info = res.data;
85 83
            if ($info.length > 0) {

+ 14 - 0
src/views/frontviews/ViewFindResult/index.vue

@ -0,0 +1,14 @@
1
<template>
2
  <div>
3
    <router-view :plat="plat"></router-view>
4
  </div>
5
</template>
6
<script>
7
  export default {
8
    props: {
9
      plat: {
10
        type: Object
11
      }
12
    }
13
  };
14
</script>

+ 7 - 9
src/views/frontviews/ViewFindResult.vue

@ -39,7 +39,7 @@
39 39
  import httpUrl from '@/libs/http';
40 40
  import util from '@/libs/util';
41 41
42
  import baseResource from '@/views/sub-component/BaseResource';
42
  import baseResource from '@/views/sub-component/BaseResult';
43 43
44 44
  export default {
45 45
    props: {
@ -72,14 +72,12 @@
72 72
    methods: {
73 73
      searchResource() {
74 74
        this.$axios.get(httpUrl.hQuery.queryResource, {
75
          params: {
76
            key: this.keyVal,
77
            pid: this.platId,
78
            shareId: this.dataO.bShareId,
79
            time: this.dataO.bTime,
80
            rows: this.rows
81
          }
82
        }).then((res) => {
75
          key: this.keyVal,
76
          pid: this.platId,
77
          shareId: this.dataO.bShareId,
78
          time: this.dataO.bTime,
79
          rows: this.rows
80
        }, (res) => {
83 81
          if (res.success) {
84 82
            var $info = res.data;
85 83
            if ($info.length > 0) {

+ 14 - 0
src/views/frontviews/ViewFindServe/index.vue

@ -0,0 +1,14 @@
1
<template>
2
  <div>
3
    <router-view :plat="plat"></router-view>
4
  </div>
5
</template>
6
<script>
7
  export default {
8
    props: {
9
      plat: {
10
        type: Object
11
      }
12
    }
13
  };
14
</script>

+ 29 - 31
src/views/frontviews/ViewFindServe.vue

@ -1,36 +1,36 @@
1 1
<template>
2 2
  <div class="main-content">
3
		<div class="wrapper-left">
4
			<div class="block-wrapper search-wrapper">
5
				<el-input v-model="keyVal" @keyup.enter.native="keywordSearch" placeholder="请输入服务内容、发布者或相关关键词" class="input-with-select">
6
					<el-button slot="append" icon="el-icon-search" @click="keywordSearch">搜索</el-button>
7
				</el-input>
8
			</div>
9
			<div class="block-wrapper">
10
				<!-- <div class="content-wrapper tab-wrapper">
11
					<div class="tab-lable">服务类型:</div>
12
					<ul class="tab-sort">
13
						<li>不限</li>
14
						<li>检测服务</li>
15
					</ul>
16
				</div> -->
17
				<div class="tab-contain">
3
    <div class="wrapper-left">
4
      <div class="block-wrapper search-wrapper">
5
        <el-input v-model="keyVal" @keyup.enter.native="keywordSearch" placeholder="请输入服务内容、发布者或相关关键词" class="input-with-select">
6
          <el-button slot="append" icon="el-icon-search" @click="keywordSearch">搜索</el-button>
7
        </el-input>
8
      </div>
9
      <div class="block-wrapper">
10
        <!-- <div class="content-wrapper tab-wrapper">
11
          <div class="tab-lable">服务类型:</div>
12
          <ul class="tab-sort">
13
            <li>不限</li>
14
            <li>检测服务</li>
15
          </ul>
16
        </div> -->
17
        <div class="tab-contain">
18 18
          <div v-show="!ifDefault">
19 19
            <baseService v-if="platServices.length" v-for="item in platServices" :key="item.index" :itemSingle="item"></baseService>
20 20
            <Loading v-show="loadingModalShow" :loadingComplete="loadingComplete" :isLoading="isLoading" v-on:upup="searchLower"></Loading>
21 21
          </div>
22 22
          <defaultPage v-show="ifDefault"></defaultPage>
23
				</div>
24
			</div>
25
		</div>
26
		<div class="wrapper-right">
27
			<div class="block-wrapper" v-if="plat.adinfo.length" v-for="item in plat.adinfo" :key="item.index">
28
				<a class="ad-wrapper" :href="item.adUrl" target="_blank">
29
					<img :src="item.imgUrl" width="280" height="200">
30
				</a>
31
			</div>
32
		</div>
33
		<BackTop></BackTop>
23
        </div>
24
      </div>
25
    </div>
26
    <div class="wrapper-right">
27
      <div class="block-wrapper" v-if="plat.adinfo.length" v-for="item in plat.adinfo" :key="item.index">
28
        <a class="ad-wrapper" :href="item.adUrl" target="_blank">
29
          <img :src="item.imgUrl" width="280" height="200">
30
        </a>
31
      </div>
32
    </div>
33
    <BackTop></BackTop>
34 34
  </div>
35 35
</template>
36 36
@ -41,8 +41,8 @@
41 41
42 42
  import baseService from '@/views/sub-component/BaseService';
43 43
44
	export default {
45
		props: {
44
  export default {
45
    props: {
46 46
      plat: {
47 47
        type: Object
48 48
      }
@ -72,14 +72,12 @@
72 72
    methods: {
73 73
      searchService() {
74 74
        this.$axios.get(httpUrl.hQuery.queryWare, {
75
          params: {
76 75
            key: this.keyVal,
77 76
            pid: this.platId,
78 77
            shareId: this.dataO.bShareId,
79 78
            time: this.dataO.bTime,
80 79
            rows: this.rows
81
          }
82
        }).then((res) => {
80
        }, (res) => {
83 81
          if (res.success) {
84 82
            var $info = res.data;
85 83
            if ($info.length > 0) {

+ 5 - 0
src/views/frontviews/ViewOrganization/index.vue

@ -0,0 +1,5 @@
1
<template>
2
  <div>
3
    <router-view></router-view>
4
  </div>
5
</template>

src/views/frontviews/ViewCooperationAgency.vue → src/views/frontviews/ViewOrganization/list.vue


+ 5 - 0
src/views/frontviews/ViewRegCompany/index.vue

@ -0,0 +1,5 @@
1
<template>
2
  <div>
3
    <router-view></router-view>
4
  </div>
5
</template>

+ 4 - 3
src/views/frontviews/ViewRegAgency.vue

@ -1,18 +1,19 @@
1 1
<template>
2 2
	<div class="cooperation">
3 3
		<div class="content-wrapper block-wrapper">
4
			<baseAgency></baseAgency>
4
			<div class="content-title content-title-center">平台合作机构</div>
5
			<baseCompany></baseCompany>
5 6
		</div>
6 7
		<BackTop></BackTop>
7 8
	</div>
8 9
</template>
9 10
10 11
<script>
11
	import baseAgency from '@/views/sub-component/BaseAgency';
12
	import baseCompany from '@/views/sub-component/BaseCompany';
12 13
13 14
	export default {
14 15
    components: {
15
      baseAgency
16
      baseCompany
16 17
    }
17 18
  };
18 19
</script>

+ 7 - 1
src/views/frontviews/platTrend/ViewPlatTrend.vue

@ -10,9 +10,15 @@
10 10
						<el-tab-pane label="平台新闻" name="first">
11 11
							<platNews></platNews>
12 12
						</el-tab-pane>
13
						<el-tab-pane label="企业动态" name="second">
13
						<el-tab-pane label="采访专栏" name="second">
14 14
							<platTrends></platTrends>
15 15
						</el-tab-pane>
16
            <el-tab-pane label="政策法规" name="third">
17
              <platTrends></platTrends>
18
            </el-tab-pane>
19
            <el-tab-pane label="通知公告" name="fourth">
20
              <platTrends></platTrends>
21
            </el-tab-pane>
16 22
					</el-tabs>
17 23
				</div>
18 24
			</div>

+ 7 - 9
src/views/frontviews/platTrend/ViewPlatTrendNews.vue

@ -34,15 +34,13 @@
34 34
    methods: {
35 35
      queryPaltNews() {
36 36
        this.$axios.get(httpUrl.hQuery.platNews.nopq, {
37
          params: {
38
            ownerId: this.platId,
39
            articleType: '3',
40
            status: 1,
41
            rows: this.rows,
42
            publishTime: this.dataO.bTime,
43
            articleId: this.dataO.bId
44
          }
45
        }).then((res) => {
37
          ownerId: this.platId,
38
          articleType: '3',
39
          status: 1,
40
          rows: this.rows,
41
          publishTime: this.dataO.bTime,
42
          articleId: this.dataO.bId
43
        }, (res) => {
46 44
          console.log(res);
47 45
          if (res.success) {
48 46
            var $info = res.data;

+ 5 - 7
src/views/frontviews/platTrend/ViewPlatTrendTrends.vue

@ -34,13 +34,11 @@
34 34
    methods: {
35 35
      queryOrgTrends(id) {
36 36
        this.$axios.get(httpUrl.hQuery.orgTrends.nopq, {
37
           params: {
38
            pid: this.platId,
39
            rows: this.rows,
40
            publishTime: this.dataO.bTime,
41
            shareId: this.dataO.bShareId
42
          }
43
        }).then((res) => {
37
          pid: this.platId,
38
          rows: this.rows,
39
          publishTime: this.dataO.bTime,
40
          shareId: this.dataO.bShareId
41
        }, (res) => {
44 42
          console.log(res);
45 43
          if (res.success) {
46 44
            var $info = res.data;

+ 201 - 0
src/views/infoshow/compShow/comp.vue

@ -0,0 +1,201 @@
1
<template>
2
  <div class="browse-main">
3
    <div class="block-wrapper">
4
      <div class="content-wrapper">
5
        <div class="headcon-box org-head">
6
          <div class="show-head headimg-box">
7
            <img :src="orgLogoUrl(orgInfo)">
8
          </div>
9
          <div class="show-info reInfo-box">
10
            <div class="info-tit">{{orgInfo.forShort ? orgInfo.forShort : orgInfo.name}}<em class="authicon" :class="{'icon-com': orgInfo.authStatus==='3'}"></em></div>
11
            <div class="info-tag"><span v-if="orgInfo.title" style="margin-right:10px">{{orgInfo.orgType}}</span> {{orgInfo.industry ? orgInfo.industry.replace(/,/gi, " | ") : ''}}</div>
12
            <div class="info-operate">
13
              <div class="addr">{{orgInfo.city}}</div>
14
              <shareOut :tUrl="elurl"></shareOut>
15
            </div>
16
          </div>
17
        </div>
18
      </div>
19
    </div>
20
    <div class="block-wrapper">
21
      <div class="wrapper-left left-main">
22
        <el-tabs v-model="activeName">
23
          <el-tab-pane label="主页" name="first">
24
            <div class="content-wrapper split-other" v-if="platServices.length">
25
              <div class="inner-wrapper">
26
                <div class="content-title">
27
                  <span>我们的产品</span>
28
                  <span class="content-more" @click="activeName='second'">更多</span>
29
                </div>
30
                <div class="content">
31
                  <!-- <baseService v-if="platServices.length" v-for="item in platServices" :key="item.index" :itemSingle="item"></baseService> -->
32
                </div>
33
              </div>
34
            </div>
35
            <div class="content-wrapper" v-if="orgInfo.descp">
36
              <div class="inner-wrapper">
37
                <div class="content-title">
38
                  <span>企业简介</span>
39
                </div>
40
                <div class="content">{{orgInfo.descp}}</div>
41
              </div>
42
              <div class="inner-wrapper" v-if="orgInfo.subject && orgInfo.subject.length">
43
                <div class="content-title">
44
                  <span>专注领域</span>
45
                </div>
46
                <div class="content">
47
                  <el-row class="tag-item">
48
                    <el-tag v-for="sub in orgInfo.subject" :key="sub.index">{{sub}}</el-tag>
49
                  </el-row>
50
                </div>
51
              </div>
52
            </div>
53
          </el-tab-pane>
54
          <el-tab-pane label="产品" name="second">
55
            <!-- <baseService v-if="platServices.length" v-for="item in platServices" :key="item.index" :itemSingle="item"></baseService> -->
56
          </el-tab-pane>
57
          <el-tab-pane label="资料" name="third">
58
            <div class="content-wrapper">
59
              <div class="inner-wrapper">
60
                <div class="content-title">
61
                  <span>企业详情</span>
62
                </div>
63
                <div class="content">
64
                  <el-row :gutter="10">
65
                    <el-col :span="12" v-if="orgInfo.name">
66
                      <el-col :span="6">企业名称:</el-col>
67
                      <el-col :span="18">{{orgInfo.name}}</el-col>
68
                    </el-col>
69
                    <el-col :span="12" v-if="orgInfo.orgSize">
70
                      <el-col :span="6">企业规模:</el-col>
71
                      <el-col :span="18">{{orgInfo.orgSize}}</el-col>
72
                    </el-col>
73
                    <el-col :span="12" v-if="orgInfo.orgType">
74
                      <el-col :span="6">企业类型:</el-col>
75
                      <el-col :span="18">{{orgInfo.orgType}}</el-col>
76
                    </el-col>
77
                    <el-col :span="12" v-if="orgInfo.addr">
78
                      <el-col :span="6">企业地址:</el-col>
79
                      <el-col :span="18">{{orgInfo.addr}}</el-col>
80
                    </el-col>
81
                    <el-col :span="12" v-if="orgInfo.foundTime">
82
                      <el-col :span="6">创立时间:</el-col>
83
                      <el-col :span="18">{{orgInfo.foundTime}}</el-col>
84
                    </el-col>
85
                    <el-col :span="12" v-if="orgInfo.orgUrl">
86
                      <el-col :span="6">企业官网:</el-col>
87
                      <el-col :span="18">{{orgInfo.orgUrl}}</el-col>
88
                    </el-col>
89
                  </el-row>
90
                </div>
91
              </div>
92
              <div class="inner-wrapper" v-if="orgInfo.qualification && orgInfo.qualification.length">
93
                <div class="content-title">
94
                  <span>企业资质</span>
95
                </div>
96
                <div class="content">
97
                   <div class="ulM">
98
                    <div class="liM" v-for="item in orgInfo.qualification" :key="item.index">
99
                      <div class="liM-tit">{{item}}</div>
100
                    </div>
101
                  </div>
102
                </div>
103
              </div>
104
            </div>
105
          </el-tab-pane>
106
        </el-tabs>
107
      </div>
108
      <div class="wrapper-right">
109
        <div class="content-wrapper">
110
          <div class="content-title">
111
            <span>相关文章</span>
112
          </div>
113
          <div class="content">
114
            <!-- <baseService v-if="platServices.length" v-for="item in platServices" :key="item.index" :itemSingle="item"></baseService> -->
115
          </div>
116
        </div>
117
        <div class="content-wrapper">
118
          <div class="content-title">
119
            <span>您可能感兴趣的企业</span>
120
          </div>
121
          <div class="content">
122
            <!-- <baseService v-if="platServices.length" v-for="item in platServices" :key="item.index" :itemSingle="item"></baseService> -->
123
          </div>
124
        </div>
125
      </div>
126
    </div>
127
    <BackTop></BackTop>
128
  </div>
129
</template>
130
131
<script>
132
  import '@/common/stylus/listitem.styl';
133
  import '@/common/stylus/browse.styl';
134
  import util from '@/libs/util';
135
  import httpUrl from '@/libs/http';
136
137
  import shareOut from '../components/ShareOut';
138
  import baseService from '@/views/sub-component/BaseService';
139
140
  export default {
141
    data() {
142
      return {
143
        activeIndex: '1',
144
        activeName: 'first',
145
        orgInfo: '',
146
        orgRegInfo: '',
147
        elurl: '',
148
        platServices: [],
149
        platResources: []
150
      };
151
    },
152
    created() {
153
      this.orgId = util.urlParse('id');
154
      this.elurl = window.location.href;
155
      this.getorgInfo();
156
    },
157
    components: {
158
      shareOut,
159
      baseService
160
    },
161
    methods: {
162
      getorgInfo() {
163
        this.$axios.get(httpUrl.kxQurey.org.query + this.orgId, {
164
        }, (res) => {
165
          if (res.success) {
166
            var $info = res.data;
167
            if ($info.subject) {
168
              $info.subject = util.strToArr($info.subject);
169
            }
170
            if ($info.qualification) {
171
              $info.qualification = util.strToArr($info.qualification);
172
            }
173
            if ($info.foundTime) {
174
              $info.foundTime = util.TimeTr($info.foundTime);
175
            }
176
            if ($info.orgSize) {
177
              $info.orgSize = util.orgSizeShow[$info.orgSize];
178
            }
179
            if ($info.orgType) {
180
              $info.orgType = util.orgTypeShow[$info.orgType];
181
            }
182
            this.orgInfo = $info;
183
          };
184
        });
185
      },
186
      getorgRegInfo(oName) {
187
        this.$axios.get(httpUrl.kxQurey.org.reg, {
188
          name: oName
189
        }, (res) => {
190
          if (res.success) {
191
            var $info = res.data;
192
            this.orgRegInfo = $info;
193
          };
194
        });
195
      },
196
      orgLogoUrl(item) {
197
        return item.hasOrgLogo ? util.ImageUrl(('org/' + item.id + '.jpg'), true) : util.defaultSet.img.org;
198
      }
199
    }
200
  };
201
</script>

+ 9 - 0
src/views/infoshow/compShow/index.vue

@ -0,0 +1,9 @@
1
<template>
2
  <div>
3
    <router-view></router-view>
4
  </div>
5
</template>
6
<script>
7
  export default {
8
  };
9
</script>

+ 141 - 0
src/views/infoshow/compShow/product.vue

@ -0,0 +1,141 @@
1
<template>
2
  <div class="browse-main">
3
    <div class="block-wrapper">
4
      <div class="wrapper-left left-main">
5
        <div class="content-wrapper split-other">
6
          <div class="headcon-box hdetail-box">
7
            <div class="zoom-box">
8
              <previewMagnify v-if="srcImg.length" :previewImg="srcImg"></previewMagnify>
9
            </div>
10
            <div class="show-info reInfo-box">
11
              <div class="info-tit">{{resourceInfo.resourceName}}</div>
12
              <div class="info-tag">应用用途:{{resourceInfo.supportedServices}}</div>
13
              <div class="info-operate zoom-operate">
14
                <div class="addr">浏览量 10</div>
15
                <collectCo></collectCo>
16
                <shareOut :tUrl="elurl" :tPosition="tPosition"></shareOut>
17
              </div>
18
            </div>
19
          </div>
20
        </div>
21
        <div class="content-wrapper">
22
          <div class="content">
23
            <el-row :gutter="10" class="rel-detail">
24
              <el-col class="rel-item" :span="24" v-if="resourceInfo.orgName">
25
                <div class="rel-tit">所属机构:</div>
26
                <div>{{resourceInfo.orgName}}</div>
27
              </el-col>
28
              <el-col class="rel-item" :span="24" v-if="resourceInfo.spec">
29
                <div class="rel-tit">厂商型号:</div>
30
                <div>{{resourceInfo.spec}}</div>
31
              </el-col>
32
              <el-col class="rel-item" :span="24" v-if="resourceInfo.parameter">
33
                <div class="rel-tit">性能参数:</div>
34
                <div v-html="resourceInfo.parameter"></div>
35
              </el-col>
36
              <el-col class="rel-item" :span="24" v-if="resourceInfo.cooperationNotes">
37
                <div class="rel-tit">合作备注:</div>
38
                <div v-html="resourceInfo.cooperationNotes"></div>
39
              </el-col>
40
              <el-col class="rel-item" :span="24" v-if="resourceInfo.descp">
41
                <div class="rel-tit">详细介绍:</div>
42
                <div v-html="resourceInfo.descp"></div>
43
              </el-col>
44
              <el-col class="rel-item" :span="24" v-if="resourceInfo.subject && resourceInfo.subject.length">
45
                <el-row class="tag-item">
46
                  <el-tag v-for="sub in resourceInfo.subject" :key="sub.index">{{sub}}</el-tag>
47
                </el-row>
48
              </el-col>
49
            </el-row>
50
          </div>
51
        </div>
52
        <div class="content-wrapper">
53
          <div class="content-title">
54
            <span>您可能感兴趣的资源</span>
55
          </div>
56
          <div class="content">
57
            <!-- <baseService v-if="platServices.length" v-for="item in platServices" :key="item.index" :itemSingle="item"></baseService> -->
58
          </div>
59
        </div>
60
      </div>
61
      <div class="wrapper-right">
62
        <div class="content-wrapper">
63
          <div class="right-split">
64
            <beyondTo :ownerId="owner.id" :ownerType="owner.type"></beyondTo>
65
          </div>
66
          <div class="right-split">
67
            <div class="content-title">
68
              <span>热门资源</span>
69
            </div>
70
            <div class="content">
71
              <!-- <baseService v-if="platServices.length" v-for="item in platServices" :key="item.index" :itemSingle="item"></baseService> -->
72
            </div>
73
          </div>
74
        </div>
75
      </div>
76
    </div>
77
    <BackTop></BackTop>
78
  </div>
79
</template>
80
81
<script>
82
  import '@/common/stylus/listitem.styl';
83
  import '@/common/stylus/browse.styl';
84
  import util from '@/libs/util';
85
  import httpUrl from '@/libs/http';
86
87
  import previewMagnify from '../components/previewMagnify';
88
  import shareOut from '../components/ShareOut';
89
  import collectCo from '../components/CollectCo';
90
  import beyondTo from '../components/BeyondTo';
91
92
  export default {
93
    data() {
94
      return {
95
        resourceInfo: '',
96
        elurl: '',
97
        tPosition: 'top-start',
98
        platServices: [],
99
        srcImg: [],
100
        owner: {
101
          id: '',
102
          type: ''
103
        }
104
      };
105
    },
106
    created() {
107
      this.resourceId = util.urlParse('id');
108
      this.elurl = window.location.href;
109
      this.getResourceInfo();
110
    },
111
    components: {
112
      // PicZoom,
113
      previewMagnify,
114
      shareOut,
115
      collectCo,
116
      beyondTo
117
    },
118
    methods: {
119
      getResourceInfo() {
120
        this.$axios.get(httpUrl.kxQurey.resource.query, {
121
          resourceId: this.resourceId
122
        }, (res) => {
123
          if (res.success) {
124
            var $info = res.data;
125
            if ($info.subject) {
126
              $info.subject = util.strToArr($info.subject);
127
            }
128
            if ($info.images.length) {
129
              this.srcImg = $info.images;
130
            }
131
            this.owner = {
132
              id: $info.professorId,
133
              type: $info.resourceType
134
            };
135
            this.resourceInfo = $info;
136
          };
137
        });
138
      }
139
    }
140
  };
141
</script>

+ 107 - 0
src/views/infoshow/components/BeyondTo/index.vue

@ -0,0 +1,107 @@
1
<template>
2
  <div class="beyond-block">
3
    <div class="expert-block">
4
      <div class="show-head"></div>
5
      <div class="show-info">
6
        <div class="info-tit">ownerInfo.name<em class="authicon icon-pro"></em></div>
7
        <div class="info-tag">ownerInfo.title</div>
8
        <div class="info-desc">ownerInfo.offt</div>
9
      </div>
10
    </div>
11
    <div class="expert-block">
12
      <div class="show-head orgimg-box">
13
        <img :src="orgLogoUrl(ownerInfo)">
14
      </div>
15
      <div class="show-info">
16
        <div class="info-tit">ownerInfo.name<em class="authicon icon-com"></em></div>
17
        <div class="info-desc">ownerInfo.title</div>
18
      </div>
19
    </div>
20
    <!-- <div class="expert-block" v-if="ownerType===1">
21
      <div class="show-head headimg-box" :style="{backgroundImage:'url('+ headUrl(ownerInfo) +')'}"></div>
22
      <div class="show-info reInfo-box">
23
        <div class="info-tit">{{ownerInfo.name}}<em class="authicon" :class="headIcon(ownerInfo)"></em></div>
24
        <div class="info-tag"><span v-if="ownerInfo.title" style="margin-right:10px">{{ownerInfo.title}}</span> {{ownerInfo.offt}}</div>
25
      </div>
26
    </div>
27
    <div class="org-block" v-if="ownerType===2">
28
      <div class="show-head headimg-box">
29
        <img :src="orgLogoUrl(ownerInfo)">
30
      </div>
31
      <div class="show-info reInfo-box">
32
        <div class="info-tit">{{ownerInfo.forShort ? ownerInfo.forShort : ownerInfo.name}}<em class="authicon" :class="{'icon-com': ownerInfo.authStatus==='3'}"></em></div>
33
        <div class="info-tag"><span v-if="ownerInfo.title" style="margin-right:10px">{{ownerInfo.orgType}}</span> {{ownerInfo.industry ? ownerInfo.industry.replace(/,/gi, " | ") : ''}}</div>
34
      </div>
35
    </div> -->
36
    <el-row class="goSpan">
37
      <el-button type="primary" icon="el-icon-plus">关注</el-button>
38
      <el-button type="primary">联系</el-button>
39
    </el-row>
40
  </div>
41
</template>
42
<script>
43
  import util from '@/libs/util';
44
  // import httpUrl from '@/libs/http';
45
  export default {
46
    props: {
47
      ownerId: {
48
        type: String
49
      },
50
      ownerType: {
51
        type: String
52
      }
53
    },
54
    data() {
55
      return {
56
        ownerInfo: ''
57
      };
58
    },
59
    mounted() {
60
    },
61
    methods: {
62
      orgLogoUrl(item) {
63
        return item.hasOrgLogo ? util.ImageUrl(('org/' + item.id + '.jpg'), true) : util.defaultSet.img.org;
64
      },
65
      headUrl(item) {
66
        return item.hasHeadImage ? util.ImageUrl(('head/' + item.id + '_l.jpg'), true) : util.defaultSet.img.expert;
67
      },
68
      headIcon(item) {
69
        return util.autho(item.authType, item.orgAuth, item.authStatus);
70
      }
71
    }
72
  };
73
</script>
74
<style lang="stylus" rel="stylesheet/stylus" scoded>
75
.beyond-block
76
  text-align:center
77
  .show-head
78
    display: block
79
    width: 120px
80
    height: 120px
81
    border: 1px solid #E5E5E5
82
    margin: 0 auto 10px
83
    background-position: center
84
    background-size: cover
85
    border-radius: 50%
86
    &.orgimg-box
87
      center-items(200px, 120px)
88
  .show-info
89
    width:100%
90
    .info-tit
91
      color:$commonFont
92
      text-ellipsis()
93
      font-size: 18px
94
      line-height: 24px
95
    .info-tag
96
      color:$commonFont
97
      text-ellipsis()
98
      font-size: 16px
99
      line-height: 24px
100
    .info-desc
101
      color:$secondaryFont
102
      text-ellipsis()
103
      font-size: 15px
104
      line-height: 24px
105
  .goSpan
106
    margin-top:15px
107
</style>

BIN
src/views/infoshow/components/CollectCo/img/icon_shoucang_hig.png


BIN
src/views/infoshow/components/CollectCo/img/icon_shoucang_nor.png


+ 38 - 0
src/views/infoshow/components/CollectCo/index.vue

@ -0,0 +1,38 @@
1
<template>
2
  <div class="collect-block">
3
    <span>收藏</span>
4
    <em style="cursor: pointer;" class="icon-font" :class="ifCollect ? 'icon-yishoucang' : 'icon-shoucang'" @click="collectFun"></em>
5
  </div>
6
</template>
7
<script>
8
  export default {
9
    props: {
10
      ifCollect: {
11
        type: Boolean
12
      }
13
    },
14
    mounted() {
15
    },
16
    methods: {
17
      collectFun() {
18
        this.ifCollect = !this.ifCollect;
19
      }
20
    }
21
  };
22
</script>
23
<style lang="stylus" rel="stylesheet/stylus" scoded>
24
.collect-block
25
  margin-right:15px
26
  font-size: 15px
27
  line-height: 15px
28
  .icon-font
29
    display: inline-block
30
    width:16px
31
    height:16px
32
    margin-left:6px
33
    background-size: cover
34
    &.icon-shoucang
35
      bg-image('/static/comimg/g_all_icon_shoucang_nor.png')
36
    &.icon-yishoucang
37
      bg-image('/static/comimg/g_all_icon_shoucang_hig.png')
38
</style>

BIN
src/views/infoshow/components/PreviewMagnify/img/mask.png


+ 208 - 0
src/views/infoshow/components/PreviewMagnify/index.vue

@ -0,0 +1,208 @@
1
<template>
2
  <div class="magnify">
3
    <div class="product-box">
4
      <div class="preview-box" @mousemove="move($event)" @mouseout="out" ref="previewBox">
5
        <div class="img-cover" ref="previewImgCover">
6
          <img :src="previewImg[selectIndex]" alt="" ref="previewImg">
7
        </div>
8
        <div class="hover-box" ref="hoverBox"></div>
9
      </div>
10
      <ul class="tb-thumb" id="thumblist">
11
        <li :class="{'tb-selected': index==selectIndex}" @click="selectFun(index)" v-for="(item,index) in previewImg" :key="item.index">
12
          <div class="tb-pic">
13
            <a href="javascript:void(0);">
14
              <img :src="item">
15
            </a>
16
          </div>
17
        </li>
18
      </ul>
19
    </div>
20
    <div class="zoom-box" v-show="zoomVisiable" ref="zoomBox">
21
      <img :src="previewImg[selectIndex]" alt="" ref="bigImg">
22
    </div>
23
  </div>
24
</template>
25
26
<script>
27
function offset(el) {
28
  let top = el.offsetTop;
29
  let left = el.offsetLeft;
30
  while (el.offsetParent) {
31
    el = el.offsetParent;
32
    top += el.offsetTop;
33
    left += el.offsetLeft;
34
  }
35
  return {
36
    left: left,
37
    top: top
38
  };
39
}
40
export default {
41
  name: 'magnify',
42
  props: {
43
    // previewImg: {
44
    //   type: Array
45
    // }
46
  },
47
  data() {
48
    return {
49
      zoomVisiable: false,
50
      hoverVisiable: false,
51
      selected: true,
52
      selectIndex: 0,
53
      previewImg: [
54
        '/data/resource/201710/C1F33120B2404644A7DD99B3DE9BFC21.jpg',
55
        '/data/resource/201710/179DCD28E4C146E99869FB1AB943DE1F.jpg',
56
        '/data/resource/201803/2CF4E47B24454D4BBEEEF126B2108D97.jpg',
57
        '/data/resource/201706/6989DDEA8E614EF6B550958F0C8A785E.jpg'
58
      ]
59
    };
60
  },
61
  methods: {
62
    out() {
63
      this.zoomVisiable = false;
64
    },
65
    move(ev) {
66
      this.init();
67
      // 鼠标距离屏幕距离
68
      let moveX = ev.clientX;
69
      let moveY = ev.clientY;
70
      // 大盒子距离顶部的距离
71
      let offsetLeft = offset(this.oPreviewBox).left;
72
      let offsetTop = offset(this.oPreviewBox).top;
73
74
      // hover遮罩层的宽高
75
      this.oHoverBox.style.width = this.bWidth / this.bimgWidth * this.kWidth + 'px';
76
      this.oHoverBox.style.height = this.bHeight / this.bimgHeight * this.kHeight + 'px';
77
78
      // 设置鼠标处于hover遮罩层正中心的位置
79
      let left = moveX - offsetLeft - this.houverWidth / 2;
80
      let top = (this.scroll > 0) ? (moveY - offsetTop + this.scroll - this.houverHeight / 2) : (moveY - offsetTop - this.houverHeight / 2);
81
82
      // 计算图片与最外框的空余位置
83
      let spareW = this.pWidth - this.kWidth;
84
      let spareH = this.pHeight - this.kHeight;
85
      // 计算hover遮罩层可以移动的最大、最小位置
86
      let maxWidth = this.kWidth - this.houverWidth + spareW / 2;
87
      let maxHeight = this.kHeight - this.houverHeight + spareH / 2;
88
      let minWidth = spareW / 2;
89
      let minHeight = spareH / 2;
90
91
      // hover遮罩层的移动范围
92
      left = left < minWidth ? minWidth : (left > maxWidth ? maxWidth : left);
93
      top = top < minHeight ? minHeight : (top > maxHeight ? maxHeight : top);
94
      // 设置hover遮罩层的移动时的当前位置
95
      this.oHoverBox.style.left = left + 'px';
96
      this.oHoverBox.style.top = top + 'px';
97
98
      // 计算放大比例scale
99
      let percentX = (left - spareW / 2) / (maxWidth - spareW / 2);
100
      let percentY = (top - spareH / 2) / (maxHeight - spareH / 2);
101
      // 设置对应的右边放大图片对应的位置
102
      this.oBigImg.style.left = percentX * (this.bWidth - this.bimgWidth) + 'px';
103
      this.oBigImg.style.top = percentY * (this.bHeight - this.bimgHeight) + 'px';
104
105
      this.$emit('move', ev);
106
      this.zoomVisiable = true;
107
    },
108
    init() {
109
      this.oHoverBox = this.$refs.hoverBox;
110
      this.oPreviewBox = this.$refs.previewBox;
111
      this.oPreviewImgCover = this.$refs.previewImgCover;
112
      this.oBigImg = this.$refs.bigImg;
113
      this.zoomBox = this.$refs.zoomBox;
114
      this.houverWidth = this.oHoverBox.offsetWidth;
115
      this.houverHeight = this.oHoverBox.offsetHeight;
116
      this.pWidth = this.oPreviewBox.offsetWidth;
117
      this.pHeight = this.oPreviewBox.offsetHeight;
118
      this.kWidth = this.oPreviewImgCover.offsetWidth;
119
      this.kHeight = this.oPreviewImgCover.offsetHeight;
120
      this.bimgWidth = this.oBigImg.offsetWidth;
121
      this.bimgHeight = this.oBigImg.offsetHeight;
122
      this.bWidth = this.zoomBox.offsetWidth;
123
      this.bHeight = this.zoomBox.offsetHeight;
124
      this.scroll = document.documentElement.scrollTop || document.body.scrollTop;
125
    },
126
    selectFun(index) {
127
      this.selectIndex = index;
128
    }
129
  }
130
};
131
</script>
132
133
<style rel="stylesheet/stylus" lang="stylus" scoped>
134
  .magnify
135
    position: relative
136
    .product-box
137
      position: relative
138
      .preview-box
139
        width: 360px
140
        height: 270px
141
        border: 1px solid #dededd
142
        position: relative
143
        display:flex
144
        justify-content: center
145
        align-items:center
146
        overflow:hidden
147
        .hover-box
148
          position: absolute
149
          display: none
150
          left: 0
151
          top: 0
152
          bottom:0
153
          width: 60px
154
          height: 60px
155
          background: url('./img/mask.png') repeat 0 0
156
          cursor: move
157
          user-select: none
158
        &:hover
159
          .hover-box
160
            display: block
161
        img
162
          max-width: 360px
163
          max-height: 270px
164
      .tb-thumb
165
        margin:10px 0 0
166
        overflow:hidden
167
        li
168
          background:none repeat scroll 0 0 transparent
169
          float:left
170
          margin:0 6px 0 0
171
          overflow:hidden
172
          .tb-pic
173
            border: 1px solid #E5E5E5
174
            a
175
              display:block
176
              height: 48px
177
              width: 66px
178
              display:flex
179
              justify-content: center
180
              align-items:center
181
            img
182
              max-height: 48px
183
              max-width: 66px
184
          &.tb-selected
185
            border: 3px solid $mainColor
186
            .tb-pic
187
              background-color: #FFFFFF
188
              border: medium none
189
              a
190
                height: 44px
191
                width: 58px
192
              img
193
                max-height: 44px
194
                max-width: 58px
195
    .zoom-box
196
      width: 300px
197
      height: 300px
198
      overflow: hidden
199
      position: absolute
200
      left: 370px
201
      border: 1px solid #dededd
202
      top: 0
203
      z-index: 700
204
      img
205
        position: absolute
206
        top: 0
207
        left: 0
208
</style>

+ 65 - 64
src/views/infoshow/components/ShareOut/index.vue

@ -1,81 +1,82 @@
1 1
<template>
2 2
  <div class="share-block">
3 3
    <span>分享到</span>
4
    <em class="operateicon icon-wechat shareWeixin">
4
    <el-popover
5
      :placement="tPosition"
6
      width="320"
7
      trigger="hover"
8
      popper-class="popper-class">
5 9
      <div class="shareCode">
6
        <div class="floatL" id="qrcode" ref="qrcode"></div>
7
        <div class="shareWord floatR">
8
          <p>打开微信“扫一扫”,<br/>打开网页后点击屏幕右上角“分享”按钮</p>
10
        <div class="qrcode" id="qrcode" ref="qrcode"></div>
11
        <div class="qrword">
12
          打开微信“扫一扫”,<br/>打开网页后点击屏幕右上角“分享”按钮
9 13
        </div>
10 14
      </div>
11
    </em>
15
      <em slot="reference" class="share-icon icon-wechat"></em>
16
    </el-popover>
12 17
  </div>
13 18
</template>
14 19
<script>
15
  // import QRCode from 'qrcode'
16
  // export default {
17
  //   // props: {
18
  //   // },
19
  //   mounted() {
20
  //   },
21
  //   methods: {
22
  //     _makeCode() {
23
  //       this.qrcodeCreat = new QRCode(document.getElementById('qrcode'), {
24
  //         width: 100,
25
  //         height: 100
26
  //       });
27
  //       var elurl = '';
28
  //       this.qrcodeCreat.makeCode(elurl);
29
  //     }
30
  //   }
31
  // };
20
  import QRCode from 'qrcodejs2';
21
  export default {
22
    props: {
23
      tUrl: {
24
        type: String
25
      },
26
      tPosition: {
27
        type: String,
28
        default: 'bottom-start'
29
      }
30
    },
31
    mounted() {
32
      this.$nextTick(function() {
33
        this._makeCode();
34
      });
35
    },
36
    methods: {
37
      _makeCode() {
38
        let qrcode = new QRCode('qrcode', {
39
          width: 120,
40
          height: 120
41
        });
42
        qrcode.clear();
43
        qrcode.makeCode(this.tUrl);
44
      }
45
    }
46
  };
32 47
</script>
33
<style lang="stylus" rel="stylesheet/stylus" scoped>
48
<style lang="stylus" rel="stylesheet/stylus" scoded>
34 49
.share-block
35
  background:rgba(60,62,81,.5)
36
  padding:14px 30px
37
  .operateicon
50
  margin-right:15px
51
  .share-icon
38 52
    display:inline-block
53
    margin-left:6px
39 54
    &.icon-wechat
40
      width:19px
41
      height:15px
55
      width:18px
56
      height:14px
42 57
      bg-image("./img/icon_weixin_nor.png")
43 58
      &:hover
44 59
        bg-image("./img/icon_weixin_hig.png")
45
    .shareWeixin
46
      font-style: normal
47
      position: relative
48
      .shareCode
49
        display:none
50
        position: absolute
51
        bottom: 40px
52
        left:-24px
53
        background:rgba(0,0,0,.6)
54
        padding: 8px
55
        width:320px
56
        overflow:hidden
57
        z-index: 688
58
        &:after
59
          display: block
60
          width: 0
61
          height: 0
62
          border:12px solid transparent
63
          border-top-color:rgba(0,0,0,.6)
64
          position: absolute
65
          bottom:-24px
66
          left:22px
67
        .shareWord
68
          width:160px
69
          margin: 16px 10px
70
          color: #FFF
71
          text-align: left
72
          font-size: 14px
73
          line-height: 28px
74
          p
75
            font-size: 14px
76
            line-height: 28px
77
          img
78
            width:120px
79
            height:120px
80
            border: 4px solid #fff
60
.popper-class
61
  background: rgba(0,0,0,.6)
62
  color:#ffffff
63
  .shareCode
64
    overflow:hidden
65
    display:flex
66
    align-items:center
67
    justify-content:space-between
68
    .qrcode
69
      float: left
70
      img,canvas
71
        border: 4px solid #ffffff
72
    .qrword
73
      width:180px
74
      font-size:14px
75
      line-height:28px
76
.el-popover
77
  border: none
78
.el-popper[x-placement^=bottom] .popper__arrow::after
79
  border-bottom-color: rgba(0,0,0,.6)
80
.el-popper[x-placement^=top] .popper__arrow::after
81
  border-top-color: rgba(0,0,0,.6)
81 82
</style>

+ 200 - 37
src/views/infoshow/expertShow/index.vue

@ -3,20 +3,16 @@
3 3
		<div class="block-wrapper">
4 4
      <div class="content-wrapper">
5 5
        <div class="headcon-box">
6
          <div class="show-head headimg-box"></div>
6
          <div class="show-head headimg-box" :style="{backgroundImage:'url('+ headUrl(expertInfo) +')'}"></div>
7 7
          <div class="show-info reInfo-box">
8
            <div class="info-tit">name<em class="authicon"></em></div>
9
            <div class="info-tag">offt</div>
10
            <div class="operateBlock bottomShow">
11
              <ul class="clearfix">
12
                <li><span>shanghai</span></li>
13
                <li>
14
                  <!-- <share-out></share-out> -->
15
                </li>
16
              </ul>
8
            <div class="info-tit">{{expertInfo.name}}<em class="authicon" :class="headIcon(expertInfo)"></em></div>
9
            <div class="info-tag"><span v-if="expertInfo.title" style="margin-right:10px">{{expertInfo.title}}</span> {{expertInfo.offt}}</div>
10
            <div class="info-operate">
11
              <div class="addr">{{expertInfo.address}}</div>
12
              <shareOut :tUrl="elurl"></shareOut>
17 13
            </div>
18 14
          </div>
19
          <el-row>
15
          <el-row class="goSpan">
20 16
            <el-button type="primary" icon="el-icon-plus">关注</el-button>
21 17
            <el-button type="primary">联系</el-button>
22 18
          </el-row>
@ -24,23 +20,156 @@
24 20
      </div>
25 21
    </div>
26 22
    <div class="block-wrapper">
27
      <div class="wrapper-left">
28
        <div class="content-wrapper plat-news">
29
          <div class="content-title" style="display: block;">
30
            <router-link class="content-more" to="/platTrends?flag=first">更多</router-link>
23
      <div class="wrapper-left left-main">
24
        <el-tabs v-model="activeName">
25
          <el-tab-pane label="主页" name="first">
26
            <div class="content-wrapper split-other" v-if="platServices.length">
27
              <div class="inner-wrapper">
28
                <div class="content-title">
29
                  <span>可提供服务</span>
30
                  <span class="content-more" @click="activeName='second'">更多</span>
31
                </div>
32
                <div class="content">
33
                  <!-- <baseService v-if="platServices.length" v-for="item in platServices" :key="item.index" :itemSingle="item"></baseService> -->
34
                </div>
35
              </div>
36
            </div>
37
            <div class="content-wrapper" v-if="expertInfo.descp">
38
              <div class="inner-wrapper">
39
                <div class="content-title">
40
                  <span>个人简介</span>
41
                </div>
42
                <div class="content">{{expertInfo.descp}}</div>
43
              </div>
44
              <div class="inner-wrapper" v-if="expertInfo.subject && expertInfo.subject.length">
45
                <div class="content-title">
46
                  <span>学术领域</span>
47
                </div>
48
                <div class="content">
49
                  <el-row class="tag-item">
50
                    <el-tag v-for="sub in expertInfo.subject" :key="sub.index">{{sub}}</el-tag>
51
                  </el-row>
52
                </div>
53
              </div>
54
              <div class="inner-wrapper" v-if="expertInfo.resAreas && expertInfo.resAreas.length">
55
                <div class="content-title">
56
                  <span>研究方向</span>
57
                </div>
58
                <div class="content">
59
                  <el-row class="tag-item">
60
                    <el-col :span="24" v-for="sub in expertInfo.resAreas" :key="sub.index">
61
                      <el-tag>{{sub}}</el-tag>
62
                    </el-col>
63
                  </el-row>
64
                </div>
65
              </div>
66
              <div class="inner-wrapper" v-if="expertInfo.industry && expertInfo.industry.length">
67
                <div class="content-title">
68
                  <span>行业领域</span>
69
                </div>
70
                <div class="content">
71
                  <el-row class="tag-item">
72
                    <el-tag v-for="sub in expertInfo.industry" :key="sub.index">{{sub}}</el-tag>
73
                  </el-row>
74
                </div>
75
              </div>
76
              <div class="inner-wrapper" v-if="platPatents.lnegth">
77
                <div class="content-title">
78
                  <span>专利</span>
79
                  <span class="content-more" @click="activeName='third'">更多</span>
80
                </div>
81
                <div class="content">
82
                  <!-- <baseService v-if="platServices.length" v-for="item in platServices" :key="item.index" :itemSingle="item"></baseService> -->
83
                </div>
84
              </div>
85
            </div>
86
          </el-tab-pane>
87
          <el-tab-pane label="服务" name="second">
88
            <!-- <baseService v-if="platServices.length" v-for="item in platServices" :key="item.index" :itemSingle="item"></baseService> -->
89
          </el-tab-pane>
90
          <el-tab-pane label="专利" name="third">
91
            <!-- <baseService v-if="platServices.length" v-for="item in platServices" :key="item.index" :itemSingle="item"></baseService> -->
92
          </el-tab-pane>
93
          <el-tab-pane label="资料" name="fourth">
94
            <div class="content-wrapper">
95
              <div class="inner-wrapper" v-if="expertInfo.projects && expertInfo.projects.length">
96
                <div class="content-title">
97
                  <span>项目经历</span>
98
                </div>
99
                <div class="content">
100
                   <div class="ulM">
101
                    <div class="liM" v-for="item in expertInfo.projects" :key="item.index">
102
                      <div class="liM-tit">{{item.name}}<small>{{item.startMonth ? item.startMonth.substr(0, 4) + '年' + item.startMonth.substr(4, 6) + '月':''}}{{item.startMonth?(item.stopMonth ? ' - ' + item.startMonth.substr(0, 4) + '年' + item.startMonth.substr(4, 6) + '月' : ' - 至今'):''}}</small></div>
103
                      <div class="liM-con">{{item.descp}}</div>
104
                    </div>
105
                  </div>
106
                </div>
107
              </div>
108
              <div class="inner-wrapper" v-if="expertInfo.honors && expertInfo.honors.length">
109
                <div class="content-title">
110
                  <span>荣誉奖项</span>
111
                </div>
112
                <div class="content">
113
                  <div class="ulM">
114
                    <div class="liM" v-for="item in expertInfo.honors" :key="item.index">
115
                      <div class="liM-tit">{{item.name}}<small>{{item.year ? item.year + '年' : ''}}</small></div>
116
                      <div class="liM-con">{{item.descp}}</div>
117
                    </div>
118
                  </div>
119
                </div>
120
              </div>
121
              <div class="inner-wrapper" v-if="expertInfo.jobs && expertInfo.jobs.length">
122
                <div class="content-title">
123
                  <span>工作经历</span>
124
                </div>
125
                <div class="content">
126
                  <div class="ulM">
127
                    <div class="liM" v-for="item in expertInfo.jobs" :key="item.index">
128
                      <div class="liM-tit">{{item.company}}{{item.department? ' - '+ item.department : ''}}{{item.title? ' - '+ item.title : ''}}<small>{{item.startMonth ? item.startMonth.substr(0, 4) + '年' + item.startMonth.substr(4, 6) + '月':''}}{{item.startMonth?(item.stopMonth ? ' - ' + item.startMonth.substr(0, 4) + '年' + item.startMonth.substr(4, 6) + '月' : ' - 至今'):''}}</small></div>
129
                    </div>
130
                  </div>
131
                </div>
132
              </div>
133
              <div class="inner-wrapper" v-if="expertInfo.edus && expertInfo.edus.length">
134
                <div class="content-title">
135
                  <span>教育背景</span>
136
                </div>
137
                <div class="content">
138
                  <div class="ulM">
139
                    <div class="liM" v-for="item in expertInfo.edus" :key="item.index">
140
                      <div class="liM-tit">{{item.school}}{{item.college? ' - '+ item.college : ''}}{{item.major? ' - '+ item.major : ''}}{{item.degree? ' - '+ item.degree : ''}}<small>{{item.year=='至今  '? item.year : item.year+'年'}}</small></div>
141
                    </div>
142
                  </div>
143
                </div>
144
              </div>
145
            </div>
146
          </el-tab-pane>
147
        </el-tabs>
148
      </div>
149
      <div class="wrapper-right">
150
        <div class="content-wrapper">
151
          <div class="content-title">
152
            <span>合作专家</span>
153
          </div>
154
          <div class="content">
155
            <!-- <baseService v-if="platServices.length" v-for="item in platServices" :key="item.index" :itemSingle="item"></baseService> -->
31 156
          </div>
32 157
        </div>
33
        <div class="content-wrapper full-wrapper" style="margin-top:20px">
158
        <div class="content-wrapper">
34 159
          <div class="content-title">
35
              <span>最新入驻企业</span>
36
              <router-link class="content-more" to="/regAgency">更多</router-link>
160
            <span>相关文章</span>
161
          </div>
162
          <div class="content">
163
            <!-- <baseService v-if="platServices.length" v-for="item in platServices" :key="item.index" :itemSingle="item"></baseService> -->
37 164
          </div>
38 165
        </div>
39
      </div>
40
      <div class="wrapper-right content-wrapper about-us">
41
        <div class="content-title">
42
          <span>关于我们</span>
43
          <router-link class="content-more" to="/about">更多</router-link>
166
        <div class="content-wrapper">
167
          <div class="content-title">
168
            <span>您可能感兴趣的专家</span>
169
          </div>
170
          <div class="content">
171
            <!-- <baseService v-if="platServices.length" v-for="item in platServices" :key="item.index" :itemSingle="item"></baseService> -->
172
          </div>
44 173
        </div>
45 174
      </div>
46 175
    </div>
@ -51,27 +180,61 @@
51 180
<script>
52 181
  import '@/common/stylus/listitem.styl';
53 182
  import '@/common/stylus/browse.styl';
54
  import ShareOut from '../components/ShareOut';
183
  import util from '@/libs/util';
184
  import httpUrl from '@/libs/http';
185
186
  import shareOut from '../components/ShareOut';
187
  import baseService from '@/views/sub-component/BaseService';
188
55 189
  export default {
56
    props: {
57
      expertId: {
58
        type: String
59
      }
60
    },
61 190
    data() {
62 191
      return {
63
        activeName: 'first'
192
        activeIndex: '1',
193
        activeName: 'first',
194
        expertInfo: '',
195
        elurl: '',
196
        platServices: [],
197
        platPatents: []
64 198
      };
65 199
    },
66
    watch: {
67
     '$route' (to, from) {
68
        if (this.$route.query.flag) {
69
          this.activeName = this.$route.query.flag; // 监听flag变化
70
        }
71
      }
200
    created() {
201
      this.expertId = util.urlParse('id');
202
      this.elurl = window.location.href;
203
      this.getExpertInfo();
72 204
    },
73 205
    components: {
74
      ShareOut
206
      shareOut,
207
      baseService
208
    },
209
    methods: {
210
      getExpertInfo() {
211
        this.$axios.get(httpUrl.kxQurey.professor.query2 + this.expertId, {
212
        }, (res) => {
213
          if (res.success) {
214
            var $info = res.data;
215
            $info.offt = util.formatOfft($info);
216
            if ($info.subject) {
217
              $info.subject = util.strToArr($info.subject);
218
            }
219
            if ($info.industry) {
220
              $info.industry = util.strToArr($info.industry);
221
            }
222
            $info.resAreas = [];
223
            if ($info.researchAreas && $info.researchAreas.length > 0) {
224
              for (let i = 0; i < $info.researchAreas.length; ++i) {
225
                $info.resAreas.push($info.researchAreas[i].caption);
226
              }
227
            }
228
            this.expertInfo = $info;
229
          };
230
        });
231
      },
232
      headUrl(item) {
233
        return item.hasHeadImage ? util.ImageUrl(('head/' + item.id + '_l.jpg'), true) : util.defaultSet.img.expert;
234
      },
235
      headIcon(item) {
236
        return util.autho(item.authType, item.orgAuth, item.authStatus);
237
      }
75 238
    }
76 239
  };
77 240
</script>

+ 199 - 40
src/views/infoshow/orgShow/index.vue

@ -1,58 +1,217 @@
1 1
<template>
2
  <div>
2
  <div class="browse-main">
3 3
		<div class="block-wrapper">
4 4
      <div class="content-wrapper">
5
        ghdfgfhdhfd
5
        <div class="headcon-box org-head">
6
          <div class="show-head headimg-box">
7
            <img :src="orgLogoUrl(orgInfo)">
8
          </div>
9
          <div class="show-info reInfo-box">
10
            <div class="info-tit">{{orgInfo.forShort ? orgInfo.forShort : orgInfo.name}}<em class="authicon" :class="{'icon-com': orgInfo.authStatus==='3'}"></em></div>
11
            <div class="info-tag"><span v-if="orgInfo.title" style="margin-right:10px">{{orgInfo.orgType}}</span> {{orgInfo.industry ? orgInfo.industry.replace(/,/gi, " | ") : ''}}</div>
12
            <div class="info-operate">
13
              <div class="addr">{{orgInfo.city}}</div>
14
              <shareOut :tUrl="elurl"></shareOut>
15
            </div>
16
          </div>
17
          <el-row class="goSpan">
18
            <el-button type="primary" icon="el-icon-plus">关注</el-button>
19
            <el-button type="primary">联系</el-button>
20
          </el-row>
21
        </div>
6 22
      </div>
7 23
    </div>
8
		<BackTop></BackTop>
24
    <div class="block-wrapper">
25
      <div class="wrapper-left left-main">
26
        <el-tabs v-model="activeName">
27
          <el-tab-pane label="主页" name="first">
28
            <div class="content-wrapper split-other" v-if="platServices.length || platResources.length">
29
              <div class="inner-wrapper" v-if="platServices.length">
30
                <div class="content-title">
31
                  <span>可提供服务</span>
32
                  <span class="content-more" @click="activeName='second'">更多</span>
33
                </div>
34
                <div class="content">
35
                  <!-- <baseService v-if="platServices.length" v-for="item in platServices" :key="item.index" :itemSingle="item"></baseService> -->
36
                </div>
37
              </div>
38
              <div class="inner-wrapper" v-if="platResources.length">
39
                <div class="content-title">
40
                  <span>可共享资源</span>
41
                  <span class="content-more" @click="activeName='third'">更多</span>
42
                </div>
43
                <div class="content">
44
                  <!-- <baseService v-if="platServices.length" v-for="item in platServices" :key="item.index" :itemSingle="item"></baseService> -->
45
                </div>
46
              </div>
47
            </div>
48
            <div class="content-wrapper" v-if="orgInfo.descp">
49
              <div class="inner-wrapper">
50
                <div class="content-title">
51
                  <span>机构简介</span>
52
                </div>
53
                <div class="content">{{orgInfo.descp}}</div>
54
              </div>
55
              <div class="inner-wrapper" v-if="orgInfo.subject && orgInfo.subject.length">
56
                <div class="content-title">
57
                  <span>专注领域</span>
58
                </div>
59
                <div class="content">
60
                  <el-row class="tag-item">
61
                    <el-tag v-for="sub in orgInfo.subject" :key="sub.index">{{sub}}</el-tag>
62
                  </el-row>
63
                </div>
64
              </div>
65
            </div>
66
          </el-tab-pane>
67
          <el-tab-pane label="服务" name="second">
68
            <!-- <baseService v-if="platServices.length" v-for="item in platServices" :key="item.index" :itemSingle="item"></baseService> -->
69
          </el-tab-pane>
70
          <el-tab-pane label="资源" name="third">
71
            <!-- <baseService v-if="platServices.length" v-for="item in platServices" :key="item.index" :itemSingle="item"></baseService> -->
72
          </el-tab-pane>
73
          <el-tab-pane label="资料" name="fourth">
74
            <div class="content-wrapper">
75
              <div class="inner-wrapper">
76
                <div class="content-title">
77
                  <span>机构详情</span>
78
                </div>
79
                <div class="content">
80
                  <el-row :gutter="10">
81
                    <el-col :span="12" v-if="orgInfo.name">
82
                      <el-col :span="6">机构名称:</el-col>
83
                      <el-col :span="18">{{orgInfo.name}}</el-col>
84
                    </el-col>
85
                    <el-col :span="12" v-if="orgInfo.orgSize">
86
                      <el-col :span="6">机构规模:</el-col>
87
                      <el-col :span="18">{{orgInfo.orgSize}}</el-col>
88
                    </el-col>
89
                    <el-col :span="12" v-if="orgInfo.orgType">
90
                      <el-col :span="6">机构类型:</el-col>
91
                      <el-col :span="18">{{orgInfo.orgType}}</el-col>
92
                    </el-col>
93
                    <el-col :span="12" v-if="orgInfo.addr">
94
                      <el-col :span="6">机构地址:</el-col>
95
                      <el-col :span="18">{{orgInfo.addr}}</el-col>
96
                    </el-col>
97
                    <el-col :span="12" v-if="orgInfo.foundTime">
98
                      <el-col :span="6">创立时间:</el-col>
99
                      <el-col :span="18">{{orgInfo.foundTime}}</el-col>
100
                    </el-col>
101
                    <el-col :span="12" v-if="orgInfo.orgUrl">
102
                      <el-col :span="6">机构官网:</el-col>
103
                      <el-col :span="18">{{orgInfo.orgUrl}}</el-col>
104
                    </el-col>
105
                  </el-row>
106
                </div>
107
              </div>
108
              <div class="inner-wrapper" v-if="orgInfo.qualification && orgInfo.qualification.length">
109
                <div class="content-title">
110
                  <span>机构资质</span>
111
                </div>
112
                <div class="content">
113
                   <div class="ulM">
114
                    <div class="liM" v-for="item in orgInfo.qualification" :key="item.index">
115
                      <div class="liM-tit">{{item}}</div>
116
                    </div>
117
                  </div>
118
                </div>
119
              </div>
120
            </div>
121
          </el-tab-pane>
122
        </el-tabs>
123
      </div>
124
      <div class="wrapper-right">
125
        <div class="content-wrapper">
126
          <div class="content-title">
127
            <span>相关文章</span>
128
          </div>
129
          <div class="content">
130
            <!-- <baseService v-if="platServices.length" v-for="item in platServices" :key="item.index" :itemSingle="item"></baseService> -->
131
          </div>
132
        </div>
133
        <div class="content-wrapper">
134
          <div class="content-title">
135
            <span>您可能感兴趣的机构</span>
136
          </div>
137
          <div class="content">
138
            <!-- <baseService v-if="platServices.length" v-for="item in platServices" :key="item.index" :itemSingle="item"></baseService> -->
139
          </div>
140
        </div>
141
      </div>
142
    </div>
143
    <BackTop></BackTop>
9 144
  </div>
10 145
</template>
11 146
12 147
<script>
13
	export default {
14
    props: {
15
      plat: {
16
        type: Object
17
      }
18
    },
148
  import '@/common/stylus/listitem.styl';
149
  import '@/common/stylus/browse.styl';
150
  import util from '@/libs/util';
151
  import httpUrl from '@/libs/http';
152
153
  import shareOut from '../components/ShareOut';
154
  import baseService from '@/views/sub-component/BaseService';
155
156
  export default {
19 157
    data() {
20 158
      return {
21
        activeName: 'first'
159
        activeIndex: '1',
160
        activeName: 'first',
161
        orgInfo: '',
162
        orgRegInfo: '',
163
        elurl: '',
164
        platServices: [],
165
        platResources: []
22 166
      };
23 167
    },
24
    watch: {
25
     '$route' (to, from) {
26
        if (this.$route.query.flag) {
27
          this.activeName = this.$route.query.flag; // 监听flag变化
28
        }
29
      }
168
    created() {
169
      this.orgId = util.urlParse('id');
170
      this.elurl = window.location.href;
171
      this.getorgInfo();
30 172
    },
31 173
    components: {
174
      shareOut,
175
      baseService
176
    },
177
    methods: {
178
      getorgInfo() {
179
        this.$axios.get(httpUrl.kxQurey.org.query + this.orgId, {
180
        }, (res) => {
181
          if (res.success) {
182
            var $info = res.data;
183
            if ($info.subject) {
184
              $info.subject = util.strToArr($info.subject);
185
            }
186
            if ($info.qualification) {
187
              $info.qualification = util.strToArr($info.qualification);
188
            }
189
            if ($info.foundTime) {
190
              $info.foundTime = util.TimeTr($info.foundTime);
191
            }
192
            if ($info.orgSize) {
193
              $info.orgSize = util.orgSizeShow[$info.orgSize];
194
            }
195
            if ($info.orgType) {
196
              $info.orgType = util.orgTypeShow[$info.orgType];
197
            }
198
            this.orgInfo = $info;
199
          };
200
        });
201
      },
202
      getorgRegInfo(oName) {
203
        this.$axios.get(httpUrl.kxQurey.org.reg, {
204
          name: oName
205
        }, (res) => {
206
          if (res.success) {
207
            var $info = res.data;
208
            this.orgRegInfo = $info;
209
          };
210
        });
211
      },
212
      orgLogoUrl(item) {
213
        return item.hasOrgLogo ? util.ImageUrl(('org/' + item.id + '.jpg'), true) : util.defaultSet.img.org;
214
      }
32 215
    }
33 216
  };
34 217
</script>
35
36
<style lang="stylus" rel="stylesheet/stylus" scoped>
37
38
  .tab-wrapper
39
    padding:10px 20px
40
    color: $commonFont
41
    li
42
      display:inline-block
43
      margin-right:20px
44
      cursor: pointer
45
      &.active
46
        color: $mainColor
47
    .el-tabs
48
      width:100%
49
    .el-tabs__header
50
      margin: 0 0 4px
51
    .el-tabs__nav-wrap::after
52
      content:none
53
    .el-tabs__content
54
      margin:0 -20px
55
      .tab-contain
56
        width:100%
57
        border-top:20px solid #f4f6f8
58
</style>

+ 142 - 0
src/views/infoshow/resourceShow/index.vue

@ -0,0 +1,142 @@
1
<template>
2
  <div class="browse-main">
3
    <div class="block-wrapper">
4
      <div class="wrapper-left left-main">
5
        <div class="content-wrapper split-other">
6
          <div class="headcon-box hdetail-box">
7
            <div class="zoom-box">
8
              <!-- <previewMagnify v-if="srcImg.length" :previewImg="srcImg"></previewMagnify> -->
9
              <previewMagnify></previewMagnify>
10
            </div>
11
            <div class="show-info reInfo-box">
12
              <div class="info-tit info-tit-big">{{resourceInfo.resourceName}}</div>
13
              <div class="info-tag">应用用途:{{resourceInfo.supportedServices}}</div>
14
              <div class="info-operate zoom-operate">
15
                <div class="addr">浏览量 10</div>
16
                <collectCo></collectCo>
17
                <shareOut :tUrl="elurl" :tPosition="tPosition"></shareOut>
18
              </div>
19
            </div>
20
          </div>
21
        </div>
22
        <div class="content-wrapper">
23
          <div class="content">
24
            <el-row :gutter="10" class="rel-detail">
25
              <el-col class="rel-item" :span="24" v-if="resourceInfo.orgName">
26
                <div class="rel-tit">所属机构:</div>
27
                <div>{{resourceInfo.orgName}}</div>
28
              </el-col>
29
              <el-col class="rel-item" :span="24" v-if="resourceInfo.spec">
30
                <div class="rel-tit">厂商型号:</div>
31
                <div>{{resourceInfo.spec}}</div>
32
              </el-col>
33
              <el-col class="rel-item" :span="24" v-if="resourceInfo.parameter">
34
                <div class="rel-tit">性能参数:</div>
35
                <div v-html="resourceInfo.parameter"></div>
36
              </el-col>
37
              <el-col class="rel-item" :span="24" v-if="resourceInfo.cooperationNotes">
38
                <div class="rel-tit">合作备注:</div>
39
                <div v-html="resourceInfo.cooperationNotes"></div>
40
              </el-col>
41
              <el-col class="rel-item" :span="24" v-if="resourceInfo.descp">
42
                <div class="rel-tit">详细介绍:</div>
43
                <div v-html="resourceInfo.descp"></div>
44
              </el-col>
45
              <el-col class="rel-item" :span="24" v-if="resourceInfo.subject && resourceInfo.subject.length">
46
                <el-row class="tag-item">
47
                  <el-tag v-for="sub in resourceInfo.subject" :key="sub.index">{{sub}}</el-tag>
48
                </el-row>
49
              </el-col>
50
            </el-row>
51
          </div>
52
        </div>
53
        <div class="content-wrapper">
54
          <div class="content-title">
55
            <span>您可能感兴趣的资源</span>
56
          </div>
57
          <div class="content">
58
            <!-- <baseService v-if="platServices.length" v-for="item in platServices" :key="item.index" :itemSingle="item"></baseService> -->
59
          </div>
60
        </div>
61
      </div>
62
      <div class="wrapper-right">
63
        <div class="content-wrapper">
64
          <div class="right-split">
65
            <beyondTo :ownerId="owner.id" :ownerType="owner.type"></beyondTo>
66
          </div>
67
          <div class="right-split">
68
            <div class="content-title">
69
              <span>热门资源</span>
70
            </div>
71
            <div class="content">
72
              <!-- <baseService v-if="platServices.length" v-for="item in platServices" :key="item.index" :itemSingle="item"></baseService> -->
73
            </div>
74
          </div>
75
        </div>
76
      </div>
77
    </div>
78
    <BackTop></BackTop>
79
  </div>
80
</template>
81
82
<script>
83
  import '@/common/stylus/listitem.styl';
84
  import '@/common/stylus/browse.styl';
85
  import util from '@/libs/util';
86
  import httpUrl from '@/libs/http';
87
88
  import previewMagnify from '../components/previewMagnify';
89
  import shareOut from '../components/ShareOut';
90
  import collectCo from '../components/CollectCo';
91
  import beyondTo from '../components/BeyondTo';
92
93
  export default {
94
    data() {
95
      return {
96
        resourceInfo: '',
97
        elurl: '',
98
        tPosition: 'top-start',
99
        platServices: [],
100
        srcImg: [],
101
        owner: {
102
          id: '',
103
          type: ''
104
        }
105
      };
106
    },
107
    created() {
108
      this.resourceId = util.urlParse('id');
109
      this.elurl = window.location.href;
110
      this.getResourceInfo();
111
    },
112
    components: {
113
      // PicZoom,
114
      previewMagnify,
115
      shareOut,
116
      collectCo,
117
      beyondTo
118
    },
119
    methods: {
120
      getResourceInfo() {
121
        this.$axios.get(httpUrl.kxQurey.resource.query, {
122
          resourceId: this.resourceId
123
        }, (res) => {
124
          if (res.success) {
125
            var $info = res.data;
126
            if ($info.subject) {
127
              $info.subject = util.strToArr($info.subject);
128
            }
129
            if ($info.images.length) {
130
              this.srcImg = $info.images;
131
            }
132
            this.owner = {
133
              id: $info.professorId,
134
              type: $info.resourceType
135
            };
136
            this.resourceInfo = $info;
137
          };
138
        });
139
      }
140
    }
141
  };
142
</script>

+ 14 - 0
src/views/infoshow/resultShow/index.vue

@ -0,0 +1,14 @@
1
<template>
2
  <div>
3
    <router-view :plat="plat"></router-view>
4
  </div>
5
</template>
6
<script>
7
  export default {
8
    props: {
9
      plat: {
10
        type: Object
11
      }
12
    }
13
  };
14
</script>

+ 156 - 0
src/views/infoshow/resultShow/patent.vue

@ -0,0 +1,156 @@
1
<template>
2
  <div class="browse-main">
3
    <div class="block-wrapper">
4
      <div class="wrapper-left 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">title</div>
10
                <div class="info-operate zoom-operate">
11
                  <div class="addr">浏览量 10</div>
12
                  <collectCo></collectCo>
13
                  <shareOut :tUrl="elurl"></shareOut>
14
                </div>
15
              </div>
16
            </div>
17
          </div>
18
          <div class="inner-wrapper">
19
            <div class="content">
20
              <el-row :gutter="10" class="rel-detail">
21
                <el-col :span="12" v-if="patentInfo.code">
22
                  <el-col :span="5">专利号:</el-col>
23
                  <el-col :span="19">{{patentInfo.code}}</el-col>
24
                </el-col>
25
                <el-col :span="12" v-if="patentInfo.pubDay">
26
                  <el-col :span="5">公开日:</el-col>
27
                  <el-col :span="19">{{patentInfo.pubDay}}</el-col>
28
                </el-col>
29
                <el-col :span="12" v-if="patentInfo.reqCode">
30
                  <el-col :span="5">申请号:</el-col>
31
                  <el-col :span="19">{{patentInfo.reqCode}}</el-col>
32
                </el-col>
33
                <el-col :span="12" v-if="patentInfo.pubDay">
34
                  <el-col :span="5">申请日:</el-col>
35
                  <el-col :span="19">{{patentInfo.pubDay}}</el-col>
36
                </el-col>
37
                <el-col :span="12" v-if="patentInfo.reqPerson">
38
                  <el-col :span="5">申请人:</el-col>
39
                  <el-col :span="19">{{patentInfo.reqPerson}}</el-col>
40
                </el-col>
41
                <el-col :span="24" v-if="patentInfo.summary">
42
                  <el-col :span="24">摘要:</el-col>
43
                  <el-col :span="24" v-html="patentInfo.summary"></el-col>
44
                </el-col>
45
                <el-col :span="24" v-if="patentInfo.cooperation">
46
                  <el-col :span="24">合作备注:</el-col>
47
                  <el-col :span="24" v-html="patentInfo.cooperation"></el-col>
48
                </el-col>
49
                <el-col :span="24" v-if="patentInfo.keywords && patentInfo.keywords.length">
50
                  <el-row class="tag-item">
51
                    <el-tag v-for="sub in patentInfo.keywords" :key="sub.index">{{sub}}</el-tag>
52
                  </el-row>
53
                </el-col>
54
              </el-row>
55
            </div>
56
          </div>
57
          <div class="inner-wrapper">
58
            <div class="content-title">
59
              <span>发明人</span>
60
            </div>
61
            <div class="content">
62
              <el-row :gutter="10">
63
                <el-col>
64
                </el-col>
65
              </el-row>
66
            </div>
67
          </div>
68
          <div class="inner-wrapper">
69
            <div class="content-title">
70
              <span>您可能感兴趣的专利</span>
71
            </div>
72
            <div class="content">
73
              <!-- <baseService v-if="platServices.length" v-for="item in platServices" :key="item.index" :itemSingle="item"></baseService> -->
74
            </div>
75
          </div>
76
        </div>
77
      </div>
78
      <div class="wrapper-right">
79
        <div class="wrapper-right">
80
          <div class="block-wrapper" v-if="plat.adinfo.length" v-for="item in plat.adinfo" :key="item.index">
81
            <a class="ad-wrapper" :href="item.adUrl" target="_blank">
82
              <img :src="item.imgUrl" width="280" height="200">
83
            </a>
84
          </div>
85
        </div>
86
      </div>
87
    </div>
88
    <BackTop></BackTop>
89
  </div>
90
</template>
91
92
<script>
93
  import '@/common/stylus/listitem.styl';
94
  import '@/common/stylus/browse.styl';
95
  import util from '@/libs/util';
96
  import httpUrl from '@/libs/http';
97
98
  import shareOut from '../components/ShareOut';
99
  import collectCo from '../components/CollectCo';
100
  import baseService from '@/views/sub-component/BaseService';
101
102
  export default {
103
    props: {
104
      plat: {
105
        type: Object
106
      }
107
    },
108
    data() {
109
      return {
110
        activeIndex: '1',
111
        activeName: 'first',
112
        patentInfo: '',
113
        elurl: '',
114
        platServices: [],
115
        platPatents: []
116
      };
117
    },
118
    created() {
119
      this.patentId = util.urlParse('id');
120
      this.elurl = window.location.href;
121
      this.getExpertInfo();
122
    },
123
    components: {
124
      shareOut,
125
      collectCo,
126
      baseService
127
    },
128
    methods: {
129
      getExpertInfo() {
130
        this.$axios.get(httpUrl.kxQurey.patent.query, {
131
          id: this.patentId
132
        }, (res) => {
133
          if (res.success) {
134
            var $info = res.data;
135
            if ($info.keywords) {
136
              $info.keywords = util.strToArr($info.keywords);
137
            }
138
            if ($info.reqDay) {
139
              $info.reqDay = util.TimeTr($info.reqDay);
140
            }
141
            if ($info.pubDay) {
142
              $info.pubDay = util.TimeTr($info.pubDay);
143
            }
144
            this.patentInfo = $info;
145
          };
146
        });
147
      },
148
      headUrl(item) {
149
        return item.hasHeadImage ? util.ImageUrl(('head/' + item.id + '_l.jpg'), true) : util.defaultSet.img.expert;
150
      },
151
      headIcon(item) {
152
        return util.autho(item.authType, item.orgAuth, item.authStatus);
153
      }
154
    }
155
  };
156
</script>

+ 141 - 0
src/views/infoshow/serviceShow/index.vue

@ -0,0 +1,141 @@
1
<template>
2
  <div class="browse-main">
3
    <div class="block-wrapper">
4
      <div class="wrapper-left left-main">
5
        <div class="content-wrapper split-other">
6
          <div class="headcon-box hdetail-box">
7
            <div class="zoom-box">
8
              <previewMagnify v-if="srcImg.length" :previewImg="srcImg"></previewMagnify>
9
            </div>
10
            <div class="show-info reInfo-box">
11
              <div class="info-tit">{{resourceInfo.resourceName}}</div>
12
              <div class="info-tag">应用用途:{{resourceInfo.supportedServices}}</div>
13
              <div class="info-operate zoom-operate">
14
                <div class="addr">浏览量 10</div>
15
                <collectCo></collectCo>
16
                <shareOut :tUrl="elurl" :tPosition="tPosition"></shareOut>
17
              </div>
18
            </div>
19
          </div>
20
        </div>
21
        <div class="content-wrapper">
22
          <div class="content">
23
            <el-row :gutter="10" class="rel-detail">
24
              <el-col :span="24" v-if="resourceInfo.orgName">
25
                <div class="rel-tit">所属机构:</div>
26
                <div>{{resourceInfo.orgName}}</div>
27
              </el-col>
28
              <el-col :span="24" v-if="resourceInfo.spec">
29
                <div class="rel-tit">厂商型号:</div>
30
                <div>{{resourceInfo.spec}}</div>
31
              </el-col>
32
              <el-col :span="24" v-if="resourceInfo.parameter">
33
                <div class="rel-tit">性能参数:</div>
34
                <div v-html="resourceInfo.parameter"></div>
35
              </el-col>
36
              <el-col :span="24" v-if="resourceInfo.cooperationNotes">
37
                <div class="rel-tit">合作备注:</div>
38
                <div v-html="resourceInfo.cooperationNotes"></div>
39
              </el-col>
40
              <el-col :span="24" v-if="resourceInfo.descp">
41
                <div class="rel-tit">详细介绍:</div>
42
                <div v-html="resourceInfo.descp"></div>
43
              </el-col>
44
              <el-col :span="24" v-if="resourceInfo.subject && resourceInfo.subject.length">
45
                <el-row>
46
                  <el-tag v-for="sub in resourceInfo.subject" :key="sub.index">{{sub}}</el-tag>
47
                </el-row>
48
              </el-col>
49
            </el-row>
50
          </div>
51
        </div>
52
        <div class="content-wrapper">
53
          <div class="content-title">
54
            <span>您可能感兴趣的资源</span>
55
          </div>
56
          <div class="content">
57
            <!-- <baseService v-if="platServices.length" v-for="item in platServices" :key="item.index" :itemSingle="item"></baseService> -->
58
          </div>
59
        </div>
60
      </div>
61
      <div class="wrapper-right">
62
        <div class="content-wrapper">
63
          <div class="right-split">
64
            <beyondTo :ownerId="owner.id" :ownerType="owner.type"></beyondTo>
65
          </div>
66
          <div class="right-split">
67
            <div class="content-title">
68
              <span>热门资源</span>
69
            </div>
70
            <div class="content">
71
              <!-- <baseService v-if="platServices.length" v-for="item in platServices" :key="item.index" :itemSingle="item"></baseService> -->
72
            </div>
73
          </div>
74
        </div>
75
      </div>
76
    </div>
77
    <BackTop></BackTop>
78
  </div>
79
</template>
80
81
<script>
82
  import '@/common/stylus/listitem.styl';
83
  import '@/common/stylus/browse.styl';
84
  import util from '@/libs/util';
85
  import httpUrl from '@/libs/http';
86
87
  import previewMagnify from '../components/previewMagnify';
88
  import shareOut from '../components/ShareOut';
89
  import collectCo from '../components/CollectCo';
90
  import beyondTo from '../components/BeyondTo';
91
92
  export default {
93
    data() {
94
      return {
95
        resourceInfo: '',
96
        elurl: '',
97
        tPosition: 'top-start',
98
        platServices: [],
99
        srcImg: [],
100
        owner: {
101
          id: '',
102
          type: ''
103
        }
104
      };
105
    },
106
    created() {
107
      this.resourceId = util.urlParse('id');
108
      this.elurl = window.location.href;
109
      this.getResourceInfo();
110
    },
111
    components: {
112
      // PicZoom,
113
      previewMagnify,
114
      shareOut,
115
      collectCo,
116
      beyondTo
117
    },
118
    methods: {
119
      getResourceInfo() {
120
        this.$axios.get(httpUrl.kxQurey.resource.query, {
121
          resourceId: this.resourceId
122
        }, (res) => {
123
          if (res.success) {
124
            var $info = res.data;
125
            if ($info.subject) {
126
              $info.subject = util.strToArr($info.subject);
127
            }
128
            if ($info.images.length) {
129
              this.srcImg = $info.images;
130
            }
131
            this.owner = {
132
              id: $info.professorId,
133
              type: $info.resourceType
134
            };
135
            this.resourceInfo = $info;
136
          };
137
        });
138
      }
139
    }
140
  };
141
</script>

+ 1 - 1
src/views/layout/components/Navbar.vue

@ -1,5 +1,5 @@
1 1
<template>
2
  <div class="contain-wrapper" v-if="showBol">
2
  <div class="contain-wrapper">
3 3
    <el-menu class="navbar" mode="horizontal">
4 4
      <div class="tag-breadcrumb">当前位置:</div><breadcrumb></breadcrumb>
5 5
    </el-menu>

+ 6 - 24
src/views/layout/components/TheHeader.vue

@ -7,7 +7,6 @@
7 7
          <span> X </span>
8 8
          <a :href="kexiuLink" target="_blank" class="a-link">科袖网</a>
9 9
          <span>联合为您服务</span>
10
          <!-- <a :href="kexiuLink + '/cmp-portal/cmp-settled-log.html'" class="a-link marLeft" target="_blank">进入企业版</a> -->
11 10
        </div>
12 11
        <div class="wrapper-right">
13 12
          <div v-if="plf_user && plf_user!=='null' && plf_user!==null">
@ -26,29 +25,10 @@
26 25
                <el-dropdown-item divided>退出登录</el-dropdown-item>
27 26
              </el-dropdown-menu>
28 27
            </el-dropdown>
29
            <!-- <el-menu
30
              router
31
              class="el-menu-demo menu-top"
32
              mode="horizontal"
33
              background-color="#373d41"
34
              text-color="#c4c3c3"
35
              active-text-color="#ffffff">
36
              <el-menu-item index="/loginPlat">通知(99+)</el-menu-item>
37
              <el-menu-item index="/regPlat">消息(99+)</el-menu-item>
38
              <el-submenu index="3" background-color="#ffffff">
39
                <template slot="title">用户名称</template>
40
                <el-menu-item index="2-1">修改资料</el-menu-item>
41
                <el-menu-item index="2-2">我的需求</el-menu-item>
42
                <el-menu-item index="2-3">我的企业</el-menu-item>
43
                <el-menu-item index="2-4">首都创新券</el-menu-item>
44
                <el-menu-item index="2-5">账户设置</el-menu-item>
45
                <el-menu-item index="2-6">退出登录</el-menu-item>
46
              </el-submenu>
47
            </el-menu> -->
48 28
          </div>
49 29
          <div v-else>
50
            <router-link class="marLeft" to='loginPlat' tag="a">请登录</router-link>
51
            <router-link class="marLeft" to='loginPlat' tag="a">立即注册</router-link>
30
            <router-link class="marLeft marLeft_1" to='loginPlat' tag="a">请登录</router-link>
31
            <router-link class="marLeft marLeft_1" to='loginPlat' tag="a">立即注册</router-link>
52 32
          </div>
53 33
        </div>
54 34
      </div>
@ -64,8 +44,8 @@
64 44
          <router-link to='/findResource' active-class="active" tag="li">找资源</router-link>
65 45
          <router-link to="/findResult" active-class="active" tag="li">找成果</router-link>
66 46
          <router-link to='/expertPool' active-class="active" tag="li">专家库</router-link>
67
          <router-link to='/cooperationAgency' active-class="active" tag="li">服务机构</router-link>
68
          <router-link to='/regAgency' active-class="active" tag="li">入驻企业</router-link>
47
          <router-link to='/CoAgency' active-class="active" tag="li">服务机构</router-link>
48
          <router-link to='/regCompany' active-class="active" tag="li">入驻企业</router-link>
69 49
          <router-link to='/about' active-class="active" tag="li">关于平台</router-link>
70 50
        </ul>
71 51
      </div>
@ -109,6 +89,8 @@
109 89
          display:inline-block
110 90
          margin-left:20px
111 91
          min-width:62px
92
          &.marLeft_1
93
            min-width:0
112 94
        .wrapper-left
113 95
          float:left
114 96
        .wrapper-right

+ 7 - 12
src/views/sub-component/BaseAgency.vue

@ -1,7 +1,7 @@
1 1
<template>
2 2
  <div>
3 3
    <div class="block-container">
4
      <a class="block-item org-item" v-for="item in orgData" :key="item.index" :href="linkUrl(item)" target="_blank">
4
      <router-link class="block-item org-item" v-for="item in orgData" :key="item.index" :to="'org_show?id='+item.id" target="_blank">
5 5
        <div class="item-block-org">
6 6
          <div class="item-pic-org">
7 7
            <img :src="orgLogoUrl(item)">
@ -11,7 +11,7 @@
11 11
            <p class="item-tag-org">{{item.industry.replace(/,/gi, ' | ')}}</p>
12 12
          </div>
13 13
        </div>
14
      </a>
14
      </router-link>
15 15
    </div>
16 16
    <Loading v-show="loadingModalShow" :loadingComplete="loadingComplete" :isLoading="isLoading" v-on:upup="loadLower" v-if="!num"></Loading>
17 17
  </div>
@ -50,13 +50,11 @@
50 50
    methods: {
51 51
      ResidentOrgs(id) {
52 52
        this.$axios.get(httpUrl.hQuery.buttedOrgs.nopq, {
53
          params: {
54
            pid: id,
55
            oid: this.dataO.bOid,
56
            time: this.dataO.bTime,
57
            rows: this.num ? this.num : this.rows
58
          }
59
        }).then((res) => {
53
          pid: id,
54
          oid: this.dataO.bOid,
55
          time: this.dataO.bTime,
56
          rows: this.num ? this.num : this.rows
57
        }, (res) => {
60 58
          if (res.success) {
61 59
            var $info = res.data;
62 60
            if ($info.length > 0) {
@ -75,9 +73,6 @@
75 73
      orgLogoUrl(item) {
76 74
        return item.hasOrgLogo ? util.ImageUrl(('org/' + item.id + '.jpg'), true) : util.defaultSet.img.org;
77 75
      },
78
      linkUrl(item) {
79
        return util.defaultSet.link.org + item.id;
80
      },
81 76
      loadLower() {
82 77
        if (this.loadingModalShow && !this.isLoading) {
83 78
          this.ResidentOrgs(this.platId);

+ 4 - 6
src/views/sub-component/BaseArticle.vue

@ -46,11 +46,9 @@
46 46
      leaveWordTotal(item) {
47 47
        var _this = this;
48 48
         this.$axios.get(httpUrl.kxQurey.leaveMsg.count, {
49
          params: {
50
            sid: item.articleId,
51
            stype: 1
52
          }
53
        }).then((res) => {
49
          sid: item.articleId,
50
          stype: 1
51
        }, (res) => {
54 52
          if (res.success) {
55 53
            _this.leverNumber = res.data;
56 54
            _this.$forceUpdate();
@ -61,7 +59,7 @@
61 59
        var _this = this;
62 60
        if (item.articleType) {
63 61
          this.$axios.get(httpUrl.kxQurey.org.query + item.ownerId, {
64
            }).then((res) => {
62
            }, (res) => {
65 63
            if (res.success) {
66 64
              let $info = res.data;
67 65
              _this.ownerName = $info.forShort ? $info.forShort : $info.name;

+ 83 - 0
src/views/sub-component/BaseCompany.vue

@ -0,0 +1,83 @@
1
<template>
2
  <div>
3
    <div class="block-container">
4
      <router-link class="block-item org-item" v-for="item in orgData" :key="item.index" :to="'comp_show?id='+item.id" target="_blank">
5
        <div class="item-block-org">
6
          <div class="item-pic-org">
7
            <img :src="orgLogoUrl(item)">
8
          </div>
9
          <div class="item-text-org">
10
            <div class="item-tit-org"><span>{{item.name}}</span><em class="authicon" :class="{'icon-com': item.authStatus==='3'}"></em></div>
11
            <p class="item-tag-org">{{item.industry.replace(/,/gi, ' | ')}}</p>
12
          </div>
13
        </div>
14
      </router-link>
15
    </div>
16
    <Loading v-show="loadingModalShow" :loadingComplete="loadingComplete" :isLoading="isLoading" v-on:upup="loadLower" v-if="!num"></Loading>
17
  </div>
18
</template>
19
20
<script>
21
  import Cookies from 'js-cookie';
22
  import util from '@/libs/util';
23
  import httpUrl from '@/libs/http';
24
25
  export default {
26
    props: {
27
      num: {
28
        type: Number
29
      }
30
    },
31
    data() {
32
      return {
33
        platId: '',
34
        rows: 30,
35
        orgData: [],
36
        dataO: {
37
          bOid: '',
38
          bTime: ''
39
        },
40
        loadingModalShow: true, // 是否显示按钮
41
        loadingComplete: false, // 是否全部加载
42
        isFormSearch: false, // 数据加载
43
        isLoading: false // button style...
44
      };
45
    },
46
    created() {
47
       this.platId = Cookies.get('platId');
48
       this.ResidentOrgs(this.platId);
49
    },
50
    methods: {
51
      ResidentOrgs(id) {
52
        this.$axios.get(httpUrl.hQuery.buttedOrgs.nopq, {
53
          pid: id,
54
          oid: this.dataO.bOid,
55
          time: this.dataO.bTime,
56
          rows: this.num ? this.num : this.rows
57
        }, (res) => {
58
          if (res.success) {
59
            var $info = res.data;
60
            if ($info.length > 0) {
61
              this.dataO.bOid = $info[$info.length - 1].id;
62
              this.dataO.bTime = $info[$info.length - 1].buttedTime;
63
              this.isFormSearch = true;
64
              this.orgData = this.orgData.concat($info);
65
            };
66
            if ($info.length < this.rows) {
67
              this.loadingModalShow = false;
68
              this.isFormSearch = false;
69
            };
70
          };
71
        });
72
      },
73
      orgLogoUrl(item) {
74
        return item.hasOrgLogo ? util.ImageUrl(('org/' + item.id + '.jpg'), true) : util.defaultSet.img.org;
75
      },
76
      loadLower() {
77
        if (this.loadingModalShow && !this.isLoading) {
78
          this.ResidentOrgs(this.platId);
79
        }
80
      }
81
    }
82
  };
83
</script>

+ 8 - 13
src/views/sub-component/BaseExpert.vue

@ -1,14 +1,14 @@
1 1
<template>
2 2
  <div>
3 3
    <div class="block-container">
4
      <a class="block-item" v-for="item in userData" :key="item.index" @click="linkUrl(item)">
4
      <router-link class="block-item" v-for="item in userData" :key="item.index" :to="'exp_show?id='+item.id" target="_blank">
5 5
        <div class="show-head" :style="{backgroundImage:'url('+ headUrl(item) +')'}"></div>
6 6
        <div class="show-info">
7 7
          <div class="info-tit">{{item.name}}<em class="authicon" :class="headIcon(item)"></em></div>
8 8
          <div class="info-tag" v-if="item.offt">{{item.offt}}</div>
9 9
          <div class="info-desc" v-if="item.reserachs">研究方向:{{item.reserachs}}</div>
10 10
        </div>
11
      </a>
11
      </router-link>
12 12
    </div>
13 13
    <Loading v-show="loadingModalShow" :loadingComplete="loadingComplete" :isLoading="isLoading" v-on:upup="loadLower" v-if="!num"></Loading>
14 14
  </div>
@ -47,13 +47,11 @@
47 47
    methods: {
48 48
      buttedProfessors(id) {
49 49
        this.$axios.get(httpUrl.hQuery.buttedProfessors.nopq, {
50
          params: {
51
            pid: id,
52
            uid: this.dataO.bUid,
53
            time: this.dataO.bTime,
54
            rows: this.num ? this.num : this.rows
55
          }
56
        }).then((res) => {
50
          pid: id,
51
          uid: this.dataO.bUid,
52
          time: this.dataO.bTime,
53
          rows: this.num ? this.num : this.rows
54
        }, (res) => {
57 55
          if (res.success) {
58 56
            var $data = res.data;
59 57
            if ($data.length > 0) {
@ -78,7 +76,7 @@
78 76
                    $data[i].offt = '';
79 77
                  }
80 78
                }
81
                this.$axios.get('/ajax/researchArea/' + $data[i].id).then(res => {
79
                this.$axios.get('/ajax/researchArea/' + $data[i].id, {}, (res) => {
82 80
                  const $info = res.data;
83 81
                  let arr = [];
84 82
                  for (let j = 0; j < $info.length; j++) {
@ -110,9 +108,6 @@
110 108
      headIcon(item) {
111 109
        return util.autho(item.authType, item.orgAuth, item.authStatus);
112 110
      },
113
      linkUrl(item) {
114
        this.$router.push({ path: 'expertShow', params: { id: item.id } });
115
      },
116 111
      loadLower() {
117 112
        if (this.loadingModalShow && !this.isLoading) {
118 113
          this.buttedProfessors(this.platId);

+ 5 - 5
src/views/sub-component/BaseResource.vue

@ -1,15 +1,15 @@
1 1
<template>
2
  <a class="list-item" :href="linkway" target="_blank">
2
  <router-link class="list-item" :to="'reso_show?id='+itemSingle.id" target="_blank">
3 3
    <div class="list-head" :style="{backgroundImage: 'url(' + imgUrl + ')'}"></div>
4 4
    <div class="list-info">
5 5
      <div class="list-tit list-topic">{{itemSingle.name}}</div>
6 6
      <div class="list-owner">{{ownerName}}<em class="authicon" :class="ownerAuth"></em></div>
7 7
      <div class="list-desc" v-if="itemSingle.cnt">用途:{{itemSingle.cnt}}</div>
8 8
    </div>
9
  </a>
9
  </router-link>
10 10
</template>
11 11
12
<script type="text/ecmascript-6">
12
<script>
13 13
  import util from '@/libs/util';
14 14
  import httpUrl from '@/libs/http';
15 15
@ -34,7 +34,7 @@
34 34
      ownerByond(item) {
35 35
        if (item.otype === '1') {
36 36
          this.$axios.get(httpUrl.kxQurey.professor.query + item.oid, {
37
            }).then((res) => {
37
            }, (res) => {
38 38
            if (res.success) {
39 39
              let $info = res.data;
40 40
              this.ownerName = $info.name;
@ -43,7 +43,7 @@
43 43
          });
44 44
        } else if (item.otype === '2') {
45 45
          this.$axios.get(httpUrl.kxQurey.org.query + item.oid, {
46
            }).then((res) => {
46
            }, (res) => {
47 47
            if (res.success) {
48 48
              let $info = res.data;
49 49
              this.ownerName = $info.forShort ? $info.forShort : $info.name;

+ 57 - 0
src/views/sub-component/BaseResult.vue

@ -0,0 +1,57 @@
1
<template>
2
  <router-link class="list-item" :to="'resu_patent?id='+itemSingle.id" target="_blank">
3
    <div class="list-head" :style="{backgroundImage: 'url(' + imgUrl + ')'}"></div>
4
    <div class="list-info">
5
      <div class="list-tit list-topic">{{itemSingle.name}}</div>
6
      <div class="list-owner">{{ownerName}}<em class="authicon" :class="ownerAuth"></em></div>
7
      <div class="list-desc" v-if="itemSingle.cnt">用途:{{itemSingle.cnt}}</div>
8
    </div>
9
  </router-link>
10
</template>
11
12
<script>
13
  import util from '@/libs/util';
14
  import httpUrl from '@/libs/http';
15
16
  export default {
17
    props: {
18
      itemSingle: {
19
        type: Object
20
      }
21
    },
22
    data() {
23
      return {
24
        linkway: util.defaultSet.link.resource + this.itemSingle.id,
25
        imgUrl: (this.itemSingle && this.itemSingle.images) ? util.ImageUrl('resource/' + this.itemSingle.images.split(',')[0]) : util.defaultSet.img.resource,
26
        ownerName: '',
27
        ownerAuth: ''
28
      };
29
    },
30
    created() {
31
      this.ownerByond(this.itemSingle);
32
    },
33
    methods: {
34
      ownerByond(item) {
35
        if (item.otype === '1') {
36
          this.$axios.get(httpUrl.kxQurey.professor.query + item.oid, {
37
            }, (res) => {
38
            if (res.success) {
39
              let $info = res.data;
40
              this.ownerName = $info.name;
41
              this.ownerAuth = util.autho($info.authType, $info.orgAuth, $info.authStatus);
42
            }
43
          });
44
        } else if (item.otype === '2') {
45
          this.$axios.get(httpUrl.kxQurey.org.query + item.oid, {
46
            }, (res) => {
47
            if (res.success) {
48
              let $info = res.data;
49
              this.ownerName = $info.forShort ? $info.forShort : $info.name;
50
              this.ownerAuth = $info.authStatus === '3' ? 'icon-com' : '';
51
            }
52
          });
53
        }
54
      }
55
    }
56
  };
57
</script>

+ 4 - 4
src/views/sub-component/BaseService.vue

@ -1,12 +1,12 @@
1 1
<template>
2
  <a class="list-item" :href="linkway" target="_blank">
2
  <router-link class="list-item" :to="'serve_show?id='+itemSingle.id" target="_blank">
3 3
    <div class="list-head" :style="{backgroundImage: 'url(' + imgUrl + ')'}"></div>
4 4
    <div class="list-info">
5 5
      <div class="list-tit list-topic">{{itemSingle.name}}</div>
6 6
      <div class="list-owner">{{ownerName}}<em class="authicon" :class="ownerAuth"></em></div>
7 7
      <div class="list-desc" v-if="itemSingle.cnt">内容:{{itemSingle.cnt}}</div>
8 8
    </div>
9
  </a>
9
  </router-link>
10 10
</template>
11 11
12 12
<script type="text/ecmascript-6">
@ -34,7 +34,7 @@
34 34
      ownerByond(item) {
35 35
        if (item.otype === '1') {
36 36
          this.$axios.get(httpUrl.kxQurey.professor.query + item.oid, {
37
            }).then((res) => {
37
            }, (res) => {
38 38
            if (res.success) {
39 39
              let $info = res.data;
40 40
              this.ownerName = $info.name;
@ -43,7 +43,7 @@
43 43
          });
44 44
        } else if (item.otype === '2') {
45 45
          this.$axios.get(httpUrl.kxQurey.org.query + item.oid, {
46
            }).then((res) => {
46
            }, (res) => {
47 47
            if (res.success) {
48 48
              let $info = res.data;
49 49
              this.ownerName = $info.forShort ? $info.forShort : $info.name;

+ 2 - 4
src/views/sub-component/DynamicTags.vue

@ -113,10 +113,8 @@
113 113
114 114
      querySearch(queryString, cb) {
115 115
        this.$axios.get(httpUrl.kxQurey.qaHotKey, {
116
          params: {
117
            key: queryString
118
          }
119
        }).then((res) => {
116
          key: queryString
117
        }, (res) => {
120 118
          if (res.success) {
121 119
            var $info = res.data;
122 120
            var oSr = [];

meeting-console - Gogs: Go Git Service

No Description

postgresql.sql 14KB

    -- 菜单 CREATE TABLE sys_menu ( menu_id bigserial, parent_id int8, name varchar(50), url varchar(200), perms varchar(500), type int, icon varchar(50), order_num int, PRIMARY KEY (menu_id) ); -- 系统用户 CREATE TABLE sys_user ( user_id bigserial, username varchar(50) NOT NULL, password varchar(100), salt varchar(20), email varchar(100), mobile varchar(100), status int, create_user_id int8, create_time timestamp, PRIMARY KEY (user_id), UNIQUE (username) ); -- 系统用户Token CREATE TABLE sys_user_token ( user_id bigserial, token varchar(100) NOT NULL, expire_time timestamp, update_time timestamp, PRIMARY KEY (user_id), UNIQUE (token) ); -- 系统验证码 CREATE TABLE sys_captcha ( uuid varchar(36) NOT NULL, code varchar(6) NOT NULL, expire_time timestamp, PRIMARY KEY (uuid) ); -- 角色 CREATE TABLE sys_role ( role_id bigserial, role_name varchar(100), remark varchar(100), create_user_id int8, create_time timestamp, PRIMARY KEY (role_id) ); -- 用户与角色对应关系 CREATE TABLE sys_user_role ( id bigserial, user_id int8, role_id int8, PRIMARY KEY (id) ); -- 角色与菜单对应关系 CREATE TABLE sys_role_menu ( id bigserial, role_id int8, menu_id int8, PRIMARY KEY (id) ); -- 系统配置信息 CREATE TABLE sys_config ( id bigserial, param_key varchar(50), param_value varchar(2000), status int DEFAULT 1, remark varchar(500), PRIMARY KEY (id), UNIQUE (param_key) ); -- 系统日志 CREATE TABLE sys_log ( id bigserial, username varchar(50), operation varchar(50), method varchar(200), params varchar(5000), time int8 NOT NULL, ip varchar(64), create_date timestamp, PRIMARY KEY (id) ); -- 文件上传 CREATE TABLE sys_oss ( id bigserial, url varchar(200), create_date timestamp, PRIMARY KEY (id) ); -- 定时任务 CREATE TABLE schedule_job ( job_id bigserial, bean_name varchar(200), params varchar(2000), cron_expression varchar(100), status int, remark varchar(255), create_time timestamp, PRIMARY KEY (job_id) ); -- 定时任务日志 CREATE TABLE schedule_job_log ( log_id bigserial, job_id int8 NOT NULL, bean_name varchar(200), params varchar(2000), status int NOT NULL, error varchar(2000), times int NOT NULL, create_time timestamp, PRIMARY KEY (log_id) ); CREATE INDEX index_job_id on schedule_job_log(job_id); -- 用户表 CREATE TABLE tb_user ( user_id bigserial, username varchar(50) NOT NULL, mobile varchar(20) NOT NULL, password varchar(64), create_time timestamp, PRIMARY KEY (user_id), UNIQUE (username) ); INSERT INTO sys_user (user_id, username, password, salt, email, mobile, status, create_user_id, create_time) VALUES ('1', 'admin', '9ec9750e709431dad22365cabc5c625482e574c74adaebba7dd02f1129e4ce1d', 'YzcmCZNvbXocrsz9dm8e', 'root@renren.io', '13612345678', '1', '1', '2016-11-11 11:11:11'); INSERT INTO sys_menu(menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (1, 0, '系统管理', NULL, NULL, 0, 'system', 0); INSERT INTO sys_menu(menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (2, 1, '管理员列表', 'sys/user', NULL, 1, 'admin', 1); INSERT INTO sys_menu(menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (3, 1, '角色管理', 'sys/role', NULL, 1, 'role', 2); INSERT INTO sys_menu(menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (4, 1, '菜单管理', 'sys/menu', NULL, 1, 'menu', 3); INSERT INTO sys_menu(menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (5, 1, 'SQL监控', 'http://localhost:8080/renren-fast/druid/sql.html', NULL, 1, 'sql', 4); INSERT INTO sys_menu(menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (6, 1, '定时任务', 'job/schedule', NULL, 1, 'job', 5); INSERT INTO sys_menu(menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (7, 6, '查看', NULL, 'sys:schedule:list,sys:schedule:info', 2, NULL, 0); INSERT INTO sys_menu(menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (8, 6, '新增', NULL, 'sys:schedule:save', 2, NULL, 0); INSERT INTO sys_menu(menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (9, 6, '修改', NULL, 'sys:schedule:update', 2, NULL, 0); INSERT INTO sys_menu(menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (10, 6, '删除', NULL, 'sys:schedule:delete', 2, NULL, 0); INSERT INTO sys_menu(menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (11, 6, '暂停', NULL, 'sys:schedule:pause', 2, NULL, 0); INSERT INTO sys_menu(menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (12, 6, '恢复', NULL, 'sys:schedule:resume', 2, NULL, 0); INSERT INTO sys_menu(menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (13, 6, '立即执行', NULL, 'sys:schedule:run', 2, NULL, 0); INSERT INTO sys_menu(menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (14, 6, '日志列表', NULL, 'sys:schedule:log', 2, NULL, 0); INSERT INTO sys_menu(menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (15, 2, '查看', NULL, 'sys:user:list,sys:user:info', 2, NULL, 0); INSERT INTO sys_menu(menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (16, 2, '新增', NULL, 'sys:user:save,sys:role:select', 2, NULL, 0); INSERT INTO sys_menu(menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (17, 2, '修改', NULL, 'sys:user:update,sys:role:select', 2, NULL, 0); INSERT INTO sys_menu(menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (18, 2, '删除', NULL, 'sys:user:delete', 2, NULL, 0); INSERT INTO sys_menu(menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (19, 3, '查看', NULL, 'sys:role:list,sys:role:info', 2, NULL, 0); INSERT INTO sys_menu(menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (20, 3, '新增', NULL, 'sys:role:save,sys:menu:list', 2, NULL, 0); INSERT INTO sys_menu(menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (21, 3, '修改', NULL, 'sys:role:update,sys:menu:list', 2, NULL, 0); INSERT INTO sys_menu(menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (22, 3, '删除', NULL, 'sys:role:delete', 2, NULL, 0); INSERT INTO sys_menu(menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (23, 4, '查看', NULL, 'sys:menu:list,sys:menu:info', 2, NULL, 0); INSERT INTO sys_menu(menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (24, 4, '新增', NULL, 'sys:menu:save,sys:menu:select', 2, NULL, 0); INSERT INTO sys_menu(menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (25, 4, '修改', NULL, 'sys:menu:update,sys:menu:select', 2, NULL, 0); INSERT INTO sys_menu(menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (26, 4, '删除', NULL, 'sys:menu:delete', 2, NULL, 0); INSERT INTO sys_menu(menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (27, 1, '参数管理', 'sys/config', 'sys:config:list,sys:config:info,sys:config:save,sys:config:update,sys:config:delete', 1, 'config', 6); INSERT INTO sys_menu(menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (29, 1, '系统日志', 'sys/log', 'sys:log:list', 1, 'log', 7); INSERT INTO sys_menu(menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (30, 1, '文件上传', 'oss/oss', 'sys:oss:all', 1, 'oss', 6); INSERT INTO sys_config (param_key, param_value, status, remark) VALUES ('CLOUD_STORAGE_CONFIG_KEY', '{"aliyunAccessKeyId":"","aliyunAccessKeySecret":"","aliyunBucketName":"","aliyunDomain":"","aliyunEndPoint":"","aliyunPrefix":"","qcloudBucketName":"","qcloudDomain":"","qcloudPrefix":"","qcloudSecretId":"","qcloudSecretKey":"","qiniuAccessKey":"NrgMfABZxWLo5B-YYSjoE8-AZ1EISdi1Z3ubLOeZ","qiniuBucketName":"ios-app","qiniuDomain":"http://7xlij2.com1.z0.glb.clouddn.com","qiniuPrefix":"upload","qiniuSecretKey":"uIwJHevMRWU0VLxFvgy0tAcOdGqasdtVlJkdy6vV","type":1}', '0', '云存储配置信息'); INSERT INTO schedule_job (bean_name, params, cron_expression, status, remark, create_time) VALUES ('testTask', 'renren', '0 0/30 * * * ?', '0', '参数测试', '2016-12-01 23:16:46'); -- 账号:13612345678 密码:admin INSERT INTO tb_user (username, mobile, password, create_time) VALUES ('mark', '13612345678', '8c6976e5b5410415bde908bd4dee15dfb167a9c873fc4bb8a81f6f2ab448a918', '2017-03-23 22:37:41'); alter sequence sys_menu_menu_id_seq restart with 31; alter sequence sys_user_user_id_seq restart with 2; -- quartz自带表结构 CREATE TABLE qrtz_job_details ( SCHED_NAME VARCHAR(120) NOT NULL, JOB_NAME VARCHAR(200) NOT NULL, JOB_GROUP VARCHAR(200) NOT NULL, DESCRIPTION VARCHAR(250) NULL, JOB_CLASS_NAME VARCHAR(250) NOT NULL, IS_DURABLE BOOL NOT NULL, IS_NONCONCURRENT BOOL NOT NULL, IS_UPDATE_DATA BOOL NOT NULL, REQUESTS_RECOVERY BOOL NOT NULL, JOB_DATA BYTEA NULL, PRIMARY KEY (SCHED_NAME,JOB_NAME,JOB_GROUP) ); CREATE TABLE qrtz_triggers ( SCHED_NAME VARCHAR(120) NOT NULL, TRIGGER_NAME VARCHAR(200) NOT NULL, TRIGGER_GROUP VARCHAR(200) NOT NULL, JOB_NAME VARCHAR(200) NOT NULL, JOB_GROUP VARCHAR(200) NOT NULL, DESCRIPTION VARCHAR(250) NULL, NEXT_FIRE_TIME BIGINT NULL, PREV_FIRE_TIME BIGINT NULL, PRIORITY INTEGER NULL, TRIGGER_STATE VARCHAR(16) NOT NULL, TRIGGER_TYPE VARCHAR(8) NOT NULL, START_TIME BIGINT NOT NULL, END_TIME BIGINT NULL, CALENDAR_NAME VARCHAR(200) NULL, MISFIRE_INSTR SMALLINT NULL, JOB_DATA BYTEA NULL, PRIMARY KEY (SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP), FOREIGN KEY (SCHED_NAME,JOB_NAME,JOB_GROUP) REFERENCES QRTZ_JOB_DETAILS(SCHED_NAME,JOB_NAME,JOB_GROUP) ); CREATE TABLE qrtz_simple_triggers ( SCHED_NAME VARCHAR(120) NOT NULL, TRIGGER_NAME VARCHAR(200) NOT NULL, TRIGGER_GROUP VARCHAR(200) NOT NULL, REPEAT_COUNT BIGINT NOT NULL, REPEAT_INTERVAL BIGINT NOT NULL, TIMES_TRIGGERED BIGINT NOT NULL, PRIMARY KEY (SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP), FOREIGN KEY (SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP) REFERENCES QRTZ_TRIGGERS(SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP) ); CREATE TABLE qrtz_cron_triggers ( SCHED_NAME VARCHAR(120) NOT NULL, TRIGGER_NAME VARCHAR(200) NOT NULL, TRIGGER_GROUP VARCHAR(200) NOT NULL, CRON_EXPRESSION VARCHAR(120) NOT NULL, TIME_ZONE_ID VARCHAR(80), PRIMARY KEY (SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP), FOREIGN KEY (SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP) REFERENCES QRTZ_TRIGGERS(SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP) ); CREATE TABLE qrtz_simprop_triggers ( SCHED_NAME VARCHAR(120) NOT NULL, TRIGGER_NAME VARCHAR(200) NOT NULL, TRIGGER_GROUP VARCHAR(200) NOT NULL, STR_PROP_1 VARCHAR(512) NULL, STR_PROP_2 VARCHAR(512) NULL, STR_PROP_3 VARCHAR(512) NULL, INT_PROP_1 INT NULL, INT_PROP_2 INT NULL, LONG_PROP_1 BIGINT NULL, LONG_PROP_2 BIGINT NULL, DEC_PROP_1 NUMERIC(13,4) NULL, DEC_PROP_2 NUMERIC(13,4) NULL, BOOL_PROP_1 BOOL NULL, BOOL_PROP_2 BOOL NULL, PRIMARY KEY (SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP), FOREIGN KEY (SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP) REFERENCES QRTZ_TRIGGERS(SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP) ); CREATE TABLE qrtz_blob_triggers ( SCHED_NAME VARCHAR(120) NOT NULL, TRIGGER_NAME VARCHAR(200) NOT NULL, TRIGGER_GROUP VARCHAR(200) NOT NULL, BLOB_DATA BYTEA NULL, PRIMARY KEY (SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP), FOREIGN KEY (SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP) REFERENCES QRTZ_TRIGGERS(SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP) ); CREATE TABLE qrtz_calendars ( SCHED_NAME VARCHAR(120) NOT NULL, CALENDAR_NAME VARCHAR(200) NOT NULL, CALENDAR BYTEA NOT NULL, PRIMARY KEY (SCHED_NAME,CALENDAR_NAME) ); CREATE TABLE qrtz_paused_trigger_grps ( SCHED_NAME VARCHAR(120) NOT NULL, TRIGGER_GROUP VARCHAR(200) NOT NULL, PRIMARY KEY (SCHED_NAME,TRIGGER_GROUP) ); CREATE TABLE qrtz_fired_triggers ( SCHED_NAME VARCHAR(120) NOT NULL, ENTRY_ID VARCHAR(95) NOT NULL, TRIGGER_NAME VARCHAR(200) NOT NULL, TRIGGER_GROUP VARCHAR(200) NOT NULL, INSTANCE_NAME VARCHAR(200) NOT NULL, FIRED_TIME BIGINT NOT NULL, SCHED_TIME BIGINT NOT NULL, PRIORITY INTEGER NOT NULL, STATE VARCHAR(16) NOT NULL, JOB_NAME VARCHAR(200) NULL, JOB_GROUP VARCHAR(200) NULL, IS_NONCONCURRENT BOOL NULL, REQUESTS_RECOVERY BOOL NULL, PRIMARY KEY (SCHED_NAME,ENTRY_ID) ); CREATE TABLE qrtz_scheduler_state ( SCHED_NAME VARCHAR(120) NOT NULL, INSTANCE_NAME VARCHAR(200) NOT NULL, LAST_CHECKIN_TIME BIGINT NOT NULL, CHECKIN_INTERVAL BIGINT NOT NULL, PRIMARY KEY (SCHED_NAME,INSTANCE_NAME) ); CREATE TABLE qrtz_locks ( SCHED_NAME VARCHAR(120) NOT NULL, LOCK_NAME VARCHAR(40) NOT NULL, PRIMARY KEY (SCHED_NAME,LOCK_NAME) ); create index idx_qrtz_j_req_recovery on qrtz_job_details(SCHED_NAME,REQUESTS_RECOVERY); create index idx_qrtz_j_grp on qrtz_job_details(SCHED_NAME,JOB_GROUP); create index idx_qrtz_t_j on qrtz_triggers(SCHED_NAME,JOB_NAME,JOB_GROUP); create index idx_qrtz_t_jg on qrtz_triggers(SCHED_NAME,JOB_GROUP); create index idx_qrtz_t_c on qrtz_triggers(SCHED_NAME,CALENDAR_NAME); create index idx_qrtz_t_g on qrtz_triggers(SCHED_NAME,TRIGGER_GROUP); create index idx_qrtz_t_state on qrtz_triggers(SCHED_NAME,TRIGGER_STATE); create index idx_qrtz_t_n_state on qrtz_triggers(SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP,TRIGGER_STATE); create index idx_qrtz_t_n_g_state on qrtz_triggers(SCHED_NAME,TRIGGER_GROUP,TRIGGER_STATE); create index idx_qrtz_t_next_fire_time on qrtz_triggers(SCHED_NAME,NEXT_FIRE_TIME); create index idx_qrtz_t_nft_st on qrtz_triggers(SCHED_NAME,TRIGGER_STATE,NEXT_FIRE_TIME); create index idx_qrtz_t_nft_misfire on qrtz_triggers(SCHED_NAME,MISFIRE_INSTR,NEXT_FIRE_TIME); create index idx_qrtz_t_nft_st_misfire on qrtz_triggers(SCHED_NAME,MISFIRE_INSTR,NEXT_FIRE_TIME,TRIGGER_STATE); create index idx_qrtz_t_nft_st_misfire_grp on qrtz_triggers(SCHED_NAME,MISFIRE_INSTR,NEXT_FIRE_TIME,TRIGGER_GROUP,TRIGGER_STATE); create index idx_qrtz_ft_trig_inst_name on qrtz_fired_triggers(SCHED_NAME,INSTANCE_NAME); create index idx_qrtz_ft_inst_job_req_rcvry on qrtz_fired_triggers(SCHED_NAME,INSTANCE_NAME,REQUESTS_RECOVERY); create index idx_qrtz_ft_j_g on qrtz_fired_triggers(SCHED_NAME,JOB_NAME,JOB_GROUP); create index idx_qrtz_ft_jg on qrtz_fired_triggers(SCHED_NAME,JOB_GROUP); create index idx_qrtz_ft_t_g on qrtz_fired_triggers(SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP); create index idx_qrtz_ft_tg on qrtz_fired_triggers(SCHED_NAME,TRIGGER_GROUP); commit;