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.
- package/esm2020/lib/components/button-group/button-group.component.mjs +35 -1
- package/esm2020/lib/components/pagination/pagination.component.mjs +36 -11
- package/esm2020/lib/components/select/select.component.mjs +46 -7
- package/fesm2015/pdm-ui-kit.mjs +142 -45
- package/fesm2015/pdm-ui-kit.mjs.map +1 -1
- package/fesm2020/pdm-ui-kit.mjs +141 -45
- package/fesm2020/pdm-ui-kit.mjs.map +1 -1
- package/lib/components/pagination/pagination.component.d.ts +10 -2
- package/lib/components/select/select.component.d.ts +12 -2
- package/package.json +1 -1
|
@@ -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 =
|
|
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
|
-
|
|
16
|
-
|
|
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
|
|
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
|
|
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
|
|
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,
|
|
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: "<
|
|
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: "<
|
|
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,
|
|
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"]}
|