UNPKG

dbweb-common

Version:

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

280 lines 25.2 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { moveItemInArray } from '@angular/cdk/drag-drop'; import { Component, ContentChildren, Directive, Input, QueryList, ViewChild, ViewChildren, ViewEncapsulation } from '@angular/core'; import { MatTab, MatTabGroup } from '@angular/material/tabs'; import { Router, RouterLink } from '@angular/router'; import { Subscription } from 'rxjs'; import { TabsService } from '../tabs.service'; // Directive to retrieve mat-tab options from router-tab.component.html // tslint:disable-next-line:directive-class-suffix export class RouterTab { /** * @param {?} tab * @param {?} routerLink */ constructor(tab, routerLink) { this.tab = tab; this.routerLink = routerLink; } } RouterTab.decorators = [ { type: Directive, args: [{ // tslint:disable-next-line:directive-selector selector: 'mat-tab[routerLink]' },] } ]; /** @nocollapse */ RouterTab.ctorParameters = () => [ { type: MatTab }, { type: RouterLink } ]; RouterTab.propDecorators = { routerLinkActiveOptions: [{ type: Input }] }; if (false) { /** @type {?} */ RouterTab.prototype.routerLinkActiveOptions; /** @type {?} */ RouterTab.prototype.tab; /** @type {?} */ RouterTab.prototype.routerLink; } // Directive to set tabs within app-router-tab // tslint:disable-next-line:directive-selector // tslint:disable-next-line:directive-class-suffix export class RouterTabItem { } RouterTabItem.decorators = [ { type: Directive, args: [{ selector: 'app-router-tab-item' },] } ]; RouterTabItem.propDecorators = { routerLink: [{ type: Input }], routerLinkActiveOptions: [{ type: Input }], actives: [{ type: Input }], disabled: [{ type: Input, args: ['disabled',] }], label: [{ type: Input }] }; if (false) { /** @type {?} */ RouterTabItem.prototype.routerLink; /** @type {?} */ RouterTabItem.prototype.routerLinkActiveOptions; /** @type {?} */ RouterTabItem.prototype.actives; /** @type {?} */ RouterTabItem.prototype.disabled; /** @type {?} */ RouterTabItem.prototype.label; } // RouterTab component with the same behavior than mat-tab-nav-bar export class RouterTabComponent { /** * @param {?} router * @param {?} tabs */ constructor(router, tabs) { this.router = router; this.tabs = tabs; this.subscription = new Subscription(); } /** * @param {?} event * @param {?} index * @return {?} */ dragStart(event, index) { this.tabBool = index; this.oldTab = this.tabs.active; } /** * @param {?} event * @return {?} */ dragEnded(event) { this.tabBool = null; } /** * @param {?} event * @return {?} */ drop(event) { // tslint:disable-next-line:radix /** @type {?} */ const previousIndex = parseInt(event.previousContainer.id.replace('list-', '')); // tslint:disable-next-line:radix /** @type {?} */ const currentIndex = parseInt(event.container.id.replace('list-', '')); if (previousIndex !== NaN && currentIndex !== NaN && previousIndex !== undefined && currentIndex !== undefined && previousIndex !== currentIndex) { // Do stuff // this.tabBool = null; // END Stuff moveItemInArray(this.tabs.tabs, previousIndex, currentIndex); } this.tabs.activeIndex = this.tabs.tabs.findIndex((/** * @param {?} v * @return {?} */ v => v === this.oldTab)); } /** * @param {?} index * @return {?} */ getAllListConnections(index) { /** @type {?} */ const connections = []; for (let i = 0; i < this.tabs.tabs.length; i++) { if (i !== index) { connections.push('list-' + i); } } return connections; } /** * @return {?} */ ngAfterViewInit() { // Remove tab click event this.matTabGroup._handleClick = (/** * @return {?} */ () => { }); // Select current tab depending on url this.setIndex(); // Subscription to navigation change // this.subscription.add( // this.router.events.subscribe(e => { // if (e instanceof NavigationEnd) { // setTimeout(() => this.setIndex(), 0); // } // }) // ); } /** * @return {?} */ ngOnDestroy() { this.subscription.unsubscribe(); } /** * @param {?} u * @return {?} */ getURLPath(u) { return ['/', ...u.root.children['primary'].segments.map((/** * @param {?} v * @return {?} */ v => v.path))]; } /** * @param {?} event * @param {?} index * @return {?} */ onTabsClick(event, index) { if (this.tabs.activeIndex !== index) { this.router.navigateByUrl(this.tabs.tabs[index].url, { state: this.tabs.tabs[index].data() }); } } /** * @param {?} e * @param {?} index * @return {?} */ removeClick(e, index) { if (this.tabs.removeTab(index)) { this.router.navigateByUrl(this.tabs.active.url, { state: this.tabs.active.data() }); } if (e && e.stopPropagation) { // 因此它支持W3C的stopPropagation()方法 e.stopPropagation(); } else { // 否则,我们需要使用IE的方式来取消事件冒泡 window.event.cancelBubble = true; } return false; } // Set current selected tab depending on navigation /** * @private * @return {?} */ setIndex() { this.routerTabs.find((/** * @param {?} tab * @param {?} i * @return {?} */ (tab, i) => { if (!this.router.isActive(tab.routerLink.urlTree, tab.routerLinkActiveOptions ? tab.routerLinkActiveOptions.exact : false)) { return false; } // tab.tab.isActive = true; this.tabs.activeIndex = i; // this.matTabGroup.selectedIndex = i; return true; })); } } RouterTabComponent.decorators = [ { type: Component, args: [{ // tslint:disable-next-line:component-selector selector: 'app-router-tab', template: "<mat-tab-group #matTabGroup class=\"hide-tab-wrapper\" [selectedIndex]=\"tabs.activeIndex\">\r\n\t<mat-tab\r\n\t\t*ngFor=\"let tab of tabs.tabs; let index = index\"\r\n\t\t[routerLink]=\"getURLPath(tab.url)\"\r\n\t\t[queryParams]=\"tab.url.queryParams\"\r\n\t>\r\n\t\t<ng-template mat-tab-label>\r\n\t\t\t<div\r\n\t\t\t\t[id]=\"'list-' + index\"\r\n\t\t\t\tclass=\"example-list router-tab-link\"\r\n\t\t\t\tcdkDropList\r\n\t\t\t\t(cdkDropListDropped)=\"drop($event)\"\r\n\t\t\t\t[cdkDropListConnectedTo]=\"getAllListConnections(index)\"\r\n\t\t\t>\r\n\t\t\t\t<a\r\n\t\t\t\t\tclass=\"example-box\"\r\n\t\t\t\t\t(click)=\"onTabsClick($event, index)\"\r\n\t\t\t\t\t(cdkDragStarted)=\"dragStart($event, index)\"\r\n\t\t\t\t\t(cdkDragEnded)=\"dragEnded($event)\"\r\n\t\t\t\t\tcdkDrag\r\n\t\t\t\t>\r\n\t\t\t\t\t<span class=\"example-custom-placeholder\" *cdkDragPlaceholder></span>\r\n\t\t\t\t\t<span [class.hide-tab]=\"index === matTabGroup.selectedIndex\" class=\"tabspan\">{{\r\n\t\t\t\t\t\ttab.titleObservable | async\r\n\t\t\t\t\t}}</span>\r\n\t\t\t\t\t<button (click)=\"removeClick($event, index)\" mat-icon-button class=\"tabButton\">\r\n\t\t\t\t\t\t<mat-icon\r\n\t\t\t\t\t\t\tsvgIcon=\"close\"\r\n\t\t\t\t\t\t\t[class.hide-tab]=\"index === matTabGroup.selectedIndex\"\r\n\t\t\t\t\t\t\tclass=\"example-tab-icon\"\r\n\t\t\t\t\t\t></mat-icon>\r\n\t\t\t\t\t</button>\r\n\t\t\t\t</a>\r\n\t\t\t\t<a *ngIf=\"tabBool === index\" class=\"example-box drag-source\" cdkDrag>\r\n\t\t\t\t\t<span class=\"example-custom-placeholder\" *cdkDragPlaceholder></span>\r\n\t\t\t\t\t<span [class.hide-tab]=\"index === matTabGroup.selectedIndex\" class=\"tabspan\">{{ tab.titleObservable | async }}</span>\r\n\t\t\t\t\t<button mat-icon-button class=\"tabButton\">\r\n\t\t\t\t\t\t<mat-icon\r\n\t\t\t\t\t\t\tsvgIcon=\"close\"\r\n\t\t\t\t\t\t\t(click)=\"removeClick($event, index)\"\r\n\t\t\t\t\t\t\tclass=\"example-tab-icon\"\r\n\t\t\t\t\t\t></mat-icon>\r\n\t\t\t\t\t</button>\r\n\t\t\t\t</a>\r\n\t\t\t</div>\r\n\t\t</ng-template>\r\n\t</mat-tab>\r\n</mat-tab-group>\r\n", encapsulation: ViewEncapsulation.None, styles: [".hide-tab-wrapper .mat-tab-body-wrapper{display:none!important}.mat-tab-label{height:30px!important;min-width:160px!important;line-height:30px;text-align:left;font-size:12px;display:block;opacity:1!important;padding:0!important;position:relative}.mat-tab-label .tabButton{position:absolute;right:0;top:-3px;height:30px;width:30px;line-height:30px}.mat-tab-label .tabButton .example-tab-icon{width:16px;height:16px}.router-tab-link{height:30px;min-width:160px}.example-list{background:#fff;border-radius:4px;overflow:hidden;display:block}.example-box{min-width:160px;height:30px;display:flex;flex-direction:row;align-items:center;justify-content:space-between;box-sizing:content-box}.drag-source{opacity:.5}.cdk-drag-preview{width:100%;box-sizing:border-box;border-radius:4px;box-shadow:0 5px 5px -3px rgba(0,0,0,.2),0 8px 10px 1px rgba(0,0,0,.14),0 3px 14px 2px rgba(0,0,0,.12);opacity:.5;font-size:12px}.cdk-drag-preview .mat-button-wrapper{width:16px!important;height:16px!important}.cdk-drag-preview .mat-button-wrapper .example-tab-icon{width:16px;height:16px}.cdk-drag-placeholder{opacity:0}.tabspan{padding:0 30px 0 6px}.cdk-drag-animating{transition:transform 250ms cubic-bezier(0,0,.2,1);transition:transform 250ms cubic-bezier(0,0,.2,1),-webkit-transform 250ms cubic-bezier(0,0,.2,1)}.cdk-drop-list-dragging a{-webkit-transform:translate3d(0,0,0)!important;transform:translate3d(0,0,0)!important}.example-custom-placeholder{width:100%;height:100%;-webkit-transform:translateX(-100%);transform:translateX(-100%);transition:transform 250ms cubic-bezier(0,0,.2,1);transition:transform 250ms cubic-bezier(0,0,.2,1),-webkit-transform 250ms cubic-bezier(0,0,.2,1)}"] }] } ]; /** @nocollapse */ RouterTabComponent.ctorParameters = () => [ { type: Router }, { type: TabsService } ]; RouterTabComponent.propDecorators = { matTabGroup: [{ type: ViewChild, args: ['matTabGroup', { static: true },] }], routerTabItems: [{ type: ContentChildren, args: [RouterTabItem,] }], routerTabs: [{ type: ViewChildren, args: [RouterTab,] }], active: [{ type: Input }] }; if (false) { /** @type {?} */ RouterTabComponent.prototype.matTabGroup; /** @type {?} */ RouterTabComponent.prototype.routerTabItems; /** @type {?} */ RouterTabComponent.prototype.routerTabs; /** @type {?} */ RouterTabComponent.prototype.tabpaixu; /** @type {?} */ RouterTabComponent.prototype.tabBool; /** @type {?} */ RouterTabComponent.prototype.oldTab; /** @type {?} */ RouterTabComponent.prototype.active; /** * @type {?} * @private */ RouterTabComponent.prototype.subscription; /** * @type {?} * @private */ RouterTabComponent.prototype.router; /** @type {?} */ RouterTabComponent.prototype.tabs; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"router-tab.component.js","sourceRoot":"ng://dbweb-common/","sources":["lib/home/router-tab/router-tab.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CdkDragDrop, moveItemInArray, CdkDragStart, CdkDragEnd } from '@angular/cdk/drag-drop';\r\nimport {\r\n\tAfterViewInit,\r\n\tComponent,\r\n\tContentChildren,\r\n\tDirective,\r\n\tInput,\r\n\tOnDestroy,\r\n\tQueryList,\r\n\tViewChild,\r\n\tViewChildren,\r\n\tViewEncapsulation\r\n} from '@angular/core';\r\nimport { MatTab, MatTabGroup } from '@angular/material/tabs';\r\nimport { NavigationEnd, Router, RouterLink, UrlTree } from '@angular/router';\r\nimport { Subscription } from 'rxjs';\r\nimport { IRouterState } from '../../router-state';\r\nimport { TabsService, Tab } from '../tabs.service';\r\n\r\n// Directive to retrieve mat-tab options from router-tab.component.html\r\n@Directive({\r\n\t// tslint:disable-next-line:directive-selector\r\n\tselector: 'mat-tab[routerLink]'\r\n})\r\n// tslint:disable-next-line:directive-class-suffix\r\nexport class RouterTab {\r\n\t@Input()\r\n\tpublic routerLinkActiveOptions: {\r\n\t\texact: boolean;\r\n\t};\r\n\r\n\tconstructor(public tab: MatTab, public routerLink: RouterLink) {}\r\n}\r\n\r\n// Directive to set tabs within app-router-tab\r\n\r\n// tslint:disable-next-line:directive-selector\r\n@Directive({ selector: 'app-router-tab-item' })\r\n// tslint:disable-next-line:directive-class-suffix\r\nexport class RouterTabItem {\r\n\t@Input()\r\n\tpublic routerLink: RouterLink;\r\n\t@Input()\r\n\tpublic routerLinkActiveOptions: {\r\n\t\texact: boolean;\r\n\t};\r\n\t@Input() actives: IRouterState;\r\n\r\n\t// tslint:disable-next-line:no-input-rename\r\n\t@Input('disabled')\r\n\tpublic disabled: boolean;\r\n\r\n\t@Input()\r\n\tpublic label: string;\r\n}\r\n\r\n// RouterTab component with the same behavior than mat-tab-nav-bar\r\n@Component({\r\n\t// tslint:disable-next-line:component-selector\r\n\tselector: 'app-router-tab',\r\n\ttemplateUrl: './router-tab.component.html',\r\n\tstyleUrls: ['./router-tab.component.scss'],\r\n\tencapsulation: ViewEncapsulation.None\r\n})\r\nexport class RouterTabComponent implements AfterViewInit, OnDestroy {\r\n\t@ViewChild('matTabGroup', { static: true })\r\n\tpublic matTabGroup: MatTabGroup;\r\n\t@ContentChildren(RouterTabItem)\r\n\tpublic routerTabItems!: QueryList<RouterTabItem>;\r\n\r\n\t@ViewChildren(RouterTab)\r\n\tpublic routerTabs: QueryList<RouterTab>;\r\n\r\n\ttabpaixu: Number;\r\n\ttabBool: number;\r\n\toldTab: Tab;\r\n\t@Input() active: IRouterState;\r\n\tprivate subscription = new Subscription();\r\n\tdragStart(event: CdkDragStart, index: number) {\r\n\t\tthis.tabBool = index;\r\n\t\tthis.oldTab = this.tabs.active;\r\n\t}\r\n\tdragEnded(event: CdkDragEnd) {\r\n\t\tthis.tabBool = null;\r\n\t}\r\n\tdrop(event: CdkDragDrop<string[]>) {\r\n\t\t// tslint:disable-next-line:radix\r\n\t\tconst previousIndex = parseInt(event.previousContainer.id.replace('list-', ''));\r\n\t\t// tslint:disable-next-line:radix\r\n\t\tconst currentIndex = parseInt(event.container.id.replace('list-', ''));\r\n\t\tif (\r\n\t\t\tpreviousIndex !== NaN &&\r\n\t\t\tcurrentIndex !== NaN &&\r\n\t\t\tpreviousIndex !== undefined &&\r\n\t\t\tcurrentIndex !== undefined &&\r\n\t\t\tpreviousIndex !== currentIndex\r\n\t\t) {\r\n\t\t\t// Do stuff\r\n\t\t\t// this.tabBool = null;\r\n\t\t\t// END Stuff\r\n\t\t\tmoveItemInArray(this.tabs.tabs, previousIndex, currentIndex);\r\n\t\t}\r\n\t\tthis.tabs.activeIndex = this.tabs.tabs.findIndex(v => v === this.oldTab);\r\n\t}\r\n\tgetAllListConnections(index: Number) {\r\n\t\tconst connections = [];\r\n\t\tfor (let i = 0; i < this.tabs.tabs.length; i++) {\r\n\t\t\tif (i !== index) {\r\n\t\t\t\tconnections.push('list-' + i);\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn connections;\r\n\t}\r\n\tconstructor(private router: Router, public tabs: TabsService) {}\r\n\r\n\tngAfterViewInit() {\r\n\t\t// Remove tab click event\r\n\t\tthis.matTabGroup._handleClick = () => {};\r\n\t\t// Select current tab depending on url\r\n\t\tthis.setIndex();\r\n\t\t// Subscription to navigation change\r\n\t\t// this.subscription.add(\r\n\t\t// \tthis.router.events.subscribe(e => {\r\n\t\t// \t\tif (e instanceof NavigationEnd) {\r\n\t\t// \t\t\tsetTimeout(() => this.setIndex(), 0);\r\n\t\t// \t\t}\r\n\t\t// \t})\r\n\t\t// );\r\n\t}\r\n\r\n\tngOnDestroy(): void {\r\n\t\tthis.subscription.unsubscribe();\r\n\t}\r\n\tgetURLPath(u: UrlTree) {\r\n\t\treturn ['/', ...u.root.children['primary'].segments.map(v => v.path)];\r\n\t}\r\n\tonTabsClick(event: MouseEvent, index: number) {\r\n\t\tif (this.tabs.activeIndex !== index) {\r\n\t\t\tthis.router.navigateByUrl(this.tabs.tabs[index].url, {\r\n\t\t\t\tstate: this.tabs.tabs[index].data()\r\n\t\t\t});\r\n\t\t}\r\n\t}\r\n\tremoveClick(e: MouseEvent, index: number) {\r\n\t\tif (this.tabs.removeTab(index)) {\r\n\t\t\tthis.router.navigateByUrl(this.tabs.active.url, {\r\n\t\t\t\tstate: this.tabs.active.data()\r\n\t\t\t});\r\n\t\t}\r\n\t\tif (e && e.stopPropagation) {\r\n\t\t\t// 因此它支持W3C的stopPropagation()方法\r\n\t\t\te.stopPropagation();\r\n\t\t} else {\r\n\t\t\t// 否则，我们需要使用IE的方式来取消事件冒泡\r\n\t\t\twindow.event.cancelBubble = true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n\t// Set current selected tab depending on navigation\r\n\tprivate setIndex() {\r\n\t\tthis.routerTabs.find((tab, i) => {\r\n\t\t\tif (\r\n\t\t\t\t!this.router.isActive(\r\n\t\t\t\t\ttab.routerLink.urlTree,\r\n\t\t\t\t\ttab.routerLinkActiveOptions ? tab.routerLinkActiveOptions.exact : false\r\n\t\t\t\t)\r\n\t\t\t) {\r\n\t\t\t\treturn false;\r\n\t\t\t}\r\n\t\t\t// tab.tab.isActive = true;\r\n\t\t\tthis.tabs.activeIndex = i;\r\n\t\t\t// this.matTabGroup.selectedIndex = i;\r\n\t\t\treturn true;\r\n\t\t});\r\n\t}\r\n}\r\n"]}