SOURCE

'use strict';

var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };

var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();

function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }

(function (global, factory) {
    global.FilterBar = factory(global);
})(typeof window !== 'undefined' ? window : undefined, function (window) {
    /**
     * 筛选条插件类
     * 
     * @class FilterBar
     */
    var FilterBar = function () {
        /**
         * 创建实例
         * 
         * @param {any} config 
         * @memberof FilterBar
         */
        function FilterBar(config, doneCallback) {
            _classCallCheck(this, FilterBar);

            this.log('init!');
            this.config = config;
            this.cache = [];
            this.lastFocusGroup = '';
            this.emptyHtml = '<p class="filter-nodata">该筛选项无数据,请重新选择筛选条件!</p>';
            this.init();
            document.documentElement.classList.remove('filter-shown');
            document.body.classList.remove('filter-shown');
            if (typeof doneCallback === 'function') {
                doneCallback();
            }
        }

        /**
         * 打印调试日志
         * 仅debug=true启用
         * 
         * @param {any} msg 
         * @memberof FilterBar
         */


        _createClass(FilterBar, [{
            key: 'log',
            value: function log() {
                if (FilterBar.debug) {
                    var _console;

                    (_console = console).log.apply(_console, arguments);
                }
            }

            /**
             * 将NodeList转为数组
             * 
             * @param {any} obj 
             * @memberof FilterBar
             */

        }, {
            key: 'toArray',
            value: function toArray(obj) {
                return Array.prototype.slice.call(obj);
            }

            /**
             * 初始化方法
             * 
             * @memberof FilterBar
             */

        }, {
            key: 'init',
            value: function init() {
                this.renderTabs();
                this.renderPanels();
                this.renderMask();
            }

            /**
             * 渲染Tabs元素
             * 
             * @memberof FilterBar
             */

        }, {
            key: 'renderTabs',
            value: function renderTabs() {
                var _this = this;

                this.log('渲染Tabs');
                var wrap = document.createElement('div');
                wrap.classList.add('filter-wrap');
                this.config.forEach(function (_ref, index) {
                    var data = _ref.data,
                        tabName = _ref.tabName,
                        selectedData = _ref.selectedData,
                        customSelected = _ref.customSelected,
                        callback = _ref.callback;

                    var tab = document.createElement('div');
                    tab.id = 'filter-tab-' + index;
                    tab.classList.add('filter-tab');

                    // 无展开面板的形式
                    if (typeof data === 'undefined') {
                        tab.classList.add('filter-tab-radio');
                    }
                    tab.addEventListener('click', function () {
                        if (typeof data !== 'undefined') {
                            // 切换显示普通列表
                            if (tab.classList.contains('on')) {
                                _this.hidePanel();
                            } else {
                                _this.showPanel(index);
                            }
                        } else {
                            // 该tab被认为是单击切换选中
                            tab.classList.toggle('selected');
                            _this.hidePanel();
                            callback({
                                selected: tab.classList.contains('selected'),
                                type: FilterBar.cbEnum.confirm,
                                ext: index
                            });
                        }
                    });
                    tab.innerHTML = '<div><span>' + tabName + '</span></div>';

                    var hasSelected = false;

                    // 判断是否已有选中
                    if (typeof selectedData === 'boolean') {
                        hasSelected = selectedData;
                    } else if (typeof selectedData === 'string') {
                        if (selectedData) {
                            hasSelected = true;
                        }
                    } else if (Array.isArray(selectedData)) {
                        if (selectedData.length) {
                            hasSelected = true;
                        }
                    } else if ((typeof selectedData === 'undefined' ? 'undefined' : _typeof(selectedData)) === 'object') {
                        if (Object.keys(selectedData).length) {
                            hasSelected = true;
                        }
                    }
                    _this.log('renderTabs - hasSelected=' + hasSelected);

                    // 普通筛选项有选中,或者自定义面板包含了选中项
                    if (hasSelected || customSelected) {
                        tab.classList.add('selected');
                    }

                    wrap.appendChild(tab);
                });

                if (!document.querySelector('.filter-wrap')) {
                    this.log('第一次初始化');

                    // 如果是第一次初始化
                    document.body.appendChild(wrap);
                } else {
                    this.log('wrap已存在,重新初始化');

                    // 重新初始化
                    var frag = document.createDocumentFragment();
                    this.toArray(wrap.querySelectorAll('.filter-tab')).forEach(function (tab) {
                        return frag.appendChild(tab);
                    });

                    // 原有的tab全部移除
                    this.toArray(document.querySelectorAll('.filter-wrap .filter-tab')).forEach(function (tab) {
                        return tab.remove();
                    });

                    // 添加新的tab
                    document.querySelector('.filter-wrap').appendChild(frag);

                    // 原有的面板全部移除
                    this.toArray(document.querySelectorAll('.filter-panel')).forEach(function (panel) {
                        return panel.remove();
                    });
                }
            }

            /**
             * 渲染下拉面板
             * 
             * @memberof FilterBar
             */

        }, {
            key: 'renderPanels',
            value: function renderPanels() {
                var _this2 = this;

                this.log('渲染Panels');
                this.config.forEach(function (_ref2, index) {
                    var data = _ref2.data;

                    if (typeof data !== 'undefined') {
                        // 弹出列表的形式
                        if (data[0] && data[0].groupCode) {
                            // 多列筛选
                            _this2.renderComplexPanel(index);
                        } else {
                            if (_this2.config[index].multi) {
                                // 单列多选
                                _this2.renderSinglePanel2(index);
                            } else {
                                // 单列单选
                                _this2.renderSinglePanel1(index);
                            }
                        }
                    }
                });
            }

            /**
             * 使用新的参数重置筛选
             * 
             * @memberof FilterBar
             */

        }, {
            key: 'reset',
            value: function reset(params) {
                var _this3 = this;

                if (params.type === FilterBar.cbEnum.confirm) {
                    // 如果是通过点击确定进行的重置,则更新全部面板
                    this.log('reset所有面板');
                    this.config = params.config;
                    this.config.forEach(function (conf, index) {
                        _this3.resetOnePanel(conf, index);

                        // 设置面板样式
                        var panel = document.querySelector('#filter-panel-' + index);
                        _this3.initPanelStyle(panel, index);
                    });
                } else {
                    // 否则仅更新所操作的面板
                    this.log('\u4EC5reset\u7B2C' + params.ext + '\u4E2A\u9762\u677F');
                    this.config[params.ext] = params.config[params.ext];
                    this.resetOnePanel(params.config[params.ext], params.ext);
                }
            }

            /**
             * 重置指定面板
             * 
             * @param {any} conf 
             * @param {any} index 
             * @memberof FilterBar
             */

        }, {
            key: 'resetOnePanel',
            value: function resetOnePanel(conf, index) {
                this.log('\u5F00\u59CBreset\u9762\u677F' + index);
                var data = conf.data,
                    selectedData = conf.selectedData,
                    customSelected = conf.customSelected;

                // 重新确定tab是否高亮
                var hasSelected = false;
                var tab = document.querySelector('#filter-tab-' + index);

                // 判断是否已有选中
                if (typeof selectedData === 'string') {
                    if (selectedData) {
                        hasSelected = true;
                    }
                } else if (Array.isArray(selectedData)) {
                    if (selectedData.length) {
                        hasSelected = true;
                    }
                } else if ((typeof selectedData === 'undefined' ? 'undefined' : _typeof(selectedData)) === 'object') {
                    if (Object.keys(selectedData).length) {
                        hasSelected = true;
                    }
                }

                // 普通筛选项有选中,或者自定义面板包含了选中项
                if (hasSelected || customSelected) {
                    tab.classList.add('selected');
                } else {
                    tab.classList.remove('selected');
                }

                // 重新构建筛选项
                if (typeof data === 'undefined') {
                    // 无列表的形式,例如门票筛选的"今日可订"
                } else if (Array.isArray(data) && data[0] && data[0].groupCode) {
                    // 多列筛选
                    this.resetComplexPanel(index);
                } else if (this.config[index].multi) {
                    // 单列多选
                    this.resetSinglePanel2(index);
                } else {
                    // 单列单选
                    this.resetSinglePanel1(index);
                }
            }

            /**
             * 计算面板的确定高度
             * 
             * @param {any} index 
             * @returns 
             * @memberof FilterBar
             */

        }, {
            key: 'calculateHeight',
            value: function calculateHeight(index) {
                var height = 0;
                var panel = document.querySelector('#filter-panel-' + index);

                // 根据屏幕的高度,设置一个最大高度,以尽可能多的展示内容
                var maxHeight = window.innerHeight - document.querySelector('.filter-wrap').offsetTop - 45 - 90;
                if (panel.classList.contains('complex')) {
                    // 复杂面板,高度定死,使用最大高度
                    height = maxHeight;
                } else if (panel.classList.contains('multi')) {
                    // 多选面板
                    var lines = this.config[index].data.length;
                    if (lines) {
                        height = lines * 45 + 47;
                    } else {
                        height = 137;
                    }
                    if (height > maxHeight) {
                        height = maxHeight;
                    }
                } else {
                    // 单列单选面板
                    var _lines = this.config[index].data.length;
                    if (_lines) {
                        height = _lines * 45;
                    } else {
                        height = 137;
                    }
                    if (height > maxHeight) {
                        height = maxHeight;
                    }
                }
                this.log('\u8BA1\u7B97\u5F97\u5230\u9762\u677F\u56FA\u5B9A\u9AD8\u5EA6\u4E3A' + height + 'px');
                return height;
            }

            /**
             * 初始化面板样式
             * 
             * @param {any} panel 
             * @param {any} index 
             * @memberof FilterBar
             */

        }, {
            key: 'initPanelStyle',
            value: function initPanelStyle(panel, index) {
                var data = this.config[index].data;
                var height = this.calculateHeight(index);
                panel.style.height = height + 'px';
                panel.style.transform = 'translate3d(0px, -' + (height + 1) + 'px, 0px)';
                panel.style.webkitTransform = 'translate3d(0px, -' + (height + 1) + 'px, 0px)';
                var ul = void 0;
                if (data[0] && data[0].groupCode) {
                    // 多列筛选
                    ul = panel.querySelector('.filter-ul');
                } else if (this.config[index].multi) {
                    // 单列多选
                    ul = panel.querySelector('ul');
                }

                if (ul) {
                    ul.style.height = height - 47 + 'px';
                }
            }

            /**
             * 渲染蒙层
             * 
             * @memberof FilterBar
             */

        }, {
            key: 'renderMask',
            value: function renderMask() {
                var _this4 = this;

                this.log('渲染蒙层');
                var mask = document.querySelector('.filter-mask');
                if (!mask) {
                    var _mask = document.createElement('div');
                    _mask.classList.add('filter-mask');
                    _mask.addEventListener('click', function () {
                        _this4.hidePanel();
                    });
                    document.body.appendChild(_mask);
                }
            }

            /**
             * 显示面板
             * 
             * @param {number} index - tab的次序
             * @memberof FilterBar
             */

        }, {
            key: 'showPanel',
            value: function showPanel(index) {
                var _this5 = this;

                this.log('\u663E\u793A\u9762\u677F' + index);
                var panel = document.querySelector('#filter-panel-' + index);
                var opendPanel = document.querySelector('.filter-panel.on');

                // 如果当前已有打开的面板,则先隐藏
                if (opendPanel) {
                    this.hidePanel(false);
                }

                panel.classList.add('on');
                panel.style.display = 'block';
                setTimeout(function () {
                    panel.style.transform = 'translate3d(0, 0, 0)';
                    panel.style.webkitTransform = 'translate3d(0, 0, 0)';
                }, 0);

                var tab = document.querySelector('#filter-tab-' + index);
                tab.classList.add('on');

                // 禁止屏幕滚动
                document.documentElement.classList.add('filter-shown');
                document.body.classList.add('filter-shown');
                setTimeout(function () {
                    _this5.log('重新启用面板动画');
                    panel.style.transitionDuration = '.3s';
                    panel.style.webkitTransitionDuration = '.3s';
                }, 0);
            }

            /**
             * 隐藏面板
             * 
             * @param {boolean} [animate=true] - 是否显示动画
             * @param {boolean} [cb=true] - 是否调用回调函数
             * @memberof FilterBar
             */

        }, {
            key: 'hidePanel',
            value: function hidePanel() {
                var _this6 = this;

                var animate = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true;
                var cb = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;

                this.log('隐藏面板');
                var opendPanel = document.querySelector('.filter-panel.on');
                if (opendPanel) {
                    var opendPanelHeight = parseInt(opendPanel.style.height.split("px")[0]);
                    var opendIndex = opendPanel.dataset.index;
                    var opendTab = document.querySelector('#filter-tab-' + opendIndex);
                    if (!animate) {
                        this.log('停用面板动画');
                        opendPanel.style.transitionDuration = '0s';
                        opendPanel.style.webkitTransitionDuration = '0s';
                    }
                    opendPanel.style.transform = 'translate3d(0, -' + (opendPanelHeight + 1) + 'px, 0)';
                    opendPanel.style.webkitTransform = 'translate3d(0, -' + (opendPanelHeight + 1) + 'px, 0)';
                    opendPanel.classList.remove('on');
                    opendTab.classList.remove('on');

                    // 开启屏幕滚动
                    document.documentElement.classList.remove('filter-shown');
                    document.body.classList.remove('filter-shown');

                    // 如果没有数据则直接退出
                    var data = this.config[opendIndex].data;
                    if (Array.isArray(data) && data.length === 0) {
                        return;
                    }

                    // 收起之后,隐藏面板,并从缓存中恢复已选项,覆盖暂选项
                    if (!animate) {
                        // opendPanel.style.display = 'none';
                        this.restoreFilter(opendIndex, cb);
                    } else {
                        setTimeout(function () {
                            // opendPanel.style.display = 'none';
                            _this6.restoreFilter(opendIndex, cb);
                        }, 300);
                    }
                }
            }

            /**
             * 从缓存中恢复已选项
             * 
             * @param {number} index 
             * @memberof FilterBar
             */

        }, {
            key: 'restoreFilter',
            value: function restoreFilter(index, cb) {
                var _this7 = this;

                this.log('\u6E05\u9664\u4E34\u65F6\u9009\u62E9\u7684\u6570\u636E\uFF0C\u6062\u590D\u9762\u677F' + index + '\u7684\u4E0A\u6B21\u5DF2\u786E\u8BA4\u6570\u636E', this.cache[index]);
                var selected = this.cache[index];
                var tab = document.querySelector('#filter-tab-' + index);
                if (Array.isArray(selected)) {
                    // 单列多选
                    var lis = document.querySelectorAll('#filter-panel-' + index + ' li');
                    this.toArray(lis).forEach(function (li) {
                        var code = li.dataset.code;
                        if (selected.indexOf(code) >= 0 || selected.length === 0 && !code) {
                            li.classList.add('selected');
                        } else {
                            li.classList.remove('selected');
                        }
                    });

                    // 改变tab样式
                    if (selected.length) {
                        tab.classList.add('selected');
                    } else {
                        tab.classList.remove('selected');
                    }

                    // 回到顶部
                    var ul = document.querySelector('#filter-panel-' + index + ' ul');
                    if (ul) {
                        ul.scrollTop = 0;
                    }
                } else if ((typeof selected === 'undefined' ? 'undefined' : _typeof(selected)) === 'object') {
                    // 多列
                    var panel = document.querySelectorAll('#filter-panel-' + index + ' .filter-ul>li');
                    this.toArray(panel).forEach(function (groupLi) {
                        var filterTxt = [];
                        var groupCode = groupLi.dataset.code;
                        _this7.toArray(groupLi.querySelectorAll('.filter-sub-ul li')).forEach(function (subLi) {
                            if (!selected[groupCode] && (!subLi.dataset.code || subLi.dataset.code === '不限') && !subLi.classList.contains('filter-sec-wrap')) {
                                subLi.classList.add('selected');
                            } else if (selected[groupCode] && selected[groupCode].indexOf(subLi.dataset.code) >= 0) {
                                subLi.classList.add('selected');
                                if (!subLi.classList.contains('filter-sec-li')) {
                                    // 普通li
                                    filterTxt.push(subLi.querySelector('span').textContent);
                                } else {
                                    // 子面板的li
                                    var forcode = subLi.parentElement.parentElement.dataset.forcode;
                                    groupLi.querySelector('.filter-sub-li[data-code="' + forcode + '"]').classList.add('selected');
                                    var subTitle = '';
                                    var itemName = subLi.querySelector('span').textContent;
                                    if (itemName === '不限') {
                                        // 第一项默认为不限
                                        subTitle = forcode;
                                    } else {
                                        subTitle = forcode + '-' + itemName;
                                    }
                                    filterTxt.push(subTitle);
                                }
                            } else {
                                subLi.classList.remove('selected');
                            }
                        });
                        groupLi.querySelector('.filter-title i').textContent = filterTxt.join('、');
                    });

                    // 改变tab样式
                    if (Object.keys(selected).length) {
                        tab.classList.add('selected');
                    } else {
                        tab.classList.remove('selected');
                    }

                    // 收起已展开的筛选
                    this.toArray(document.querySelectorAll('#filter-panel-' + index + ' .filter-more.opend')).forEach(function (more) {
                        more.classList.remove('opend');
                        var subUl = more.parentElement.nextElementSibling;
                        subUl.style.maxHeight = '40px';
                    });

                    // 回到顶部
                    var _ul = document.querySelector('#filter-panel-' + index + ' .filter-ul');
                    if (_ul) {
                        _ul.scrollTop = 0;
                    }

                    // 上次点击的组置空
                    this.lastFocusGroup = '';
                }

                // 执行回调
                if (cb) {
                    this.config[index].callback({
                        selected: selected,
                        type: FilterBar.cbEnum.cancel,
                        ext: index
                    });
                }
            }

            /**
             * 初始化单列单选列表
             * 
             * @param {number} index - 筛选tab次序
             * @memberof FilterBar
             */

        }, {
            key: 'renderSinglePanel1',
            value: function renderSinglePanel1(index) {
                var _this8 = this;

                this.log('\u521D\u59CB\u5316\u5355\u9009\u9762\u677F' + index);
                var render = function render(panel) {
                    if (!_this8.config[index].data.length) {
                        // 如果不存在筛选
                        panel.innerHTML = _this8.emptyHtml;
                    } else {
                        var ul = document.createElement('ul');

                        // 初始化单列单选列表的项
                        _this8.initSinglePanel1Items(index, ul);

                        panel.appendChild(ul);
                    }
                };

                var panel = void 0;
                if (!document.querySelector('#filter-panel-' + index)) {
                    // 不存在则创建面板
                    panel = document.createElement('div');
                    panel.id = 'filter-panel-' + index;
                    panel.classList.add('filter-panel');
                    panel.dataset.index = index;
                    render(panel);
                    document.querySelector('.filter-wrap').appendChild(panel);
                } else {
                    panel = document.querySelector('#filter-panel-' + index);
                    panel.innerHTML = '';
                    render(panel);
                }

                // 设置面板样式
                this.initPanelStyle(panel, index);

                // 将已选项存入缓存
                this.cache[index] = this.config[index].selectedData;
            }

            /**
             * 重置单列单选列表
             * 
             * @param {number} index - 筛选tab次序
             * @memberof FilterBar
             */

        }, {
            key: 'resetSinglePanel1',
            value: function resetSinglePanel1(index) {
                this.log('\u91CD\u7F6E\u5355\u9009\u9762\u677F' + index);
                var ul = document.querySelector('#filter-panel-' + index + ' ul');

                // 如果本次重置的筛选数据为空,或者之前面板无数据,则完全初始化
                if (!this.config[index].data.length || !ul) {
                    this.renderSinglePanel1(index);
                    return;
                }

                // 创建新的筛选项元素
                var frag = document.createDocumentFragment();

                // 初始化单列单选列表的项
                this.initSinglePanel1Items(index, frag);

                // 清空原先的筛选项
                ul.innerHTML = '';

                // 添加新的筛选项到ul
                ul.appendChild(frag);
            }

            /**
             * 初始化单列单选列表的项
             * 
             * @param {number} index - 筛选tab次序
             * @param {any} container - 生成的项放入的容器
             * @memberof FilterBar
             */

        }, {
            key: 'initSinglePanel1Items',
            value: function initSinglePanel1Items(index, container) {
                var _this9 = this;

                var data = this.config[index].data;
                var selectedData = this.config[index].selectedData;
                data.forEach(function (item) {
                    var li = document.createElement('li');
                    li.dataset.code = item.itemCode;
                    li.textContent = item.itemName;

                    // 处理选中状态
                    if (item.itemCode === String(selectedData)) {
                        li.classList.add('selected');

                        // 替换tab文字
                        if (_this9.config[index].replace) {
                            var tab = document.querySelector('#filter-tab-' + index);
                            if ((!item.itemCode || item.itemCode === '不限') && !_this9.config[index].replaceDefault) {
                                // 不限的情况,若replaceDefault=false,则不替换
                                tab.querySelector('span').textContent = _this9.config[index].tabName;
                            } else {
                                // 用已选项替换tab文字
                                tab.querySelector('span').textContent = item.itemName;
                            }
                        }
                    }

                    // 绑定筛选项的点击事件
                    li.addEventListener('click', function () {
                        var tab = document.querySelector('#filter-tab-' + index);
                        var panel = document.querySelector('#filter-panel-' + index);

                        // 调整选中状态
                        var selected = panel.querySelector('li.selected');
                        if (selected) {
                            selected.classList.remove('selected');
                        }
                        li.classList.add('selected');

                        // 已选项放入缓存
                        _this9.cache[index] = item.itemCode;

                        // 执行回调函数
                        _this9.config[index].callback({
                            selected: item.itemCode,
                            type: FilterBar.cbEnum.confirm,
                            ext: index
                        });

                        // 隐藏面板
                        _this9.hidePanel(true, false);

                        // 改变tab样式
                        if (item.itemCode) {
                            tab.classList.add('selected');
                        } else {
                            tab.classList.remove('selected');
                        }

                        // 修改tab文字
                        if (_this9.config[index].replace) {
                            if ((!item.itemCode || item.itemCode === '不限') && !_this9.config[index].replaceDefault) {
                                // 不限的情况,若replaceDefault=false,则不替换
                                tab.querySelector('span').textContent = _this9.config[index].tabName;
                            } else {
                                // 用已选项替换tab文字
                                tab.querySelector('span').textContent = item.itemName;
                            }
                        }
                    });
                    container.appendChild(li);
                });
            }

            /**
             * 获取当前的已选项(单列多选或多列情况)
             * 
             * @param {any} panel 
             * @returns 
             * @memberof FilterBar
             */

        }, {
            key: 'getSelectedItems',
            value: function getSelectedItems(panel) {
                var _this10 = this;

                if (panel.classList.contains('multi')) {
                    // 多选面板
                    var liSelected = panel.querySelectorAll('li.selected');
                    var selectedItems = [];
                    this.toArray(liSelected).forEach(function (li) {
                        var code = li.dataset.code;
                        if (code) {
                            selectedItems.push(code);
                        }
                    });
                    return selectedItems;
                }

                // 复杂面板
                var result = {};
                var ul = panel.querySelectorAll('.filter-ul>li');
                this.toArray(ul).forEach(function (li) {
                    var selectedItems = [];
                    var items = li.querySelectorAll('.filter-sub-ul li');
                    _this10.toArray(items).forEach(function (item) {
                        if (!item.classList.contains('filter-li-haspanel') && item.classList.contains('selected') && item.dataset.code && item.dataset.code !== '不限') {
                            selectedItems.push(item.dataset.code);
                        }
                    });
                    if (selectedItems.length > 0) {
                        result[li.dataset.code] = selectedItems;
                    }
                });
                return result;
            }

            /**
             * 处理多选项的点击
             * 
             * @param {any} li 
             * @param {any} panel 
             * @memberof FilterBar
             */

        }, {
            key: 'handleMultiSelect',
            value: function handleMultiSelect(li, panel) {
                var isDefaultItem = !li.dataset.code;
                if (isDefaultItem) {
                    if (!li.classList.contains('selected')) {
                        this.toArray(panel.querySelectorAll('li.selected')).forEach(function (li) {
                            return li.classList.remove('selected');
                        });
                        li.classList.add('selected');
                    }
                } else {
                    // 点击的是普通项
                    li.classList.toggle('selected');

                    // 还要再处理下"不限"选项
                    if (panel.querySelectorAll('.selected').length) {
                        panel.querySelector('li').classList.remove('selected');
                    } else {
                        panel.querySelector('li').classList.add('selected');
                    }
                }
            }

            /**
             * 渲染单列多选列表
             * 
             * @param {number} index - 筛选tab次序
             * @memberof FilterBar
             */

        }, {
            key: 'renderSinglePanel2',
            value: function renderSinglePanel2(index) {
                var _this11 = this;

                this.log('\u521D\u59CB\u5316\u591A\u9009\u9762\u677F' + index);
                var render = function render(panel) {
                    if (!_this11.config[index].data.length) {
                        // 如果不存在筛选
                        panel.innerHTML = _this11.emptyHtml;
                    } else {
                        var ul = document.createElement('ul');

                        // 初始化单列多选列表的项
                        _this11.initSinglePanel2Items(index, ul);

                        panel.appendChild(ul);

                        // 操作面板
                        var action = document.createElement('div');
                        action.classList.add('filter-action');

                        // 重置
                        var reset = document.createElement('div');
                        reset.innerHTML = '<div class="filter-action-txt">重置</div>';
                        reset.classList.add('filter-reset');
                        reset.addEventListener('click', function () {
                            // 恢复到不限
                            _this11.toArray(panel.querySelectorAll('li.selected')).forEach(function (li) {
                                return li.classList.remove('selected');
                            });
                            panel.querySelector('li').classList.add('selected');

                            // 回到顶部
                            ul.scrollTop = 0;

                            // 改变tab样式
                            document.querySelector('#filter-tab-' + index).classList.remove('selected');

                            // 执行回调
                            var selected = _this11.getSelectedItems(panel);
                            _this11.config[index].callback({
                                selected: selected,
                                type: FilterBar.cbEnum.clear,
                                ext: index
                            });
                        });

                        // 确认
                        var confirm = document.createElement('div');
                        if (!_this11.config[index].confirmHtml) {
                            confirm.innerHTML = '<div class="filter-action-txt">确认</div>';
                        } else {
                            confirm.innerHTML = _this11.config[index].confirmHtml;
                        }
                        confirm.classList.add('filter-confirm');
                        confirm.addEventListener('click', function () {
                            var tab = document.querySelector('#filter-tab-' + index);
                            var selectedItems = _this11.getSelectedItems(panel);

                            // 将已选项放入缓存
                            _this11.cache[index] = selectedItems;

                            // 执行回调
                            _this11.config[index].callback({
                                selected: selectedItems,
                                type: FilterBar.cbEnum.confirm,
                                ext: index
                            });

                            // 隐藏面板
                            _this11.hidePanel(true, false);

                            // 改变tab样式
                            if (selectedItems.length) {
                                tab.classList.add('selected');
                            } else {
                                tab.classList.remove('selected');
                            }
                        });

                        action.appendChild(reset);
                        action.appendChild(confirm);
                        panel.appendChild(action);
                    }
                };

                var panel = void 0;
                if (!document.querySelector('#filter-panel-' + index)) {
                    // 不存在则创建面板
                    panel = document.createElement('div');
                    panel.id = 'filter-panel-' + index;
                    panel.classList.add('filter-panel');
                    panel.classList.add('multi');
                    panel.dataset.index = index;
                    render(panel);
                    document.querySelector('.filter-wrap').appendChild(panel);
                } else {
                    panel = document.querySelector('#filter-panel-' + index);
                    panel.innerHTML = '';
                    render(panel);
                }

                // 设置面板样式
                this.initPanelStyle(panel, index);

                // 将已选项存入缓存
                this.cache[index] = this.config[index].selectedData;
            }
        }, {
            key: 'resetSinglePanel2',
            value: function resetSinglePanel2(index) {
                this.log('\u91CD\u7F6E\u591A\u9009\u9762\u677F' + index);
                var ul = document.querySelector('#filter-panel-' + index + ' ul');

                // 如果本次重置的筛选数据为空,或者之前面板无数据,则完全初始化
                if (!this.config[index].data.length || !ul) {
                    this.renderSinglePanel2(index);
                    return;
                }

                // 创建新的筛选项元素
                var frag = document.createDocumentFragment();

                // 初始化单列多选列表的项
                this.initSinglePanel2Items(index, frag);

                // 清空原先的筛选项
                ul.innerHTML = '';

                // 添加新的筛选项到ul
                ul.appendChild(frag);

                // 更新确认按钮的文字
                var confirm = document.querySelector('#filter-panel-' + index + ' .filter-confirm');
                if (!this.config[index].confirmHtml) {
                    confirm.innerHTML = '<div class="filter-action-txt">确认</div>';
                } else {
                    confirm.innerHTML = this.config[index].confirmHtml;
                }
            }

            /**
             * 初始化单列多选列表的项
             * 
             * @param {number} index - 筛选tab次序
             * @param {any} container - 生成的项放入的容器
             * @memberof FilterBar
             */

        }, {
            key: 'initSinglePanel2Items',
            value: function initSinglePanel2Items(index, container) {
                var _this12 = this;

                var data = this.config[index].data;
                var selectedData = this.config[index].selectedData;
                data.forEach(function (item) {
                    var li = document.createElement('li');
                    li.dataset.code = item.itemCode;
                    li.textContent = item.itemName;

                    // 处理选中状态
                    if (selectedData.length === 0 && !item.itemCode) {
                        li.classList.add('selected');
                    } else if (selectedData.indexOf(item.itemCode) >= 0) {
                        li.classList.add('selected');
                    }

                    // 绑定筛选项的点击事件
                    li.addEventListener('click', function () {
                        var tab = document.querySelector('#filter-tab-' + index);
                        var panel = document.querySelector('#filter-panel-' + index);

                        // 调整选中状态
                        _this12.handleMultiSelect(li, panel);

                        // 当前的暂选项
                        var selected = _this12.getSelectedItems(panel);

                        // 改变tab样式
                        if (selected.length) {
                            tab.classList.add('selected');
                        } else {
                            tab.classList.remove('selected');
                        }

                        // 执行回调
                        _this12.config[index].callback({
                            selected: selected,
                            type: FilterBar.cbEnum.item,
                            ext: index
                        });
                    });
                    container.appendChild(li);
                });
            }

            /**
             * 渲染复杂列表
             * 
             * @param {any} index 
             * @memberof FilterBar
             */

        }, {
            key: 'renderComplexPanel',
            value: function renderComplexPanel(index) {
                var _this13 = this;

                this.log('\u521D\u59CB\u5316\u590D\u6742\u9762\u677F' + index);
                var render = function render(panel) {
                    if (!_this13.config[index].data.length) {
                        // 如果不存在筛选
                        panel.innerHTML = _this13.emptyHtml;
                    } else {
                        var ul = document.createElement('ul');
                        ul.classList.add('filter-ul');

                        // 初始化复杂列表的项
                        _this13.initComplexPanelItems(index, ul, []);

                        panel.appendChild(ul);

                        // 操作面板
                        var action = document.createElement('div');
                        action.classList.add('filter-action');

                        // 重置
                        var reset = document.createElement('div');
                        reset.innerHTML = '<div class="filter-action-txt">重置</div>';
                        reset.classList.add('filter-reset');
                        reset.addEventListener('click', function () {
                            // 恢复到不限
                            _this13.toArray(panel.querySelectorAll('.filter-sub-ul li')).forEach(function (li) {
                                li.classList.remove('selected');
                                if (li.classList.contains('filter-sub-li') && (!li.dataset.code || li.dataset.code === '不限')) {
                                    li.classList.add('selected');
                                }
                            });

                            // 清空已选的提示
                            _this13.toArray(panel.querySelectorAll('.filter-title i')).forEach(function (i) {
                                i.textContent = '';
                            });

                            // 收起已展开的子面板
                            _this13.toArray(panel.querySelectorAll('.filter-sec-wrap.opend')).forEach(function (wrap) {
                                wrap.classList.remove('opend');
                                wrap.style.height = '0';
                                wrap.style.display = 'none';
                            });

                            // 收起已展开的筛选
                            _this13.toArray(panel.querySelectorAll('.filter-more')).forEach(function (more) {
                                more.classList.remove('opend');
                                var subUl = more.parentElement.nextElementSibling;
                                subUl.style.maxHeight = '40px';
                            });

                            // 回到顶部
                            ul.scrollTop = 0;

                            // 改变tab样式
                            document.querySelector('#filter-tab-' + index).classList.remove('selected');

                            // 上次点击的组置空
                            _this13.lastFocusGroup = '';

                            // 执行回调
                            var selected = _this13.getSelectedItems(panel);
                            _this13.config[index].callback({
                                selected: selected,
                                type: FilterBar.cbEnum.clear,
                                ext: index
                            });
                        });

                        // 确认
                        var confirm = document.createElement('div');
                        if (!_this13.config[index].confirmHtml) {
                            confirm.innerHTML = '<div class="filter-action-txt">确认</div>';
                        } else {
                            confirm.innerHTML = _this13.config[index].confirmHtml;
                        }
                        confirm.classList.add('filter-confirm');
                        confirm.addEventListener('click', function () {
                            var tab = document.querySelector('#filter-tab-' + index);
                            var selectedItems = _this13.getSelectedItems(panel);

                            // 将已选项放入缓存
                            _this13.cache[index] = selectedItems;

                            // 执行回调
                            _this13.config[index].callback({
                                selected: selectedItems,
                                type: FilterBar.cbEnum.confirm,
                                ext: index
                            });

                            // 隐藏面板
                            _this13.hidePanel(true, false);

                            // 改变tab样式
                            if (Object.keys(selectedItems).length) {
                                tab.classList.add('selected');
                            } else {
                                tab.classList.remove('selected');
                            }
                        });

                        action.appendChild(reset);
                        action.appendChild(confirm);
                        panel.appendChild(action);
                    }
                };

                var panel = void 0;
                if (!document.querySelector('#filter-panel-' + index)) {
                    // 不存在则创建面板
                    panel = document.createElement('div');
                    panel.id = 'filter-panel-' + index;
                    panel.classList.add('filter-panel');
                    panel.classList.add('complex');
                    if (this.config[index].mutex) {
                        panel.classList.add('mutex');
                    }
                    panel.dataset.index = index;
                    render(panel);
                    document.querySelector('.filter-wrap').appendChild(panel);
                } else {
                    panel = document.querySelector('#filter-panel-' + index);
                    panel.innerHTML = '';
                    render(panel);
                }

                // 设置面板样式
                this.initPanelStyle(panel, index);

                // 将已选项存入缓存
                this.cache[index] = this.config[index].selectedData;
            }

            /**
             * 重置复杂列表
             * 
             * @param {any} index 
             * @memberof FilterBar
             */

        }, {
            key: 'resetComplexPanel',
            value: function resetComplexPanel(index) {
                var _this14 = this;

                this.log('\u91CD\u7F6E\u590D\u6742\u9762\u677F' + index);
                var panel = document.querySelector('#filter-panel-' + index);
                var ul = panel.querySelector('.filter-ul');

                // 如果本次重置的筛选数据为空,或者之前面板无数据,则完全初始化
                if (!this.config[index].data.length || !ul) {
                    this.renderComplexPanel(index);
                    return;
                }

                // 找出原来面板哪些是展开状态
                var opendFilters = [];
                this.toArray(ul.querySelectorAll('.filter-more.opend')).forEach(function (more) {
                    _this14.log(more.parentElement.parentElement);
                    opendFilters.push(more.parentElement.parentElement.dataset.code);
                });

                // 创建新的筛选项元素
                var frag = document.createDocumentFragment();

                // 初始化复杂列表的项
                this.initComplexPanelItems(index, frag, opendFilters);

                // 清空原先的筛选项
                ul.innerHTML = '';

                // 添加新的筛选项到ul
                ul.appendChild(frag);

                // 如果当前面板已展开,滚动上次点击的项到可视区域
                if (panel.classList.contains('on') && this.lastFocusGroup) {
                    var lastClick = panel.querySelector('.filter-ul>li[data-code="' + this.lastFocusGroup + '"]');
                    lastClick.scrollIntoView();
                }

                // 更新确认按钮的文字
                var confirm = document.querySelector('#filter-panel-' + index + ' .filter-confirm');
                if (!this.config[index].confirmHtml) {
                    confirm.innerHTML = '<div class="filter-action-txt">确认</div>';
                } else {
                    confirm.innerHTML = this.config[index].confirmHtml;
                }
            }

            /**
             * 初始化复杂列表的项
             * 
             * @param {number} index - 筛选tab次序 
             * @param {any} container - 生成的项放入的容器
             * @param {array} opendFilters - 之前已展开的组
             * @memberof FilterBar
             */

        }, {
            key: 'initComplexPanelItems',
            value: function initComplexPanelItems(index, container, opendFilters) {
                var _this15 = this;

                var data = this.config[index].data;
                var selectedData = this.config[index].selectedData;
                data.forEach(function (groupItem) {
                    // 如果items是一个数组,说明是标准筛选列表,否则就是自定义面板
                    if (Array.isArray(groupItem.items)) {
                        var groupLi = document.createElement('li');
                        groupLi.dataset.code = groupItem.groupCode;

                        // 将"不限"过滤掉
                        // const groupItemsRemoveEmpty = groupItem.items.filter(item => item.itemCode);

                        // 每个分组的标题
                        var h3 = document.createElement('h3');
                        h3.classList.add('filter-title');

                        var title = document.createElement('span');
                        title.textContent = groupItem.groupName;
                        h3.appendChild(title);

                        // 每个分组的筛选块
                        var subUl = document.createElement('ul');
                        subUl.classList.add('filter-sub-ul');

                        // 右上角显示的已选项
                        var filterTxt = [];

                        // 临时存放二级菜单节点的数组
                        var secNodeList = [];

                        groupItem.items.forEach(function (subItem, i) {
                            if (!subItem.secItems) {
                                // 一级列表
                                var subLi = document.createElement('li');
                                subLi.classList.add('filter-sub-li');
                                subLi.dataset.code = subItem.itemCode || '';
                                var subDiv = document.createElement('div');
                                var subSpan = document.createElement('span');
                                subSpan.textContent = subItem.itemName;
                                subDiv.appendChild(subSpan);
                                subLi.appendChild(subDiv);

                                // 判断选中
                                if (!selectedData[groupItem.groupCode] && !subItem.itemCode) {
                                    subLi.classList.add('selected');
                                } else if (selectedData[groupItem.groupCode] && selectedData[groupItem.groupCode].indexOf(subItem.itemCode) >= 0) {
                                    subLi.classList.add('selected');
                                    filterTxt.push(subItem.itemName);
                                }

                                // 绑定筛选项的点击事件
                                subLi.addEventListener('click', function () {
                                    var panel = document.querySelector('#filter-panel-' + index);
                                    var tab = document.querySelector('#filter-tab-' + index);

                                    if (!groupItem.multiFlag) {
                                        // 单选情况
                                        if (_this15.config[index].mutex) {
                                            // 互斥处理,恢复面板中全部筛选到不限
                                            _this15.toArray(document.querySelectorAll('#filter-panel-' + index + ' .filter-sub-ul .filter-sub-li')).forEach(function (li) {
                                                if (!li.dataset.code) {
                                                    li.classList.add('selected');
                                                } else {
                                                    li.classList.remove('selected');
                                                }
                                                li.parentElement.previousElementSibling.querySelector('i').textContent = '';
                                            });

                                            // 清除子面板的已选项
                                            _this15.toArray(document.querySelectorAll('#filter-panel-' + index + ' .filter-sec-li.selected')).forEach(function (li) {
                                                return li.classList.remove('selected');
                                            });
                                        }
                                        _this15.toArray(subUl.querySelectorAll('li.selected')).forEach(function (li) {
                                            return li.classList.remove('selected');
                                        });
                                        subLi.classList.add('selected');

                                        // 右上角已选项显示
                                        var _subTitle = '';
                                        if (subItem.itemCode) {
                                            _subTitle = subItem.itemName;
                                        }
                                        groupLi.querySelector('h3 i').textContent = _subTitle;
                                    } else {
                                        // 点击样式处理
                                        _this15.handleMultiSelect(subLi, subUl);

                                        // 右上角已选项显示
                                        var _subTitle2 = [];
                                        _this15.toArray(subUl.querySelectorAll('li.selected')).forEach(function (li) {
                                            if (li.dataset.code) {
                                                _subTitle2.push(li.querySelector('span').textContent);
                                            }
                                        });
                                        groupLi.querySelector('h3 i').textContent = _subTitle2.join('、');
                                    }

                                    // 当前的暂选项
                                    var selected = _this15.getSelectedItems(panel);

                                    // 改变tab样式
                                    if (Object.keys(selected).length || _this15.config[index].customSelected) {
                                        tab.classList.add('selected');
                                    } else {
                                        tab.classList.remove('selected');
                                    }

                                    // 将当前点击项所在的组存入缓存,以便reset之后自动滚动到可见区域中
                                    _this15.lastFocusGroup = groupItem.groupCode;

                                    // 执行回调
                                    _this15.config[index].callback({
                                        selected: selected,
                                        type: FilterBar.cbEnum.item,
                                        ext: index
                                    });
                                });

                                subUl.appendChild(subLi);
                            } else {
                                // 两级列表
                                var _subLi = document.createElement('li');
                                _subLi.classList.add('filter-sub-li');
                                _subLi.dataset.code = subItem.itemCode || '';
                                if (subItem.itemCode && subItem.itemCode !== '不限') {
                                    // 对于有子面板的li,添加特殊类以区分
                                    _subLi.classList.add('filter-li-haspanel');
                                }
                                var _subDiv = document.createElement('div');
                                var _subSpan = document.createElement('span');
                                _subSpan.textContent = subItem.itemName;
                                _subDiv.appendChild(_subSpan);
                                _subLi.appendChild(_subDiv);

                                // 判断选中
                                if (!selectedData[groupItem.groupCode] && (!subItem.itemCode || subItem.itemCode === '不限')) {
                                    _subLi.classList.add('selected');
                                }

                                _subLi.addEventListener('click', function () {
                                    var panel = document.querySelector('#filter-panel-' + index);
                                    var tab = document.querySelector('#filter-tab-' + index);
                                    var code = _subLi.dataset.code;

                                    // 清除其余项的选中
                                    _this15.toArray(subUl.querySelectorAll('.filter-sub-li.selected')).forEach(function (li) {
                                        return li.classList.remove('selected');
                                    });
                                    // 将点击项设为已选
                                    _subLi.classList.add('selected');

                                    if (!code || code === '不限') {

                                        // 收起打开的子面板
                                        var opendPanel = subUl.querySelector('.filter-sec-wrap.opend');
                                        if (opendPanel) {
                                            opendPanel.classList.remove('opend');
                                            opendPanel.style.height = '0';
                                            setTimeout(function () {
                                                opendPanel.style.display = 'none';
                                            }, 200);
                                        }

                                        var opendUl = subUl.previousElementSibling.querySelector('.filter-more.opend');
                                        if (!opendUl) {
                                            // 如果组未展开
                                            subUl.style.maxHeight = '40px';
                                        } else {
                                            // 组面板已展开
                                            // 计算当前组的高度
                                            var subLines = 1;
                                            var liCount = subUl.querySelectorAll('.filter-sub-li').length;
                                            if (liCount % 4 > 0) {
                                                subLines = parseInt(liCount / 4) + 1;
                                            } else {
                                                subLines = liCount / 4;
                                            }
                                            var ulHeight = 36 * subLines + (subLines - 1) * 8;

                                            subUl.style.maxHeight = ulHeight + 'px';
                                        }

                                        // 清除所有子面板的选中
                                        _this15.toArray(subUl.querySelectorAll('.filter-sec-li.selected')).forEach(function (li) {
                                            return li.classList.remove('selected');
                                        });

                                        // 清除已选提示文字
                                        _subLi.parentElement.previousElementSibling.querySelector('i').textContent = '';

                                        // 当前的暂选项
                                        var selected = _this15.getSelectedItems(panel);

                                        // 改变tab样式
                                        if (Object.keys(selected).length || _this15.config[index].customSelected) {
                                            tab.classList.add('selected');
                                        } else {
                                            tab.classList.remove('selected');
                                        }

                                        // 将当前点击项所在的组存入缓存,以便reset之后自动滚动到可见区域中
                                        _this15.lastFocusGroup = groupItem.groupCode;

                                        // 执行回调
                                        _this15.config[index].callback({
                                            selected: selected,
                                            type: FilterBar.cbEnum.item,
                                            ext: index
                                        });
                                    } else {
                                        // 点击的是普通项
                                        var secPanel = subUl.querySelector('.filter-sec-wrap[data-forcode="' + code + '"]');
                                        if (secPanel) {
                                            // 默认选中 不限
                                            var secPanelBXSelected = secPanel.querySelector(".filter-sec-li.selected") ? false : true;
                                            var secPanelBXCode = secPanel.querySelector('.filter-sec-li[data-code=""]');
                                            if (secPanel && secPanelBXSelected && secPanelBXCode) {
                                                secPanelBXCode.classList.add("selected");
                                            }
                                            if (secPanel.classList.contains('opend')) {
                                                // 子面板在打开的情况下,组被人为收起,这里仅修改组高度
                                                if (subUl.style.maxHeight === '40px') {
                                                    var secLines = secPanel.dataset.lines;
                                                    var secPanelHeight = secLines * 44 + 8;
                                                    subUl.style.maxHeight = 52 + secPanelHeight + 'px';
                                                    return;
                                                }

                                                // 隐藏
                                                secPanel.classList.remove('opend');
                                                secPanel.style.height = '0';

                                                var _opendUl = subUl.previousElementSibling.querySelector('.filter-more.opend');
                                                if (!_opendUl) {
                                                    // 如果组未展开
                                                    subUl.style.maxHeight = '40px';
                                                } else {
                                                    // 组面板已展开
                                                    // 计算当前组的高度
                                                    var _subLines = 1;
                                                    var _liCount = subUl.querySelectorAll('.filter-sub-li').length;
                                                    if (_liCount % 4 > 0) {
                                                        _subLines = parseInt(_liCount / 4) + 1;
                                                    } else {
                                                        _subLines = _liCount / 4;
                                                    }
                                                    var _ulHeight = 36 * _subLines + (_subLines - 1) * 8;

                                                    subUl.style.maxHeight = _ulHeight + 'px';
                                                }
                                                setTimeout(function () {
                                                    // 隐藏子面板
                                                    secPanel.style.display = 'none';
                                                }, 200);
                                            } else {
                                                // 先隐藏所有子面板
                                                _this15.toArray(subUl.querySelectorAll('.filter-sec-wrap.opend')).forEach(function (wrap) {
                                                    wrap.classList.remove('opend');
                                                    wrap.style.height = '0';
                                                    wrap.style.display = 'none';
                                                });

                                                // 再显示对应的子面板
                                                secPanel.classList.add('opend');
                                                secPanel.style.display = 'block';
                                                var _secLines = secPanel.dataset.lines;
                                                var _secPanelHeight = _secLines * 44 + 8;
                                                setTimeout(function () {
                                                    // 设置子面板高度
                                                    secPanel.style.height = _secPanelHeight + 'px';

                                                    var opendUl = subUl.previousElementSibling.querySelector('.filter-more.opend');
                                                    if (!opendUl) {
                                                        // 如果组未展开
                                                        subUl.style.maxHeight = 52 + _secPanelHeight + 'px';
                                                    } else {
                                                        // 组面板已展开
                                                        // 计算当前组的高度
                                                        var _subLines2 = 1;
                                                        var _liCount2 = subUl.querySelectorAll('.filter-sub-li').length;
                                                        if (_liCount2 % 4 > 0) {
                                                            _subLines2 = parseInt(_liCount2 / 4) + 1;
                                                        } else {
                                                            _subLines2 = _liCount2 / 4;
                                                        }
                                                        var _ulHeight2 = 36 * _subLines2 + (_subLines2 - 1) * 8;

                                                        subUl.style.maxHeight = _ulHeight2 + _secPanelHeight + 12 + 'px';
                                                    }
                                                }, 0);
                                            }
                                        }
                                    }
                                });

                                subUl.appendChild(_subLi);

                                // 生成子面板筛选
                                var secItems = subItem.secItems;
                                if (secItems.length) {
                                    var wrapLi = document.createElement('li');
                                    wrapLi.classList.add('filter-sec-wrap');
                                    var lines = secItems.length % 4 === 0 ? secItems.length / 4 : parseInt(secItems.length / 4) + 1;
                                    wrapLi.dataset.lines = lines;
                                    wrapLi.dataset.forcode = subItem.itemCode || '';
                                    var triangle = document.createElement('i');
                                    triangle.classList.add('filter-triangle');

                                    // 计算三角箭头的left值
                                    var idx = i % 4;
                                    var liWidth = (window.innerWidth - 10) / 4;
                                    var left = liWidth * idx + (liWidth - 10) / 2 - 8;
                                    triangle.style.left = left + 'px';
                                    wrapLi.appendChild(triangle);
                                    var secUl = document.createElement('ul');
                                    secUl.classList.add('filter-sec-ul');

                                    // 子面板列表
                                    secItems.forEach(function (secItem, i) {
                                        var secLi = document.createElement('li');
                                        secLi.classList.add('filter-sec-li');
                                        secLi.dataset.code = secItem.itemCode || '';
                                        var secDiv = document.createElement('div');
                                        var secSpan = document.createElement('span');
                                        secSpan.textContent = secItem.itemName;
                                        secDiv.appendChild(secSpan);
                                        secLi.appendChild(secDiv);

                                        // 判断选中
                                        if (selectedData[groupItem.groupCode] && selectedData[groupItem.groupCode].indexOf(secItem.itemCode) >= 0) {
                                            secLi.classList.add('selected');
                                            var code = subItem.itemCode;
                                            subUl.querySelector('.filter-sub-li[data-code="' + code + '"]').classList.add('selected');

                                            // 右上角已选项显示
                                            var _subTitle3 = '';
                                            var itemName = secItem.itemName;
                                            if (i === 0) {
                                                // 第一项默认为不限
                                                _subTitle3 = code;
                                            } else {
                                                _subTitle3 = code + '-' + itemName;
                                            }
                                            filterTxt.push(_subTitle3);
                                        }

                                        secLi.addEventListener('click', function () {
                                            if (_this15.config[index].mutex) {
                                                // 互斥处理,恢复面板中全部筛选到不限
                                                _this15.toArray(document.querySelectorAll('#filter-panel-' + index + ' .filter-sub-ul .filter-sub-li')).forEach(function (li) {
                                                    if (!li.dataset.code) {
                                                        li.classList.add('selected');
                                                    } else {
                                                        li.classList.remove('selected');
                                                    }
                                                    li.parentElement.previousElementSibling.querySelector('i').textContent = '';
                                                });
                                            }

                                            // 子面板中的选中调整
                                            _this15.toArray(subUl.querySelectorAll('.filter-sec-li.selected')).forEach(function (li) {
                                                return li.classList.remove('selected');
                                            });
                                            secLi.classList.add('selected');

                                            // 父面板的选中调整
                                            _this15.toArray(subUl.querySelectorAll('.filter-sub-li.selected')).forEach(function (li) {
                                                return li.classList.remove('selected');
                                            });
                                            var forcode = wrapLi.dataset.forcode;
                                            var parentLi = subUl.querySelector('.filter-sub-li[data-code="' + forcode + '"]');
                                            if (parentLi) {
                                                parentLi.classList.add('selected');
                                            }

                                            // 右上角已选项显示
                                            var subTitle = '';
                                            var itemName = secItem.itemName;
                                            if (i === 0) {
                                                // 第一项默认为不限
                                                subTitle = forcode;
                                            } else {
                                                subTitle = forcode + '-' + itemName;
                                            }
                                            groupLi.querySelector('h3 i').textContent = subTitle;

                                            var panel = document.querySelector('#filter-panel-' + index);
                                            var tab = document.querySelector('#filter-tab-' + index);

                                            // 当前的暂选项
                                            var selected = _this15.getSelectedItems(panel);

                                            // 改变tab样式
                                            if (Object.keys(selected).length || _this15.config[index].customSelected) {
                                                tab.classList.add('selected');
                                            } else {
                                                tab.classList.remove('selected');
                                            }

                                            // 将当前点击项所在的组存入缓存,以便reset之后自动滚动到可见区域中
                                            _this15.lastFocusGroup = groupItem.groupCode;

                                            // 执行回调
                                            _this15.config[index].callback({
                                                selected: selected,
                                                type: FilterBar.cbEnum.item,
                                                ext: index
                                            });
                                        });
                                        secUl.appendChild(secLi);
                                    });
                                    wrapLi.appendChild(secUl);
                                    secNodeList.push(wrapLi);
                                }

                                // 一行展示4个项,每隔4个元素就将临时存放二级菜单节点的数组中剩下的内容插入
                                if ((i + 1) % 4 === 0) {
                                    while (secNodeList.length) {
                                        subUl.appendChild(secNodeList.shift());
                                    }
                                }
                            }
                        });

                        // 如果secNodeList中依然有元素,说明是两级筛选,并且最后一行的的子面板还没有加入到subUl中
                        if (secNodeList.length) {
                            while (secNodeList.length) {
                                subUl.appendChild(secNodeList.shift());
                            }
                        }

                        var subTitle = document.createElement('i');
                        subTitle.textContent = filterTxt.join('、');
                        h3.appendChild(subTitle);

                        groupLi.appendChild(h3);
                        groupLi.appendChild(subUl);

                        // 多于4个筛选项,则显示展开更多的箭头
                        if (groupItem.items.length > 4) {
                            var more = document.createElement('div');
                            more.classList.add('filter-more');
                            more.addEventListener('click', function () {
                                if (!more.classList.contains('opend')) {
                                    more.classList.add('opend');
                                    var currentUl = groupLi.querySelector('.filter-sub-ul');
                                    var scrollHeight = currentUl.scrollHeight;
                                    currentUl.style.maxHeight = scrollHeight + 'px';
                                } else {
                                    more.classList.remove('opend');
                                    var _currentUl = groupLi.querySelector('.filter-sub-ul');
                                    _currentUl.style.maxHeight = '40px';
                                }
                            });

                            // 如果之前该筛选为展开,则自动展开
                            if (opendFilters.indexOf(groupItem.groupCode) >= 0) {
                                more.classList.add('opend');
                                var lines = 1;
                                if (groupItem.items.length % 4 > 0) {
                                    lines = parseInt(groupItem.items.length / 4) + 1;
                                } else {
                                    lines = groupItem.items.length / 4;
                                }
                                var scrollHeight = 36 * lines + (lines - 1) * 8;
                                var currentUl = groupLi.querySelector('.filter-sub-ul');
                                currentUl.style.maxHeight = scrollHeight + 'px';
                            }

                            h3.classList.add('more');
                            h3.appendChild(more);
                        }

                        container.appendChild(groupLi);
                    } else {
                        container.appendChild(groupItem.items);
                    }
                });
            }
        }]);

        return FilterBar;
    }();

    /**
     * 回调类型
     */


    FilterBar.cbEnum = {
        /**
         * 确认
         */
        confirm: 'confirm',

        /**
         * 重置
         */
        clear: 'clear',

        /**
         * 项
         */
        item: 'item',

        /**
         * 取消
         */
        cancel: 'cancel'
    };

    /**
     * 开启调试日志
     */
    FilterBar.debug = false;

    return FilterBar;
});


 // 单选数据
        var data1 = [{
            itemName: '综合排序',
            itemCode: '',
            default: true
        }, {
            itemName: '新品推荐',
            itemCode: '37',
            default: false
        }, {
            itemName: '价格从低到高价格从低到高价格从低到高价格从低到高价格从低到高价格从低到高价格从低到高',
            itemCode: '3',
            default: false
        }, {
            itemName: '价格从高到低',
            itemCode: '2',
            default: false
        }, {
            itemName: '好评度从高到低',
            itemCode: '27',
            default: false
        }];
        // 多选数据
        var data2 = [{ "default": true, "itemCode": "", "itemName": "不限" }, { "default": false, "itemCode": "playMethod=401", "itemName": "香港+迪士尼" }, { "default": false, "itemCode": "playMethod=865", "itemName": "厦门+鼓浪屿" }, { "default": false, "itemCode": "playMethod=3533", "itemName": "珠海长隆" }, { "default": false, "itemCode": "playMethod=405", "itemName": "香港+海洋公园+迪士尼香港+海洋公园+迪士尼香港+海洋公园+迪士尼香港+海洋公园+迪士尼香港+海洋公园+迪士尼香港+海洋公园+迪士尼香港+海洋公园+迪士尼香港+海洋公园+迪士尼" }, { "default": false, "itemCode": "playMethod=3532", "itemName": "广州长隆" }, { "default": false, "itemCode": "playMethod=402", "itemName": "香港+迪士尼+澳门" }, { "default": false, "itemCode": "playMethod=232", "itemName": "澳门一地" }, { "default": false, "itemCode": "playMethod=887", "itemName": "拉萨+纳木错" }, { "default": false, "itemCode": "playMethod=848", "itemName": "青岛一地" }, { "default": false, "itemCode": "playMethod=1104", "itemName": "三亚湾+亚龙湾" }, { "default": false, "itemCode": "playMethod=1144", "itemName": "华东三市+水乡" }, { "default": false, "itemCode": "playMethod=1161", "itemName": "拉萨+纳木错+羊湖+日喀则" }, { "default": false, "itemCode": "playMethod=3559", "itemName": "华东三市+迪士尼" }, { "default": false, "itemCode": "playMethod=408", "itemName": "香港一地" }];
        // 互斥数据
        var data4 = [{"groupCode":"地标","groupName":"地标","multiFlag":false,"items":[{"itemCode":"","itemName":"不限","default":true},{"itemCode":"972","itemName":"K11购物艺术中心","default":false},{"itemCode":"935","itemName":"七浦路","default":false},{"itemCode":"950","itemName":"上海书城","default":false},{"itemCode":"947","itemName":"上海博物馆","default":false},{"itemCode":"959","itemName":"上海商城","default":false},{"itemCode":"921","itemName":"上海大厦","default":false},{"itemCode":"973","itemName":"上海广场(原无限度)","default":false},{"itemCode":"963","itemName":"上海戏剧学院","default":false},{"itemCode":"967","itemName":"上海电视台","default":false},{"itemCode":"949","itemName":"上海音乐厅","default":false},{"itemCode":"1067","itemName":"上海音乐学院","default":false}]},{"groupCode":"火车站","groupName":"火车站","multiFlag":false,"items":[{"itemCode":"","itemName":"不限","default":true},{"itemCode":"13257","itemName":"上海南站","default":false},{"itemCode":"6037","itemName":"上海火车南站","default":false},{"itemCode":"6039","itemName":"上海站","default":false},{"itemCode":"6038","itemName":"上海虹桥站","default":false},{"itemCode":"6036","itemName":"上海西站","default":false},{"itemCode":"5844","itemName":"北京北站","default":false},{"itemCode":"5846","itemName":"北京站","default":false},{"itemCode":"5858","itemName":"朝阳站","default":false},{"itemCode":"13312","itemName":"松江站","default":false}]},{"groupCode":"地铁","groupName":"地铁(2级菜单)","multiFlag":false,"items":[{"itemCode":"10号线","itemName":"10号线","secItems":[{"itemCode":"","itemName":"不限","default":false},{"itemCode":"7653","itemName":"上海图书馆","default":false},{"itemCode":"7702","itemName":"南京东路","default":false},{"itemCode":"7701","itemName":"四川北路","default":false},{"itemCode":"7697","itemName":"天潼路","default":false},{"itemCode":"7686","itemName":"新天地","default":false},{"itemCode":"7810","itemName":"海伦路","default":false},{"itemCode":"7698","itemName":"老西门","default":false},{"itemCode":"7709","itemName":"豫园","default":false},{"itemCode":"7669","itemName":"陕西南路","default":false}]},{"itemCode":"11号线","itemName":"11号线","secItems":[{"itemCode":"","itemName":"不限","default":false},{"itemCode":"7835","itemName":"三林东","default":false},{"itemCode":"7836","itemName":"上海游泳馆","default":false},{"itemCode":"7643","itemName":"徐家汇","default":false},{"itemCode":"7634","itemName":"江苏路","default":false}]},{"itemCode":"1号线","itemName":"1号线","secItems":[{"itemCode":"","itemName":"不限","default":false},{"itemCode":"7839","itemName":"上海火车站","default":false},{"itemCode":"7682","itemName":"人民广场","default":false},{"itemCode":"7663","itemName":"常熟路","default":false},{"itemCode":"7643","itemName":"徐家汇","default":false},{"itemCode":"7676","itemName":"新闸路","default":false},{"itemCode":"7671","itemName":"汉中路","default":false},{"itemCode":"7657","itemName":"衡山路","default":false},{"itemCode":"7669","itemName":"陕西南路","default":false},{"itemCode":"7681","itemName":"黄陂南路","default":false}]},{"itemCode":"2号线","itemName":"2号线","secItems":[{"itemCode":"","itemName":"不限","default":false},{"itemCode":"7809","itemName":"东昌路","default":false},{"itemCode":"7682","itemName":"人民广场","default":false},{"itemCode":"7702","itemName":"南京东路","default":false},{"itemCode":"7672","itemName":"南京西路","default":false},{"itemCode":"7634","itemName":"江苏路","default":false},{"itemCode":"7833","itemName":"科技馆","default":false},{"itemCode":"7730","itemName":"陆家嘴","default":false},{"itemCode":"7655","itemName":"静安寺","default":false}]},{"itemCode":"3号线","itemName":"3号线","secItems":[{"itemCode":"","itemName":"不限","default":false},{"itemCode":"7839","itemName":"上海火车站","default":false},{"itemCode":"7816","itemName":"东宝兴路","default":false},{"itemCode":"7688","itemName":"宝山路","default":false}]},{"itemCode":"4号线","itemName":"4号线","secItems":[{"itemCode":"","itemName":"不限","default":false},{"itemCode":"7839","itemName":"上海火车站","default":false},{"itemCode":"7666","itemName":"东安路","default":false},{"itemCode":"7811","itemName":"临平路","default":false},{"itemCode":"7725","itemName":"南浦大桥","default":false},{"itemCode":"7675","itemName":"大木桥路","default":false},{"itemCode":"7744","itemName":"大连路","default":false},{"itemCode":"7688","itemName":"宝山路","default":false},{"itemCode":"7750","itemName":"杨树浦路","default":false},{"itemCode":"7753","itemName":"浦东大道","default":false},{"itemCode":"7810","itemName":"海伦路","default":false},{"itemCode":"7711","itemName":"西藏南路","default":false},{"itemCode":"7685","itemName":"鲁班路","default":false}]},{"itemCode":"7号线","itemName":"7号线","secItems":[{"itemCode":"","itemName":"不限","default":false},{"itemCode":"7666","itemName":"东安路","default":false},{"itemCode":"7663","itemName":"常熟路","default":false},{"itemCode":"7651","itemName":"昌平路","default":false},{"itemCode":"7660","itemName":"肇嘉浜路","default":false},{"itemCode":"7825","itemName":"长寿路","default":false},{"itemCode":"7655","itemName":"静安寺","default":false}]},{"itemCode":"8号线","itemName":"8号线","secItems":[{"itemCode":"","itemName":"不限","default":false},{"itemCode":"7677","itemName":"中兴路","default":false},{"itemCode":"7834","itemName":"中华艺术宫","default":false},{"itemCode":"7682","itemName":"人民广场","default":false},{"itemCode":"7691","itemName":"大世界","default":false},{"itemCode":"7680","itemName":"曲阜路","default":false},{"itemCode":"7698","itemName":"老西门","default":false},{"itemCode":"7819","itemName":"西藏北路","default":false},{"itemCode":"7711","itemName":"西藏南路","default":false},{"itemCode":"7707","itemName":"陆家浜路","default":false}]},{"itemCode":"9号线","itemName":"9号线","secItems":[{"itemCode":"","itemName":"不限","default":false},{"itemCode":"7820","itemName":"商城路","default":false},{"itemCode":"7673","itemName":"嘉善路","default":false},{"itemCode":"7722","itemName":"小南门","default":false},{"itemCode":"7643","itemName":"徐家汇","default":false},{"itemCode":"7678","itemName":"打浦桥","default":false},{"itemCode":"7660","itemName":"肇嘉浜路","default":false},{"itemCode":"7707","itemName":"陆家浜路","default":false},{"itemCode":"7690","itemName":"马当路","default":false}]}]},{"groupCode":"长途汽车站","groupName":"长途汽车站","multiFlag":false,"items":[{"itemCode":"","itemName":"不限","default":true},{"itemCode":"6625","itemName":"上海五角场长途汽车站","default":false},{"itemCode":"6631","itemName":"上海南浦大桥旅游站","default":false},{"itemCode":"6623","itemName":"上海嘉定汽车站","default":false},{"itemCode":"6633","itemName":"上海太平洋长途客运站","default":false}]}]
        
        // 复杂数据
        var data5 = [{"groupCode":"景点区域","groupName":"景点区域(2级菜单)","multiFlag":false,"items":[{"itemCode":"不限","itemName":"不限","secItems":[]},{"itemCode":"河北","itemName":"河北","secItems":[{"itemCode":"province=3","itemName":"不限"},{"itemCode":"city=4","itemName":"石家庄"},{"itemCode":"city=9","itemName":"保定"},{"itemCode":"city=7","itemName":"邯郸"},{"itemCode":"city=5","itemName":"唐山"},{"itemCode":"city=6","itemName":"秦皇岛"},{"itemCode":"city=10","itemName":"张家口"},{"itemCode":"city=8","itemName":"邢台"},{"itemCode":"city=11","itemName":"承德"},{"itemCode":"city=13","itemName":"廊坊"}]},{"itemCode":"北京","itemName":"北京","secItems":[{"itemCode":"province=1","itemName":"不限"},{"itemCode":"city=1","itemName":"北京"}]},{"itemCode":"广东","itemName":"广东","secItems":[{"itemCode":"province=228","itemName":"不限"},{"itemCode":"city=229","itemName":"广州"},{"itemCode":"city=231","itemName":"深圳"},{"itemCode":"city=234","itemName":"佛山"},{"itemCode":"city=245","itemName":"清远"},{"itemCode":"city=230","itemName":"韶关"}]},{"itemCode":"云南","itemName":"云南","secItems":[{"itemCode":"province=312","itemName":"不限"},{"itemCode":"city=315","itemName":"昆明"},{"itemCode":"city=320","itemName":"丽江"},{"itemCode":"city=326","itemName":"西双版纳"},{"itemCode":"city=327","itemName":"大理"},{"itemCode":"city=3889","itemName":"迪庆"}]},{"itemCode":"山东","itemName":"山东","secItems":[{"itemCode":"province=159","itemName":"不限"},{"itemCode":"city=161","itemName":"青岛"},{"itemCode":"city=168","itemName":"济宁"},{"itemCode":"city=174","itemName":"临沂"},{"itemCode":"city=160","itemName":"济南"},{"itemCode":"city=167","itemName":"潍坊"}]},{"itemCode":"浙江","itemName":"浙江","secItems":[{"itemCode":"province=96","itemName":"不限"},{"itemCode":"city=100","itemName":"杭州"},{"itemCode":"city=111","itemName":"绍兴"}]},{"itemCode":"四川","itemName":"四川","secItems":[{"itemCode":"province=278","itemName":"不限"},{"itemCode":"city=297","itemName":"阿坝"},{"itemCode":"city=279","itemName":"成都"}]},{"itemCode":"江苏","itemName":"江苏","secItems":[{"itemCode":"province=80","itemName":"不限"},{"itemCode":"city=87","itemName":"苏州"},{"itemCode":"city=82","itemName":"南京"}]},{"itemCode":"辽宁","itemName":"辽宁","secItems":[{"itemCode":"province=41","itemName":"不限"},{"itemCode":"city=42","itemName":"沈阳"}]},{"itemCode":"湖北","itemName":"湖北","secItems":[{"itemCode":"province=198","itemName":"不限"},{"itemCode":"city=199","itemName":"武汉"},{"itemCode":"city=3668","itemName":"神农架"}]},{"itemCode":"江西","itemName":"江西","secItems":[{"itemCode":"province=145","itemName":"不限"},{"itemCode":"city=3891","itemName":"九江"},{"itemCode":"city=156","itemName":"上饶"}]},{"itemCode":"陕西","itemName":"陕西","secItems":[{"itemCode":"province=339","itemName":"不限"},{"itemCode":"city=340","itemName":"西安"}]},{"itemCode":"福建","itemName":"福建","secItems":[{"itemCode":"province=135","itemName":"不限"},{"itemCode":"city=140","itemName":"泉州"},{"itemCode":"city=137","itemName":"厦门"}]},{"itemCode":"湖南","itemName":"湖南","secItems":[{"itemCode":"province=212","itemName":"不限"},{"itemCode":"city=213","itemName":"长沙"},{"itemCode":"city=227","itemName":"湘西"}]}]},{"groupCode":"旅游类型","groupName":"旅游类型","multiFlag":false,"items":[{"default":true,"itemCode":"","itemName":"不限"},{"default":false,"itemCode":"category=171818132","itemName":"景点+酒店"},{"default":false,"itemCode":"category=18182","itemName":"机票+酒店"}]},{"groupCode":"价格范围","groupName":"价格范围","multiFlag":false,"items":[{"default":true,"itemCode":"","itemName":"不限"},{"default":false,"itemCode":"price=1","itemName":"100元以下"},{"default":false,"itemCode":"price=2","itemName":"101-500元"},{"default":false,"itemCode":"price=3","itemName":"501-1000元"},{"default":false,"itemCode":"price=4","itemName":"1001-2000元"},{"default":false,"itemCode":"price=5","itemName":"2001-4000元"},{"default":false,"itemCode":"price=6","itemName":"4001-6000元"},{"default":false,"itemCode":"price=7","itemName":"6001-10000元"},{"default":false,"itemCode":"price=8","itemName":"10001元以上"}]},{"groupCode":"出发地","groupName":"出发地","multiFlag":false,"items":[{"default":true,"itemCode":"","itemName":"不限"},{"default":false,"itemCode":"districtId=56","itemName":"南京"},{"default":false,"itemCode":"districtId=9","itemName":"上海"},{"default":false,"itemCode":"districtId=69","itemName":"杭州"},{"default":false,"itemCode":"districtId=57","itemName":"无锡"}]},{"groupCode":"酒店星级","groupName":"酒店星级","multiFlag":false,"items":[{"default":true,"itemCode":"","itemName":"不限"},{"default":false,"itemCode":"hotelStar=100101","itemName":"五星级/豪华型"},{"default":false,"itemCode":"hotelStar=102103","itemName":"四星级/品质型"},{"default":false,"itemCode":"hotelStar=109","itemName":"其他/其他"},{"default":false,"itemCode":"hotelStar=104105","itemName":"三星级/舒适型"},{"default":false,"itemCode":"hotelStar=106107","itemName":"二星级/简约型"}]},{"groupCode":"产品等级","groupName":"产品等级(多选)","multiFlag":true,"items":[{"default":true,"itemCode":"","itemName":"不限"},{"default":false,"itemCode":"productGrade=0","itemName":"3钻"},{"default":false,"itemCode":"productGrade=1","itemName":"4钻"},{"default":false,"itemCode":"productGrade=2","itemName":"5钻"}]},{"groupCode":"自主品牌","groupName":"自主品牌(多选)","multiFlag":true,"items":[{"default":true,"itemCode":"","itemName":"不限"},{"default":false,"itemCode":"brandLvTuTagId=2365","itemName":"驴悦亲子"},{"default":false,"itemCode":"brandLvTuTagId=3504","itemName":"逍遥驴行"}]}];
        var filterObj;
        var params = [{
            tabName: '单选',
            selectedData: '',
            replace: true,
            data: data1,
            callback: cb
        }, {
            tabName: '多选',
            selectedData: [],
            data: data2,
            multi: true,
            callback: cb
        }, {
            tabName: '无面板',
            selectedData: {},
            callback: cb
        }, {
            tabName: '互斥',
            selectedData: {},
            data: data4,
            mutex: true,
            callback: cb
        }, {
            tabName: '复杂',
            selectedData: {
                '价格范围': ['price=2'],
                '景点区域': ['city=9']
            },
            data: data5,
            callback: cb
        }];
        filterObj = new FilterBar(params);
        function cb(data) {
            console.log(data);
        }
.filter-wrap {
    color: #666;
    font-size: 14px;
    margin: 0;
    padding-left: 0;
    padding-right: 0;
    position: fixed;
    left: 0;
    top: 0;
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
    width: 100%;
    height: 45px;
    background-color: #ffffff;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-direction: row;
    flex-direction: row;
    -webkit-flex-wrap: nowrap;
    flex-wrap: nowrap;
    z-index: 300;
    box-sizing: border-box;
}

.filter-wrap * {
    box-sizing: border-box;
}

.filter-wrap ul {
    margin: 0;
    padding: 0;
}

.filter-wrap ul, .filter-wrap li {
    list-style: none;
}

.filter-tab {
    -webkit-box-flex: 1;
    -webkit-flex-grow: 1;
    flex-grow: 1;
    -webkit-flex-shrink: 1;
    flex-shrink: 1;
    -webkit-flex-basis: 0%;
    flex-basis: 0%;
    background-color: #fff;
    color: #666;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    flex-direction: column;
    -webkit-flex-wrap: nowrap;
    flex-wrap: nowrap;
    text-align: center;
    border-image: url() 2 stretch;
    -webkit-border-image: url() 2 stretch;
    border-width: 0 0 1px 0;
    border-style: solid;
    z-index: 301;
    position: relative;
}

.filter-tab div {
    width: 100%;
    text-align: center;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    justify-content: center;
    display: flex;
    overflow: hidden;
}

.filter-tab span {
    display: -webkit-box;
    text-overflow: ellipsis;
    -webkit-line-clamp: 1;
    position: relative;
    -webkit-box-pack: center;
    justify-content: center;
    margin: 0 15px 0 4px;
    line-height: 50px;
    -webkit-box-orient: vertical;
}

.filter-tab.selected span{
    color: #d30775;
}

.filter-tab span:after {
    border: 5px solid transparent;
    border-top: 5px solid #666;
    width: 0;
    height: 0;
    top: 21px;
    right: -14px;
    position: absolute;
    content: ' ';
    transition: all 0.3s;
}

.filter-tab.filter-tab-radio span:after {
    border: 0;
}

.filter-tab.selected span:after {
    border-top-color: #d30775;
}

.filter-tab.on span:after {
    -webkit-transform: translateY(-50%) rotate(180deg);
     transform: translateY(-50%) rotate(180deg); 
}

.filter-mask {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0,0,0,.5);
    z-index: 1;
}

html.filter-shown, body.filter-shown {
    overflow-y: hidden;
    height: 100%;
}

body.filter-shown .filter-mask {
    display: block;
}

.filter-panel {
    display: none;
    margin: 0;
    padding-left: 0;
    padding-right: 0;
    position: absolute;
    /* max-height: 0; */
    top: 45px;
    left: 0;
    width: 100%;
    background-color: #fff;
    min-width: 320px;
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-transition: -webkit-transform .3s ease-out;
    transition: -webkit-transform .3s ease-out;
    transition: transform .3s ease-out;
    transition: transform .3s ease-out,-webkit-transform .3s ease-out;
}

.filter-panel.on {
    /* max-height: 250px; */
}

.filter-panel ul {
    padding-left: 10px;
    width: 100%;
    overflow: auto;
    -webkit-overflow-scrolling: touch;
    overflow-scrolling: touch;
}

.filter-panel ul li {
    width: 100%;
    height: 45px;
    line-height: 45px;
    font-size: 14px;
    border-image: url() 2 stretch;
    -webkit-border-image: url() 2 stretch;
    border-width: 0 0 1px 0;
    border-style: solid;
    position: relative;
    padding-right: 32px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.filter-panel ul li.selected {
    color: #d30775;
}

.filter-panel ul li.selected:after {
    content: "";
    width: 7px;
    height: 12px;
    border-bottom: 1px solid #d30775;
    border-right: 1px solid #d30775;
    position: absolute;
    right: 10px;
    top: 17px;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

.filter-panel.multi ul li:before {
    content: "";
    width: 16px;
    height: 16px;
    border: 1px solid #aaa;
    border-radius: 2px;
    position: absolute;
    right: 8px;
    top: 14px;
}

.filter-panel.multi ul li.selected:before { 
    border-color: #d30775;
}

.filter-panel.multi ul li.selected:after { 
    right: 14px;
    top: 16px;
    width: 5px;
    height: 10px;
}

.filter-panel.complex li {
    padding-right: 0;
    height: auto;
}

.filter-panel.complex li:last-child {
    border-bottom: 0;
}

.filter-panel.complex li .filter-title {
    color: #333;
    font-size: 14px;
    margin: 0;
    font-weight: normal;
    padding-right: 10px;
}

.filter-panel.complex li .filter-title.more {
    padding-right: 40px;
}

.filter-panel.complex li .filter-title span {
    color: #666;
}

.filter-panel.complex li .filter-title i {
    color: #d30775;
    font-size: 12px;
    float: right;
    display: block;
    width: 150px;
    overflow: hidden;
    text-overflow: ellipsis;
    text-align: right;
    height: 45px;
    line-height: 45px;
    font-style: normal;
}

.filter-panel .filter-sub-ul {
    overflow: hidden;
    padding-left: 0;
    max-height: 40px; 
    margin-bottom: 16px;
    -webkit-transition: max-height .3s ease-out;
    transition: max-height .3s ease-out;
}

.filter-panel .filter-sub-ul li {
    width: 25%;
    float: left;
    font-size: 12px;
    border: 0;
    padding-right: 0;
    background: #fff;
    z-index: 2;
}

.filter-panel .filter-sub-ul li:nth-of-type(1) div,
.filter-panel .filter-sub-ul li:nth-of-type(2) div,
.filter-panel .filter-sub-ul li:nth-of-type(3) div,
.filter-panel .filter-sub-ul li:nth-of-type(4) div{
    margin-top: 0;
}

.filter-panel .filter-sub-ul li div {
    height: 36px;
    margin: 8px 10px 0 0;
    border: 1px solid #F4F4F4;
    border-radius: 3px;
    background: #F4F4F4;
}

.filter-panel .filter-sub-ul li div span {
    display: -webkit-box;
    max-height: 36px;
    line-height: 18px;
    text-align: center;
    overflow: hidden;
    text-overflow: ellipsis;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    white-space: normal;
    position: relative;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
}

.filter-panel .filter-sub-ul li.selected div {
    border-color: #d30775;
    background: #fff;
}

.filter-panel .filter-sub-ul li.selected:after {
    border: 0;
}

.filter-action {
    position: absolute;
    width: 100%;
    bottom: 0;
}

.filter-action>div {
    height: 48px;
    width: 50%;
    float: left;
    text-align: center;
    letter-spacing: 2px;
}

.filter-action-txt {
    line-height: 47px;
}

.filter-reset {
    background: #fff;
    -webkit-border-image: url() 2 stretch;
    border-width: 1px 0 1px 0;
    border-style: solid;
}

.filter-confirm {
    background: #d30775;
    color: #fff;
}

.filter-more {
    position: absolute;
    right: 0;
    top: 0px;
    bottom: 10px;
    width: 40px;
    height: 45px;
    background: #fff;
}

.filter-more:after {
    content: "";
    border-top: 1px solid #777;
    border-right: 1px solid #777;
    -webkit-transform: translateY(50%) rotate(135deg);
    transform: translateY(50%) rotate(135deg);
    position: absolute;
    top: 10px;
    right: 15px;
    width: 9px;
    height: 9px;
    transition: all 0.3s;
}

.filter-more.opend:after {
    -webkit-transform: translateY(50%) rotate(-45deg);
    transform: translateY(50%) rotate(-45deg);
    top: 15px;
}

.filter-nodata {
    text-align: center;
    position: relative;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    margin-top: -10px;
}

.filter-panel .filter-sub-ul .filter-sec-wrap {
    width: 100%;
    margin-bottom: 2px;
    padding-right: 10px;
    margin-top: 10px;
    overflow: initial;
    z-index: 1;
    height: 0;
    display: none;
    transition: height .2s ease-out;
}

.filter-panel .filter-sub-ul .filter-sec-wrap .filter-triangle {
    border-style: solid;
    border-width: 0px 8px 7px 8px;
    border-color: transparent transparent #F4F4F4 transparent;
    position: absolute;
    top: -7px;
    left: 38px;
}

.filter-panel .filter-sub-ul .filter-sec-wrap .filter-sec-ul {
    width: 100%;
    background: #F4F4F4;
    padding-top: 8px;
    padding-right: 5px;
    padding-bottom: 8px;
}

.filter-panel .filter-sub-ul .filter-sec-wrap .filter-sec-li {
    background: transparent;
}

.filter-panel .filter-sub-ul .filter-sec-wrap li div {
    background: #fff;
    margin-right: 5px;
}
console 命令行工具 X clear

                    
>
console