all files / dui/src/plugin/ TableColumnAlign.js

38.46% Statements 10/26
21.43% Branches 3/14
40% Functions 2/5
38.46% Lines 10/26
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80                                                                                                                                           
/**
 * 列对其方式插件
 *
 * @file 列对其方式插件
 * @author Brian Li(lbxxlht@163.com)
 *
 * 数据结构
 * <Rules>
 *  {
 *      index: <number>, // 列索引号,从0开始
 *      align: <string>  // 列对其方式:'left', 'right', 'center'
 *  }
 */
var define = typeof define === 'function' && define.amd ? define : function (factory) {
    typeof module === 'object' ? (module.exports = factory(require)) : '';
};
 
define(function (require) {
 
    var util = require('../core/util');
    var Plugin = require('../core/plugin');
 
    // public /////////////////////////////////////////////////////////////////
 
    /**
     * 构造函数
     *
     * @constructor
     * @param {Object} param 初始化对象
     * @param {Array.<Rules>} 对齐配置数据源
     */
    function TableColumnAlign(param) {
        if (!(this instanceof TableColumnAlign)) {
            return new TableColumnAlign(param);
        }
        param = param || {};
        this.rules = param.rules || [];
        Plugin.call(this, param);
    }
 
    util.inherit(TableColumnAlign, Plugin);
 
    /**
     * @override
     *
     * @param {Object} param 宿主UI初始化时的参数引用,***操作请小心***
     * @return {boolean} 是否初始化成功
     */
    TableColumnAlign.prototype.load = function (param) {
        param.pluginSkin = util.joinClassName(param.pluginSkin, 'table-column-align');
        param.tpl = extendTPL(param.tpl, this.rules);
        return true;
    };
 
    return TableColumnAlign;
 
    // private /////////////////////////////////////////////////////////////////
 
    /**
     * 对模版进行扩充
     *
     * @param {Array.<string>} tpl 原始模板
     * @param {Array.<Object>} rules 列对其配置
     * @return {Array.<string>} 扩展后的模板
     */
    function extendTPL(tpl, rules) {
        if (rules.length === 0) {
            return tpl;
        }
        var picker = new util.Picker(tpl);
        for (var i = 0; i < rules.length; i++) {
            var column = rules[i].index;
            var align = 'align' + '-' + rules[i].align;
            picker.find('[data-ui-column="' + column + '"]').addClass(align);
        }
        return picker.export();
    }
 
});