kero
Version:
<img src="http://tinper.org/assets/images/kero.png" width="120" style="max-width:100%;"/>
144 lines (136 loc) • 4.28 kB
JavaScript
/**
* Module : kero dataTable ref
* Author : liuyk(liuyk@yonyou.com)
* Date : 2016-08-01 14:34:01
*/
/**
* 为选中行绑定监听,当选中行发生改变时触发对应方法
* @memberof DataTable
* @param {string} fieldName 绑定的字段名
* @example
* datatable.refSelectedRows().subscribe(function(){})
*/
const refSelectedRows = function() {
return ko.pureComputed({
read: function() {
var ins = this.selectedIndices() || []
var rs = this.rows()
var selectedRows = []
for (var i = 0; i < ins.length; i++) {
selectedRows.push(rs[i])
}
return selectedRows
},
owner: this
})
}
/**
* 为某个字段绑定监听,当字段发生改变时触发对应方法
* @memberof DataTable
* @param {string} fieldName 绑定的字段名
* @example
* datatable.ref('field1').subscribe(function(){})
*/
const ref = function(fieldName) {
this.createField(fieldName);
if (!this.valueChange[fieldName])
this.valueChange[fieldName] = ko.observable(1);
return ko.pureComputed({
read: function() {
this.valueChange[fieldName]();
this.currentRowChange();
var row = this.getCurrentRow()
if (row) {
return row.getChildValue(fieldName)
} else
return ''
},
write: function(value) {
var row = this.getCurrentRow()
if (row)
row.setChildValue(fieldName, value);
},
owner: this
})
}
/**
* 绑定字段属性,当字段属性发生改变时触发对应方法
* @memberof DataTable
* @param {string} fieldName 绑定的字段名
* @param {string} key 绑定的属性key
* @example
* datatable.refMeta('field1','type').subscribe(function(){})
*/
const refMeta = function(fieldName, key) {
if (!this.metaChange[fieldName + '.' + key])
this.metaChange[fieldName + '.' + key] = ko.observable(1);
return ko.pureComputed({
read: function() {
this.metaChange[fieldName + '.' + key]();
this.currentRowChange();
return this.getMeta(fieldName, key)
},
write: function(value) {
this.setMeta(fieldName, key, value)
},
owner: this
})
}
/**
* 绑定当前行的字段属性,当字段属性发生改变时触发对应方法
* @memberof DataTable
* @param {string} fieldName 绑定的字段名
* @param {string} key 绑定的属性key
* @example
* datatable.refRowMeta('field1','type').subscribe(function(){})
*/
const refRowMeta = function(fieldName, key) {
if (!this.metaChange[fieldName + '.' + key])
this.metaChange[fieldName + '.' + key] = ko.observable(1);
return ko.pureComputed({
read: function() {
this.metaChange[fieldName + '.' + key]();
this.currentRowChange();
var row = this.getCurrentRow()
if (row)
return row.getMeta(fieldName, key)
else
return this.getMeta(fieldName, key)
},
write: function(value) {
var row = this.getCurrentRow()
if (row)
row.setMeta(fieldName, value)
},
owner: this
})
}
/**
* 绑定字段是否可修改属性,当字段可修改属性发生改变时触发对应方法
* @memberof DataTable
* @param {string} fieldName 绑定的字段名
* @example
* datatable.refEnable('field1').subscribe(function(){})
*/
const refEnable = function(fieldName) {
return ko.pureComputed({
//enable优先级: dataTable.enable > row上的enable > field中的enable定义
read: function() {
this.enableChange();
if (!fieldName)
return this.enable;
var fieldEnable = this.getRowMeta(fieldName, 'enable')
if (typeof fieldEnable == 'undefined' || fieldEnable == null)
fieldEnable = true;
return fieldEnable && this.enable
},
owner: this
})
}
export const refFunObj = {
refSelectedRows: refSelectedRows,
ref: ref,
refMeta: refMeta,
refRowMeta: refRowMeta,
refEnable: refEnable
}