UNPKG

dbweb-common

Version:

用`yarn add dbweb-common`安装,不要忘记修改`angular.json`里的 `architect\build\options\assets`,加上

187 lines 14.9 kB
/** * @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"]}