UNPKG

dbweb-common

Version:

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

234 lines 16.6 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; /** @type {?} */ var toolbarShowDelay = 300; var Header = /** @class */ (function () { function Header() { } /** * @param {?} col * @param {?} event * @return {?} */ Header.prototype.headerMouseenter = /** * @param {?} col * @param {?} event * @return {?} */ function (col, event) { this.current.x = ((/** @type {?} */ (event.target))).cellIndex; this.headerToolbarShowTimer = setTimeout((/** * @return {?} */ function () { col.showToolbar = true; }), toolbarShowDelay); }; /** * @param {?} col * @return {?} */ Header.prototype.headerMouseleave = /** * @param {?} col * @return {?} */ function (col) { if (this.headerToolbarShowTimer) { clearTimeout(this.headerToolbarShowTimer); this.headerToolbarShowTimer = undefined; } col.showToolbar = false; }; /** * @param {?} event * @param {?} col * @return {?} */ Header.prototype.lockButtonClick = /** * @param {?} event * @param {?} col * @return {?} */ function (event, col) { col.sticky = true; col.showToolbar = false; this.syncColumn(); event.stopPropagation(); event.preventDefault(); }; /** * @param {?} event * @param {?} col * @return {?} */ Header.prototype.unlockButtonClick = /** * @param {?} event * @param {?} col * @return {?} */ function (event, col) { col.sticky = false; col.showToolbar = false; this.syncColumn(); event.stopPropagation(); event.preventDefault(); }; /** * @param {?} event * @param {?} col * @return {?} */ Header.prototype.toLeftButtonClick = /** * @param {?} event * @param {?} col * @return {?} */ function (event, col) { /** @type {?} */ var realIndex = col.index; /** @type {?} */ var 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 {?} */ Header.prototype.toRightButtonClick = /** * @param {?} event * @param {?} col * @return {?} */ function (event, col) { /** @type {?} */ var realIndex = col.index; /** @type {?} */ var 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 {?} */ Header.prototype.stickyColumnRight = /** * 返回一个列是不是固定列的最右边列 * @param {?} colIndex * @return {?} */ function (colIndex) { return (colIndex < this._tableColumns.length - 1 && this._tableColumns[colIndex].sticky && !this._tableColumns[colIndex + 1].sticky); }; // 同步列的设置,主要是重新根据固定列排定顺序 // 同步列的设置,主要是重新根据固定列排定顺序 /** * @return {?} */ Header.prototype.syncColumn = // 同步列的设置,主要是重新根据固定列排定顺序 /** * @return {?} */ function () { var _this = this; /** * 先把上次存在的列照样输出,注意保留原有的顺序 * @type {?} */ var cols = (this.columns || []).filter((/** * @param {?} col * @return {?} */ function (col) { return _this.displayColumns.find((/** * @param {?} vv * @return {?} */ function (vv) { return vv.Name === col.Name; })) !== undefined; })); /** * 再输出剩下的列 * @type {?} */ var cc = (this.displayColumns || []).filter((/** * @param {?} col * @return {?} */ function (col) { return cols.find((/** * @param {?} vv * @return {?} */ function (vv) { return vv.Name === col.Name; })) === undefined; })); cols = cols.concat(cc); // 把固定列提升到最前面 cols = cols.filter((/** * @param {?} v * @return {?} */ function (v) { return v.sticky; })).concat(cols.filter((/** * @param {?} v * @return {?} */ function (v) { return !v.sticky; }))); cols.forEach((/** * @param {?} v1 * @param {?} idx * @return {?} */ function (v1, idx) { return (v1.index = idx); })); this.columns = cols; this._tableColumns = tslib_1.__spread(this.fixStartColumns).concat( /**固定的列排在前面 */ this.columns, this.fixEndColumns); this.displayColumnNames = this._tableColumns.map((/** * @param {?} vv * @return {?} */ function (vv) { return vv.Name; })); /**妈蛋,列内容变化,宽度还是算上一次的,造成列宽计算不对,只有变通的延后调用一次强制更新 */ setTimeout((/** * @return {?} */ function () { _this.tabDataOrg.updateStickyColumnStyles(); }), 10); }; return Header; }()); export { Header }; 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"]}