Authored by 徐炜

Merge branch 'release/4.9.1.0'

@@ -7,6 +7,7 @@ const queryString = require('querystring'); @@ -7,6 +7,7 @@ const queryString = require('querystring');
7 const Promise = require('bluebird'); 7 const Promise = require('bluebird');
8 const co = Promise.coroutine; 8 const co = Promise.coroutine;
9 const headerModel = require('../../../doraemon/models/header'); // 头部model 9 const headerModel = require('../../../doraemon/models/header'); // 头部model
  10 +const _ = require('lodash');
10 11
11 12
12 const getResource = code => { 13 const getResource = code => {
@@ -91,20 +92,34 @@ const getPlatForm = (req) => { @@ -91,20 +92,34 @@ const getPlatForm = (req) => {
91 let userAgent = req.get('User-Agent'); 92 let userAgent = req.get('User-Agent');
92 let yoho = {}; 93 let yoho = {};
93 let uids = req.get('User-Agent').match(/uid=([^;]+)/i); 94 let uids = req.get('User-Agent').match(/uid=([^;]+)/i);
  95 + let versions = req.get('User-Agent').match(/app_version=([^;]+)/i);
94 let arrs = []; 96 let arrs = [];
95 - let version = false; 97 + let isNewVersion = false;
96 const isProduction = process.env.NODE_ENV === 'production'; 98 const isProduction = process.env.NODE_ENV === 'production';
97 99
98 yoho.isiOS = /\(i[^;]+;( U;)? CPU.+Mac OS X/i.test(userAgent); 100 yoho.isiOS = /\(i[^;]+;( U;)? CPU.+Mac OS X/i.test(userAgent);
99 yoho.isAndroid = /Android/i.test(userAgent); 101 yoho.isAndroid = /Android/i.test(userAgent);
100 yoho.isApp = /YohoBuy/i.test(req.get('User-Agent')) || (req.query.app_version && req.query.client_type); 102 yoho.isApp = /YohoBuy/i.test(req.get('User-Agent')) || (req.query.app_version && req.query.client_type);
101 - if (req.query.app_version) {  
102 - arrs = req.query.app_version.split('.');  
103 - version = arrs.length > 2 && Number(arrs.slice(0, 2).join('') + arrs[2].slice(0, 1)) > 490;  
104 - }  
105 103
  104 + yoho.app_version = versions && versions.length === 2 ? versions[1] : '';
  105 + yoho.app_version = yoho.app_version || req.query.app_version || '';
  106 + if (yoho.app_version) {
  107 + yoho.app_version = _.toString(yoho.app_version);
  108 + arrs = yoho.app_version.split('.');
  109 + if (arrs.length > 2) {
  110 + if (arrs[0] && +arrs[0] < 4) {
  111 + isNewVersion = false;
  112 + } else if (arrs[1] && +arrs[1] < 9) {
  113 + isNewVersion = false;
  114 + } else if (arrs[2] && +arrs[2] <= 0) {
  115 + isNewVersion = false;
  116 + } else {
  117 + isNewVersion = true;
  118 + }
  119 + }
  120 + }
106 121
107 - yoho.isSupportStudent = !yoho.isApp || version; 122 + yoho.isSupportStudent = !yoho.isApp || isNewVersion;
108 yoho.http = 'http:'; 123 yoho.http = 'http:';
109 if (isProduction) { 124 if (isProduction) {
110 yoho.http = 'https:'; 125 yoho.http = 'https:';
@@ -117,37 +132,19 @@ const getPlatForm = (req) => { @@ -117,37 +132,19 @@ const getPlatForm = (req) => {
117 132
118 yoho.isStudent = data.data && data.data.vip_info && data.data.vip_info.is_student ? true : false; 133 yoho.isStudent = data.data && data.data.vip_info && data.data.vip_info.is_student ? true : false;
119 134
120 - // console.log(yoho); 135 + // yoho.isStudent = false;
121 return yoho; 136 return yoho;
122 })(); 137 })();
123 138
124 139
125 }; 140 };
126 141
127 -// const getRequest = (url)=>{  
128 -//  
129 -// let regurl = /^[^\?]+\?([\w\W]+)$/;  
130 -// let regpara = /([^&=]+)=([\w\W]*?)(&|$|#)/g;  
131 -// let ret = {};  
132 -// let strpara,  
133 -// result;  
134 -//  
135 -// let arrurl = regurl.exec(url);  
136 -//  
137 -// if (arrurl && arrurl[1]) {  
138 -// strpara = arrurl[1];  
139 -// while ((result = regpara.exec(strpara)) !== null) {  
140 -// ret[result[1]] = result[2];  
141 -// }  
142 -// }  
143 -// return ret;  
144 -// };  
145 -  
146 142
147 exports.index = (req, res, next) => { 143 exports.index = (req, res, next) => {
148 let code = 'a83b7d55324fb65f96c1f85a3387ebd8'; 144 let code = 'a83b7d55324fb65f96c1f85a3387ebd8';
149 let uid = req.__USER__.uid; 145 let uid = req.__USER__.uid;
150 let options; 146 let options;
  147 + let noLoginUrl = helpers.urlFormat('/activity/student/register') + '?openby:yohobuy={"action":"go.weblogin","params":{"jumpurl":{"url":"' + req.__USER__.http + '//m.yohobuy.com/activity/student"}}}';
151 148
152 149
153 150
@@ -185,25 +182,16 @@ exports.index = (req, res, next) => { @@ -185,25 +182,16 @@ exports.index = (req, res, next) => {
185 } 182 }
186 }); 183 });
187 if (coupons && coupons.data) { 184 if (coupons && coupons.data) {
188 - coupons.link = link && link.data ? link.data[0].url + (req.__USER__.isApp ? '&app_version=1' : '') : ''; 185 + coupons.link = link && link.data ? link.data[0].url + (req.__USER__.isApp ? '&app_version=' + req.__USER__.app_version : '') : '';
189 coupons.data = (coupons.data || []).map((item) => { 186 coupons.data = (coupons.data || []).map((item) => {
  187 + // let url = item.image.url;
190 couponids.push(item.couponID); 188 couponids.push(item.couponID);
191 189
192 - if (!req.__USER__.isLogin) {  
193 - item.image.url = 'http://m.yohobuy.com/activity/student/register?openby:yohobuy={"action":"go.weblogin","params":{"jumpurl":{"url":"http://m.yohobuy.com/activity/student"}}}';  
194 - }  
195 -  
196 - // if (item.image.url.indexOf('?') === -1) {  
197 - // item.image.url += '?'; 190 + // if (!req.__USER__.isLogin) {
  191 + // url = 'http://m.yohobuy.com/activity/student/register?openby:yohobuy={"action":"go.weblogin","params":{"jumpurl":{"url":"http://m.yohobuy.com/activity/student"}}}';
198 // } 192 // }
199 // 193 //
200 - //  
201 - // url = item.image.url.substring(0, item.image.url.indexOf('?'));  
202 - //  
203 - // param = JSON.stringify(getRequest(item.image.url));  
204 - // item.image.url = item.image.url + '&app_version=1&openby:yohobuy={"action":"go.h5","params":{"islogin":"N","url":"' + url + '","param":' + param + '}}';  
205 -  
206 - // console.log(item); 194 + // item.image.noLoginUrl=url;
207 return item; 195 return item;
208 }); 196 });
209 } 197 }
@@ -242,7 +230,10 @@ exports.index = (req, res, next) => { @@ -242,7 +230,10 @@ exports.index = (req, res, next) => {
242 isLogin: req.__USER__.isLogin, 230 isLogin: req.__USER__.isLogin,
243 title: '有货学生专享优惠', 231 title: '有货学生专享优惠',
244 http: req.__USER__.http, 232 http: req.__USER__.http,
245 - uid: req.__USER__.uid 233 + uid: req.__USER__.uid,
  234 + app_version: req.__USER__.app_version,
  235 + isAppNoLogin: req.__USER__.isApp && !req.__USER__.isLogin,
  236 + noLoginUrl: noLoginUrl
246 }; 237 };
247 if (!req.__USER__.isApp) { 238 if (!req.__USER__.isApp) {
248 options.pageHeader = headerModel.setNav({ 239 options.pageHeader = headerModel.setNav({
@@ -261,7 +252,7 @@ exports.index = (req, res, next) => { @@ -261,7 +252,7 @@ exports.index = (req, res, next) => {
261 } 252 }
262 } else { 253 } else {
263 // no login 254 // no login
264 - options.loginUrl = options.loginUrl + '?openby:yohobuy={"action":"go.weblogin","params":{"jumpurl":{"url":"' + req.__USER__.http + '//m.yohobuy.com/activity/student/register"}}}'; 255 + options.loginUrl = options.loginUrl + '?openby:yohobuy={"action":"go.weblogin","params":{"jumpurl":{"url":"' + req.__USER__.http + '//m.yohobuy.com/activity/student/register","antarget":"1"}}}';
265 } 256 }
266 } else { 257 } else {
267 if (options.isLogin) { 258 if (options.isLogin) {
@@ -350,15 +341,20 @@ exports.verifystudent = (req, res, next) => { @@ -350,15 +341,20 @@ exports.verifystudent = (req, res, next) => {
350 Promise.all([verifiedStudentTotal(), vip(), verifyStudent(uid, params.college_name, params.education_degree, params.enrollment_year, params.token)]) 341 Promise.all([verifiedStudentTotal(), vip(), verifyStudent(uid, params.college_name, params.education_degree, params.enrollment_year, params.token)])
351 .then((datas) => { 342 .then((datas) => {
352 let isverify = false, 343 let isverify = false,
353 - prompt = '你的学校信息未通审核'; 344 + prompt = '您的学校信息未通过审核';
354 345
355 if (datas[2].code === 200) { 346 if (datas[2].code === 200) {
356 - if (datas[2].data.isStudent === 1) {  
357 - isverify = true;  
358 - prompt = datas[2].data.prompt; 347 + if (datas[2].code === 200) {
  348 + if (datas[2].data.isStudent === 1) {
  349 + isverify = true;
  350 + prompt = datas[2].data.prompt;
  351 + }
  352 + } else {
  353 + prompt = datas[2].message;
359 } 354 }
  355 +
360 } else { 356 } else {
361 - prompt = datas[2].message; 357 + prompt = '认证失败';
362 } 358 }
363 datas[1].data.product_list = datas[1].data.product_list.map(function(value) { 359 datas[1].data.product_list = datas[1].data.product_list.map(function(value) {
364 value.goodsId = value.goods_list[0].goods_id; 360 value.goodsId = value.goods_list[0].goods_id;
@@ -375,7 +371,8 @@ exports.verifystudent = (req, res, next) => { @@ -375,7 +371,8 @@ exports.verifystudent = (req, res, next) => {
375 isLogin: user.data && user.data.vip_info && user.data.vip_info.is_student ? true : false, 371 isLogin: user.data && user.data.vip_info && user.data.vip_info.is_student ? true : false,
376 title: '学生身份认证', 372 title: '学生身份认证',
377 http: req.__USER__.http, 373 http: req.__USER__.http,
378 - uid: req.__USER__.uid 374 + uid: req.__USER__.uid,
  375 + app_version: req.__USER__.app_version
379 }); 376 });
380 }).catch(next); 377 }).catch(next);
381 378
@@ -37,27 +37,44 @@ @@ -37,27 +37,44 @@
37 {{#each data}} 37 {{#each data}}
38 <div class="coupon-floor" coupon-id="{{couponID}}"> 38 <div class="coupon-floor" coupon-id="{{couponID}}">
39 <div class="floor-main" style="background-image: url({{image image.src 0 0}});"> 39 <div class="floor-main" style="background-image: url({{image image.src 0 0}});">
40 - <a href='{{image.url}}' class="main-left"></a>  
41 - <a href='{{image.url}}' class="main-right-use" > 40 + <a href='{{image.url}}' class="main-left"></a>
42 {{#isEqual status 1}} 41 {{#isEqual status 1}}
43 - <span class="on-receive on-lingqu no-bg">  
44 - <p>点击</p>  
45 - <p>领取</p>  
46 - </span> 42 + {{#if @root.isAppNoLogin}}
  43 + <a href='{{@root.noLoginUrl}}' class="main-right-use" >
  44 + <span class="on-receive on-lingqu no-bg">
  45 + <p>点击</p>
  46 + <p>领取</p>
  47 + </span>
  48 + </a>
  49 + {{else}}
  50 + <div class="main-right-use" href='{{../image.url}}'>
  51 + <span class="on-receive on-lingqu no-bg">
  52 + <p>点击</p>
  53 + <p>领取</p>
  54 + </span>
  55 + </div>
  56 +
  57 + {{/if}}
47 {{/isEqual}} 58 {{/isEqual}}
  59 +
48 {{#isEqual status 2}} 60 {{#isEqual status 2}}
  61 + <a href='{{../image.url}}' class="main-right-use" >
49 <span class="zero"></span> 62 <span class="zero"></span>
  63 + </a>
50 {{/isEqual}} 64 {{/isEqual}}
51 {{#isEqual status 3}} 65 {{#isEqual status 3}}
  66 + <a href='{{../image.url}}' class="main-right-use" >
52 <span class="received"></span> 67 <span class="received"></span>
  68 + </a>
53 {{/isEqual}} 69 {{/isEqual}}
54 {{#isEqual status 4}} 70 {{#isEqual status 4}}
  71 + <a href='{{../image.url}}' class="main-right-use" >
55 <span class="on-receive no-bg" > 72 <span class="on-receive no-bg" >
56 <p>已经</p> 73 <p>已经</p>
57 <p>过期</p> 74 <p>过期</p>
58 </span> 75 </span>
  76 + </a>
59 {{/isEqual}} 77 {{/isEqual}}
60 - </a>  
61 </div> 78 </div>
62 </div> 79 </div>
63 {{/each}} 80 {{/each}}
@@ -77,7 +94,7 @@ @@ -77,7 +94,7 @@
77 {{/activities}} 94 {{/activities}}
78 95
79 <section class='s-section clearfix'> 96 <section class='s-section clearfix'>
80 - <h1>学生专享商品<a class="more iconfont" href="//search.m.yohobuy.com/?students=1&title=学生专享商品&uid={{uid}}{{#isApp}}&app_version=1{{/isApp}}">&#xe618;</a></h1> 97 + <h1>学生专享商品<a class="more iconfont" href="//search.m.yohobuy.com/?students=1&title=学生专享商品&uid={{uid}}{{#isApp}}&app_version={{@root.app_version}}{{/isApp}}">&#xe618;</a></h1>
81 <div class='goods-list clearfix'> 98 <div class='goods-list clearfix'>
82 {{#each goods}} 99 {{#each goods}}
83 <div class="good-info"> 100 <div class="good-info">
@@ -110,7 +127,7 @@ @@ -110,7 +127,7 @@
110 <a href="{{url}}">{{product_name}}</a> 127 <a href="{{url}}">{{product_name}}</a>
111 </div> 128 </div>
112 <div class="price"> 129 <div class="price">
113 - <span class="sale-price">¥{{round student_price}} <i class='s-biaoqian'>学生价</i></span> 130 + <span class="sale-price">¥{{round student_price}} <a class='s-biaoqian'>学生价</a></span>
114 <p class="s-price-block"> 131 <p class="s-price-block">
115 <span class="market-price">¥{{round market_price}}</span> 132 <span class="market-price">¥{{round market_price}}</span>
116 </p> 133 </p>
@@ -119,7 +136,7 @@ @@ -119,7 +136,7 @@
119 </div> 136 </div>
120 {{/each}} 137 {{/each}}
121 </div> 138 </div>
122 - <a class='s-more' href='//search.m.yohobuy.com/?students=1&title=学生专享商品&uid={{uid}}{{#isApp}}&app_version=1{{/isApp}}'>查看更多</a> 139 + <a class='s-more' href='//search.m.yohobuy.com/?students=1&title=学生专享商品&uid={{uid}}{{#isApp}}&app_version={{@root.app_version}}{{/isApp}}'>查看更多</a>
123 </section> 140 </section>
124 141
125 {{#loginUrl}} 142 {{#loginUrl}}
@@ -16,11 +16,11 @@ @@ -16,11 +16,11 @@
16 <section class='s-section clearfix'> 16 <section class='s-section clearfix'>
17 <div class='s-verify-img s-verify-fail'></div> 17 <div class='s-verify-img s-verify-fail'></div>
18 <p class='s-verify-title'>太遗憾了,{{./prompt}}</p> 18 <p class='s-verify-title'>太遗憾了,{{./prompt}}</p>
19 - <p class='s-verify-txt'>可以<a class='red' href='//m.yohobuy.com/activity/student/register'>重新验证 ></a></p> 19 + <p class='s-verify-txt'>可以<a class='red' href='//m.yohobuy.com/activity/student/register'>重新验证 ></a></p>
20 </section> 20 </section>
21 {{/if}} 21 {{/if}}
22 <section class='s-section clearfix'> 22 <section class='s-section clearfix'>
23 - <h1>学生专享商品<a class="more iconfont" href="//search.m.yohobuy.com/?students=1&title=学生专享商品&uid={{uid}}{{#isApp}}&app_version=1{{/isApp}}">&#xe618;</a></h1> 23 + <h1>学生专享商品<a class="more iconfont" href="//search.m.yohobuy.com/?students=1&title=学生专享商品&uid={{uid}}{{#isApp}}&app_version={{@root.app_version}}{{/isApp}}">&#xe618;</a></h1>
24 <div class='goods-list clearfix'> 24 <div class='goods-list clearfix'>
25 {{#each goods}} 25 {{#each goods}}
26 <div class="good-info"> 26 <div class="good-info">
@@ -62,7 +62,7 @@ @@ -62,7 +62,7 @@
62 </div> 62 </div>
63 {{/each}} 63 {{/each}}
64 </div> 64 </div>
65 - <a class='s-more' href="//search.m.yohobuy.com/?students=1&title=学生专享商品{{#isApp}}&app_version=1{{/isApp}}">查看更多</a> 65 + <a class='s-more' href="//search.m.yohobuy.com/?students=1&title=学生专享商品{{#isApp}}&app_version={{@root.app_version}}{{/isApp}}">查看更多</a>
66 </section> 66 </section>
67 </div> 67 </div>
68 </div> 68 </div>
@@ -37,6 +37,7 @@ exports.index = (req, res, next) => { @@ -37,6 +37,7 @@ exports.index = (req, res, next) => {
37 res.render('plusstar/index', Object.assign({ 37 res.render('plusstar/index', Object.assign({
38 page: 'plusstar-index', 38 page: 'plusstar-index',
39 result: result, 39 result: result,
  40 + isApp: isApp,
40 title: title 41 title: title
41 }, parameter)); 42 }, parameter));
42 }).catch(next); 43 }).catch(next);
@@ -95,7 +95,7 @@ const getResources = (params, options) => { @@ -95,7 +95,7 @@ const getResources = (params, options) => {
95 } 95 }
96 96
97 break; 97 break;
98 - case 'title_image': 98 + case 'title_image' :
99 if (typeof data[res.template_name] === 'undefined') { 99 if (typeof data[res.template_name] === 'undefined') {
100 data[res.template_name] = []; 100 data[res.template_name] = [];
101 } 101 }
@@ -12,6 +12,10 @@ @@ -12,6 +12,10 @@
12 {{/if}} 12 {{/if}}
13 <!--/tab-nav--> 13 <!--/tab-nav-->
14 14
  15 + {{#if isApp}}
  16 + <div class='empty-height'></div>
  17 + {{/if}}
  18 +
15 <div class="plusstar-resources"> 19 <div class="plusstar-resources">
16 <!--资源位数据模板--> 20 <!--资源位数据模板-->
17 </div><!--/plusstar-resources--> 21 </div><!--/plusstar-resources-->
1 -<div class='installment-help'> 1 +<div class='installment-help installment-agreement'>
2 <div class='content help-title'>有货分期-信而富用户服务协议</div> 2 <div class='content help-title'>有货分期-信而富用户服务协议</div>
  3 + <br />
3 <div class='help-group'> 4 <div class='help-group'>
4 <h2>【特别提示】</h2> 5 <h2>【特别提示】</h2>
5 <p> 6 <p>
@@ -76,10 +77,17 @@ @@ -76,10 +77,17 @@
76 </p> 77 </p>
77 <p> 78 <p>
78 3.2您了解并同意,确保平台账户及密码的机密安全是用户的责任,您将对利用用户账户及密码所进行的一切行动及言论负完全的责任,并同意以下事项: 79 3.2您了解并同意,确保平台账户及密码的机密安全是用户的责任,您将对利用用户账户及密码所进行的一切行动及言论负完全的责任,并同意以下事项:
79 - (1)您不对其他任何人泄露账户及密码,亦不可使用其他任何人的账户或密码;因黑客、病毒或您的保管疏忽等非信而富过错导致个人账户及密码遭他人非法使用的,信而富不承担任何责任;  
80 - (2)信而富通过您的账户及密码来识别您的指令和操作,您同意并确认,使用账户及密码登录后在本平台的一切行为均代表您本人的使用,账户操作所产生的电子信息记录均为您个人行为的有效凭证,并由您本人承担由此产生的全部责任;  
81 - (3)冒用他人账户及密码的,信而富及合法授权主体保留追究实际使用人责任的权利;  
82 - (4)信而富提示您创建一个安全密码,避免选择过于简单或明显的单词或日期,比如您的姓名、昵称或者生日等。 80 + <span class='indent2'>
  81 + (1)您不对其他任何人泄露账户及密码,亦不可使用其他任何人的账户或密码;因黑客、病毒或您的保管疏忽等非信而富过错导致个人账户及密码遭他人非法使用的,信而富不承担任何责任;<br />
  82 + </span>
  83 + <span class='indent2'>
  84 + (2)信而富通过您的账户及密码来识别您的指令和操作,您同意并确认,使用账户及密码登录后在本平台的一切行为均代表您本人的使用,账户操作所产生的电子信息记录均为您个人行为的有效凭证,并由您本人承担由此产生的全部责任;</span>
  85 + <span class='indent2'>
  86 + (3)冒用他人账户及密码的,信而富及合法授权主体保留追究实际使用人责任的权利;
  87 + </span>
  88 + <span class='indent2'>
  89 + (4)信而富提示您创建一个安全密码,避免选择过于简单或明显的单词或日期,比如您的姓名、昵称或者生日等。
  90 + </span>
83 </p> 91 </p>
84 <p> 92 <p>
85 3.3您完成申请注册手续后,获得本平台账户的使用权,该使用权仅属于初始申请注册人。您禁止赠与、借用、租用、转让或售卖平台账户。您若发现有第三人冒用或盗用您的用户账户及密码,或其他任何未经合法授权的情形,应立即以有效方式通知信而富,要求信而富暂停相关服务,否则由此产生的一切责任由您本人承担。同时您理解信而富对您的请求采取行动需要合理期限,信而富对第三人使用该服务所导致的损失不承担任何责任。 93 3.3您完成申请注册手续后,获得本平台账户的使用权,该使用权仅属于初始申请注册人。您禁止赠与、借用、租用、转让或售卖平台账户。您若发现有第三人冒用或盗用您的用户账户及密码,或其他任何未经合法授权的情形,应立即以有效方式通知信而富,要求信而富暂停相关服务,否则由此产生的一切责任由您本人承担。同时您理解信而富对您的请求采取行动需要合理期限,信而富对第三人使用该服务所导致的损失不承担任何责任。
@@ -95,13 +103,28 @@ @@ -95,13 +103,28 @@
95 </p> 103 </p>
96 <p class='underline bold'> 104 <p class='underline bold'>
97 3.7信而富有权基于单方独立判断,在其认为可能发生危害交易安全或用户违反本平台规则等情形时,有权不经通知而暂停、中断或终止向您提供的本协议项下的全部或部分服务,并有权视情况单方决定将用户注册资料移除或删除,且无需对用户或任何第三方承担任何责任。前述情形包括但不限于: 105 3.7信而富有权基于单方独立判断,在其认为可能发生危害交易安全或用户违反本平台规则等情形时,有权不经通知而暂停、中断或终止向您提供的本协议项下的全部或部分服务,并有权视情况单方决定将用户注册资料移除或删除,且无需对用户或任何第三方承担任何责任。前述情形包括但不限于:
98 - (1)信而富认为用户提供的个人资料不具有真实性、有效性或完整性;  
99 - (2)信而富发现异常交易或有疑义或有违法之可能时;  
100 - (3)信而富认为用户已经违反相关法律法规或本协议中规定的各类规则及精神;  
101 - (4)用户在使用本平台收费服务时未按规定向相关方支付相应的平台服务费用或第三方服务费用;  
102 - (5)用户账户已连续三年内未实际使用且账户中余额为零;  
103 - (6)信而富按照法律规定或主管部门的要求;  
104 - (7)出于安全的原因或其他必要的情形。 106 + <span class='indent2'>
  107 + (1)信而富认为用户提供的个人资料不具有真实性、有效性或完整性;
  108 + </span>
  109 + <span class='indent2'>
  110 + (2)信而富发现异常交易或有疑义或有违法之可能时;
  111 + </span>
  112 + <span class='indent2'>
  113 + (3)信而富认为用户已经违反相关法律法规或本协议中规定的各类规则及精神;
  114 + </span>
  115 + <span class='indent2'>
  116 + (4)用户在使用本平台收费服务时未按规定向相关方支付相应的平台服务费用或第三方服务费用;
  117 + </span>
  118 + <span class='indent2'>
  119 + (5)用户账户已连续三年内未实际使用且账户中余额为零;
  120 + </span>
  121 + <span class='indent2'>
  122 + (6)信而富按照法律规定或主管部门的要求;
  123 + </span>
  124 + <span class='indent2'>
  125 + (7)出于安全的原因或其他必要的情形。
  126 + </span>
  127 + </ul>
105 </p> 128 </p>
106 <p> 129 <p>
107 3.8用户同意,用户账户的暂停、中断或终止不代表用户责任的终止,用户仍应对使用本平台服务期间的行为承担可能的违约或损害赔偿责任,同时信而富仍可保有用户的相关信息。 130 3.8用户同意,用户账户的暂停、中断或终止不代表用户责任的终止,用户仍应对使用本平台服务期间的行为承担可能的违约或损害赔偿责任,同时信而富仍可保有用户的相关信息。
@@ -121,21 +144,37 @@ @@ -121,21 +144,37 @@
121 </p> 144 </p>
122 <p> 145 <p>
123 4.4 您确认知晓并同意,信而富可将您的信息用于: 146 4.4 您确认知晓并同意,信而富可将您的信息用于:
124 - (1)信而富向您及时发送重要通知,如软件更新、本协议条款的变更;  
125 - (2)信而富内部进行审计、数据分析和研究等,以改进信而富的产品、服务和与您之间的沟通;  
126 - (3)依本协议约定,信而富管理、审查您的信息及进行处理措施;  
127 - (4)信而富为提供本协议项下服务而必需的其他用途;  
128 - (5)法律法规所要求的其他用途。 147 + <span class='indent2'>
  148 + (1)信而富向您及时发送重要通知,如软件更新、本协议条款的变更;
  149 + </span>
  150 + <span class='indent2'>
  151 + (2)信而富内部进行审计、数据分析和研究等,以改进信而富的产品、服务和与您之间的沟通;
  152 + </span>
  153 + <span class='indent2'>
  154 + (3)依本协议约定,信而富管理、审查您的信息及进行处理措施;
  155 + </span>
  156 + <span class='indent2'>
  157 + (4)信而富为提供本协议项下服务而必需的其他用途;
  158 + </span>
  159 + <span class='indent2'>
  160 + (5)法律法规所要求的其他用途。
  161 + </span>
129 </p> 162 </p>
130 <p> 163 <p>
131 4.5信而富将运用各种安全技术和程序建立完善的管理制度来保护您的个人信息,以免遭受未经授权的访问、使用或披露。但对于因您个人原因、因黑客攻击、电脑病毒侵入及其它不可抗力事件、或其它非信而富原因导致的个人信息的泄露和损失,信而富不承担任何责任。 164 4.5信而富将运用各种安全技术和程序建立完善的管理制度来保护您的个人信息,以免遭受未经授权的访问、使用或披露。但对于因您个人原因、因黑客攻击、电脑病毒侵入及其它不可抗力事件、或其它非信而富原因导致的个人信息的泄露和损失,信而富不承担任何责任。
132 </p> 165 </p>
133 <p> 166 <p>
134 4.6 为本协议之目的,您特此同意授权信而富指定的公司在发生与您有关的下列任一情形时,可以通过中国人民银行个人信息基础数据库或/及其他征信系统或/及与征信相关的第三方数据库(以下统称“征信数据库”)查询您的个人信用信息(个人信用信息包括与您有关的基本信息、信贷信息或与本人信用直接或间接相关的其他各项信息),并通过征信数据库对该等个人信用信息进行各项识别、验证和筛查: 167 4.6 为本协议之目的,您特此同意授权信而富指定的公司在发生与您有关的下列任一情形时,可以通过中国人民银行个人信息基础数据库或/及其他征信系统或/及与征信相关的第三方数据库(以下统称“征信数据库”)查询您的个人信用信息(个人信用信息包括与您有关的基本信息、信贷信息或与本人信用直接或间接相关的其他各项信息),并通过征信数据库对该等个人信用信息进行各项识别、验证和筛查:
135 - (1)涉及您的个人借款申请;  
136 - (2)涉及您的个人担保事宜;  
137 - (3)对您名下已发生的个人借款或个人担保进行风险管理及后续信息跟踪管理。 168 + <span class='indent2'>
  169 + (1)涉及您的个人借款申请;
  170 + </span>
  171 + <span class='indent2'>
  172 + (2)涉及您的个人担保事宜;
  173 + </span>
  174 + <span class='indent2'>
  175 + (3)对您名下已发生的个人借款或个人担保进行风险管理及后续信息跟踪管理。
138 同时授权信而富指定的公司将您的个人信用信息向包括中国人民银行信息基础数据库在内的征信数据库报送。 176 同时授权信而富指定的公司将您的个人信用信息向包括中国人民银行信息基础数据库在内的征信数据库报送。
  177 + </span>
139 </p> 178 </p>
140 </div> 179 </div>
141 180
@@ -168,12 +207,24 @@ @@ -168,12 +207,24 @@
168 </p> 207 </p>
169 <p> 208 <p>
170 6.4除非信而富书面许可,您不得从事下列任一行为,否则信而富将保留追究您责任的权利: 209 6.4除非信而富书面许可,您不得从事下列任一行为,否则信而富将保留追究您责任的权利:
171 - (1)删除软件及其副本上关于著作权的信息;  
172 - (2)对软件进行反向工程、反向汇编、反向编译,或者以其他方式尝试发现软件的源代码;  
173 - (3)对信而富拥有知识产权的内容进行使用、出租、出借、复制、修改、链接、转载、汇编、发表、出版、建立镜像站点等;  
174 - (4)对软件或者软件运行过程中释放到任何终端内存中的数据、软件运行过程中客户端与服务器端的交互数据,以及软件运行所必需的系统数据,进行复制、修改、增加、删除、挂接运行或创作任何衍生作品,形式包括但不限于使用插件、外挂或非经信而富授权的第三方工具/服务接入软件和相关系统;  
175 - (5)通过修改或伪造软件运行中的指令、数据,增加、删减、变动软件的功能或运行效果,或者将用于上述用途的软件、方法进行运营或向公众传播,无论这些行为是否为商业目的;  
176 - (6)通过非信而富开发、授权的第三方软件、插件、外挂、系统,登录或使用信而富软件及服务,或制作、发布、传播非信而富开发、授权的第三方软件、插件、外挂、系统。 210 + <span class='indent2'>
  211 + (1)删除软件及其副本上关于著作权的信息;
  212 + </span>
  213 + <span class='indent2'>
  214 + (2)对软件进行反向工程、反向汇编、反向编译,或者以其他方式尝试发现软件的源代码;
  215 + </span>
  216 + <span class='indent2'>
  217 + (3)对信而富拥有知识产权的内容进行使用、出租、出借、复制、修改、链接、转载、汇编、发表、出版、建立镜像站点等;
  218 + </span>
  219 + <span class='indent2'>
  220 + (4)对软件或者软件运行过程中释放到任何终端内存中的数据、软件运行过程中客户端与服务器端的交互数据,以及软件运行所必需的系统数据,进行复制、修改、增加、删除、挂接运行或创作任何衍生作品,形式包括但不限于使用插件、外挂或非经信而富授权的第三方工具/服务接入软件和相关系统;
  221 + </span>
  222 + <span class='indent2'>
  223 + (5)通过修改或伪造软件运行中的指令、数据,增加、删减、变动软件的功能或运行效果,或者将用于上述用途的软件、方法进行运营或向公众传播,无论这些行为是否为商业目的;
  224 + </span>
  225 + <span class='indent2'>
  226 + (6)通过非信而富开发、授权的第三方软件、插件、外挂、系统,登录或使用信而富软件及服务,或制作、发布、传播非信而富开发、授权的第三方软件、插件、外挂、系统。
  227 + </span>
177 </p> 228 </p>
178 </div> 229 </div>
179 230
@@ -200,13 +251,27 @@ @@ -200,13 +251,27 @@
200 <h2>八、【用户的守法义务】</h2> 251 <h2>八、【用户的守法义务】</h2>
201 <p> 252 <p>
202 8.1您在使用平台服务时须遵守法律法规以及公序良俗,不得利用平台服务从事违法违规行为,包括但不限于: 253 8.1您在使用平台服务时须遵守法律法规以及公序良俗,不得利用平台服务从事违法违规行为,包括但不限于:
203 - (1)发布、传送、传播、储存危害国家安全统一、破坏社会稳定、违反公序良俗、侮辱、诽谤、淫秽、暴力以及任何违反国家法律法规的内容;  
204 - (2)发布、传送、传播、储存侵害他人知识产权、商业秘密等合法权利的内容;  
205 - (3)提交、发布虚假信息,或盗用他人头像或资料,冒充、利用他人名义,恶意虚构事实、隐瞒真相以误导、欺骗他人;  
206 - (4)发布、传送、传播广告信息及垃圾信息;  
207 - (5)侵害他人名誉、隐私权、商业秘密、商标权、著作权、专利权、其它知识产权及其它权益;  
208 - (6)从事任何不法交易行为;  
209 - (7)其他法律法规禁止或信而富有正当理由认为不适当的行为。 254 + <span class='indent2'>
  255 + (1)发布、传送、传播、储存危害国家安全统一、破坏社会稳定、违反公序良俗、侮辱、诽谤、淫秽、暴力以及任何违反国家法律法规的内容;
  256 + </span>
  257 + <span class='indent2'>
  258 + (2)发布、传送、传播、储存侵害他人知识产权、商业秘密等合法权利的内容;
  259 + </span>
  260 + <span class='indent2'>
  261 + (3)提交、发布虚假信息,或盗用他人头像或资料,冒充、利用他人名义,恶意虚构事实、隐瞒真相以误导、欺骗他人;
  262 + </span>
  263 + <span class='indent2'>
  264 + (4)发布、传送、传播广告信息及垃圾信息;
  265 + </span>
  266 + <span class='indent2'>
  267 + (5)侵害他人名誉、隐私权、商业秘密、商标权、著作权、专利权、其它知识产权及其它权益;
  268 + </span>
  269 + <span class='indent2'>
  270 + (6)从事任何不法交易行为;
  271 + </span>
  272 + <span class='indent2'>
  273 + (7)其他法律法规禁止或信而富有正当理由认为不适当的行为。
  274 + </span>
210 </p> 275 </p>
211 <p> 276 <p>
212 8.2如果您违反了本条约定,相关国家机关或机构可能会对您提起诉讼、罚款或采取其他制裁措施,并要求信而富给予协助,造成损害的,您应依法予以赔偿,信而富不承担任何责任。 277 8.2如果您违反了本条约定,相关国家机关或机构可能会对您提起诉讼、罚款或采取其他制裁措施,并要求信而富给予协助,造成损害的,您应依法予以赔偿,信而富不承担任何责任。
@@ -226,18 +291,36 @@ @@ -226,18 +291,36 @@
226 </p> 291 </p>
227 <p class='bold'> 292 <p class='bold'>
228 9.2 在法律允许的范围内,信而富对以下情形导致的服务中断、受阻,数据丢失以及其他的损失和风险不承担责任: 293 9.2 在法律允许的范围内,信而富对以下情形导致的服务中断、受阻,数据丢失以及其他的损失和风险不承担责任:
229 - (1)受到计算机病毒、木马或其他恶意程序、黑客攻击的破坏;  
230 - (2)您或信而富的电脑软件、系统、硬件和通信线路出现故障;  
231 - (3)您自身责任所导致的损失或风险(例如您未按照本协议或本平台不时公布的任何规则进行操作;您向本平台发送的指令信息不明确、或存在歧义、不完整等;您账户内余额不足);  
232 - (4)第三方(包括但不限于银行、第三方支付机构等)服务瑕疵;  
233 - (5)您通过非信而富授权的方式使用本服务;  
234 - (6)其他信而富无法控制或合理预见的情形。 294 + <span class='indent2'>
  295 + (1)受到计算机病毒、木马或其他恶意程序、黑客攻击的破坏;
  296 + </span>
  297 + <span class='indent2'>
  298 + (2)您或信而富的电脑软件、系统、硬件和通信线路出现故障;
  299 + </span>
  300 + <span class='indent2'>
  301 + (3)您自身责任所导致的损失或风险(例如您未按照本协议或本平台不时公布的任何规则进行操作;您向本平台发送的指令信息不明确、或存在歧义、不完整等;您账户内余额不足);
  302 + </span>
  303 + <span class='indent2'>
  304 + (4)第三方(包括但不限于银行、第三方支付机构等)服务瑕疵;
  305 + </span>
  306 + <span class='indent2'>
  307 + (5)您通过非信而富授权的方式使用本服务;
  308 + </span>
  309 + <span class='indent2'>
  310 + (6)其他信而富无法控制或合理预见的情形。
  311 + </span>
235 </p> 312 </p>
236 <p> 313 <p>
237 9.3 您理解并同意,在使用本服务的过程中,可能会遇到网络信息或其他您行为带来的风险,信而富不对任何信息的真实性、适用性、合法性承担责任,也不对因侵权行为给您造成的损害负责。这些风险包括但不限于: 314 9.3 您理解并同意,在使用本服务的过程中,可能会遇到网络信息或其他您行为带来的风险,信而富不对任何信息的真实性、适用性、合法性承担责任,也不对因侵权行为给您造成的损害负责。这些风险包括但不限于:
238 - (1)来自他人匿名或冒名的含有威胁、诽谤、令人反感或非法内容的信息;  
239 - (2)因使用本协议项下的服务,遭受他人误导、欺骗或其他导致或可能导致的任何心理、生理上的伤害以及经济上的损失;  
240 - (3)其他因网络信息或您行为引起的风险。 315 + <span class='indent2'>
  316 + (1)来自他人匿名或冒名的含有威胁、诽谤、令人反感或非法内容的信息;
  317 + </span>
  318 + <span class='indent2'>
  319 + (2)因使用本协议项下的服务,遭受他人误导、欺骗或其他导致或可能导致的任何心理、生理上的伤害以及经济上的损失;
  320 + </span>
  321 + <span class='indent2'>
  322 + (3)其他因网络信息或您行为引起的风险。
  323 + </span>
241 </p> 324 </p>
242 <p> 325 <p>
243 9.4 信而富无法也没有义务保证用户在发出借款要约后,能够实际获得借款,用户因前述原因而遭受的损失信而富不承担责任。 326 9.4 信而富无法也没有义务保证用户在发出借款要约后,能够实际获得借款,用户因前述原因而遭受的损失信而富不承担责任。
@@ -264,9 +347,6 @@ @@ -264,9 +347,6 @@
264 <p> 347 <p>
265 10.4本协议条款无论因何种原因部分无效或不可执行,其余条款仍有效,对双方具有约束力。 348 10.4本协议条款无论因何种原因部分无效或不可执行,其余条款仍有效,对双方具有约束力。
266 </p> 349 </p>
267 - <p>  
268 - (正文完)  
269 - </p>  
270 </div> 350 </div>
271 </div> 351 </div>
272 352
1 <div class='installment-help'> 1 <div class='installment-help'>
2 - <div class='content help-title'>分期支付帮助中心</div>  
3 <div class='help-group'> 2 <div class='help-group'>
4 <h2>一、有货分期介绍</h2> 3 <h2>一、有货分期介绍</h2>
5 <p> 4 <p>
@@ -45,7 +45,8 @@ const dist = { @@ -45,7 +45,8 @@ const dist = {
45 const postcssPlugin = (et) => { 45 const postcssPlugin = (et) => {
46 var sprites = { 46 var sprites = {
47 spritesmith: { 47 spritesmith: {
48 - padding: 8 48 + // 不能设置过小,否则有边缘会有问题
  49 + padding: 20
49 }, 50 },
50 filterBy(file) { 51 filterBy(file) {
51 // base64 的图片没有 url 过滤掉 52 // base64 的图片没有 url 过滤掉
@@ -60,6 +61,7 @@ const postcssPlugin = (et) => { @@ -60,6 +61,7 @@ const postcssPlugin = (et) => {
60 group = group === '' ? 'yo' : group; 61 group = group === '' ? 'yo' : group;
61 62
62 file.retina = true; 63 file.retina = true;
  64 + file.radio = 2;
63 65
64 return group ? Promise.resolve(group) : Promise.reject(group); 66 return group ? Promise.resolve(group) : Promise.reject(group);
65 } 67 }

36.6 KB | W: | H:

29.6 KB | W: | H:

  • 2-up
  • Swipe
  • Onion skin

7.36 KB | W: | H:

7.42 KB | W: | H:

  • 2-up
  • Swipe
  • Onion skin

47.4 KB | W: | H:

48 KB | W: | H:

  • 2-up
  • Swipe
  • Onion skin

2.52 KB | W: | H:

2.55 KB | W: | H:

  • 2-up
  • Swipe
  • Onion skin
@@ -478,6 +478,7 @@ AsideSlider.prototype._bindAsideSlider = function($initialator, $slider) { @@ -478,6 +478,7 @@ AsideSlider.prototype._bindAsideSlider = function($initialator, $slider) {
478 } 478 }
479 if (isShow) { 479 if (isShow) {
480 this.isFirst=true; 480 this.isFirst=true;
  481 + $('input').blur();
481 this.asideSlideIn($slider); 482 this.asideSlideIn($slider);
482 } else { 483 } else {
483 tip.show('请先选择省份'); 484 tip.show('请先选择省份');
@@ -411,7 +411,7 @@ $(document).on('click', '.s-submit', function() { @@ -411,7 +411,7 @@ $(document).on('click', '.s-submit', function() {
411 C_ID: C_ID, 411 C_ID: C_ID,
412 SRC_ID: 5, 412 SRC_ID: 5,
413 SUBMIT_RES: 1 413 SUBMIT_RES: 1
414 - }, false); 414 + }, true);
415 } 415 }
416 416
417 location.href = data.data; 417 location.href = data.data;
@@ -62,9 +62,11 @@ function getUrlParam(name) { @@ -62,9 +62,11 @@ function getUrlParam(name) {
62 62
63 63
64 64
65 -$('.on-lingqu').on('click', function() { 65 +$('.on-lingqu', 'div.main-right-use').on('click', function() {
66 var $curDom = $(this), 66 var $curDom = $(this),
67 - req = ''; 67 + req = '',
  68 + href = '',
  69 + a = '';
68 70
69 if (getUrlParam('app_version')) { 71 if (getUrlParam('app_version')) {
70 req += '&app_version=' + getUrlParam('app_version'); 72 req += '&app_version=' + getUrlParam('app_version');
@@ -73,6 +75,8 @@ $('.on-lingqu').on('click', function() { @@ -73,6 +75,8 @@ $('.on-lingqu').on('click', function() {
73 if (getUrlParam('uid')) { 75 if (getUrlParam('uid')) {
74 req += '&uid=' + getUrlParam('uid'); 76 req += '&uid=' + getUrlParam('uid');
75 } 77 }
  78 +
  79 +
76 if (!$curDom.hasClass('received')) { 80 if (!$curDom.hasClass('received')) {
77 $.ajax({ 81 $.ajax({
78 url: '//m.yohobuy.com/coupon/receiveCoupon?code=a83b7d55324fb65f96c1f85a3387ebd8' + req, 82 url: '//m.yohobuy.com/coupon/receiveCoupon?code=a83b7d55324fb65f96c1f85a3387ebd8' + req,
@@ -93,8 +97,11 @@ $('.on-lingqu').on('click', function() { @@ -93,8 +97,11 @@ $('.on-lingqu').on('click', function() {
93 location.href = newUrl; 97 location.href = newUrl;
94 } else { 98 } else {
95 if (status) { 99 if (status) {
96 - $curDom.html('').removeClass('on-receive').removeClass('no-bg');  
97 - $curDom.addClass('received'); 100 + href = $curDom.parent('.main-right-use').attr('href');
  101 + $curDom.parent('.main-right-use').wrap('<a class=\'main-right-use\' href=' + href + '></a>');
  102 + a = $curDom.parent('.main-right-use').parent('a');
  103 + a.html('<span class="received"></span>');
  104 +
98 tip.show('领券成功'); 105 tip.show('领券成功');
99 } else { 106 } else {
100 tip.show(msg); 107 tip.show(msg);
@@ -266,18 +273,21 @@ $('.s-activity', '.s-section').click(function() { @@ -266,18 +273,21 @@ $('.s-activity', '.s-section').click(function() {
266 }); 273 });
267 $('.good-info', '.goods-list').click(function() { 274 $('.good-info', '.goods-list').click(function() {
268 var options; 275 var options;
269 - var url = $(this).find('.good-detail-img').find('.good-thumb').attr('href');  
270 - var index = $(this).index();  
271 - var tid = $(this).parents('.s-section').data('template-id'); 276 +
  277 + // var url = $(this).find('.good-detail-img').find('.good-thumb').attr('href');
  278 + // var index = $(this).index();
  279 + // var tid = $(this).parents('.s-section').data('template-id');
  280 + var index = $(this).index;
  281 + var goodids = $(this).find('.good-thumb').attr('href').match(/"product_skn":([^}]+)/, 'g');
  282 + var goodid = goodids && goodids.length === 2 ? goodids[1] : '';
272 283
273 options = { 284 options = {
274 - EVENT: 'YB_STUDENT_VIP_FLR',  
275 - C_ID: C_ID,  
276 - F_ID: tid || 4,  
277 - F_NAME: '学生专享专区',  
278 - F_URL: url,  
279 - F_INDEX: 4,  
280 - I_INDEX: index 285 + EVENT: 'YB_STUDENT_VIP_GDS_LIST',
  286 + PRD_NUM: index,
  287 + PRD_ID: goodid,
  288 + ACTION_ID: 0,
  289 + SORT_TYPE: 4,
  290 + REC_ID: Date.now()
281 }; 291 };
282 if (window._yas && window._yas.sendCustomInfo) { 292 if (window._yas && window._yas.sendCustomInfo) {
283 window._yas.sendCustomInfo(options, true); 293 window._yas.sendCustomInfo(options, true);
@@ -10,7 +10,9 @@ var plusstar = {}, @@ -10,7 +10,9 @@ var plusstar = {},
10 require('../common'); 10 require('../common');
11 11
12 plusstar = { 12 plusstar = {
13 - scrollObj: {}, 13 + common: {
  14 + codeDefault: ''
  15 + },
14 init: function() { 16 init: function() {
15 var that = this, 17 var that = this,
16 $liDom, 18 $liDom,
@@ -18,6 +20,13 @@ plusstar = { @@ -18,6 +20,13 @@ plusstar = {
18 20
19 $tabUlDom = $('.plusstar-page .tab-nav ul'); 21 $tabUlDom = $('.plusstar-page .tab-nav ul');
20 22
  23 + // 重置tab code位置
  24 + if (window.localStorage) {
  25 + $tabUlDom.find('li').each(function() {
  26 + localStorage.setItem($(this).data('code'), 0);
  27 + });
  28 + }
  29 +
21 $tabUlDom.find('li').css({ 30 $tabUlDom.find('li').css({
22 width: 100 / $tabUlDom.find('li').length + '%' 31 width: 100 / $tabUlDom.find('li').length + '%'
23 }); 32 });
@@ -50,13 +59,10 @@ plusstar = { @@ -50,13 +59,10 @@ plusstar = {
50 tabNav: function(code) { 59 tabNav: function(code) {
51 var that = this; 60 var that = this;
52 61
53 - if (typeof this.scrollObj[code] === 'undefined') {  
54 - // 如果不是第一次点击,回顶部  
55 - $(document).scrollTop(0);  
56 - this.scrollObj[code] = true;  
57 - } 62 + this.common.codeDefault = code;// 记住最后一次的tab code
58 63
59 loading.showLoadingMask(); 64 loading.showLoadingMask();
  65 +
60 $.ajax({ 66 $.ajax({
61 type: 'GET', 67 type: 'GET',
62 url: '/guang/plusstar/resources-template', 68 url: '/guang/plusstar/resources-template',
@@ -86,6 +92,11 @@ plusstar = { @@ -86,6 +92,11 @@ plusstar = {
86 } 92 }
87 }); 93 });
88 }, 40); 94 }, 40);
  95 +
  96 + // 设置滚动条的位置
  97 + if (window.localStorage) {
  98 + $(document).scrollTop(localStorage.getItem(code) || 0);
  99 + }
89 }, 100 },
90 error: function() { 101 error: function() {
91 tip.show('网络断开连接了~'); 102 tip.show('网络断开连接了~');
@@ -111,10 +122,24 @@ plusstar = { @@ -111,10 +122,24 @@ plusstar = {
111 }; 122 };
112 123
113 $(function() { 124 $(function() {
114 - if ($footer.length > 0) {  
115 - $footer.before( 125 +
  126 + if (!(window.queryString.app_version || window.queryString.appVersion)) {
  127 + $('.tab-nav').css({
  128 + position: 'absolute'
  129 + });
  130 +
  131 + $footer.css({
  132 + 'max-width': '650px'
  133 + }).before(
116 '<div style="height: ' + parseInt($footer.css('height'), 0) + 'px"></div>' 134 '<div style="height: ' + parseInt($footer.css('height'), 0) + 'px"></div>'
117 ); 135 );
118 } 136 }
  137 +
119 plusstar.init(); 138 plusstar.init();
  139 +
  140 + if (window.localStorage) {
  141 + $(document).scroll(function() {
  142 + localStorage.setItem(plusstar.common.codeDefault, $(this).scrollTop());
  143 + });
  144 + }
120 }); 145 });
@@ -410,6 +410,9 @@ @@ -410,6 +410,9 @@
410 410
411 input { 411 input {
412 border: 0 none; 412 border: 0 none;
  413 + padding: 12px 0;
  414 + height: 60px;
  415 + line-height: 60px;
413 } 416 }
414 417
415 .s-red { 418 .s-red {
@@ -56,13 +56,13 @@ @@ -56,13 +56,13 @@
56 display: inline-block; 56 display: inline-block;
57 width: 52px; 57 width: 52px;
58 height: 54px; 58 height: 54px;
59 - background-image: url('/channel/click-txt.png'); 59 + background-image: url("/channel/click-txt.png");
60 } 60 }
61 61
62 &.received { 62 &.received {
63 width: 113px; 63 width: 113px;
64 - height: 132px;  
65 - background-image: url('/channel/received.png'); 64 + height: 140px;
  65 + background-image: url("/channel/received.png");
66 position: absolute; 66 position: absolute;
67 top: 0; 67 top: 0;
68 right: 0; 68 right: 0;
@@ -70,8 +70,8 @@ @@ -70,8 +70,8 @@
70 70
71 &.zero { 71 &.zero {
72 width: 111px; 72 width: 111px;
73 - height: 132px;  
74 - background-image: url('/channel/zero.png'); 73 + height: 140px;
  74 + background-image: url("/channel/zero.png");
75 position: absolute; 75 position: absolute;
76 top: 0; 76 top: 0;
77 right: 0; 77 right: 0;
@@ -2,8 +2,8 @@ @@ -2,8 +2,8 @@
2 position: relative; 2 position: relative;
3 margin-right: auto; 3 margin-right: auto;
4 margin-left: auto; 4 margin-left: auto;
  5 + max-width: 640px;
5 width: 100%; 6 width: 100%;
6 - max-width: 750px;  
7 7
8 .margin-top-0 { 8 .margin-top-0 {
9 margin-top: 0; 9 margin-top: 0;
@@ -11,8 +11,9 @@ @@ -11,8 +11,9 @@
11 11
12 .tab-nav { 12 .tab-nav {
13 width: 100%; 13 width: 100%;
  14 + max-width: inherit;
14 height: 80px; 15 height: 80px;
15 - font-size: 16px; 16 + font-size: 26px;
16 text-align: center; 17 text-align: center;
17 position: fixed; 18 position: fixed;
18 z-index: 10; 19 z-index: 10;
@@ -28,6 +29,7 @@ @@ -28,6 +29,7 @@
28 white-space: nowrap; 29 white-space: nowrap;
29 overflow: hidden; 30 overflow: hidden;
30 text-overflow: ellipsis; 31 text-overflow: ellipsis;
  32 + cursor: pointer;
31 33
32 &:first-child { 34 &:first-child {
33 margin-left: -10px; 35 margin-left: -10px;
@@ -52,10 +54,8 @@ @@ -52,10 +54,8 @@
52 } 54 }
53 } 55 }
54 56
55 - .plusstar-resources:before { 57 + .empty-height {
56 height: 72px; 58 height: 72px;
57 - content: "";  
58 - display: inline-block;  
59 } 59 }
60 60
61 .resources { 61 .resources {
@@ -81,13 +81,12 @@ @@ -81,13 +81,12 @@
81 .header-title { 81 .header-title {
82 position: relative; 82 position: relative;
83 width: 100%; 83 width: 100%;
84 - height: 70px; 84 + height: 80px;
85 font-size: 28px; 85 font-size: 28px;
86 - line-height: 70px; 86 + line-height: 80px;
87 text-align: center; 87 text-align: center;
88 font-weight: bold; 88 font-weight: bold;
89 margin: 0; 89 margin: 0;
90 - margin-top: 20px;  
91 90
92 .more { 91 .more {
93 position: absolute; 92 position: absolute;
@@ -115,7 +114,6 @@ @@ -115,7 +114,6 @@
115 .swipe-indicators { 114 .swipe-indicators {
116 display: none; 115 display: none;
117 } 116 }
118 -  
119 } 117 }
120 118
121 .swipe-item { 119 .swipe-item {
1 .installment-help { 1 .installment-help {
2 - padding: 0 5px; 2 + padding: 30px;
3 margin: 0; 3 margin: 0;
4 background-color: #fff; 4 background-color: #fff;
5 - font-family: "Helvetica", "黑体", "Arial"; 5 + font-family: "微软雅黑";
  6 + color: #444;
6 7
7 .help-title { 8 .help-title {
8 text-align: center; 9 text-align: center;
9 - font-size: 40px; 10 + font-size: 28px;
10 margin-top: 10px; 11 margin-top: 10px;
  12 + font-weight: bold;
11 } 13 }
12 14
13 .help-group { 15 .help-group {
14 text-align: left; 16 text-align: left;
15 - margin: 20px 5px; 17 + margin: 0 5px 45px;
16 18
17 h2 { 19 h2 {
18 - font-size: 34px; 20 + font-size: 26px;
  21 + font-weight: bold;
19 } 22 }
20 23
21 p { 24 p {
22 - font-size: 28px; 25 + font-size: 26px;
23 line-height: 40px; 26 line-height: 40px;
24 margin-top: 10px; 27 margin-top: 10px;
25 - text-indent: 2em;  
26 } 28 }
27 29
28 .remind { 30 .remind {
@@ -61,3 +63,23 @@ @@ -61,3 +63,23 @@
61 } 63 }
62 } 64 }
63 } 65 }
  66 +
  67 +.installment-agreement {
  68 + p {
  69 + text-indent: 2em;
  70 + }
  71 +
  72 + ul {
  73 + list-style-type: none;
  74 +
  75 + li {
  76 +
  77 + display: inline-block;
  78 + }
  79 + }
  80 +
  81 + .indent2 {
  82 + text-indent: 2em;
  83 + display: inline-block;
  84 + }
  85 +}
@@ -81,7 +81,7 @@ @@ -81,7 +81,7 @@
81 } 81 }
82 82
83 .record-cont { 83 .record-cont {
84 - width: 360px; 84 + width: 240px;
85 height: 84px; 85 height: 84px;
86 float: left; 86 float: left;
87 overflow: hidden; 87 overflow: hidden;
@@ -140,6 +140,10 @@ @@ -140,6 +140,10 @@
140 width: 560px; 140 width: 560px;
141 margin: -165px 0 0 -280px; 141 margin: -165px 0 0 -280px;
142 } 142 }
  143 +
  144 + .notice-cont {
  145 + padding: 28px !important;
  146 + }
143 } 147 }
144 } 148 }
145 149