dbweb-common
Version:
用`yarn add dbweb-common`安装,不要忘记修改`angular.json`里的 `architect\build\options\assets`,加上
280 lines • 25.2 kB
JavaScript
/**
* @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((/**
* {?} v
* {?}
*/
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"]}