接入产品cms
Showing
4 changed files
with
121 additions
and
67 deletions
... | @@ -80,6 +80,7 @@ module.exports = { | ... | @@ -80,6 +80,7 @@ module.exports = { |
80 | newsList : "/pingan_hklife_webapi/cms/news/list", | 80 | newsList : "/pingan_hklife_webapi/cms/news/list", |
81 | newsDetail : "/pingan_hklife_webapi/cms/news/get", | 81 | newsDetail : "/pingan_hklife_webapi/cms/news/get", |
82 | companyOutline : "/pingan_hklife_webapi/cms/company/outline", | 82 | companyOutline : "/pingan_hklife_webapi/cms/company/outline", |
83 | productInfo : "/pingan_hklife_webapi/cms/product", | ||
83 | 84 | ||
84 | config : "/pingan_hklife_webapi/config" | 85 | config : "/pingan_hklife_webapi/config" |
85 | } | 86 | } |
... | \ No newline at end of file | ... | \ No newline at end of file | ... | ... |
... | @@ -23,17 +23,17 @@ export default { | ... | @@ -23,17 +23,17 @@ export default { |
23 | loading: false, | 23 | loading: false, |
24 | showTips: false, | 24 | showTips: false, |
25 | data: { | 25 | data: { |
26 | firstName: "玛丽", | 26 | // firstName: "玛丽", |
27 | lastName: "何", | 27 | // lastName: "何", |
28 | birthDate: "1999-07-15", | 28 | // birthDate: "1999-07-15", |
29 | idNo: "H4099030", | 29 | // idNo: "H4099030", |
30 | idType: "40" | 30 | // idType: "40" |
31 | 31 | ||
32 | // firstName: "", | 32 | firstName: "", |
33 | // lastName: "", | 33 | lastName: "", |
34 | // birthDate: "", | 34 | birthDate: "", |
35 | // idNo: "", | 35 | idNo: "", |
36 | // idType: "" | 36 | idType: "" |
37 | } | 37 | } |
38 | } | 38 | } |
39 | }, | 39 | }, | ... | ... |
... | @@ -37,6 +37,10 @@ export default { | ... | @@ -37,6 +37,10 @@ export default { |
37 | playerOptions: {}, | 37 | playerOptions: {}, |
38 | bannerTipsVisible: true, | 38 | bannerTipsVisible: true, |
39 | productList: [], | 39 | productList: [], |
40 | // 全部的信息 | ||
41 | sourceData: {}, | ||
42 | bottomBtnType: "", | ||
43 | bottomBtnLink: "" | ||
40 | } | 44 | } |
41 | }, | 45 | }, |
42 | components: {}, | 46 | components: {}, |
... | @@ -59,54 +63,59 @@ export default { | ... | @@ -59,54 +63,59 @@ export default { |
59 | onHideBannerTipsHandler() { | 63 | onHideBannerTipsHandler() { |
60 | this.bannerTipsVisible = false; | 64 | this.bannerTipsVisible = false; |
61 | }, | 65 | }, |
62 | 66 | // fetchBanner() { | |
63 | fetchBanner() { | 67 | // return new Promise((resolve, reject) => { |
64 | return new Promise((resolve, reject) => { | 68 | // httpPost({ |
65 | httpPost({ | 69 | // url: api.banner |
66 | url: api.banner | 70 | // }).then(res => { |
67 | }).then(res => { | 71 | // resolve(res); |
68 | resolve(res); | 72 | // }); |
69 | }); | 73 | // }); |
70 | }); | 74 | // }, |
71 | }, | 75 | // fetchIndexVideo() { |
72 | fetchIndexVideo() { | 76 | // return new Promise((resolve, reject) => { |
73 | return new Promise((resolve, reject) => { | 77 | // httpPost({ |
74 | httpPost({ | 78 | // url: api.indexVideo |
75 | url: api.indexVideo | 79 | // }).then(res => { |
76 | }).then(res => { | 80 | // sessionStorage.setItem("_video_url", res.videoUrl); |
77 | sessionStorage.setItem("_video_url", res.videoUrl); | 81 | // sessionStorage.setItem("_poster_url", res.posterUrl); |
78 | sessionStorage.setItem("_poster_url", res.posterUrl); | 82 | // resolve(res); |
79 | resolve(res); | 83 | // }); |
80 | }); | 84 | // }); |
81 | }); | 85 | // }, |
86 | bottomBtnHandle() { | ||
87 | this.btnNavigateTo(this.bottomBtnType, this.bottomBtnLink); | ||
82 | }, | 88 | }, |
83 | refreshBanner() { | 89 | btnNavigateTo(type, link) { |
84 | let key = this.locale; | 90 | switch (type) { |
85 | if (key == "zh") { | 91 | case "none": |
86 | key = "cn"; | 92 | break; |
93 | case "news": | ||
94 | this.$router.push({ | ||
95 | path: "/news/detail", | ||
96 | query: { | ||
97 | c: link | ||
98 | } | ||
99 | }); | ||
100 | break; | ||
101 | case "product": | ||
102 | break; | ||
103 | case "vhis": | ||
104 | this.$router.push({ | ||
105 | path: "/vhis", | ||
106 | query: { | ||
107 | p: link | ||
108 | } | ||
109 | }); | ||
110 | break; | ||
111 | default: | ||
112 | location.href = link; | ||
113 | break; | ||
87 | } | 114 | } |
88 | let bannerList = []; | ||
89 | this.bannerCandidateList.forEach(element => { | ||
90 | bannerList.push(element[key]); | ||
91 | }); | ||
92 | |||
93 | bannerList = [{ | ||
94 | pcBannerUrl: "@/assets/images/vhis/kv.png", | ||
95 | mobileBannerUrl: "@/assets/images/vhis/kv.png", | ||
96 | btns: [{ | ||
97 | n: "立即報價", | ||
98 | c: "#f05a23", | ||
99 | t: "vhis", | ||
100 | l: "endowment", | ||
101 | }] | ||
102 | }] | ||
103 | |||
104 | this.$set(this, 'bannerList', bannerList); | ||
105 | console.log("bannerList:", bannerList); | ||
106 | }, | 115 | }, |
107 | refreshVideoPlayer() { | 116 | refreshVideoPlayer(videoUrl, posterUrl) { |
108 | let videoUrl = sessionStorage.getItem("_video_url"); | 117 | // let videoUrl = sessionStorage.getItem("_video_url"); |
109 | let posterUrl = sessionStorage.getItem("_poster_url"); | 118 | // let posterUrl = sessionStorage.getItem("_poster_url"); |
110 | let playerOptions = { | 119 | let playerOptions = { |
111 | width: 800, | 120 | width: 800, |
112 | height: 450, | 121 | height: 450, |
... | @@ -157,19 +166,63 @@ export default { | ... | @@ -157,19 +166,63 @@ export default { |
157 | }, | 166 | }, |
158 | initData() { | 167 | initData() { |
159 | this.initProduct(); | 168 | this.initProduct(); |
160 | this.fetchBanner().then(res => { | 169 | let targetData = null; |
161 | this.bannerCandidateList = res; | 170 | switch (this.locale) { |
162 | this.refreshBanner(); | 171 | case "zh": |
163 | }); | 172 | targetData = this.sourceData.confCn; |
164 | this.fetchIndexVideo().then(res => { | 173 | break; |
165 | this.refreshVideoPlayer(); | 174 | case "en": |
166 | }); | 175 | targetData = this.sourceData.confEn; |
176 | break; | ||
177 | case "tc": | ||
178 | targetData = this.sourceData.confTc; | ||
179 | break; | ||
180 | } | ||
181 | if (targetData) { | ||
182 | let bannerList = [{ | ||
183 | pcBannerUrl: targetData.pcBannerUrl, | ||
184 | mobileBannerUrl: targetData.mobileBannerUrl, | ||
185 | btns: targetData.btnDescribe | ||
186 | }]; | ||
187 | this.$set(this, 'bannerList', bannerList); | ||
188 | console.log(this.bannerList); | ||
189 | |||
190 | this.refreshVideoPlayer(targetData.videoUrl, targetData.videoPlayer); | ||
191 | // 设置标题 | ||
192 | document.title = targetData.productName; | ||
193 | |||
194 | this.bottomBtnType = targetData.bottomUrlType; | ||
195 | this.bottomBtnLink = targetData.bottomUrlLink; | ||
196 | } | ||
197 | // this.fetchBanner().then(res => { | ||
198 | // this.bannerCandidateList = res; | ||
199 | // this.refreshBanner(); | ||
200 | // }); | ||
201 | // this.fetchIndexVideo().then(res => { | ||
202 | // this.refreshVideoPlayer(); | ||
203 | // }); | ||
167 | }, | 204 | }, |
205 | initActivity() { | ||
206 | let d = localStorage.getItem("voluntaryInfo"); | ||
207 | if (d) { | ||
208 | try { | ||
209 | this.sourceData = JSON.parse(d); | ||
210 | this.initData(); | ||
211 | } catch (e) { | ||
212 | } | ||
213 | } | ||
214 | } | ||
168 | }, | 215 | }, |
169 | mounted() { | 216 | mounted() { |
170 | this.initData(); | 217 | this.initActivity(); |
171 | }, | 218 | }, |
172 | created() { | 219 | created() { |
173 | 220 | httpGet({ url: api.productInfo, data: { code: "voluntary" } }).then(res => { | |
221 | if (res) { | ||
222 | localStorage.setItem("voluntaryInfo", JSON.stringify(res)); | ||
223 | this.sourceData = res; | ||
224 | } | ||
225 | this.initData(); | ||
226 | }) | ||
174 | } | 227 | } |
175 | } | 228 | } | ... | ... |
... | @@ -7,8 +7,8 @@ | ... | @@ -7,8 +7,8 @@ |
7 | <div class="banner banner-pc"> | 7 | <div class="banner banner-pc"> |
8 | <swiper :options="swiperOption"> | 8 | <swiper :options="swiperOption"> |
9 | <swiper-slide v-for="(item,index) in bannerList" :key="index"> | 9 | <swiper-slide v-for="(item,index) in bannerList" :key="index"> |
10 | <!-- <img class="banner-img" :src="item.pcBannerUrl"> --> | 10 | <img class="banner-img" :src="item.pcBannerUrl"> |
11 | <img :src="require('@/assets/images/vhis/kv.png')"> | 11 | <!-- <img :src="require('@/assets/images/vhis/kv.png')"> --> |
12 | <div class="btn-wrap"> | 12 | <div class="btn-wrap"> |
13 | <div v-for="(btnItem, btnIndex) in item.btns" :key="btnIndex"> | 13 | <div v-for="(btnItem, btnIndex) in item.btns" :key="btnIndex"> |
14 | <div class="banner-btn" v-if="btnItem.n && btnItem.t && btnItem.c" @click="btnNavigateTo(btnItem.t,btnItem.l)" :style="{backgroundColor:btnItem.c}">{{btnItem.n}}</div> | 14 | <div class="banner-btn" v-if="btnItem.n && btnItem.t && btnItem.c" @click="btnNavigateTo(btnItem.t,btnItem.l)" :style="{backgroundColor:btnItem.c}">{{btnItem.n}}</div> |
... | @@ -166,7 +166,7 @@ | ... | @@ -166,7 +166,7 @@ |
166 | </div> | 166 | </div> |
167 | 167 | ||
168 | <!-- 立即投保 --> | 168 | <!-- 立即投保 --> |
169 | <div class="submit-btn"> | 169 | <div class="submit-btn" @click="bottomBtnHandle()"> |
170 | 立即投保 | 170 | 立即投保 |
171 | </div> | 171 | </div> |
172 | 172 | ... | ... |
-
Please register or sign in to post a comment