ngx-histaff-alpha 2.2.8 → 2.3.0
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/esm2022/lib/app/libraries/core-button-group-vns/core-button-vns/core-button-vns.component.mjs +5 -6
- package/esm2022/lib/app/libraries/core-table/ICoreTableColumnItem.mjs +1 -1
- package/esm2022/lib/app/libraries/core-tree-grid/core-tree-grid/core-tree-grid.component.mjs +47 -13
- package/esm2022/lib/app/root/menu/menu/menu.component.mjs +31 -7
- package/esm2022/lib/app/services/core-table.service.mjs +71 -0
- package/esm2022/public-api.mjs +2 -1
- package/fesm2022/ngx-histaff-alpha.mjs +146 -21
- package/fesm2022/ngx-histaff-alpha.mjs.map +1 -1
- package/lib/app/libraries/core-table/ICoreTableColumnItem.d.ts +1 -0
- package/lib/app/libraries/core-tree-grid/core-tree-grid/core-tree-grid.component.d.ts +15 -4
- package/lib/app/root/menu/menu/menu.component.d.ts +10 -3
- package/lib/app/services/core-table.service.d.ts +17 -0
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
|
@@ -1,5 +1,4 @@
|
|
|
1
|
-
import { Component, EventEmitter, Input, Output, ViewChild
|
|
2
|
-
import { noneAutoClosedAlertOptions } from '../../../constants/alertOptions';
|
|
1
|
+
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
3
2
|
import { CommonModule } from '@angular/common';
|
|
4
3
|
import { TranslatePipe } from '../../../app-pipes/translate.pipe';
|
|
5
4
|
import { TooltipDirective } from '../../tooltip/tooltip.directive';
|
|
@@ -38,9 +37,9 @@ export class CoreButtonVnsComponent {
|
|
|
38
37
|
this.subscriptions.push(filter[0].mustBeHidden$.subscribe(mbh => this.hidden = mbh.includes(this.data.code)));
|
|
39
38
|
}
|
|
40
39
|
else {
|
|
41
|
-
if (isDevMode()) {
|
|
42
|
-
|
|
43
|
-
}
|
|
40
|
+
// if (isDevMode()) {
|
|
41
|
+
// this.alertService.warn("Không tìm thấy instance number của nhóm nút", noneAutoClosedAlertOptions);
|
|
42
|
+
// }
|
|
44
43
|
}
|
|
45
44
|
}
|
|
46
45
|
ngAfterViewInit() {
|
|
@@ -105,4 +104,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
105
104
|
type: ViewChild,
|
|
106
105
|
args: ["container"]
|
|
107
106
|
}] } });
|
|
108
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-button-vns.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-button-group-vns/core-button-vns/core-button-vns.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-button-group-vns/core-button-vns/core-button-vns.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAiB,SAAS,EAAc,YAAY,EAAE,KAAK,EAAqB,MAAM,EAA4B,SAAS,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAMrK,OAAO,EAAE,0BAA0B,EAAE,MAAM,iCAAiC,CAAC;AAC7E,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AAClE,OAAO,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;;;;;;;AAanE,MAAM,OAAO,sBAAsB;IAmBjC,YACU,GAAyB,EACzB,sBAA8C,EAC9C,YAA0B,EAC1B,QAAmB,EACpB,UAAsB;QAJrB,QAAG,GAAH,GAAG,CAAsB;QACzB,2BAAsB,GAAtB,sBAAsB,CAAwB;QAC9C,iBAAY,GAAZ,YAAY,CAAc;QAC1B,aAAQ,GAAR,QAAQ,CAAW;QACpB,eAAU,GAAV,UAAU,CAAY;QAlBtB,gBAAW,GAAY,KAAK,CAAC;QAC5B,gBAAW,GAAG,IAAI,YAAY,EAAkB,CAAC;QAK3D,kBAAa,GAAmB,EAAE,CAAC;QAEnC,oBAAe,GAAG,OAAO,CAAC;QAG1B,gBAAW,GAAY,KAAK,CAAC;IAQzB,CAAC;IAEL,WAAW,CAAC,OAAsB;QAEhC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,YAAY,EAAE;YACpC,UAAU;YACV,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;SAClB;IAEH,CAAC;IAED,QAAQ;QAEN,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,MAAM,EAAE;YACvC,IAAI,CAAC,eAAe,GAAG,MAAM,CAAC;SAC/B;QAED,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC,CAC7C,CAAA;QACD,MAAM,MAAM,GAAG,IAAI,CAAC,sBAAsB,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,cAAc,KAAK,IAAI,CAAC,cAAc,CAAC,CAAC;QAC3G,IAAI,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE;YACnB,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,MAAM,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CACrF,CAAA;SACF;aAAM;YACL,IAAI,SAAS,EAAE,EAAE;gBACf,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,6CAA6C,EAAE,0BAA0B,CAAC,CAAC;aACnG;SACF;IAEH,CAAC;IAED,eAAe;QACb;;WAEG;QACH,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAQ,EAAE,EAAE;YACrE;;eAEG;YACH,IAAI,IAAI,CAAC,SAAS,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE;gBACxE,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;aAC1B;QACH,CAAC,CAAC,CAAC;QAEH,UAAU,CAAC,GAAG,EAAE;YAEd,IAAI,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;gBACxB,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,CAAC,sBAAsB,CAAC,iCAAiC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;oBAC1E,IAAI,CAAC,IAAI,CAAC,eAAe,GAAG,CAAC,CAAA;gBAC/B,CAAC,CAAC,CACH,CAAA;aACF;QAEH,CAAC,CAAC,CAAA;IAEJ,CAAC;IAED,aAAa;QACX,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,UAAU,EAAE;YAC1B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SAClC;aAAM;YACL,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC;SACtC;IACH,CAAC;IAED,YAAY,CAAC,IAA+B,EAAE,CAAM;QAClD,CAAC,CAAC,eAAe,EAAE,CAAC;QACpB,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE,UAAU,EAAE;YAC3B,IAAI,CAAC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,SAAS,CAAC;YAC5C,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACjC,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;SAC1B;IACH,CAAC;8GApGU,sBAAsB;kGAAtB,sBAAsB,iXCtBnC,23DA+BM,2CDhBF,YAAY,iTACZ,aAAa,kDACb,gBAAgB;;2FAKP,sBAAsB;kBAXlC,SAAS;+BACE,iBAAiB,cACf,IAAI,WACP;wBACP,YAAY;wBACZ,aAAa;wBACb,gBAAgB;qBACjB;0MAMQ,MAAM;sBAAd,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACI,WAAW;sBAApB,MAAM;gBAEiB,SAAS;sBAAhC,SAAS;uBAAC,WAAW","sourcesContent":["import { AfterViewInit, Component, ElementRef, EventEmitter, Input, OnChanges, OnInit, Output, Renderer2, SimpleChanges, ViewChild, isDevMode } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { ICoreButtonDropdownOption, ICoreButtonVNS } from '../core-button-group-vns/ICoreButtonVNS';\r\nimport { CoreButtonGroupService } from '../core-button-group-service';\r\nimport { AlertService } from '../../alert/alert.service';\r\nimport { MultiLanguageService } from '../../../services/multi-language.service';\r\nimport { noneAutoClosedAlertOptions } from '../../../constants/alertOptions';\r\nimport { CommonModule } from '@angular/common';\r\nimport { TranslatePipe } from '../../../app-pipes/translate.pipe';\r\nimport { TooltipDirective } from '../../tooltip/tooltip.directive';\r\nimport { DomService } from '../../services/dom.service';\r\n@Component({\r\n  selector: 'core-button-vns',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    TranslatePipe,\r\n    TooltipDirective,\r\n  ],\r\n  templateUrl: './core-button-vns.component.html',\r\n  //styleUrls: ['./core-button-vns.component.scss']\r\n})\r\nexport class CoreButtonVnsComponent implements OnInit, OnChanges, AfterViewInit {\r\n\r\n  @Input() height!: number;\r\n  @Input() data!: ICoreButtonVNS;\r\n  @Input() instanceNumber!: number;\r\n  @Input() disabled!: boolean;\r\n  @Input() showCaption: boolean = false;\r\n  @Output() buttonClick = new EventEmitter<ICoreButtonVNS>();\r\n\r\n  @ViewChild(\"container\") container!: ElementRef;\r\n\r\n  lang!: string\r\n  subscriptions: Subscription[] = [];\r\n  hidden!: boolean;\r\n  toolTipPosition = \"under\";\r\n\r\n  listenerFn!: () => void;\r\n  expandState: boolean = false;\r\n\r\n  constructor(\r\n    private mls: MultiLanguageService,\r\n    private coreButtonGroupService: CoreButtonGroupService,\r\n    private alertService: AlertService,\r\n    private renderer: Renderer2,\r\n    public domService: DomService\r\n  ) { }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n\r\n    if (!changes['height']?.currentValue) {\r\n      //fallback\r\n      this.height = 30;\r\n    }\r\n\r\n  }\r\n\r\n  ngOnInit(): void {\r\n\r\n    if (!!this.data.dropdownOptions?.length) {\r\n      this.toolTipPosition = \"left\";\r\n    }\r\n\r\n    this.subscriptions.push(\r\n      this.mls.lang$.subscribe(x => this.lang = x)\r\n    )\r\n    const filter = this.coreButtonGroupService.instances.filter(x => x.instanceNumber === this.instanceNumber);\r\n    if (!!filter.length) {\r\n      this.subscriptions.push(\r\n        filter[0].mustBeHidden$.subscribe(mbh => this.hidden = mbh.includes(this.data.code))\r\n      )\r\n    } else {\r\n      if (isDevMode()) {\r\n        this.alertService.warn(\"Không tìm thấy instance number của nhóm nút\", noneAutoClosedAlertOptions);\r\n      }\r\n    }\r\n\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    /**\r\n     * This events get called by all clicks on the page\r\n     */\r\n    this.listenerFn = this.renderer.listen('window', 'click', (e: Event) => {\r\n      /*\r\n       * handle click outside\r\n       */\r\n      if (this.container && !!!this.container.nativeElement.contains(e.target)) {\r\n        this.expandState = false;\r\n      }\r\n    });\r\n\r\n    setTimeout(() => {\r\n\r\n      if (this.data.isDropdown) {\r\n        this.subscriptions.push(\r\n          this.coreButtonGroupService.headerButtonPrintDropdownOptions$.subscribe(x => {\r\n            this.data.dropdownOptions = x\r\n          })\r\n        )\r\n      }\r\n      \r\n    })\r\n\r\n  }\r\n\r\n  onButtonClick(): void {\r\n    if (!this.data?.isDropdown) {\r\n      this.buttonClick.emit(this.data);\r\n    } else {\r\n      this.expandState = !this.expandState;\r\n    }\r\n  }\r\n\r\n  onChildClick(item: ICoreButtonDropdownOption, e: any) {\r\n    e.stopPropagation();\r\n    if (!!this.data?.isDropdown) {\r\n      this.data.childCodeClicked = item.childCode;\r\n      this.buttonClick.emit(this.data);\r\n      this.expandState = false;\r\n    }\r\n  }\r\n\r\n}\r\n","<div #container [ngStyle]=\"{ height: height + 'px' }\" [class.alpha-header-btn]=\"!!data.isHeader\"\r\n    [class.alpha-non-header-btn]=\"!data.isHeader\" class=\"core-button-vns-container d-flex d-flex-center\"\r\n    [appTooltip]=\"data.caption | translate: lang\" (click)=\"!hidden ? onButtonClick() : null\">\r\n    <div [ngClass]=\"data.styleClass\" [class.disabled]=\"disabled\" [class.temporary-unavailable]=\"!!hidden\">\r\n        <i src=\"\" [class]=\"data.iconClass\" [class.temporary-unavailable]=\"!!hidden\"></i>\r\n        <span [class.temporary-unavailable]=\"!!hidden\" class=\"button-caption\"\r\n            *ngIf=\"!!showCaption || !!data.showCaption\">{{ data.caption | translate: lang }}</span>\r\n\r\n            @if (!!data.isDropdown) {\r\n                <div #dropdown class=\"header-button-dropdown-wrapper\"\r\n                    [ngStyle]=\"{\r\n                        position: 'absolute',\r\n                        display: !!expandState ? 'block' : 'none',\r\n                        minWidth: '100px',\r\n                        zIndex: domService.getMaxZIndex() + 1\r\n                    }\"\r\n                >\r\n                    @for (item of data.dropdownOptions!; track item) {\r\n                        <div class=\"header-button-dropdown-line\" (click)=\"onChildClick(item, $event)\">\r\n                            <span [class]=\"item.childIconWrapperClass\">\r\n                                <i [class]=\"item.childIconClass\"></i>\r\n                            </span>\r\n                            <span [ngStyle]=\"{\r\n                                textOverflow: 'ellipsis'\r\n                            }\" [appTooltip]=\"item.childCaptionCode | translate: lang\">{{ item.childCaptionCode | translate: lang }}</span>\r\n                        </div>\r\n                    }\r\n                </div>\r\n            }\r\n\r\n    </div>\r\n</div>"]}
|
|
107
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-button-vns.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-button-group-vns/core-button-vns/core-button-vns.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-button-group-vns/core-button-vns/core-button-vns.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAiB,SAAS,EAAc,YAAY,EAAE,KAAK,EAAqB,MAAM,EAA4B,SAAS,EAAa,MAAM,eAAe,CAAC;AAOrK,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AAClE,OAAO,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;;;;;;;AAanE,MAAM,OAAO,sBAAsB;IAmBjC,YACU,GAAyB,EACzB,sBAA8C,EAC9C,YAA0B,EAC1B,QAAmB,EACpB,UAAsB;QAJrB,QAAG,GAAH,GAAG,CAAsB;QACzB,2BAAsB,GAAtB,sBAAsB,CAAwB;QAC9C,iBAAY,GAAZ,YAAY,CAAc;QAC1B,aAAQ,GAAR,QAAQ,CAAW;QACpB,eAAU,GAAV,UAAU,CAAY;QAlBtB,gBAAW,GAAY,KAAK,CAAC;QAC5B,gBAAW,GAAG,IAAI,YAAY,EAAkB,CAAC;QAK3D,kBAAa,GAAmB,EAAE,CAAC;QAEnC,oBAAe,GAAG,OAAO,CAAC;QAG1B,gBAAW,GAAY,KAAK,CAAC;IAQzB,CAAC;IAEL,WAAW,CAAC,OAAsB;QAEhC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,YAAY,EAAE;YACpC,UAAU;YACV,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;SAClB;IAEH,CAAC;IAED,QAAQ;QAEN,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,MAAM,EAAE;YACvC,IAAI,CAAC,eAAe,GAAG,MAAM,CAAC;SAC/B;QAED,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC,CAC7C,CAAA;QACD,MAAM,MAAM,GAAG,IAAI,CAAC,sBAAsB,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,cAAc,KAAK,IAAI,CAAC,cAAc,CAAC,CAAC;QAC3G,IAAI,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE;YACnB,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,MAAM,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CACrF,CAAA;SACF;aAAM;YACL,qBAAqB;YACrB,uGAAuG;YACvG,IAAI;SACL;IAEH,CAAC;IAED,eAAe;QACb;;WAEG;QACH,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAQ,EAAE,EAAE;YACrE;;eAEG;YACH,IAAI,IAAI,CAAC,SAAS,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE;gBACxE,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;aAC1B;QACH,CAAC,CAAC,CAAC;QAEH,UAAU,CAAC,GAAG,EAAE;YAEd,IAAI,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;gBACxB,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,CAAC,sBAAsB,CAAC,iCAAiC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;oBAC1E,IAAI,CAAC,IAAI,CAAC,eAAe,GAAG,CAAC,CAAA;gBAC/B,CAAC,CAAC,CACH,CAAA;aACF;QAEH,CAAC,CAAC,CAAA;IAEJ,CAAC;IAED,aAAa;QACX,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,UAAU,EAAE;YAC1B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SAClC;aAAM;YACL,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC;SACtC;IACH,CAAC;IAED,YAAY,CAAC,IAA+B,EAAE,CAAM;QAClD,CAAC,CAAC,eAAe,EAAE,CAAC;QACpB,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE,UAAU,EAAE;YAC3B,IAAI,CAAC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,SAAS,CAAC;YAC5C,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACjC,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;SAC1B;IACH,CAAC;8GApGU,sBAAsB;kGAAtB,sBAAsB,iXCtBnC,23DA+BM,2CDhBF,YAAY,iTACZ,aAAa,kDACb,gBAAgB;;2FAKP,sBAAsB;kBAXlC,SAAS;+BACE,iBAAiB,cACf,IAAI,WACP;wBACP,YAAY;wBACZ,aAAa;wBACb,gBAAgB;qBACjB;0MAMQ,MAAM;sBAAd,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACI,WAAW;sBAApB,MAAM;gBAEiB,SAAS;sBAAhC,SAAS;uBAAC,WAAW","sourcesContent":["import { AfterViewInit, Component, ElementRef, EventEmitter, Input, OnChanges, OnInit, Output, Renderer2, SimpleChanges, ViewChild, isDevMode } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { ICoreButtonDropdownOption, ICoreButtonVNS } from '../core-button-group-vns/ICoreButtonVNS';\r\nimport { CoreButtonGroupService } from '../core-button-group-service';\r\nimport { AlertService } from '../../alert/alert.service';\r\nimport { MultiLanguageService } from '../../../services/multi-language.service';\r\nimport { noneAutoClosedAlertOptions } from '../../../constants/alertOptions';\r\nimport { CommonModule } from '@angular/common';\r\nimport { TranslatePipe } from '../../../app-pipes/translate.pipe';\r\nimport { TooltipDirective } from '../../tooltip/tooltip.directive';\r\nimport { DomService } from '../../services/dom.service';\r\n@Component({\r\n  selector: 'core-button-vns',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    TranslatePipe,\r\n    TooltipDirective,\r\n  ],\r\n  templateUrl: './core-button-vns.component.html',\r\n  //styleUrls: ['./core-button-vns.component.scss']\r\n})\r\nexport class CoreButtonVnsComponent implements OnInit, OnChanges, AfterViewInit {\r\n\r\n  @Input() height!: number;\r\n  @Input() data!: ICoreButtonVNS;\r\n  @Input() instanceNumber!: number;\r\n  @Input() disabled!: boolean;\r\n  @Input() showCaption: boolean = false;\r\n  @Output() buttonClick = new EventEmitter<ICoreButtonVNS>();\r\n\r\n  @ViewChild(\"container\") container!: ElementRef;\r\n\r\n  lang!: string\r\n  subscriptions: Subscription[] = [];\r\n  hidden!: boolean;\r\n  toolTipPosition = \"under\";\r\n\r\n  listenerFn!: () => void;\r\n  expandState: boolean = false;\r\n\r\n  constructor(\r\n    private mls: MultiLanguageService,\r\n    private coreButtonGroupService: CoreButtonGroupService,\r\n    private alertService: AlertService,\r\n    private renderer: Renderer2,\r\n    public domService: DomService\r\n  ) { }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n\r\n    if (!changes['height']?.currentValue) {\r\n      //fallback\r\n      this.height = 30;\r\n    }\r\n\r\n  }\r\n\r\n  ngOnInit(): void {\r\n\r\n    if (!!this.data.dropdownOptions?.length) {\r\n      this.toolTipPosition = \"left\";\r\n    }\r\n\r\n    this.subscriptions.push(\r\n      this.mls.lang$.subscribe(x => this.lang = x)\r\n    )\r\n    const filter = this.coreButtonGroupService.instances.filter(x => x.instanceNumber === this.instanceNumber);\r\n    if (!!filter.length) {\r\n      this.subscriptions.push(\r\n        filter[0].mustBeHidden$.subscribe(mbh => this.hidden = mbh.includes(this.data.code))\r\n      )\r\n    } else {\r\n      // if (isDevMode()) {\r\n      //   this.alertService.warn(\"Không tìm thấy instance number của nhóm nút\", noneAutoClosedAlertOptions);\r\n      // }\r\n    }\r\n\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    /**\r\n     * This events get called by all clicks on the page\r\n     */\r\n    this.listenerFn = this.renderer.listen('window', 'click', (e: Event) => {\r\n      /*\r\n       * handle click outside\r\n       */\r\n      if (this.container && !!!this.container.nativeElement.contains(e.target)) {\r\n        this.expandState = false;\r\n      }\r\n    });\r\n\r\n    setTimeout(() => {\r\n\r\n      if (this.data.isDropdown) {\r\n        this.subscriptions.push(\r\n          this.coreButtonGroupService.headerButtonPrintDropdownOptions$.subscribe(x => {\r\n            this.data.dropdownOptions = x\r\n          })\r\n        )\r\n      }\r\n      \r\n    })\r\n\r\n  }\r\n\r\n  onButtonClick(): void {\r\n    if (!this.data?.isDropdown) {\r\n      this.buttonClick.emit(this.data);\r\n    } else {\r\n      this.expandState = !this.expandState;\r\n    }\r\n  }\r\n\r\n  onChildClick(item: ICoreButtonDropdownOption, e: any) {\r\n    e.stopPropagation();\r\n    if (!!this.data?.isDropdown) {\r\n      this.data.childCodeClicked = item.childCode;\r\n      this.buttonClick.emit(this.data);\r\n      this.expandState = false;\r\n    }\r\n  }\r\n\r\n}\r\n","<div #container [ngStyle]=\"{ height: height + 'px' }\" [class.alpha-header-btn]=\"!!data.isHeader\"\r\n    [class.alpha-non-header-btn]=\"!data.isHeader\" class=\"core-button-vns-container d-flex d-flex-center\"\r\n    [appTooltip]=\"data.caption | translate: lang\" (click)=\"!hidden ? onButtonClick() : null\">\r\n    <div [ngClass]=\"data.styleClass\" [class.disabled]=\"disabled\" [class.temporary-unavailable]=\"!!hidden\">\r\n        <i src=\"\" [class]=\"data.iconClass\" [class.temporary-unavailable]=\"!!hidden\"></i>\r\n        <span [class.temporary-unavailable]=\"!!hidden\" class=\"button-caption\"\r\n            *ngIf=\"!!showCaption || !!data.showCaption\">{{ data.caption | translate: lang }}</span>\r\n\r\n            @if (!!data.isDropdown) {\r\n                <div #dropdown class=\"header-button-dropdown-wrapper\"\r\n                    [ngStyle]=\"{\r\n                        position: 'absolute',\r\n                        display: !!expandState ? 'block' : 'none',\r\n                        minWidth: '100px',\r\n                        zIndex: domService.getMaxZIndex() + 1\r\n                    }\"\r\n                >\r\n                    @for (item of data.dropdownOptions!; track item) {\r\n                        <div class=\"header-button-dropdown-line\" (click)=\"onChildClick(item, $event)\">\r\n                            <span [class]=\"item.childIconWrapperClass\">\r\n                                <i [class]=\"item.childIconClass\"></i>\r\n                            </span>\r\n                            <span [ngStyle]=\"{\r\n                                textOverflow: 'ellipsis'\r\n                            }\" [appTooltip]=\"item.childCaptionCode | translate: lang\">{{ item.childCaptionCode | translate: lang }}</span>\r\n                        </div>\r\n                    }\r\n                </div>\r\n            }\r\n\r\n    </div>\r\n</div>"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSUNvcmVUYWJsZUNvbHVtbkl0ZW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtaGlzdGFmZi1hbHBoYS9zcmMvbGliL2FwcC9saWJyYXJpZXMvY29yZS10YWJsZS9JQ29yZVRhYmxlQ29sdW1uSXRlbS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGVtcGxhdGVSZWYgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBFbnVtU29ydERpcmVjdGlvbiB9IGZyb20gXCIuLi8uLi9lbnVtL0VudW1Tb3J0RGlyZWN0aW9uXCI7XHJcbmltcG9ydCB7IEVudW1UcmFuc2xhdGVLZXkgfSBmcm9tIFwiYWxwaGEtZ2xvYmFsLWNvbnN0YW50c1wiO1xyXG5pbXBvcnQgeyBFbnVtQ29yZVRhYmxlUGlwZVR5cGUgfSBmcm9tIFwiLi9FbnVtQ29yZVRhYmxlUGlwZVR5cGVcIjtcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgSUNvcmVUYWJsZUNvbHVtbkl0ZW0ge1xyXG4gICAgY2FwdGlvbjogRW51bVRyYW5zbGF0ZUtleSB8IHN0cmluZzsgLy8gTGF0dGVyIHdlIHdpbGwgcmVtb3ZlIFwifCBzdHJpbmdcIlxyXG4gICAgZmllbGQ6IHN0cmluZztcclxuICAgIGhlYWRlckdyb3VwPzogRW51bVRyYW5zbGF0ZUtleTtcclxuICAgIHR5cGU6IHN0cmluZztcclxuICAgIHNlYXJjaD86IHN0cmluZztcclxuICAgIHBpcGU/OiBFbnVtQ29yZVRhYmxlUGlwZVR5cGU7XHJcbiAgICBhbGlnbjogc3RyaW5nO1xyXG4gICAgcmVhZG9ubHk/OiBib29sZWFuO1xyXG4gICAgd2lkdGg/OiBudW1iZXI7XHJcbiAgICBoaWRkZW4/OiBib29sZWFuO1xyXG4gICAgaGlkZVNlYXJjaEJveD86IGJvb2xlYW47XHJcbiAgICBzb3J0RGlyZWN0aW9uPzogRW51bVNvcnREaXJlY3Rpb247XHJcbiAgICB0ZW1wbGF0ZVJlZj86IFRlbXBsYXRlUmVmPGFueT47XHJcbiAgICB0ZW1wbGF0ZVJlZkFsbG93RWRpdE9uUm93QWN0aXZlZD86IGJvb2xlYW47XHJcbiAgICB0cmFuc2xhdGU/OiBib29sZWFuO1xyXG59Il19
|