Blame view

public/js/guang/plusstar-index.page.js 13.2 KB
郝肖肖 authored
1
var $ = require('yoho-jquery'),
郝肖肖 authored
2
    tip = require('../plugin/tip'),
3
    Swiper = require('yoho-swiper2'),
4
    loading = require('../plugin/loading'),
郝肖肖 authored
5
    debounce = require('lodash/debounce');
郝肖肖 authored
6
7
var plusstar = {};
郝肖肖 authored
8
9
var windowHeight = $(window).height();
郝肖肖 authored
10
var scrollFn,
11
    scrollTop,
12
    RECPOSE,
郝肖肖 authored
13
    isApp,
14
    searching = false,
沈志敏 authored
15 16
    resourcesTp = {},
    CID;
郝肖肖 authored
17
18 19
require('guang/plusstar/index.page.css');
20
require('yoho-jquery-lazyload');
郝肖肖 authored
21
require('../common');
郝肖肖 authored
22
郝肖肖 authored
23
plusstar = {
24
    common: {
郝肖肖 authored
25
        codeDefault: '',
26 27 28
        page: 1,
        pagesize: 20,
        pageTotal: 1,
郝肖肖 authored
29
        productSkns: []
30
    },
郝肖肖 authored
31
    init: function() {
郝肖肖 authored
32 33 34 35 36 37 38 39 40
        var that = this,
            $liDom,
            $tabUlDom;

        $tabUlDom = $('.plusstar-page .tab-nav ul');

        $tabUlDom.find('li').css({
            width: 100 / $tabUlDom.find('li').length + '%'
        });
郝肖肖 authored
41
42 43 44 45 46
        $tabUlDom.find('li').each(function() {
            // 重新进入滑动位置清除
            window.setCookie($(this).data('code'), 0);
        });
47
        // 事情委托机制
郝肖肖 authored
48
        $tabUlDom.bind('click', function(event) {
沈志敏 authored
49
郝肖肖 authored
50
            $liDom = $(event.target).closest('li');
51 52 53 54 55

            if ($liDom.hasClass('focus')) {
                return true;
            }
郝肖肖 authored
56 57
            $(this).find('li').removeClass('focus');
            $liDom.addClass('focus');
58
            that.ParentLiDom = $liDom;// 保留当前tab先中的对象
郝肖肖 authored
59
            that.tabNav($liDom.data('code'));
60
61 62 63
            if (!window._yas || !window._yas.sendCustomInfo) {
                return;
            }
64
65
            // 点击潮流优选上方的TAB按钮时
沈志敏 authored
66 67 68 69 70
            window._yas.sendCustomInfo({
                op: 'YB_FASHION_TAB_C',
                appop: 'YB_H5_STROLL_PLUSSTAR_TAB_C',
                param: JSON.stringify({
                    TAB_ID: $liDom.index() + 1,
沈志敏 authored
71
                    C_ID: CID
沈志敏 authored
72 73 74 75 76 77 78
                })
            }, true);

            window._yas.sendCustomInfo({
                op: 'YB_FASHION_HOME_L',
                param: JSON.stringify({
                    TAB_ID: that.ParentLiDom.index() + 1,
沈志敏 authored
79
                    C_ID: CID
沈志敏 authored
80 81
                })
            }, true);
郝肖肖 authored
82 83
        });
84
        // start -- 默认选中
郝肖肖 authored
85 86 87 88
        $liDom = $tabUlDom.find('li.focus');
        if ($liDom.length <= 0) {
            // 默认第一个
            $liDom = $('.plusstar-page .tab-nav ul li:eq(0)');
郝肖肖 authored
89
        }
郝肖肖 authored
90
        $tabUlDom.find('li').removeClass('focus');
91
        $liDom.addClass('focus');
郝肖肖 authored
92
        that.ParentLiDom = $liDom;// 保留当前tab先中的对象
93 94
        // that.tabNav($liDom.data('code'));
        that.resInit();
95
        // ent -- 默认选中
96 97 98 99 100
        setTimeout(function() {
            that._yas();
        }, 1000);
    },
    _yas: function() {
郝肖肖 authored
101
        // http://redmine.yoho.cn/issues/12224
102 103 104 105 106
        var that = this;

        if (!window._yas || !window._yas.sendCustomInfo) {
            return false;
        }
郝肖肖 authored
107
108
        RECPOSE = that.ParentLiDom.index() !== 0 ? 100015 : 100014;
郝肖肖 authored
109
        $('.plusstar-resources').bind('click', function(event) {
郝肖肖 authored
110
            var $dom, $domA, index;
郝肖肖 authored
111 112 113 114 115

            if ($(event.target).closest('.good-info').length > 0) {
                // 商品单击埋点
                $dom = $(event.target).closest('.good-info');
                index = $dom.index() + 1;
沈志敏 authored
116
                window.givePoint({
沈志敏 authored
117
                    isAppOp: true,
郝肖肖 authored
118
                    REC_POSE: RECPOSE,
119
                    PRD_ID: $dom.data('good-id'),
郝肖肖 authored
120
                    ORDER_CODE: '',
121 122
                    PRD_NUM: index % that.common.pagesize === 0 ? that.common.pagesize : index % that.common.pagesize,
                    ACTION_ID: 1,
沈志敏 authored
123
                    PAGE_NUM: Math.ceil(index / that.common.pagesize)
沈志敏 authored
124
                });
郝肖肖 authored
125 126
            } else if ($(event.target).closest('.banner-top').length > 0) {
                // 头部banner楼层埋点
郝肖肖 authored
127
                $dom = $(event.target).closest('li');
郝肖肖 authored
128 129 130
                index = $dom.index() + 1;
                window._yas.sendCustomInfo({
                    op: 'YB_FASHION_FLR_C',
沈志敏 authored
131 132
                    appop: 'YB_H5_STROLL_PLUSSTAR_FLR_C',
                    param: JSON.stringify({
沈志敏 authored
133
                        C_ID: CID,
郝肖肖 authored
134
                        TAB_ID: that.ParentLiDom.index() + 1,
郝肖肖 authored
135
                        F_ID: $dom.closest('ul').data('id'),
郝肖肖 authored
136
                        F_NAME: '焦点图',
郝肖肖 authored
137
                        F_URL: encodeURIComponent($dom.find('a').attr('href').replace(/\"/g, '\\"')),
郝肖肖 authored
138
                        F_INDEX: 1,
139
                        I_INDEX: index
沈志敏 authored
140
                    })
郝肖肖 authored
141
                }, true);
郝肖肖 authored
142 143 144 145 146
            } else if ($(event.target).closest('.speck-title-image a').length > 0) {
                // 各楼层埋点
                $dom = $(event.target).closest('.speck-title-image');
                $domA = $(event.target).closest('.speck-title-image a');
郝肖肖 authored
147 148
                window._yas.sendCustomInfo({
                    op: 'YB_FASHION_FLR_C',
沈志敏 authored
149 150
                    appop: 'YB_H5_STROLL_PLUSSTAR_FLR_C',
                    param: JSON.stringify({
沈志敏 authored
151
                        C_ID: CID,
郝肖肖 authored
152
                        TAB_ID: that.ParentLiDom.index() + 1,
郝肖肖 authored
153 154
                        F_ID: $dom.data('fid'),
                        F_NAME: $dom.data('name'),
郝肖肖 authored
155
                        F_URL: encodeURIComponent($domA.attr('href').replace(/\"/g, '\\"')),
郝肖肖 authored
156 157
                        F_INDEX: $dom.index() + 1,
                        I_INDEX: $domA.hasClass('more') ? 0 : ($domA.index() + 1)
沈志敏 authored
158
                    })
郝肖肖 authored
159 160
                }, true);
            }
郝肖肖 authored
161
        });
162 163 164 165

        // 潮流优选首页加载时
        window._yas.sendCustomInfo({
            op: 'YB_FASHION_HOME_L',
沈志敏 authored
166
            param: JSON.stringify({
沈志敏 authored
167
                C_ID: CID,
168
                TAB_ID: that.ParentLiDom.index() + 1
沈志敏 authored
169
            })
170
        }, true);
郝肖肖 authored
171 172
    },
    tabNav: function(code) {
173
        var that = this;
沈志敏 authored
174
        var tabId = that.ParentLiDom.index() + 1;
175
176
        this.common.codeDefault = code;// 记住最后一次的tab code
177
        this.common.page = 1;// 商品列表从第一页开始
郝肖肖 authored
178
        searching = false;// 初始化翻页
郝肖肖 authored
179
沈志敏 authored
180
        function execResData(data) {
郝肖肖 authored
181
沈志敏 authored
182
            $('.plusstar-resources').html(data);
183
沈志敏 authored
184 185 186 187
            if (data === '') {
                tip.show('没有更多内容了');
                return true;
            }
188
沈志敏 authored
189 190
            // 固定底部去除
            window.rePosFooter();
郝肖肖 authored
191
沈志敏 authored
192 193
            // 记录切换tab位置
            $(document).scrollTop(window.cookie(code) || 0);
郝肖肖 authored
194
沈志敏 authored
195
            that.resInit();
196
沈志敏 authored
197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214
        }

        if (resourcesTp[tabId]) {
            execResData(resourcesTp[tabId]);
        } else {
            $.ajax({
                type: 'GET',
                url: '/guang/plusstar/resources-template',
                data: {
                    code: code,
                    uid: window.queryString.uid,
                    app_version: isApp,
                    yh_channel: tabId
                },
                dataType: 'html',
                success: function(data) {
                    resourcesTp[tabId] = data;
                    execResData(data);
215
沈志敏 authored
216 217 218 219 220 221 222 223 224
                    // 页面中下拉曝光
                    setTimeout(function() {
                        if (window._yas && window._yas.sendAppLogs) {
                            var actionUrl = [],
                                aDom = $('.plusstar-resources').find('a');

                            aDom.each(function() {
                                actionUrl.push($(this).attr('href'));
                            });
225 226 227 228 229 230 231 232 233 234 235 236

                            aDom.on('click', function() {
                                window._yas.sendAppLogs({
                                    appop: 'YB_H5_PAGE_FLR_C',
                                    param: JSON.stringify({
                                        C_ID: window._ChannelVary[window.cookie('_Channel')] || 1,
                                        PAGE_URL: window.originUrl,
                                        PAGE_NAME: window.qs.title || document.title,
                                        F_URL: $(this).attr('href')
                                    })
                                }, true);
                            });
沈志敏 authored
237 238 239 240 241 242 243 244 245 246 247 248

                            window._yas.sendAppLogs({
                                appop: 'YB_H5_SHOW',
                                param: JSON.stringify({
                                    C_ID: window._ChannelVary[window.cookie('_Channel')] || 1,
                                    PAGE_URL: window.originUrl,
                                    PAGE_NAME: window.qs.title || document.title,
                                    ACTION_URL: actionUrl
                                })
                            }, true);
                        }
                    }, 500);
沈志敏 authored
249 250 251 252 253 254
                },
                error: function() {
                    tip.show('网络断开连接了~');
                }
            });
        }
255 256
    },
    resInit: function() {
257 258 259 260
        var that = this,
            productSkns = '',
            tabId;
261 262 263 264 265
        // 头部banner轮播
        if ($('.banner-swiper').find('li').size() > 1) {
            new Swiper('.banner-swiper', {
                lazyLoading: true,
                lazyLoadingInPrevNext: true,
266
                loop: false,
267 268 269 270 271 272 273
                autoplay: 3000,
                autoplayDisableOnInteraction: false,
                paginationClickable: true,
                slideElement: 'li',
                pagination: '.banner-top .pagination-inner'
            });
        }
274 275 276

        $('.plusstar-resources').find('img.lazy').lazyload();
        productSkns = $('.product-skns').val();
277
278 279 280 281 282 283
        if (productSkns) {
            this.common.productSkns = productSkns.split(',');
        }

        this.common.pageTotal = Math.ceil(this.common.productSkns.length / this.common.pagesize);
284
        tabId = that.ParentLiDom.index() + 1;
285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306
        setTimeout(function() {
            $.ajax({
                type: 'POST',
                url: '/guang/plusstar/userSkn',
                data: {
                    skns: productSkns,
                    uid: window.queryString.uid,
                    app_version: isApp,
                    yh_channel: tabId
                },
                dataType: 'json',
                success: function(data) {
                    if (data) {
                        that.common.productSkns = data;
                    }
                    that.common.pageTotal = Math.ceil(that.common.productSkns.length / that.common.pagesize);
                },
                error: function() {
                    tip.show('网络断开连接了~');
                }
            });
        }, 300);
郝肖肖 authored
307 308 309
    },
    goodsList: function() {
        var that = this,
郝肖肖 authored
310
            skn = [];
郝肖肖 authored
311
312 313 314 315 316 317 318 319 320 321 322
        if (searching) {
            return;
        }
        searching = true;

        if (that.common.page > that.common.pageTotal) {
            return false;
        }

        loading.showLoadingMask();
        skn = that.common.productSkns.slice((that.common.page - 1) * that.common.pagesize, that.common.page * that.common.pagesize);
郝肖肖 authored
323 324 325
        $.ajax({
            type: 'POST',
            url: '/guang/plusstar/resources-goodsList',
郝肖肖 authored
326
            timeout: 5000,
郝肖肖 authored
327
            data: {
328
                productSkn: skn.join(','),
329
                app_version: isApp
郝肖肖 authored
330 331 332
            },
            dataType: 'html',
            success: function(data) {
郝肖肖 authored
333
                skn = [];
334 335
                loading.hideLoadingMask();
                searching = false;
336
                that.common.page++;
郝肖肖 authored
337
郝肖肖 authored
338 339 340 341
                if (data === '') {
                    return true;
                }
郝肖肖 authored
342
                $.each($(data).siblings('.good-info'), function() {
343
                    skn.push($(this).data('good-id'));
郝肖肖 authored
344 345
                });
沈志敏 authored
346
                window.givePoint({
沈志敏 authored
347
                    isAppOp: true,
沈志敏 authored
348
                    C_ID: CID,
郝肖肖 authored
349 350 351
                    REC_POSE: RECPOSE,
                    PRD_ID: skn.join(','),
                    ORDER_CODE: '',
352 353
                    PRD_NUM: that.common.pagesize,
                    ACTION_ID: 0,
沈志敏 authored
354
                    PAGE_NUM: that.common.page - 1
沈志敏 authored
355
                });
郝肖肖 authored
356
郝肖肖 authored
357 358
                $('.plusstar-resources .goods').append(data);
郝肖肖 authored
359
                $('.plusstar-resources .goods').find('img.lazy:not([src])').lazyload();
360
                $('.resources .goods .page-total').remove();
郝肖肖 authored
361 362
            },
            error: function() {
363
                searching = false;
郝肖肖 authored
364
                tip.show('网络断开连接了~');
365
                loading.hideLoadingMask();
郝肖肖 authored
366 367
            }
        });
郝肖肖 authored
368 369 370
    }
};
郝肖肖 authored
371
scrollFn = debounce(function() {
372
    scrollTop = $(document).scrollTop();
373 374

    // 保留滑动位置,产品要求
郝肖肖 authored
375
    window.setCookie(plusstar.common.codeDefault, $(this).scrollTop());
376
377
    // 当scroll到最后一列商品的高度后继续请求下一页数据
378
    if (400 + scrollTop >= $(document).height() - windowHeight) {
379
        plusstar.goodsList();
郝肖肖 authored
380
    }
381
郝肖肖 authored
382
}, 200);
383
郝肖肖 authored
384
$(function() {
385
    isApp = window.queryString.app_version || window.queryString.appVersion;
郝肖肖 authored
386
387 388 389 390 391 392 393
    // if (isApp) {
    //     $('.plusstar-resources').css({'margin-top': $('.tab-nav').height()});
    // } else {
    //     $('.tab-nav').css({
    //         position: 'relative'
    //     });
    // }
郝肖肖 authored
394
395
    // 男:1,女:2,潮童:3,创意生活:4
沈志敏 authored
396
    CID = window.queryString.yh_channel || window._ChannelVary[window.cookie('_Channel')] || 1;
397
郝肖肖 authored
398
    plusstar.init();
399
郝肖肖 authored
400 401 402 403
    // 滚动翻页
    $(window).scroll(function() {
        scrollFn();
    });
404
});