@sd-angular/core 0.0.974 → 0.0.975
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/sd-angular-core-loading.umd.js +5 -5
- package/bundles/sd-angular-core-loading.umd.js.map +1 -1
- package/bundles/sd-angular-core-loading.umd.min.js +1 -1
- package/bundles/sd-angular-core-loading.umd.min.js.map +1 -1
- package/bundles/sd-angular-core-tab-router.umd.js +1 -1
- package/bundles/sd-angular-core-tab-router.umd.min.js +1 -1
- package/bundles/sd-angular-core-tab-router.umd.min.js.map +1 -1
- package/esm2015/loading/src/lib/loading.service.js +8 -8
- package/esm2015/tab-router/src/lib/components/tab-router-outlet/tab-router-outlet.component.js +1 -1
- package/fesm2015/sd-angular-core-loading.js +5 -5
- package/fesm2015/sd-angular-core-loading.js.map +1 -1
- package/fesm2015/sd-angular-core-tab-router.js +1 -1
- package/package.json +1 -1
- package/{sd-angular-core-0.0.974.tgz → sd-angular-core-0.0.975.tgz} +0 -0
- package/tab-router/sd-angular-core-tab-router.metadata.json +1 -1
|
@@ -11,16 +11,16 @@
|
|
|
11
11
|
var SdLoadingService = /** @class */ (function () {
|
|
12
12
|
function SdLoadingService() {
|
|
13
13
|
var _this = this;
|
|
14
|
-
this.loadingId =
|
|
14
|
+
this.loadingId = "L8d556b9b-f6dd-46e9-9710-757e65d82839";
|
|
15
15
|
this.start = function (element) {
|
|
16
|
-
if (element === void 0) { element =
|
|
16
|
+
if (element === void 0) { element = "body"; }
|
|
17
17
|
$__default['default'](element).append(_this.loadingNormal);
|
|
18
18
|
};
|
|
19
19
|
this.isLoading = function () {
|
|
20
20
|
return $__default['default']("#" + _this.loadingId).length > 0;
|
|
21
21
|
};
|
|
22
22
|
this.stop = function (element) {
|
|
23
|
-
if (element === void 0) { element =
|
|
23
|
+
if (element === void 0) { element = "body"; }
|
|
24
24
|
$__default['default'](element).children("#" + _this.loadingId).remove();
|
|
25
25
|
};
|
|
26
26
|
}
|
|
@@ -28,7 +28,7 @@
|
|
|
28
28
|
// Loading
|
|
29
29
|
get: function () {
|
|
30
30
|
// tslint:disable-next-line: max-line-length
|
|
31
|
-
return "<div id=\"" + this.loadingId + "\" style=\"top:0;left:0;height:100vh;width:100vw;position:absolute;opacity:0.6;background:#FFFFFF;z-index: 99999;\"><i class=\"fa fa-5x fa-spinner fa-pulse\" style=\"margin-top:calc(50vh - 2.5rem);margin-left:calc(50vw - 2.5rem)\"></i></div>";
|
|
31
|
+
return "<div class=\"sd-loading\" id=\"" + this.loadingId + "\" style=\"top:0;left:0;height:100vh;width:100vw;position:absolute;opacity:0.6;background:#FFFFFF;z-index: 99999;\"><i class=\"fa fa-5x fa-spinner fa-pulse\" style=\"margin-top:calc(50vh - 2.5rem);margin-left:calc(50vw - 2.5rem)\"></i></div>";
|
|
32
32
|
},
|
|
33
33
|
enumerable: false,
|
|
34
34
|
configurable: true
|
|
@@ -38,7 +38,7 @@
|
|
|
38
38
|
SdLoadingService.ɵprov = i0.ɵɵdefineInjectable({ factory: function SdLoadingService_Factory() { return new SdLoadingService(); }, token: SdLoadingService, providedIn: "root" });
|
|
39
39
|
SdLoadingService.decorators = [
|
|
40
40
|
{ type: i0.Injectable, args: [{
|
|
41
|
-
providedIn:
|
|
41
|
+
providedIn: "root",
|
|
42
42
|
},] }
|
|
43
43
|
];
|
|
44
44
|
SdLoadingService.ctorParameters = function () { return []; };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sd-angular-core-loading.umd.js","sources":["../../../../projects/sd-core/loading/src/lib/loading.service.ts","../../../../projects/sd-core/loading/src/public-api.ts","../../../../projects/sd-core/loading/sd-angular-core-loading.ts"],"sourcesContent":["import { Injectable } from
|
|
1
|
+
{"version":3,"file":"sd-angular-core-loading.umd.js","sources":["../../../../projects/sd-core/loading/src/lib/loading.service.ts","../../../../projects/sd-core/loading/src/public-api.ts","../../../../projects/sd-core/loading/sd-angular-core-loading.ts"],"sourcesContent":["import { Injectable } from \"@angular/core\";\r\nimport $ from \"jquery\";\r\n\r\n@Injectable({\r\n providedIn: \"root\",\r\n})\r\nexport class SdLoadingService {\r\n private loadingId = \"L8d556b9b-f6dd-46e9-9710-757e65d82839\";\r\n\r\n constructor() {}\r\n\r\n // Loading\r\n private get loadingNormal() {\r\n // tslint:disable-next-line: max-line-length\r\n return `<div class=\"sd-loading\" id=\"${this.loadingId}\" style=\"top:0;left:0;height:100vh;width:100vw;position:absolute;opacity:0.6;background:#FFFFFF;z-index: 99999;\"><i class=\"fa fa-5x fa-spinner fa-pulse\" style=\"margin-top:calc(50vh - 2.5rem);margin-left:calc(50vw - 2.5rem)\"></i></div>`;\r\n }\r\n\r\n start = (element: string = \"body\") => {\r\n $(element).append(this.loadingNormal);\r\n };\r\n\r\n isLoading = () => {\r\n return $(`#${this.loadingId}`).length > 0;\r\n };\r\n\r\n stop = (element: string = \"body\") => {\r\n $(element).children(`#${this.loadingId}`).remove();\r\n };\r\n}\r\n","/*\r\n * Public API Surface of superdev-angular-core\r\n */\r\n\r\nexport * from './lib/loading.service';\r\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":["$","Injectable"],"mappings":";;;;;;;;;;;QASE;YAAA,iBAAgB;YAFR,cAAS,GAAG,uCAAuC,CAAC;YAU5D,UAAK,GAAG,UAAC,OAAwB;gBAAxB,wBAAA,EAAA,gBAAwB;gBAC/BA,qBAAC,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,KAAI,CAAC,aAAa,CAAC,CAAC;aACvC,CAAC;YAEF,cAAS,GAAG;gBACV,OAAOA,qBAAC,CAAC,MAAI,KAAI,CAAC,SAAW,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;aAC3C,CAAC;YAEF,SAAI,GAAG,UAAC,OAAwB;gBAAxB,wBAAA,EAAA,gBAAwB;gBAC9BA,qBAAC,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,MAAI,KAAI,CAAC,SAAW,CAAC,CAAC,MAAM,EAAE,CAAC;aACpD,CAAC;SAlBc;QAGhB,sBAAY,2CAAa;;iBAAzB;;gBAEE,OAAO,oCAA+B,IAAI,CAAC,SAAS,sPAA4O,CAAC;aAClS;;;WAAA;;;;;gBAZFC,aAAU,SAAC;oBACV,UAAU,EAAE,MAAM;iBACnB;;;;ICLD;;;;ICAA;;;;;;;;;;;;;;"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
!function(e,n){"object"==typeof exports&&"undefined"!=typeof module?n(exports,require("@angular/core"),require("jquery")):"function"==typeof define&&define.amd?define("@sd-angular/core/loading",["exports","@angular/core","jquery"],n):n(((e="undefined"!=typeof globalThis?globalThis:e||self)["sd-angular"]=e["sd-angular"]||{},e["sd-angular"].core=e["sd-angular"].core||{},e["sd-angular"].core.loading={}),e.ng.core,e.$)}(this,(function(e,n,o){"use strict";function t(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var r=t(o),i=function(){function e(){var e=this;this.loadingId="L8d556b9b-f6dd-46e9-9710-757e65d82839",this.start=function(n){void 0===n&&(n="body"),r.default(n).append(e.loadingNormal)},this.isLoading=function(){return r.default("#"+e.loadingId).length>0},this.stop=function(n){void 0===n&&(n="body"),r.default(n).children("#"+e.loadingId).remove()}}return Object.defineProperty(e.prototype,"loadingNormal",{get:function(){return'<div id="'+this.loadingId+'" style="top:0;left:0;height:100vh;width:100vw;position:absolute;opacity:0.6;background:#FFFFFF;z-index: 99999;"><i class="fa fa-5x fa-spinner fa-pulse" style="margin-top:calc(50vh - 2.5rem);margin-left:calc(50vw - 2.5rem)"></i></div>'},enumerable:!1,configurable:!0}),e}();i.ɵprov=n.ɵɵdefineInjectable({factory:function(){return new i},token:i,providedIn:"root"}),i.decorators=[{type:n.Injectable,args:[{providedIn:"root"}]}],i.ctorParameters=function(){return[]},e.SdLoadingService=i,Object.defineProperty(e,"__esModule",{value:!0})}));
|
|
1
|
+
!function(e,n){"object"==typeof exports&&"undefined"!=typeof module?n(exports,require("@angular/core"),require("jquery")):"function"==typeof define&&define.amd?define("@sd-angular/core/loading",["exports","@angular/core","jquery"],n):n(((e="undefined"!=typeof globalThis?globalThis:e||self)["sd-angular"]=e["sd-angular"]||{},e["sd-angular"].core=e["sd-angular"].core||{},e["sd-angular"].core.loading={}),e.ng.core,e.$)}(this,(function(e,n,o){"use strict";function t(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var r=t(o),i=function(){function e(){var e=this;this.loadingId="L8d556b9b-f6dd-46e9-9710-757e65d82839",this.start=function(n){void 0===n&&(n="body"),r.default(n).append(e.loadingNormal)},this.isLoading=function(){return r.default("#"+e.loadingId).length>0},this.stop=function(n){void 0===n&&(n="body"),r.default(n).children("#"+e.loadingId).remove()}}return Object.defineProperty(e.prototype,"loadingNormal",{get:function(){return'<div class="sd-loading" id="'+this.loadingId+'" style="top:0;left:0;height:100vh;width:100vw;position:absolute;opacity:0.6;background:#FFFFFF;z-index: 99999;"><i class="fa fa-5x fa-spinner fa-pulse" style="margin-top:calc(50vh - 2.5rem);margin-left:calc(50vw - 2.5rem)"></i></div>'},enumerable:!1,configurable:!0}),e}();i.ɵprov=n.ɵɵdefineInjectable({factory:function(){return new i},token:i,providedIn:"root"}),i.decorators=[{type:n.Injectable,args:[{providedIn:"root"}]}],i.ctorParameters=function(){return[]},e.SdLoadingService=i,Object.defineProperty(e,"__esModule",{value:!0})}));
|
|
2
2
|
//# sourceMappingURL=sd-angular-core-loading.umd.min.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../projects/sd-core/loading/src/lib/loading.service.ts"],"names":["SdLoadingService","_this","this","loadingId","start","element","$","append","loadingNormal","isLoading","length","stop","children","remove","Object","defineProperty","prototype","Injectable","args","providedIn"],"mappings":"uiBASE,SAAAA,IAAA,IAAAC,EAAAC,KAFQA,KAAAC,UAAY,
|
|
1
|
+
{"version":3,"sources":["../../../../projects/sd-core/loading/src/lib/loading.service.ts"],"names":["SdLoadingService","_this","this","loadingId","start","element","$","append","loadingNormal","isLoading","length","stop","children","remove","Object","defineProperty","prototype","Injectable","args","providedIn"],"mappings":"uiBASE,SAAAA,IAAA,IAAAC,EAAAC,KAFQA,KAAAC,UAAY,wCAUpBD,KAAAE,MAAQ,SAACC,QAAA,IAAAA,IAAAA,EAAA,QACPC,EAAAA,QAAED,GAASE,OAAON,EAAKO,gBAGzBN,KAAAO,UAAY,WACV,OAAOH,EAAAA,QAAE,IAAIL,EAAKE,WAAaO,OAAS,GAG1CR,KAAAS,KAAO,SAACN,QAAA,IAAAA,IAAAA,EAAA,QACNC,EAAAA,QAAED,GAASO,SAAS,IAAIX,EAAKE,WAAaU,iBAd5CC,OAAAC,eAAYf,EAAAgB,UAAA,gBAAa,KAAzB,WAEE,MAAO,+BAA+Bd,KAAKC,UAAS,kYAXvDc,EAAAA,WAAUC,KAAA,CAAC,CACVC,WAAY","sourcesContent":["import { Injectable } from \"@angular/core\";\r\nimport $ from \"jquery\";\r\n\r\n@Injectable({\r\n providedIn: \"root\",\r\n})\r\nexport class SdLoadingService {\r\n private loadingId = \"L8d556b9b-f6dd-46e9-9710-757e65d82839\";\r\n\r\n constructor() {}\r\n\r\n // Loading\r\n private get loadingNormal() {\r\n // tslint:disable-next-line: max-line-length\r\n return `<div class=\"sd-loading\" id=\"${this.loadingId}\" style=\"top:0;left:0;height:100vh;width:100vw;position:absolute;opacity:0.6;background:#FFFFFF;z-index: 99999;\"><i class=\"fa fa-5x fa-spinner fa-pulse\" style=\"margin-top:calc(50vh - 2.5rem);margin-left:calc(50vw - 2.5rem)\"></i></div>`;\r\n }\r\n\r\n start = (element: string = \"body\") => {\r\n $(element).append(this.loadingNormal);\r\n };\r\n\r\n isLoading = () => {\r\n return $(`#${this.loadingId}`).length > 0;\r\n };\r\n\r\n stop = (element: string = \"body\") => {\r\n $(element).children(`#${this.loadingId}`).remove();\r\n };\r\n}\r\n"]}
|
|
@@ -753,7 +753,7 @@
|
|
|
753
753
|
{ type: i0.Component, args: [{
|
|
754
754
|
selector: 'sd-tab-router-outlet',
|
|
755
755
|
template: "<sd-tab-router-nav [tabs]=\"tabs\" #tabRouterNav></sd-tab-router-nav>\r\n\r\n<div class=\"tab-router__list\">\r\n <ng-container *ngFor=\"let tab of tabs\">\r\n <div class=\"tab-router__pane\" [class.active]=\"tab.isActive\" [id]=\"tab.key\">\r\n <div class=\"tab-router__content\">\r\n <ng-container\r\n *ngComponentOutlet=\"tab.component; injector: tab.injector\"\r\n ></ng-container>\r\n </div>\r\n </div>\r\n </ng-container>\r\n</div>\r\n",
|
|
756
|
-
styles: [":host{display:flex;flex-direction:column;height:calc(100vh - 64px);width:100%}::ng-deep page-layout{height:100%!important}.tab-router__list{flex:1}.tab-router__pane{display:none;height:100%;position:relative;width:100%}.tab-router__pane.active{display:block}.tab-router__content{bottom:0;height:100%;left:0;overflow:auto;position:absolute;right:0;top:0;width:100%}"]
|
|
756
|
+
styles: [":host{display:flex;flex-direction:column;height:calc(100vh - 64px);width:100%}:host ::ng-deep .sd-loading{max-height:100%;max-width:100%}::ng-deep page-layout{height:100%!important}.tab-router__list{flex:1}.tab-router__pane{display:none;height:100%;position:relative;width:100%}.tab-router__pane.active{display:block}.tab-router__content{bottom:0;height:100%;left:0;overflow:auto;position:absolute;right:0;top:0;width:100%}"]
|
|
757
757
|
},] }
|
|
758
758
|
];
|
|
759
759
|
SdTabRouterOutletComponent.ctorParameters = function () { return [
|
|
@@ -12,5 +12,5 @@
|
|
|
12
12
|
LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
|
|
13
13
|
OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
|
14
14
|
PERFORMANCE OF THIS SOFTWARE.
|
|
15
|
-
***************************************************************************** */function b(t,e){function r(){this.constructor=t}f(t,e),t.prototype=null===e?Object.create(e):(r.prototype=e.prototype,new r)}function d(t,e,r,n){return new(r||(r=Promise))((function(o,a){function i(t){try{s(n.next(t))}catch(t){a(t)}}function u(t){try{s(n.throw(t))}catch(t){a(t)}}function s(t){var e;t.done?o(t.value):(e=t.value,e instanceof r?e:new r((function(t){t(e)}))).then(i,u)}s((n=n.apply(t,e||[])).next())}))}function h(t,e){var r,n,o,a,i={label:0,sent:function(){if(1&o[0])throw o[1];return o[1]},trys:[],ops:[]};return a={next:u(0),throw:u(1),return:u(2)},"function"==typeof Symbol&&(a[Symbol.iterator]=function(){return this}),a;function u(a){return function(u){return function(a){if(r)throw new TypeError("Generator is already executing.");for(;i;)try{if(r=1,n&&(o=2&a[0]?n.return:a[0]?n.throw||((o=n.return)&&o.call(n),0):n.next)&&!(o=o.call(n,a[1])).done)return o;switch(n=0,o&&(a=[2&a[0],o.value]),a[0]){case 0:case 1:o=a;break;case 4:return i.label++,{value:a[1],done:!1};case 5:i.label++,n=a[1],a=[0];continue;case 7:a=i.ops.pop(),i.trys.pop();continue;default:if(!(o=i.trys,(o=o.length>0&&o[o.length-1])||6!==a[0]&&2!==a[0])){i=0;continue}if(3===a[0]&&(!o||a[1]>o[0]&&a[1]<o[3])){i.label=a[1];break}if(6===a[0]&&i.label<o[1]){i.label=o[1],o=a;break}if(o&&i.label<o[2]){i.label=o[2],i.ops.push(a);break}o[2]&&i.ops.pop(),i.trys.pop();continue}a=e.call(t,i)}catch(t){a=[6,t],n=0}finally{r=o=0}if(5&a[0])throw a[1];return{value:a[0]?a[1]:void 0,done:!0}}([a,u])}}}Object.create;function v(t,e){var r="function"==typeof Symbol&&t[Symbol.iterator];if(!r)return t;var n,o,a=r.call(t),i=[];try{for(;(void 0===e||e-- >0)&&!(n=a.next()).done;)i.push(n.value)}catch(t){o={error:t}}finally{try{n&&!n.done&&(r=a.return)&&r.call(a)}finally{if(o)throw o.error}}return i}var m;Object.create;function y(t,e){if(!e.has(t))throw new TypeError("attempted to get private field on non-instance");return e.get(t)}function g(t,e,r){if(!e.has(t))throw new TypeError("attempted to set private field on non-instance");return e.set(t,r),r}var _=function(){function t(t){m.set(this,void 0),g(this,m,t)}return Object.defineProperty(t.prototype,"tab",{get:function(){return y(this,m)},enumerable:!1,configurable:!0}),t}();m=new WeakMap;var w,x,k=function(t){function e(){return null!==t&&t.apply(this,arguments)||this}return b(e,t),e}(_),S=function(t){function e(){return null!==t&&t.apply(this,arguments)||this}return b(e,t),e}(_),j=function(){function t(t){var e=this;this.notifyService=t,this.events=new n.BehaviorSubject(new _(null)),this.actions=new n.BehaviorSubject(null),this.builders=new n.BehaviorSubject([]),w.set(this,null),x.set(this,[]),this.addBuilder=function(t){y(e,x).some((function(e){return e.component===t.component}))||(y(e,x).push(t),e.builders.next(y(e,x)))},this.setCurrentTab=function(t){g(e,w,t)},this.pushEvent=function(t,r){e.events.next(new r(t))},this.setOptions=function(){},this.close=function(t){t?e.actions.next({type:"close",tab:t}):y(e,w)&&e.actions.next({type:"close",tab:y(e,w)})}}return Object.defineProperty(t.prototype,"currentTab",{get:function(){return y(this,w)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"key",{get:function(){var t;return(null===(t=y(this,w))||void 0===t?void 0:t.key)||null},enumerable:!1,configurable:!0}),t}();w=new WeakMap,x=new WeakMap,j.ɵprov=r.ɵɵdefineInjectable({factory:function(){return new j(r.ɵɵinject(o.SdNotifyService))},token:j,providedIn:"root"}),j.decorators=[{type:r.Injectable,args:[{providedIn:"root"}]}],j.ctorParameters=function(){return[{type:o.SdNotifyService}]};var R=function t(e){t.tabRouterService.next(e)};R.tabRouterService=new n.BehaviorSubject(void 0),R.ɵprov=r.ɵɵdefineInjectable({factory:function(){return new R(r.ɵɵinject(j))},token:R,providedIn:"root"}),R.decorators=[{type:r.Injectable,args:[{providedIn:"root"}]}],R.ctorParameters=function(){return[{type:j}]};var I=function(t){var e=this;this.tabRouterService=t,this.close=function(t){t.preventDefault(),t.stopPropagation(),e.tabRouterService.close(e.tab)}};I.decorators=[{type:r.Component,args:[{selector:"sd-tab-router-item",template:'<a [routerLink]="[tab.url]" [queryParams]="tab.queryParams" [state]="{ switchTab: true }"\r\n class="tab-router__item d-flex align-items-center" [ngClass]="{\r\n \'tab-router__item--active\': tab.isActive\r\n }">\r\n <ng-container *ngIf="tab | sdTabInfo | async as tabInfo">\r\n <div class="\r\n tab-router__icon\r\n d-flex\r\n align-items-center\r\n justify-content-center\r\n mr-8\r\n " [ngStyle]="{\r\n \'background-color\': tabInfo.color\r\n }" [matTooltip]="tabInfo.tooltip || tabInfo.name" matTooltipPosition="below" matTooltipShowDelay="1000">\r\n {{ tabInfo.initialName || \'SD\' }}\r\n </div>\r\n <div class="flex-1">\r\n <div class="tab-router__name">{{ tabInfo.name }}</div>\r\n </div>\r\n <button type="button" class="\r\n tab-router__close\r\n d-flex\r\n align-items-center\r\n justify-content-center\r\n ml-4\r\n " (click)="close($event)">\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n </ng-container>\r\n\r\n</a>',styles:[':host{flex:1 1 auto;max-width:240px;position:relative}:host:after{background:#dde0e5;bottom:0;content:"";height:16px;margin:auto;position:absolute;right:0;top:0;width:1px}:host:last-child:after{content:none}.flex-1{flex:1}.tab-router__icon{background-color:#5c6bc0;border-radius:2px;color:#fff;font-size:10px;height:16px;line-height:1;text-transform:uppercase;width:16px}.tab-router__icon .mat-icon{font-size:10px;height:10px;width:10px}.tab-router__close{background:none;border:0;border-radius:50%;color:#757575;height:16px;outline:none;width:16px}.tab-router__close:hover{background-color:rgba(0,0,0,.12)}.tab-router__close .mat-icon{font-size:12px;height:12px;width:12px}.tab-router__item{background:#f2f3f4;color:inherit;font-size:12px;line-height:16px;padding:16px 16px 8px;text-decoration:none}.tab-router__item:hover{background-color:#fff}.tab-router__name{-webkit-box-orient:vertical;-webkit-line-clamp:1;display:-webkit-box;overflow:hidden;text-overflow:ellipsis}.tab-router__item--active{background-color:#fff;border-radius:8px 8px 0 0}']}]}],I.ctorParameters=function(){return[{type:j}]},I.propDecorators={tab:[{type:r.Input}]};var T,P,C,N,O,q,M,A=function(){function t(){var t=this;this.mode="default",this.checkUI=function(){var e=(t.tabRouterNav.nativeElement.clientWidth-64*t.tabs.length)/t.tabs.length;t.mode=e<=20?"compact":"default"}}return t.prototype.onResize=function(t){this.checkUI()},t}();A.decorators=[{type:r.Component,args:[{selector:"sd-tab-router-nav",template:'<div\r\n #tabRouterNav\r\n class="tab-router__nav tab-router__nav--{{ mode }} d-flex align-items-center"\r\n>\r\n <ng-container *ngFor="let tab of tabs">\r\n <sd-tab-router-item [tab]="tab"></sd-tab-router-item>\r\n </ng-container>\r\n</div>\r\n',styles:[".tab-router__nav{background:#f9f9f9}.tab-router__nav--compact::ng-deep .tab-router__name{display:none}.tab-router__nav--compact::ng-deep .tab-router__icon{margin:0!important}.tab-router__nav--compact::ng-deep .tab-router__item--active{min-width:240px}.tab-router__nav--compact::ng-deep .tab-router__item--active .tab-router__icon{margin-right:8px!important}.tab-router__nav--compact::ng-deep .tab-router__item--active .tab-router__name{display:-webkit-box}"]}]}],A.ctorParameters=function(){return[]},A.propDecorators={tabRouterNav:[{type:r.ViewChild,args:["tabRouterNav"]}],tabs:[{type:r.Input}],onResize:[{type:r.HostListener,args:["window:resize",["$event"]]}]};var D=function(){function t(t,r,o,i,u,s,c,l){var f=this;this.router=t,this.activatedRoute=r,this.cd=o,this.injector=i,this.compiler=u,this.tabDecoratorService=s,this.tabRouterService=c,this.sdNotifyService=l,this.tabs=[],T.set(this,void 0),P.set(this,new n.Subscription),C.set(this,!0),N.set(this,(function(t){var e,r=t.isActive,n=t.key;if(r){var o=f.tabs.findIndex((function(t){return t.key===n})),a=f.tabs[o+1]||f.tabs[o-1];if(a){var i=a.url,u=Object.assign({},a.queryParams||{});f.tabs=f.tabs.filter((function(t){return t.key!==n})),f.router.navigate([i],{queryParams:u,state:{switchTab:!0}})}else f.tabs=f.tabs.filter((function(t){return t.key!==n})),f.router.navigateByUrl("/",{state:{switchTab:!0}})}else f.tabs=f.tabs.filter((function(e){return e.key!==t.key})),null===(e=f.tabRouterNav)||void 0===e||e.checkUI(),f.cd.markForCheck()})),O.set(this,(function(t,e){return d(f,void 0,void 0,(function(){var r,n,o,a,i,u,s,c,l,f,b,d,m,g,_,w,x,j,R,I,P,C,N,O,q=this;return h(this,(function(h){switch(h.label){case 0:return(null==e?void 0:e.component)?(f=e.component,b=Object.assign({},e.queryParams||{}),d=Object.assign({},e.params||{}),m=v(t.split("?"),1),g=m[0],_=p({url:g,queryParams:b}),w=-1,x=-1,this.tabs.forEach((function(t,e){t.key===_?(t.isActive=!0,w=e):(t.isActive&&(x=e,q.tabRouterService.pushEvent(t,S)),t.isActive=!1)})),j=this.router.getCurrentNavigation(),w>=0&&(null===(n=null===(r=null==j?void 0:j.extras)||void 0===r?void 0:r.state)||void 0===n?void 0:n.switchTab)?(R=this.tabs[w],this.tabRouterService.setCurrentTab(R),this.tabRouterService.pushEvent(R,k),[3,5]):[3,1]):[2];case 1:return"function"!=typeof(null===(a=null===(o=null==e?void 0:e.parent)||void 0===o?void 0:o.routeConfig)||void 0===a?void 0:a.loadChildren)?[3,4]:[4,e.parent.routeConfig.loadChildren()];case 2:return I=h.sent(),[4,this.compiler.compileModuleAsync(I)];case 3:P=h.sent(),C=P.create(this.injector),N=y(this,M).call(this,y(this,T),f),O={key:_,component:f,injector:new E(N,C),isActive:!0,name:g,url:g,params:d,queryParams:b},this.tabRouterService.setCurrentTab(O),x>=0&&(null===(u=null===(i=null==j?void 0:j.extras)||void 0===i?void 0:i.state)||void 0===u?void 0:u.replaceTab)&&this.tabs.splice(x,1),w>=0&&!(null===(c=null===(s=null==j?void 0:j.extras)||void 0===s?void 0:s.state)||void 0===c?void 0:c.switchTab)?this.tabs[w]=O:this.tabs.push(O),h.label=4;case 4:null===(l=this.tabRouterNav)||void 0===l||l.checkUI(),this.tabs.length>10&&this.sdNotifyService.notify.warning("Bạn đã mở quá nhiều tab. Vui lòng tắt các tab không dùng để hệ thống hoạt động tốt hơn."),this.tabs.length>12&&this.tabs.splice(0,this.tabs.length-10),h.label=5;case 5:return this.cd.markForCheck(),[2]}}))}))})),q.set(this,(function(t){if(!t)return null;for(;t.firstChild;)t=t.firstChild;return t})),M.set(this,(function(t,e){if(!t)return null;if(t.component&&t.component===e)return t;for(;t.firstChild;)if((t=t.firstChild).component&&t.component===e)return t;return null})),y(this,P).add(t.events.pipe(e.filter((function(t){return t instanceof a.RoutesRecognized||t instanceof a.NavigationEnd}))).subscribe((function(t){return d(f,void 0,void 0,(function(){var e;return h(this,(function(r){switch(r.label){case 0:return y(this,C)&&t instanceof a.NavigationEnd?(g(this,C,!1),e=y(this,q).call(this,this.activatedRoute.snapshot),g(this,T,this.router.routerState.root),[4,y(this,O).call(this,t.urlAfterRedirects||t.url,e)]):[3,2];case 1:return r.sent(),[2];case 2:return!y(this,C)&&t instanceof a.RoutesRecognized?(e=y(this,q).call(this,t.state.root),g(this,T,this.router.routerState.root),[4,y(this,O).call(this,t.urlAfterRedirects||t.url,e)]):[3,4];case 3:r.sent(),r.label=4;case 4:return[2]}}))}))}))),y(this,P).add(c.actions.subscribe((function(t){t&&"close"===t.type&&y(f,N).call(f,t.tab)})))}return t.prototype.ngOnDestroy=function(){y(this,P).unsubscribe()},t}();T=new WeakMap,P=new WeakMap,C=new WeakMap,N=new WeakMap,O=new WeakMap,q=new WeakMap,M=new WeakMap,D.decorators=[{type:r.Component,args:[{selector:"sd-tab-router-outlet",template:'<sd-tab-router-nav [tabs]="tabs" #tabRouterNav></sd-tab-router-nav>\r\n\r\n<div class="tab-router__list">\r\n <ng-container *ngFor="let tab of tabs">\r\n <div class="tab-router__pane" [class.active]="tab.isActive" [id]="tab.key">\r\n <div class="tab-router__content">\r\n <ng-container\r\n *ngComponentOutlet="tab.component; injector: tab.injector"\r\n ></ng-container>\r\n </div>\r\n </div>\r\n </ng-container>\r\n</div>\r\n',styles:[":host{display:flex;flex-direction:column;height:calc(100vh - 64px);width:100%}::ng-deep page-layout{height:100%!important}.tab-router__list{flex:1}.tab-router__pane{display:none;height:100%;position:relative;width:100%}.tab-router__pane.active{display:block}.tab-router__content{bottom:0;height:100%;left:0;overflow:auto;position:absolute;right:0;top:0;width:100%}"]}]}],D.ctorParameters=function(){return[{type:a.Router},{type:a.ActivatedRoute},{type:r.ChangeDetectorRef},{type:r.Injector},{type:r.Compiler},{type:R},{type:j},{type:o.SdNotifyService}]},D.propDecorators={tabRouterNav:[{type:r.ViewChild,args:["tabRouterNav"]}]};var E=function(){function t(t,e){this.route=t,this.parent=e}return t.prototype.get=function(t,e){return t===a.ActivatedRoute&&this.route?this.route:this.parent.get(t,e)},t}(),W=function(){function t(t){this.tabRouterService=t}return t.prototype.transform=function(t){return this.tabRouterService.builders.pipe(e.map((function(e){var r=e.find((function(e){return e.component===t.component}));if(r){var n=t.url,o=t.params,a=t.queryParams;return t.tabInfo={name:"function"==typeof r.name?r.name({url:n,params:o,queryParams:a}):r.name,initialName:"function"==typeof r.initialName?r.initialName({url:n,params:o,queryParams:a}):r.initialName,tooltip:"function"==typeof r.tooltip?r.tooltip({url:n,params:o,queryParams:a}):r.tooltip,color:"function"==typeof r.color?r.color({url:n,params:o,queryParams:a}):r.color},t.tabInfo}return t.tabInfo={name:t.url,initialName:null},t.tabInfo})))},t}();W.decorators=[{type:r.Pipe,args:[{name:"sdTabInfo"}]}],W.ctorParameters=function(){return[{type:j}]};var z=function(){};z.decorators=[{type:r.NgModule,args:[{declarations:[I,A,D,W],imports:[a.RouterModule,u.CommonModule,s.MatIconModule,c.MatTooltipModule],exports:[I,A,D],providers:[]}]}],t.SdTabActivated=k,t.SdTabBase=_,t.SdTabComponent=function(t){return function(r){R.tabRouterService.pipe(e.filter((function(t){return null!=t})),e.take(1)).subscribe((function(e){e.addBuilder(t)}))}},t.SdTabDeactivated=S,t.SdTabDecoratorService=R,t.SdTabRouterItemComponent=I,t.SdTabRouterModule=z,t.SdTabRouterNavComponent=A,t.SdTabRouterOutletComponent=D,t.SdTabRouterService=j,t.ɵa=W,Object.defineProperty(t,"__esModule",{value:!0})}));
|
|
15
|
+
***************************************************************************** */function b(t,e){function r(){this.constructor=t}f(t,e),t.prototype=null===e?Object.create(e):(r.prototype=e.prototype,new r)}function d(t,e,r,n){return new(r||(r=Promise))((function(o,a){function i(t){try{s(n.next(t))}catch(t){a(t)}}function u(t){try{s(n.throw(t))}catch(t){a(t)}}function s(t){var e;t.done?o(t.value):(e=t.value,e instanceof r?e:new r((function(t){t(e)}))).then(i,u)}s((n=n.apply(t,e||[])).next())}))}function h(t,e){var r,n,o,a,i={label:0,sent:function(){if(1&o[0])throw o[1];return o[1]},trys:[],ops:[]};return a={next:u(0),throw:u(1),return:u(2)},"function"==typeof Symbol&&(a[Symbol.iterator]=function(){return this}),a;function u(a){return function(u){return function(a){if(r)throw new TypeError("Generator is already executing.");for(;i;)try{if(r=1,n&&(o=2&a[0]?n.return:a[0]?n.throw||((o=n.return)&&o.call(n),0):n.next)&&!(o=o.call(n,a[1])).done)return o;switch(n=0,o&&(a=[2&a[0],o.value]),a[0]){case 0:case 1:o=a;break;case 4:return i.label++,{value:a[1],done:!1};case 5:i.label++,n=a[1],a=[0];continue;case 7:a=i.ops.pop(),i.trys.pop();continue;default:if(!(o=i.trys,(o=o.length>0&&o[o.length-1])||6!==a[0]&&2!==a[0])){i=0;continue}if(3===a[0]&&(!o||a[1]>o[0]&&a[1]<o[3])){i.label=a[1];break}if(6===a[0]&&i.label<o[1]){i.label=o[1],o=a;break}if(o&&i.label<o[2]){i.label=o[2],i.ops.push(a);break}o[2]&&i.ops.pop(),i.trys.pop();continue}a=e.call(t,i)}catch(t){a=[6,t],n=0}finally{r=o=0}if(5&a[0])throw a[1];return{value:a[0]?a[1]:void 0,done:!0}}([a,u])}}}Object.create;function v(t,e){var r="function"==typeof Symbol&&t[Symbol.iterator];if(!r)return t;var n,o,a=r.call(t),i=[];try{for(;(void 0===e||e-- >0)&&!(n=a.next()).done;)i.push(n.value)}catch(t){o={error:t}}finally{try{n&&!n.done&&(r=a.return)&&r.call(a)}finally{if(o)throw o.error}}return i}var m;Object.create;function g(t,e){if(!e.has(t))throw new TypeError("attempted to get private field on non-instance");return e.get(t)}function y(t,e,r){if(!e.has(t))throw new TypeError("attempted to set private field on non-instance");return e.set(t,r),r}var _=function(){function t(t){m.set(this,void 0),y(this,m,t)}return Object.defineProperty(t.prototype,"tab",{get:function(){return g(this,m)},enumerable:!1,configurable:!0}),t}();m=new WeakMap;var w,x,k=function(t){function e(){return null!==t&&t.apply(this,arguments)||this}return b(e,t),e}(_),S=function(t){function e(){return null!==t&&t.apply(this,arguments)||this}return b(e,t),e}(_),j=function(){function t(t){var e=this;this.notifyService=t,this.events=new n.BehaviorSubject(new _(null)),this.actions=new n.BehaviorSubject(null),this.builders=new n.BehaviorSubject([]),w.set(this,null),x.set(this,[]),this.addBuilder=function(t){g(e,x).some((function(e){return e.component===t.component}))||(g(e,x).push(t),e.builders.next(g(e,x)))},this.setCurrentTab=function(t){y(e,w,t)},this.pushEvent=function(t,r){e.events.next(new r(t))},this.setOptions=function(){},this.close=function(t){t?e.actions.next({type:"close",tab:t}):g(e,w)&&e.actions.next({type:"close",tab:g(e,w)})}}return Object.defineProperty(t.prototype,"currentTab",{get:function(){return g(this,w)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"key",{get:function(){var t;return(null===(t=g(this,w))||void 0===t?void 0:t.key)||null},enumerable:!1,configurable:!0}),t}();w=new WeakMap,x=new WeakMap,j.ɵprov=r.ɵɵdefineInjectable({factory:function(){return new j(r.ɵɵinject(o.SdNotifyService))},token:j,providedIn:"root"}),j.decorators=[{type:r.Injectable,args:[{providedIn:"root"}]}],j.ctorParameters=function(){return[{type:o.SdNotifyService}]};var R=function t(e){t.tabRouterService.next(e)};R.tabRouterService=new n.BehaviorSubject(void 0),R.ɵprov=r.ɵɵdefineInjectable({factory:function(){return new R(r.ɵɵinject(j))},token:R,providedIn:"root"}),R.decorators=[{type:r.Injectable,args:[{providedIn:"root"}]}],R.ctorParameters=function(){return[{type:j}]};var I=function(t){var e=this;this.tabRouterService=t,this.close=function(t){t.preventDefault(),t.stopPropagation(),e.tabRouterService.close(e.tab)}};I.decorators=[{type:r.Component,args:[{selector:"sd-tab-router-item",template:'<a [routerLink]="[tab.url]" [queryParams]="tab.queryParams" [state]="{ switchTab: true }"\r\n class="tab-router__item d-flex align-items-center" [ngClass]="{\r\n \'tab-router__item--active\': tab.isActive\r\n }">\r\n <ng-container *ngIf="tab | sdTabInfo | async as tabInfo">\r\n <div class="\r\n tab-router__icon\r\n d-flex\r\n align-items-center\r\n justify-content-center\r\n mr-8\r\n " [ngStyle]="{\r\n \'background-color\': tabInfo.color\r\n }" [matTooltip]="tabInfo.tooltip || tabInfo.name" matTooltipPosition="below" matTooltipShowDelay="1000">\r\n {{ tabInfo.initialName || \'SD\' }}\r\n </div>\r\n <div class="flex-1">\r\n <div class="tab-router__name">{{ tabInfo.name }}</div>\r\n </div>\r\n <button type="button" class="\r\n tab-router__close\r\n d-flex\r\n align-items-center\r\n justify-content-center\r\n ml-4\r\n " (click)="close($event)">\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n </ng-container>\r\n\r\n</a>',styles:[':host{flex:1 1 auto;max-width:240px;position:relative}:host:after{background:#dde0e5;bottom:0;content:"";height:16px;margin:auto;position:absolute;right:0;top:0;width:1px}:host:last-child:after{content:none}.flex-1{flex:1}.tab-router__icon{background-color:#5c6bc0;border-radius:2px;color:#fff;font-size:10px;height:16px;line-height:1;text-transform:uppercase;width:16px}.tab-router__icon .mat-icon{font-size:10px;height:10px;width:10px}.tab-router__close{background:none;border:0;border-radius:50%;color:#757575;height:16px;outline:none;width:16px}.tab-router__close:hover{background-color:rgba(0,0,0,.12)}.tab-router__close .mat-icon{font-size:12px;height:12px;width:12px}.tab-router__item{background:#f2f3f4;color:inherit;font-size:12px;line-height:16px;padding:16px 16px 8px;text-decoration:none}.tab-router__item:hover{background-color:#fff}.tab-router__name{-webkit-box-orient:vertical;-webkit-line-clamp:1;display:-webkit-box;overflow:hidden;text-overflow:ellipsis}.tab-router__item--active{background-color:#fff;border-radius:8px 8px 0 0}']}]}],I.ctorParameters=function(){return[{type:j}]},I.propDecorators={tab:[{type:r.Input}]};var T,P,C,N,O,q,M,A=function(){function t(){var t=this;this.mode="default",this.checkUI=function(){var e=(t.tabRouterNav.nativeElement.clientWidth-64*t.tabs.length)/t.tabs.length;t.mode=e<=20?"compact":"default"}}return t.prototype.onResize=function(t){this.checkUI()},t}();A.decorators=[{type:r.Component,args:[{selector:"sd-tab-router-nav",template:'<div\r\n #tabRouterNav\r\n class="tab-router__nav tab-router__nav--{{ mode }} d-flex align-items-center"\r\n>\r\n <ng-container *ngFor="let tab of tabs">\r\n <sd-tab-router-item [tab]="tab"></sd-tab-router-item>\r\n </ng-container>\r\n</div>\r\n',styles:[".tab-router__nav{background:#f9f9f9}.tab-router__nav--compact::ng-deep .tab-router__name{display:none}.tab-router__nav--compact::ng-deep .tab-router__icon{margin:0!important}.tab-router__nav--compact::ng-deep .tab-router__item--active{min-width:240px}.tab-router__nav--compact::ng-deep .tab-router__item--active .tab-router__icon{margin-right:8px!important}.tab-router__nav--compact::ng-deep .tab-router__item--active .tab-router__name{display:-webkit-box}"]}]}],A.ctorParameters=function(){return[]},A.propDecorators={tabRouterNav:[{type:r.ViewChild,args:["tabRouterNav"]}],tabs:[{type:r.Input}],onResize:[{type:r.HostListener,args:["window:resize",["$event"]]}]};var D=function(){function t(t,r,o,i,u,s,c,l){var f=this;this.router=t,this.activatedRoute=r,this.cd=o,this.injector=i,this.compiler=u,this.tabDecoratorService=s,this.tabRouterService=c,this.sdNotifyService=l,this.tabs=[],T.set(this,void 0),P.set(this,new n.Subscription),C.set(this,!0),N.set(this,(function(t){var e,r=t.isActive,n=t.key;if(r){var o=f.tabs.findIndex((function(t){return t.key===n})),a=f.tabs[o+1]||f.tabs[o-1];if(a){var i=a.url,u=Object.assign({},a.queryParams||{});f.tabs=f.tabs.filter((function(t){return t.key!==n})),f.router.navigate([i],{queryParams:u,state:{switchTab:!0}})}else f.tabs=f.tabs.filter((function(t){return t.key!==n})),f.router.navigateByUrl("/",{state:{switchTab:!0}})}else f.tabs=f.tabs.filter((function(e){return e.key!==t.key})),null===(e=f.tabRouterNav)||void 0===e||e.checkUI(),f.cd.markForCheck()})),O.set(this,(function(t,e){return d(f,void 0,void 0,(function(){var r,n,o,a,i,u,s,c,l,f,b,d,m,y,_,w,x,j,R,I,P,C,N,O,q=this;return h(this,(function(h){switch(h.label){case 0:return(null==e?void 0:e.component)?(f=e.component,b=Object.assign({},e.queryParams||{}),d=Object.assign({},e.params||{}),m=v(t.split("?"),1),y=m[0],_=p({url:y,queryParams:b}),w=-1,x=-1,this.tabs.forEach((function(t,e){t.key===_?(t.isActive=!0,w=e):(t.isActive&&(x=e,q.tabRouterService.pushEvent(t,S)),t.isActive=!1)})),j=this.router.getCurrentNavigation(),w>=0&&(null===(n=null===(r=null==j?void 0:j.extras)||void 0===r?void 0:r.state)||void 0===n?void 0:n.switchTab)?(R=this.tabs[w],this.tabRouterService.setCurrentTab(R),this.tabRouterService.pushEvent(R,k),[3,5]):[3,1]):[2];case 1:return"function"!=typeof(null===(a=null===(o=null==e?void 0:e.parent)||void 0===o?void 0:o.routeConfig)||void 0===a?void 0:a.loadChildren)?[3,4]:[4,e.parent.routeConfig.loadChildren()];case 2:return I=h.sent(),[4,this.compiler.compileModuleAsync(I)];case 3:P=h.sent(),C=P.create(this.injector),N=g(this,M).call(this,g(this,T),f),O={key:_,component:f,injector:new E(N,C),isActive:!0,name:y,url:y,params:d,queryParams:b},this.tabRouterService.setCurrentTab(O),x>=0&&(null===(u=null===(i=null==j?void 0:j.extras)||void 0===i?void 0:i.state)||void 0===u?void 0:u.replaceTab)&&this.tabs.splice(x,1),w>=0&&!(null===(c=null===(s=null==j?void 0:j.extras)||void 0===s?void 0:s.state)||void 0===c?void 0:c.switchTab)?this.tabs[w]=O:this.tabs.push(O),h.label=4;case 4:null===(l=this.tabRouterNav)||void 0===l||l.checkUI(),this.tabs.length>10&&this.sdNotifyService.notify.warning("Bạn đã mở quá nhiều tab. Vui lòng tắt các tab không dùng để hệ thống hoạt động tốt hơn."),this.tabs.length>12&&this.tabs.splice(0,this.tabs.length-10),h.label=5;case 5:return this.cd.markForCheck(),[2]}}))}))})),q.set(this,(function(t){if(!t)return null;for(;t.firstChild;)t=t.firstChild;return t})),M.set(this,(function(t,e){if(!t)return null;if(t.component&&t.component===e)return t;for(;t.firstChild;)if((t=t.firstChild).component&&t.component===e)return t;return null})),g(this,P).add(t.events.pipe(e.filter((function(t){return t instanceof a.RoutesRecognized||t instanceof a.NavigationEnd}))).subscribe((function(t){return d(f,void 0,void 0,(function(){var e;return h(this,(function(r){switch(r.label){case 0:return g(this,C)&&t instanceof a.NavigationEnd?(y(this,C,!1),e=g(this,q).call(this,this.activatedRoute.snapshot),y(this,T,this.router.routerState.root),[4,g(this,O).call(this,t.urlAfterRedirects||t.url,e)]):[3,2];case 1:return r.sent(),[2];case 2:return!g(this,C)&&t instanceof a.RoutesRecognized?(e=g(this,q).call(this,t.state.root),y(this,T,this.router.routerState.root),[4,g(this,O).call(this,t.urlAfterRedirects||t.url,e)]):[3,4];case 3:r.sent(),r.label=4;case 4:return[2]}}))}))}))),g(this,P).add(c.actions.subscribe((function(t){t&&"close"===t.type&&g(f,N).call(f,t.tab)})))}return t.prototype.ngOnDestroy=function(){g(this,P).unsubscribe()},t}();T=new WeakMap,P=new WeakMap,C=new WeakMap,N=new WeakMap,O=new WeakMap,q=new WeakMap,M=new WeakMap,D.decorators=[{type:r.Component,args:[{selector:"sd-tab-router-outlet",template:'<sd-tab-router-nav [tabs]="tabs" #tabRouterNav></sd-tab-router-nav>\r\n\r\n<div class="tab-router__list">\r\n <ng-container *ngFor="let tab of tabs">\r\n <div class="tab-router__pane" [class.active]="tab.isActive" [id]="tab.key">\r\n <div class="tab-router__content">\r\n <ng-container\r\n *ngComponentOutlet="tab.component; injector: tab.injector"\r\n ></ng-container>\r\n </div>\r\n </div>\r\n </ng-container>\r\n</div>\r\n',styles:[":host{display:flex;flex-direction:column;height:calc(100vh - 64px);width:100%}:host ::ng-deep .sd-loading{max-height:100%;max-width:100%}::ng-deep page-layout{height:100%!important}.tab-router__list{flex:1}.tab-router__pane{display:none;height:100%;position:relative;width:100%}.tab-router__pane.active{display:block}.tab-router__content{bottom:0;height:100%;left:0;overflow:auto;position:absolute;right:0;top:0;width:100%}"]}]}],D.ctorParameters=function(){return[{type:a.Router},{type:a.ActivatedRoute},{type:r.ChangeDetectorRef},{type:r.Injector},{type:r.Compiler},{type:R},{type:j},{type:o.SdNotifyService}]},D.propDecorators={tabRouterNav:[{type:r.ViewChild,args:["tabRouterNav"]}]};var E=function(){function t(t,e){this.route=t,this.parent=e}return t.prototype.get=function(t,e){return t===a.ActivatedRoute&&this.route?this.route:this.parent.get(t,e)},t}(),W=function(){function t(t){this.tabRouterService=t}return t.prototype.transform=function(t){return this.tabRouterService.builders.pipe(e.map((function(e){var r=e.find((function(e){return e.component===t.component}));if(r){var n=t.url,o=t.params,a=t.queryParams;return t.tabInfo={name:"function"==typeof r.name?r.name({url:n,params:o,queryParams:a}):r.name,initialName:"function"==typeof r.initialName?r.initialName({url:n,params:o,queryParams:a}):r.initialName,tooltip:"function"==typeof r.tooltip?r.tooltip({url:n,params:o,queryParams:a}):r.tooltip,color:"function"==typeof r.color?r.color({url:n,params:o,queryParams:a}):r.color},t.tabInfo}return t.tabInfo={name:t.url,initialName:null},t.tabInfo})))},t}();W.decorators=[{type:r.Pipe,args:[{name:"sdTabInfo"}]}],W.ctorParameters=function(){return[{type:j}]};var z=function(){};z.decorators=[{type:r.NgModule,args:[{declarations:[I,A,D,W],imports:[a.RouterModule,u.CommonModule,s.MatIconModule,c.MatTooltipModule],exports:[I,A,D],providers:[]}]}],t.SdTabActivated=k,t.SdTabBase=_,t.SdTabComponent=function(t){return function(r){R.tabRouterService.pipe(e.filter((function(t){return null!=t})),e.take(1)).subscribe((function(e){e.addBuilder(t)}))}},t.SdTabDeactivated=S,t.SdTabDecoratorService=R,t.SdTabRouterItemComponent=I,t.SdTabRouterModule=z,t.SdTabRouterNavComponent=A,t.SdTabRouterOutletComponent=D,t.SdTabRouterService=j,t.ɵa=W,Object.defineProperty(t,"__esModule",{value:!0})}));
|
|
16
16
|
//# sourceMappingURL=sd-angular-core-tab-router.umd.min.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../node_modules/tslib/tslib.es6.js","../../../../projects/sd-core/tab-router/src/lib/events/tab-router.event.ts","../../../../projects/sd-core/tab-router/src/lib/services/tab-router.service.ts","../../../../projects/sd-core/tab-router/src/lib/services/tab-decorator.service.ts","../../../../projects/sd-core/tab-router/src/lib/components/tab-router-item/tab-router-item.component.ts","../../../../projects/sd-core/tab-router/src/lib/components/tab-router-nav/tab-router-nav.component.ts","../../../../projects/sd-core/tab-router/src/lib/components/tab-router-outlet/tab-router-outlet.component.ts","../../../../projects/sd-core/tab-router/src/lib/pipes/tab-info.pipe.ts","../../../../projects/sd-core/tab-router/src/lib/tab-router.module.ts","../../../../projects/sd-core/tab-router/src/lib/decorators/tab.decorator.ts"],"names":["extendStatics","d","b","Object","setPrototypeOf","__proto__","Array","p","prototype","hasOwnProperty","call","__extends","__","this","constructor","create","__awaiter","thisArg","_arguments","P","generator","Promise","resolve","reject","fulfilled","value","step","next","e","rejected","result","done","then","apply","__generator","body","f","y","t","g","_","label","sent","trys","ops","verb","throw","return","Symbol","iterator","n","v","op","TypeError","pop","length","push","__read","o","m","r","i","ar","error","__classPrivateFieldGet","receiver","privateMap","has","get","__classPrivateFieldSet","set","SdTabBase","tab","_tab","defineProperty","SdTabActivated","_super","SdTabDeactivated","SdTabRouterService","notifyService","_this","events","BehaviorSubject","actions","builders","_currentTab","_componentBuilders","addBuilder","builder","some","component","setCurrentTab","pushEvent","Event","setOptions","close","type","_a","key","Injectable","args","providedIn","SdNotifyService","SdTabDecoratorService","tabRouterService","undefined","event","preventDefault","stopPropagation","Component","selector","template","Input","SdTabRouterNavComponent","mode","checkUI","nameWidth","tabRouterNav","nativeElement","clientWidth","tabs","onResize","ViewChild","HostListener","SdTabRouterOutletComponent","router","activatedRoute","cd","injector","compiler","tabDecoratorService","sdNotifyService","_rootRoute","_subscription","Subscription","_firstLoad","_closeTab","isActive","activeKey","activeIndex","findIndex","_k","nextTab","nextUrl","url","nextQueryParams","assign","queryParams","filter","navigate","state","switchTab","navigateByUrl","markForCheck","_activeRoute","fullUrl","route","params","split","hash","existedIndex","activatedIndex","forEach","index","currentNavigation","getCurrentNavigation","_b","extras","existedTab","_d","_c","parent","routeConfig","loadChildren","module","_l","compileModuleAsync","factory","injector_1","activatedRoute_1","_getActivatedRoute","SdOutletInjector","name","_f","_e","replaceTab","splice","_h","_g","_j","notify","warning","_getActivatedRouteSnapshot","activatedRouteSnapshot","firstChild","add","pipe","RoutesRecognized","NavigationEnd","subscribe","snapshot","routerState","root","urlAfterRedirects","ngOnDestroy","unsubscribe","Router","ActivatedRoute","ChangeDetectorRef","Injector","Compiler","token","notFoundValue","SdTabInfoPipe","transform","map","find","tabInfo","initialName","tooltip","color","Pipe","NgModule","declarations","SdTabRouterItemComponent","imports","RouterModule","CommonModule","MatIconModule","MatTooltipModule","exports","providers","service","take"],"mappings":"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","sourcesContent":["/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n};\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, privateMap) {\r\n if (!privateMap.has(receiver)) {\r\n throw new TypeError(\"attempted to get private field on non-instance\");\r\n }\r\n return privateMap.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, privateMap, value) {\r\n if (!privateMap.has(receiver)) {\r\n throw new TypeError(\"attempted to set private field on non-instance\");\r\n }\r\n privateMap.set(receiver, value);\r\n return value;\r\n}\r\n","import { SdTab } from '../models/tab-router.model';\r\n\r\nexport class SdTabBase {\r\n #tab: SdTab | null;\r\n\r\n constructor(tab: SdTab | null) {\r\n this.#tab = tab;\r\n }\r\n\r\n get tab(): SdTab | null {\r\n return this.#tab;\r\n }\r\n}\r\n\r\nexport class SdTabActivated extends SdTabBase {}\r\n\r\nexport class SdTabDeactivated extends SdTabBase {}\r\n\r\nexport declare type SdTabEvent = SdTabActivated | SdTabDeactivated;\r\n","import { Injectable, Type } from '@angular/core';\r\nimport { BehaviorSubject } from 'rxjs';\r\nimport { SdTab } from '../models/tab-router.model';\r\nimport { SdTabAction } from '../actions/tab-router.action';\r\nimport { SdTabEvent, SdTabBase } from '../events/tab-router.event';\r\nimport { SdNotifyService } from '@sd-angular/core/notify';\r\nimport { SdTabComponentBuilder } from '../decorators/tab.decorator';\r\n\r\n@Injectable({\r\n providedIn: 'root',\r\n})\r\nexport class SdTabRouterService {\r\n events = new BehaviorSubject<SdTabEvent>(new SdTabBase(null));\r\n actions = new BehaviorSubject<SdTabAction | null>(null);\r\n builders = new BehaviorSubject<SdTabComponentBuilder[]>([]);\r\n\r\n #currentTab: SdTab | null = null;\r\n #componentBuilders: SdTabComponentBuilder[] = [];\r\n constructor(private notifyService: SdNotifyService) {\r\n }\r\n\r\n addBuilder = (builder: SdTabComponentBuilder) => {\r\n if (!this.#componentBuilders.some(e => e.component === builder.component)) {\r\n this.#componentBuilders.push(builder);\r\n this.builders.next(this.#componentBuilders);\r\n }\r\n }\r\n\r\n get currentTab() {\r\n return this.#currentTab;\r\n }\r\n\r\n get key() {\r\n return this.#currentTab?.key || null;\r\n }\r\n\r\n // select = (tabOrKey: string | SdTab): void => {\r\n // const tab = this.#tabs.find(e => {\r\n // if (typeof (tabOrKey) === 'string') {\r\n // return e.key === tabOrKey;\r\n // }\r\n // return e.key === tabOrKey?.key;\r\n // });\r\n // if (tab) {\r\n // this.#currentTab = tab;\r\n // }\r\n // }\r\n\r\n // add = (tab: SdTab): void => {\r\n // if (!tab.key) {\r\n // this.notifyService.notify.warning('Tab key is required');\r\n // }\r\n // if (!tab.component) {\r\n // this.notifyService.notify.warning('Tab component is required');\r\n // }\r\n // const existedTab = this.#tabs.find(e => e.key === tab.key);\r\n // if (!existedTab) {\r\n // this.#tabs.push(tab);\r\n // this.select(tab);\r\n // } else {\r\n // this.select(existedTab);\r\n // }\r\n // }\r\n\r\n // remove = (tabOrKey: string | SdTab): void => {\r\n // this.#tabs = this.#tabs.filter(e => {\r\n // if (typeof (tabOrKey) === 'string') {\r\n // return e.key !== tabOrKey;\r\n // }\r\n // return e.key !== tabOrKey?.key;\r\n // });\r\n // }\r\n\r\n setCurrentTab = (tab: SdTab): void => {\r\n this.#currentTab = tab;\r\n }\r\n\r\n pushEvent = (tab: SdTab, Event: Type<SdTabEvent>) => {\r\n this.events.next(new Event(tab));\r\n }\r\n\r\n setOptions = () => { };\r\n\r\n close = (tab?: SdTab) => {\r\n if (tab) {\r\n this.actions.next({\r\n type: 'close',\r\n tab,\r\n });\r\n } else if (this.#currentTab) {\r\n this.actions.next({\r\n type: 'close',\r\n tab: this.#currentTab,\r\n });\r\n }\r\n }\r\n}\r\n","import { Injectable } from '@angular/core';\r\nimport { BehaviorSubject } from 'rxjs';\r\nimport { SdTabRouterService } from './tab-router.service';\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class SdTabDecoratorService {\r\n static tabRouterService = new BehaviorSubject<SdTabRouterService>(undefined);\r\n constructor(tabRouterService: SdTabRouterService) {\r\n SdTabDecoratorService.tabRouterService.next(tabRouterService);\r\n }\r\n}\r\n","import { Component, Input } from '@angular/core';\r\n\r\nimport { SdTab } from '../../models/tab-router.model';\r\nimport { SdTabRouterService } from '../../services/tab-router.service';\r\n\r\n@Component({\r\n selector: 'sd-tab-router-item',\r\n templateUrl: './tab-router-item.component.html',\r\n styleUrls: ['./tab-router-item.component.scss'],\r\n})\r\nexport class SdTabRouterItemComponent {\r\n @Input() tab: SdTab;\r\n\r\n constructor(private tabRouterService: SdTabRouterService) {}\r\n\r\n close = (event: Event) => {\r\n event.preventDefault();\r\n event.stopPropagation();\r\n this.tabRouterService.close(this.tab);\r\n }\r\n}\r\n","import {\r\n Component,\r\n ElementRef,\r\n HostListener,\r\n Input,\r\n ViewChild,\r\n} from '@angular/core';\r\n\r\nimport { SdTab } from '../../models/tab-router.model';\r\n\r\n@Component({\r\n selector: 'sd-tab-router-nav',\r\n templateUrl: './tab-router-nav.component.html',\r\n styleUrls: ['./tab-router-nav.component.scss'],\r\n})\r\nexport class SdTabRouterNavComponent {\r\n @ViewChild('tabRouterNav') tabRouterNav: ElementRef;\r\n\r\n @Input() tabs: SdTab[];\r\n mode: 'default' | 'compact' = 'default';\r\n\r\n constructor() {}\r\n\r\n @HostListener('window:resize', ['$event'])\r\n onResize(event): void {\r\n this.checkUI();\r\n }\r\n\r\n checkUI = () => {\r\n const width = this.tabRouterNav.nativeElement.clientWidth;\r\n const nameWidth = (width - this.tabs.length * 64) / this.tabs.length;\r\n if (nameWidth <= 20) {\r\n this.mode = 'compact';\r\n } else {\r\n this.mode = 'default';\r\n }\r\n }\r\n}\r\n","import {\r\n ChangeDetectionStrategy,\r\n ChangeDetectorRef,\r\n Compiler,\r\n Component,\r\n Injector,\r\n NgModuleRef,\r\n OnDestroy,\r\n OnInit,\r\n Type,\r\n ViewChild,\r\n} from '@angular/core';\r\nimport {\r\n ActivatedRoute,\r\n ActivatedRouteSnapshot,\r\n ChildrenOutletContexts,\r\n // ChildrenOutletContexts,\r\n Event,\r\n NavigationEnd,\r\n PRIMARY_OUTLET,\r\n Router,\r\n RoutesRecognized,\r\n} from '@angular/router';\r\nimport { SdNotifyService } from '@sd-angular/core/notify';\r\nimport {\r\n SdTabActivated,\r\n SdTabDeactivated,\r\n} from '../../events/tab-router.event';\r\n\r\nimport { SdTab } from '../../models/tab-router.model';\r\nimport { SdTabAction } from '../../actions/tab-router.action';\r\nimport { SdTabRouterService } from '../../services/tab-router.service';\r\nimport { SdTabRouterNavComponent } from '../tab-router-nav/tab-router-nav.component';\r\nimport { Subscription } from 'rxjs';\r\nimport { SdTabDecoratorService } from '../../services/tab-decorator.service';\r\nimport { filter } from 'rxjs/operators';\r\nimport * as hash from 'object-hash';\r\n\r\n@Component({\r\n selector: 'sd-tab-router-outlet',\r\n templateUrl: './tab-router-outlet.component.html',\r\n styleUrls: ['./tab-router-outlet.component.scss'],\r\n // changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class SdTabRouterOutletComponent implements OnDestroy {\r\n @ViewChild('tabRouterNav') tabRouterNav: SdTabRouterNavComponent;\r\n tabs: SdTab[] = [];\r\n\r\n #rootRoute: ActivatedRoute;\r\n #subscription = new Subscription();\r\n #firstLoad = true;\r\n constructor(\r\n private router: Router,\r\n private activatedRoute: ActivatedRoute,\r\n private cd: ChangeDetectorRef,\r\n private injector: Injector,\r\n private compiler: Compiler,\r\n private tabDecoratorService: SdTabDecoratorService,\r\n private tabRouterService: SdTabRouterService,\r\n private sdNotifyService: SdNotifyService\r\n ) {\r\n this.#subscription.add(\r\n router.events\r\n .pipe(\r\n filter(\r\n (event) =>\r\n event instanceof RoutesRecognized ||\r\n event instanceof NavigationEnd\r\n )\r\n )\r\n .subscribe(async (event: RoutesRecognized | NavigationEnd) => {\r\n if (this.#firstLoad && event instanceof NavigationEnd) {\r\n this.#firstLoad = false;\r\n const route = this.#getActivatedRouteSnapshot(\r\n this.activatedRoute.snapshot\r\n );\r\n this.#rootRoute = this.router.routerState.root;\r\n await this.#activeRoute(\r\n event.urlAfterRedirects || event.url,\r\n route\r\n );\r\n return;\r\n }\r\n if (!this.#firstLoad && event instanceof RoutesRecognized) {\r\n const route = this.#getActivatedRouteSnapshot(event.state.root);\r\n this.#rootRoute = this.router.routerState.root;\r\n await this.#activeRoute(\r\n event.urlAfterRedirects || event.url,\r\n route\r\n );\r\n }\r\n })\r\n );\r\n\r\n this.#subscription.add(\r\n tabRouterService.actions.subscribe((event: SdTabAction | null) => {\r\n if (event && event.type === 'close') {\r\n this.#closeTab(event.tab);\r\n }\r\n })\r\n );\r\n }\r\n\r\n ngOnDestroy(): void {\r\n this.#subscription.unsubscribe();\r\n }\r\n\r\n #closeTab = (tab: SdTab) => {\r\n const { isActive, key: activeKey } = tab;\r\n\r\n if (isActive) {\r\n const activeIndex = this.tabs.findIndex(({ key }) => key === activeKey);\r\n const nextTab = this.tabs[activeIndex + 1] || this.tabs[activeIndex - 1];\r\n if (nextTab) {\r\n const { url: nextUrl } = nextTab;\r\n const nextQueryParams = {\r\n ...(nextTab.queryParams || {}),\r\n };\r\n\r\n this.tabs = this.tabs.filter(({ key }) => key !== activeKey);\r\n this.router.navigate([nextUrl], {\r\n queryParams: nextQueryParams,\r\n state: {\r\n switchTab: true,\r\n },\r\n });\r\n } else {\r\n this.tabs = this.tabs.filter(({ key }) => key !== activeKey);\r\n this.router.navigateByUrl('/', {\r\n state: {\r\n switchTab: true,\r\n },\r\n });\r\n }\r\n } else {\r\n this.tabs = this.tabs.filter(({ key }) => key !== tab.key);\r\n this.tabRouterNav?.checkUI();\r\n this.cd.markForCheck();\r\n }\r\n };\r\n\r\n #activeRoute = async (\r\n fullUrl: string,\r\n route: ActivatedRouteSnapshot | null\r\n ) => {\r\n if (!route?.component) {\r\n return;\r\n }\r\n const component = route.component as Type<any>;\r\n const queryParams = {\r\n ...(route.queryParams || {}),\r\n };\r\n const params = {\r\n ...(route.params || {}),\r\n };\r\n\r\n const [url] = fullUrl.split('?');\r\n const key = hash({ url, queryParams });\r\n\r\n let existedIndex = -1;\r\n let activatedIndex = -1;\r\n this.tabs.forEach((tab: SdTab, index: number) => {\r\n if (tab.key === key) {\r\n tab.isActive = true;\r\n existedIndex = index;\r\n } else {\r\n if (tab.isActive) {\r\n activatedIndex = index;\r\n this.tabRouterService.pushEvent(tab, SdTabDeactivated);\r\n }\r\n tab.isActive = false;\r\n }\r\n });\r\n\r\n const currentNavigation = this.router.getCurrentNavigation();\r\n if (existedIndex >= 0 && currentNavigation?.extras?.state?.switchTab) {\r\n const existedTab = this.tabs[existedIndex];\r\n this.tabRouterService.setCurrentTab(existedTab);\r\n this.tabRouterService.pushEvent(existedTab, SdTabActivated);\r\n } else {\r\n if (typeof route?.parent?.routeConfig?.loadChildren === 'function') {\r\n const module = await route.parent.routeConfig.loadChildren();\r\n const factory = await this.compiler.compileModuleAsync(module);\r\n const injector = factory.create(this.injector);\r\n const activatedRoute = this.#getActivatedRoute(\r\n this.#rootRoute,\r\n component\r\n );\r\n\r\n const tab = {\r\n key,\r\n component,\r\n injector: new SdOutletInjector(activatedRoute, injector),\r\n isActive: true,\r\n name: url,\r\n url,\r\n params,\r\n queryParams,\r\n };\r\n\r\n this.tabRouterService.setCurrentTab(tab);\r\n if (\r\n activatedIndex >= 0 &&\r\n currentNavigation?.extras?.state?.replaceTab\r\n ) {\r\n this.tabs.splice(activatedIndex, 1);\r\n }\r\n if (existedIndex >= 0 && !currentNavigation?.extras?.state?.switchTab) {\r\n this.tabs[existedIndex] = tab;\r\n } else {\r\n this.tabs.push(tab);\r\n }\r\n }\r\n\r\n this.tabRouterNav?.checkUI();\r\n if (this.tabs.length > 10) {\r\n this.sdNotifyService.notify.warning(\r\n 'Bạn đã mở quá nhiều tab. Vui lòng tắt các tab không dùng để hệ thống hoạt động tốt hơn.'\r\n );\r\n }\r\n if (this.tabs.length > 12) {\r\n this.tabs.splice(0, this.tabs.length - 10);\r\n }\r\n }\r\n this.cd.markForCheck();\r\n };\r\n\r\n #getActivatedRouteSnapshot = (\r\n activatedRouteSnapshot: ActivatedRouteSnapshot\r\n ): ActivatedRouteSnapshot | null => {\r\n if (!activatedRouteSnapshot) {\r\n return null;\r\n }\r\n while (activatedRouteSnapshot.firstChild) {\r\n activatedRouteSnapshot = activatedRouteSnapshot.firstChild;\r\n }\r\n return activatedRouteSnapshot;\r\n };\r\n\r\n #getActivatedRoute = (\r\n activatedRoute: ActivatedRoute,\r\n component: any\r\n ): ActivatedRoute | null => {\r\n if (!activatedRoute) {\r\n return null;\r\n }\r\n\r\n if (activatedRoute.component && activatedRoute.component === component) {\r\n return activatedRoute;\r\n }\r\n while (activatedRoute.firstChild) {\r\n activatedRoute = activatedRoute.firstChild;\r\n if (activatedRoute.component && activatedRoute.component === component) {\r\n return activatedRoute;\r\n }\r\n }\r\n return null;\r\n };\r\n}\r\n\r\nclass SdOutletInjector implements Injector {\r\n constructor(\r\n private route: ActivatedRoute | null,\r\n // private childContexts: ChildrenOutletContexts,\r\n private parent: any\r\n ) {}\r\n\r\n get(token: any, notFoundValue?: any): any {\r\n if (token === ActivatedRoute && this.route) {\r\n return this.route;\r\n }\r\n\r\n // if (token === ChildrenOutletContexts) {\r\n // return this.childContexts;\r\n // }\r\n\r\n return this.parent.get(token, notFoundValue);\r\n }\r\n}\r\n","import { Pipe, PipeTransform } from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\nimport { map } from 'rxjs/operators';\r\nimport { SdTab, SdTabInfo } from '../models/tab-router.model';\r\nimport { SdTabRouterService } from '../services/tab-router.service';\r\n@Pipe({\r\n name: 'sdTabInfo'\r\n})\r\nexport class SdTabInfoPipe implements PipeTransform {\r\n constructor(private tabRouterService: SdTabRouterService) { }\r\n transform(tab: SdTab): Observable<SdTabInfo> {\r\n return this.tabRouterService.builders.pipe(map(builders => {\r\n const builder = builders.find(e => e.component === tab.component);\r\n if (builder) {\r\n const { url, params, queryParams } = tab;\r\n tab.tabInfo = {\r\n name: typeof (builder.name) === 'function' ?\r\n builder.name({ url, params, queryParams }) : builder.name,\r\n initialName: typeof (builder.initialName) === 'function' ?\r\n builder.initialName({ url, params, queryParams }) : builder.initialName,\r\n tooltip: typeof (builder.tooltip) === 'function' ?\r\n builder.tooltip({ url, params, queryParams }) : builder.tooltip,\r\n color: typeof (builder.color) === 'function' ?\r\n builder.color({ url, params, queryParams }) : builder.color\r\n };\r\n return tab.tabInfo;\r\n }\r\n tab.tabInfo = {\r\n name: tab.url,\r\n initialName: null,\r\n };\r\n return tab.tabInfo;\r\n }));\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { RouterModule } from '@angular/router';\r\nimport { CommonModule } from '@angular/common';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\n\r\nimport { SdTabRouterItemComponent } from './components/tab-router-item/tab-router-item.component';\r\nimport { SdTabRouterNavComponent } from './components/tab-router-nav/tab-router-nav.component';\r\nimport { SdTabRouterOutletComponent } from './components/tab-router-outlet/tab-router-outlet.component';\r\nimport { SdTabInfoPipe } from './pipes/tab-info.pipe';\r\n\r\n@NgModule({\r\n declarations: [\r\n SdTabRouterItemComponent,\r\n SdTabRouterNavComponent,\r\n SdTabRouterOutletComponent,\r\n SdTabInfoPipe,\r\n ],\r\n imports: [RouterModule, CommonModule, MatIconModule, MatTooltipModule],\r\n exports: [\r\n SdTabRouterItemComponent,\r\n SdTabRouterNavComponent,\r\n SdTabRouterOutletComponent,\r\n ],\r\n providers: [],\r\n})\r\nexport class SdTabRouterModule {}\r\n","import { Type } from '@angular/core';\r\nimport { filter, take, takeWhile } from 'rxjs/operators';\r\nimport { SdTabDecoratorService } from '../services/tab-decorator.service';\r\n\r\nexport declare interface SdTabComponentBuilder {\r\n component: Type<any>;\r\n name: string | ((args: { url: string, params: any, queryParams: any }) => string);\r\n initialName: string | ((args: { url: string, params: any, queryParams: any }) => string);\r\n tooltip?: string | ((args: { url: string, params: any, queryParams: any }) => string);\r\n color?: string | ((args: { url: string, params: any, queryParams: any }) => string);\r\n isDetail?: boolean;\r\n}\r\n\r\nexport function SdTabComponent<T>(builder: SdTabComponentBuilder) {\r\n return (constructor: T) => {\r\n SdTabDecoratorService.tabRouterService.pipe(\r\n filter(service => service !== undefined && service !== null),\r\n take(1)).subscribe(service => {\r\n service.addBuilder(builder);\r\n });\r\n };\r\n}\r\n"]}
|
|
1
|
+
{"version":3,"sources":["../../../../node_modules/tslib/tslib.es6.js","../../../../projects/sd-core/tab-router/src/lib/events/tab-router.event.ts","../../../../projects/sd-core/tab-router/src/lib/services/tab-router.service.ts","../../../../projects/sd-core/tab-router/src/lib/services/tab-decorator.service.ts","../../../../projects/sd-core/tab-router/src/lib/components/tab-router-item/tab-router-item.component.ts","../../../../projects/sd-core/tab-router/src/lib/components/tab-router-nav/tab-router-nav.component.ts","../../../../projects/sd-core/tab-router/src/lib/components/tab-router-outlet/tab-router-outlet.component.ts","../../../../projects/sd-core/tab-router/src/lib/pipes/tab-info.pipe.ts","../../../../projects/sd-core/tab-router/src/lib/tab-router.module.ts","../../../../projects/sd-core/tab-router/src/lib/decorators/tab.decorator.ts"],"names":["extendStatics","d","b","Object","setPrototypeOf","__proto__","Array","p","prototype","hasOwnProperty","call","__extends","__","this","constructor","create","__awaiter","thisArg","_arguments","P","generator","Promise","resolve","reject","fulfilled","value","step","next","e","rejected","result","done","then","apply","__generator","body","f","y","t","g","_","label","sent","trys","ops","verb","throw","return","Symbol","iterator","n","v","op","TypeError","pop","length","push","__read","o","m","r","i","ar","error","__classPrivateFieldGet","receiver","privateMap","has","get","__classPrivateFieldSet","set","SdTabBase","tab","_tab","defineProperty","SdTabActivated","_super","SdTabDeactivated","SdTabRouterService","notifyService","_this","events","BehaviorSubject","actions","builders","_currentTab","_componentBuilders","addBuilder","builder","some","component","setCurrentTab","pushEvent","Event","setOptions","close","type","_a","key","Injectable","args","providedIn","SdNotifyService","SdTabDecoratorService","tabRouterService","undefined","event","preventDefault","stopPropagation","Component","selector","template","Input","SdTabRouterNavComponent","mode","checkUI","nameWidth","tabRouterNav","nativeElement","clientWidth","tabs","onResize","ViewChild","HostListener","SdTabRouterOutletComponent","router","activatedRoute","cd","injector","compiler","tabDecoratorService","sdNotifyService","_rootRoute","_subscription","Subscription","_firstLoad","_closeTab","isActive","activeKey","activeIndex","findIndex","_k","nextTab","nextUrl","url","nextQueryParams","assign","queryParams","filter","navigate","state","switchTab","navigateByUrl","markForCheck","_activeRoute","fullUrl","route","params","split","hash","existedIndex","activatedIndex","forEach","index","currentNavigation","getCurrentNavigation","_b","extras","existedTab","_d","_c","parent","routeConfig","loadChildren","module","_l","compileModuleAsync","factory","injector_1","activatedRoute_1","_getActivatedRoute","SdOutletInjector","name","_f","_e","replaceTab","splice","_h","_g","_j","notify","warning","_getActivatedRouteSnapshot","activatedRouteSnapshot","firstChild","add","pipe","RoutesRecognized","NavigationEnd","subscribe","snapshot","routerState","root","urlAfterRedirects","ngOnDestroy","unsubscribe","Router","ActivatedRoute","ChangeDetectorRef","Injector","Compiler","token","notFoundValue","SdTabInfoPipe","transform","map","find","tabInfo","initialName","tooltip","color","Pipe","NgModule","declarations","SdTabRouterItemComponent","imports","RouterModule","CommonModule","MatIconModule","MatTooltipModule","exports","providers","service","take"],"mappings":"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","sourcesContent":["/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n};\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, privateMap) {\r\n if (!privateMap.has(receiver)) {\r\n throw new TypeError(\"attempted to get private field on non-instance\");\r\n }\r\n return privateMap.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, privateMap, value) {\r\n if (!privateMap.has(receiver)) {\r\n throw new TypeError(\"attempted to set private field on non-instance\");\r\n }\r\n privateMap.set(receiver, value);\r\n return value;\r\n}\r\n","import { SdTab } from '../models/tab-router.model';\r\n\r\nexport class SdTabBase {\r\n #tab: SdTab | null;\r\n\r\n constructor(tab: SdTab | null) {\r\n this.#tab = tab;\r\n }\r\n\r\n get tab(): SdTab | null {\r\n return this.#tab;\r\n }\r\n}\r\n\r\nexport class SdTabActivated extends SdTabBase {}\r\n\r\nexport class SdTabDeactivated extends SdTabBase {}\r\n\r\nexport declare type SdTabEvent = SdTabActivated | SdTabDeactivated;\r\n","import { Injectable, Type } from '@angular/core';\r\nimport { BehaviorSubject } from 'rxjs';\r\nimport { SdTab } from '../models/tab-router.model';\r\nimport { SdTabAction } from '../actions/tab-router.action';\r\nimport { SdTabEvent, SdTabBase } from '../events/tab-router.event';\r\nimport { SdNotifyService } from '@sd-angular/core/notify';\r\nimport { SdTabComponentBuilder } from '../decorators/tab.decorator';\r\n\r\n@Injectable({\r\n providedIn: 'root',\r\n})\r\nexport class SdTabRouterService {\r\n events = new BehaviorSubject<SdTabEvent>(new SdTabBase(null));\r\n actions = new BehaviorSubject<SdTabAction | null>(null);\r\n builders = new BehaviorSubject<SdTabComponentBuilder[]>([]);\r\n\r\n #currentTab: SdTab | null = null;\r\n #componentBuilders: SdTabComponentBuilder[] = [];\r\n constructor(private notifyService: SdNotifyService) {\r\n }\r\n\r\n addBuilder = (builder: SdTabComponentBuilder) => {\r\n if (!this.#componentBuilders.some(e => e.component === builder.component)) {\r\n this.#componentBuilders.push(builder);\r\n this.builders.next(this.#componentBuilders);\r\n }\r\n }\r\n\r\n get currentTab() {\r\n return this.#currentTab;\r\n }\r\n\r\n get key() {\r\n return this.#currentTab?.key || null;\r\n }\r\n\r\n // select = (tabOrKey: string | SdTab): void => {\r\n // const tab = this.#tabs.find(e => {\r\n // if (typeof (tabOrKey) === 'string') {\r\n // return e.key === tabOrKey;\r\n // }\r\n // return e.key === tabOrKey?.key;\r\n // });\r\n // if (tab) {\r\n // this.#currentTab = tab;\r\n // }\r\n // }\r\n\r\n // add = (tab: SdTab): void => {\r\n // if (!tab.key) {\r\n // this.notifyService.notify.warning('Tab key is required');\r\n // }\r\n // if (!tab.component) {\r\n // this.notifyService.notify.warning('Tab component is required');\r\n // }\r\n // const existedTab = this.#tabs.find(e => e.key === tab.key);\r\n // if (!existedTab) {\r\n // this.#tabs.push(tab);\r\n // this.select(tab);\r\n // } else {\r\n // this.select(existedTab);\r\n // }\r\n // }\r\n\r\n // remove = (tabOrKey: string | SdTab): void => {\r\n // this.#tabs = this.#tabs.filter(e => {\r\n // if (typeof (tabOrKey) === 'string') {\r\n // return e.key !== tabOrKey;\r\n // }\r\n // return e.key !== tabOrKey?.key;\r\n // });\r\n // }\r\n\r\n setCurrentTab = (tab: SdTab): void => {\r\n this.#currentTab = tab;\r\n }\r\n\r\n pushEvent = (tab: SdTab, Event: Type<SdTabEvent>) => {\r\n this.events.next(new Event(tab));\r\n }\r\n\r\n setOptions = () => { };\r\n\r\n close = (tab?: SdTab) => {\r\n if (tab) {\r\n this.actions.next({\r\n type: 'close',\r\n tab,\r\n });\r\n } else if (this.#currentTab) {\r\n this.actions.next({\r\n type: 'close',\r\n tab: this.#currentTab,\r\n });\r\n }\r\n }\r\n}\r\n","import { Injectable } from '@angular/core';\r\nimport { BehaviorSubject } from 'rxjs';\r\nimport { SdTabRouterService } from './tab-router.service';\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class SdTabDecoratorService {\r\n static tabRouterService = new BehaviorSubject<SdTabRouterService>(undefined);\r\n constructor(tabRouterService: SdTabRouterService) {\r\n SdTabDecoratorService.tabRouterService.next(tabRouterService);\r\n }\r\n}\r\n","import { Component, Input } from '@angular/core';\r\n\r\nimport { SdTab } from '../../models/tab-router.model';\r\nimport { SdTabRouterService } from '../../services/tab-router.service';\r\n\r\n@Component({\r\n selector: 'sd-tab-router-item',\r\n templateUrl: './tab-router-item.component.html',\r\n styleUrls: ['./tab-router-item.component.scss'],\r\n})\r\nexport class SdTabRouterItemComponent {\r\n @Input() tab: SdTab;\r\n\r\n constructor(private tabRouterService: SdTabRouterService) {}\r\n\r\n close = (event: Event) => {\r\n event.preventDefault();\r\n event.stopPropagation();\r\n this.tabRouterService.close(this.tab);\r\n }\r\n}\r\n","import {\r\n Component,\r\n ElementRef,\r\n HostListener,\r\n Input,\r\n ViewChild,\r\n} from '@angular/core';\r\n\r\nimport { SdTab } from '../../models/tab-router.model';\r\n\r\n@Component({\r\n selector: 'sd-tab-router-nav',\r\n templateUrl: './tab-router-nav.component.html',\r\n styleUrls: ['./tab-router-nav.component.scss'],\r\n})\r\nexport class SdTabRouterNavComponent {\r\n @ViewChild('tabRouterNav') tabRouterNav: ElementRef;\r\n\r\n @Input() tabs: SdTab[];\r\n mode: 'default' | 'compact' = 'default';\r\n\r\n constructor() {}\r\n\r\n @HostListener('window:resize', ['$event'])\r\n onResize(event): void {\r\n this.checkUI();\r\n }\r\n\r\n checkUI = () => {\r\n const width = this.tabRouterNav.nativeElement.clientWidth;\r\n const nameWidth = (width - this.tabs.length * 64) / this.tabs.length;\r\n if (nameWidth <= 20) {\r\n this.mode = 'compact';\r\n } else {\r\n this.mode = 'default';\r\n }\r\n }\r\n}\r\n","import {\r\n ChangeDetectionStrategy,\r\n ChangeDetectorRef,\r\n Compiler,\r\n Component,\r\n Injector,\r\n NgModuleRef,\r\n OnDestroy,\r\n OnInit,\r\n Type,\r\n ViewChild,\r\n} from '@angular/core';\r\nimport {\r\n ActivatedRoute,\r\n ActivatedRouteSnapshot,\r\n ChildrenOutletContexts,\r\n // ChildrenOutletContexts,\r\n Event,\r\n NavigationEnd,\r\n PRIMARY_OUTLET,\r\n Router,\r\n RoutesRecognized,\r\n} from '@angular/router';\r\nimport { SdNotifyService } from '@sd-angular/core/notify';\r\nimport {\r\n SdTabActivated,\r\n SdTabDeactivated,\r\n} from '../../events/tab-router.event';\r\n\r\nimport { SdTab } from '../../models/tab-router.model';\r\nimport { SdTabAction } from '../../actions/tab-router.action';\r\nimport { SdTabRouterService } from '../../services/tab-router.service';\r\nimport { SdTabRouterNavComponent } from '../tab-router-nav/tab-router-nav.component';\r\nimport { Subscription } from 'rxjs';\r\nimport { SdTabDecoratorService } from '../../services/tab-decorator.service';\r\nimport { filter } from 'rxjs/operators';\r\nimport * as hash from 'object-hash';\r\n\r\n@Component({\r\n selector: 'sd-tab-router-outlet',\r\n templateUrl: './tab-router-outlet.component.html',\r\n styleUrls: ['./tab-router-outlet.component.scss'],\r\n // changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class SdTabRouterOutletComponent implements OnDestroy {\r\n @ViewChild('tabRouterNav') tabRouterNav: SdTabRouterNavComponent;\r\n tabs: SdTab[] = [];\r\n\r\n #rootRoute: ActivatedRoute;\r\n #subscription = new Subscription();\r\n #firstLoad = true;\r\n constructor(\r\n private router: Router,\r\n private activatedRoute: ActivatedRoute,\r\n private cd: ChangeDetectorRef,\r\n private injector: Injector,\r\n private compiler: Compiler,\r\n private tabDecoratorService: SdTabDecoratorService,\r\n private tabRouterService: SdTabRouterService,\r\n private sdNotifyService: SdNotifyService\r\n ) {\r\n this.#subscription.add(\r\n router.events\r\n .pipe(\r\n filter(\r\n (event) =>\r\n event instanceof RoutesRecognized ||\r\n event instanceof NavigationEnd\r\n )\r\n )\r\n .subscribe(async (event: RoutesRecognized | NavigationEnd) => {\r\n if (this.#firstLoad && event instanceof NavigationEnd) {\r\n this.#firstLoad = false;\r\n const route = this.#getActivatedRouteSnapshot(\r\n this.activatedRoute.snapshot\r\n );\r\n this.#rootRoute = this.router.routerState.root;\r\n await this.#activeRoute(\r\n event.urlAfterRedirects || event.url,\r\n route\r\n );\r\n return;\r\n }\r\n if (!this.#firstLoad && event instanceof RoutesRecognized) {\r\n const route = this.#getActivatedRouteSnapshot(event.state.root);\r\n this.#rootRoute = this.router.routerState.root;\r\n await this.#activeRoute(\r\n event.urlAfterRedirects || event.url,\r\n route\r\n );\r\n }\r\n })\r\n );\r\n\r\n this.#subscription.add(\r\n tabRouterService.actions.subscribe((event: SdTabAction | null) => {\r\n if (event && event.type === 'close') {\r\n this.#closeTab(event.tab);\r\n }\r\n })\r\n );\r\n }\r\n\r\n ngOnDestroy(): void {\r\n this.#subscription.unsubscribe();\r\n }\r\n\r\n #closeTab = (tab: SdTab) => {\r\n const { isActive, key: activeKey } = tab;\r\n\r\n if (isActive) {\r\n const activeIndex = this.tabs.findIndex(({ key }) => key === activeKey);\r\n const nextTab = this.tabs[activeIndex + 1] || this.tabs[activeIndex - 1];\r\n if (nextTab) {\r\n const { url: nextUrl } = nextTab;\r\n const nextQueryParams = {\r\n ...(nextTab.queryParams || {}),\r\n };\r\n\r\n this.tabs = this.tabs.filter(({ key }) => key !== activeKey);\r\n this.router.navigate([nextUrl], {\r\n queryParams: nextQueryParams,\r\n state: {\r\n switchTab: true,\r\n },\r\n });\r\n } else {\r\n this.tabs = this.tabs.filter(({ key }) => key !== activeKey);\r\n this.router.navigateByUrl('/', {\r\n state: {\r\n switchTab: true,\r\n },\r\n });\r\n }\r\n } else {\r\n this.tabs = this.tabs.filter(({ key }) => key !== tab.key);\r\n this.tabRouterNav?.checkUI();\r\n this.cd.markForCheck();\r\n }\r\n };\r\n\r\n #activeRoute = async (\r\n fullUrl: string,\r\n route: ActivatedRouteSnapshot | null\r\n ) => {\r\n if (!route?.component) {\r\n return;\r\n }\r\n const component = route.component as Type<any>;\r\n const queryParams = {\r\n ...(route.queryParams || {}),\r\n };\r\n const params = {\r\n ...(route.params || {}),\r\n };\r\n\r\n const [url] = fullUrl.split('?');\r\n const key = hash({ url, queryParams });\r\n\r\n let existedIndex = -1;\r\n let activatedIndex = -1;\r\n this.tabs.forEach((tab: SdTab, index: number) => {\r\n if (tab.key === key) {\r\n tab.isActive = true;\r\n existedIndex = index;\r\n } else {\r\n if (tab.isActive) {\r\n activatedIndex = index;\r\n this.tabRouterService.pushEvent(tab, SdTabDeactivated);\r\n }\r\n tab.isActive = false;\r\n }\r\n });\r\n\r\n const currentNavigation = this.router.getCurrentNavigation();\r\n if (existedIndex >= 0 && currentNavigation?.extras?.state?.switchTab) {\r\n const existedTab = this.tabs[existedIndex];\r\n this.tabRouterService.setCurrentTab(existedTab);\r\n this.tabRouterService.pushEvent(existedTab, SdTabActivated);\r\n } else {\r\n if (typeof route?.parent?.routeConfig?.loadChildren === 'function') {\r\n const module = await route.parent.routeConfig.loadChildren();\r\n const factory = await this.compiler.compileModuleAsync(module);\r\n const injector = factory.create(this.injector);\r\n const activatedRoute = this.#getActivatedRoute(\r\n this.#rootRoute,\r\n component\r\n );\r\n\r\n const tab = {\r\n key,\r\n component,\r\n injector: new SdOutletInjector(activatedRoute, injector),\r\n isActive: true,\r\n name: url,\r\n url,\r\n params,\r\n queryParams,\r\n };\r\n\r\n this.tabRouterService.setCurrentTab(tab);\r\n if (\r\n activatedIndex >= 0 &&\r\n currentNavigation?.extras?.state?.replaceTab\r\n ) {\r\n this.tabs.splice(activatedIndex, 1);\r\n }\r\n if (existedIndex >= 0 && !currentNavigation?.extras?.state?.switchTab) {\r\n this.tabs[existedIndex] = tab;\r\n } else {\r\n this.tabs.push(tab);\r\n }\r\n }\r\n\r\n this.tabRouterNav?.checkUI();\r\n if (this.tabs.length > 10) {\r\n this.sdNotifyService.notify.warning(\r\n 'Bạn đã mở quá nhiều tab. Vui lòng tắt các tab không dùng để hệ thống hoạt động tốt hơn.'\r\n );\r\n }\r\n if (this.tabs.length > 12) {\r\n this.tabs.splice(0, this.tabs.length - 10);\r\n }\r\n }\r\n this.cd.markForCheck();\r\n };\r\n\r\n #getActivatedRouteSnapshot = (\r\n activatedRouteSnapshot: ActivatedRouteSnapshot\r\n ): ActivatedRouteSnapshot | null => {\r\n if (!activatedRouteSnapshot) {\r\n return null;\r\n }\r\n while (activatedRouteSnapshot.firstChild) {\r\n activatedRouteSnapshot = activatedRouteSnapshot.firstChild;\r\n }\r\n return activatedRouteSnapshot;\r\n };\r\n\r\n #getActivatedRoute = (\r\n activatedRoute: ActivatedRoute,\r\n component: any\r\n ): ActivatedRoute | null => {\r\n if (!activatedRoute) {\r\n return null;\r\n }\r\n\r\n if (activatedRoute.component && activatedRoute.component === component) {\r\n return activatedRoute;\r\n }\r\n while (activatedRoute.firstChild) {\r\n activatedRoute = activatedRoute.firstChild;\r\n if (activatedRoute.component && activatedRoute.component === component) {\r\n return activatedRoute;\r\n }\r\n }\r\n return null;\r\n };\r\n}\r\n\r\nclass SdOutletInjector implements Injector {\r\n constructor(\r\n private route: ActivatedRoute | null,\r\n // private childContexts: ChildrenOutletContexts,\r\n private parent: any\r\n ) {}\r\n\r\n get(token: any, notFoundValue?: any): any {\r\n if (token === ActivatedRoute && this.route) {\r\n return this.route;\r\n }\r\n\r\n // if (token === ChildrenOutletContexts) {\r\n // return this.childContexts;\r\n // }\r\n\r\n return this.parent.get(token, notFoundValue);\r\n }\r\n}\r\n","import { Pipe, PipeTransform } from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\nimport { map } from 'rxjs/operators';\r\nimport { SdTab, SdTabInfo } from '../models/tab-router.model';\r\nimport { SdTabRouterService } from '../services/tab-router.service';\r\n@Pipe({\r\n name: 'sdTabInfo'\r\n})\r\nexport class SdTabInfoPipe implements PipeTransform {\r\n constructor(private tabRouterService: SdTabRouterService) { }\r\n transform(tab: SdTab): Observable<SdTabInfo> {\r\n return this.tabRouterService.builders.pipe(map(builders => {\r\n const builder = builders.find(e => e.component === tab.component);\r\n if (builder) {\r\n const { url, params, queryParams } = tab;\r\n tab.tabInfo = {\r\n name: typeof (builder.name) === 'function' ?\r\n builder.name({ url, params, queryParams }) : builder.name,\r\n initialName: typeof (builder.initialName) === 'function' ?\r\n builder.initialName({ url, params, queryParams }) : builder.initialName,\r\n tooltip: typeof (builder.tooltip) === 'function' ?\r\n builder.tooltip({ url, params, queryParams }) : builder.tooltip,\r\n color: typeof (builder.color) === 'function' ?\r\n builder.color({ url, params, queryParams }) : builder.color\r\n };\r\n return tab.tabInfo;\r\n }\r\n tab.tabInfo = {\r\n name: tab.url,\r\n initialName: null,\r\n };\r\n return tab.tabInfo;\r\n }));\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { RouterModule } from '@angular/router';\r\nimport { CommonModule } from '@angular/common';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\n\r\nimport { SdTabRouterItemComponent } from './components/tab-router-item/tab-router-item.component';\r\nimport { SdTabRouterNavComponent } from './components/tab-router-nav/tab-router-nav.component';\r\nimport { SdTabRouterOutletComponent } from './components/tab-router-outlet/tab-router-outlet.component';\r\nimport { SdTabInfoPipe } from './pipes/tab-info.pipe';\r\n\r\n@NgModule({\r\n declarations: [\r\n SdTabRouterItemComponent,\r\n SdTabRouterNavComponent,\r\n SdTabRouterOutletComponent,\r\n SdTabInfoPipe,\r\n ],\r\n imports: [RouterModule, CommonModule, MatIconModule, MatTooltipModule],\r\n exports: [\r\n SdTabRouterItemComponent,\r\n SdTabRouterNavComponent,\r\n SdTabRouterOutletComponent,\r\n ],\r\n providers: [],\r\n})\r\nexport class SdTabRouterModule {}\r\n","import { Type } from '@angular/core';\r\nimport { filter, take, takeWhile } from 'rxjs/operators';\r\nimport { SdTabDecoratorService } from '../services/tab-decorator.service';\r\n\r\nexport declare interface SdTabComponentBuilder {\r\n component: Type<any>;\r\n name: string | ((args: { url: string, params: any, queryParams: any }) => string);\r\n initialName: string | ((args: { url: string, params: any, queryParams: any }) => string);\r\n tooltip?: string | ((args: { url: string, params: any, queryParams: any }) => string);\r\n color?: string | ((args: { url: string, params: any, queryParams: any }) => string);\r\n isDetail?: boolean;\r\n}\r\n\r\nexport function SdTabComponent<T>(builder: SdTabComponentBuilder) {\r\n return (constructor: T) => {\r\n SdTabDecoratorService.tabRouterService.pipe(\r\n filter(service => service !== undefined && service !== null),\r\n take(1)).subscribe(service => {\r\n service.addBuilder(builder);\r\n });\r\n };\r\n}\r\n"]}
|
|
@@ -1,30 +1,30 @@
|
|
|
1
|
-
import { Injectable } from
|
|
2
|
-
import $ from
|
|
1
|
+
import { Injectable } from "@angular/core";
|
|
2
|
+
import $ from "jquery";
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export class SdLoadingService {
|
|
5
5
|
constructor() {
|
|
6
|
-
this.loadingId =
|
|
7
|
-
this.start = (element =
|
|
6
|
+
this.loadingId = "L8d556b9b-f6dd-46e9-9710-757e65d82839";
|
|
7
|
+
this.start = (element = "body") => {
|
|
8
8
|
$(element).append(this.loadingNormal);
|
|
9
9
|
};
|
|
10
10
|
this.isLoading = () => {
|
|
11
11
|
return $(`#${this.loadingId}`).length > 0;
|
|
12
12
|
};
|
|
13
|
-
this.stop = (element =
|
|
13
|
+
this.stop = (element = "body") => {
|
|
14
14
|
$(element).children(`#${this.loadingId}`).remove();
|
|
15
15
|
};
|
|
16
16
|
}
|
|
17
17
|
// Loading
|
|
18
18
|
get loadingNormal() {
|
|
19
19
|
// tslint:disable-next-line: max-line-length
|
|
20
|
-
return `<div id="${this.loadingId}" style="top:0;left:0;height:100vh;width:100vw;position:absolute;opacity:0.6;background:#FFFFFF;z-index: 99999;"><i class="fa fa-5x fa-spinner fa-pulse" style="margin-top:calc(50vh - 2.5rem);margin-left:calc(50vw - 2.5rem)"></i></div>`;
|
|
20
|
+
return `<div class="sd-loading" id="${this.loadingId}" style="top:0;left:0;height:100vh;width:100vw;position:absolute;opacity:0.6;background:#FFFFFF;z-index: 99999;"><i class="fa fa-5x fa-spinner fa-pulse" style="margin-top:calc(50vh - 2.5rem);margin-left:calc(50vw - 2.5rem)"></i></div>`;
|
|
21
21
|
}
|
|
22
22
|
}
|
|
23
23
|
SdLoadingService.ɵprov = i0.ɵɵdefineInjectable({ factory: function SdLoadingService_Factory() { return new SdLoadingService(); }, token: SdLoadingService, providedIn: "root" });
|
|
24
24
|
SdLoadingService.decorators = [
|
|
25
25
|
{ type: Injectable, args: [{
|
|
26
|
-
providedIn:
|
|
26
|
+
providedIn: "root",
|
|
27
27
|
},] }
|
|
28
28
|
];
|
|
29
29
|
SdLoadingService.ctorParameters = () => [];
|
|
30
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZGluZy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IkM6L1VzZXJzL25naGlhdHQxNS9EZXNrdG9wL1dvcmtpbmcvMU1HL2xpYi1jb3JlLXVpL3Byb2plY3RzL3NkLWNvcmUvbG9hZGluZy8iLCJzb3VyY2VzIjpbInNyYy9saWIvbG9hZGluZy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxDQUFDLE1BQU0sUUFBUSxDQUFDOztBQUt2QixNQUFNLE9BQU8sZ0JBQWdCO0lBRzNCO1FBRlEsY0FBUyxHQUFHLHVDQUF1QyxDQUFDO1FBVTVELFVBQUssR0FBRyxDQUFDLFVBQWtCLE1BQU0sRUFBRSxFQUFFO1lBQ25DLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQ3hDLENBQUMsQ0FBQztRQUVGLGNBQVMsR0FBRyxHQUFHLEVBQUU7WUFDZixPQUFPLENBQUMsQ0FBQyxJQUFJLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQyxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUM7UUFDNUMsQ0FBQyxDQUFDO1FBRUYsU0FBSSxHQUFHLENBQUMsVUFBa0IsTUFBTSxFQUFFLEVBQUU7WUFDbEMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLFFBQVEsQ0FBQyxJQUFJLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQyxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ3JELENBQUMsQ0FBQztJQWxCYSxDQUFDO0lBRWhCLFVBQVU7SUFDVixJQUFZLGFBQWE7UUFDdkIsNENBQTRDO1FBQzVDLE9BQU8sK0JBQStCLElBQUksQ0FBQyxTQUFTLDRPQUE0TyxDQUFDO0lBQ25TLENBQUM7Ozs7WUFaRixVQUFVLFNBQUM7Z0JBQ1YsVUFBVSxFQUFFLE1BQU07YUFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0ICQgZnJvbSBcImpxdWVyeVwiO1xyXG5cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46IFwicm9vdFwiLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgU2RMb2FkaW5nU2VydmljZSB7XHJcbiAgcHJpdmF0ZSBsb2FkaW5nSWQgPSBcIkw4ZDU1NmI5Yi1mNmRkLTQ2ZTktOTcxMC03NTdlNjVkODI4MzlcIjtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7fVxyXG5cclxuICAvLyBMb2FkaW5nXHJcbiAgcHJpdmF0ZSBnZXQgbG9hZGluZ05vcm1hbCgpIHtcclxuICAgIC8vIHRzbGludDpkaXNhYmxlLW5leHQtbGluZTogbWF4LWxpbmUtbGVuZ3RoXHJcbiAgICByZXR1cm4gYDxkaXYgY2xhc3M9XCJzZC1sb2FkaW5nXCIgaWQ9XCIke3RoaXMubG9hZGluZ0lkfVwiIHN0eWxlPVwidG9wOjA7bGVmdDowO2hlaWdodDoxMDB2aDt3aWR0aDoxMDB2dztwb3NpdGlvbjphYnNvbHV0ZTtvcGFjaXR5OjAuNjtiYWNrZ3JvdW5kOiNGRkZGRkY7ei1pbmRleDogOTk5OTk7XCI+PGkgY2xhc3M9XCJmYSBmYS01eCBmYS1zcGlubmVyIGZhLXB1bHNlXCIgc3R5bGU9XCJtYXJnaW4tdG9wOmNhbGMoNTB2aCAtIDIuNXJlbSk7bWFyZ2luLWxlZnQ6Y2FsYyg1MHZ3IC0gMi41cmVtKVwiPjwvaT48L2Rpdj5gO1xyXG4gIH1cclxuXHJcbiAgc3RhcnQgPSAoZWxlbWVudDogc3RyaW5nID0gXCJib2R5XCIpID0+IHtcclxuICAgICQoZWxlbWVudCkuYXBwZW5kKHRoaXMubG9hZGluZ05vcm1hbCk7XHJcbiAgfTtcclxuXHJcbiAgaXNMb2FkaW5nID0gKCkgPT4ge1xyXG4gICAgcmV0dXJuICQoYCMke3RoaXMubG9hZGluZ0lkfWApLmxlbmd0aCA+IDA7XHJcbiAgfTtcclxuXHJcbiAgc3RvcCA9IChlbGVtZW50OiBzdHJpbmcgPSBcImJvZHlcIikgPT4ge1xyXG4gICAgJChlbGVtZW50KS5jaGlsZHJlbihgIyR7dGhpcy5sb2FkaW5nSWR9YCkucmVtb3ZlKCk7XHJcbiAgfTtcclxufVxyXG4iXX0=
|
package/esm2015/tab-router/src/lib/components/tab-router-outlet/tab-router-outlet.component.js
CHANGED
|
@@ -179,7 +179,7 @@ SdTabRouterOutletComponent.decorators = [
|
|
|
179
179
|
{ type: Component, args: [{
|
|
180
180
|
selector: 'sd-tab-router-outlet',
|
|
181
181
|
template: "<sd-tab-router-nav [tabs]=\"tabs\" #tabRouterNav></sd-tab-router-nav>\r\n\r\n<div class=\"tab-router__list\">\r\n <ng-container *ngFor=\"let tab of tabs\">\r\n <div class=\"tab-router__pane\" [class.active]=\"tab.isActive\" [id]=\"tab.key\">\r\n <div class=\"tab-router__content\">\r\n <ng-container\r\n *ngComponentOutlet=\"tab.component; injector: tab.injector\"\r\n ></ng-container>\r\n </div>\r\n </div>\r\n </ng-container>\r\n</div>\r\n",
|
|
182
|
-
styles: [":host{display:flex;flex-direction:column;height:calc(100vh - 64px);width:100%}::ng-deep page-layout{height:100%!important}.tab-router__list{flex:1}.tab-router__pane{display:none;height:100%;position:relative;width:100%}.tab-router__pane.active{display:block}.tab-router__content{bottom:0;height:100%;left:0;overflow:auto;position:absolute;right:0;top:0;width:100%}"]
|
|
182
|
+
styles: [":host{display:flex;flex-direction:column;height:calc(100vh - 64px);width:100%}:host ::ng-deep .sd-loading{max-height:100%;max-width:100%}::ng-deep page-layout{height:100%!important}.tab-router__list{flex:1}.tab-router__pane{display:none;height:100%;position:relative;width:100%}.tab-router__pane.active{display:block}.tab-router__content{bottom:0;height:100%;left:0;overflow:auto;position:absolute;right:0;top:0;width:100%}"]
|
|
183
183
|
},] }
|
|
184
184
|
];
|
|
185
185
|
SdTabRouterOutletComponent.ctorParameters = () => [
|
|
@@ -3,27 +3,27 @@ import $ from 'jquery';
|
|
|
3
3
|
|
|
4
4
|
class SdLoadingService {
|
|
5
5
|
constructor() {
|
|
6
|
-
this.loadingId =
|
|
7
|
-
this.start = (element =
|
|
6
|
+
this.loadingId = "L8d556b9b-f6dd-46e9-9710-757e65d82839";
|
|
7
|
+
this.start = (element = "body") => {
|
|
8
8
|
$(element).append(this.loadingNormal);
|
|
9
9
|
};
|
|
10
10
|
this.isLoading = () => {
|
|
11
11
|
return $(`#${this.loadingId}`).length > 0;
|
|
12
12
|
};
|
|
13
|
-
this.stop = (element =
|
|
13
|
+
this.stop = (element = "body") => {
|
|
14
14
|
$(element).children(`#${this.loadingId}`).remove();
|
|
15
15
|
};
|
|
16
16
|
}
|
|
17
17
|
// Loading
|
|
18
18
|
get loadingNormal() {
|
|
19
19
|
// tslint:disable-next-line: max-line-length
|
|
20
|
-
return `<div id="${this.loadingId}" style="top:0;left:0;height:100vh;width:100vw;position:absolute;opacity:0.6;background:#FFFFFF;z-index: 99999;"><i class="fa fa-5x fa-spinner fa-pulse" style="margin-top:calc(50vh - 2.5rem);margin-left:calc(50vw - 2.5rem)"></i></div>`;
|
|
20
|
+
return `<div class="sd-loading" id="${this.loadingId}" style="top:0;left:0;height:100vh;width:100vw;position:absolute;opacity:0.6;background:#FFFFFF;z-index: 99999;"><i class="fa fa-5x fa-spinner fa-pulse" style="margin-top:calc(50vh - 2.5rem);margin-left:calc(50vw - 2.5rem)"></i></div>`;
|
|
21
21
|
}
|
|
22
22
|
}
|
|
23
23
|
SdLoadingService.ɵprov = ɵɵdefineInjectable({ factory: function SdLoadingService_Factory() { return new SdLoadingService(); }, token: SdLoadingService, providedIn: "root" });
|
|
24
24
|
SdLoadingService.decorators = [
|
|
25
25
|
{ type: Injectable, args: [{
|
|
26
|
-
providedIn:
|
|
26
|
+
providedIn: "root",
|
|
27
27
|
},] }
|
|
28
28
|
];
|
|
29
29
|
SdLoadingService.ctorParameters = () => [];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sd-angular-core-loading.js","sources":["../../../../projects/sd-core/loading/src/lib/loading.service.ts","../../../../projects/sd-core/loading/src/public-api.ts","../../../../projects/sd-core/loading/sd-angular-core-loading.ts"],"sourcesContent":["import { Injectable } from
|
|
1
|
+
{"version":3,"file":"sd-angular-core-loading.js","sources":["../../../../projects/sd-core/loading/src/lib/loading.service.ts","../../../../projects/sd-core/loading/src/public-api.ts","../../../../projects/sd-core/loading/sd-angular-core-loading.ts"],"sourcesContent":["import { Injectable } from \"@angular/core\";\r\nimport $ from \"jquery\";\r\n\r\n@Injectable({\r\n providedIn: \"root\",\r\n})\r\nexport class SdLoadingService {\r\n private loadingId = \"L8d556b9b-f6dd-46e9-9710-757e65d82839\";\r\n\r\n constructor() {}\r\n\r\n // Loading\r\n private get loadingNormal() {\r\n // tslint:disable-next-line: max-line-length\r\n return `<div class=\"sd-loading\" id=\"${this.loadingId}\" style=\"top:0;left:0;height:100vh;width:100vw;position:absolute;opacity:0.6;background:#FFFFFF;z-index: 99999;\"><i class=\"fa fa-5x fa-spinner fa-pulse\" style=\"margin-top:calc(50vh - 2.5rem);margin-left:calc(50vw - 2.5rem)\"></i></div>`;\r\n }\r\n\r\n start = (element: string = \"body\") => {\r\n $(element).append(this.loadingNormal);\r\n };\r\n\r\n isLoading = () => {\r\n return $(`#${this.loadingId}`).length > 0;\r\n };\r\n\r\n stop = (element: string = \"body\") => {\r\n $(element).children(`#${this.loadingId}`).remove();\r\n };\r\n}\r\n","/*\r\n * Public API Surface of superdev-angular-core\r\n */\r\n\r\nexport * from './lib/loading.service';\r\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;MAMa,gBAAgB;IAG3B;QAFQ,cAAS,GAAG,uCAAuC,CAAC;QAU5D,UAAK,GAAG,CAAC,UAAkB,MAAM;YAC/B,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;SACvC,CAAC;QAEF,cAAS,GAAG;YACV,OAAO,CAAC,CAAC,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;SAC3C,CAAC;QAEF,SAAI,GAAG,CAAC,UAAkB,MAAM;YAC9B,CAAC,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC;SACpD,CAAC;KAlBc;;IAGhB,IAAY,aAAa;;QAEvB,OAAO,+BAA+B,IAAI,CAAC,SAAS,4OAA4O,CAAC;KAClS;;;;YAZF,UAAU,SAAC;gBACV,UAAU,EAAE,MAAM;aACnB;;;;ACLD;;;;ACAA;;;;;;"}
|
|
@@ -366,7 +366,7 @@ SdTabRouterOutletComponent.decorators = [
|
|
|
366
366
|
{ type: Component, args: [{
|
|
367
367
|
selector: 'sd-tab-router-outlet',
|
|
368
368
|
template: "<sd-tab-router-nav [tabs]=\"tabs\" #tabRouterNav></sd-tab-router-nav>\r\n\r\n<div class=\"tab-router__list\">\r\n <ng-container *ngFor=\"let tab of tabs\">\r\n <div class=\"tab-router__pane\" [class.active]=\"tab.isActive\" [id]=\"tab.key\">\r\n <div class=\"tab-router__content\">\r\n <ng-container\r\n *ngComponentOutlet=\"tab.component; injector: tab.injector\"\r\n ></ng-container>\r\n </div>\r\n </div>\r\n </ng-container>\r\n</div>\r\n",
|
|
369
|
-
styles: [":host{display:flex;flex-direction:column;height:calc(100vh - 64px);width:100%}::ng-deep page-layout{height:100%!important}.tab-router__list{flex:1}.tab-router__pane{display:none;height:100%;position:relative;width:100%}.tab-router__pane.active{display:block}.tab-router__content{bottom:0;height:100%;left:0;overflow:auto;position:absolute;right:0;top:0;width:100%}"]
|
|
369
|
+
styles: [":host{display:flex;flex-direction:column;height:calc(100vh - 64px);width:100%}:host ::ng-deep .sd-loading{max-height:100%;max-width:100%}::ng-deep page-layout{height:100%!important}.tab-router__list{flex:1}.tab-router__pane{display:none;height:100%;position:relative;width:100%}.tab-router__pane.active{display:block}.tab-router__content{bottom:0;height:100%;left:0;overflow:auto;position:absolute;right:0;top:0;width:100%}"]
|
|
370
370
|
},] }
|
|
371
371
|
];
|
|
372
372
|
SdTabRouterOutletComponent.ctorParameters = () => [
|
package/package.json
CHANGED
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"__symbolic":"module","version":4,"metadata":{"SdTabInfo":{"__symbolic":"interface"},"SdTab":{"__symbolic":"interface"},"SdTabBase":{"__symbolic":"class","members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"SdTab"}]}]}},"SdTabActivated":{"__symbolic":"class","extends":{"__symbolic":"reference","name":"SdTabBase"},"members":{}},"SdTabDeactivated":{"__symbolic":"class","extends":{"__symbolic":"reference","name":"SdTabBase"},"members":{}},"SdTabEvent":{"__symbolic":"interface"},"SdTabAction":{"__symbolic":"interface"},"SdTabComponentBuilder":{"__symbolic":"interface"},"SdTabComponent":{"__symbolic":"function","parameters":["builder"],"value":{"__symbolic":"error","message":"Lambda not supported","line":14,"character":9,"module":"./src/lib/decorators/tab.decorator"}},"SdTabRouterService":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":8,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@sd-angular/core/notify","name":"SdNotifyService","line":18,"character":37}]}]},"statics":{"ɵprov":{}}},"SdTabDecoratorService":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":3,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"SdTabRouterService"}]}]},"statics":{"tabRouterService":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"rxjs","name":"BehaviorSubject","line":7,"character":32},"arguments":[{"__symbolic":"reference","name":"undefined"}]},"ɵprov":{}}},"SdTabRouterItemComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":5,"character":1},"arguments":[{"selector":"sd-tab-router-item","template":"<a [routerLink]=\"[tab.url]\" [queryParams]=\"tab.queryParams\" [state]=\"{ switchTab: true }\"\r\n class=\"tab-router__item d-flex align-items-center\" [ngClass]=\"{\r\n 'tab-router__item--active': tab.isActive\r\n }\">\r\n <ng-container *ngIf=\"tab | sdTabInfo | async as tabInfo\">\r\n <div class=\"\r\n tab-router__icon\r\n d-flex\r\n align-items-center\r\n justify-content-center\r\n mr-8\r\n \" [ngStyle]=\"{\r\n 'background-color': tabInfo.color\r\n }\" [matTooltip]=\"tabInfo.tooltip || tabInfo.name\" matTooltipPosition=\"below\" matTooltipShowDelay=\"1000\">\r\n {{ tabInfo.initialName || 'SD' }}\r\n </div>\r\n <div class=\"flex-1\">\r\n <div class=\"tab-router__name\">{{ tabInfo.name }}</div>\r\n </div>\r\n <button type=\"button\" class=\"\r\n tab-router__close\r\n d-flex\r\n align-items-center\r\n justify-content-center\r\n ml-4\r\n \" (click)=\"close($event)\">\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n </ng-container>\r\n\r\n</a>","styles":[":host{flex:1 1 auto;max-width:240px;position:relative}:host:after{background:#dde0e5;bottom:0;content:\"\";height:16px;margin:auto;position:absolute;right:0;top:0;width:1px}:host:last-child:after{content:none}.flex-1{flex:1}.tab-router__icon{background-color:#5c6bc0;border-radius:2px;color:#fff;font-size:10px;height:16px;line-height:1;text-transform:uppercase;width:16px}.tab-router__icon .mat-icon{font-size:10px;height:10px;width:10px}.tab-router__close{background:none;border:0;border-radius:50%;color:#757575;height:16px;outline:none;width:16px}.tab-router__close:hover{background-color:rgba(0,0,0,.12)}.tab-router__close .mat-icon{font-size:12px;height:12px;width:12px}.tab-router__item{background:#f2f3f4;color:inherit;font-size:12px;line-height:16px;padding:16px 16px 8px;text-decoration:none}.tab-router__item:hover{background-color:#fff}.tab-router__name{-webkit-box-orient:vertical;-webkit-line-clamp:1;display:-webkit-box;overflow:hidden;text-overflow:ellipsis}.tab-router__item--active{background-color:#fff;border-radius:8px 8px 0 0}"]}]}],"members":{"tab":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":11,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"SdTabRouterService"}]}]}},"SdTabRouterNavComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":10,"character":1},"arguments":[{"selector":"sd-tab-router-nav","template":"<div\r\n #tabRouterNav\r\n class=\"tab-router__nav tab-router__nav--{{ mode }} d-flex align-items-center\"\r\n>\r\n <ng-container *ngFor=\"let tab of tabs\">\r\n <sd-tab-router-item [tab]=\"tab\"></sd-tab-router-item>\r\n </ng-container>\r\n</div>\r\n","styles":[".tab-router__nav{background:#f9f9f9}.tab-router__nav--compact::ng-deep .tab-router__name{display:none}.tab-router__nav--compact::ng-deep .tab-router__icon{margin:0!important}.tab-router__nav--compact::ng-deep .tab-router__item--active{min-width:240px}.tab-router__nav--compact::ng-deep .tab-router__item--active .tab-router__icon{margin-right:8px!important}.tab-router__nav--compact::ng-deep .tab-router__item--active .tab-router__name{display:-webkit-box}"]}]}],"members":{"tabRouterNav":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":16,"character":3},"arguments":["tabRouterNav"]}]}],"tabs":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":18,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor"}],"onResize":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":23,"character":3},"arguments":["window:resize",["$event"]]}]}]}},"SdTabRouterOutletComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":38,"character":1},"arguments":[{"selector":"sd-tab-router-outlet","template":"<sd-tab-router-nav [tabs]=\"tabs\" #tabRouterNav></sd-tab-router-nav>\r\n\r\n<div class=\"tab-router__list\">\r\n <ng-container *ngFor=\"let tab of tabs\">\r\n <div class=\"tab-router__pane\" [class.active]=\"tab.isActive\" [id]=\"tab.key\">\r\n <div class=\"tab-router__content\">\r\n <ng-container\r\n *ngComponentOutlet=\"tab.component; injector: tab.injector\"\r\n ></ng-container>\r\n </div>\r\n </div>\r\n </ng-container>\r\n</div>\r\n","styles":[":host{display:flex;flex-direction:column;height:calc(100vh - 64px);width:100%}::ng-deep page-layout{height:100%!important}.tab-router__list{flex:1}.tab-router__pane{display:none;height:100%;position:relative;width:100%}.tab-router__pane.active{display:block}.tab-router__content{bottom:0;height:100%;left:0;overflow:auto;position:absolute;right:0;top:0;width:100%}"]}]}],"members":{"tabRouterNav":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":45,"character":3},"arguments":["tabRouterNav"]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/router","name":"Router","line":52,"character":20},{"__symbolic":"reference","module":"@angular/router","name":"ActivatedRoute","line":53,"character":28},{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":54,"character":16},{"__symbolic":"reference","module":"@angular/core","name":"Injector","line":55,"character":22},{"__symbolic":"reference","module":"@angular/core","name":"Compiler","line":56,"character":22},{"__symbolic":"reference","name":"SdTabDecoratorService"},{"__symbolic":"reference","name":"SdTabRouterService"},{"__symbolic":"reference","module":"@sd-angular/core/notify","name":"SdNotifyService","line":59,"character":29}]}],"ngOnDestroy":[{"__symbolic":"method"}]}},"SdTabRouterModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":11,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"SdTabRouterItemComponent"},{"__symbolic":"reference","name":"SdTabRouterNavComponent"},{"__symbolic":"reference","name":"SdTabRouterOutletComponent"},{"__symbolic":"reference","name":"ɵa"}],"imports":[{"__symbolic":"reference","module":"@angular/router","name":"RouterModule","line":18,"character":12},{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":18,"character":26},{"__symbolic":"reference","module":"@angular/material/icon","name":"MatIconModule","line":18,"character":40},{"__symbolic":"reference","module":"@angular/material/tooltip","name":"MatTooltipModule","line":18,"character":55}],"exports":[{"__symbolic":"reference","name":"SdTabRouterItemComponent"},{"__symbolic":"reference","name":"SdTabRouterNavComponent"},{"__symbolic":"reference","name":"SdTabRouterOutletComponent"}],"providers":[]}]}],"members":{}},"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Pipe","line":5,"character":1},"arguments":[{"name":"sdTabInfo"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"SdTabRouterService"}]}],"transform":[{"__symbolic":"method"}]}}},"origins":{"SdTabInfo":"./src/lib/models/tab-router.model","SdTab":"./src/lib/models/tab-router.model","SdTabBase":"./src/lib/events/tab-router.event","SdTabActivated":"./src/lib/events/tab-router.event","SdTabDeactivated":"./src/lib/events/tab-router.event","SdTabEvent":"./src/lib/events/tab-router.event","SdTabAction":"./src/lib/actions/tab-router.action","SdTabComponentBuilder":"./src/lib/decorators/tab.decorator","SdTabComponent":"./src/lib/decorators/tab.decorator","SdTabRouterService":"./src/lib/services/tab-router.service","SdTabDecoratorService":"./src/lib/services/tab-decorator.service","SdTabRouterItemComponent":"./src/lib/components/tab-router-item/tab-router-item.component","SdTabRouterNavComponent":"./src/lib/components/tab-router-nav/tab-router-nav.component","SdTabRouterOutletComponent":"./src/lib/components/tab-router-outlet/tab-router-outlet.component","SdTabRouterModule":"./src/lib/tab-router.module","ɵa":"./src/lib/pipes/tab-info.pipe"},"importAs":"@sd-angular/core/tab-router"}
|
|
1
|
+
{"__symbolic":"module","version":4,"metadata":{"SdTabInfo":{"__symbolic":"interface"},"SdTab":{"__symbolic":"interface"},"SdTabBase":{"__symbolic":"class","members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"SdTab"}]}]}},"SdTabActivated":{"__symbolic":"class","extends":{"__symbolic":"reference","name":"SdTabBase"},"members":{}},"SdTabDeactivated":{"__symbolic":"class","extends":{"__symbolic":"reference","name":"SdTabBase"},"members":{}},"SdTabEvent":{"__symbolic":"interface"},"SdTabAction":{"__symbolic":"interface"},"SdTabComponentBuilder":{"__symbolic":"interface"},"SdTabComponent":{"__symbolic":"function","parameters":["builder"],"value":{"__symbolic":"error","message":"Lambda not supported","line":14,"character":9,"module":"./src/lib/decorators/tab.decorator"}},"SdTabRouterService":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":8,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@sd-angular/core/notify","name":"SdNotifyService","line":18,"character":37}]}]},"statics":{"ɵprov":{}}},"SdTabDecoratorService":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":3,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"SdTabRouterService"}]}]},"statics":{"tabRouterService":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"rxjs","name":"BehaviorSubject","line":7,"character":32},"arguments":[{"__symbolic":"reference","name":"undefined"}]},"ɵprov":{}}},"SdTabRouterItemComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":5,"character":1},"arguments":[{"selector":"sd-tab-router-item","template":"<a [routerLink]=\"[tab.url]\" [queryParams]=\"tab.queryParams\" [state]=\"{ switchTab: true }\"\r\n class=\"tab-router__item d-flex align-items-center\" [ngClass]=\"{\r\n 'tab-router__item--active': tab.isActive\r\n }\">\r\n <ng-container *ngIf=\"tab | sdTabInfo | async as tabInfo\">\r\n <div class=\"\r\n tab-router__icon\r\n d-flex\r\n align-items-center\r\n justify-content-center\r\n mr-8\r\n \" [ngStyle]=\"{\r\n 'background-color': tabInfo.color\r\n }\" [matTooltip]=\"tabInfo.tooltip || tabInfo.name\" matTooltipPosition=\"below\" matTooltipShowDelay=\"1000\">\r\n {{ tabInfo.initialName || 'SD' }}\r\n </div>\r\n <div class=\"flex-1\">\r\n <div class=\"tab-router__name\">{{ tabInfo.name }}</div>\r\n </div>\r\n <button type=\"button\" class=\"\r\n tab-router__close\r\n d-flex\r\n align-items-center\r\n justify-content-center\r\n ml-4\r\n \" (click)=\"close($event)\">\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n </ng-container>\r\n\r\n</a>","styles":[":host{flex:1 1 auto;max-width:240px;position:relative}:host:after{background:#dde0e5;bottom:0;content:\"\";height:16px;margin:auto;position:absolute;right:0;top:0;width:1px}:host:last-child:after{content:none}.flex-1{flex:1}.tab-router__icon{background-color:#5c6bc0;border-radius:2px;color:#fff;font-size:10px;height:16px;line-height:1;text-transform:uppercase;width:16px}.tab-router__icon .mat-icon{font-size:10px;height:10px;width:10px}.tab-router__close{background:none;border:0;border-radius:50%;color:#757575;height:16px;outline:none;width:16px}.tab-router__close:hover{background-color:rgba(0,0,0,.12)}.tab-router__close .mat-icon{font-size:12px;height:12px;width:12px}.tab-router__item{background:#f2f3f4;color:inherit;font-size:12px;line-height:16px;padding:16px 16px 8px;text-decoration:none}.tab-router__item:hover{background-color:#fff}.tab-router__name{-webkit-box-orient:vertical;-webkit-line-clamp:1;display:-webkit-box;overflow:hidden;text-overflow:ellipsis}.tab-router__item--active{background-color:#fff;border-radius:8px 8px 0 0}"]}]}],"members":{"tab":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":11,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"SdTabRouterService"}]}]}},"SdTabRouterNavComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":10,"character":1},"arguments":[{"selector":"sd-tab-router-nav","template":"<div\r\n #tabRouterNav\r\n class=\"tab-router__nav tab-router__nav--{{ mode }} d-flex align-items-center\"\r\n>\r\n <ng-container *ngFor=\"let tab of tabs\">\r\n <sd-tab-router-item [tab]=\"tab\"></sd-tab-router-item>\r\n </ng-container>\r\n</div>\r\n","styles":[".tab-router__nav{background:#f9f9f9}.tab-router__nav--compact::ng-deep .tab-router__name{display:none}.tab-router__nav--compact::ng-deep .tab-router__icon{margin:0!important}.tab-router__nav--compact::ng-deep .tab-router__item--active{min-width:240px}.tab-router__nav--compact::ng-deep .tab-router__item--active .tab-router__icon{margin-right:8px!important}.tab-router__nav--compact::ng-deep .tab-router__item--active .tab-router__name{display:-webkit-box}"]}]}],"members":{"tabRouterNav":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":16,"character":3},"arguments":["tabRouterNav"]}]}],"tabs":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":18,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor"}],"onResize":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":23,"character":3},"arguments":["window:resize",["$event"]]}]}]}},"SdTabRouterOutletComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":38,"character":1},"arguments":[{"selector":"sd-tab-router-outlet","template":"<sd-tab-router-nav [tabs]=\"tabs\" #tabRouterNav></sd-tab-router-nav>\r\n\r\n<div class=\"tab-router__list\">\r\n <ng-container *ngFor=\"let tab of tabs\">\r\n <div class=\"tab-router__pane\" [class.active]=\"tab.isActive\" [id]=\"tab.key\">\r\n <div class=\"tab-router__content\">\r\n <ng-container\r\n *ngComponentOutlet=\"tab.component; injector: tab.injector\"\r\n ></ng-container>\r\n </div>\r\n </div>\r\n </ng-container>\r\n</div>\r\n","styles":[":host{display:flex;flex-direction:column;height:calc(100vh - 64px);width:100%}:host ::ng-deep .sd-loading{max-height:100%;max-width:100%}::ng-deep page-layout{height:100%!important}.tab-router__list{flex:1}.tab-router__pane{display:none;height:100%;position:relative;width:100%}.tab-router__pane.active{display:block}.tab-router__content{bottom:0;height:100%;left:0;overflow:auto;position:absolute;right:0;top:0;width:100%}"]}]}],"members":{"tabRouterNav":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":45,"character":3},"arguments":["tabRouterNav"]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/router","name":"Router","line":52,"character":20},{"__symbolic":"reference","module":"@angular/router","name":"ActivatedRoute","line":53,"character":28},{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":54,"character":16},{"__symbolic":"reference","module":"@angular/core","name":"Injector","line":55,"character":22},{"__symbolic":"reference","module":"@angular/core","name":"Compiler","line":56,"character":22},{"__symbolic":"reference","name":"SdTabDecoratorService"},{"__symbolic":"reference","name":"SdTabRouterService"},{"__symbolic":"reference","module":"@sd-angular/core/notify","name":"SdNotifyService","line":59,"character":29}]}],"ngOnDestroy":[{"__symbolic":"method"}]}},"SdTabRouterModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":11,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"SdTabRouterItemComponent"},{"__symbolic":"reference","name":"SdTabRouterNavComponent"},{"__symbolic":"reference","name":"SdTabRouterOutletComponent"},{"__symbolic":"reference","name":"ɵa"}],"imports":[{"__symbolic":"reference","module":"@angular/router","name":"RouterModule","line":18,"character":12},{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":18,"character":26},{"__symbolic":"reference","module":"@angular/material/icon","name":"MatIconModule","line":18,"character":40},{"__symbolic":"reference","module":"@angular/material/tooltip","name":"MatTooltipModule","line":18,"character":55}],"exports":[{"__symbolic":"reference","name":"SdTabRouterItemComponent"},{"__symbolic":"reference","name":"SdTabRouterNavComponent"},{"__symbolic":"reference","name":"SdTabRouterOutletComponent"}],"providers":[]}]}],"members":{}},"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Pipe","line":5,"character":1},"arguments":[{"name":"sdTabInfo"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"SdTabRouterService"}]}],"transform":[{"__symbolic":"method"}]}}},"origins":{"SdTabInfo":"./src/lib/models/tab-router.model","SdTab":"./src/lib/models/tab-router.model","SdTabBase":"./src/lib/events/tab-router.event","SdTabActivated":"./src/lib/events/tab-router.event","SdTabDeactivated":"./src/lib/events/tab-router.event","SdTabEvent":"./src/lib/events/tab-router.event","SdTabAction":"./src/lib/actions/tab-router.action","SdTabComponentBuilder":"./src/lib/decorators/tab.decorator","SdTabComponent":"./src/lib/decorators/tab.decorator","SdTabRouterService":"./src/lib/services/tab-router.service","SdTabDecoratorService":"./src/lib/services/tab-decorator.service","SdTabRouterItemComponent":"./src/lib/components/tab-router-item/tab-router-item.component","SdTabRouterNavComponent":"./src/lib/components/tab-router-nav/tab-router-nav.component","SdTabRouterOutletComponent":"./src/lib/components/tab-router-outlet/tab-router-outlet.component","SdTabRouterModule":"./src/lib/tab-router.module","ɵa":"./src/lib/pipes/tab-info.pipe"},"importAs":"@sd-angular/core/tab-router"}
|