@tekus/kiosks-design-system 3.0.1 → 3.1.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.
@@ -72,6 +72,18 @@ export class TkKioskCustomCheckCardComponent {
72
72
  */
73
73
  this.onClick = new EventEmitter();
74
74
  }
75
+ /**
76
+ * Determines if the add button should be disabled
77
+ */
78
+ get isAddDisabled() {
79
+ return (this.isDisabled || (this.totalMax > 0 && this.quantity >= this.totalMax));
80
+ }
81
+ /**
82
+ * Determines if the minus button should be disabled
83
+ */
84
+ get isMinusDisabled() {
85
+ return (this.isDisabled || (this.totalMin >= 0 && this.quantity <= this.totalMin));
86
+ }
75
87
  /**
76
88
  * Handles counter value changes with validation
77
89
  * @param value - The increment/decrement value
@@ -95,7 +107,7 @@ export class TkKioskCustomCheckCardComponent {
95
107
  this.onClick.emit();
96
108
  }
97
109
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: TkKioskCustomCheckCardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
98
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.3", type: TkKioskCustomCheckCardComponent, isStandalone: true, selector: "tk-kiosk-custom-check-card", inputs: { title: "title", image: "image", price: "price", selected: "selected", typeCounter: "typeCounter", quantity: "quantity", totalMax: "totalMax", totalMin: "totalMin", isSelectable: "isSelectable", isDisabled: "isDisabled", typeCheck: "typeCheck", imageBorderRadius: "imageBorderRadius", width: "width", minHeight: "minHeight" }, outputs: { onChange: "onChange", onClick: "onClick" }, ngImport: i0, template: "<tk-kiosk-check-card\n [option]=\"{\n image: image,\n name: title,\n checked: selected\n }\"\n [isDisabled]=\"isDisabled\"\n [hideCheck]=\"!isSelectable\"\n [type]=\"typeCheck\"\n [imageBorderRadius]=\"imageBorderRadius\"\n (onClick)=\"handleClick()\"\n [width]=\"width || (!typeCounter ? '' : '240px')\"\n [minHeight]=\"minHeight\">\n <div class=\"tk-kiosk-custom-check-card__content\">\n @if (price) {\n <tk-kiosk-typography\n style=\"text-align: center\"\n type=\"h6-heading\"\n weight=\"600\">\n {{ price | customCurrency }}\n </tk-kiosk-typography>\n } @if (typeCounter === 'add') {\n <div\n (click)=\"$event.stopPropagation()\"\n (keydown.space)=\"$event.stopPropagation()\"\n (keydown.enter)=\"$event.stopPropagation()\">\n <tk-kiosk-icon-btn\n [size]=\"'small'\"\n color=\"primary\"\n (btnClick)=\"onChangeCounter(1)\"></tk-kiosk-icon-btn>\n </div>\n } @if (typeCounter === 'minus') {\n <div\n (click)=\"$event.stopPropagation()\"\n (keydown.space)=\"$event.stopPropagation()\"\n (keydown.enter)=\"$event.stopPropagation()\">\n <tk-kiosk-icon-btn\n [size]=\"'small'\"\n icon=\"tk-kiosk:minus\"\n color=\"primary\"\n (btnClick)=\"onChangeCounter(-1)\"></tk-kiosk-icon-btn>\n </div>\n } @if (typeCounter === 'counter') {\n <div\n (click)=\"$event.stopPropagation()\"\n (keydown.space)=\"$event.stopPropagation()\"\n (keydown.enter)=\"$event.stopPropagation()\">\n <tk-kiosk-btn-count\n [count]=\"quantity\"\n [stroked]=\"false\"\n [totalMax]=\"totalMax\"\n [totalMin]=\"totalMin\"\n size=\"small\"\n color=\"primary\"\n (onAdd)=\"onChangeCounter(1)\"\n (onRemove)=\"onChangeCounter(-1)\"></tk-kiosk-btn-count>\n </div>\n }\n </div>\n</tk-kiosk-check-card>\n", styles: [".tk-kiosk-custom-check-card__content{display:flex;flex-direction:column;gap:12px}\n"], dependencies: [{ kind: "component", type: TkKioskTypographyComponent, selector: "tk-kiosk-typography", inputs: ["type", "color", "size", "weight", "lineBreak"] }, { kind: "component", type: TkKioskIconBtnComponent, selector: "tk-kiosk-icon-btn", inputs: ["isDisabled", "size", "type", "color", "icon", "iconSrc", "bgColor"], outputs: ["btnClick"] }, { kind: "component", type: TkKioskBtnCountComponent, selector: "tk-kiosk-btn-count", inputs: ["count", "totalMax", "totalMin", "measure", "type", "rounded", "color", "size", "stroked"], outputs: ["onAdd", "onRemove"] }, { kind: "component", type: TkKioskCheckCardComponent, selector: "tk-kiosk-check-card", inputs: ["width", "minHeight", "isDisabled", "hideCheck", "imageBorderRadius", "option", "type"], outputs: ["onClick"] }, { kind: "pipe", type: CustomCurrencyPipe, name: "customCurrency" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
110
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.3", type: TkKioskCustomCheckCardComponent, isStandalone: true, selector: "tk-kiosk-custom-check-card", inputs: { title: "title", image: "image", price: "price", selected: "selected", typeCounter: "typeCounter", quantity: "quantity", totalMax: "totalMax", totalMin: "totalMin", isSelectable: "isSelectable", isDisabled: "isDisabled", typeCheck: "typeCheck", imageBorderRadius: "imageBorderRadius", width: "width", minHeight: "minHeight" }, outputs: { onChange: "onChange", onClick: "onClick" }, ngImport: i0, template: "<tk-kiosk-check-card\n [option]=\"{\n image: image,\n name: title,\n checked: selected\n }\"\n [isDisabled]=\"isDisabled\"\n [hideCheck]=\"!isSelectable\"\n [type]=\"typeCheck\"\n [imageBorderRadius]=\"imageBorderRadius\"\n (onClick)=\"handleClick()\"\n [width]=\"width || (!typeCounter ? '' : '240px')\"\n [minHeight]=\"minHeight\">\n <div class=\"tk-kiosk-custom-check-card__content\">\n @if (price) {\n <tk-kiosk-typography\n style=\"text-align: center\"\n type=\"h6-heading\"\n weight=\"600\">\n {{ price | customCurrency }}\n </tk-kiosk-typography>\n } @if (typeCounter === 'add') {\n <div\n (click)=\"$event.stopPropagation()\"\n (keydown.space)=\"$event.stopPropagation()\"\n (keydown.enter)=\"$event.stopPropagation()\">\n <tk-kiosk-icon-btn\n [size]=\"'small'\"\n color=\"primary\"\n (btnClick)=\"onChangeCounter(1)\"></tk-kiosk-icon-btn>\n </div>\n } @if (typeCounter === 'minus') {\n <div\n (click)=\"$event.stopPropagation()\"\n (keydown.space)=\"$event.stopPropagation()\"\n (keydown.enter)=\"$event.stopPropagation()\">\n <tk-kiosk-icon-btn\n [size]=\"'small'\"\n icon=\"tk-kiosk:minus\"\n color=\"primary\"\n (btnClick)=\"onChangeCounter(-1)\"></tk-kiosk-icon-btn>\n </div>\n } @if (typeCounter === 'counter') {\n <div\n (click)=\"$event.stopPropagation()\"\n (keydown.space)=\"$event.stopPropagation()\"\n (keydown.enter)=\"$event.stopPropagation()\">\n <tk-kiosk-btn-count\n [count]=\"quantity\"\n [stroked]=\"false\"\n [totalMax]=\"totalMax\"\n [totalMin]=\"totalMin\"\n [isAddDisabled]=\"isAddDisabled\"\n [isMinusDisabled]=\"isMinusDisabled\"\n size=\"small\"\n color=\"primary\"\n (onAdd)=\"onChangeCounter(1)\"\n (onRemove)=\"onChangeCounter(-1)\"></tk-kiosk-btn-count>\n </div>\n }\n </div>\n</tk-kiosk-check-card>\n", styles: [".tk-kiosk-custom-check-card__content{display:flex;flex-direction:column;gap:12px}\n"], dependencies: [{ kind: "component", type: TkKioskTypographyComponent, selector: "tk-kiosk-typography", inputs: ["type", "color", "size", "weight", "lineBreak"] }, { kind: "component", type: TkKioskIconBtnComponent, selector: "tk-kiosk-icon-btn", inputs: ["isDisabled", "size", "type", "color", "icon", "iconSrc", "bgColor"], outputs: ["btnClick"] }, { kind: "component", type: TkKioskBtnCountComponent, selector: "tk-kiosk-btn-count", inputs: ["count", "totalMax", "totalMin", "measure", "isAddDisabled", "isMinusDisabled", "type", "rounded", "color", "size", "stroked"], outputs: ["onAdd", "onRemove"] }, { kind: "component", type: TkKioskCheckCardComponent, selector: "tk-kiosk-check-card", inputs: ["width", "minHeight", "isDisabled", "hideCheck", "imageBorderRadius", "option", "type"], outputs: ["onClick"] }, { kind: "pipe", type: CustomCurrencyPipe, name: "customCurrency" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
99
111
  }
100
112
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: TkKioskCustomCheckCardComponent, decorators: [{
101
113
  type: Component,
@@ -105,7 +117,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
105
117
  TkKioskBtnCountComponent,
106
118
  TkKioskCheckCardComponent,
107
119
  CustomCurrencyPipe,
108
- ], changeDetection: ChangeDetectionStrategy.OnPush, template: "<tk-kiosk-check-card\n [option]=\"{\n image: image,\n name: title,\n checked: selected\n }\"\n [isDisabled]=\"isDisabled\"\n [hideCheck]=\"!isSelectable\"\n [type]=\"typeCheck\"\n [imageBorderRadius]=\"imageBorderRadius\"\n (onClick)=\"handleClick()\"\n [width]=\"width || (!typeCounter ? '' : '240px')\"\n [minHeight]=\"minHeight\">\n <div class=\"tk-kiosk-custom-check-card__content\">\n @if (price) {\n <tk-kiosk-typography\n style=\"text-align: center\"\n type=\"h6-heading\"\n weight=\"600\">\n {{ price | customCurrency }}\n </tk-kiosk-typography>\n } @if (typeCounter === 'add') {\n <div\n (click)=\"$event.stopPropagation()\"\n (keydown.space)=\"$event.stopPropagation()\"\n (keydown.enter)=\"$event.stopPropagation()\">\n <tk-kiosk-icon-btn\n [size]=\"'small'\"\n color=\"primary\"\n (btnClick)=\"onChangeCounter(1)\"></tk-kiosk-icon-btn>\n </div>\n } @if (typeCounter === 'minus') {\n <div\n (click)=\"$event.stopPropagation()\"\n (keydown.space)=\"$event.stopPropagation()\"\n (keydown.enter)=\"$event.stopPropagation()\">\n <tk-kiosk-icon-btn\n [size]=\"'small'\"\n icon=\"tk-kiosk:minus\"\n color=\"primary\"\n (btnClick)=\"onChangeCounter(-1)\"></tk-kiosk-icon-btn>\n </div>\n } @if (typeCounter === 'counter') {\n <div\n (click)=\"$event.stopPropagation()\"\n (keydown.space)=\"$event.stopPropagation()\"\n (keydown.enter)=\"$event.stopPropagation()\">\n <tk-kiosk-btn-count\n [count]=\"quantity\"\n [stroked]=\"false\"\n [totalMax]=\"totalMax\"\n [totalMin]=\"totalMin\"\n size=\"small\"\n color=\"primary\"\n (onAdd)=\"onChangeCounter(1)\"\n (onRemove)=\"onChangeCounter(-1)\"></tk-kiosk-btn-count>\n </div>\n }\n </div>\n</tk-kiosk-check-card>\n", styles: [".tk-kiosk-custom-check-card__content{display:flex;flex-direction:column;gap:12px}\n"] }]
120
+ ], changeDetection: ChangeDetectionStrategy.OnPush, template: "<tk-kiosk-check-card\n [option]=\"{\n image: image,\n name: title,\n checked: selected\n }\"\n [isDisabled]=\"isDisabled\"\n [hideCheck]=\"!isSelectable\"\n [type]=\"typeCheck\"\n [imageBorderRadius]=\"imageBorderRadius\"\n (onClick)=\"handleClick()\"\n [width]=\"width || (!typeCounter ? '' : '240px')\"\n [minHeight]=\"minHeight\">\n <div class=\"tk-kiosk-custom-check-card__content\">\n @if (price) {\n <tk-kiosk-typography\n style=\"text-align: center\"\n type=\"h6-heading\"\n weight=\"600\">\n {{ price | customCurrency }}\n </tk-kiosk-typography>\n } @if (typeCounter === 'add') {\n <div\n (click)=\"$event.stopPropagation()\"\n (keydown.space)=\"$event.stopPropagation()\"\n (keydown.enter)=\"$event.stopPropagation()\">\n <tk-kiosk-icon-btn\n [size]=\"'small'\"\n color=\"primary\"\n (btnClick)=\"onChangeCounter(1)\"></tk-kiosk-icon-btn>\n </div>\n } @if (typeCounter === 'minus') {\n <div\n (click)=\"$event.stopPropagation()\"\n (keydown.space)=\"$event.stopPropagation()\"\n (keydown.enter)=\"$event.stopPropagation()\">\n <tk-kiosk-icon-btn\n [size]=\"'small'\"\n icon=\"tk-kiosk:minus\"\n color=\"primary\"\n (btnClick)=\"onChangeCounter(-1)\"></tk-kiosk-icon-btn>\n </div>\n } @if (typeCounter === 'counter') {\n <div\n (click)=\"$event.stopPropagation()\"\n (keydown.space)=\"$event.stopPropagation()\"\n (keydown.enter)=\"$event.stopPropagation()\">\n <tk-kiosk-btn-count\n [count]=\"quantity\"\n [stroked]=\"false\"\n [totalMax]=\"totalMax\"\n [totalMin]=\"totalMin\"\n [isAddDisabled]=\"isAddDisabled\"\n [isMinusDisabled]=\"isMinusDisabled\"\n size=\"small\"\n color=\"primary\"\n (onAdd)=\"onChangeCounter(1)\"\n (onRemove)=\"onChangeCounter(-1)\"></tk-kiosk-btn-count>\n </div>\n }\n </div>\n</tk-kiosk-check-card>\n", styles: [".tk-kiosk-custom-check-card__content{display:flex;flex-direction:column;gap:12px}\n"] }]
109
121
  }], propDecorators: { title: [{
110
122
  type: Input
111
123
  }], image: [{
@@ -139,4 +151,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
139
151
  }], onClick: [{
140
152
  type: Output
141
153
  }] } });
142
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tk-kiosk-custom-check-card.component.js","sourceRoot":"","sources":["../../../../../../projects/tk-kiosk-ds/src/lib/components/tk-kiosk-custom-check-card/tk-kiosk-custom-check-card.component.ts","../../../../../../projects/tk-kiosk-ds/src/lib/components/tk-kiosk-custom-check-card/tk-kiosk-custom-check-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  ChangeDetectionStrategy,\n} from '@angular/core';\nimport { TkKioskTypographyComponent } from '../tk-kiosk-typography';\nimport { TkKioskIconBtnComponent } from '../tk-kiosk-icon-btn';\nimport { TkKioskBtnCountComponent } from '../tk-kiosk-btn-count';\nimport { CustomCurrencyPipe } from '../../pipes/custom-currency.pipe';\nimport { TkKioskCheckCardComponent } from '../tk-kiosk-check-card/tk-kiosk-check-card.component';\nimport { CounterType, CheckType, BorderRadiusType } from '../../types';\n\n@Component({\n  selector: 'tk-kiosk-custom-check-card',\n  standalone: true,\n  imports: [\n    TkKioskTypographyComponent,\n    TkKioskIconBtnComponent,\n    TkKioskBtnCountComponent,\n    TkKioskCheckCardComponent,\n    CustomCurrencyPipe,\n  ],\n  templateUrl: './tk-kiosk-custom-check-card.component.html',\n  styleUrl: './tk-kiosk-custom-check-card.component.scss',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TkKioskCustomCheckCardComponent {\n  /**\n   * Display title for the custom component\n   */\n  @Input() title = '';\n\n  /**\n   * Image URL to display in the component\n   */\n  @Input() image = '';\n\n  /**\n   * Price value to display\n   */\n  @Input() price = 0;\n\n  /**\n   * Selection state of the component\n   */\n  @Input() selected = false;\n\n  /**\n   * Type of counter to display (add, minus, counter, or none)\n   */\n  @Input() typeCounter: CounterType = '';\n\n  /**\n   * Current quantity value for counter\n   */\n  @Input() quantity = 0;\n\n  /**\n   * Maximum allowed quantity\n   */\n  @Input() totalMax = 0;\n\n  /**\n   * Minimum allowed quantity\n   */\n  @Input() totalMin = 0;\n\n  /**\n   * Whether the component can be selected\n   */\n  @Input() isSelectable = true;\n\n  /**\n   * Whether the component is disabled\n   */\n  @Input() isDisabled = false;\n\n  /**\n   * Type of check card (simple or multiple)\n   */\n  @Input() typeCheck: CheckType = 'simple';\n\n  /**\n   * Border radius style for the image (circle or none)\n   */\n  @Input() imageBorderRadius: BorderRadiusType = 'circle';\n\n  /**\n   * Custom width for the component\n   */\n  @Input() width = '';\n\n  /**\n   * Minimum height for the component\n   */\n  @Input() minHeight = '';\n\n  /**\n   * Emitted when counter value changes\n   */\n  @Output() onChange = new EventEmitter<number>();\n\n  /**\n   * Emitted when component is clicked\n   */\n  @Output() onClick = new EventEmitter<void>();\n\n  /**\n   * Handles counter value changes with validation\n   * @param value - The increment/decrement value\n   */\n  public onChangeCounter(value: number): void {\n    if (this.isDisabled) return;\n\n    const newQuantity = this.quantity + value;\n\n    if (this.totalMax > 0 && newQuantity > this.totalMax) return;\n    if (this.totalMin >= 0 && newQuantity < this.totalMin) return;\n\n    this.onChange.emit(newQuantity);\n  }\n\n  /**\n   * Handles component click events\n   */\n  public handleClick(): void {\n    if (!this.isSelectable || this.isDisabled) return;\n\n    this.onClick.emit();\n  }\n}\n","<tk-kiosk-check-card\n  [option]=\"{\n    image: image,\n    name: title,\n    checked: selected\n  }\"\n  [isDisabled]=\"isDisabled\"\n  [hideCheck]=\"!isSelectable\"\n  [type]=\"typeCheck\"\n  [imageBorderRadius]=\"imageBorderRadius\"\n  (onClick)=\"handleClick()\"\n  [width]=\"width || (!typeCounter ? '' : '240px')\"\n  [minHeight]=\"minHeight\">\n  <div class=\"tk-kiosk-custom-check-card__content\">\n    @if (price) {\n    <tk-kiosk-typography\n      style=\"text-align: center\"\n      type=\"h6-heading\"\n      weight=\"600\">\n      {{ price | customCurrency }}\n    </tk-kiosk-typography>\n    } @if (typeCounter === 'add') {\n    <div\n      (click)=\"$event.stopPropagation()\"\n      (keydown.space)=\"$event.stopPropagation()\"\n      (keydown.enter)=\"$event.stopPropagation()\">\n      <tk-kiosk-icon-btn\n        [size]=\"'small'\"\n        color=\"primary\"\n        (btnClick)=\"onChangeCounter(1)\"></tk-kiosk-icon-btn>\n    </div>\n    } @if (typeCounter === 'minus') {\n    <div\n      (click)=\"$event.stopPropagation()\"\n      (keydown.space)=\"$event.stopPropagation()\"\n      (keydown.enter)=\"$event.stopPropagation()\">\n      <tk-kiosk-icon-btn\n        [size]=\"'small'\"\n        icon=\"tk-kiosk:minus\"\n        color=\"primary\"\n        (btnClick)=\"onChangeCounter(-1)\"></tk-kiosk-icon-btn>\n    </div>\n    } @if (typeCounter === 'counter') {\n    <div\n      (click)=\"$event.stopPropagation()\"\n      (keydown.space)=\"$event.stopPropagation()\"\n      (keydown.enter)=\"$event.stopPropagation()\">\n      <tk-kiosk-btn-count\n        [count]=\"quantity\"\n        [stroked]=\"false\"\n        [totalMax]=\"totalMax\"\n        [totalMin]=\"totalMin\"\n        size=\"small\"\n        color=\"primary\"\n        (onAdd)=\"onChangeCounter(1)\"\n        (onRemove)=\"onChangeCounter(-1)\"></tk-kiosk-btn-count>\n    </div>\n    }\n  </div>\n</tk-kiosk-check-card>\n"]}
154
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tk-kiosk-custom-check-card.component.js","sourceRoot":"","sources":["../../../../../../projects/tk-kiosk-ds/src/lib/components/tk-kiosk-custom-check-card/tk-kiosk-custom-check-card.component.ts","../../../../../../projects/tk-kiosk-ds/src/lib/components/tk-kiosk-custom-check-card/tk-kiosk-custom-check-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  ChangeDetectionStrategy,\n} from '@angular/core';\nimport { TkKioskTypographyComponent } from '../tk-kiosk-typography';\nimport { TkKioskIconBtnComponent } from '../tk-kiosk-icon-btn';\nimport { TkKioskBtnCountComponent } from '../tk-kiosk-btn-count';\nimport { CustomCurrencyPipe } from '../../pipes/custom-currency.pipe';\nimport { TkKioskCheckCardComponent } from '../tk-kiosk-check-card/tk-kiosk-check-card.component';\nimport { CounterType, CheckType, BorderRadiusType } from '../../types';\n\n@Component({\n  selector: 'tk-kiosk-custom-check-card',\n  standalone: true,\n  imports: [\n    TkKioskTypographyComponent,\n    TkKioskIconBtnComponent,\n    TkKioskBtnCountComponent,\n    TkKioskCheckCardComponent,\n    CustomCurrencyPipe,\n  ],\n  templateUrl: './tk-kiosk-custom-check-card.component.html',\n  styleUrl: './tk-kiosk-custom-check-card.component.scss',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TkKioskCustomCheckCardComponent {\n  /**\n   * Display title for the custom component\n   */\n  @Input() title = '';\n\n  /**\n   * Image URL to display in the component\n   */\n  @Input() image = '';\n\n  /**\n   * Price value to display\n   */\n  @Input() price = 0;\n\n  /**\n   * Selection state of the component\n   */\n  @Input() selected = false;\n\n  /**\n   * Type of counter to display (add, minus, counter, or none)\n   */\n  @Input() typeCounter: CounterType = '';\n\n  /**\n   * Current quantity value for counter\n   */\n  @Input() quantity = 0;\n\n  /**\n   * Maximum allowed quantity\n   */\n  @Input() totalMax = 0;\n\n  /**\n   * Minimum allowed quantity\n   */\n  @Input() totalMin = 0;\n\n  /**\n   * Whether the component can be selected\n   */\n  @Input() isSelectable = true;\n\n  /**\n   * Whether the component is disabled\n   */\n  @Input() isDisabled = false;\n\n  /**\n   * Type of check card (simple or multiple)\n   */\n  @Input() typeCheck: CheckType = 'simple';\n\n  /**\n   * Border radius style for the image (circle or none)\n   */\n  @Input() imageBorderRadius: BorderRadiusType = 'circle';\n\n  /**\n   * Custom width for the component\n   */\n  @Input() width = '';\n\n  /**\n   * Minimum height for the component\n   */\n  @Input() minHeight = '';\n\n  /**\n   * Emitted when counter value changes\n   */\n  @Output() onChange = new EventEmitter<number>();\n\n  /**\n   * Emitted when component is clicked\n   */\n  @Output() onClick = new EventEmitter<void>();\n\n  /**\n   * Determines if the add button should be disabled\n   */\n  get isAddDisabled(): boolean {\n    return (\n      this.isDisabled || (this.totalMax > 0 && this.quantity >= this.totalMax)\n    );\n  }\n\n  /**\n   * Determines if the minus button should be disabled\n   */\n  get isMinusDisabled(): boolean {\n    return (\n      this.isDisabled || (this.totalMin >= 0 && this.quantity <= this.totalMin)\n    );\n  }\n\n  /**\n   * Handles counter value changes with validation\n   * @param value - The increment/decrement value\n   */\n  public onChangeCounter(value: number): void {\n    if (this.isDisabled) return;\n\n    const newQuantity = this.quantity + value;\n\n    if (this.totalMax > 0 && newQuantity > this.totalMax) return;\n    if (this.totalMin >= 0 && newQuantity < this.totalMin) return;\n\n    this.onChange.emit(newQuantity);\n  }\n\n  /**\n   * Handles component click events\n   */\n  public handleClick(): void {\n    if (!this.isSelectable || this.isDisabled) return;\n\n    this.onClick.emit();\n  }\n}\n","<tk-kiosk-check-card\n  [option]=\"{\n    image: image,\n    name: title,\n    checked: selected\n  }\"\n  [isDisabled]=\"isDisabled\"\n  [hideCheck]=\"!isSelectable\"\n  [type]=\"typeCheck\"\n  [imageBorderRadius]=\"imageBorderRadius\"\n  (onClick)=\"handleClick()\"\n  [width]=\"width || (!typeCounter ? '' : '240px')\"\n  [minHeight]=\"minHeight\">\n  <div class=\"tk-kiosk-custom-check-card__content\">\n    @if (price) {\n    <tk-kiosk-typography\n      style=\"text-align: center\"\n      type=\"h6-heading\"\n      weight=\"600\">\n      {{ price | customCurrency }}\n    </tk-kiosk-typography>\n    } @if (typeCounter === 'add') {\n    <div\n      (click)=\"$event.stopPropagation()\"\n      (keydown.space)=\"$event.stopPropagation()\"\n      (keydown.enter)=\"$event.stopPropagation()\">\n      <tk-kiosk-icon-btn\n        [size]=\"'small'\"\n        color=\"primary\"\n        (btnClick)=\"onChangeCounter(1)\"></tk-kiosk-icon-btn>\n    </div>\n    } @if (typeCounter === 'minus') {\n    <div\n      (click)=\"$event.stopPropagation()\"\n      (keydown.space)=\"$event.stopPropagation()\"\n      (keydown.enter)=\"$event.stopPropagation()\">\n      <tk-kiosk-icon-btn\n        [size]=\"'small'\"\n        icon=\"tk-kiosk:minus\"\n        color=\"primary\"\n        (btnClick)=\"onChangeCounter(-1)\"></tk-kiosk-icon-btn>\n    </div>\n    } @if (typeCounter === 'counter') {\n    <div\n      (click)=\"$event.stopPropagation()\"\n      (keydown.space)=\"$event.stopPropagation()\"\n      (keydown.enter)=\"$event.stopPropagation()\">\n      <tk-kiosk-btn-count\n        [count]=\"quantity\"\n        [stroked]=\"false\"\n        [totalMax]=\"totalMax\"\n        [totalMin]=\"totalMin\"\n        [isAddDisabled]=\"isAddDisabled\"\n        [isMinusDisabled]=\"isMinusDisabled\"\n        size=\"small\"\n        color=\"primary\"\n        (onAdd)=\"onChangeCounter(1)\"\n        (onRemove)=\"onChangeCounter(-1)\"></tk-kiosk-btn-count>\n    </div>\n    }\n  </div>\n</tk-kiosk-check-card>\n"]}
@@ -10,14 +10,38 @@ import * as i4 from "ng-zorro-antd/core/wave";
10
10
  import * as i5 from "ng-zorro-antd/icon";
11
11
  export class TkKioskIconBtnComponent {
12
12
  constructor() {
13
+ /**
14
+ * Emitted when button is clicked
15
+ */
13
16
  this.btnClick = new EventEmitter();
17
+ /**
18
+ * Whether the button is disabled
19
+ */
14
20
  this.isDisabled = false;
21
+ /**
22
+ * Size of the button
23
+ */
15
24
  this.size = 'regular';
25
+ /**
26
+ * Type of button style
27
+ */
16
28
  this.type = '';
29
+ /**
30
+ * Color theme of the button
31
+ */
17
32
  this.color = 'secondary';
33
+ /**
34
+ * Icon name to display
35
+ */
18
36
  this.icon = 'tk-kiosk:add';
37
+ /**
38
+ * Custom background color
39
+ */
19
40
  this.bgColor = '';
20
41
  }
42
+ /**
43
+ * Handles button click events
44
+ */
21
45
  onClick() {
22
46
  this.btnClick.emit();
23
47
  }
@@ -44,4 +68,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
44
68
  }], bgColor: [{
45
69
  type: Input
46
70
  }] } });
47
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGsta2lvc2staWNvbi1idG4uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGsta2lvc2stZHMvc3JjL2xpYi9jb21wb25lbnRzL3RrLWtpb3NrLWljb24tYnRuL3RrLWtpb3NrLWljb24tYnRuLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RrLWtpb3NrLWRzL3NyYy9saWIvY29tcG9uZW50cy90ay1raW9zay1pY29uLWJ0bi90ay1raW9zay1pY29uLWJ0bi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBQy9FLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDdEQsT0FBTyxFQUFFLGVBQWUsRUFBRSxZQUFZLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQzs7Ozs7OztBQVNuRSxNQUFNLE9BQU8sdUJBQXVCO0lBUHBDO1FBUVksYUFBUSxHQUFHLElBQUksWUFBWSxFQUFFLENBQUM7UUFDL0IsZUFBVSxHQUFHLEtBQUssQ0FBQztRQUNuQixTQUFJLEdBQWtDLFNBQVMsQ0FBQztRQUNoRCxTQUFJLEdBQStDLEVBQUUsQ0FBQztRQUN0RCxVQUFLLEdBQXVDLFdBQVcsQ0FBQztRQUN4RCxTQUFJLEdBQUcsY0FBYyxDQUFDO1FBRXRCLFlBQU8sR0FBRyxFQUFFLENBQUM7S0FLdkI7SUFIQyxPQUFPO1FBQ0wsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUN2QixDQUFDOzhHQVpVLHVCQUF1QjtrR0FBdkIsdUJBQXVCLHdQQ1pwQyxrYkFlQSxva3F5Q0RQWSxZQUFZLGdPQUFFLGNBQWMsK3FCQUFFLFlBQVk7OzJGQUl6Qyx1QkFBdUI7a0JBUG5DLFNBQVM7K0JBQ0UsbUJBQW1CLGNBQ2pCLElBQUksV0FDUCxDQUFDLFlBQVksRUFBRSxjQUFjLEVBQUUsWUFBWSxFQUFFLGVBQWUsQ0FBQzs4QkFLNUQsUUFBUTtzQkFBakIsTUFBTTtnQkFDRSxVQUFVO3NCQUFsQixLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSztnQkFDRyxJQUFJO3NCQUFaLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSztnQkFDRyxPQUFPO3NCQUFmLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE56QnV0dG9uTW9kdWxlIH0gZnJvbSAnbmctem9ycm8tYW50ZC9idXR0b24nO1xuaW1wb3J0IHsgTnpJY29uRGlyZWN0aXZlLCBOekljb25Nb2R1bGUgfSBmcm9tICduZy16b3Jyby1hbnRkL2ljb24nO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd0ay1raW9zay1pY29uLWJ0bicsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIE56QnV0dG9uTW9kdWxlLCBOekljb25Nb2R1bGUsIE56SWNvbkRpcmVjdGl2ZV0sXG4gIHRlbXBsYXRlVXJsOiAnLi90ay1raW9zay1pY29uLWJ0bi5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL3RrLWtpb3NrLWljb24tYnRuLmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIFRrS2lvc2tJY29uQnRuQ29tcG9uZW50IHtcbiAgQE91dHB1dCgpIGJ0bkNsaWNrID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuICBASW5wdXQoKSBpc0Rpc2FibGVkID0gZmFsc2U7XG4gIEBJbnB1dCgpIHNpemU6ICdzbWFsbCcgfCAncmVndWxhcicgfCAnbGFyZ2UnID0gJ3JlZ3VsYXInO1xuICBASW5wdXQoKSB0eXBlOiAnb3V0bGluZScgfCAnYm9yZGVyLWxlc3MnIHwgJ3N0cm9rZWQnIHwgJycgPSAnJztcbiAgQElucHV0KCkgY29sb3I6ICdwcmltYXJ5JyB8ICdzZWNvbmRhcnknIHwgJ2FjY2VudCcgPSAnc2Vjb25kYXJ5JztcbiAgQElucHV0KCkgaWNvbiA9ICd0ay1raW9zazphZGQnO1xuICBASW5wdXQoKSBpY29uU3JjOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gIEBJbnB1dCgpIGJnQ29sb3IgPSAnJztcblxuICBvbkNsaWNrKCkge1xuICAgIHRoaXMuYnRuQ2xpY2suZW1pdCgpO1xuICB9XG59XG4iLCI8YnV0dG9uXG4gIG56LWJ1dHRvblxuICBuelR5cGU9XCJwcmltYXJ5XCJcbiAgbnpTaGFwZT1cImNpcmNsZVwiXG4gIChjbGljayk9XCJvbkNsaWNrKClcIlxuICBbbmdDbGFzc109XCIndGstaWNvbi1idG4gJyArIHNpemUgKyAnICcgKyBjb2xvciArICcgJyArIHR5cGUgKyAnICcgKyBpY29uXCJcbiAgW2Rpc2FibGVkXT1cImlzRGlzYWJsZWRcIlxuICBbc3R5bGUuYmFja2dyb3VuZENvbG9yXT1cImJnQ29sb3JcIlxuPlxuICA8aW1nIFtzcmNdPVwiaWNvblNyY1wiIGFsdD1cImljb25cIiAqbmdJZj1cImljb25TcmM7IGVsc2UgaWNvblN2Z1wiIC8+XG5cbiAgPG5nLXRlbXBsYXRlICNpY29uU3ZnPlxuICAgIDxzcGFuIG56LWljb24gW256VHlwZV09XCJpY29uXCIgY2xhc3M9XCJpY29uXCI+PC9zcGFuPlxuICA8L25nLXRlbXBsYXRlPlxuPC9idXR0b24+XG4iXX0=
71
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGsta2lvc2staWNvbi1idG4uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGsta2lvc2stZHMvc3JjL2xpYi9jb21wb25lbnRzL3RrLWtpb3NrLWljb24tYnRuL3RrLWtpb3NrLWljb24tYnRuLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RrLWtpb3NrLWRzL3NyYy9saWIvY29tcG9uZW50cy90ay1raW9zay1pY29uLWJ0bi90ay1raW9zay1pY29uLWJ0bi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDdEQsT0FBTyxFQUFFLGVBQWUsRUFBRSxZQUFZLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQzs7Ozs7OztBQVNuRSxNQUFNLE9BQU8sdUJBQXVCO0lBUHBDO1FBUUU7O1dBRUc7UUFDTyxhQUFRLEdBQUcsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUV4Qzs7V0FFRztRQUNNLGVBQVUsR0FBRyxLQUFLLENBQUM7UUFFNUI7O1dBRUc7UUFDTSxTQUFJLEdBQWtDLFNBQVMsQ0FBQztRQUV6RDs7V0FFRztRQUNNLFNBQUksR0FBK0MsRUFBRSxDQUFDO1FBRS9EOztXQUVHO1FBQ00sVUFBSyxHQUF1QyxXQUFXLENBQUM7UUFFakU7O1dBRUc7UUFDTSxTQUFJLEdBQUcsY0FBYyxDQUFDO1FBTy9COztXQUVHO1FBQ00sWUFBTyxHQUFHLEVBQUUsQ0FBQztLQVF2QjtJQU5DOztPQUVHO0lBQ0ksT0FBTztRQUNaLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDdkIsQ0FBQzs4R0E5Q1UsdUJBQXVCO2tHQUF2Qix1QkFBdUIsd1BDWnBDLGtiQWVBLG9rcXlDRFBZLFlBQVksZ09BQUUsY0FBYywrcUJBQUUsWUFBWTs7MkZBSXpDLHVCQUF1QjtrQkFQbkMsU0FBUzsrQkFDRSxtQkFBbUIsY0FDakIsSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLGNBQWMsRUFBRSxZQUFZLEVBQUUsZUFBZSxDQUFDOzhCQVE1RCxRQUFRO3NCQUFqQixNQUFNO2dCQUtFLFVBQVU7c0JBQWxCLEtBQUs7Z0JBS0csSUFBSTtzQkFBWixLQUFLO2dCQUtHLElBQUk7c0JBQVosS0FBSztnQkFLRyxLQUFLO3NCQUFiLEtBQUs7Z0JBS0csSUFBSTtzQkFBWixLQUFLO2dCQUtHLE9BQU87c0JBQWYsS0FBSztnQkFLRyxPQUFPO3NCQUFmLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE56QnV0dG9uTW9kdWxlIH0gZnJvbSAnbmctem9ycm8tYW50ZC9idXR0b24nO1xuaW1wb3J0IHsgTnpJY29uRGlyZWN0aXZlLCBOekljb25Nb2R1bGUgfSBmcm9tICduZy16b3Jyby1hbnRkL2ljb24nO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd0ay1raW9zay1pY29uLWJ0bicsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIE56QnV0dG9uTW9kdWxlLCBOekljb25Nb2R1bGUsIE56SWNvbkRpcmVjdGl2ZV0sXG4gIHRlbXBsYXRlVXJsOiAnLi90ay1raW9zay1pY29uLWJ0bi5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL3RrLWtpb3NrLWljb24tYnRuLmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIFRrS2lvc2tJY29uQnRuQ29tcG9uZW50IHtcbiAgLyoqXG4gICAqIEVtaXR0ZWQgd2hlbiBidXR0b24gaXMgY2xpY2tlZFxuICAgKi9cbiAgQE91dHB1dCgpIGJ0bkNsaWNrID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gIC8qKlxuICAgKiBXaGV0aGVyIHRoZSBidXR0b24gaXMgZGlzYWJsZWRcbiAgICovXG4gIEBJbnB1dCgpIGlzRGlzYWJsZWQgPSBmYWxzZTtcblxuICAvKipcbiAgICogU2l6ZSBvZiB0aGUgYnV0dG9uXG4gICAqL1xuICBASW5wdXQoKSBzaXplOiAnc21hbGwnIHwgJ3JlZ3VsYXInIHwgJ2xhcmdlJyA9ICdyZWd1bGFyJztcblxuICAvKipcbiAgICogVHlwZSBvZiBidXR0b24gc3R5bGVcbiAgICovXG4gIEBJbnB1dCgpIHR5cGU6ICdvdXRsaW5lJyB8ICdib3JkZXItbGVzcycgfCAnc3Ryb2tlZCcgfCAnJyA9ICcnO1xuXG4gIC8qKlxuICAgKiBDb2xvciB0aGVtZSBvZiB0aGUgYnV0dG9uXG4gICAqL1xuICBASW5wdXQoKSBjb2xvcjogJ3ByaW1hcnknIHwgJ3NlY29uZGFyeScgfCAnYWNjZW50JyA9ICdzZWNvbmRhcnknO1xuXG4gIC8qKlxuICAgKiBJY29uIG5hbWUgdG8gZGlzcGxheVxuICAgKi9cbiAgQElucHV0KCkgaWNvbiA9ICd0ay1raW9zazphZGQnO1xuXG4gIC8qKlxuICAgKiBDdXN0b20gaWNvbiBzb3VyY2UgVVJMXG4gICAqL1xuICBASW5wdXQoKSBpY29uU3JjOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG5cbiAgLyoqXG4gICAqIEN1c3RvbSBiYWNrZ3JvdW5kIGNvbG9yXG4gICAqL1xuICBASW5wdXQoKSBiZ0NvbG9yID0gJyc7XG5cbiAgLyoqXG4gICAqIEhhbmRsZXMgYnV0dG9uIGNsaWNrIGV2ZW50c1xuICAgKi9cbiAgcHVibGljIG9uQ2xpY2soKTogdm9pZCB7XG4gICAgdGhpcy5idG5DbGljay5lbWl0KCk7XG4gIH1cbn1cbiIsIjxidXR0b25cbiAgbnotYnV0dG9uXG4gIG56VHlwZT1cInByaW1hcnlcIlxuICBuelNoYXBlPVwiY2lyY2xlXCJcbiAgKGNsaWNrKT1cIm9uQ2xpY2soKVwiXG4gIFtuZ0NsYXNzXT1cIid0ay1pY29uLWJ0biAnICsgc2l6ZSArICcgJyArIGNvbG9yICsgJyAnICsgdHlwZSArICcgJyArIGljb25cIlxuICBbZGlzYWJsZWRdPVwiaXNEaXNhYmxlZFwiXG4gIFtzdHlsZS5iYWNrZ3JvdW5kQ29sb3JdPVwiYmdDb2xvclwiXG4+XG4gIDxpbWcgW3NyY109XCJpY29uU3JjXCIgYWx0PVwiaWNvblwiICpuZ0lmPVwiaWNvblNyYzsgZWxzZSBpY29uU3ZnXCIgLz5cblxuICA8bmctdGVtcGxhdGUgI2ljb25Tdmc+XG4gICAgPHNwYW4gbnotaWNvbiBbbnpUeXBlXT1cImljb25cIiBjbGFzcz1cImljb25cIj48L3NwYW4+XG4gIDwvbmctdGVtcGxhdGU+XG48L2J1dHRvbj5cbiJdfQ==