pdm-ui-kit 0.1.29 → 0.1.31

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.
@@ -45,9 +45,17 @@ export class PdmButtonGroupComponent {
45
45
  '[&>pdm-select:first-child>select]:!rounded-l-md',
46
46
  '[&>pdm-select:last-child>select]:!rounded-r-md',
47
47
  '[&>pdm-select>select]:shadow-none',
48
+ '[&>pdm-select>div>button]:!rounded-none',
49
+ '[&>pdm-select:first-child>div>button]:!rounded-l-md',
50
+ '[&>pdm-select:last-child>div>button]:!rounded-r-md',
51
+ '[&>pdm-select:not(:first-child)>div>button]:!rounded-l-none',
52
+ '[&>pdm-select:not(:last-child)>div>button]:!rounded-r-none',
53
+ '[&>pdm-select:not(:first-child)>div>button]:!border-l-0',
54
+ '[&>pdm-select>div>button]:shadow-none',
48
55
  '[&>pdm-button>button]:!rounded-none',
49
56
  '[&>pdm-button:first-child>button]:!rounded-l-md',
50
57
  '[&>pdm-button:last-child>button]:!rounded-r-md',
58
+ '[&>pdm-button:not(:first-child)>button]:!border-l-0',
51
59
  '[&>pdm-input>div>input]:!rounded-none',
52
60
  '[&>pdm-input:first-child>div>input]:!rounded-l-md',
53
61
  '[&>pdm-input:last-child>div>input]:!rounded-r-md',
@@ -65,10 +73,12 @@ export class PdmButtonGroupComponent {
65
73
  '[&>pdm-tooltip>span>pdm-button>button]:!rounded-none',
66
74
  '[&>pdm-tooltip:first-child>span>pdm-button>button]:!rounded-l-md',
67
75
  '[&>pdm-tooltip:last-child>span>pdm-button>button]:!rounded-r-md',
76
+ '[&>pdm-tooltip:not(:first-child)>span>pdm-button>button]:!border-l-0',
68
77
  '[&>pdm-tooltip>span>pdm-button>button]:shadow-none',
69
78
  '[&>pdm-tooltip>span>button]:!rounded-none',
70
79
  '[&>pdm-tooltip:first-child>span>button]:!rounded-l-md',
71
80
  '[&>pdm-tooltip:last-child>span>button]:!rounded-r-md',
81
+ '[&>pdm-tooltip:not(:first-child)>span>button]:!border-l-0',
72
82
  '[&>pdm-tooltip>span>button]:shadow-none',
73
83
  '[&>pdm-tooltip>span>pdm-input>div>input]:!rounded-none',
74
84
  '[&>pdm-tooltip:first-child>span>pdm-input>div>input]:!rounded-l-md',
@@ -85,6 +95,13 @@ export class PdmButtonGroupComponent {
85
95
  '[&>pdm-tooltip:first-child>span>pdm-select>select]:!rounded-l-md',
86
96
  '[&>pdm-tooltip:last-child>span>pdm-select>select]:!rounded-r-md',
87
97
  '[&>pdm-tooltip>span>pdm-select>select]:shadow-none',
98
+ '[&>pdm-tooltip>span>pdm-select>div>button]:!rounded-none',
99
+ '[&>pdm-tooltip:first-child>span>pdm-select>div>button]:!rounded-l-md',
100
+ '[&>pdm-tooltip:last-child>span>pdm-select>div>button]:!rounded-r-md',
101
+ '[&>pdm-tooltip:not(:first-child)>span>pdm-select>div>button]:!rounded-l-none',
102
+ '[&>pdm-tooltip:not(:last-child)>span>pdm-select>div>button]:!rounded-r-none',
103
+ '[&>pdm-tooltip:not(:first-child)>span>pdm-select>div>button]:!border-l-0',
104
+ '[&>pdm-tooltip>span>pdm-select>div>button]:shadow-none',
88
105
  '[&>pdm-tooltip>span>select]:!rounded-none',
89
106
  '[&>pdm-tooltip:first-child>span>select]:!rounded-l-md',
90
107
  '[&>pdm-tooltip:last-child>span>select]:!rounded-r-md',
@@ -113,9 +130,17 @@ export class PdmButtonGroupComponent {
113
130
  '[&>pdm-select:first-child>select]:!rounded-t-md',
114
131
  '[&>pdm-select:last-child>select]:!rounded-b-md',
115
132
  '[&>pdm-select>select]:shadow-none',
133
+ '[&>pdm-select>div>button]:!rounded-none',
134
+ '[&>pdm-select:first-child>div>button]:!rounded-t-md',
135
+ '[&>pdm-select:last-child>div>button]:!rounded-b-md',
136
+ '[&>pdm-select:not(:first-child)>div>button]:!rounded-t-none',
137
+ '[&>pdm-select:not(:last-child)>div>button]:!rounded-b-none',
138
+ '[&>pdm-select:not(:first-child)>div>button]:!border-t-0',
139
+ '[&>pdm-select>div>button]:shadow-none',
116
140
  '[&>pdm-input>div>input]:bg-background',
117
141
  '[&>pdm-input>div>input]:shadow-none',
118
142
  '[&>pdm-button>button]:shadow-none',
143
+ '[&>pdm-button:not(:first-child)>button]:!border-t-0',
119
144
  '[&>pdm-tooltip>span>*]:rounded-none',
120
145
  '[&>pdm-tooltip:first-child>span>*]:rounded-t-md',
121
146
  '[&>pdm-tooltip:last-child>span>*]:rounded-b-md',
@@ -123,10 +148,12 @@ export class PdmButtonGroupComponent {
123
148
  '[&>pdm-tooltip>span>pdm-button>button]:!rounded-none',
124
149
  '[&>pdm-tooltip:first-child>span>pdm-button>button]:!rounded-t-md',
125
150
  '[&>pdm-tooltip:last-child>span>pdm-button>button]:!rounded-b-md',
151
+ '[&>pdm-tooltip:not(:first-child)>span>pdm-button>button]:!border-t-0',
126
152
  '[&>pdm-tooltip>span>pdm-button>button]:shadow-none',
127
153
  '[&>pdm-tooltip>span>button]:!rounded-none',
128
154
  '[&>pdm-tooltip:first-child>span>button]:!rounded-t-md',
129
155
  '[&>pdm-tooltip:last-child>span>button]:!rounded-b-md',
156
+ '[&>pdm-tooltip:not(:first-child)>span>button]:!border-t-0',
130
157
  '[&>pdm-tooltip>span>button]:shadow-none',
131
158
  '[&>pdm-tooltip>span>pdm-input>div>input]:!rounded-none',
132
159
  '[&>pdm-tooltip:first-child>span>pdm-input>div>input]:!rounded-t-md',
@@ -143,6 +170,13 @@ export class PdmButtonGroupComponent {
143
170
  '[&>pdm-tooltip:first-child>span>pdm-select>select]:!rounded-t-md',
144
171
  '[&>pdm-tooltip:last-child>span>pdm-select>select]:!rounded-b-md',
145
172
  '[&>pdm-tooltip>span>pdm-select>select]:shadow-none',
173
+ '[&>pdm-tooltip>span>pdm-select>div>button]:!rounded-none',
174
+ '[&>pdm-tooltip:first-child>span>pdm-select>div>button]:!rounded-t-md',
175
+ '[&>pdm-tooltip:last-child>span>pdm-select>div>button]:!rounded-b-md',
176
+ '[&>pdm-tooltip:not(:first-child)>span>pdm-select>div>button]:!rounded-t-none',
177
+ '[&>pdm-tooltip:not(:last-child)>span>pdm-select>div>button]:!rounded-b-none',
178
+ '[&>pdm-tooltip:not(:first-child)>span>pdm-select>div>button]:!border-t-0',
179
+ '[&>pdm-tooltip>span>pdm-select>div>button]:shadow-none',
146
180
  '[&>pdm-tooltip>span>select]:!rounded-none',
147
181
  '[&>pdm-tooltip:first-child>span>select]:!rounded-t-md',
148
182
  '[&>pdm-tooltip:last-child>span>select]:!rounded-b-md',
@@ -180,4 +214,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
180
214
  }], className: [{
181
215
  type: Input
182
216
  }] } });
183
- //# 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          '[&>*]:rounded-none',\n          '[&>*:first-child]:rounded-l-md',\n          '[&>*:last-child]:rounded-r-md',\n          '[&>*:not(:first-child)]:-ml-px',\n          '[&>*:not(:first-child)]:border-l-0',\n          '[&>pdm-button]:flex',\n          '[&>pdm-button>button]:h-9',\n          '[&>pdm-input]:flex-1',\n          '[&>pdm-input>div]:w-full',\n          '[&>pdm-select>select]:!rounded-none',\n          '[&>pdm-select:first-child>select]:!rounded-l-md',\n          '[&>pdm-select:last-child>select]:!rounded-r-md',\n          '[&>pdm-select>select]:shadow-none',\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          '[&>pdm-tooltip>span>*]:rounded-none',\n          '[&>pdm-tooltip:first-child>span>*]:rounded-l-md',\n          '[&>pdm-tooltip:last-child>span>*]:rounded-r-md',\n          '[&>pdm-tooltip:not(:first-child)>span>*]:border-l-0',\n          '[&>pdm-tooltip>span>pdm-button>button]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>pdm-button>button]:!rounded-l-md',\n          '[&>pdm-tooltip:last-child>span>pdm-button>button]:!rounded-r-md',\n          '[&>pdm-tooltip>span>pdm-button>button]:shadow-none',\n          '[&>pdm-tooltip>span>button]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>button]:!rounded-l-md',\n          '[&>pdm-tooltip:last-child>span>button]:!rounded-r-md',\n          '[&>pdm-tooltip>span>button]:shadow-none',\n          '[&>pdm-tooltip>span>pdm-input>div>input]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>pdm-input>div>input]:!rounded-l-md',\n          '[&>pdm-tooltip:last-child>span>pdm-input>div>input]:!rounded-r-md',\n          '[&>pdm-tooltip>span>pdm-input>div>input]:shadow-none',\n          '[&>pdm-tooltip>span>input]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>input]:!rounded-l-md',\n          '[&>pdm-tooltip:last-child>span>input]:!rounded-r-md',\n          '[&>pdm-tooltip>span>input]:shadow-none',\n          '[&>pdm-tooltip>span>pdm-input-group>div]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>pdm-input-group>div]:!rounded-l-md',\n          '[&>pdm-tooltip:last-child>span>pdm-input-group>div]:!rounded-r-md',\n          '[&>pdm-tooltip>span>pdm-select>select]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>pdm-select>select]:!rounded-l-md',\n          '[&>pdm-tooltip:last-child>span>pdm-select>select]:!rounded-r-md',\n          '[&>pdm-tooltip>span>pdm-select>select]:shadow-none',\n          '[&>pdm-tooltip>span>select]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>select]:!rounded-l-md',\n          '[&>pdm-tooltip:last-child>span>select]:!rounded-r-md',\n          '[&>pdm-tooltip>span>select]:shadow-none'\n        ].join(' ')\n      : '';\n\n    const groupVerticalClasses = isGroup && isVertical && !this.separated\n      ? [\n          '[&>*]:rounded-none',\n          '[&>*:first-child]:rounded-t-md',\n          '[&>*:last-child]:rounded-b-md',\n          '[&>*:not(:first-child)]:-mt-px',\n          '[&>*:not(:first-child)]:border-t-0',\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-select>select]:!rounded-none',\n          '[&>pdm-select:first-child>select]:!rounded-t-md',\n          '[&>pdm-select:last-child>select]:!rounded-b-md',\n          '[&>pdm-select>select]:shadow-none',\n          '[&>pdm-input>div>input]:bg-background',\n          '[&>pdm-input>div>input]:shadow-none',\n          '[&>pdm-button>button]:shadow-none',\n          '[&>pdm-tooltip>span>*]:rounded-none',\n          '[&>pdm-tooltip:first-child>span>*]:rounded-t-md',\n          '[&>pdm-tooltip:last-child>span>*]:rounded-b-md',\n          '[&>pdm-tooltip:not(:first-child)>span>*]:border-t-0',\n          '[&>pdm-tooltip>span>pdm-button>button]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>pdm-button>button]:!rounded-t-md',\n          '[&>pdm-tooltip:last-child>span>pdm-button>button]:!rounded-b-md',\n          '[&>pdm-tooltip>span>pdm-button>button]:shadow-none',\n          '[&>pdm-tooltip>span>button]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>button]:!rounded-t-md',\n          '[&>pdm-tooltip:last-child>span>button]:!rounded-b-md',\n          '[&>pdm-tooltip>span>button]:shadow-none',\n          '[&>pdm-tooltip>span>pdm-input>div>input]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>pdm-input>div>input]:!rounded-t-md',\n          '[&>pdm-tooltip:last-child>span>pdm-input>div>input]:!rounded-b-md',\n          '[&>pdm-tooltip>span>pdm-input>div>input]:shadow-none',\n          '[&>pdm-tooltip>span>input]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>input]:!rounded-t-md',\n          '[&>pdm-tooltip:last-child>span>input]:!rounded-b-md',\n          '[&>pdm-tooltip>span>input]:shadow-none',\n          '[&>pdm-tooltip>span>pdm-input-group>div]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>pdm-input-group>div]:!rounded-t-md',\n          '[&>pdm-tooltip:last-child>span>pdm-input-group>div]:!rounded-b-md',\n          '[&>pdm-tooltip>span>pdm-select>select]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>pdm-select>select]:!rounded-t-md',\n          '[&>pdm-tooltip:last-child>span>pdm-select>select]:!rounded-b-md',\n          '[&>pdm-tooltip>span>pdm-select>select]:shadow-none',\n          '[&>pdm-tooltip>span>select]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>select]:!rounded-t-md',\n          '[&>pdm-tooltip:last-child>span>select]:!rounded-b-md',\n          '[&>pdm-tooltip>span>select]: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"]}
217
+ //# 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          '[&>*]:rounded-none',\n          '[&>*:first-child]:rounded-l-md',\n          '[&>*:last-child]:rounded-r-md',\n          '[&>*:not(:first-child)]:-ml-px',\n          '[&>*:not(:first-child)]:border-l-0',\n          '[&>pdm-button]:flex',\n          '[&>pdm-button>button]:h-9',\n          '[&>pdm-input]:flex-1',\n          '[&>pdm-input>div]:w-full',\n          '[&>pdm-select>select]:!rounded-none',\n          '[&>pdm-select:first-child>select]:!rounded-l-md',\n          '[&>pdm-select:last-child>select]:!rounded-r-md',\n          '[&>pdm-select>select]:shadow-none',\n          '[&>pdm-select>div>button]:!rounded-none',\n          '[&>pdm-select:first-child>div>button]:!rounded-l-md',\n          '[&>pdm-select:last-child>div>button]:!rounded-r-md',\n          '[&>pdm-select:not(:first-child)>div>button]:!rounded-l-none',\n          '[&>pdm-select:not(:last-child)>div>button]:!rounded-r-none',\n          '[&>pdm-select:not(:first-child)>div>button]:!border-l-0',\n          '[&>pdm-select>div>button]:shadow-none',\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-button:not(:first-child)>button]:!border-l-0',\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          '[&>pdm-tooltip>span>*]:rounded-none',\n          '[&>pdm-tooltip:first-child>span>*]:rounded-l-md',\n          '[&>pdm-tooltip:last-child>span>*]:rounded-r-md',\n          '[&>pdm-tooltip:not(:first-child)>span>*]:border-l-0',\n          '[&>pdm-tooltip>span>pdm-button>button]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>pdm-button>button]:!rounded-l-md',\n          '[&>pdm-tooltip:last-child>span>pdm-button>button]:!rounded-r-md',\n          '[&>pdm-tooltip:not(:first-child)>span>pdm-button>button]:!border-l-0',\n          '[&>pdm-tooltip>span>pdm-button>button]:shadow-none',\n          '[&>pdm-tooltip>span>button]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>button]:!rounded-l-md',\n          '[&>pdm-tooltip:last-child>span>button]:!rounded-r-md',\n          '[&>pdm-tooltip:not(:first-child)>span>button]:!border-l-0',\n          '[&>pdm-tooltip>span>button]:shadow-none',\n          '[&>pdm-tooltip>span>pdm-input>div>input]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>pdm-input>div>input]:!rounded-l-md',\n          '[&>pdm-tooltip:last-child>span>pdm-input>div>input]:!rounded-r-md',\n          '[&>pdm-tooltip>span>pdm-input>div>input]:shadow-none',\n          '[&>pdm-tooltip>span>input]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>input]:!rounded-l-md',\n          '[&>pdm-tooltip:last-child>span>input]:!rounded-r-md',\n          '[&>pdm-tooltip>span>input]:shadow-none',\n          '[&>pdm-tooltip>span>pdm-input-group>div]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>pdm-input-group>div]:!rounded-l-md',\n          '[&>pdm-tooltip:last-child>span>pdm-input-group>div]:!rounded-r-md',\n          '[&>pdm-tooltip>span>pdm-select>select]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>pdm-select>select]:!rounded-l-md',\n          '[&>pdm-tooltip:last-child>span>pdm-select>select]:!rounded-r-md',\n          '[&>pdm-tooltip>span>pdm-select>select]:shadow-none',\n          '[&>pdm-tooltip>span>pdm-select>div>button]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>pdm-select>div>button]:!rounded-l-md',\n          '[&>pdm-tooltip:last-child>span>pdm-select>div>button]:!rounded-r-md',\n          '[&>pdm-tooltip:not(:first-child)>span>pdm-select>div>button]:!rounded-l-none',\n          '[&>pdm-tooltip:not(:last-child)>span>pdm-select>div>button]:!rounded-r-none',\n          '[&>pdm-tooltip:not(:first-child)>span>pdm-select>div>button]:!border-l-0',\n          '[&>pdm-tooltip>span>pdm-select>div>button]:shadow-none',\n          '[&>pdm-tooltip>span>select]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>select]:!rounded-l-md',\n          '[&>pdm-tooltip:last-child>span>select]:!rounded-r-md',\n          '[&>pdm-tooltip>span>select]:shadow-none'\n        ].join(' ')\n      : '';\n\n    const groupVerticalClasses = isGroup && isVertical && !this.separated\n      ? [\n          '[&>*]:rounded-none',\n          '[&>*:first-child]:rounded-t-md',\n          '[&>*:last-child]:rounded-b-md',\n          '[&>*:not(:first-child)]:-mt-px',\n          '[&>*:not(:first-child)]:border-t-0',\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-select>select]:!rounded-none',\n          '[&>pdm-select:first-child>select]:!rounded-t-md',\n          '[&>pdm-select:last-child>select]:!rounded-b-md',\n          '[&>pdm-select>select]:shadow-none',\n          '[&>pdm-select>div>button]:!rounded-none',\n          '[&>pdm-select:first-child>div>button]:!rounded-t-md',\n          '[&>pdm-select:last-child>div>button]:!rounded-b-md',\n          '[&>pdm-select:not(:first-child)>div>button]:!rounded-t-none',\n          '[&>pdm-select:not(:last-child)>div>button]:!rounded-b-none',\n          '[&>pdm-select:not(:first-child)>div>button]:!border-t-0',\n          '[&>pdm-select>div>button]:shadow-none',\n          '[&>pdm-input>div>input]:bg-background',\n          '[&>pdm-input>div>input]:shadow-none',\n          '[&>pdm-button>button]:shadow-none',\n          '[&>pdm-button:not(:first-child)>button]:!border-t-0',\n          '[&>pdm-tooltip>span>*]:rounded-none',\n          '[&>pdm-tooltip:first-child>span>*]:rounded-t-md',\n          '[&>pdm-tooltip:last-child>span>*]:rounded-b-md',\n          '[&>pdm-tooltip:not(:first-child)>span>*]:border-t-0',\n          '[&>pdm-tooltip>span>pdm-button>button]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>pdm-button>button]:!rounded-t-md',\n          '[&>pdm-tooltip:last-child>span>pdm-button>button]:!rounded-b-md',\n          '[&>pdm-tooltip:not(:first-child)>span>pdm-button>button]:!border-t-0',\n          '[&>pdm-tooltip>span>pdm-button>button]:shadow-none',\n          '[&>pdm-tooltip>span>button]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>button]:!rounded-t-md',\n          '[&>pdm-tooltip:last-child>span>button]:!rounded-b-md',\n          '[&>pdm-tooltip:not(:first-child)>span>button]:!border-t-0',\n          '[&>pdm-tooltip>span>button]:shadow-none',\n          '[&>pdm-tooltip>span>pdm-input>div>input]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>pdm-input>div>input]:!rounded-t-md',\n          '[&>pdm-tooltip:last-child>span>pdm-input>div>input]:!rounded-b-md',\n          '[&>pdm-tooltip>span>pdm-input>div>input]:shadow-none',\n          '[&>pdm-tooltip>span>input]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>input]:!rounded-t-md',\n          '[&>pdm-tooltip:last-child>span>input]:!rounded-b-md',\n          '[&>pdm-tooltip>span>input]:shadow-none',\n          '[&>pdm-tooltip>span>pdm-input-group>div]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>pdm-input-group>div]:!rounded-t-md',\n          '[&>pdm-tooltip:last-child>span>pdm-input-group>div]:!rounded-b-md',\n          '[&>pdm-tooltip>span>pdm-select>select]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>pdm-select>select]:!rounded-t-md',\n          '[&>pdm-tooltip:last-child>span>pdm-select>select]:!rounded-b-md',\n          '[&>pdm-tooltip>span>pdm-select>select]:shadow-none',\n          '[&>pdm-tooltip>span>pdm-select>div>button]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>pdm-select>div>button]:!rounded-t-md',\n          '[&>pdm-tooltip:last-child>span>pdm-select>div>button]:!rounded-b-md',\n          '[&>pdm-tooltip:not(:first-child)>span>pdm-select>div>button]:!rounded-t-none',\n          '[&>pdm-tooltip:not(:last-child)>span>pdm-select>div>button]:!rounded-b-none',\n          '[&>pdm-tooltip:not(:first-child)>span>pdm-select>div>button]:!border-t-0',\n          '[&>pdm-tooltip>span>pdm-select>div>button]:shadow-none',\n          '[&>pdm-tooltip>span>select]:!rounded-none',\n          '[&>pdm-tooltip:first-child>span>select]:!rounded-t-md',\n          '[&>pdm-tooltip:last-child>span>select]:!rounded-b-md',\n          '[&>pdm-tooltip>span>select]: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,34 @@ 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
  import * as i2 from "../icon/icon.component";
5
+ import * as i3 from "../select/select.component";
5
6
  export class PdmPaginationComponent {
6
7
  constructor() {
7
8
  this.page = 1;
8
9
  this.pageCount = 1;
9
- this.maxVisible = 5;
10
+ this.maxVisible = 4;
10
11
  this.className = '';
12
+ this.rowsPerPageLabel = 'Rows per page';
13
+ this.rowsPerPage = 10;
14
+ this.rowsPerPageOptions = [10, 20, 30, 50];
11
15
  this.pageChange = new EventEmitter();
16
+ this.rowsPerPageChange = new EventEmitter();
17
+ }
18
+ get rowsPerPageSelectOptions() {
19
+ return this.rowsPerPageOptions.map((value) => ({
20
+ label: String(value),
21
+ value: String(value)
22
+ }));
23
+ }
24
+ get rowsPerPageValue() {
25
+ return String(this.rowsPerPage);
12
26
  }
13
27
  get visiblePages() {
14
28
  const total = Math.max(1, this.pageCount);
15
- const visible = Math.max(1, this.maxVisible);
16
- const half = Math.floor(visible / 2);
17
- let start = Math.max(1, this.page - half);
18
- let end = Math.min(total, start + visible - 1);
19
- if (end - start + 1 < visible) {
20
- start = Math.max(1, end - visible + 1);
29
+ if (total <= Math.max(1, this.maxVisible)) {
30
+ return Array.from({ length: total }, (_, i) => i + 1);
21
31
  }
22
- return Array.from({ length: end - start + 1 }, (_, i) => start + i);
32
+ return [1, 2, 'ellipsis', total];
23
33
  }
24
34
  setPage(next) {
25
35
  if (next < 1 || next > this.pageCount || next === this.page) {
@@ -27,12 +37,19 @@ export class PdmPaginationComponent {
27
37
  }
28
38
  this.pageChange.emit(next);
29
39
  }
40
+ onRowsPerPageChangeValue(value) {
41
+ const next = Number(value);
42
+ if (!Number.isFinite(next) || next <= 0 || next === this.rowsPerPage) {
43
+ return;
44
+ }
45
+ this.rowsPerPageChange.emit(next);
46
+ }
30
47
  }
31
48
  PdmPaginationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: PdmPaginationComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
32
- PdmPaginationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: PdmPaginationComponent, selector: "pdm-pagination", inputs: { page: "page", pageCount: "pageCount", maxVisible: "maxVisible", className: "className" }, outputs: { pageChange: "pageChange" }, ngImport: i0, template: "<nav aria-label=\"Pagination\" [ngClass]=\"['mx-auto flex w-full justify-center', className]\">\n <ul class=\"flex items-center gap-1\">\n <li>\n <button type=\"button\" class=\"inline-flex h-9 items-center justify-center gap-1 rounded-md px-2 text-sm text-foreground hover:bg-accent disabled:opacity-50 ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2\" [disabled]=\"page <= 1\" (click)=\"setPage(page - 1)\">\n <pdm-icon name=\"chevron-left\" [size]=\"14\"></pdm-icon>\n Previous\n </button>\n </li>\n <li *ngFor=\"let pageNumber of visiblePages\">\n <button\n type=\"button\"\n [ngClass]=\"[\n 'inline-flex h-9 min-w-9 items-center justify-center rounded-md px-2 text-sm ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2',\n pageNumber === page\n ? 'border border-border bg-muted text-foreground shadow-sm'\n : 'text-foreground hover:bg-accent hover:text-accent-foreground'\n ]\"\n (click)=\"setPage(pageNumber)\"\n >\n {{ pageNumber }}\n </button>\n </li>\n <li>\n <button type=\"button\" class=\"inline-flex h-9 items-center justify-center gap-1 rounded-md px-2 text-sm text-foreground hover:bg-accent disabled:opacity-50 ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2\" [disabled]=\"page >= pageCount\" (click)=\"setPage(page + 1)\">\n Next\n <pdm-icon name=\"chevron-right\" [size]=\"14\"></pdm-icon>\n </button>\n </li>\n </ul>\n</nav>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i2.PdmIconComponent, selector: "pdm-icon", inputs: ["name", "library", "assetUrl", "size", "strokeWidth", "className", "ariaLabel", "decorative"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
49
+ PdmPaginationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: PdmPaginationComponent, selector: "pdm-pagination", inputs: { page: "page", pageCount: "pageCount", maxVisible: "maxVisible", className: "className", rowsPerPageLabel: "rowsPerPageLabel", rowsPerPage: "rowsPerPage", rowsPerPageOptions: "rowsPerPageOptions" }, outputs: { pageChange: "pageChange", rowsPerPageChange: "rowsPerPageChange" }, ngImport: i0, template: "<nav\n aria-label=\"Pagination\"\n [ngClass]=\"[\n 'mx-auto flex w-full flex-wrap items-center justify-center gap-4',\n className,\n ]\"\n>\n <div class=\"flex items-center gap-3\" *ngIf=\"rowsPerPageOptions.length > 0\">\n <span class=\"text-sm font-medium text-foreground\">{{\n rowsPerPageLabel\n }}</span>\n <pdm-select\n [value]=\"rowsPerPageValue\"\n [options]=\"rowsPerPageSelectOptions\"\n [placeholder]=\"rowsPerPageValue\"\n className=\"w-[120px]\"\n (valueChange)=\"onRowsPerPageChangeValue($event)\"\n ></pdm-select>\n </div>\n\n <ul class=\"flex items-center gap-1\">\n <li>\n <button\n type=\"button\"\n class=\"inline-flex h-9 items-center justify-center gap-1 rounded-md px-2 text-sm text-foreground hover:bg-accent disabled:opacity-50 ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2\"\n [disabled]=\"page <= 1\"\n (click)=\"setPage(page - 1)\"\n >\n <pdm-icon name=\"chevron-left\" [size]=\"14\"></pdm-icon>\n Previous\n </button>\n </li>\n <li *ngFor=\"let pageNumber of visiblePages\">\n <ng-container *ngIf=\"pageNumber === 'ellipsis'; else pageButton\">\n <span\n class=\"inline-flex h-9 min-w-9 items-center justify-center px-2 text-sm text-muted-foreground\"\n >...</span\n >\n </ng-container>\n <ng-template #pageButton>\n <button\n type=\"button\"\n [ngClass]=\"[\n 'inline-flex h-9 min-w-9 items-center justify-center rounded-md px-2 text-sm ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2',\n pageNumber === page\n ? 'border border-border bg-muted text-foreground shadow-sm'\n : 'text-foreground hover:bg-accent hover:text-accent-foreground',\n ]\"\n (click)=\"setPage(+pageNumber)\"\n >\n {{ pageNumber }}\n </button>\n </ng-template>\n </li>\n <li>\n <button\n type=\"button\"\n class=\"inline-flex h-9 items-center justify-center gap-1 rounded-md px-2 text-sm text-foreground hover:bg-accent disabled:opacity-50 ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2\"\n [disabled]=\"page >= pageCount\"\n (click)=\"setPage(page + 1)\"\n >\n Next\n <pdm-icon name=\"chevron-right\" [size]=\"14\"></pdm-icon>\n </button>\n </li>\n </ul>\n</nav>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.PdmIconComponent, selector: "pdm-icon", inputs: ["name", "library", "assetUrl", "size", "strokeWidth", "className", "ariaLabel", "decorative"] }, { kind: "component", type: i3.PdmSelectComponent, selector: "pdm-select", inputs: ["id", "value", "options", "disabled", "invalid", "className", "placeholder"], outputs: ["valueChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
33
50
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: PdmPaginationComponent, decorators: [{
34
51
  type: Component,
35
- args: [{ selector: 'pdm-pagination', changeDetection: ChangeDetectionStrategy.OnPush, template: "<nav aria-label=\"Pagination\" [ngClass]=\"['mx-auto flex w-full justify-center', className]\">\n <ul class=\"flex items-center gap-1\">\n <li>\n <button type=\"button\" class=\"inline-flex h-9 items-center justify-center gap-1 rounded-md px-2 text-sm text-foreground hover:bg-accent disabled:opacity-50 ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2\" [disabled]=\"page <= 1\" (click)=\"setPage(page - 1)\">\n <pdm-icon name=\"chevron-left\" [size]=\"14\"></pdm-icon>\n Previous\n </button>\n </li>\n <li *ngFor=\"let pageNumber of visiblePages\">\n <button\n type=\"button\"\n [ngClass]=\"[\n 'inline-flex h-9 min-w-9 items-center justify-center rounded-md px-2 text-sm ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2',\n pageNumber === page\n ? 'border border-border bg-muted text-foreground shadow-sm'\n : 'text-foreground hover:bg-accent hover:text-accent-foreground'\n ]\"\n (click)=\"setPage(pageNumber)\"\n >\n {{ pageNumber }}\n </button>\n </li>\n <li>\n <button type=\"button\" class=\"inline-flex h-9 items-center justify-center gap-1 rounded-md px-2 text-sm text-foreground hover:bg-accent disabled:opacity-50 ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2\" [disabled]=\"page >= pageCount\" (click)=\"setPage(page + 1)\">\n Next\n <pdm-icon name=\"chevron-right\" [size]=\"14\"></pdm-icon>\n </button>\n </li>\n </ul>\n</nav>\n" }]
52
+ args: [{ selector: 'pdm-pagination', changeDetection: ChangeDetectionStrategy.OnPush, template: "<nav\n aria-label=\"Pagination\"\n [ngClass]=\"[\n 'mx-auto flex w-full flex-wrap items-center justify-center gap-4',\n className,\n ]\"\n>\n <div class=\"flex items-center gap-3\" *ngIf=\"rowsPerPageOptions.length > 0\">\n <span class=\"text-sm font-medium text-foreground\">{{\n rowsPerPageLabel\n }}</span>\n <pdm-select\n [value]=\"rowsPerPageValue\"\n [options]=\"rowsPerPageSelectOptions\"\n [placeholder]=\"rowsPerPageValue\"\n className=\"w-[120px]\"\n (valueChange)=\"onRowsPerPageChangeValue($event)\"\n ></pdm-select>\n </div>\n\n <ul class=\"flex items-center gap-1\">\n <li>\n <button\n type=\"button\"\n class=\"inline-flex h-9 items-center justify-center gap-1 rounded-md px-2 text-sm text-foreground hover:bg-accent disabled:opacity-50 ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2\"\n [disabled]=\"page <= 1\"\n (click)=\"setPage(page - 1)\"\n >\n <pdm-icon name=\"chevron-left\" [size]=\"14\"></pdm-icon>\n Previous\n </button>\n </li>\n <li *ngFor=\"let pageNumber of visiblePages\">\n <ng-container *ngIf=\"pageNumber === 'ellipsis'; else pageButton\">\n <span\n class=\"inline-flex h-9 min-w-9 items-center justify-center px-2 text-sm text-muted-foreground\"\n >...</span\n >\n </ng-container>\n <ng-template #pageButton>\n <button\n type=\"button\"\n [ngClass]=\"[\n 'inline-flex h-9 min-w-9 items-center justify-center rounded-md px-2 text-sm ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2',\n pageNumber === page\n ? 'border border-border bg-muted text-foreground shadow-sm'\n : 'text-foreground hover:bg-accent hover:text-accent-foreground',\n ]\"\n (click)=\"setPage(+pageNumber)\"\n >\n {{ pageNumber }}\n </button>\n </ng-template>\n </li>\n <li>\n <button\n type=\"button\"\n class=\"inline-flex h-9 items-center justify-center gap-1 rounded-md px-2 text-sm text-foreground hover:bg-accent disabled:opacity-50 ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2\"\n [disabled]=\"page >= pageCount\"\n (click)=\"setPage(page + 1)\"\n >\n Next\n <pdm-icon name=\"chevron-right\" [size]=\"14\"></pdm-icon>\n </button>\n </li>\n </ul>\n</nav>\n" }]
36
53
  }], propDecorators: { page: [{
37
54
  type: Input
38
55
  }], pageCount: [{
@@ -41,7 +58,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
41
58
  type: Input
42
59
  }], className: [{
43
60
  type: Input
61
+ }], rowsPerPageLabel: [{
62
+ type: Input
63
+ }], rowsPerPage: [{
64
+ type: Input
65
+ }], rowsPerPageOptions: [{
66
+ type: Input
44
67
  }], pageChange: [{
45
68
  type: Output
69
+ }], rowsPerPageChange: [{
70
+ type: Output
46
71
  }] } });
47
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnaW5hdGlvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvcGFnaW5hdGlvbi9wYWdpbmF0aW9uLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9wYWdpbmF0aW9uL3BhZ2luYXRpb24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7OztBQU9oRyxNQUFNLE9BQU8sc0JBQXNCO0lBTG5DO1FBTVcsU0FBSSxHQUFHLENBQUMsQ0FBQztRQUNULGNBQVMsR0FBRyxDQUFDLENBQUM7UUFDZCxlQUFVLEdBQUcsQ0FBQyxDQUFDO1FBQ2YsY0FBUyxHQUFHLEVBQUUsQ0FBQztRQUVkLGVBQVUsR0FBRyxJQUFJLFlBQVksRUFBVSxDQUFDO0tBdUJuRDtJQXJCQyxJQUFJLFlBQVk7UUFDZCxNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDMUMsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQzdDLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxHQUFHLENBQUMsQ0FBQyxDQUFDO1FBQ3JDLElBQUksS0FBSyxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUFFLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLENBQUM7UUFDMUMsSUFBSSxHQUFHLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsS0FBSyxHQUFHLE9BQU8sR0FBRyxDQUFDLENBQUMsQ0FBQztRQUUvQyxJQUFJLEdBQUcsR0FBRyxLQUFLLEdBQUcsQ0FBQyxHQUFHLE9BQU8sRUFBRTtZQUM3QixLQUFLLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUUsR0FBRyxHQUFHLE9BQU8sR0FBRyxDQUFDLENBQUMsQ0FBQztTQUN4QztRQUVELE9BQU8sS0FBSyxDQUFDLElBQUksQ0FBQyxFQUFFLE1BQU0sRUFBRSxHQUFHLEdBQUcsS0FBSyxHQUFHLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsS0FBSyxHQUFHLENBQUMsQ0FBQyxDQUFDO0lBQ3RFLENBQUM7SUFFRCxPQUFPLENBQUMsSUFBWTtRQUNsQixJQUFJLElBQUksR0FBRyxDQUFDLElBQUksSUFBSSxHQUFHLElBQUksQ0FBQyxTQUFTLElBQUksSUFBSSxLQUFLLElBQUksQ0FBQyxJQUFJLEVBQUU7WUFDM0QsT0FBTztTQUNSO1FBRUQsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDN0IsQ0FBQzs7bUhBNUJVLHNCQUFzQjt1R0FBdEIsc0JBQXNCLGlNQ1BuQyxnc0RBOEJBOzJGRHZCYSxzQkFBc0I7a0JBTGxDLFNBQVM7K0JBQ0UsZ0JBQWdCLG1CQUVULHVCQUF1QixDQUFDLE1BQU07OEJBR3RDLElBQUk7c0JBQVosS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFFSSxVQUFVO3NCQUFuQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3BkbS1wYWdpbmF0aW9uJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3BhZ2luYXRpb24uY29tcG9uZW50Lmh0bWwnLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBQZG1QYWdpbmF0aW9uQ29tcG9uZW50IHtcbiAgQElucHV0KCkgcGFnZSA9IDE7XG4gIEBJbnB1dCgpIHBhZ2VDb3VudCA9IDE7XG4gIEBJbnB1dCgpIG1heFZpc2libGUgPSA1O1xuICBASW5wdXQoKSBjbGFzc05hbWUgPSAnJztcblxuICBAT3V0cHV0KCkgcGFnZUNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8bnVtYmVyPigpO1xuXG4gIGdldCB2aXNpYmxlUGFnZXMoKTogbnVtYmVyW10ge1xuICAgIGNvbnN0IHRvdGFsID0gTWF0aC5tYXgoMSwgdGhpcy5wYWdlQ291bnQpO1xuICAgIGNvbnN0IHZpc2libGUgPSBNYXRoLm1heCgxLCB0aGlzLm1heFZpc2libGUpO1xuICAgIGNvbnN0IGhhbGYgPSBNYXRoLmZsb29yKHZpc2libGUgLyAyKTtcbiAgICBsZXQgc3RhcnQgPSBNYXRoLm1heCgxLCB0aGlzLnBhZ2UgLSBoYWxmKTtcbiAgICBsZXQgZW5kID0gTWF0aC5taW4odG90YWwsIHN0YXJ0ICsgdmlzaWJsZSAtIDEpO1xuXG4gICAgaWYgKGVuZCAtIHN0YXJ0ICsgMSA8IHZpc2libGUpIHtcbiAgICAgIHN0YXJ0ID0gTWF0aC5tYXgoMSwgZW5kIC0gdmlzaWJsZSArIDEpO1xuICAgIH1cblxuICAgIHJldHVybiBBcnJheS5mcm9tKHsgbGVuZ3RoOiBlbmQgLSBzdGFydCArIDEgfSwgKF8sIGkpID0+IHN0YXJ0ICsgaSk7XG4gIH1cblxuICBzZXRQYWdlKG5leHQ6IG51bWJlcik6IHZvaWQge1xuICAgIGlmIChuZXh0IDwgMSB8fCBuZXh0ID4gdGhpcy5wYWdlQ291bnQgfHwgbmV4dCA9PT0gdGhpcy5wYWdlKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgdGhpcy5wYWdlQ2hhbmdlLmVtaXQobmV4dCk7XG4gIH1cbn1cbiIsIjxuYXYgYXJpYS1sYWJlbD1cIlBhZ2luYXRpb25cIiBbbmdDbGFzc109XCJbJ214LWF1dG8gZmxleCB3LWZ1bGwganVzdGlmeS1jZW50ZXInLCBjbGFzc05hbWVdXCI+XG4gIDx1bCBjbGFzcz1cImZsZXggaXRlbXMtY2VudGVyIGdhcC0xXCI+XG4gICAgPGxpPlxuICAgICAgPGJ1dHRvbiB0eXBlPVwiYnV0dG9uXCIgY2xhc3M9XCJpbmxpbmUtZmxleCBoLTkgaXRlbXMtY2VudGVyIGp1c3RpZnktY2VudGVyIGdhcC0xIHJvdW5kZWQtbWQgcHgtMiB0ZXh0LXNtIHRleHQtZm9yZWdyb3VuZCBob3ZlcjpiZy1hY2NlbnQgZGlzYWJsZWQ6b3BhY2l0eS01MCByaW5nLW9mZnNldC1iYWNrZ3JvdW5kIGZvY3VzLXZpc2libGU6b3V0bGluZS1ub25lIGZvY3VzLXZpc2libGU6cmluZy0yIGZvY3VzLXZpc2libGU6cmluZy1yaW5nIGZvY3VzLXZpc2libGU6cmluZy1vZmZzZXQtMlwiIFtkaXNhYmxlZF09XCJwYWdlIDw9IDFcIiAoY2xpY2spPVwic2V0UGFnZShwYWdlIC0gMSlcIj5cbiAgICAgICAgPHBkbS1pY29uIG5hbWU9XCJjaGV2cm9uLWxlZnRcIiBbc2l6ZV09XCIxNFwiPjwvcGRtLWljb24+XG4gICAgICAgIFByZXZpb3VzXG4gICAgICA8L2J1dHRvbj5cbiAgICA8L2xpPlxuICAgIDxsaSAqbmdGb3I9XCJsZXQgcGFnZU51bWJlciBvZiB2aXNpYmxlUGFnZXNcIj5cbiAgICAgIDxidXR0b25cbiAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgIFtuZ0NsYXNzXT1cIltcbiAgICAgICAgICAnaW5saW5lLWZsZXggaC05IG1pbi13LTkgaXRlbXMtY2VudGVyIGp1c3RpZnktY2VudGVyIHJvdW5kZWQtbWQgcHgtMiB0ZXh0LXNtIHJpbmctb2Zmc2V0LWJhY2tncm91bmQgZm9jdXMtdmlzaWJsZTpvdXRsaW5lLW5vbmUgZm9jdXMtdmlzaWJsZTpyaW5nLTIgZm9jdXMtdmlzaWJsZTpyaW5nLXJpbmcgZm9jdXMtdmlzaWJsZTpyaW5nLW9mZnNldC0yJyxcbiAgICAgICAgICBwYWdlTnVtYmVyID09PSBwYWdlXG4gICAgICAgICAgICA/ICdib3JkZXIgYm9yZGVyLWJvcmRlciBiZy1tdXRlZCB0ZXh0LWZvcmVncm91bmQgc2hhZG93LXNtJ1xuICAgICAgICAgICAgOiAndGV4dC1mb3JlZ3JvdW5kIGhvdmVyOmJnLWFjY2VudCBob3Zlcjp0ZXh0LWFjY2VudC1mb3JlZ3JvdW5kJ1xuICAgICAgICBdXCJcbiAgICAgICAgKGNsaWNrKT1cInNldFBhZ2UocGFnZU51bWJlcilcIlxuICAgICAgPlxuICAgICAgICB7eyBwYWdlTnVtYmVyIH19XG4gICAgICA8L2J1dHRvbj5cbiAgICA8L2xpPlxuICAgIDxsaT5cbiAgICAgIDxidXR0b24gdHlwZT1cImJ1dHRvblwiIGNsYXNzPVwiaW5saW5lLWZsZXggaC05IGl0ZW1zLWNlbnRlciBqdXN0aWZ5LWNlbnRlciBnYXAtMSByb3VuZGVkLW1kIHB4LTIgdGV4dC1zbSB0ZXh0LWZvcmVncm91bmQgaG92ZXI6YmctYWNjZW50IGRpc2FibGVkOm9wYWNpdHktNTAgcmluZy1vZmZzZXQtYmFja2dyb3VuZCBmb2N1cy12aXNpYmxlOm91dGxpbmUtbm9uZSBmb2N1cy12aXNpYmxlOnJpbmctMiBmb2N1cy12aXNpYmxlOnJpbmctcmluZyBmb2N1cy12aXNpYmxlOnJpbmctb2Zmc2V0LTJcIiBbZGlzYWJsZWRdPVwicGFnZSA+PSBwYWdlQ291bnRcIiAoY2xpY2spPVwic2V0UGFnZShwYWdlICsgMSlcIj5cbiAgICAgICAgTmV4dFxuICAgICAgICA8cGRtLWljb24gbmFtZT1cImNoZXZyb24tcmlnaHRcIiBbc2l6ZV09XCIxNFwiPjwvcGRtLWljb24+XG4gICAgICA8L2J1dHRvbj5cbiAgICA8L2xpPlxuICA8L3VsPlxuPC9uYXY+XG4iXX0=
72
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/pagination/pagination.component.ts","../../../../../../src/lib/components/pagination/pagination.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;;;;;AAQhG,MAAM,OAAO,sBAAsB;IALnC;QAMW,SAAI,GAAG,CAAC,CAAC;QACT,cAAS,GAAG,CAAC,CAAC;QACd,eAAU,GAAG,CAAC,CAAC;QACf,cAAS,GAAG,EAAE,CAAC;QACf,qBAAgB,GAAG,eAAe,CAAC;QACnC,gBAAW,GAAG,EAAE,CAAC;QACjB,uBAAkB,GAAa,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;QAE/C,eAAU,GAAG,IAAI,YAAY,EAAU,CAAC;QACxC,sBAAiB,GAAG,IAAI,YAAY,EAAU,CAAC;KAsC1D;IApCC,IAAI,wBAAwB;QAC1B,OAAO,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;YAC7C,KAAK,EAAE,MAAM,CAAC,KAAK,CAAC;YACpB,KAAK,EAAE,MAAM,CAAC,KAAK,CAAC;SACrB,CAAC,CAAC,CAAC;IACN,CAAC;IAED,IAAI,gBAAgB;QAClB,OAAO,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IAClC,CAAC;IAED,IAAI,YAAY;QACd,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;QAC1C,IAAI,KAAK,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,EAAE;YACzC,OAAO,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;SACvD;QAED,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,UAAU,EAAE,KAAK,CAAC,CAAC;IACnC,CAAC;IAED,OAAO,CAAC,IAAY;QAClB,IAAI,IAAI,GAAG,CAAC,IAAI,IAAI,GAAG,IAAI,CAAC,SAAS,IAAI,IAAI,KAAK,IAAI,CAAC,IAAI,EAAE;YAC3D,OAAO;SACR;QAED,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;IAED,wBAAwB,CAAC,KAAa;QACpC,MAAM,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QAC3B,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,IAAI,KAAK,IAAI,CAAC,WAAW,EAAE;YACpE,OAAO;SACR;QAED,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACpC,CAAC;;mHA/CU,sBAAsB;uGAAtB,sBAAsB,qVCRnC,wlFAmEA;2FD3Da,sBAAsB;kBALlC,SAAS;+BACE,gBAAgB,mBAET,uBAAuB,CAAC,MAAM;8BAGtC,IAAI;sBAAZ,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBAEI,UAAU;sBAAnB,MAAM;gBACG,iBAAiB;sBAA1B,MAAM","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';\nimport type { PdmNativeSelectOption } from '../native-select/native-select.component';\n\n@Component({\n  selector: 'pdm-pagination',\n  templateUrl: './pagination.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class PdmPaginationComponent {\n  @Input() page = 1;\n  @Input() pageCount = 1;\n  @Input() maxVisible = 4;\n  @Input() className = '';\n  @Input() rowsPerPageLabel = 'Rows per page';\n  @Input() rowsPerPage = 10;\n  @Input() rowsPerPageOptions: number[] = [10, 20, 30, 50];\n\n  @Output() pageChange = new EventEmitter<number>();\n  @Output() rowsPerPageChange = new EventEmitter<number>();\n\n  get rowsPerPageSelectOptions(): PdmNativeSelectOption[] {\n    return this.rowsPerPageOptions.map((value) => ({\n      label: String(value),\n      value: String(value)\n    }));\n  }\n\n  get rowsPerPageValue(): string {\n    return String(this.rowsPerPage);\n  }\n\n  get visiblePages(): Array<number | 'ellipsis'> {\n    const total = Math.max(1, this.pageCount);\n    if (total <= Math.max(1, this.maxVisible)) {\n      return Array.from({ length: total }, (_, i) => i + 1);\n    }\n\n    return [1, 2, 'ellipsis', total];\n  }\n\n  setPage(next: number): void {\n    if (next < 1 || next > this.pageCount || next === this.page) {\n      return;\n    }\n\n    this.pageChange.emit(next);\n  }\n\n  onRowsPerPageChangeValue(value: string): void {\n    const next = Number(value);\n    if (!Number.isFinite(next) || next <= 0 || next === this.rowsPerPage) {\n      return;\n    }\n\n    this.rowsPerPageChange.emit(next);\n  }\n}\n","<nav\n  aria-label=\"Pagination\"\n  [ngClass]=\"[\n    'mx-auto flex w-full flex-wrap items-center justify-center gap-4',\n    className,\n  ]\"\n>\n  <div class=\"flex items-center gap-3\" *ngIf=\"rowsPerPageOptions.length > 0\">\n    <span class=\"text-sm font-medium text-foreground\">{{\n      rowsPerPageLabel\n    }}</span>\n    <pdm-select\n      [value]=\"rowsPerPageValue\"\n      [options]=\"rowsPerPageSelectOptions\"\n      [placeholder]=\"rowsPerPageValue\"\n      className=\"w-[120px]\"\n      (valueChange)=\"onRowsPerPageChangeValue($event)\"\n    ></pdm-select>\n  </div>\n\n  <ul class=\"flex items-center gap-1\">\n    <li>\n      <button\n        type=\"button\"\n        class=\"inline-flex h-9 items-center justify-center gap-1 rounded-md px-2 text-sm text-foreground hover:bg-accent disabled:opacity-50 ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2\"\n        [disabled]=\"page <= 1\"\n        (click)=\"setPage(page - 1)\"\n      >\n        <pdm-icon name=\"chevron-left\" [size]=\"14\"></pdm-icon>\n        Previous\n      </button>\n    </li>\n    <li *ngFor=\"let pageNumber of visiblePages\">\n      <ng-container *ngIf=\"pageNumber === 'ellipsis'; else pageButton\">\n        <span\n          class=\"inline-flex h-9 min-w-9 items-center justify-center px-2 text-sm text-muted-foreground\"\n          >...</span\n        >\n      </ng-container>\n      <ng-template #pageButton>\n        <button\n          type=\"button\"\n          [ngClass]=\"[\n            'inline-flex h-9 min-w-9 items-center justify-center rounded-md px-2 text-sm ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2',\n            pageNumber === page\n              ? 'border border-border bg-muted text-foreground shadow-sm'\n              : 'text-foreground hover:bg-accent hover:text-accent-foreground',\n          ]\"\n          (click)=\"setPage(+pageNumber)\"\n        >\n          {{ pageNumber }}\n        </button>\n      </ng-template>\n    </li>\n    <li>\n      <button\n        type=\"button\"\n        class=\"inline-flex h-9 items-center justify-center gap-1 rounded-md px-2 text-sm text-foreground hover:bg-accent disabled:opacity-50 ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2\"\n        [disabled]=\"page >= pageCount\"\n        (click)=\"setPage(page + 1)\"\n      >\n        Next\n        <pdm-icon name=\"chevron-right\" [size]=\"14\"></pdm-icon>\n      </button>\n    </li>\n  </ul>\n</nav>\n"]}
@@ -1,26 +1,57 @@
1
- import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, HostListener, Input, Output } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
3
  import * as i1 from "@angular/common";
4
+ import * as i2 from "../icon/icon.component";
4
5
  export class PdmSelectComponent {
5
- constructor() {
6
+ constructor(elementRef) {
7
+ this.elementRef = elementRef;
6
8
  this.id = '';
7
9
  this.value = '';
8
10
  this.options = [];
9
11
  this.disabled = false;
10
12
  this.invalid = false;
11
13
  this.className = '';
14
+ this.placeholder = 'Select an option';
15
+ this.open = false;
12
16
  this.valueChange = new EventEmitter();
13
17
  }
18
+ get selectedOption() {
19
+ return this.options.find((option) => option.value === this.value);
20
+ }
21
+ get selectedLabel() {
22
+ return this.selectedOption?.label || this.placeholder;
23
+ }
24
+ toggle() {
25
+ if (this.disabled)
26
+ return;
27
+ this.open = !this.open;
28
+ }
14
29
  onChange(event) {
15
30
  this.valueChange.emit(event.target.value);
16
31
  }
32
+ selectOption(option) {
33
+ if (option.disabled)
34
+ return;
35
+ this.valueChange.emit(option.value);
36
+ this.open = false;
37
+ }
38
+ onDocumentClick(event) {
39
+ if (!this.open)
40
+ return;
41
+ if (!this.elementRef.nativeElement.contains(event.target)) {
42
+ this.open = false;
43
+ }
44
+ }
45
+ onEscape() {
46
+ this.open = false;
47
+ }
17
48
  }
18
- PdmSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: PdmSelectComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
19
- PdmSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: PdmSelectComponent, selector: "pdm-select", inputs: { id: "id", value: "value", options: "options", disabled: "disabled", invalid: "invalid", className: "className" }, outputs: { valueChange: "valueChange" }, ngImport: i0, template: "<select\n [id]=\"id\"\n [value]=\"value\"\n [disabled]=\"disabled\"\n [attr.aria-invalid]=\"invalid\"\n [ngClass]=\"[\n 'border-input focus-visible:border-ring focus-visible:ring-2 focus-visible:ring-ring/50 aria-invalid:ring-2 aria-invalid:ring-destructive aria-invalid:border-destructive aria-invalid:placeholder:text-destructive/70 flex h-9 w-full rounded-md border bg-transparent px-3 py-2 text-sm text-foreground shadow-sm outline-none disabled:cursor-not-allowed disabled:opacity-50',\n className\n ]\"\n (change)=\"onChange($event)\"\n>\n <option *ngFor=\"let option of options\" [value]=\"option.value\" [disabled]=\"option.disabled\">{{ option.label }}</option>\n</select>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
49
+ PdmSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: PdmSelectComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
50
+ PdmSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: PdmSelectComponent, selector: "pdm-select", inputs: { id: "id", value: "value", options: "options", disabled: "disabled", invalid: "invalid", className: "className", placeholder: "placeholder" }, outputs: { valueChange: "valueChange" }, host: { listeners: { "document:click": "onDocumentClick($event)", "document:keydown.escape": "onEscape()" } }, ngImport: i0, template: "<div [ngClass]=\"['relative', className || 'w-full']\">\n <button\n type=\"button\"\n [id]=\"id\"\n [disabled]=\"disabled\"\n [attr.aria-invalid]=\"invalid\"\n [attr.aria-expanded]=\"open\"\n [attr.data-state]=\"open ? 'open' : 'closed'\"\n aria-haspopup=\"listbox\"\n (click)=\"toggle()\"\n [ngClass]=\"[\n 'border-input focus-visible:border-ring focus-visible:ring-2 focus-visible:ring-ring/50 aria-invalid:ring-2 aria-invalid:ring-destructive aria-invalid:border-destructive flex h-9 w-full items-center justify-between rounded-md border bg-background px-3 py-2 text-sm shadow-sm outline-none disabled:cursor-not-allowed disabled:opacity-50',\n ]\"\n >\n <span\n [ngClass]=\"[\n 'min-w-0 flex-1 truncate text-left leading-5',\n selectedOption\n ? 'font-medium text-foreground'\n : 'font-normal text-muted-foreground',\n ]\"\n >\n {{ selectedLabel }}\n </span>\n <pdm-icon\n name=\"chevron-down\"\n [size]=\"16\"\n className=\"shrink-0 text-muted-foreground\"\n ></pdm-icon>\n </button>\n\n <div\n *ngIf=\"open\"\n role=\"listbox\"\n [attr.aria-labelledby]=\"id || null\"\n class=\"absolute left-0 top-[calc(100%+4px)] z-50 max-h-96 w-full overflow-y-auto rounded-md border border-border bg-popover p-1 text-popover-foreground shadow-md\"\n >\n <button\n *ngFor=\"let option of options\"\n type=\"button\"\n role=\"option\"\n [attr.aria-selected]=\"option.value === value\"\n [disabled]=\"option.disabled\"\n (click)=\"selectOption(option)\"\n [ngClass]=\"[\n 'flex w-full items-center justify-between rounded-sm px-2 py-1.5 text-left text-sm outline-none transition-colors',\n option.disabled\n ? 'cursor-not-allowed opacity-50'\n : 'hover:bg-accent hover:text-accent-foreground focus-visible:bg-accent focus-visible:text-accent-foreground',\n option.value === value ? 'bg-accent text-accent-foreground' : '',\n ]\"\n >\n <span class=\"min-w-0 flex-1 truncate leading-5\">{{ option.label }}</span>\n <span\n *ngIf=\"option.value === value\"\n class=\"ml-2 flex shrink-0 items-center justify-end\"\n >\n <pdm-icon\n name=\"check\"\n [size]=\"16\"\n className=\"shrink-0 text-current\"\n ></pdm-icon>\n </span>\n </button>\n </div>\n\n <select\n class=\"sr-only\"\n tabindex=\"-1\"\n aria-hidden=\"true\"\n [value]=\"value\"\n (change)=\"onChange($event)\"\n >\n <option\n *ngFor=\"let option of options\"\n [value]=\"option.value\"\n [disabled]=\"option.disabled\"\n >\n {{ option.label }}\n </option>\n </select>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.PdmIconComponent, selector: "pdm-icon", inputs: ["name", "library", "assetUrl", "size", "strokeWidth", "className", "ariaLabel", "decorative"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
20
51
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: PdmSelectComponent, decorators: [{
21
52
  type: Component,
22
- args: [{ selector: 'pdm-select', changeDetection: ChangeDetectionStrategy.OnPush, template: "<select\n [id]=\"id\"\n [value]=\"value\"\n [disabled]=\"disabled\"\n [attr.aria-invalid]=\"invalid\"\n [ngClass]=\"[\n 'border-input focus-visible:border-ring focus-visible:ring-2 focus-visible:ring-ring/50 aria-invalid:ring-2 aria-invalid:ring-destructive aria-invalid:border-destructive aria-invalid:placeholder:text-destructive/70 flex h-9 w-full rounded-md border bg-transparent px-3 py-2 text-sm text-foreground shadow-sm outline-none disabled:cursor-not-allowed disabled:opacity-50',\n className\n ]\"\n (change)=\"onChange($event)\"\n>\n <option *ngFor=\"let option of options\" [value]=\"option.value\" [disabled]=\"option.disabled\">{{ option.label }}</option>\n</select>\n" }]
23
- }], propDecorators: { id: [{
53
+ args: [{ selector: 'pdm-select', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div [ngClass]=\"['relative', className || 'w-full']\">\n <button\n type=\"button\"\n [id]=\"id\"\n [disabled]=\"disabled\"\n [attr.aria-invalid]=\"invalid\"\n [attr.aria-expanded]=\"open\"\n [attr.data-state]=\"open ? 'open' : 'closed'\"\n aria-haspopup=\"listbox\"\n (click)=\"toggle()\"\n [ngClass]=\"[\n 'border-input focus-visible:border-ring focus-visible:ring-2 focus-visible:ring-ring/50 aria-invalid:ring-2 aria-invalid:ring-destructive aria-invalid:border-destructive flex h-9 w-full items-center justify-between rounded-md border bg-background px-3 py-2 text-sm shadow-sm outline-none disabled:cursor-not-allowed disabled:opacity-50',\n ]\"\n >\n <span\n [ngClass]=\"[\n 'min-w-0 flex-1 truncate text-left leading-5',\n selectedOption\n ? 'font-medium text-foreground'\n : 'font-normal text-muted-foreground',\n ]\"\n >\n {{ selectedLabel }}\n </span>\n <pdm-icon\n name=\"chevron-down\"\n [size]=\"16\"\n className=\"shrink-0 text-muted-foreground\"\n ></pdm-icon>\n </button>\n\n <div\n *ngIf=\"open\"\n role=\"listbox\"\n [attr.aria-labelledby]=\"id || null\"\n class=\"absolute left-0 top-[calc(100%+4px)] z-50 max-h-96 w-full overflow-y-auto rounded-md border border-border bg-popover p-1 text-popover-foreground shadow-md\"\n >\n <button\n *ngFor=\"let option of options\"\n type=\"button\"\n role=\"option\"\n [attr.aria-selected]=\"option.value === value\"\n [disabled]=\"option.disabled\"\n (click)=\"selectOption(option)\"\n [ngClass]=\"[\n 'flex w-full items-center justify-between rounded-sm px-2 py-1.5 text-left text-sm outline-none transition-colors',\n option.disabled\n ? 'cursor-not-allowed opacity-50'\n : 'hover:bg-accent hover:text-accent-foreground focus-visible:bg-accent focus-visible:text-accent-foreground',\n option.value === value ? 'bg-accent text-accent-foreground' : '',\n ]\"\n >\n <span class=\"min-w-0 flex-1 truncate leading-5\">{{ option.label }}</span>\n <span\n *ngIf=\"option.value === value\"\n class=\"ml-2 flex shrink-0 items-center justify-end\"\n >\n <pdm-icon\n name=\"check\"\n [size]=\"16\"\n className=\"shrink-0 text-current\"\n ></pdm-icon>\n </span>\n </button>\n </div>\n\n <select\n class=\"sr-only\"\n tabindex=\"-1\"\n aria-hidden=\"true\"\n [value]=\"value\"\n (change)=\"onChange($event)\"\n >\n <option\n *ngFor=\"let option of options\"\n [value]=\"option.value\"\n [disabled]=\"option.disabled\"\n >\n {{ option.label }}\n </option>\n </select>\n</div>\n" }]
54
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { id: [{
24
55
  type: Input
25
56
  }], value: [{
26
57
  type: Input
@@ -32,7 +63,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
32
63
  type: Input
33
64
  }], className: [{
34
65
  type: Input
66
+ }], placeholder: [{
67
+ type: Input
35
68
  }], valueChange: [{
36
69
  type: Output
70
+ }], onDocumentClick: [{
71
+ type: HostListener,
72
+ args: ['document:click', ['$event']]
73
+ }], onEscape: [{
74
+ type: HostListener,
75
+ args: ['document:keydown.escape']
37
76
  }] } });
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9zZWxlY3Qvc2VsZWN0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9zZWxlY3Qvc2VsZWN0LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQWFoRyxNQUFNLE9BQU8sa0JBQWtCO0lBTC9CO1FBTVcsT0FBRSxHQUFHLEVBQUUsQ0FBQztRQUNSLFVBQUssR0FBRyxFQUFFLENBQUM7UUFDWCxZQUFPLEdBQXNCLEVBQUUsQ0FBQztRQUNoQyxhQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ2pCLFlBQU8sR0FBRyxLQUFLLENBQUM7UUFDaEIsY0FBUyxHQUFHLEVBQUUsQ0FBQztRQUVkLGdCQUFXLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztLQUtwRDtJQUhDLFFBQVEsQ0FBQyxLQUFZO1FBQ25CLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFFLEtBQUssQ0FBQyxNQUE0QixDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ25FLENBQUM7OytHQVpVLGtCQUFrQjttR0FBbEIsa0JBQWtCLHVOQ2IvQiwyckJBYUE7MkZEQWEsa0JBQWtCO2tCQUw5QixTQUFTOytCQUNFLFlBQVksbUJBRUwsdUJBQXVCLENBQUMsTUFBTTs4QkFHdEMsRUFBRTtzQkFBVixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxPQUFPO3NCQUFmLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxPQUFPO3NCQUFmLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFFSSxXQUFXO3NCQUFwQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGRtU2VsZWN0T3B0aW9uIHtcbiAgbGFiZWw6IHN0cmluZztcbiAgdmFsdWU6IHN0cmluZztcbiAgZGlzYWJsZWQ/OiBib29sZWFuO1xufVxuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdwZG0tc2VsZWN0JyxcbiAgdGVtcGxhdGVVcmw6ICcuL3NlbGVjdC5jb21wb25lbnQuaHRtbCcsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIFBkbVNlbGVjdENvbXBvbmVudCB7XG4gIEBJbnB1dCgpIGlkID0gJyc7XG4gIEBJbnB1dCgpIHZhbHVlID0gJyc7XG4gIEBJbnB1dCgpIG9wdGlvbnM6IFBkbVNlbGVjdE9wdGlvbltdID0gW107XG4gIEBJbnB1dCgpIGRpc2FibGVkID0gZmFsc2U7XG4gIEBJbnB1dCgpIGludmFsaWQgPSBmYWxzZTtcbiAgQElucHV0KCkgY2xhc3NOYW1lID0gJyc7XG5cbiAgQE91dHB1dCgpIHZhbHVlQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjxzdHJpbmc+KCk7XG5cbiAgb25DaGFuZ2UoZXZlbnQ6IEV2ZW50KTogdm9pZCB7XG4gICAgdGhpcy52YWx1ZUNoYW5nZS5lbWl0KChldmVudC50YXJnZXQgYXMgSFRNTFNlbGVjdEVsZW1lbnQpLnZhbHVlKTtcbiAgfVxufVxuIiwiPHNlbGVjdFxuICBbaWRdPVwiaWRcIlxuICBbdmFsdWVdPVwidmFsdWVcIlxuICBbZGlzYWJsZWRdPVwiZGlzYWJsZWRcIlxuICBbYXR0ci5hcmlhLWludmFsaWRdPVwiaW52YWxpZFwiXG4gIFtuZ0NsYXNzXT1cIltcbiAgICAnYm9yZGVyLWlucHV0IGZvY3VzLXZpc2libGU6Ym9yZGVyLXJpbmcgZm9jdXMtdmlzaWJsZTpyaW5nLTIgZm9jdXMtdmlzaWJsZTpyaW5nLXJpbmcvNTAgYXJpYS1pbnZhbGlkOnJpbmctMiBhcmlhLWludmFsaWQ6cmluZy1kZXN0cnVjdGl2ZSBhcmlhLWludmFsaWQ6Ym9yZGVyLWRlc3RydWN0aXZlIGFyaWEtaW52YWxpZDpwbGFjZWhvbGRlcjp0ZXh0LWRlc3RydWN0aXZlLzcwIGZsZXggaC05IHctZnVsbCByb3VuZGVkLW1kIGJvcmRlciBiZy10cmFuc3BhcmVudCBweC0zIHB5LTIgdGV4dC1zbSB0ZXh0LWZvcmVncm91bmQgc2hhZG93LXNtIG91dGxpbmUtbm9uZSBkaXNhYmxlZDpjdXJzb3Itbm90LWFsbG93ZWQgZGlzYWJsZWQ6b3BhY2l0eS01MCcsXG4gICAgY2xhc3NOYW1lXG4gIF1cIlxuICAoY2hhbmdlKT1cIm9uQ2hhbmdlKCRldmVudClcIlxuPlxuICA8b3B0aW9uICpuZ0Zvcj1cImxldCBvcHRpb24gb2Ygb3B0aW9uc1wiIFt2YWx1ZV09XCJvcHRpb24udmFsdWVcIiBbZGlzYWJsZWRdPVwib3B0aW9uLmRpc2FibGVkXCI+e3sgb3B0aW9uLmxhYmVsIH19PC9vcHRpb24+XG48L3NlbGVjdD5cbiJdfQ==
77
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/select/select.component.ts","../../../../../../src/lib/components/select/select.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAc,YAAY,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;;;;AAa1H,MAAM,OAAO,kBAAkB;IAa7B,YAA6B,UAAmC;QAAnC,eAAU,GAAV,UAAU,CAAyB;QAZvD,OAAE,GAAG,EAAE,CAAC;QACR,UAAK,GAAG,EAAE,CAAC;QACX,YAAO,GAAsB,EAAE,CAAC;QAChC,aAAQ,GAAG,KAAK,CAAC;QACjB,YAAO,GAAG,KAAK,CAAC;QAChB,cAAS,GAAG,EAAE,CAAC;QACf,gBAAW,GAAG,kBAAkB,CAAC;QAE1C,SAAI,GAAG,KAAK,CAAC;QAEH,gBAAW,GAAG,IAAI,YAAY,EAAU,CAAC;IAEgB,CAAC;IAEpE,IAAI,cAAc;QAChB,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,CAAC,CAAC;IACpE,CAAC;IAED,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,cAAc,EAAE,KAAK,IAAI,IAAI,CAAC,WAAW,CAAC;IACxD,CAAC;IAED,MAAM;QACJ,IAAI,IAAI,CAAC,QAAQ;YAAE,OAAO;QAC1B,IAAI,CAAC,IAAI,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC;IACzB,CAAC;IAED,QAAQ,CAAC,KAAY;QACnB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAE,KAAK,CAAC,MAA4B,CAAC,KAAK,CAAC,CAAC;IACnE,CAAC;IAED,YAAY,CAAC,MAAuB;QAClC,IAAI,MAAM,CAAC,QAAQ;YAAE,OAAO;QAC5B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QACpC,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;IACpB,CAAC;IAGD,eAAe,CAAC,KAAiB;QAC/B,IAAI,CAAC,IAAI,CAAC,IAAI;YAAE,OAAO;QACvB,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAc,CAAC,EAAE;YACjE,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;SACnB;IACH,CAAC;IAGD,QAAQ;QACN,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;IACpB,CAAC;;+GAjDU,kBAAkB;mGAAlB,kBAAkB,kWCb/B,+sFAkFA;2FDrEa,kBAAkB;kBAL9B,SAAS;+BACE,YAAY,mBAEL,uBAAuB,CAAC,MAAM;iGAGtC,EAAE;sBAAV,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBAII,WAAW;sBAApB,MAAM;gBA4BP,eAAe;sBADd,YAAY;uBAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC;gBAS1C,QAAQ;sBADP,YAAY;uBAAC,yBAAyB","sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, HostListener, Input, Output } from '@angular/core';\n\nexport interface PdmSelectOption {\n  label: string;\n  value: string;\n  disabled?: boolean;\n}\n\n@Component({\n  selector: 'pdm-select',\n  templateUrl: './select.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class PdmSelectComponent {\n  @Input() id = '';\n  @Input() value = '';\n  @Input() options: PdmSelectOption[] = [];\n  @Input() disabled = false;\n  @Input() invalid = false;\n  @Input() className = '';\n  @Input() placeholder = 'Select an option';\n\n  open = false;\n\n  @Output() valueChange = new EventEmitter<string>();\n\n  constructor(private readonly elementRef: ElementRef<HTMLElement>) {}\n\n  get selectedOption(): PdmSelectOption | undefined {\n    return this.options.find((option) => option.value === this.value);\n  }\n\n  get selectedLabel(): string {\n    return this.selectedOption?.label || this.placeholder;\n  }\n\n  toggle(): void {\n    if (this.disabled) return;\n    this.open = !this.open;\n  }\n\n  onChange(event: Event): void {\n    this.valueChange.emit((event.target as HTMLSelectElement).value);\n  }\n\n  selectOption(option: PdmSelectOption): void {\n    if (option.disabled) return;\n    this.valueChange.emit(option.value);\n    this.open = false;\n  }\n\n  @HostListener('document:click', ['$event'])\n  onDocumentClick(event: MouseEvent): void {\n    if (!this.open) return;\n    if (!this.elementRef.nativeElement.contains(event.target as Node)) {\n      this.open = false;\n    }\n  }\n\n  @HostListener('document:keydown.escape')\n  onEscape(): void {\n    this.open = false;\n  }\n}\n","<div [ngClass]=\"['relative', className || 'w-full']\">\n  <button\n    type=\"button\"\n    [id]=\"id\"\n    [disabled]=\"disabled\"\n    [attr.aria-invalid]=\"invalid\"\n    [attr.aria-expanded]=\"open\"\n    [attr.data-state]=\"open ? 'open' : 'closed'\"\n    aria-haspopup=\"listbox\"\n    (click)=\"toggle()\"\n    [ngClass]=\"[\n      'border-input focus-visible:border-ring focus-visible:ring-2 focus-visible:ring-ring/50 aria-invalid:ring-2 aria-invalid:ring-destructive aria-invalid:border-destructive flex h-9 w-full items-center justify-between rounded-md border bg-background px-3 py-2 text-sm shadow-sm outline-none disabled:cursor-not-allowed disabled:opacity-50',\n    ]\"\n  >\n    <span\n      [ngClass]=\"[\n        'min-w-0 flex-1 truncate text-left leading-5',\n        selectedOption\n          ? 'font-medium text-foreground'\n          : 'font-normal text-muted-foreground',\n      ]\"\n    >\n      {{ selectedLabel }}\n    </span>\n    <pdm-icon\n      name=\"chevron-down\"\n      [size]=\"16\"\n      className=\"shrink-0 text-muted-foreground\"\n    ></pdm-icon>\n  </button>\n\n  <div\n    *ngIf=\"open\"\n    role=\"listbox\"\n    [attr.aria-labelledby]=\"id || null\"\n    class=\"absolute left-0 top-[calc(100%+4px)] z-50 max-h-96 w-full overflow-y-auto rounded-md border border-border bg-popover p-1 text-popover-foreground shadow-md\"\n  >\n    <button\n      *ngFor=\"let option of options\"\n      type=\"button\"\n      role=\"option\"\n      [attr.aria-selected]=\"option.value === value\"\n      [disabled]=\"option.disabled\"\n      (click)=\"selectOption(option)\"\n      [ngClass]=\"[\n        'flex w-full items-center justify-between rounded-sm px-2 py-1.5 text-left text-sm outline-none transition-colors',\n        option.disabled\n          ? 'cursor-not-allowed opacity-50'\n          : 'hover:bg-accent hover:text-accent-foreground focus-visible:bg-accent focus-visible:text-accent-foreground',\n        option.value === value ? 'bg-accent text-accent-foreground' : '',\n      ]\"\n    >\n      <span class=\"min-w-0 flex-1 truncate leading-5\">{{ option.label }}</span>\n      <span\n        *ngIf=\"option.value === value\"\n        class=\"ml-2 flex shrink-0 items-center justify-end\"\n      >\n        <pdm-icon\n          name=\"check\"\n          [size]=\"16\"\n          className=\"shrink-0 text-current\"\n        ></pdm-icon>\n      </span>\n    </button>\n  </div>\n\n  <select\n    class=\"sr-only\"\n    tabindex=\"-1\"\n    aria-hidden=\"true\"\n    [value]=\"value\"\n    (change)=\"onChange($event)\"\n  >\n    <option\n      *ngFor=\"let option of options\"\n      [value]=\"option.value\"\n      [disabled]=\"option.disabled\"\n    >\n      {{ option.label }}\n    </option>\n  </select>\n</div>\n"]}