/**
* 列对其方式插件
*
* @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();
}
});
|