@smartbit4all/ng-client 4.2.105 → 4.2.107
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/smart-form/widgets/smartformwidget/smartformwidget.component.mjs +3 -3
- package/esm2022/lib/smart-grid/components/generic-component/expanded-row-renderer.component.mjs +8 -3
- package/esm2022/lib/smart-grid/smart-grid.component.mjs +7 -3
- package/esm2022/lib/view-context/smart-ui-action/ui-action-button/ui-action-button.component.mjs +47 -14
- package/fesm2022/smartbit4all-ng-client.mjs +61 -19
- package/fesm2022/smartbit4all-ng-client.mjs.map +1 -1
- package/lib/smart-grid/components/generic-component/expanded-row-renderer.component.d.ts +3 -1
- package/package.json +1 -1
- package/smartbit4all-ng-client-4.2.107.tgz +0 -0
- package/smartbit4all-ng-client-4.2.105.tgz +0 -0
package/esm2022/lib/view-context/smart-ui-action/ui-action-button/ui-action-button.component.mjs
CHANGED
|
@@ -70,7 +70,7 @@ export class UiActionButtonComponent {
|
|
|
70
70
|
}
|
|
71
71
|
getbtnClass() {
|
|
72
72
|
if (this.descriptor.color) {
|
|
73
|
-
return 'p-button-' + this.descriptor?.color;
|
|
73
|
+
return 'p-button-' + this.descriptor?.color + ' sb4-' + this.descriptor?.color;
|
|
74
74
|
}
|
|
75
75
|
return '';
|
|
76
76
|
}
|
|
@@ -79,19 +79,52 @@ export class UiActionButtonComponent {
|
|
|
79
79
|
switch (this.descriptor.type) {
|
|
80
80
|
case UiActionButtonType.NORMAL:
|
|
81
81
|
return {
|
|
82
|
+
'sb4-normal': true,
|
|
82
83
|
'p-button-text': true,
|
|
83
84
|
'p-button-rounded': true,
|
|
84
85
|
};
|
|
85
86
|
case UiActionButtonType.FLAT:
|
|
86
|
-
return {
|
|
87
|
+
return {
|
|
88
|
+
'sb4-flat': true,
|
|
89
|
+
'p-button-raised': true,
|
|
90
|
+
'p-button-rounded': true,
|
|
91
|
+
};
|
|
87
92
|
case UiActionButtonType.RAISED:
|
|
88
|
-
return {
|
|
93
|
+
return {
|
|
94
|
+
'sb4-raised': true,
|
|
95
|
+
'p-button-raised': true,
|
|
96
|
+
'p-button-rounded': true,
|
|
97
|
+
};
|
|
89
98
|
case UiActionButtonType.STROKED:
|
|
90
|
-
return {
|
|
99
|
+
return {
|
|
100
|
+
'sb4-stroked': true,
|
|
101
|
+
'p-button-outlined': true,
|
|
102
|
+
'p-button-rounded': true,
|
|
103
|
+
};
|
|
91
104
|
case UiActionButtonType.MINI_FAB:
|
|
92
|
-
return {
|
|
105
|
+
return {
|
|
106
|
+
'sb4-minifab': true,
|
|
107
|
+
'p-button-rounded': true,
|
|
108
|
+
'p-button-text': true,
|
|
109
|
+
'p-button-raised': true,
|
|
110
|
+
};
|
|
111
|
+
case UiActionButtonType.FAB:
|
|
112
|
+
return {
|
|
113
|
+
'sb4-fab': true,
|
|
114
|
+
'p-button-rounded': true,
|
|
115
|
+
'p-button-text': true,
|
|
116
|
+
'p-button-raised': true,
|
|
117
|
+
};
|
|
118
|
+
case UiActionButtonType.ICON:
|
|
119
|
+
return {
|
|
120
|
+
'sb4-icon': true,
|
|
121
|
+
'p-button-rounded': true,
|
|
122
|
+
'p-button-text': true,
|
|
123
|
+
'p-button-raised': true,
|
|
124
|
+
};
|
|
93
125
|
default:
|
|
94
126
|
return {
|
|
127
|
+
'sb4-basic': true,
|
|
95
128
|
'p-button-text': true,
|
|
96
129
|
'p-button-raised': true,
|
|
97
130
|
'p-button-rounded': true,
|
|
@@ -102,21 +135,21 @@ export class UiActionButtonComponent {
|
|
|
102
135
|
else {
|
|
103
136
|
switch (this.descriptor.type) {
|
|
104
137
|
case UiActionButtonType.NORMAL:
|
|
105
|
-
return 'mat-mdc-button';
|
|
138
|
+
return 'mat-mdc-button sb4-normal';
|
|
106
139
|
case UiActionButtonType.FLAT:
|
|
107
|
-
return 'mat-mdc-flat-button';
|
|
140
|
+
return 'mat-mdc-flat-button sb4-flat';
|
|
108
141
|
case UiActionButtonType.RAISED:
|
|
109
|
-
return 'mat-mdc-raised-button';
|
|
142
|
+
return 'mat-mdc-raised-button sb4-raised';
|
|
110
143
|
case UiActionButtonType.STROKED:
|
|
111
|
-
return 'mat-mdc-stroked-button';
|
|
144
|
+
return 'mat-mdc-stroked-button sb4-stroked';
|
|
112
145
|
case UiActionButtonType.ICON:
|
|
113
|
-
return 'mat-mdc-icon-button';
|
|
146
|
+
return 'mat-mdc-icon-button sb4-icon';
|
|
114
147
|
case UiActionButtonType.MINI_FAB:
|
|
115
|
-
return 'mat-mdc-mini-fab';
|
|
148
|
+
return 'mat-mdc-mini-fab sb4-minifab';
|
|
116
149
|
case UiActionButtonType.FAB:
|
|
117
|
-
return 'mat-mdc-fab';
|
|
150
|
+
return 'mat-mdc-fab sb4-fab';
|
|
118
151
|
default:
|
|
119
|
-
return `mat-button`;
|
|
152
|
+
return `mat-button sb4-basic`;
|
|
120
153
|
}
|
|
121
154
|
}
|
|
122
155
|
}
|
|
@@ -147,4 +180,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
147
180
|
}], actionDoubleClick: [{
|
|
148
181
|
type: Output
|
|
149
182
|
}] } });
|
|
150
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-action-button.component.js","sourceRoot":"","sources":["../../../../../../../projects/smart-ng-client/src/lib/view-context/smart-ui-action/ui-action-button/ui-action-button.component.ts","../../../../../../../projects/smart-ng-client/src/lib/view-context/smart-ui-action/ui-action-button/ui-action-button.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Inject,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Optional,\r\n  Output,\r\n  SimpleChanges,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { UiActionModel } from '../ui-action.model';\r\nimport { Subject } from 'rxjs';\r\nimport { COMPONENT_LIBRARY, ComponentLibrary } from '../../utility/componentLibrary';\r\nimport { UiActionButtonType } from '../../api/model/uiActionButtonType';\r\nimport { IconPosition } from '../../api/model/iconPosition';\r\nimport { Style, UiAction, UiActionDescriptor } from '../../api';\r\nimport { SmartStyleUtility } from '../../utility/smart-style-utility';\r\n\r\n@Component({\r\n  selector: 'ui-action-button',\r\n  templateUrl: './ui-action-button.component.html',\r\n  styleUrl: './ui-action-button.component.css',\r\n})\r\nexport class UiActionButtonComponent implements OnInit, OnDestroy {\r\n  private _destroy$: Subject<void> = new Subject();\r\n\r\n  @Input() disabled?: boolean;\r\n  @Input() descriptor!: UiActionDescriptor;\r\n  @Input() code?: string;\r\n  @Input() addedCssClass?: string;\r\n\r\n  @Output() actionClick = new EventEmitter<{\r\n    event: MouseEvent;\r\n    descriptor?: UiActionDescriptor;\r\n    code?: string;\r\n    uiAction?: UiAction;\r\n  }>();\r\n  @Output() actionDoubleClick = new EventEmitter<{\r\n    event: any;\r\n    descriptor?: UiActionDescriptor;\r\n    code?: string;\r\n  }>();\r\n\r\n  componentLibrary = ComponentLibrary;\r\n  compLib: ComponentLibrary;\r\n  mainActionModel!: UiActionModel;\r\n\r\n  pressedButtonActive: boolean = true;\r\n  menuOpened: boolean = false;\r\n\r\n  constructor(\r\n    public changeDetector: ChangeDetectorRef,\r\n    @Inject(COMPONENT_LIBRARY) @Optional() compLib?: ComponentLibrary\r\n  ) {\r\n    this.compLib = compLib ?? ComponentLibrary.PRIMENG;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (!this.descriptor) {\r\n      throw new Error(\r\n        'UiActionButtonComponent: \"descriptor\" input is required but was not provided.'\r\n      );\r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['descriptor'] && this.descriptor) {\r\n      this.mainActionModel = {\r\n        descriptor: this.descriptor,\r\n        uiAction: {\r\n          descriptor: this.descriptor,\r\n          code: this.code,\r\n          disabled: this.disabled ?? false,\r\n        },\r\n      } as UiActionModel;\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._destroy$.next();\r\n    this._destroy$.complete();\r\n  }\r\n\r\n  async onActionClicked(event: MouseEvent, model: UiActionModel): Promise<void> {\r\n    event.stopPropagation();\r\n    this.actionClick.emit({\r\n      event,\r\n      code: model.uiAction.code,\r\n      descriptor: model.descriptor!,\r\n    });\r\n  }\r\n\r\n  onActionDoubleClicked(event: any): void {\r\n    event.stopPropagation();\r\n    this.actionDoubleClick.emit({\r\n      event,\r\n      code: this.code,\r\n      descriptor: this.descriptor,\r\n    });\r\n  }\r\n\r\n  iconPosition(): typeof IconPosition {\r\n    return IconPosition;\r\n  }\r\n\r\n  isOnlyIcon(): boolean {\r\n    return (\r\n      this.descriptor?.type === UiActionButtonType.ICON ||\r\n      this.descriptor?.type === UiActionButtonType.MINI_FAB ||\r\n      this.descriptor?.type === UiActionButtonType.FAB\r\n    );\r\n  }\r\n\r\n  getbtnClass(): string {\r\n    if (this.descriptor.color) {\r\n      return 'p-button-' + this.descriptor?.color;\r\n    }\r\n    return '';\r\n  }\r\n\r\n  getType(): any {\r\n    if (this.compLib === ComponentLibrary.PRIMENG) {\r\n      switch (this.descriptor.type) {\r\n        case UiActionButtonType.NORMAL:\r\n          return {\r\n            'p-button-text': true,\r\n            'p-button-rounded': true,\r\n          };\r\n        case UiActionButtonType.FLAT:\r\n          return { 'p-button-raised': true, 'p-button-rounded': true };\r\n        case UiActionButtonType.RAISED:\r\n          return { 'p-button-raised': true, 'p-button-rounded': true };\r\n        case UiActionButtonType.STROKED:\r\n          return { 'p-button-outlined': true, 'p-button-rounded': true };\r\n        case UiActionButtonType.MINI_FAB:\r\n          return { 'p-button-rounded': true, 'p-button-text': true, 'p-button-raised': true };\r\n        default:\r\n          return {\r\n            'p-button-text': true,\r\n            'p-button-raised': true,\r\n            'p-button-rounded': true,\r\n            'p-button-outlined': true,\r\n          };\r\n      }\r\n    } else {\r\n      switch (this.descriptor.type) {\r\n        case UiActionButtonType.NORMAL:\r\n          return 'mat-mdc-button';\r\n        case UiActionButtonType.FLAT:\r\n          return 'mat-mdc-flat-button';\r\n        case UiActionButtonType.RAISED:\r\n          return 'mat-mdc-raised-button';\r\n        case UiActionButtonType.STROKED:\r\n          return 'mat-mdc-stroked-button';\r\n        case UiActionButtonType.ICON:\r\n          return 'mat-mdc-icon-button';\r\n        case UiActionButtonType.MINI_FAB:\r\n          return 'mat-mdc-mini-fab';\r\n        case UiActionButtonType.FAB:\r\n          return 'mat-mdc-fab';\r\n        default:\r\n          return `mat-button`;\r\n      }\r\n    }\r\n  }\r\n\r\n  calcStyle(style?: Style): any {\r\n    return SmartStyleUtility.getNgStyles(style);\r\n  }\r\n}\r\n","<ng-container *ngTemplateOutlet=\"buttonWithBadge\"></ng-container>\r\n\r\n<ng-template #buttonWithBadge>\r\n  @if (descriptor && descriptor.badge) {\r\n  <ui-badge [descriptor]=\"descriptor.badge\">\r\n    <ng-container *ngTemplateOutlet=\"buttonTemplate\"></ng-container>\r\n  </ui-badge>\r\n  } @else {\r\n  <ng-container *ngTemplateOutlet=\"buttonTemplate\"></ng-container>\r\n  }\r\n</ng-template>\r\n\r\n<ng-template #buttonTemplate>\r\n  @if(compLib === componentLibrary.PRIMENG) {\r\n  <button\r\n    pButton\r\n    pRipple\r\n    [smartTooltip]=\"descriptor.tooltip\"\r\n    [disabled]=\"!!disabled\"\r\n    (click)=\"onActionClicked($event, mainActionModel)\"\r\n    (dblclick)=\"onActionDoubleClicked($event)\"\r\n    [autofocus]=\"false\"\r\n    [ngStyle]=\"calcStyle(descriptor.style)\"\r\n    [ngClass]=\"getType()\"\r\n    class=\"{{ getbtnClass() }} {{ addedCssClass }}\"\r\n    type=\"button\"\r\n  >\r\n    <div *ngIf=\"isOnlyIcon(); then buttonIcon; else text\"></div>\r\n  </button>\r\n  } @else {\r\n  <button\r\n    mat-button\r\n    [smartTooltip]=\"descriptor.tooltip\"\r\n    [color]=\"descriptor.color\"\r\n    [disabled]=\"!!disabled\"\r\n    (click)=\"onActionClicked($event, mainActionModel)\"\r\n    (dblclick)=\"onActionDoubleClicked($event)\"\r\n    [ngStyle]=\"calcStyle(descriptor.style)\"\r\n    [ngClass]=\"getType()\"\r\n    class=\"{{ getbtnClass() }} {{ addedCssClass }}\"\r\n    type=\"button\"\r\n  >\r\n    <div *ngIf=\"isOnlyIcon(); then buttonIcon; else text\"></div>\r\n  </button>\r\n  }\r\n</ng-template>\r\n\r\n<ng-template #text>\r\n  @if(descriptor.iconPosition === iconPosition().PRE){\r\n  <ng-container *ngTemplateOutlet=\"buttonIcon\" />\r\n  }\r\n  {{ descriptor.title }}\r\n  @if(descriptor.iconPosition === iconPosition().POST){\r\n  <ng-container *ngTemplateOutlet=\"buttonIcon\" />\r\n  }\r\n</ng-template>\r\n\r\n<ng-template #buttonIcon>\r\n  @if(descriptor.iconResource){\r\n  <smart-icon [imageResource]=\"descriptor.iconResource\"></smart-icon>\r\n  }@else {\r\n  <smart-icon\r\n    [icon]=\"descriptor.icon\"\r\n    [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n  ></smart-icon>\r\n  }\r\n</ng-template>\r\n"]}
|
|
183
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-action-button.component.js","sourceRoot":"","sources":["../../../../../../../projects/smart-ng-client/src/lib/view-context/smart-ui-action/ui-action-button/ui-action-button.component.ts","../../../../../../../projects/smart-ng-client/src/lib/view-context/smart-ui-action/ui-action-button/ui-action-button.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EAET,YAAY,EACZ,MAAM,EACN,KAAK,EAGL,QAAQ,EACR,MAAM,GAGP,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAC;AACrF,OAAO,EAAE,kBAAkB,EAAE,MAAM,oCAAoC,CAAC;AACxE,OAAO,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;AAE5D,OAAO,EAAE,iBAAiB,EAAE,MAAM,mCAAmC,CAAC;;;;;;;;;AAOtE,MAAM,OAAO,uBAAuB;IA2BlC,YACS,cAAiC,EACD,OAA0B;QAD1D,mBAAc,GAAd,cAAc,CAAmB;QA3BlC,cAAS,GAAkB,IAAI,OAAO,EAAE,CAAC;QAOvC,gBAAW,GAAG,IAAI,YAAY,EAKpC,CAAC;QACK,sBAAiB,GAAG,IAAI,YAAY,EAI1C,CAAC;QAEL,qBAAgB,GAAG,gBAAgB,CAAC;QAIpC,wBAAmB,GAAY,IAAI,CAAC;QACpC,eAAU,GAAY,KAAK,CAAC;QAM1B,IAAI,CAAC,OAAO,GAAG,OAAO,IAAI,gBAAgB,CAAC,OAAO,CAAC;IACrD,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC;YACrB,MAAM,IAAI,KAAK,CACb,+EAA+E,CAChF,CAAC;QACJ,CAAC;IACH,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,YAAY,CAAC,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YAC7C,IAAI,CAAC,eAAe,GAAG;gBACrB,UAAU,EAAE,IAAI,CAAC,UAAU;gBAC3B,QAAQ,EAAE;oBACR,UAAU,EAAE,IAAI,CAAC,UAAU;oBAC3B,IAAI,EAAE,IAAI,CAAC,IAAI;oBACf,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,KAAK;iBACjC;aACe,CAAC;QACrB,CAAC;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QACtB,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;IAC5B,CAAC;IAED,KAAK,CAAC,eAAe,CAAC,KAAiB,EAAE,KAAoB;QAC3D,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;YACpB,KAAK;YACL,IAAI,EAAE,KAAK,CAAC,QAAQ,CAAC,IAAI;YACzB,UAAU,EAAE,KAAK,CAAC,UAAW;SAC9B,CAAC,CAAC;IACL,CAAC;IAED,qBAAqB,CAAC,KAAU;QAC9B,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC;YAC1B,KAAK;YACL,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,UAAU,EAAE,IAAI,CAAC,UAAU;SAC5B,CAAC,CAAC;IACL,CAAC;IAED,YAAY;QACV,OAAO,YAAY,CAAC;IACtB,CAAC;IAED,UAAU;QACR,OAAO,CACL,IAAI,CAAC,UAAU,EAAE,IAAI,KAAK,kBAAkB,CAAC,IAAI;YACjD,IAAI,CAAC,UAAU,EAAE,IAAI,KAAK,kBAAkB,CAAC,QAAQ;YACrD,IAAI,CAAC,UAAU,EAAE,IAAI,KAAK,kBAAkB,CAAC,GAAG,CACjD,CAAC;IACJ,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;YAC1B,OAAO,WAAW,GAAG,IAAI,CAAC,UAAU,EAAE,KAAK,GAAG,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,KAAK,CAAC;QACjF,CAAC;QACD,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,OAAO;QACL,IAAI,IAAI,CAAC,OAAO,KAAK,gBAAgB,CAAC,OAAO,EAAE,CAAC;YAC9C,QAAQ,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;gBAC7B,KAAK,kBAAkB,CAAC,MAAM;oBAC5B,OAAO;wBACL,YAAY,EAAE,IAAI;wBAClB,eAAe,EAAE,IAAI;wBACrB,kBAAkB,EAAE,IAAI;qBACzB,CAAC;gBACJ,KAAK,kBAAkB,CAAC,IAAI;oBAC1B,OAAO;wBACL,UAAU,EAAE,IAAI;wBAChB,iBAAiB,EAAE,IAAI;wBACvB,kBAAkB,EAAE,IAAI;qBACzB,CAAC;gBACJ,KAAK,kBAAkB,CAAC,MAAM;oBAC5B,OAAO;wBACL,YAAY,EAAE,IAAI;wBAClB,iBAAiB,EAAE,IAAI;wBACvB,kBAAkB,EAAE,IAAI;qBACzB,CAAC;gBACJ,KAAK,kBAAkB,CAAC,OAAO;oBAC7B,OAAO;wBACL,aAAa,EAAE,IAAI;wBACnB,mBAAmB,EAAE,IAAI;wBACzB,kBAAkB,EAAE,IAAI;qBACzB,CAAC;gBACJ,KAAK,kBAAkB,CAAC,QAAQ;oBAC9B,OAAO;wBACL,aAAa,EAAE,IAAI;wBACnB,kBAAkB,EAAE,IAAI;wBACxB,eAAe,EAAE,IAAI;wBACrB,iBAAiB,EAAE,IAAI;qBACxB,CAAC;gBACJ,KAAK,kBAAkB,CAAC,GAAG;oBACzB,OAAO;wBACL,SAAS,EAAE,IAAI;wBACf,kBAAkB,EAAE,IAAI;wBACxB,eAAe,EAAE,IAAI;wBACrB,iBAAiB,EAAE,IAAI;qBACxB,CAAC;gBACJ,KAAK,kBAAkB,CAAC,IAAI;oBAC1B,OAAO;wBACL,UAAU,EAAE,IAAI;wBAChB,kBAAkB,EAAE,IAAI;wBACxB,eAAe,EAAE,IAAI;wBACrB,iBAAiB,EAAE,IAAI;qBACxB,CAAC;gBACJ;oBACE,OAAO;wBACL,WAAW,EAAE,IAAI;wBACjB,eAAe,EAAE,IAAI;wBACrB,iBAAiB,EAAE,IAAI;wBACvB,kBAAkB,EAAE,IAAI;wBACxB,mBAAmB,EAAE,IAAI;qBAC1B,CAAC;YACN,CAAC;QACH,CAAC;aAAM,CAAC;YACN,QAAQ,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;gBAC7B,KAAK,kBAAkB,CAAC,MAAM;oBAC5B,OAAO,2BAA2B,CAAC;gBACrC,KAAK,kBAAkB,CAAC,IAAI;oBAC1B,OAAO,8BAA8B,CAAC;gBACxC,KAAK,kBAAkB,CAAC,MAAM;oBAC5B,OAAO,kCAAkC,CAAC;gBAC5C,KAAK,kBAAkB,CAAC,OAAO;oBAC7B,OAAO,oCAAoC,CAAC;gBAC9C,KAAK,kBAAkB,CAAC,IAAI;oBAC1B,OAAO,8BAA8B,CAAC;gBACxC,KAAK,kBAAkB,CAAC,QAAQ;oBAC9B,OAAO,8BAA8B,CAAC;gBACxC,KAAK,kBAAkB,CAAC,GAAG;oBACzB,OAAO,qBAAqB,CAAC;gBAC/B;oBACE,OAAO,sBAAsB,CAAC;YAClC,CAAC;QACH,CAAC;IACH,CAAC;IAED,SAAS,CAAC,KAAa;QACrB,OAAO,iBAAiB,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;IAC9C,CAAC;+GAlLU,uBAAuB,mDA6BxB,iBAAiB;mGA7BhB,uBAAuB,wQC3BpC,woEAmEA;;4FDxCa,uBAAuB;kBALnC,SAAS;+BACE,kBAAkB;;0BAiCzB,MAAM;2BAAC,iBAAiB;;0BAAG,QAAQ;yCA1B7B,QAAQ;sBAAhB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,aAAa;sBAArB,KAAK;gBAEI,WAAW;sBAApB,MAAM;gBAMG,iBAAiB;sBAA1B,MAAM","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Inject,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Optional,\r\n  Output,\r\n  SimpleChanges,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { UiActionModel } from '../ui-action.model';\r\nimport { Subject } from 'rxjs';\r\nimport { COMPONENT_LIBRARY, ComponentLibrary } from '../../utility/componentLibrary';\r\nimport { UiActionButtonType } from '../../api/model/uiActionButtonType';\r\nimport { IconPosition } from '../../api/model/iconPosition';\r\nimport { Style, UiAction, UiActionDescriptor } from '../../api';\r\nimport { SmartStyleUtility } from '../../utility/smart-style-utility';\r\n\r\n@Component({\r\n  selector: 'ui-action-button',\r\n  templateUrl: './ui-action-button.component.html',\r\n  styleUrl: './ui-action-button.component.css',\r\n})\r\nexport class UiActionButtonComponent implements OnInit, OnDestroy {\r\n  private _destroy$: Subject<void> = new Subject();\r\n\r\n  @Input() disabled?: boolean;\r\n  @Input() descriptor!: UiActionDescriptor;\r\n  @Input() code?: string;\r\n  @Input() addedCssClass?: string;\r\n\r\n  @Output() actionClick = new EventEmitter<{\r\n    event: MouseEvent;\r\n    descriptor?: UiActionDescriptor;\r\n    code?: string;\r\n    uiAction?: UiAction;\r\n  }>();\r\n  @Output() actionDoubleClick = new EventEmitter<{\r\n    event: any;\r\n    descriptor?: UiActionDescriptor;\r\n    code?: string;\r\n  }>();\r\n\r\n  componentLibrary = ComponentLibrary;\r\n  compLib: ComponentLibrary;\r\n  mainActionModel!: UiActionModel;\r\n\r\n  pressedButtonActive: boolean = true;\r\n  menuOpened: boolean = false;\r\n\r\n  constructor(\r\n    public changeDetector: ChangeDetectorRef,\r\n    @Inject(COMPONENT_LIBRARY) @Optional() compLib?: ComponentLibrary\r\n  ) {\r\n    this.compLib = compLib ?? ComponentLibrary.PRIMENG;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (!this.descriptor) {\r\n      throw new Error(\r\n        'UiActionButtonComponent: \"descriptor\" input is required but was not provided.'\r\n      );\r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['descriptor'] && this.descriptor) {\r\n      this.mainActionModel = {\r\n        descriptor: this.descriptor,\r\n        uiAction: {\r\n          descriptor: this.descriptor,\r\n          code: this.code,\r\n          disabled: this.disabled ?? false,\r\n        },\r\n      } as UiActionModel;\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._destroy$.next();\r\n    this._destroy$.complete();\r\n  }\r\n\r\n  async onActionClicked(event: MouseEvent, model: UiActionModel): Promise<void> {\r\n    event.stopPropagation();\r\n    this.actionClick.emit({\r\n      event,\r\n      code: model.uiAction.code,\r\n      descriptor: model.descriptor!,\r\n    });\r\n  }\r\n\r\n  onActionDoubleClicked(event: any): void {\r\n    event.stopPropagation();\r\n    this.actionDoubleClick.emit({\r\n      event,\r\n      code: this.code,\r\n      descriptor: this.descriptor,\r\n    });\r\n  }\r\n\r\n  iconPosition(): typeof IconPosition {\r\n    return IconPosition;\r\n  }\r\n\r\n  isOnlyIcon(): boolean {\r\n    return (\r\n      this.descriptor?.type === UiActionButtonType.ICON ||\r\n      this.descriptor?.type === UiActionButtonType.MINI_FAB ||\r\n      this.descriptor?.type === UiActionButtonType.FAB\r\n    );\r\n  }\r\n\r\n  getbtnClass(): string {\r\n    if (this.descriptor.color) {\r\n      return 'p-button-' + this.descriptor?.color + ' sb4-' + this.descriptor?.color;\r\n    }\r\n    return '';\r\n  }\r\n\r\n  getType(): any {\r\n    if (this.compLib === ComponentLibrary.PRIMENG) {\r\n      switch (this.descriptor.type) {\r\n        case UiActionButtonType.NORMAL:\r\n          return {\r\n            'sb4-normal': true,\r\n            'p-button-text': true,\r\n            'p-button-rounded': true,\r\n          };\r\n        case UiActionButtonType.FLAT:\r\n          return {\r\n            'sb4-flat': true,\r\n            'p-button-raised': true,\r\n            'p-button-rounded': true,\r\n          };\r\n        case UiActionButtonType.RAISED:\r\n          return {\r\n            'sb4-raised': true,\r\n            'p-button-raised': true,\r\n            'p-button-rounded': true,\r\n          };\r\n        case UiActionButtonType.STROKED:\r\n          return {\r\n            'sb4-stroked': true,\r\n            'p-button-outlined': true,\r\n            'p-button-rounded': true,\r\n          };\r\n        case UiActionButtonType.MINI_FAB:\r\n          return {\r\n            'sb4-minifab': true,\r\n            'p-button-rounded': true,\r\n            'p-button-text': true,\r\n            'p-button-raised': true,\r\n          };\r\n        case UiActionButtonType.FAB:\r\n          return {\r\n            'sb4-fab': true,\r\n            'p-button-rounded': true,\r\n            'p-button-text': true,\r\n            'p-button-raised': true,\r\n          };\r\n        case UiActionButtonType.ICON:\r\n          return {\r\n            'sb4-icon': true,\r\n            'p-button-rounded': true,\r\n            'p-button-text': true,\r\n            'p-button-raised': true,\r\n          };\r\n        default:\r\n          return {\r\n            'sb4-basic': true,\r\n            'p-button-text': true,\r\n            'p-button-raised': true,\r\n            'p-button-rounded': true,\r\n            'p-button-outlined': true,\r\n          };\r\n      }\r\n    } else {\r\n      switch (this.descriptor.type) {\r\n        case UiActionButtonType.NORMAL:\r\n          return 'mat-mdc-button sb4-normal';\r\n        case UiActionButtonType.FLAT:\r\n          return 'mat-mdc-flat-button sb4-flat';\r\n        case UiActionButtonType.RAISED:\r\n          return 'mat-mdc-raised-button sb4-raised';\r\n        case UiActionButtonType.STROKED:\r\n          return 'mat-mdc-stroked-button sb4-stroked';\r\n        case UiActionButtonType.ICON:\r\n          return 'mat-mdc-icon-button sb4-icon';\r\n        case UiActionButtonType.MINI_FAB:\r\n          return 'mat-mdc-mini-fab sb4-minifab';\r\n        case UiActionButtonType.FAB:\r\n          return 'mat-mdc-fab sb4-fab';\r\n        default:\r\n          return `mat-button sb4-basic`;\r\n      }\r\n    }\r\n  }\r\n\r\n  calcStyle(style?: Style): any {\r\n    return SmartStyleUtility.getNgStyles(style);\r\n  }\r\n}\r\n","<ng-container *ngTemplateOutlet=\"buttonWithBadge\"></ng-container>\r\n\r\n<ng-template #buttonWithBadge>\r\n  @if (descriptor && descriptor.badge) {\r\n  <ui-badge [descriptor]=\"descriptor.badge\">\r\n    <ng-container *ngTemplateOutlet=\"buttonTemplate\"></ng-container>\r\n  </ui-badge>\r\n  } @else {\r\n  <ng-container *ngTemplateOutlet=\"buttonTemplate\"></ng-container>\r\n  }\r\n</ng-template>\r\n\r\n<ng-template #buttonTemplate>\r\n  @if(compLib === componentLibrary.PRIMENG) {\r\n  <button\r\n    pButton\r\n    pRipple\r\n    [smartTooltip]=\"descriptor.tooltip\"\r\n    [disabled]=\"!!disabled\"\r\n    (click)=\"onActionClicked($event, mainActionModel)\"\r\n    (dblclick)=\"onActionDoubleClicked($event)\"\r\n    [autofocus]=\"false\"\r\n    [ngStyle]=\"calcStyle(descriptor.style)\"\r\n    [ngClass]=\"getType()\"\r\n    class=\"{{ getbtnClass() }} {{ addedCssClass }}\"\r\n    type=\"button\"\r\n  >\r\n    <div *ngIf=\"isOnlyIcon(); then buttonIcon; else text\"></div>\r\n  </button>\r\n  } @else {\r\n  <button\r\n    mat-button\r\n    [smartTooltip]=\"descriptor.tooltip\"\r\n    [color]=\"descriptor.color\"\r\n    [disabled]=\"!!disabled\"\r\n    (click)=\"onActionClicked($event, mainActionModel)\"\r\n    (dblclick)=\"onActionDoubleClicked($event)\"\r\n    [ngStyle]=\"calcStyle(descriptor.style)\"\r\n    [ngClass]=\"getType()\"\r\n    class=\"{{ getbtnClass() }} {{ addedCssClass }}\"\r\n    type=\"button\"\r\n  >\r\n    <div *ngIf=\"isOnlyIcon(); then buttonIcon; else text\"></div>\r\n  </button>\r\n  }\r\n</ng-template>\r\n\r\n<ng-template #text>\r\n  @if(descriptor.iconPosition === iconPosition().PRE){\r\n  <ng-container *ngTemplateOutlet=\"buttonIcon\" />\r\n  }\r\n  {{ descriptor.title }}\r\n  @if(descriptor.iconPosition === iconPosition().POST){\r\n  <ng-container *ngTemplateOutlet=\"buttonIcon\" />\r\n  }\r\n</ng-template>\r\n\r\n<ng-template #buttonIcon>\r\n  @if(descriptor.iconResource){\r\n  <smart-icon [imageResource]=\"descriptor.iconResource\"></smart-icon>\r\n  }@else {\r\n  <smart-icon\r\n    [icon]=\"descriptor.icon\"\r\n    [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n  ></smart-icon>\r\n  }\r\n</ng-template>\r\n"]}
|