dbweb-common
Version:
用`yarn add dbweb-common`安装,不要忘记修改`angular.json`里的 `architect\build\options\assets`,加上
133 lines • 13.2 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
export class ContextMenu {
constructor() {
this.contextMenuPosition = { x: '0px', y: '0px' };
}
/**
* @param {?} colIndex
* @param {?} rowIndex
* @return {?}
*/
cellSelector(colIndex, rowIndex) {
return false;
}
/**
* @param {?} event
* @param {?} col
* @param {?} row
* @return {?}
*/
openContextMenu(event, col, row) {
if (this.cellSelector(col, row)) {
event.preventDefault(); // Suppress the browser's context menu
this.contextMenuPosition = { x: event.clientX + 'px', y: event.clientY + 'px' };
this.contextMenu.openMenu(); // Open your custom context menu instead
document
.getElementsByClassName('cdk-overlay-backdrop')[0]
.addEventListener('contextmenu', (/**
* @param {?} offEvent
* @return {?}
*/
(offEvent) => {
offEvent.preventDefault();
this.contextMenu.closeMenu();
}));
}
}
/**
* @param {?} hasTitle
* @return {?}
*/
onSelCopyClick(hasTitle) {
// 注意有反向选择
/** @type {?} */
const x = Math.min(this.selector.startX, this.selector.endX);
/** @type {?} */
const x1 = Math.max(this.selector.startX, this.selector.endX);
/** @type {?} */
const y = Math.min(this.selector.startY, this.selector.endY);
/** @type {?} */
const y1 = Math.max(this.selector.startY, this.selector.endY);
/** @type {?} */
const text = [];
if (hasTitle) {
/** @type {?} */
const line = [];
for (let ix = x; ix <= x1; ix++) {
line.push(this.tabData.nativeElement.rows[0].cells[ix].innerText.trim()); // 发现有换行,需要去除
}
text.push(line.join('\t'));
}
for (let iy = y; iy <= y1; iy++) {
/** @type {?} */
const line = [];
for (let ix = x; ix <= x1; ix++) {
line.push(this.tabData.nativeElement.rows[iy + 1].cells[ix].innerText.trim());
}
text.push(line.join('\t'));
}
this._clipboardService.copyFromContent(text.join('\n'));
}
/**
* @param {?} event
* @return {?}
*/
onSelLineMenuClick(event) {
/** @type {?} */
const y = Math.min(this.selector.startY, this.selector.endY);
/** @type {?} */
const y1 = Math.max(this.selector.startY, this.selector.endY);
this.svr.data.tableRowSelection.select(...this.dataSource.slice(y, y1 + 1).map((/**
* @param {?} v
* @return {?}
*/
v => v.Key)));
}
/**
* @return {?}
*/
onSelCancelLineMenuClick() {
/** @type {?} */
const y = Math.min(this.selector.startY, this.selector.endY);
/** @type {?} */
const y1 = Math.max(this.selector.startY, this.selector.endY);
this.svr.data.tableRowSelection.deselect(...this.dataSource.slice(y, y1 + 1).map((/**
* @param {?} v
* @return {?}
*/
v => v.Key)));
}
/**
* @return {?}
*/
onSelAllMenuClick() {
if (this.dataSource.length > 0) {
this.selector.startX = 1;
this.selector.startY = 0;
this.selector.endX = this.columns.length + 1; // 加个序号列
this.selector.endY = this.dataSource.length - 1;
}
}
}
if (false) {
/** @type {?} */
ContextMenu.prototype.contextMenu;
/** @type {?} */
ContextMenu.prototype.contextMenuPosition;
/** @type {?} */
ContextMenu.prototype.svr;
/** @type {?} */
ContextMenu.prototype.selector;
/** @type {?} */
ContextMenu.prototype.tabData;
/** @type {?} */
ContextMenu.prototype._clipboardService;
/** @type {?} */
ContextMenu.prototype.dataSource;
/** @type {?} */
ContextMenu.prototype.columns;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"contex-menu.js","sourceRoot":"ng://dbweb-common/","sources":["lib/record-view/table/contex-menu.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef } from '@angular/core';\r\nimport { MatMenuTrigger } from '@angular/material/menu';\r\nimport { ClipboardService } from 'ngx-clipboard';\r\nimport { IRenderRow, TableColumnType } from '../model/model';\r\nimport { ServiceService } from '../service/service.service';\r\nimport { ISelector } from './selector';\r\n\r\nexport class ContextMenu {\r\n\tcontextMenu: MatMenuTrigger;\r\n\tcontextMenuPosition = { x: '0px', y: '0px' };\r\n\tsvr: ServiceService;\r\n\tselector: ISelector;\r\n\ttabData: ElementRef<HTMLTableElement>;\r\n\t_clipboardService: ClipboardService;\r\n\tdataSource: IRenderRow[];\r\n\tcolumns: TableColumnType[];\r\n\tcellSelector(colIndex: number, rowIndex: number): boolean {\r\n\t\treturn false;\r\n\t}\r\n\topenContextMenu(event: MouseEvent, col: number, row: number) {\r\n\t\tif (this.cellSelector(col, row)) {\r\n\t\t\tevent.preventDefault(); // Suppress the browser's context menu\r\n\t\t\tthis.contextMenuPosition = { x: event.clientX + 'px', y: event.clientY + 'px' };\r\n\t\t\tthis.contextMenu.openMenu(); // Open your custom context menu instead\r\n\t\t\tdocument\r\n\t\t\t\t.getElementsByClassName('cdk-overlay-backdrop')[0]\r\n\t\t\t\t.addEventListener('contextmenu', (offEvent: any) => {\r\n\t\t\t\t\toffEvent.preventDefault();\r\n\t\t\t\t\tthis.contextMenu.closeMenu();\r\n\t\t\t\t});\r\n\t\t}\r\n\t}\r\n\tonSelCopyClick(hasTitle: boolean) {\r\n\t\t// 注意有反向选择\r\n\t\tconst x = Math.min(this.selector.startX, this.selector.endX);\r\n\t\tconst x1 = Math.max(this.selector.startX, this.selector.endX);\r\n\t\tconst y = Math.min(this.selector.startY, this.selector.endY);\r\n\t\tconst y1 = Math.max(this.selector.startY, this.selector.endY);\r\n\t\tconst text = [];\r\n\t\tif (hasTitle) {\r\n\t\t\tconst line = [];\r\n\t\t\tfor (let ix = x; ix <= x1; ix++) {\r\n\t\t\t\tline.push(this.tabData.nativeElement.rows[0].cells[ix].innerText.trim()); // 发现有换行，需要去除\r\n\t\t\t}\r\n\t\t\ttext.push(line.join('\\t'));\r\n\t\t}\r\n\t\tfor (let iy = y; iy <= y1; iy++) {\r\n\t\t\tconst line = [];\r\n\t\t\tfor (let ix = x; ix <= x1; ix++) {\r\n\t\t\t\tline.push(this.tabData.nativeElement.rows[iy + 1].cells[ix].innerText.trim());\r\n\t\t\t}\r\n\t\t\ttext.push(line.join('\\t'));\r\n\t\t}\r\n\r\n\t\tthis._clipboardService.copyFromContent(text.join('\\n'));\r\n\t}\r\n\tonSelLineMenuClick(event: MouseEvent) {\r\n\t\tconst y = Math.min(this.selector.startY, this.selector.endY);\r\n\t\tconst y1 = Math.max(this.selector.startY, this.selector.endY);\r\n\t\tthis.svr.data.tableRowSelection.select(...this.dataSource.slice(y, y1 + 1).map(v => v.Key));\r\n\t}\r\n\tonSelCancelLineMenuClick() {\r\n\t\tconst y = Math.min(this.selector.startY, this.selector.endY);\r\n\t\tconst y1 = Math.max(this.selector.startY, this.selector.endY);\r\n\t\tthis.svr.data.tableRowSelection.deselect(...this.dataSource.slice(y, y1 + 1).map(v => v.Key));\r\n\t}\r\n\tonSelAllMenuClick() {\r\n\t\tif (this.dataSource.length > 0) {\r\n\t\t\tthis.selector.startX = 1;\r\n\t\t\tthis.selector.startY = 0;\r\n\t\t\tthis.selector.endX = this.columns.length + 1; // 加个序号列\r\n\t\t\tthis.selector.endY = this.dataSource.length - 1;\r\n\t\t}\r\n\t}\r\n}\r\n"]}