pdm-ui-kit 0.1.16 → 0.1.18

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.
@@ -12,19 +12,19 @@ export class PdmButtonComponent {
12
12
  this.className = '';
13
13
  this.pressed = new EventEmitter();
14
14
  this.toneClassMap = {
15
- default: { default: 'border-transparent bg-primary text-primary-foreground', hover: 'border-transparent bg-primary text-primary-foreground opacity-90' },
16
- primary: { default: 'border-transparent bg-primary text-primary-foreground', hover: 'border-transparent bg-primary text-primary-foreground opacity-90' },
17
- destructive: { default: 'border-transparent bg-destructive text-destructive-foreground', hover: 'border-transparent bg-destructive text-destructive-foreground opacity-90' },
15
+ default: { default: 'border-primary bg-primary text-primary-foreground', hover: 'border-primary bg-primary text-primary-foreground opacity-90' },
16
+ primary: { default: 'border-primary bg-primary text-primary-foreground', hover: 'border-primary bg-primary text-primary-foreground opacity-90' },
17
+ destructive: { default: 'border-border bg-destructive text-destructive-foreground', hover: 'border-border bg-destructive text-destructive-foreground opacity-90' },
18
18
  outline: { default: 'border-border bg-background text-foreground', hover: 'border-border bg-muted text-foreground' },
19
- subtle: { default: 'border-transparent bg-secondary text-secondary-foreground', hover: 'border-transparent bg-accent text-accent-foreground' },
20
- secondary: { default: 'border-transparent bg-secondary text-secondary-foreground', hover: 'border-transparent bg-accent text-accent-foreground' },
21
- ghost: { default: 'border-transparent bg-transparent text-foreground', hover: 'border-transparent bg-accent text-accent-foreground' },
22
- link: { default: 'border-transparent bg-transparent text-primary', hover: 'border-transparent bg-transparent text-primary underline underline-offset-4' },
23
- 'with-icon': { default: 'border-transparent bg-primary text-primary-foreground', hover: 'border-transparent bg-primary text-primary-foreground opacity-90' },
19
+ subtle: { default: 'border-secondary bg-secondary text-secondary-foreground', hover: 'border-accent bg-accent text-accent-foreground' },
20
+ secondary: { default: 'border-secondary bg-secondary text-secondary-foreground', hover: 'border-accent bg-accent text-accent-foreground' },
21
+ ghost: { default: 'border-border bg-transparent text-foreground', hover: 'border-border bg-accent text-accent-foreground' },
22
+ link: { default: 'border-border bg-transparent text-primary', hover: 'border-border bg-transparent text-primary underline underline-offset-4' },
23
+ 'with-icon': { default: 'border-primary bg-primary text-primary-foreground', hover: 'border-primary bg-primary text-primary-foreground opacity-90' },
24
24
  icon: { default: 'border-border bg-background text-foreground', hover: 'border-border bg-accent text-accent-foreground' },
25
25
  'icon-circle': { default: 'border-border bg-background text-foreground', hover: 'border-border bg-accent text-accent-foreground' },
26
26
  rounded: { default: 'border-border bg-background text-foreground', hover: 'border-border bg-accent text-accent-foreground' },
27
- loading: { default: 'border-transparent bg-primary text-primary-foreground opacity-70', hover: 'border-transparent bg-primary text-primary-foreground opacity-70' }
27
+ loading: { default: 'border-primary bg-primary text-primary-foreground opacity-70', hover: 'border-primary bg-primary text-primary-foreground opacity-70' }
28
28
  };
29
29
  }
30
30
  get isDisabled() {
@@ -79,4 +79,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
79
79
  }], pressed: [{
80
80
  type: Output
81
81
  }] } });
82
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/button/button.component.ts","../../../../../../src/lib/components/button/button.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;;;AAwBhG,MAAM,OAAO,kBAAkB;IAL/B;QAMW,SAAI,GAAkC,QAAQ,CAAC;QAC/C,YAAO,GAAqB,SAAS,CAAC;QACtC,UAAK,GAAmB,SAAS,CAAC;QAClC,SAAI,GAAkB,SAAS,CAAC;QAChC,aAAQ,GAAG,KAAK,CAAC;QACjB,YAAO,GAAG,KAAK,CAAC;QAChB,cAAS,GAAG,EAAE,CAAC;QAEd,YAAO,GAAG,IAAI,YAAY,EAAc,CAAC;QAE1C,iBAAY,GAAiE;YACpF,OAAO,EAAE,EAAE,OAAO,EAAE,uDAAuD,EAAE,KAAK,EAAE,kEAAkE,EAAE;YACxJ,OAAO,EAAE,EAAE,OAAO,EAAE,uDAAuD,EAAE,KAAK,EAAE,kEAAkE,EAAE;YACxJ,WAAW,EAAE,EAAE,OAAO,EAAE,+DAA+D,EAAE,KAAK,EAAE,0EAA0E,EAAE;YAC5K,OAAO,EAAE,EAAE,OAAO,EAAE,6CAA6C,EAAE,KAAK,EAAE,wCAAwC,EAAE;YACpH,MAAM,EAAE,EAAE,OAAO,EAAE,2DAA2D,EAAE,KAAK,EAAE,qDAAqD,EAAE;YAC9I,SAAS,EAAE,EAAE,OAAO,EAAE,2DAA2D,EAAE,KAAK,EAAE,qDAAqD,EAAE;YACjJ,KAAK,EAAE,EAAE,OAAO,EAAE,mDAAmD,EAAE,KAAK,EAAE,qDAAqD,EAAE;YACrI,IAAI,EAAE,EAAE,OAAO,EAAE,gDAAgD,EAAE,KAAK,EAAE,6EAA6E,EAAE;YACzJ,WAAW,EAAE,EAAE,OAAO,EAAE,uDAAuD,EAAE,KAAK,EAAE,kEAAkE,EAAE;YAC5J,IAAI,EAAE,EAAE,OAAO,EAAE,6CAA6C,EAAE,KAAK,EAAE,gDAAgD,EAAE;YACzH,aAAa,EAAE,EAAE,OAAO,EAAE,6CAA6C,EAAE,KAAK,EAAE,gDAAgD,EAAE;YAClI,OAAO,EAAE,EAAE,OAAO,EAAE,6CAA6C,EAAE,KAAK,EAAE,gDAAgD,EAAE;YAC5H,OAAO,EAAE,EAAE,OAAO,EAAE,kEAAkE,EAAE,KAAK,EAAE,kEAAkE,EAAE;SACpK,CAAC;KAkCH;IAhCC,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,KAAK,SAAS,CAAC;IACrE,CAAC;IAED,IAAI,WAAW;QACb,MAAM,YAAY,GAAG,IAAI,CAAC,KAAK,KAAK,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC;QAClE,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,YAAY,CAAC,CAAC;QAEhE,OAAO;YACL,0SAA0S;YAC1S,IAAI,CAAC,OAAO,KAAK,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE;YAC9C,IAAI,CAAC,OAAO,KAAK,MAAM,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE;YAC5C,IAAI,CAAC,OAAO,KAAK,aAAa,CAAC,CAAC,CAAC,4BAA4B,CAAC,CAAC,CAAC,EAAE;YAClE,IAAI,CAAC,OAAO,KAAK,SAAS,CAAC,CAAC,CAAC,0BAA0B,CAAC,CAAC,CAAC,EAAE;YAC5D,IAAI,CAAC,OAAO,KAAK,MAAM,IAAI,IAAI,CAAC,OAAO,KAAK,aAAa,IAAI,IAAI,CAAC,OAAO,KAAK,SAAS;gBACrF,CAAC,CAAC,IAAI,CAAC,IAAI,KAAK,OAAO;oBACrB,CAAC,CAAC,kBAAkB;oBACpB,CAAC,CAAC,IAAI,CAAC,IAAI,KAAK,OAAO;wBACrB,CAAC,CAAC,WAAW;wBACb,CAAC,CAAC,UAAU;gBAChB,CAAC,CAAC,EAAE;YACN,IAAI,CAAC,OAAO,KAAK,MAAM,IAAI,IAAI,CAAC,KAAK,KAAK,OAAO,CAAC,CAAC,CAAC,8BAA8B,CAAC,CAAC,CAAC,EAAE;YACvF,SAAS;YACT,IAAI,CAAC,SAAS;SACf,CAAC;IACJ,CAAC;IAED,OAAO,CAAC,KAAiB;QACvB,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YACpB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SAC1B;IACH,CAAC;;+GA1DU,kBAAkB;mGAAlB,kBAAkB,iOCxB/B,yhBAeA;2FDSa,kBAAkB;kBAL9B,SAAS;+BACE,YAAY,mBAEL,uBAAuB,CAAC,MAAM;8BAGtC,IAAI;sBAAZ,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBAEI,OAAO;sBAAhB,MAAM","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';\n\nexport type PdmButtonVariant =\n  | 'default'\n  | 'primary'\n  | 'destructive'\n  | 'outline'\n  | 'subtle'\n  | 'secondary'\n  | 'ghost'\n  | 'link'\n  | 'with-icon'\n  | 'icon'\n  | 'icon-circle'\n  | 'rounded'\n  | 'loading';\nexport type PdmButtonState = 'default' | 'hover';\nexport type PdmButtonSize = 'small' | 'default' | 'large';\n\n@Component({\n  selector: 'pdm-button',\n  templateUrl: './button.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class PdmButtonComponent {\n  @Input() type: 'button' | 'submit' | 'reset' = 'button';\n  @Input() variant: PdmButtonVariant = 'default';\n  @Input() state: PdmButtonState = 'default';\n  @Input() size: PdmButtonSize = 'default';\n  @Input() disabled = false;\n  @Input() loading = false;\n  @Input() className = '';\n\n  @Output() pressed = new EventEmitter<MouseEvent>();\n\n  readonly toneClassMap: Record<PdmButtonVariant, { default: string; hover: string }> = {\n    default: { default: 'border-transparent bg-primary text-primary-foreground', hover: 'border-transparent bg-primary text-primary-foreground opacity-90' },\n    primary: { default: 'border-transparent bg-primary text-primary-foreground', hover: 'border-transparent bg-primary text-primary-foreground opacity-90' },\n    destructive: { default: 'border-transparent bg-destructive text-destructive-foreground', hover: 'border-transparent bg-destructive text-destructive-foreground opacity-90' },\n    outline: { default: 'border-border bg-background text-foreground', hover: 'border-border bg-muted text-foreground' },\n    subtle: { default: 'border-transparent bg-secondary text-secondary-foreground', hover: 'border-transparent bg-accent text-accent-foreground' },\n    secondary: { default: 'border-transparent bg-secondary text-secondary-foreground', hover: 'border-transparent bg-accent text-accent-foreground' },\n    ghost: { default: 'border-transparent bg-transparent text-foreground', hover: 'border-transparent bg-accent text-accent-foreground' },\n    link: { default: 'border-transparent bg-transparent text-primary', hover: 'border-transparent bg-transparent text-primary underline underline-offset-4' },\n    'with-icon': { default: 'border-transparent bg-primary text-primary-foreground', hover: 'border-transparent bg-primary text-primary-foreground opacity-90' },\n    icon: { default: 'border-border bg-background text-foreground', hover: 'border-border bg-accent text-accent-foreground' },\n    'icon-circle': { default: 'border-border bg-background text-foreground', hover: 'border-border bg-accent text-accent-foreground' },\n    rounded: { default: 'border-border bg-background text-foreground', hover: 'border-border bg-accent text-accent-foreground' },\n    loading: { default: 'border-transparent bg-primary text-primary-foreground opacity-70', hover: 'border-transparent bg-primary text-primary-foreground opacity-70' }\n  };\n\n  get isDisabled(): boolean {\n    return this.disabled || this.loading || this.variant === 'loading';\n  }\n\n  get rootClasses(): string[] {\n    const currentState = this.state === 'hover' ? 'hover' : 'default';\n    const toneClass = this.toneClassMap[this.variant][currentState];\n\n    return [\n      'inline-flex items-center justify-center gap-2 rounded-md border text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-[3px] focus-visible:ring-ring/50 focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 bg-clip-padding',\n      this.variant === 'link' ? 'px-4 py-2 h-9' : '',\n      this.variant === 'icon' ? 'h-9 w-9 p-0' : '',\n      this.variant === 'icon-circle' ? 'h-10 w-10 rounded-full p-0' : '',\n      this.variant === 'rounded' ? 'h-9 w-9 rounded-full p-0' : '',\n      this.variant !== 'icon' && this.variant !== 'icon-circle' && this.variant !== 'rounded'\n        ? this.size === 'small'\n          ? 'h-8 px-3 text-xs'\n          : this.size === 'large'\n            ? 'h-10 px-8'\n            : 'h-9 px-4'\n        : '',\n      this.variant === 'link' && this.state === 'hover' ? 'underline underline-offset-4' : '',\n      toneClass,\n      this.className\n    ];\n  }\n\n  onClick(event: MouseEvent): void {\n    if (!this.isDisabled) {\n      this.pressed.emit(event);\n    }\n  }\n}\n","<button\n  [type]=\"type\"\n  [disabled]=\"isDisabled\"\n  [attr.aria-busy]=\"loading\"\n  [ngClass]=\"rootClasses\"\n  (click)=\"onClick($event)\"\n>\n  <span\n    *ngIf=\"loading\"\n    class=\"inline-block h-4 w-4 animate-spin rounded-full border-2 border-current border-r-transparent\"\n    aria-hidden=\"true\"\n  ></span>\n  <ng-content select=\"[pdmButtonIcon]\" *ngIf=\"variant === 'with-icon' || variant === 'icon' || variant === 'icon-circle' || variant === 'rounded'\"></ng-content>\n  <ng-content></ng-content>\n</button>\n"]}
82
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/button/button.component.ts","../../../../../../src/lib/components/button/button.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';\n\nexport type PdmButtonVariant =\n  | 'default'\n  | 'primary'\n  | 'destructive'\n  | 'outline'\n  | 'subtle'\n  | 'secondary'\n  | 'ghost'\n  | 'link'\n  | 'with-icon'\n  | 'icon'\n  | 'icon-circle'\n  | 'rounded'\n  | 'loading';\nexport type PdmButtonState = 'default' | 'hover';\nexport type PdmButtonSize = 'small' | 'default' | 'large';\n\n@Component({\n  selector: 'pdm-button',\n  templateUrl: './button.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class PdmButtonComponent {\n  @Input() type: 'button' | 'submit' | 'reset' = 'button';\n  @Input() variant: PdmButtonVariant = 'default';\n  @Input() state: PdmButtonState = 'default';\n  @Input() size: PdmButtonSize = 'default';\n  @Input() disabled = false;\n  @Input() loading = false;\n  @Input() className = '';\n\n  @Output() pressed = new EventEmitter<MouseEvent>();\n\n  readonly toneClassMap: Record<PdmButtonVariant, { default: string; hover: string }> = {\n    default: { default: 'border-primary bg-primary text-primary-foreground', hover: 'border-primary bg-primary text-primary-foreground opacity-90' },\n    primary: { default: 'border-primary bg-primary text-primary-foreground', hover: 'border-primary bg-primary text-primary-foreground opacity-90' },\n    destructive: { default: 'border-border bg-destructive text-destructive-foreground', hover: 'border-border bg-destructive text-destructive-foreground opacity-90' },\n    outline: { default: 'border-border bg-background text-foreground', hover: 'border-border bg-muted text-foreground' },\n    subtle: { default: 'border-secondary bg-secondary text-secondary-foreground', hover: 'border-accent bg-accent text-accent-foreground' },\n    secondary: { default: 'border-secondary bg-secondary text-secondary-foreground', hover: 'border-accent bg-accent text-accent-foreground' },\n    ghost: { default: 'border-border bg-transparent text-foreground', hover: 'border-border bg-accent text-accent-foreground' },\n    link: { default: 'border-border bg-transparent text-primary', hover: 'border-border bg-transparent text-primary underline underline-offset-4' },\n    'with-icon': { default: 'border-primary bg-primary text-primary-foreground', hover: 'border-primary bg-primary text-primary-foreground opacity-90' },\n    icon: { default: 'border-border bg-background text-foreground', hover: 'border-border bg-accent text-accent-foreground' },\n    'icon-circle': { default: 'border-border bg-background text-foreground', hover: 'border-border bg-accent text-accent-foreground' },\n    rounded: { default: 'border-border bg-background text-foreground', hover: 'border-border bg-accent text-accent-foreground' },\n    loading: { default: 'border-primary bg-primary text-primary-foreground opacity-70', hover: 'border-primary bg-primary text-primary-foreground opacity-70' }\n  };\n\n  get isDisabled(): boolean {\n    return this.disabled || this.loading || this.variant === 'loading';\n  }\n\n  get rootClasses(): string[] {\n    const currentState = this.state === 'hover' ? 'hover' : 'default';\n    const toneClass = this.toneClassMap[this.variant][currentState];\n\n    return [\n      'inline-flex items-center justify-center gap-2 rounded-md border text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-[3px] focus-visible:ring-ring/50 focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 bg-clip-padding',\n      this.variant === 'link' ? 'px-4 py-2 h-9' : '',\n      this.variant === 'icon' ? 'h-9 w-9 p-0' : '',\n      this.variant === 'icon-circle' ? 'h-10 w-10 rounded-full p-0' : '',\n      this.variant === 'rounded' ? 'h-9 w-9 rounded-full p-0' : '',\n      this.variant !== 'icon' && this.variant !== 'icon-circle' && this.variant !== 'rounded'\n        ? this.size === 'small'\n          ? 'h-8 px-3 text-xs'\n          : this.size === 'large'\n            ? 'h-10 px-8'\n            : 'h-9 px-4'\n        : '',\n      this.variant === 'link' && this.state === 'hover' ? 'underline underline-offset-4' : '',\n      toneClass,\n      this.className\n    ];\n  }\n\n  onClick(event: MouseEvent): void {\n    if (!this.isDisabled) {\n      this.pressed.emit(event);\n    }\n  }\n}\n","<button\n  [type]=\"type\"\n  [disabled]=\"isDisabled\"\n  [attr.aria-busy]=\"loading\"\n  [ngClass]=\"rootClasses\"\n  (click)=\"onClick($event)\"\n>\n  <span\n    *ngIf=\"loading\"\n    class=\"inline-block h-4 w-4 animate-spin rounded-full border-2 border-current border-r-transparent\"\n    aria-hidden=\"true\"\n  ></span>\n  <ng-content select=\"[pdmButtonIcon]\" *ngIf=\"variant === 'with-icon' || variant === 'icon' || variant === 'icon-circle' || variant === 'rounded'\"></ng-content>\n  <ng-content></ng-content>\n</button>\n"]}
@@ -33,6 +33,8 @@ export class PdmButtonGroupComponent {
33
33
  const groupHorizontalClasses = isGroup && !isVertical && !this.separated
34
34
  ? [
35
35
  '[&>*:not(:first-child)]:-ml-px',
36
+ '[&>pdm-button]:flex',
37
+ '[&>pdm-button>button]:h-9',
36
38
  '[&>pdm-input]:flex-1',
37
39
  '[&>pdm-input>div]:w-full',
38
40
  '[&>pdm-button>button]:!rounded-none',
@@ -53,6 +55,8 @@ export class PdmButtonGroupComponent {
53
55
  const groupVerticalClasses = isGroup && isVertical && !this.separated
54
56
  ? [
55
57
  '[&>*:not(:first-child)]:-mt-px',
58
+ '[&>pdm-button]:flex',
59
+ '[&>pdm-button>button]:h-9',
56
60
  '[&>pdm-button>button]:!rounded-none',
57
61
  '[&>pdm-button:first-child>button]:!rounded-t-md',
58
62
  '[&>pdm-button:last-child>button]:!rounded-b-md',
@@ -98,4 +102,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
98
102
  }], className: [{
99
103
  type: Input
100
104
  }] } });
101
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button-group.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/button-group/button-group.component.ts","../../../../../../src/lib/components/button-group/button-group.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input } from '@angular/core';\n\nexport type PdmButtonGroupVariant = 'default' | 'group' | 'orientation' | 'separator';\nexport type PdmButtonGroupOrientation = 'horizontal' | 'vertical';\n\n@Component({\n  selector: 'pdm-button-group',\n  templateUrl: './button-group.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class PdmButtonGroupComponent {\n  @Input() variant: PdmButtonGroupVariant = 'default';\n  @Input() orientation?: PdmButtonGroupOrientation;\n  @Input() direction?: PdmButtonGroupOrientation;\n  @Input() separated = true;\n  @Input() className = '';\n\n  get rootClasses(): string[] {\n    const effectiveOrientation = this.orientation ?? this.direction ?? 'horizontal';\n    const isVertical = this.variant === 'orientation' || effectiveOrientation === 'vertical';\n    const isGroup = this.variant === 'group';\n    const isAttached = !this.separated && this.variant !== 'default';\n    const isSeparator = this.variant === 'separator';\n\n    const attachedClasses = isAttached && !isGroup\n      ? isVertical\n        ? [\n            '[&>*]:rounded-none',\n            '[&>*:first-child]:rounded-t-md',\n            '[&>*:last-child]:rounded-b-md',\n            '[&>*:not(:first-child)]:border-t-0',\n            '[&>*:not(:first-child)]:-mt-px'\n          ].join(' ')\n        : [\n            '[&>*]:rounded-none',\n            '[&>*:first-child]:rounded-l-md',\n            '[&>*:last-child]:rounded-r-md',\n            '[&>*:not(:first-child)]:border-l-0',\n            '[&>*:not(:first-child)]:-ml-px'\n          ].join(' ')\n      : '';\n\n    const groupHorizontalClasses = isGroup && !isVertical && !this.separated\n      ? [\n          '[&>*:not(:first-child)]:-ml-px',\n          '[&>pdm-input]:flex-1',\n          '[&>pdm-input>div]:w-full',\n          '[&>pdm-button>button]:!rounded-none',\n          '[&>pdm-button:first-child>button]:!rounded-l-md',\n          '[&>pdm-button:last-child>button]:!rounded-r-md',\n          '[&>pdm-input>div>input]:!rounded-none',\n          '[&>pdm-input:first-child>div>input]:!rounded-l-md',\n          '[&>pdm-input:last-child>div>input]:!rounded-r-md',\n          '[&>pdm-input-group>div]:!rounded-none',\n          '[&>pdm-input-group:first-child>div]:!rounded-l-md',\n          '[&>pdm-input-group:last-child>div]:!rounded-r-md',\n          '[&>pdm-input>div>input]:bg-background',\n          '[&>pdm-input>div>input]:shadow-none',\n          '[&>pdm-button>button]:rounded-l-none',\n          '[&>pdm-button>button]:shadow-none'\n        ].join(' ')\n      : '';\n\n    const groupVerticalClasses = isGroup && isVertical && !this.separated\n      ? [\n          '[&>*:not(:first-child)]:-mt-px',\n          '[&>pdm-button>button]:!rounded-none',\n          '[&>pdm-button:first-child>button]:!rounded-t-md',\n          '[&>pdm-button:last-child>button]:!rounded-b-md',\n          '[&>pdm-input>div>input]:!rounded-none',\n          '[&>pdm-input:first-child>div>input]:!rounded-t-md',\n          '[&>pdm-input:last-child>div>input]:!rounded-b-md',\n          '[&>pdm-input-group>div]:!rounded-none',\n          '[&>pdm-input-group:first-child>div]:!rounded-t-md',\n          '[&>pdm-input-group:last-child>div]:!rounded-b-md',\n          '[&>pdm-input>div>input]:bg-background',\n          '[&>pdm-input>div>input]:shadow-none',\n          '[&>pdm-button>button]:shadow-none'\n        ].join(' ')\n      : '';\n\n    return [\n      'inline-flex w-fit',\n      isVertical ? 'flex-col items-stretch' : 'items-center',\n      this.variant === 'default' || this.separated ? 'gap-2' : 'gap-0',\n      isGroup ? '*:focus-visible:relative *:focus-visible:z-10' : '',\n      attachedClasses,\n      groupHorizontalClasses,\n      groupVerticalClasses,\n      isSeparator\n        ? 'overflow-hidden rounded-md border border-border bg-secondary shadow-sm'\n        : '',\n      this.className\n    ];\n  }\n}\n","<div\n  role=\"group\"\n  [attr.aria-orientation]=\"variant === 'orientation' || orientation === 'vertical' || direction === 'vertical' ? 'vertical' : 'horizontal'\"\n  [ngClass]=\"rootClasses\"\n>\n  <ng-content></ng-content>\n</div>\n"]}
105
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button-group.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/button-group/button-group.component.ts","../../../../../../src/lib/components/button-group/button-group.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input } from '@angular/core';\n\nexport type PdmButtonGroupVariant = 'default' | 'group' | 'orientation' | 'separator';\nexport type PdmButtonGroupOrientation = 'horizontal' | 'vertical';\n\n@Component({\n  selector: 'pdm-button-group',\n  templateUrl: './button-group.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class PdmButtonGroupComponent {\n  @Input() variant: PdmButtonGroupVariant = 'default';\n  @Input() orientation?: PdmButtonGroupOrientation;\n  @Input() direction?: PdmButtonGroupOrientation;\n  @Input() separated = true;\n  @Input() className = '';\n\n  get rootClasses(): string[] {\n    const effectiveOrientation = this.orientation ?? this.direction ?? 'horizontal';\n    const isVertical = this.variant === 'orientation' || effectiveOrientation === 'vertical';\n    const isGroup = this.variant === 'group';\n    const isAttached = !this.separated && this.variant !== 'default';\n    const isSeparator = this.variant === 'separator';\n\n    const attachedClasses = isAttached && !isGroup\n      ? isVertical\n        ? [\n            '[&>*]:rounded-none',\n            '[&>*:first-child]:rounded-t-md',\n            '[&>*:last-child]:rounded-b-md',\n            '[&>*:not(:first-child)]:border-t-0',\n            '[&>*:not(:first-child)]:-mt-px'\n          ].join(' ')\n        : [\n            '[&>*]:rounded-none',\n            '[&>*:first-child]:rounded-l-md',\n            '[&>*:last-child]:rounded-r-md',\n            '[&>*:not(:first-child)]:border-l-0',\n            '[&>*:not(:first-child)]:-ml-px'\n          ].join(' ')\n      : '';\n\n    const groupHorizontalClasses = isGroup && !isVertical && !this.separated\n      ? [\n          '[&>*:not(:first-child)]:-ml-px',\n          '[&>pdm-button]:flex',\n          '[&>pdm-button>button]:h-9',\n          '[&>pdm-input]:flex-1',\n          '[&>pdm-input>div]:w-full',\n          '[&>pdm-button>button]:!rounded-none',\n          '[&>pdm-button:first-child>button]:!rounded-l-md',\n          '[&>pdm-button:last-child>button]:!rounded-r-md',\n          '[&>pdm-input>div>input]:!rounded-none',\n          '[&>pdm-input:first-child>div>input]:!rounded-l-md',\n          '[&>pdm-input:last-child>div>input]:!rounded-r-md',\n          '[&>pdm-input-group>div]:!rounded-none',\n          '[&>pdm-input-group:first-child>div]:!rounded-l-md',\n          '[&>pdm-input-group:last-child>div]:!rounded-r-md',\n          '[&>pdm-input>div>input]:bg-background',\n          '[&>pdm-input>div>input]:shadow-none',\n          '[&>pdm-button>button]:rounded-l-none',\n          '[&>pdm-button>button]:shadow-none'\n        ].join(' ')\n      : '';\n\n    const groupVerticalClasses = isGroup && isVertical && !this.separated\n      ? [\n          '[&>*:not(:first-child)]:-mt-px',\n          '[&>pdm-button]:flex',\n          '[&>pdm-button>button]:h-9',\n          '[&>pdm-button>button]:!rounded-none',\n          '[&>pdm-button:first-child>button]:!rounded-t-md',\n          '[&>pdm-button:last-child>button]:!rounded-b-md',\n          '[&>pdm-input>div>input]:!rounded-none',\n          '[&>pdm-input:first-child>div>input]:!rounded-t-md',\n          '[&>pdm-input:last-child>div>input]:!rounded-b-md',\n          '[&>pdm-input-group>div]:!rounded-none',\n          '[&>pdm-input-group:first-child>div]:!rounded-t-md',\n          '[&>pdm-input-group:last-child>div]:!rounded-b-md',\n          '[&>pdm-input>div>input]:bg-background',\n          '[&>pdm-input>div>input]:shadow-none',\n          '[&>pdm-button>button]:shadow-none'\n        ].join(' ')\n      : '';\n\n    return [\n      'inline-flex w-fit',\n      isVertical ? 'flex-col items-stretch' : 'items-center',\n      this.variant === 'default' || this.separated ? 'gap-2' : 'gap-0',\n      isGroup ? '*:focus-visible:relative *:focus-visible:z-10' : '',\n      attachedClasses,\n      groupHorizontalClasses,\n      groupVerticalClasses,\n      isSeparator\n        ? 'overflow-hidden rounded-md border border-border bg-secondary shadow-sm'\n        : '',\n      this.className\n    ];\n  }\n}\n","<div\n  role=\"group\"\n  [attr.aria-orientation]=\"variant === 'orientation' || orientation === 'vertical' || direction === 'vertical' ? 'vertical' : 'horizontal'\"\n  [ngClass]=\"rootClasses\"\n>\n  <ng-content></ng-content>\n</div>\n"]}
@@ -2,24 +2,45 @@ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from
2
2
  import * as i0 from "@angular/core";
3
3
  import * as i1 from "@angular/common";
4
4
  export class PdmSwitchComponent {
5
- constructor() {
5
+ constructor(cdr) {
6
+ this.cdr = cdr;
6
7
  this.id = '';
7
8
  this.checked = false;
8
9
  this.disabled = false;
9
10
  this.label = '';
10
11
  this.className = '';
12
+ this.size = 'default';
11
13
  this.checkedChange = new EventEmitter();
12
14
  }
13
- onToggle(event) {
14
- this.checkedChange.emit(event.target.checked);
15
+ get rootClasses() {
16
+ return [
17
+ 'peer relative inline-flex shrink-0 items-center rounded-full border border-transparent outline-none transition-all focus-visible:border-ring focus-visible:ring-3 focus-visible:ring-ring/50 disabled:cursor-not-allowed disabled:opacity-50',
18
+ this.size === 'sm' ? 'h-[14px] w-[24px]' : 'h-[18.4px] w-[32px]',
19
+ this.checked ? 'bg-primary' : 'bg-input dark:bg-input/80'
20
+ ];
21
+ }
22
+ get thumbClasses() {
23
+ return [
24
+ 'pointer-events-none block rounded-full bg-background ring-0 transition-transform',
25
+ this.size === 'sm' ? 'size-3' : 'size-4',
26
+ this.checked ? 'translate-x-[calc(100%-2px)]' : 'translate-x-0'
27
+ ];
28
+ }
29
+ onToggle() {
30
+ if (this.disabled)
31
+ return;
32
+ const next = !this.checked;
33
+ this.checked = next;
34
+ this.checkedChange.emit(next);
35
+ this.cdr.markForCheck();
15
36
  }
16
37
  }
17
- PdmSwitchComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: PdmSwitchComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
18
- PdmSwitchComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: PdmSwitchComponent, selector: "pdm-switch", inputs: { id: "id", checked: "checked", disabled: "disabled", label: "label", className: "className" }, outputs: { checkedChange: "checkedChange" }, ngImport: i0, template: "<label [attr.for]=\"id\" [ngClass]=\"['inline-flex items-center gap-2', className]\">\n <input\n [id]=\"id\"\n type=\"checkbox\"\n class=\"peer sr-only\"\n [checked]=\"checked\"\n [disabled]=\"disabled\"\n (change)=\"onToggle($event)\"\n />\n <span class=\"relative inline-flex h-6 w-11 items-center rounded-full border border-transparent bg-muted transition-colors peer-focus-visible:ring-2 peer-focus-visible:ring-ring peer-focus-visible:ring-offset-2 peer-focus-visible:ring-offset-background peer-disabled:opacity-50 peer-checked:bg-primary\">\n <span class=\"h-5 w-5 translate-x-0.5 rounded-full bg-background shadow-sm transition-transform peer-checked:translate-x-5\"></span>\n </span>\n <span *ngIf=\"label\" class=\"text-sm text-foreground\">{{ label }}</span>\n</label>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
38
+ PdmSwitchComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: PdmSwitchComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
39
+ PdmSwitchComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: PdmSwitchComponent, selector: "pdm-switch", inputs: { id: "id", checked: "checked", disabled: "disabled", label: "label", className: "className", size: "size" }, outputs: { checkedChange: "checkedChange" }, ngImport: i0, template: "<div [ngClass]=\"['flex items-center space-x-2', className]\">\n <button\n type=\"button\"\n role=\"switch\"\n [attr.aria-checked]=\"checked\"\n [attr.aria-disabled]=\"disabled\"\n [attr.data-state]=\"checked ? 'checked' : 'unchecked'\"\n [attr.data-disabled]=\"disabled ? 'true' : 'false'\"\n [attr.data-size]=\"size\"\n [attr.data-slot]=\"'switch'\"\n [attr.value]=\"checked ? 'on' : 'off'\"\n [id]=\"id\"\n [disabled]=\"disabled\"\n [ngClass]=\"rootClasses\"\n (click)=\"onToggle()\"\n >\n <span\n [attr.data-state]=\"checked ? 'checked' : 'unchecked'\"\n [attr.data-slot]=\"'switch-thumb'\"\n [ngClass]=\"thumbClasses\"\n ></span>\n </button>\n <label\n *ngIf=\"label\"\n [attr.for]=\"id\"\n [attr.data-slot]=\"'label'\"\n class=\"flex cursor-pointer items-center gap-2 text-sm leading-none font-medium select-none peer-disabled:cursor-not-allowed peer-disabled:opacity-50\"\n (click)=\"onToggle()\"\n >\n {{ label }}\n </label>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
19
40
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: PdmSwitchComponent, decorators: [{
20
41
  type: Component,
21
- args: [{ selector: 'pdm-switch', changeDetection: ChangeDetectionStrategy.OnPush, template: "<label [attr.for]=\"id\" [ngClass]=\"['inline-flex items-center gap-2', className]\">\n <input\n [id]=\"id\"\n type=\"checkbox\"\n class=\"peer sr-only\"\n [checked]=\"checked\"\n [disabled]=\"disabled\"\n (change)=\"onToggle($event)\"\n />\n <span class=\"relative inline-flex h-6 w-11 items-center rounded-full border border-transparent bg-muted transition-colors peer-focus-visible:ring-2 peer-focus-visible:ring-ring peer-focus-visible:ring-offset-2 peer-focus-visible:ring-offset-background peer-disabled:opacity-50 peer-checked:bg-primary\">\n <span class=\"h-5 w-5 translate-x-0.5 rounded-full bg-background shadow-sm transition-transform peer-checked:translate-x-5\"></span>\n </span>\n <span *ngIf=\"label\" class=\"text-sm text-foreground\">{{ label }}</span>\n</label>\n" }]
22
- }], propDecorators: { id: [{
42
+ args: [{ selector: 'pdm-switch', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div [ngClass]=\"['flex items-center space-x-2', className]\">\n <button\n type=\"button\"\n role=\"switch\"\n [attr.aria-checked]=\"checked\"\n [attr.aria-disabled]=\"disabled\"\n [attr.data-state]=\"checked ? 'checked' : 'unchecked'\"\n [attr.data-disabled]=\"disabled ? 'true' : 'false'\"\n [attr.data-size]=\"size\"\n [attr.data-slot]=\"'switch'\"\n [attr.value]=\"checked ? 'on' : 'off'\"\n [id]=\"id\"\n [disabled]=\"disabled\"\n [ngClass]=\"rootClasses\"\n (click)=\"onToggle()\"\n >\n <span\n [attr.data-state]=\"checked ? 'checked' : 'unchecked'\"\n [attr.data-slot]=\"'switch-thumb'\"\n [ngClass]=\"thumbClasses\"\n ></span>\n </button>\n <label\n *ngIf=\"label\"\n [attr.for]=\"id\"\n [attr.data-slot]=\"'label'\"\n class=\"flex cursor-pointer items-center gap-2 text-sm leading-none font-medium select-none peer-disabled:cursor-not-allowed peer-disabled:opacity-50\"\n (click)=\"onToggle()\"\n >\n {{ label }}\n </label>\n</div>\n" }]
43
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { id: [{
23
44
  type: Input
24
45
  }], checked: [{
25
46
  type: Input
@@ -29,7 +50,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
29
50
  type: Input
30
51
  }], className: [{
31
52
  type: Input
53
+ }], size: [{
54
+ type: Input
32
55
  }], checkedChange: [{
33
56
  type: Output
34
57
  }] } });
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3dpdGNoLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9zd2l0Y2gvc3dpdGNoLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9zd2l0Y2gvc3dpdGNoLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQU9oRyxNQUFNLE9BQU8sa0JBQWtCO0lBTC9CO1FBTVcsT0FBRSxHQUFHLEVBQUUsQ0FBQztRQUNSLFlBQU8sR0FBRyxLQUFLLENBQUM7UUFDaEIsYUFBUSxHQUFHLEtBQUssQ0FBQztRQUNqQixVQUFLLEdBQUcsRUFBRSxDQUFDO1FBQ1gsY0FBUyxHQUFHLEVBQUUsQ0FBQztRQUVkLGtCQUFhLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztLQUt2RDtJQUhDLFFBQVEsQ0FBQyxLQUFZO1FBQ25CLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFFLEtBQUssQ0FBQyxNQUEyQixDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ3RFLENBQUM7OytHQVhVLGtCQUFrQjttR0FBbEIsa0JBQWtCLHVNQ1AvQix5eUJBY0E7MkZEUGEsa0JBQWtCO2tCQUw5QixTQUFTOytCQUNFLFlBQVksbUJBRUwsdUJBQXVCLENBQUMsTUFBTTs4QkFHdEMsRUFBRTtzQkFBVixLQUFLO2dCQUNHLE9BQU87c0JBQWYsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUVJLGFBQWE7c0JBQXRCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncGRtLXN3aXRjaCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9zd2l0Y2guY29tcG9uZW50Lmh0bWwnLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBQZG1Td2l0Y2hDb21wb25lbnQge1xuICBASW5wdXQoKSBpZCA9ICcnO1xuICBASW5wdXQoKSBjaGVja2VkID0gZmFsc2U7XG4gIEBJbnB1dCgpIGRpc2FibGVkID0gZmFsc2U7XG4gIEBJbnB1dCgpIGxhYmVsID0gJyc7XG4gIEBJbnB1dCgpIGNsYXNzTmFtZSA9ICcnO1xuXG4gIEBPdXRwdXQoKSBjaGVja2VkQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjxib29sZWFuPigpO1xuXG4gIG9uVG9nZ2xlKGV2ZW50OiBFdmVudCk6IHZvaWQge1xuICAgIHRoaXMuY2hlY2tlZENoYW5nZS5lbWl0KChldmVudC50YXJnZXQgYXMgSFRNTElucHV0RWxlbWVudCkuY2hlY2tlZCk7XG4gIH1cbn1cbiIsIjxsYWJlbCBbYXR0ci5mb3JdPVwiaWRcIiBbbmdDbGFzc109XCJbJ2lubGluZS1mbGV4IGl0ZW1zLWNlbnRlciBnYXAtMicsIGNsYXNzTmFtZV1cIj5cbiAgPGlucHV0XG4gICAgW2lkXT1cImlkXCJcbiAgICB0eXBlPVwiY2hlY2tib3hcIlxuICAgIGNsYXNzPVwicGVlciBzci1vbmx5XCJcbiAgICBbY2hlY2tlZF09XCJjaGVja2VkXCJcbiAgICBbZGlzYWJsZWRdPVwiZGlzYWJsZWRcIlxuICAgIChjaGFuZ2UpPVwib25Ub2dnbGUoJGV2ZW50KVwiXG4gIC8+XG4gIDxzcGFuIGNsYXNzPVwicmVsYXRpdmUgaW5saW5lLWZsZXggaC02IHctMTEgaXRlbXMtY2VudGVyIHJvdW5kZWQtZnVsbCBib3JkZXIgYm9yZGVyLXRyYW5zcGFyZW50IGJnLW11dGVkIHRyYW5zaXRpb24tY29sb3JzIHBlZXItZm9jdXMtdmlzaWJsZTpyaW5nLTIgcGVlci1mb2N1cy12aXNpYmxlOnJpbmctcmluZyBwZWVyLWZvY3VzLXZpc2libGU6cmluZy1vZmZzZXQtMiBwZWVyLWZvY3VzLXZpc2libGU6cmluZy1vZmZzZXQtYmFja2dyb3VuZCBwZWVyLWRpc2FibGVkOm9wYWNpdHktNTAgcGVlci1jaGVja2VkOmJnLXByaW1hcnlcIj5cbiAgICA8c3BhbiBjbGFzcz1cImgtNSB3LTUgdHJhbnNsYXRlLXgtMC41IHJvdW5kZWQtZnVsbCBiZy1iYWNrZ3JvdW5kIHNoYWRvdy1zbSB0cmFuc2l0aW9uLXRyYW5zZm9ybSBwZWVyLWNoZWNrZWQ6dHJhbnNsYXRlLXgtNVwiPjwvc3Bhbj5cbiAgPC9zcGFuPlxuICA8c3BhbiAqbmdJZj1cImxhYmVsXCIgY2xhc3M9XCJ0ZXh0LXNtIHRleHQtZm9yZWdyb3VuZFwiPnt7IGxhYmVsIH19PC9zcGFuPlxuPC9sYWJlbD5cbiJdfQ==
58
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3dpdGNoLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9zd2l0Y2gvc3dpdGNoLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9zd2l0Y2gvc3dpdGNoLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBcUIsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFTbkgsTUFBTSxPQUFPLGtCQUFrQjtJQUM3QixZQUE2QixHQUFzQjtRQUF0QixRQUFHLEdBQUgsR0FBRyxDQUFtQjtRQUUxQyxPQUFFLEdBQUcsRUFBRSxDQUFDO1FBQ1IsWUFBTyxHQUFHLEtBQUssQ0FBQztRQUNoQixhQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ2pCLFVBQUssR0FBRyxFQUFFLENBQUM7UUFDWCxjQUFTLEdBQUcsRUFBRSxDQUFDO1FBQ2YsU0FBSSxHQUFrQixTQUFTLENBQUM7UUFFL0Isa0JBQWEsR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFDO0lBVEEsQ0FBQztJQVd2RCxJQUFJLFdBQVc7UUFDYixPQUFPO1lBQ0wsOE9BQThPO1lBQzlPLElBQUksQ0FBQyxJQUFJLEtBQUssSUFBSSxDQUFDLENBQUMsQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDLENBQUMscUJBQXFCO1lBQ2hFLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsMkJBQTJCO1NBQzFELENBQUM7SUFDSixDQUFDO0lBRUQsSUFBSSxZQUFZO1FBQ2QsT0FBTztZQUNMLGtGQUFrRjtZQUNsRixJQUFJLENBQUMsSUFBSSxLQUFLLElBQUksQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxRQUFRO1lBQ3hDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLDhCQUE4QixDQUFDLENBQUMsQ0FBQyxlQUFlO1NBQ2hFLENBQUM7SUFDSixDQUFDO0lBRUQsUUFBUTtRQUNOLElBQUksSUFBSSxDQUFDLFFBQVE7WUFBRSxPQUFPO1FBQzFCLE1BQU0sSUFBSSxHQUFHLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQztRQUMzQixJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQztRQUNwQixJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUM5QixJQUFJLENBQUMsR0FBRyxDQUFDLFlBQVksRUFBRSxDQUFDO0lBQzFCLENBQUM7OytHQWxDVSxrQkFBa0I7bUdBQWxCLGtCQUFrQixxTkNUL0Isb2dDQWdDQTsyRkR2QmEsa0JBQWtCO2tCQUw5QixTQUFTOytCQUNFLFlBQVksbUJBRUwsdUJBQXVCLENBQUMsTUFBTTt3R0FLdEMsRUFBRTtzQkFBVixLQUFLO2dCQUNHLE9BQU87c0JBQWYsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSztnQkFFSSxhQUFhO3NCQUF0QixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENoYW5nZURldGVjdG9yUmVmLCBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgdHlwZSBQZG1Td2l0Y2hTaXplID0gJ2RlZmF1bHQnIHwgJ3NtJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncGRtLXN3aXRjaCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9zd2l0Y2guY29tcG9uZW50Lmh0bWwnLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBQZG1Td2l0Y2hDb21wb25lbnQge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IGNkcjogQ2hhbmdlRGV0ZWN0b3JSZWYpIHt9XG5cbiAgQElucHV0KCkgaWQgPSAnJztcbiAgQElucHV0KCkgY2hlY2tlZCA9IGZhbHNlO1xuICBASW5wdXQoKSBkaXNhYmxlZCA9IGZhbHNlO1xuICBASW5wdXQoKSBsYWJlbCA9ICcnO1xuICBASW5wdXQoKSBjbGFzc05hbWUgPSAnJztcbiAgQElucHV0KCkgc2l6ZTogUGRtU3dpdGNoU2l6ZSA9ICdkZWZhdWx0JztcblxuICBAT3V0cHV0KCkgY2hlY2tlZENoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8Ym9vbGVhbj4oKTtcblxuICBnZXQgcm9vdENsYXNzZXMoKTogc3RyaW5nW10ge1xuICAgIHJldHVybiBbXG4gICAgICAncGVlciByZWxhdGl2ZSBpbmxpbmUtZmxleCBzaHJpbmstMCBpdGVtcy1jZW50ZXIgcm91bmRlZC1mdWxsIGJvcmRlciBib3JkZXItdHJhbnNwYXJlbnQgb3V0bGluZS1ub25lIHRyYW5zaXRpb24tYWxsIGZvY3VzLXZpc2libGU6Ym9yZGVyLXJpbmcgZm9jdXMtdmlzaWJsZTpyaW5nLTMgZm9jdXMtdmlzaWJsZTpyaW5nLXJpbmcvNTAgZGlzYWJsZWQ6Y3Vyc29yLW5vdC1hbGxvd2VkIGRpc2FibGVkOm9wYWNpdHktNTAnLFxuICAgICAgdGhpcy5zaXplID09PSAnc20nID8gJ2gtWzE0cHhdIHctWzI0cHhdJyA6ICdoLVsxOC40cHhdIHctWzMycHhdJyxcbiAgICAgIHRoaXMuY2hlY2tlZCA/ICdiZy1wcmltYXJ5JyA6ICdiZy1pbnB1dCBkYXJrOmJnLWlucHV0LzgwJ1xuICAgIF07XG4gIH1cblxuICBnZXQgdGh1bWJDbGFzc2VzKCk6IHN0cmluZ1tdIHtcbiAgICByZXR1cm4gW1xuICAgICAgJ3BvaW50ZXItZXZlbnRzLW5vbmUgYmxvY2sgcm91bmRlZC1mdWxsIGJnLWJhY2tncm91bmQgcmluZy0wIHRyYW5zaXRpb24tdHJhbnNmb3JtJyxcbiAgICAgIHRoaXMuc2l6ZSA9PT0gJ3NtJyA/ICdzaXplLTMnIDogJ3NpemUtNCcsXG4gICAgICB0aGlzLmNoZWNrZWQgPyAndHJhbnNsYXRlLXgtW2NhbGMoMTAwJS0ycHgpXScgOiAndHJhbnNsYXRlLXgtMCdcbiAgICBdO1xuICB9XG5cbiAgb25Ub2dnbGUoKTogdm9pZCB7XG4gICAgaWYgKHRoaXMuZGlzYWJsZWQpIHJldHVybjtcbiAgICBjb25zdCBuZXh0ID0gIXRoaXMuY2hlY2tlZDtcbiAgICB0aGlzLmNoZWNrZWQgPSBuZXh0O1xuICAgIHRoaXMuY2hlY2tlZENoYW5nZS5lbWl0KG5leHQpO1xuICAgIHRoaXMuY2RyLm1hcmtGb3JDaGVjaygpO1xuICB9XG59XG4iLCI8ZGl2IFtuZ0NsYXNzXT1cIlsnZmxleCBpdGVtcy1jZW50ZXIgc3BhY2UteC0yJywgY2xhc3NOYW1lXVwiPlxuICA8YnV0dG9uXG4gICAgdHlwZT1cImJ1dHRvblwiXG4gICAgcm9sZT1cInN3aXRjaFwiXG4gICAgW2F0dHIuYXJpYS1jaGVja2VkXT1cImNoZWNrZWRcIlxuICAgIFthdHRyLmFyaWEtZGlzYWJsZWRdPVwiZGlzYWJsZWRcIlxuICAgIFthdHRyLmRhdGEtc3RhdGVdPVwiY2hlY2tlZCA/ICdjaGVja2VkJyA6ICd1bmNoZWNrZWQnXCJcbiAgICBbYXR0ci5kYXRhLWRpc2FibGVkXT1cImRpc2FibGVkID8gJ3RydWUnIDogJ2ZhbHNlJ1wiXG4gICAgW2F0dHIuZGF0YS1zaXplXT1cInNpemVcIlxuICAgIFthdHRyLmRhdGEtc2xvdF09XCInc3dpdGNoJ1wiXG4gICAgW2F0dHIudmFsdWVdPVwiY2hlY2tlZCA/ICdvbicgOiAnb2ZmJ1wiXG4gICAgW2lkXT1cImlkXCJcbiAgICBbZGlzYWJsZWRdPVwiZGlzYWJsZWRcIlxuICAgIFtuZ0NsYXNzXT1cInJvb3RDbGFzc2VzXCJcbiAgICAoY2xpY2spPVwib25Ub2dnbGUoKVwiXG4gID5cbiAgICA8c3BhblxuICAgICAgW2F0dHIuZGF0YS1zdGF0ZV09XCJjaGVja2VkID8gJ2NoZWNrZWQnIDogJ3VuY2hlY2tlZCdcIlxuICAgICAgW2F0dHIuZGF0YS1zbG90XT1cIidzd2l0Y2gtdGh1bWInXCJcbiAgICAgIFtuZ0NsYXNzXT1cInRodW1iQ2xhc3Nlc1wiXG4gICAgPjwvc3Bhbj5cbiAgPC9idXR0b24+XG4gIDxsYWJlbFxuICAgICpuZ0lmPVwibGFiZWxcIlxuICAgIFthdHRyLmZvcl09XCJpZFwiXG4gICAgW2F0dHIuZGF0YS1zbG90XT1cIidsYWJlbCdcIlxuICAgIGNsYXNzPVwiZmxleCBjdXJzb3ItcG9pbnRlciBpdGVtcy1jZW50ZXIgZ2FwLTIgdGV4dC1zbSBsZWFkaW5nLW5vbmUgZm9udC1tZWRpdW0gc2VsZWN0LW5vbmUgcGVlci1kaXNhYmxlZDpjdXJzb3Itbm90LWFsbG93ZWQgcGVlci1kaXNhYmxlZDpvcGFjaXR5LTUwXCJcbiAgICAoY2xpY2spPVwib25Ub2dnbGUoKVwiXG4gID5cbiAgICB7eyBsYWJlbCB9fVxuICA8L2xhYmVsPlxuPC9kaXY+XG4iXX0=
@@ -291,6 +291,8 @@ class PdmButtonGroupComponent {
291
291
  const groupHorizontalClasses = isGroup && !isVertical && !this.separated
292
292
  ? [
293
293
  '[&>*:not(:first-child)]:-ml-px',
294
+ '[&>pdm-button]:flex',
295
+ '[&>pdm-button>button]:h-9',
294
296
  '[&>pdm-input]:flex-1',
295
297
  '[&>pdm-input>div]:w-full',
296
298
  '[&>pdm-button>button]:!rounded-none',
@@ -311,6 +313,8 @@ class PdmButtonGroupComponent {
311
313
  const groupVerticalClasses = isGroup && isVertical && !this.separated
312
314
  ? [
313
315
  '[&>*:not(:first-child)]:-mt-px',
316
+ '[&>pdm-button]:flex',
317
+ '[&>pdm-button>button]:h-9',
314
318
  '[&>pdm-button>button]:!rounded-none',
315
319
  '[&>pdm-button:first-child>button]:!rounded-t-md',
316
320
  '[&>pdm-button:last-child>button]:!rounded-b-md',
@@ -368,19 +372,19 @@ class PdmButtonComponent {
368
372
  this.className = '';
369
373
  this.pressed = new EventEmitter();
370
374
  this.toneClassMap = {
371
- default: { default: 'border-transparent bg-primary text-primary-foreground', hover: 'border-transparent bg-primary text-primary-foreground opacity-90' },
372
- primary: { default: 'border-transparent bg-primary text-primary-foreground', hover: 'border-transparent bg-primary text-primary-foreground opacity-90' },
373
- destructive: { default: 'border-transparent bg-destructive text-destructive-foreground', hover: 'border-transparent bg-destructive text-destructive-foreground opacity-90' },
375
+ default: { default: 'border-primary bg-primary text-primary-foreground', hover: 'border-primary bg-primary text-primary-foreground opacity-90' },
376
+ primary: { default: 'border-primary bg-primary text-primary-foreground', hover: 'border-primary bg-primary text-primary-foreground opacity-90' },
377
+ destructive: { default: 'border-border bg-destructive text-destructive-foreground', hover: 'border-border bg-destructive text-destructive-foreground opacity-90' },
374
378
  outline: { default: 'border-border bg-background text-foreground', hover: 'border-border bg-muted text-foreground' },
375
- subtle: { default: 'border-transparent bg-secondary text-secondary-foreground', hover: 'border-transparent bg-accent text-accent-foreground' },
376
- secondary: { default: 'border-transparent bg-secondary text-secondary-foreground', hover: 'border-transparent bg-accent text-accent-foreground' },
377
- ghost: { default: 'border-transparent bg-transparent text-foreground', hover: 'border-transparent bg-accent text-accent-foreground' },
378
- link: { default: 'border-transparent bg-transparent text-primary', hover: 'border-transparent bg-transparent text-primary underline underline-offset-4' },
379
- 'with-icon': { default: 'border-transparent bg-primary text-primary-foreground', hover: 'border-transparent bg-primary text-primary-foreground opacity-90' },
379
+ subtle: { default: 'border-secondary bg-secondary text-secondary-foreground', hover: 'border-accent bg-accent text-accent-foreground' },
380
+ secondary: { default: 'border-secondary bg-secondary text-secondary-foreground', hover: 'border-accent bg-accent text-accent-foreground' },
381
+ ghost: { default: 'border-border bg-transparent text-foreground', hover: 'border-border bg-accent text-accent-foreground' },
382
+ link: { default: 'border-border bg-transparent text-primary', hover: 'border-border bg-transparent text-primary underline underline-offset-4' },
383
+ 'with-icon': { default: 'border-primary bg-primary text-primary-foreground', hover: 'border-primary bg-primary text-primary-foreground opacity-90' },
380
384
  icon: { default: 'border-border bg-background text-foreground', hover: 'border-border bg-accent text-accent-foreground' },
381
385
  'icon-circle': { default: 'border-border bg-background text-foreground', hover: 'border-border bg-accent text-accent-foreground' },
382
386
  rounded: { default: 'border-border bg-background text-foreground', hover: 'border-border bg-accent text-accent-foreground' },
383
- loading: { default: 'border-transparent bg-primary text-primary-foreground opacity-70', hover: 'border-transparent bg-primary text-primary-foreground opacity-70' }
387
+ loading: { default: 'border-primary bg-primary text-primary-foreground opacity-70', hover: 'border-primary bg-primary text-primary-foreground opacity-70' }
384
388
  };
385
389
  }
386
390
  get isDisabled() {
@@ -2696,24 +2700,45 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
2696
2700
  }] } });
2697
2701
 
2698
2702
  class PdmSwitchComponent {
2699
- constructor() {
2703
+ constructor(cdr) {
2704
+ this.cdr = cdr;
2700
2705
  this.id = '';
2701
2706
  this.checked = false;
2702
2707
  this.disabled = false;
2703
2708
  this.label = '';
2704
2709
  this.className = '';
2710
+ this.size = 'default';
2705
2711
  this.checkedChange = new EventEmitter();
2706
2712
  }
2707
- onToggle(event) {
2708
- this.checkedChange.emit(event.target.checked);
2713
+ get rootClasses() {
2714
+ return [
2715
+ 'peer relative inline-flex shrink-0 items-center rounded-full border border-transparent outline-none transition-all focus-visible:border-ring focus-visible:ring-3 focus-visible:ring-ring/50 disabled:cursor-not-allowed disabled:opacity-50',
2716
+ this.size === 'sm' ? 'h-[14px] w-[24px]' : 'h-[18.4px] w-[32px]',
2717
+ this.checked ? 'bg-primary' : 'bg-input dark:bg-input/80'
2718
+ ];
2719
+ }
2720
+ get thumbClasses() {
2721
+ return [
2722
+ 'pointer-events-none block rounded-full bg-background ring-0 transition-transform',
2723
+ this.size === 'sm' ? 'size-3' : 'size-4',
2724
+ this.checked ? 'translate-x-[calc(100%-2px)]' : 'translate-x-0'
2725
+ ];
2726
+ }
2727
+ onToggle() {
2728
+ if (this.disabled)
2729
+ return;
2730
+ const next = !this.checked;
2731
+ this.checked = next;
2732
+ this.checkedChange.emit(next);
2733
+ this.cdr.markForCheck();
2709
2734
  }
2710
2735
  }
2711
- PdmSwitchComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: PdmSwitchComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
2712
- PdmSwitchComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: PdmSwitchComponent, selector: "pdm-switch", inputs: { id: "id", checked: "checked", disabled: "disabled", label: "label", className: "className" }, outputs: { checkedChange: "checkedChange" }, ngImport: i0, template: "<label [attr.for]=\"id\" [ngClass]=\"['inline-flex items-center gap-2', className]\">\n <input\n [id]=\"id\"\n type=\"checkbox\"\n class=\"peer sr-only\"\n [checked]=\"checked\"\n [disabled]=\"disabled\"\n (change)=\"onToggle($event)\"\n />\n <span class=\"relative inline-flex h-6 w-11 items-center rounded-full border border-transparent bg-muted transition-colors peer-focus-visible:ring-2 peer-focus-visible:ring-ring peer-focus-visible:ring-offset-2 peer-focus-visible:ring-offset-background peer-disabled:opacity-50 peer-checked:bg-primary\">\n <span class=\"h-5 w-5 translate-x-0.5 rounded-full bg-background shadow-sm transition-transform peer-checked:translate-x-5\"></span>\n </span>\n <span *ngIf=\"label\" class=\"text-sm text-foreground\">{{ label }}</span>\n</label>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
2736
+ PdmSwitchComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: PdmSwitchComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
2737
+ PdmSwitchComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: PdmSwitchComponent, selector: "pdm-switch", inputs: { id: "id", checked: "checked", disabled: "disabled", label: "label", className: "className", size: "size" }, outputs: { checkedChange: "checkedChange" }, ngImport: i0, template: "<div [ngClass]=\"['flex items-center space-x-2', className]\">\n <button\n type=\"button\"\n role=\"switch\"\n [attr.aria-checked]=\"checked\"\n [attr.aria-disabled]=\"disabled\"\n [attr.data-state]=\"checked ? 'checked' : 'unchecked'\"\n [attr.data-disabled]=\"disabled ? 'true' : 'false'\"\n [attr.data-size]=\"size\"\n [attr.data-slot]=\"'switch'\"\n [attr.value]=\"checked ? 'on' : 'off'\"\n [id]=\"id\"\n [disabled]=\"disabled\"\n [ngClass]=\"rootClasses\"\n (click)=\"onToggle()\"\n >\n <span\n [attr.data-state]=\"checked ? 'checked' : 'unchecked'\"\n [attr.data-slot]=\"'switch-thumb'\"\n [ngClass]=\"thumbClasses\"\n ></span>\n </button>\n <label\n *ngIf=\"label\"\n [attr.for]=\"id\"\n [attr.data-slot]=\"'label'\"\n class=\"flex cursor-pointer items-center gap-2 text-sm leading-none font-medium select-none peer-disabled:cursor-not-allowed peer-disabled:opacity-50\"\n (click)=\"onToggle()\"\n >\n {{ label }}\n </label>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
2713
2738
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: PdmSwitchComponent, decorators: [{
2714
2739
  type: Component,
2715
- args: [{ selector: 'pdm-switch', changeDetection: ChangeDetectionStrategy.OnPush, template: "<label [attr.for]=\"id\" [ngClass]=\"['inline-flex items-center gap-2', className]\">\n <input\n [id]=\"id\"\n type=\"checkbox\"\n class=\"peer sr-only\"\n [checked]=\"checked\"\n [disabled]=\"disabled\"\n (change)=\"onToggle($event)\"\n />\n <span class=\"relative inline-flex h-6 w-11 items-center rounded-full border border-transparent bg-muted transition-colors peer-focus-visible:ring-2 peer-focus-visible:ring-ring peer-focus-visible:ring-offset-2 peer-focus-visible:ring-offset-background peer-disabled:opacity-50 peer-checked:bg-primary\">\n <span class=\"h-5 w-5 translate-x-0.5 rounded-full bg-background shadow-sm transition-transform peer-checked:translate-x-5\"></span>\n </span>\n <span *ngIf=\"label\" class=\"text-sm text-foreground\">{{ label }}</span>\n</label>\n" }]
2716
- }], propDecorators: { id: [{
2740
+ args: [{ selector: 'pdm-switch', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div [ngClass]=\"['flex items-center space-x-2', className]\">\n <button\n type=\"button\"\n role=\"switch\"\n [attr.aria-checked]=\"checked\"\n [attr.aria-disabled]=\"disabled\"\n [attr.data-state]=\"checked ? 'checked' : 'unchecked'\"\n [attr.data-disabled]=\"disabled ? 'true' : 'false'\"\n [attr.data-size]=\"size\"\n [attr.data-slot]=\"'switch'\"\n [attr.value]=\"checked ? 'on' : 'off'\"\n [id]=\"id\"\n [disabled]=\"disabled\"\n [ngClass]=\"rootClasses\"\n (click)=\"onToggle()\"\n >\n <span\n [attr.data-state]=\"checked ? 'checked' : 'unchecked'\"\n [attr.data-slot]=\"'switch-thumb'\"\n [ngClass]=\"thumbClasses\"\n ></span>\n </button>\n <label\n *ngIf=\"label\"\n [attr.for]=\"id\"\n [attr.data-slot]=\"'label'\"\n class=\"flex cursor-pointer items-center gap-2 text-sm leading-none font-medium select-none peer-disabled:cursor-not-allowed peer-disabled:opacity-50\"\n (click)=\"onToggle()\"\n >\n {{ label }}\n </label>\n</div>\n" }]
2741
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { id: [{
2717
2742
  type: Input
2718
2743
  }], checked: [{
2719
2744
  type: Input
@@ -2723,6 +2748,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
2723
2748
  type: Input
2724
2749
  }], className: [{
2725
2750
  type: Input
2751
+ }], size: [{
2752
+ type: Input
2726
2753
  }], checkedChange: [{
2727
2754
  type: Output
2728
2755
  }] } });