ngx-histaff-alpha 3.7.9 → 3.8.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.
|
@@ -107,11 +107,18 @@ export class CoreButtonVnsComponent {
|
|
|
107
107
|
}
|
|
108
108
|
if (this.hidden)
|
|
109
109
|
return;
|
|
110
|
-
if (!this.
|
|
110
|
+
if (!this.data.isHeader) {
|
|
111
111
|
this.buttonClick.emit(this.data);
|
|
112
112
|
}
|
|
113
113
|
else {
|
|
114
|
-
this.
|
|
114
|
+
if (this.data?.isDropdown) {
|
|
115
|
+
this.expandState = !this.expandState;
|
|
116
|
+
}
|
|
117
|
+
else {
|
|
118
|
+
if (!this.debugging) {
|
|
119
|
+
this.buttonClick.emit(this.data);
|
|
120
|
+
}
|
|
121
|
+
}
|
|
115
122
|
}
|
|
116
123
|
}
|
|
117
124
|
onChildClick(item, e) {
|
|
@@ -149,4 +156,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
149
156
|
type: ViewChild,
|
|
150
157
|
args: ["container"]
|
|
151
158
|
}] } });
|
|
152
|
-
//# 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;AACrK,OAAO,EAAE,eAAe,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,EAAE,GAAG,EAAgB,MAAM,MAAM,CAAC;AAKxF,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AAClE,OAAO,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;AAEnE,OAAO,EAAE,qBAAqB,EAAE,MAAM,gDAAgD,CAAC;AACvF,OAAO,EAAE,cAAc,EAAE,MAAM,qCAAqC,CAAC;;;;;;;;AAerE,MAAM,OAAO,sBAAsB;IA2BjC,YACU,GAAyB,EACzB,sBAA8C,EAC9C,YAA0B,EAC1B,KAAiB,EACjB,QAAmB,EACpB,UAAsB,EACrB,aAA4B;QAN5B,QAAG,GAAH,GAAG,CAAsB;QACzB,2BAAsB,GAAtB,sBAAsB,CAAwB;QAC9C,iBAAY,GAAZ,YAAY,CAAc;QAC1B,UAAK,GAAL,KAAK,CAAY;QACjB,aAAQ,GAAR,QAAQ,CAAW;QACpB,eAAU,GAAV,UAAU,CAAY;QACrB,kBAAa,GAAb,aAAa,CAAe;QA5B7B,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;QAI7B,iBAAY,GAAG,IAAI,eAAe,CAAS,EAAE,CAAC,CAAC;IAc3C,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,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,OAAO,CAAC;QAEzE,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;QAED,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,mCAAmC;YACnC,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,OAAO,CAAC,kCAAkC,CAAC,CAAC;YAE3F,yEAAyE;YACzE,IAAI,aAAa,IAAI,aAAa,CAAC,gBAAgB,KAAK,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE;gBAChF,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;gBAC/B,gDAAgD;gBAChD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC;aAChE;iBAAM;gBACL,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;aACjC;YAED,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC,CACjE,CAAA;YAED,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,CAAC,YAAY,CAAC,IAAI,CACpB,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,EACjD,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,EAC5B,MAAM,CAAC,YAAY,CAAC,EAAE,CAAC,YAAY,IAAI,CAAC,CAAC,CAAC;iBACzC,SAAS,CAAC,CAAC,CAAC,EAAE;gBACb,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,OAAO,CAAA;gBACxE,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAC7C,CAAC,CAAC,CACL,CAAA;YAED,IAAI,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;gBAExB,QAAQ,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE;oBACtB,KAAK,qBAAqB,CAAC,qBAAqB;wBAC9C,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,CAAC,sBAAsB,CAAC,iCAAiC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;4BAC1E,IAAI,CAAC,IAAI,CAAC,eAAe,GAAG,CAAC,CAAA;wBAC/B,CAAC,CAAC,CACH,CAAA;wBACD,MAAM;oBACR,KAAK,qBAAqB,CAAC,iCAAiC;wBAC1D,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,CAAC,sBAAsB,CAAC,2CAA2C,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;4BACpF,IAAI,CAAC,IAAI,CAAC,eAAe,GAAG,CAAC,CAAA;wBAC/B,CAAC,CAAC,CACH,CAAA;wBACD,MAAM;oBACR;wBACE,MAAM;iBACT;aAEF;QAEH,CAAC,CAAC,CAAA;IAEJ,CAAC;IAED,aAAa;QACX,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,CAAC,CAAC;QAE5C,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YACtB,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC;YAClC,MAAM,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;YAC5D,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;SAC7C;QAED,IAAI,IAAI,CAAC,MAAM;YAAE,OAAO;QAExB,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,UAAU,EAAE;YAC7C,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,IAAI,CAAC,SAAS,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE,UAAU,EAAE;YAC9C,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;8GArKU,sBAAsB;kGAAtB,sBAAsB,iXC1BnC,otFA4DM,kmCD1CF,YAAY,+GACZ,aAAa,kDACb,gBAAgB,kIAChB,cAAc;;2FAKL,sBAAsB;kBAZlC,SAAS;+BACE,iBAAiB,cACf,IAAI,WACP;wBACP,YAAY;wBACZ,aAAa;wBACb,gBAAgB;wBAChB,cAAc;qBACf;+PAMQ,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 { BehaviorSubject, buffer, debounceTime, filter, map, 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 { 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\nimport { EnumCoreButtonVNSCode } from '../core-button-group-vns/EnumCoreButtonVNSCode';\r\nimport { StringHtmlPipe } from '../../../app-pipes/string-html.pipe';\r\nimport { ActionService } from '../../../services/action.service';\r\n\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    StringHtmlPipe,\r\n  ],\r\n  templateUrl: './core-button-vns.component.html',\r\n  styleUrl: './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  iconSvg?: string;\r\n\r\n  clickStream$ = new BehaviorSubject<string>('');\r\n\r\n  debugging!: boolean;\r\n\r\n  isLastChildOfGroup!: boolean;\r\n\r\n  constructor(\r\n    private mls: MultiLanguageService,\r\n    private coreButtonGroupService: CoreButtonGroupService,\r\n    private alertService: AlertService,\r\n    private elRef: ElementRef,\r\n    private renderer: Renderer2,\r\n    public domService: DomService,\r\n    private actionService: ActionService,\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    this.iconSvg = this.actionService.actionMap.get(this.data.code)?.iconSvg;\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\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      // Get the parent container element\r\n      const parentElement = this.elRef.nativeElement.closest('.core-button-group-vns-container');\r\n\r\n      // Check if the current element is the last child of the parent container\r\n      if (parentElement && parentElement.lastElementChild === this.elRef.nativeElement) {\r\n        this.isLastChildOfGroup = true;\r\n        // Add a class or perform any operation you need\r\n        this.renderer.addClass(this.elRef.nativeElement, 'last-child');\r\n      } else {\r\n        this.isLastChildOfGroup = false;\r\n      }\r\n\r\n      this.subscriptions.push(\r\n        this.actionService.debugging$.subscribe(x => this.debugging = x)\r\n      )\r\n\r\n      this.subscriptions.push(\r\n        this.clickStream$.pipe(\r\n          buffer(this.clickStream$.pipe(debounceTime(250))),\r\n          map(clicks => clicks.length),\r\n          filter(clicksLength => clicksLength >= 5))\r\n          .subscribe(_ => {\r\n            this.iconSvg = this.actionService.actionMap.get(this.data.code)?.iconSvg\r\n            this.actionService.showEditSvg$.next(true);\r\n          })\r\n      )\r\n\r\n      if (this.data.isDropdown) {\r\n\r\n        switch (this.data.code) {\r\n          case EnumCoreButtonVNSCode.HEADER_DROPDOWN_PRINT:\r\n            this.subscriptions.push(\r\n              this.coreButtonGroupService.headerButtonPrintDropdownOptions$.subscribe(x => {\r\n                this.data.dropdownOptions = x\r\n              })\r\n            )\r\n            break;\r\n          case EnumCoreButtonVNSCode.HEADER_DROPDOWN_SET_WORK_SCHEDULE:\r\n            this.subscriptions.push(\r\n              this.coreButtonGroupService.headerButtonSetWorkScheduleDropdownOptions$.subscribe(x => {\r\n                this.data.dropdownOptions = x\r\n              })\r\n            )\r\n            break;\r\n          default:\r\n            break;\r\n        }\r\n\r\n      }\r\n\r\n    })\r\n\r\n  }\r\n\r\n  onButtonClick(): void {\r\n    this.clickStream$.next(crypto.randomUUID());\r\n\r\n    if (this.data.isHeader) {\r\n      const actionCode = this.data.code;\r\n      const action = this.actionService.actionMap.get(actionCode);\r\n      this.actionService.clickedItem$.next(action)\r\n    }\r\n\r\n    if (this.hidden) return;\r\n\r\n    if (!this.debugging && !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.debugging && !!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 class=\"core-button-vns-container\" #container style=\"height: 30px;\" [class.alpha-header-button]=\"!!data.isHeader\"\r\n    [class.alpha-non-header-btn]=\"!data.isHeader\" [appTooltip]=\"data.caption | translate: lang\"\r\n    (click)=\"onButtonClick()\" [ngStyle]=\"{ \r\n            width: !!data.isHeader ? (data.withDivider ? 2 * height + 'px' : height + 'px') : 'auto',\r\n        }\">\r\n\r\n\r\n    @if (!!data.isHeader) {\r\n\r\n        <div class=\"action-wrapper\" [class.pointer]=\"!hidden\" [class.last-child]=\"isLastChildOfGroup\" [class.temporary-unavailable]=\"!!hidden\">\r\n\r\n            @if (!iconSvg || !iconSvg?.length) {\r\n            <i src=\"\" [class]=\"data.iconClass\" [class.temporary-unavailable]=\"!!hidden\"></i>\r\n            } @else {\r\n            <i [class.temporary-unavailable]=\"!!hidden\" style=\"display: inline-block;\" [innerHtml]=\"iconSvg | stringHtml\">\r\n            </i>\r\n            }\r\n    \r\n            @if (!!data.isDropdown) {\r\n            <div #dropdown class=\"header-button-dropdown-wrapper\" [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                @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 |\r\n                        translate: lang }}</span>\r\n                </div>\r\n                }\r\n            </div>\r\n            }\r\n    \r\n            @if (!!showCaption || !!data.showCaption) {\r\n            <span [class.temporary-unavailable]=\"!!hidden\" class=\"button-caption\">{{ data.caption | translate: lang\r\n                }}</span>\r\n            }\r\n    \r\n        </div>\r\n    \r\n        @if (!!data.withDivider) {\r\n        <div [ngStyle]=\"{ height: height + 'px', display: 'inline-block' }\" class=\"separator\"></div>\r\n        }\r\n\r\n\r\n    } @else {\r\n\r\n\r\n        <button [class.temporary-unavailable]=\"!!hidden\" [class.last-child]=\"isLastChildOfGroup\" class=\"btn-for-form btn btn-secondary\">{{ data.caption | translate: lang\r\n                }}</button>\r\n\r\n    }\r\n\r\n\r\n</div>"]}
|
|
159
|
+
//# 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":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, EventEmitter, Input, OnChanges, OnInit, Output, Renderer2, SimpleChanges, ViewChild, isDevMode } from '@angular/core';\r\nimport { BehaviorSubject, buffer, debounceTime, filter, map, 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 { 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\nimport { EnumCoreButtonVNSCode } from '../core-button-group-vns/EnumCoreButtonVNSCode';\r\nimport { StringHtmlPipe } from '../../../app-pipes/string-html.pipe';\r\nimport { ActionService } from '../../../services/action.service';\r\n\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    StringHtmlPipe,\r\n  ],\r\n  templateUrl: './core-button-vns.component.html',\r\n  styleUrl: './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  iconSvg?: string;\r\n\r\n  clickStream$ = new BehaviorSubject<string>('');\r\n\r\n  debugging!: boolean;\r\n\r\n  isLastChildOfGroup!: boolean;\r\n\r\n  constructor(\r\n    private mls: MultiLanguageService,\r\n    private coreButtonGroupService: CoreButtonGroupService,\r\n    private alertService: AlertService,\r\n    private elRef: ElementRef,\r\n    private renderer: Renderer2,\r\n    public domService: DomService,\r\n    private actionService: ActionService,\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    this.iconSvg = this.actionService.actionMap.get(this.data.code)?.iconSvg;\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\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      // Get the parent container element\r\n      const parentElement = this.elRef.nativeElement.closest('.core-button-group-vns-container');\r\n\r\n      // Check if the current element is the last child of the parent container\r\n      if (parentElement && parentElement.lastElementChild === this.elRef.nativeElement) {\r\n        this.isLastChildOfGroup = true;\r\n        // Add a class or perform any operation you need\r\n        this.renderer.addClass(this.elRef.nativeElement, 'last-child');\r\n      } else {\r\n        this.isLastChildOfGroup = false;\r\n      }\r\n\r\n      this.subscriptions.push(\r\n        this.actionService.debugging$.subscribe(x => this.debugging = x)\r\n      )\r\n\r\n      this.subscriptions.push(\r\n        this.clickStream$.pipe(\r\n          buffer(this.clickStream$.pipe(debounceTime(250))),\r\n          map(clicks => clicks.length),\r\n          filter(clicksLength => clicksLength >= 5))\r\n          .subscribe(_ => {\r\n            this.iconSvg = this.actionService.actionMap.get(this.data.code)?.iconSvg\r\n            this.actionService.showEditSvg$.next(true);\r\n          })\r\n      )\r\n\r\n      if (this.data.isDropdown) {\r\n\r\n        switch (this.data.code) {\r\n          case EnumCoreButtonVNSCode.HEADER_DROPDOWN_PRINT:\r\n            this.subscriptions.push(\r\n              this.coreButtonGroupService.headerButtonPrintDropdownOptions$.subscribe(x => {\r\n                this.data.dropdownOptions = x\r\n              })\r\n            )\r\n            break;\r\n          case EnumCoreButtonVNSCode.HEADER_DROPDOWN_SET_WORK_SCHEDULE:\r\n            this.subscriptions.push(\r\n              this.coreButtonGroupService.headerButtonSetWorkScheduleDropdownOptions$.subscribe(x => {\r\n                this.data.dropdownOptions = x\r\n              })\r\n            )\r\n            break;\r\n          default:\r\n            break;\r\n        }\r\n\r\n      }\r\n\r\n    })\r\n\r\n  }\r\n\r\n  onButtonClick(): void {\r\n    this.clickStream$.next(crypto.randomUUID());\r\n\r\n    if (this.data.isHeader) {\r\n      const actionCode = this.data.code;\r\n      const action = this.actionService.actionMap.get(actionCode);\r\n      this.actionService.clickedItem$.next(action)\r\n    }\r\n\r\n    if (this.hidden) return;\r\n\r\n    if (!this.data.isHeader) {\r\n      this.buttonClick.emit(this.data);\r\n    } else {\r\n      if (this.data?.isDropdown) {\r\n        this.expandState = !this.expandState;  \r\n      } else {\r\n        if (!this.debugging) {\r\n          this.buttonClick.emit(this.data);    \r\n        }    \r\n      }\r\n    }\r\n  }\r\n\r\n  onChildClick(item: ICoreButtonDropdownOption, e: any) {\r\n    e.stopPropagation();\r\n    if (!this.debugging && !!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 class=\"core-button-vns-container\" #container style=\"height: 30px;\" [class.alpha-header-button]=\"!!data.isHeader\"\r\n    [class.alpha-non-header-btn]=\"!data.isHeader\" [appTooltip]=\"data.caption | translate: lang\"\r\n    (click)=\"onButtonClick()\" [ngStyle]=\"{ \r\n            width: !!data.isHeader ? (data.withDivider ? 2 * height + 'px' : height + 'px') : 'auto',\r\n        }\">\r\n\r\n\r\n    @if (!!data.isHeader) {\r\n\r\n        <div class=\"action-wrapper\" [class.pointer]=\"!hidden\" [class.last-child]=\"isLastChildOfGroup\" [class.temporary-unavailable]=\"!!hidden\">\r\n\r\n            @if (!iconSvg || !iconSvg?.length) {\r\n            <i src=\"\" [class]=\"data.iconClass\" [class.temporary-unavailable]=\"!!hidden\"></i>\r\n            } @else {\r\n            <i [class.temporary-unavailable]=\"!!hidden\" style=\"display: inline-block;\" [innerHtml]=\"iconSvg | stringHtml\">\r\n            </i>\r\n            }\r\n    \r\n            @if (!!data.isDropdown) {\r\n            <div #dropdown class=\"header-button-dropdown-wrapper\" [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                @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 |\r\n                        translate: lang }}</span>\r\n                </div>\r\n                }\r\n            </div>\r\n            }\r\n    \r\n            @if (!!showCaption || !!data.showCaption) {\r\n            <span [class.temporary-unavailable]=\"!!hidden\" class=\"button-caption\">{{ data.caption | translate: lang\r\n                }}</span>\r\n            }\r\n    \r\n        </div>\r\n    \r\n        @if (!!data.withDivider) {\r\n        <div [ngStyle]=\"{ height: height + 'px', display: 'inline-block' }\" class=\"separator\"></div>\r\n        }\r\n\r\n\r\n    } @else {\r\n\r\n\r\n        <button [class.temporary-unavailable]=\"!!hidden\" [class.last-child]=\"isLastChildOfGroup\" class=\"btn-for-form btn btn-secondary\">{{ data.caption | translate: lang\r\n                }}</button>\r\n\r\n    }\r\n\r\n\r\n</div>"]}
|
|
@@ -5784,11 +5784,18 @@ class CoreButtonVnsComponent {
|
|
|
5784
5784
|
}
|
|
5785
5785
|
if (this.hidden)
|
|
5786
5786
|
return;
|
|
5787
|
-
if (!this.
|
|
5787
|
+
if (!this.data.isHeader) {
|
|
5788
5788
|
this.buttonClick.emit(this.data);
|
|
5789
5789
|
}
|
|
5790
5790
|
else {
|
|
5791
|
-
this.
|
|
5791
|
+
if (this.data?.isDropdown) {
|
|
5792
|
+
this.expandState = !this.expandState;
|
|
5793
|
+
}
|
|
5794
|
+
else {
|
|
5795
|
+
if (!this.debugging) {
|
|
5796
|
+
this.buttonClick.emit(this.data);
|
|
5797
|
+
}
|
|
5798
|
+
}
|
|
5792
5799
|
}
|
|
5793
5800
|
}
|
|
5794
5801
|
onChildClick(item, e) {
|