dbweb-common
Version:
用`yarn add dbweb-common`安装,不要忘记修改`angular.json`里的 `architect\build\options\assets`,加上
187 lines • 14.9 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/** @type {?} */
const toolbarShowDelay = 300;
export class Header {
/**
* @param {?} col
* @param {?} event
* @return {?}
*/
headerMouseenter(col, event) {
this.current.x = ((/** @type {?} */ (event.target))).cellIndex;
this.headerToolbarShowTimer = setTimeout((/**
* @return {?}
*/
() => {
col.showToolbar = true;
}), toolbarShowDelay);
}
/**
* @param {?} col
* @return {?}
*/
headerMouseleave(col) {
if (this.headerToolbarShowTimer) {
clearTimeout(this.headerToolbarShowTimer);
this.headerToolbarShowTimer = undefined;
}
col.showToolbar = false;
}
/**
* @param {?} event
* @param {?} col
* @return {?}
*/
lockButtonClick(event, col) {
col.sticky = true;
col.showToolbar = false;
this.syncColumn();
event.stopPropagation();
event.preventDefault();
}
/**
* @param {?} event
* @param {?} col
* @return {?}
*/
unlockButtonClick(event, col) {
col.sticky = false;
col.showToolbar = false;
this.syncColumn();
event.stopPropagation();
event.preventDefault();
}
/**
* @param {?} event
* @param {?} col
* @return {?}
*/
toLeftButtonClick(event, col) {
/** @type {?} */
const realIndex = col.index;
/** @type {?} */
const tmp = this.columns[realIndex];
tmp.showToolbar = false;
this.columns[realIndex] = this.columns[realIndex - 1];
this.columns[realIndex - 1] = tmp;
this.syncColumn();
event.stopPropagation();
event.preventDefault();
}
/**
* @param {?} event
* @param {?} col
* @return {?}
*/
toRightButtonClick(event, col) {
/** @type {?} */
const realIndex = col.index;
/** @type {?} */
const tmp = this.columns[realIndex];
tmp.showToolbar = false;
this.columns[realIndex] = this.columns[realIndex + 1];
this.columns[realIndex + 1] = tmp;
this.syncColumn();
event.stopPropagation();
event.preventDefault();
}
/**
* 返回一个列是不是固定列的最右边列
* @param {?} colIndex
* @return {?}
*/
stickyColumnRight(colIndex) {
return (colIndex < this._tableColumns.length - 1 &&
this._tableColumns[colIndex].sticky &&
!this._tableColumns[colIndex + 1].sticky);
}
// 同步列的设置,主要是重新根据固定列排定顺序
/**
* @return {?}
*/
syncColumn() {
/**
* 先把上次存在的列照样输出,注意保留原有的顺序
* @type {?}
*/
let cols = (this.columns || []).filter((/**
* @param {?} col
* @return {?}
*/
col => this.displayColumns.find((/**
* @param {?} vv
* @return {?}
*/
vv => vv.Name === col.Name)) !== undefined));
/**
* 再输出剩下的列
* @type {?}
*/
const cc = (this.displayColumns || []).filter((/**
* @param {?} col
* @return {?}
*/
col => cols.find((/**
* @param {?} vv
* @return {?}
*/
vv => vv.Name === col.Name)) === undefined));
cols = cols.concat(cc);
// 把固定列提升到最前面
cols = cols.filter((/**
* @param {?} v
* @return {?}
*/
v => v.sticky)).concat(cols.filter((/**
* @param {?} v
* @return {?}
*/
v => !v.sticky)));
cols.forEach((/**
* @param {?} v1
* @param {?} idx
* @return {?}
*/
(v1, idx) => (v1.index = idx)));
this.columns = cols;
this._tableColumns = [...this.fixStartColumns].concat(
/**固定的列排在前面 */
this.columns, this.fixEndColumns);
this.displayColumnNames = this._tableColumns.map((/**
* @param {?} vv
* @return {?}
*/
vv => vv.Name));
/**妈蛋,列内容变化,宽度还是算上一次的,造成列宽计算不对,只有变通的延后调用一次强制更新 */
setTimeout((/**
* @return {?}
*/
() => {
this.tabDataOrg.updateStickyColumnStyles();
}), 10);
}
}
if (false) {
/** @type {?} */
Header.prototype.current;
/** @type {?} */
Header.prototype.columns;
/** @type {?} */
Header.prototype._tableColumns;
/** @type {?} */
Header.prototype.displayColumns;
/** @type {?} */
Header.prototype.displayColumnNames;
/** @type {?} */
Header.prototype.headerToolbarShowTimer;
/** @type {?} */
Header.prototype.tabDataOrg;
/** @type {?} */
Header.prototype.fixStartColumns;
/** @type {?} */
Header.prototype.fixEndColumns;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"header.js","sourceRoot":"ng://dbweb-common/","sources":["lib/record-view/table/header.ts"],"names":[],"mappings":"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","sourcesContent":["import { MatTable } from '@angular/material/table';\r\nimport { IRenderRow, TableColumnType } from '../model/model';\r\nimport { IPoint } from './selector';\r\nconst toolbarShowDelay = 300;\r\nexport class Header {\r\n\tcurrent: IPoint;\r\n\tcolumns: TableColumnType[];\r\n\t_tableColumns: TableColumnType[];\r\n\tdisplayColumns: TableColumnType[];\r\n\tdisplayColumnNames: string[];\r\n\theaderToolbarShowTimer: NodeJS.Timer;\r\n\ttabDataOrg: MatTable<IRenderRow>;\r\n\treadonly fixStartColumns: TableColumnType[];\r\n\treadonly fixEndColumns: TableColumnType[];\r\n\theaderMouseenter(col: TableColumnType, event: MouseEvent) {\r\n\t\tthis.current.x = (<HTMLTableCellElement>event.target).cellIndex;\r\n\r\n\t\tthis.headerToolbarShowTimer = setTimeout(() => {\r\n\t\t\tcol.showToolbar = true;\r\n\t\t}, toolbarShowDelay);\r\n\t}\r\n\theaderMouseleave(col: TableColumnType) {\r\n\t\tif (this.headerToolbarShowTimer) {\r\n\t\t\tclearTimeout(this.headerToolbarShowTimer);\r\n\t\t\tthis.headerToolbarShowTimer = undefined;\r\n\t\t}\r\n\t\tcol.showToolbar = false;\r\n\t}\r\n\tlockButtonClick(event: MouseEvent, col: TableColumnType) {\r\n\t\tcol.sticky = true;\r\n\t\tcol.showToolbar = false;\r\n\t\tthis.syncColumn();\r\n\t\tevent.stopPropagation();\r\n\t\tevent.preventDefault();\r\n\t}\r\n\tunlockButtonClick(event: MouseEvent, col: TableColumnType) {\r\n\t\tcol.sticky = false;\r\n\t\tcol.showToolbar = false;\r\n\t\tthis.syncColumn();\r\n\t\tevent.stopPropagation();\r\n\t\tevent.preventDefault();\r\n\t}\r\n\ttoLeftButtonClick(event: MouseEvent, col: TableColumnType) {\r\n\t\tconst realIndex = col.index;\r\n\t\tconst tmp = this.columns[realIndex];\r\n\t\ttmp.showToolbar = false;\r\n\t\tthis.columns[realIndex] = this.columns[realIndex - 1];\r\n\t\tthis.columns[realIndex - 1] = tmp;\r\n\t\tthis.syncColumn();\r\n\t\tevent.stopPropagation();\r\n\t\tevent.preventDefault();\r\n\t}\r\n\ttoRightButtonClick(event: MouseEvent, col: TableColumnType) {\r\n\t\tconst realIndex = col.index;\r\n\t\tconst tmp = this.columns[realIndex];\r\n\t\ttmp.showToolbar = false;\r\n\t\tthis.columns[realIndex] = this.columns[realIndex + 1];\r\n\t\tthis.columns[realIndex + 1] = tmp;\r\n\t\tthis.syncColumn();\r\n\t\tevent.stopPropagation();\r\n\t\tevent.preventDefault();\r\n\t}\r\n\t/**返回一个列是不是固定列的最右边列 */\r\n\tstickyColumnRight(colIndex: number) {\r\n\t\treturn (\r\n\t\t\tcolIndex < this._tableColumns.length - 1 &&\r\n\t\t\tthis._tableColumns[colIndex].sticky &&\r\n\t\t\t!this._tableColumns[colIndex + 1].sticky\r\n\t\t);\r\n\t}\r\n\t// 同步列的设置，主要是重新根据固定列排定顺序\r\n\tsyncColumn() {\r\n\t\t/**先把上次存在的列照样输出,注意保留原有的顺序 */\r\n\t\tlet cols = (this.columns || []).filter(\r\n\t\t\tcol => this.displayColumns.find(vv => vv.Name === col.Name) !== undefined\r\n\t\t);\r\n\r\n\t\t/**再输出剩下的列 */\r\n\t\tconst cc = (this.displayColumns || []).filter(col => cols.find(vv => vv.Name === col.Name) === undefined);\r\n\t\tcols = cols.concat(cc);\r\n\t\t// 把固定列提升到最前面\r\n\t\tcols = cols.filter(v => v.sticky).concat(cols.filter(v => !v.sticky));\r\n\t\tcols.forEach((v1, idx) => (v1.index = idx));\r\n\t\tthis.columns = cols;\r\n\t\tthis._tableColumns = [...this.fixStartColumns].concat(\r\n\t\t\t/**固定的列排在前面 */\r\n\t\t\tthis.columns,\r\n\t\t\tthis.fixEndColumns\r\n\t\t);\r\n\t\tthis.displayColumnNames = this._tableColumns.map(vv => vv.Name);\r\n\t\t/**妈蛋，列内容变化，宽度还是算上一次的，造成列宽计算不对，只有变通的延后调用一次强制更新 */\r\n\t\tsetTimeout(() => {\r\n\t\t\tthis.tabDataOrg.updateStickyColumnStyles();\r\n\t\t}, 10);\r\n\t}\r\n}\r\n"]}