@radix-ng/primitives 0.20.1 → 0.21.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (65) hide show
  1. package/avatar/src/avatar-fallback.directive.d.ts +1 -1
  2. package/avatar/src/avatar-image.directive.d.ts +3 -3
  3. package/compodoc/documentation.json +6022 -1655
  4. package/core/index.d.ts +1 -0
  5. package/core/src/id-generator.d.ts +12 -0
  6. package/esm2022/avatar/src/avatar-fallback.directive.mjs +6 -8
  7. package/esm2022/avatar/src/avatar-image.directive.mjs +4 -3
  8. package/esm2022/core/index.mjs +2 -1
  9. package/esm2022/core/src/create-inject-context/index.mjs +2 -2
  10. package/esm2022/core/src/id-generator.mjs +43 -0
  11. package/esm2022/popover/index.mjs +14 -4
  12. package/esm2022/popover/src/popover-anchor.directive.mjs +70 -0
  13. package/esm2022/popover/src/popover-anchor.token.mjs +3 -0
  14. package/esm2022/popover/src/popover-arrow.directive.mjs +12 -7
  15. package/esm2022/popover/src/popover-close.directive.mjs +17 -5
  16. package/esm2022/popover/src/popover-close.token.mjs +3 -0
  17. package/esm2022/popover/src/popover-content-attributes.component.mjs +70 -0
  18. package/esm2022/popover/src/popover-content-attributes.token.mjs +3 -0
  19. package/esm2022/popover/src/popover-content.directive.mjs +120 -92
  20. package/esm2022/popover/src/popover-root.directive.mjs +234 -61
  21. package/esm2022/popover/src/popover-root.inject.mjs +4 -4
  22. package/esm2022/popover/src/popover-trigger.directive.mjs +10 -11
  23. package/esm2022/popover/src/popover.constants.mjs +2 -2
  24. package/esm2022/popover/src/popover.types.mjs +18 -1
  25. package/esm2022/popover/src/popover.utils.mjs +4 -6
  26. package/esm2022/switch/src/switch-input.directive.mjs +16 -7
  27. package/esm2022/switch/src/switch-root.directive.mjs +59 -14
  28. package/esm2022/switch/src/switch-thumb.directive.mjs +3 -3
  29. package/esm2022/toggle/index.mjs +2 -2
  30. package/esm2022/toggle/src/toggle-visually-hidden-input.directive.mjs +31 -0
  31. package/esm2022/toggle/src/toggle.directive.mjs +37 -8
  32. package/fesm2022/radix-ng-primitives-avatar.mjs +8 -9
  33. package/fesm2022/radix-ng-primitives-avatar.mjs.map +1 -1
  34. package/fesm2022/radix-ng-primitives-core.mjs +44 -3
  35. package/fesm2022/radix-ng-primitives-core.mjs.map +1 -1
  36. package/fesm2022/radix-ng-primitives-popover.mjs +679 -312
  37. package/fesm2022/radix-ng-primitives-popover.mjs.map +1 -1
  38. package/fesm2022/radix-ng-primitives-switch.mjs +76 -22
  39. package/fesm2022/radix-ng-primitives-switch.mjs.map +1 -1
  40. package/fesm2022/radix-ng-primitives-toggle.mjs +45 -15
  41. package/fesm2022/radix-ng-primitives-toggle.mjs.map +1 -1
  42. package/package.json +1 -1
  43. package/popover/index.d.ts +5 -1
  44. package/popover/src/popover-anchor.directive.d.ts +28 -0
  45. package/popover/src/popover-anchor.token.d.ts +3 -0
  46. package/popover/src/popover-arrow.directive.d.ts +8 -5
  47. package/popover/src/popover-close.directive.d.ts +2 -2
  48. package/popover/src/popover-close.token.d.ts +3 -0
  49. package/popover/src/popover-content-attributes.component.d.ts +17 -0
  50. package/popover/src/popover-content-attributes.token.d.ts +3 -0
  51. package/popover/src/popover-content.directive.d.ts +35 -24
  52. package/popover/src/popover-root.directive.d.ts +91 -18
  53. package/popover/src/popover-root.inject.d.ts +2 -1
  54. package/popover/src/popover-trigger.directive.d.ts +5 -5
  55. package/popover/src/popover.constants.d.ts +1 -1
  56. package/popover/src/popover.types.d.ts +14 -3
  57. package/switch/src/switch-input.directive.d.ts +2 -0
  58. package/switch/src/switch-root.directive.d.ts +33 -5
  59. package/toggle/index.d.ts +2 -2
  60. package/toggle/src/toggle-visually-hidden-input.directive.d.ts +6 -0
  61. package/toggle/src/toggle.directive.d.ts +19 -2
  62. package/esm2022/popover/src/popover-root.token.mjs +0 -3
  63. package/esm2022/toggle/src/toggle-input.directive.mjs +0 -30
  64. package/popover/src/popover-root.token.d.ts +0 -3
  65. package/toggle/src/toggle-input.directive.d.ts +0 -6
@@ -68,9 +68,7 @@ export function getContentPosition(sideAndAlignWithOffsets) {
68
68
  export function getArrowPositionParams(sideAndAlign, arrowWidthAndHeight, triggerWidthAndHeight) {
69
69
  const posParams = {
70
70
  top: '',
71
- bottom: '',
72
71
  left: '',
73
- right: '',
74
72
  transform: ''
75
73
  };
76
74
  if ([RdxPopoverSide.Top, RdxPopoverSide.Bottom].includes(sideAndAlign.side)) {
@@ -88,12 +86,12 @@ export function getArrowPositionParams(sideAndAlign, arrowWidthAndHeight, trigge
88
86
  posParams.left = `calc(50% - ${arrowWidthAndHeight.width / 2}px)`;
89
87
  }
90
88
  else if (sideAndAlign.align === RdxPopoverAlign.End) {
91
- posParams.right = `${(triggerWidthAndHeight.width - arrowWidthAndHeight.width) / 2}px`;
89
+ posParams.left = `calc(100% - ${(triggerWidthAndHeight.width + arrowWidthAndHeight.width) / 2}px)`;
92
90
  }
93
91
  }
94
92
  else if ([RdxPopoverSide.Left, RdxPopoverSide.Right].includes(sideAndAlign.side)) {
95
93
  if (sideAndAlign.side === RdxPopoverSide.Left) {
96
- posParams.right = `-${arrowWidthAndHeight.width}px`;
94
+ posParams.left = `100%`;
97
95
  posParams.transform = `rotate(-90deg) translate(0, -50%)`;
98
96
  }
99
97
  else {
@@ -107,9 +105,9 @@ export function getArrowPositionParams(sideAndAlign, arrowWidthAndHeight, trigge
107
105
  posParams.top = `calc(50% - ${arrowWidthAndHeight.height / 2}px)`;
108
106
  }
109
107
  else if (sideAndAlign.align === RdxPopoverAlign.End) {
110
- posParams.bottom = `${(triggerWidthAndHeight.height - arrowWidthAndHeight.height) / 2}px`;
108
+ posParams.top = `calc(100% - ${(triggerWidthAndHeight.height + arrowWidthAndHeight.height) / 2}px)`;
111
109
  }
112
110
  }
113
111
  return posParams;
114
112
  }
115
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.utils.js","sourceRoot":"","sources":["../../../../../packages/primitives/popover/src/popover.utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { ConnectedPosition, ConnectionPositionPair } from '@angular/cdk/overlay';\nimport { POPOVER_POSITIONS } from './popover.constants';\nimport {\n    RdxAllPossibleConnectedPositions,\n    RdxArrowPositionParams,\n    RdxPopoverAlign,\n    RdxPopoverSide,\n    RdxSideAndAlign,\n    RdxSideAndAlignOffsets\n} from './popover.types';\n\nlet allPossibleConnectedPositions: RdxAllPossibleConnectedPositions;\nexport function getAllPossibleConnectedPositions() {\n    if (!allPossibleConnectedPositions) {\n        allPossibleConnectedPositions = new Map();\n    }\n    if (allPossibleConnectedPositions.size < 1) {\n        Object.keys(POPOVER_POSITIONS).forEach((side) => {\n            Object.keys(POPOVER_POSITIONS[side as RdxPopoverSide] ?? {}).forEach((align) => {\n                (allPossibleConnectedPositions as Map<any, any>).set(\n                    `${side as RdxPopoverSide}|${align as RdxPopoverAlign}`,\n                    POPOVER_POSITIONS[side as RdxPopoverSide][align as RdxPopoverAlign]\n                );\n            });\n        });\n    }\n    return allPossibleConnectedPositions;\n}\n\nexport function getSideAndAlignFromAllPossibleConnectedPositions(position: ConnectionPositionPair): RdxSideAndAlign {\n    const allPossibleConnectedPositions = getAllPossibleConnectedPositions();\n    let sideAndAlign: RdxSideAndAlign | undefined;\n    allPossibleConnectedPositions.forEach((value, key) => {\n        if (\n            position.originX === value.originX &&\n            position.originY === value.originY &&\n            position.overlayX === value.overlayX &&\n            position.overlayY === value.overlayY\n        ) {\n            const sideAndAlignArray = key.split('|');\n            sideAndAlign = {\n                side: sideAndAlignArray[0] as RdxPopoverSide,\n                align: sideAndAlignArray[1] as RdxPopoverAlign\n            };\n        }\n    });\n    if (!sideAndAlign) {\n        throw Error(\n            `[RdxPopover] cannot infer both side and align from the given position (${JSON.stringify(position)})`\n        );\n    }\n    return sideAndAlign;\n}\n\nexport function getContentPosition(\n    sideAndAlignWithOffsets: RdxSideAndAlign & RdxSideAndAlignOffsets\n): ConnectedPosition {\n    const { side, align, sideOffset, alignOffset } = sideAndAlignWithOffsets;\n\n    const position = {\n        ...(POPOVER_POSITIONS[side]?.[align] ?? POPOVER_POSITIONS[RdxPopoverSide.Top][RdxPopoverAlign.Center])\n    };\n\n    if (sideOffset > 0) {\n        let xFactor = 0;\n        let yFactor = 0;\n\n        switch (side) {\n            case RdxPopoverSide.Top:\n                yFactor = -1;\n                break;\n            case RdxPopoverSide.Bottom:\n                yFactor = 1;\n                break;\n            case RdxPopoverSide.Left:\n                xFactor = -1;\n                break;\n            case RdxPopoverSide.Right:\n                xFactor = 1;\n                break;\n        }\n\n        position.offsetX = xFactor * sideOffset;\n        position.offsetY = yFactor * sideOffset;\n    }\n\n    if ([RdxPopoverAlign.Start, RdxPopoverAlign.End].includes(align) && alignOffset) {\n        const alignOffsetFactor = align === RdxPopoverAlign.End ? -1 : 1;\n\n        position.offsetX = alignOffsetFactor * alignOffset;\n    }\n\n    return position;\n}\n\nexport function getArrowPositionParams(\n    sideAndAlign: RdxSideAndAlign,\n    arrowWidthAndHeight: { width: number; height: number },\n    triggerWidthAndHeight: { width: number; height: number }\n): RdxArrowPositionParams {\n    const posParams = {\n        top: '',\n        bottom: '',\n        left: '',\n        right: '',\n        transform: ''\n    };\n\n    if ([RdxPopoverSide.Top, RdxPopoverSide.Bottom].includes(sideAndAlign.side)) {\n        if (sideAndAlign.side === RdxPopoverSide.Top) {\n            posParams.top = '100%';\n        } else {\n            posParams.top = `-${arrowWidthAndHeight.height}px`;\n            posParams.transform = `rotate(180deg)`;\n        }\n\n        if (sideAndAlign.align === RdxPopoverAlign.Start) {\n            posParams.left = `${(triggerWidthAndHeight.width - arrowWidthAndHeight.width) / 2}px`;\n        } else if (sideAndAlign.align === RdxPopoverAlign.Center) {\n            posParams.left = `calc(50% - ${arrowWidthAndHeight.width / 2}px)`;\n        } else if (sideAndAlign.align === RdxPopoverAlign.End) {\n            posParams.right = `${(triggerWidthAndHeight.width - arrowWidthAndHeight.width) / 2}px`;\n        }\n    } else if ([RdxPopoverSide.Left, RdxPopoverSide.Right].includes(sideAndAlign.side)) {\n        if (sideAndAlign.side === RdxPopoverSide.Left) {\n            posParams.right = `-${arrowWidthAndHeight.width}px`;\n            posParams.transform = `rotate(-90deg) translate(0, -50%)`;\n        } else {\n            posParams.left = `-${arrowWidthAndHeight.width}px`;\n            posParams.transform = `rotate(90deg) translate(0, -50%)`;\n        }\n\n        if (sideAndAlign.align === RdxPopoverAlign.Start) {\n            posParams.top = `${(triggerWidthAndHeight.height - arrowWidthAndHeight.height) / 2}px`;\n        } else if (sideAndAlign.align === RdxPopoverAlign.Center) {\n            posParams.top = `calc(50% - ${arrowWidthAndHeight.height / 2}px)`;\n        } else if (sideAndAlign.align === RdxPopoverAlign.End) {\n            posParams.bottom = `${(triggerWidthAndHeight.height - arrowWidthAndHeight.height) / 2}px`;\n        }\n    }\n\n    return posParams;\n}\n"]}
113
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.utils.js","sourceRoot":"","sources":["../../../../../packages/primitives/popover/src/popover.utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { ConnectedPosition, ConnectionPositionPair } from '@angular/cdk/overlay';\nimport { POPOVER_POSITIONS } from './popover.constants';\nimport {\n    RdxAllPossibleConnectedPositions,\n    RdxArrowPositionParams,\n    RdxPopoverAlign,\n    RdxPopoverSide,\n    RdxSideAndAlign,\n    RdxSideAndAlignOffsets\n} from './popover.types';\n\nlet allPossibleConnectedPositions: RdxAllPossibleConnectedPositions;\nexport function getAllPossibleConnectedPositions() {\n    if (!allPossibleConnectedPositions) {\n        allPossibleConnectedPositions = new Map();\n    }\n    if (allPossibleConnectedPositions.size < 1) {\n        Object.keys(POPOVER_POSITIONS).forEach((side) => {\n            Object.keys(POPOVER_POSITIONS[side as RdxPopoverSide] ?? {}).forEach((align) => {\n                (allPossibleConnectedPositions as Map<any, any>).set(\n                    `${side as RdxPopoverSide}|${align as RdxPopoverAlign}`,\n                    POPOVER_POSITIONS[side as RdxPopoverSide][align as RdxPopoverAlign]\n                );\n            });\n        });\n    }\n    return allPossibleConnectedPositions;\n}\n\nexport function getSideAndAlignFromAllPossibleConnectedPositions(position: ConnectionPositionPair): RdxSideAndAlign {\n    const allPossibleConnectedPositions = getAllPossibleConnectedPositions();\n    let sideAndAlign: RdxSideAndAlign | undefined;\n    allPossibleConnectedPositions.forEach((value, key) => {\n        if (\n            position.originX === value.originX &&\n            position.originY === value.originY &&\n            position.overlayX === value.overlayX &&\n            position.overlayY === value.overlayY\n        ) {\n            const sideAndAlignArray = key.split('|');\n            sideAndAlign = {\n                side: sideAndAlignArray[0] as RdxPopoverSide,\n                align: sideAndAlignArray[1] as RdxPopoverAlign\n            };\n        }\n    });\n    if (!sideAndAlign) {\n        throw Error(\n            `[RdxPopover] cannot infer both side and align from the given position (${JSON.stringify(position)})`\n        );\n    }\n    return sideAndAlign;\n}\n\nexport function getContentPosition(\n    sideAndAlignWithOffsets: RdxSideAndAlign & RdxSideAndAlignOffsets\n): ConnectedPosition {\n    const { side, align, sideOffset, alignOffset } = sideAndAlignWithOffsets;\n\n    const position = {\n        ...(POPOVER_POSITIONS[side]?.[align] ?? POPOVER_POSITIONS[RdxPopoverSide.Top][RdxPopoverAlign.Center])\n    };\n\n    if (sideOffset > 0) {\n        let xFactor = 0;\n        let yFactor = 0;\n\n        switch (side) {\n            case RdxPopoverSide.Top:\n                yFactor = -1;\n                break;\n            case RdxPopoverSide.Bottom:\n                yFactor = 1;\n                break;\n            case RdxPopoverSide.Left:\n                xFactor = -1;\n                break;\n            case RdxPopoverSide.Right:\n                xFactor = 1;\n                break;\n        }\n\n        position.offsetX = xFactor * sideOffset;\n        position.offsetY = yFactor * sideOffset;\n    }\n\n    if ([RdxPopoverAlign.Start, RdxPopoverAlign.End].includes(align) && alignOffset) {\n        const alignOffsetFactor = align === RdxPopoverAlign.End ? -1 : 1;\n\n        position.offsetX = alignOffsetFactor * alignOffset;\n    }\n\n    return position;\n}\n\nexport function getArrowPositionParams(\n    sideAndAlign: RdxSideAndAlign,\n    arrowWidthAndHeight: { width: number; height: number },\n    triggerWidthAndHeight: { width: number; height: number }\n): RdxArrowPositionParams {\n    const posParams: RdxArrowPositionParams = {\n        top: '',\n        left: '',\n        transform: ''\n    };\n\n    if ([RdxPopoverSide.Top, RdxPopoverSide.Bottom].includes(sideAndAlign.side)) {\n        if (sideAndAlign.side === RdxPopoverSide.Top) {\n            posParams.top = '100%';\n        } else {\n            posParams.top = `-${arrowWidthAndHeight.height}px`;\n            posParams.transform = `rotate(180deg)`;\n        }\n\n        if (sideAndAlign.align === RdxPopoverAlign.Start) {\n            posParams.left = `${(triggerWidthAndHeight.width - arrowWidthAndHeight.width) / 2}px`;\n        } else if (sideAndAlign.align === RdxPopoverAlign.Center) {\n            posParams.left = `calc(50% - ${arrowWidthAndHeight.width / 2}px)`;\n        } else if (sideAndAlign.align === RdxPopoverAlign.End) {\n            posParams.left = `calc(100% - ${(triggerWidthAndHeight.width + arrowWidthAndHeight.width) / 2}px)`;\n        }\n    } else if ([RdxPopoverSide.Left, RdxPopoverSide.Right].includes(sideAndAlign.side)) {\n        if (sideAndAlign.side === RdxPopoverSide.Left) {\n            posParams.left = `100%`;\n            posParams.transform = `rotate(-90deg) translate(0, -50%)`;\n        } else {\n            posParams.left = `-${arrowWidthAndHeight.width}px`;\n            posParams.transform = `rotate(90deg) translate(0, -50%)`;\n        }\n\n        if (sideAndAlign.align === RdxPopoverAlign.Start) {\n            posParams.top = `${(triggerWidthAndHeight.height - arrowWidthAndHeight.height) / 2}px`;\n        } else if (sideAndAlign.align === RdxPopoverAlign.Center) {\n            posParams.top = `calc(50% - ${arrowWidthAndHeight.height / 2}px)`;\n        } else if (sideAndAlign.align === RdxPopoverAlign.End) {\n            posParams.top = `calc(100% - ${(triggerWidthAndHeight.height + arrowWidthAndHeight.height) / 2}px)`;\n        }\n    }\n\n    return posParams;\n}\n"]}
@@ -5,8 +5,12 @@ export class RdxSwitchInputDirective {
5
5
  constructor() {
6
6
  this.switchRoot = injectSwitch();
7
7
  }
8
+ /** @ignore */
9
+ onBlur() {
10
+ this.switchRoot.onTouched?.();
11
+ }
8
12
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxSwitchInputDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
9
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.11", type: RdxSwitchInputDirective, isStandalone: true, selector: "input[rdxSwitchInput]", host: { attributes: { "type": "checkbox", "tabindex": "-1" }, properties: { "attr.defaultChecked": "switchRoot.checked()", "attr.aria-checked": "switchRoot.checked()", "attr.aria-hidden": "true", "attr.aria-required": "switchRoot.required()", "attr.data-state": "switchRoot.checked() ? \"checked\" : \"unchecked\"", "attr.data-disabled": "switchRoot.disabledState() ? \"true\" : null", "attr.disabled": "switchRoot.disabledState() ? switchRoot.disabledState() : null", "attr.value": "switchRoot.checked() ? \"on\" : \"off\"" }, styleAttribute: "transform: translateX(-100%); position: absolute; overflow: hidden; pointerEvents: none; opacity: 0; margin: 0;" }, exportAs: ["rdxSwitchInput"], ngImport: i0 }); }
13
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.11", type: RdxSwitchInputDirective, isStandalone: true, selector: "input[rdxSwitchInput]", host: { attributes: { "type": "checkbox", "role": "switch", "tabindex": "-1" }, listeners: { "blur": "onBlur()" }, properties: { "attr.id": "switchRoot.inputId()", "attr.defaultChecked": "switchRoot.checkedState()", "attr.aria-checked": "switchRoot.checkedState()", "attr.aria-hidden": "true", "attr.aria-label": "switchRoot.ariaLabel()", "attr.aria-labelledby": "switchRoot.ariaLabelledBy()", "attr.aria-required": "switchRoot.required()", "attr.data-state": "switchRoot.checkedState() ? \"checked\" : \"unchecked\"", "attr.data-disabled": "switchRoot.disabledState() ? \"true\" : null", "attr.disabled": "switchRoot.disabledState() ? switchRoot.disabledState() : null", "attr.value": "switchRoot.checkedState() ? \"on\" : \"off\"" }, styleAttribute: "transform: translateX(-100%); position: absolute; overflow: hidden; pointerEvents: none; opacity: 0; margin: 0;" }, exportAs: ["rdxSwitchInput"], ngImport: i0 }); }
10
14
  }
11
15
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxSwitchInputDirective, decorators: [{
12
16
  type: Directive,
@@ -16,17 +20,22 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImpo
16
20
  standalone: true,
17
21
  host: {
18
22
  type: 'checkbox',
23
+ role: 'switch',
19
24
  tabindex: '-1',
20
- '[attr.defaultChecked]': 'switchRoot.checked()',
21
- '[attr.aria-checked]': 'switchRoot.checked()',
25
+ '[attr.id]': 'switchRoot.inputId()',
26
+ '[attr.defaultChecked]': 'switchRoot.checkedState()',
27
+ '[attr.aria-checked]': 'switchRoot.checkedState()',
22
28
  '[attr.aria-hidden]': 'true',
29
+ '[attr.aria-label]': 'switchRoot.ariaLabel()',
30
+ '[attr.aria-labelledby]': 'switchRoot.ariaLabelledBy()',
23
31
  '[attr.aria-required]': 'switchRoot.required()',
24
- '[attr.data-state]': 'switchRoot.checked() ? "checked" : "unchecked"',
32
+ '[attr.data-state]': 'switchRoot.checkedState() ? "checked" : "unchecked"',
25
33
  '[attr.data-disabled]': 'switchRoot.disabledState() ? "true" : null',
26
34
  '[attr.disabled]': 'switchRoot.disabledState() ? switchRoot.disabledState() : null',
27
- '[attr.value]': 'switchRoot.checked() ? "on" : "off"',
28
- style: 'transform: translateX(-100%); position: absolute; overflow: hidden; pointerEvents: none; opacity: 0; margin: 0;'
35
+ '[attr.value]': 'switchRoot.checkedState() ? "on" : "off"',
36
+ style: 'transform: translateX(-100%); position: absolute; overflow: hidden; pointerEvents: none; opacity: 0; margin: 0;',
37
+ '(blur)': 'onBlur()'
29
38
  }
30
39
  }]
31
40
  }] });
32
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3dpdGNoLWlucHV0LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3ByaW1pdGl2ZXMvc3dpdGNoL3NyYy9zd2l0Y2gtaW5wdXQuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHlCQUF5QixDQUFDOztBQW9CdkQsTUFBTSxPQUFPLHVCQUF1QjtJQWxCcEM7UUFtQnVCLGVBQVUsR0FBRyxZQUFZLEVBQUUsQ0FBQztLQUNsRDsrR0FGWSx1QkFBdUI7bUdBQXZCLHVCQUF1Qjs7NEZBQXZCLHVCQUF1QjtrQkFsQm5DLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLHVCQUF1QjtvQkFDakMsUUFBUSxFQUFFLGdCQUFnQjtvQkFDMUIsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLElBQUksRUFBRTt3QkFDRixJQUFJLEVBQUUsVUFBVTt3QkFDaEIsUUFBUSxFQUFFLElBQUk7d0JBQ2QsdUJBQXVCLEVBQUUsc0JBQXNCO3dCQUMvQyxxQkFBcUIsRUFBRSxzQkFBc0I7d0JBQzdDLG9CQUFvQixFQUFFLE1BQU07d0JBQzVCLHNCQUFzQixFQUFFLHVCQUF1Qjt3QkFDL0MsbUJBQW1CLEVBQUUsZ0RBQWdEO3dCQUNyRSxzQkFBc0IsRUFBRSw0Q0FBNEM7d0JBQ3BFLGlCQUFpQixFQUFFLGdFQUFnRTt3QkFDbkYsY0FBYyxFQUFFLHFDQUFxQzt3QkFDckQsS0FBSyxFQUFFLGlIQUFpSDtxQkFDM0g7aUJBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGluamVjdFN3aXRjaCB9IGZyb20gJy4vc3dpdGNoLXJvb3QuZGlyZWN0aXZlJztcblxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdpbnB1dFtyZHhTd2l0Y2hJbnB1dF0nLFxuICAgIGV4cG9ydEFzOiAncmR4U3dpdGNoSW5wdXQnLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaG9zdDoge1xuICAgICAgICB0eXBlOiAnY2hlY2tib3gnLFxuICAgICAgICB0YWJpbmRleDogJy0xJyxcbiAgICAgICAgJ1thdHRyLmRlZmF1bHRDaGVja2VkXSc6ICdzd2l0Y2hSb290LmNoZWNrZWQoKScsXG4gICAgICAgICdbYXR0ci5hcmlhLWNoZWNrZWRdJzogJ3N3aXRjaFJvb3QuY2hlY2tlZCgpJyxcbiAgICAgICAgJ1thdHRyLmFyaWEtaGlkZGVuXSc6ICd0cnVlJyxcbiAgICAgICAgJ1thdHRyLmFyaWEtcmVxdWlyZWRdJzogJ3N3aXRjaFJvb3QucmVxdWlyZWQoKScsXG4gICAgICAgICdbYXR0ci5kYXRhLXN0YXRlXSc6ICdzd2l0Y2hSb290LmNoZWNrZWQoKSA/IFwiY2hlY2tlZFwiIDogXCJ1bmNoZWNrZWRcIicsXG4gICAgICAgICdbYXR0ci5kYXRhLWRpc2FibGVkXSc6ICdzd2l0Y2hSb290LmRpc2FibGVkU3RhdGUoKSA/IFwidHJ1ZVwiIDogbnVsbCcsXG4gICAgICAgICdbYXR0ci5kaXNhYmxlZF0nOiAnc3dpdGNoUm9vdC5kaXNhYmxlZFN0YXRlKCkgPyBzd2l0Y2hSb290LmRpc2FibGVkU3RhdGUoKSA6IG51bGwnLFxuICAgICAgICAnW2F0dHIudmFsdWVdJzogJ3N3aXRjaFJvb3QuY2hlY2tlZCgpID8gXCJvblwiIDogXCJvZmZcIicsXG4gICAgICAgIHN0eWxlOiAndHJhbnNmb3JtOiB0cmFuc2xhdGVYKC0xMDAlKTsgcG9zaXRpb246IGFic29sdXRlOyBvdmVyZmxvdzogaGlkZGVuOyBwb2ludGVyRXZlbnRzOiBub25lOyBvcGFjaXR5OiAwOyBtYXJnaW46IDA7J1xuICAgIH1cbn0pXG5leHBvcnQgY2xhc3MgUmR4U3dpdGNoSW5wdXREaXJlY3RpdmUge1xuICAgIHByb3RlY3RlZCByZWFkb25seSBzd2l0Y2hSb290ID0gaW5qZWN0U3dpdGNoKCk7XG59XG4iXX0=
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3dpdGNoLWlucHV0LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3ByaW1pdGl2ZXMvc3dpdGNoL3NyYy9zd2l0Y2gtaW5wdXQuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHlCQUF5QixDQUFDOztBQTBCdkQsTUFBTSxPQUFPLHVCQUF1QjtJQXhCcEM7UUF5QnVCLGVBQVUsR0FBRyxZQUFZLEVBQUUsQ0FBQztLQU1sRDtJQUpHLGNBQWM7SUFDSixNQUFNO1FBQ1osSUFBSSxDQUFDLFVBQVUsQ0FBQyxTQUFTLEVBQUUsRUFBRSxDQUFDO0lBQ2xDLENBQUM7K0dBTlEsdUJBQXVCO21HQUF2Qix1QkFBdUI7OzRGQUF2Qix1QkFBdUI7a0JBeEJuQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSx1QkFBdUI7b0JBQ2pDLFFBQVEsRUFBRSxnQkFBZ0I7b0JBQzFCLFVBQVUsRUFBRSxJQUFJO29CQUNoQixJQUFJLEVBQUU7d0JBQ0YsSUFBSSxFQUFFLFVBQVU7d0JBQ2hCLElBQUksRUFBRSxRQUFRO3dCQUNkLFFBQVEsRUFBRSxJQUFJO3dCQUNkLFdBQVcsRUFBRSxzQkFBc0I7d0JBQ25DLHVCQUF1QixFQUFFLDJCQUEyQjt3QkFDcEQscUJBQXFCLEVBQUUsMkJBQTJCO3dCQUNsRCxvQkFBb0IsRUFBRSxNQUFNO3dCQUM1QixtQkFBbUIsRUFBRSx3QkFBd0I7d0JBQzdDLHdCQUF3QixFQUFFLDZCQUE2Qjt3QkFDdkQsc0JBQXNCLEVBQUUsdUJBQXVCO3dCQUMvQyxtQkFBbUIsRUFBRSxxREFBcUQ7d0JBQzFFLHNCQUFzQixFQUFFLDRDQUE0Qzt3QkFDcEUsaUJBQWlCLEVBQUUsZ0VBQWdFO3dCQUNuRixjQUFjLEVBQUUsMENBQTBDO3dCQUMxRCxLQUFLLEVBQUUsaUhBQWlIO3dCQUV4SCxRQUFRLEVBQUUsVUFBVTtxQkFDdkI7aUJBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGluamVjdFN3aXRjaCB9IGZyb20gJy4vc3dpdGNoLXJvb3QuZGlyZWN0aXZlJztcblxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdpbnB1dFtyZHhTd2l0Y2hJbnB1dF0nLFxuICAgIGV4cG9ydEFzOiAncmR4U3dpdGNoSW5wdXQnLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaG9zdDoge1xuICAgICAgICB0eXBlOiAnY2hlY2tib3gnLFxuICAgICAgICByb2xlOiAnc3dpdGNoJyxcbiAgICAgICAgdGFiaW5kZXg6ICctMScsXG4gICAgICAgICdbYXR0ci5pZF0nOiAnc3dpdGNoUm9vdC5pbnB1dElkKCknLFxuICAgICAgICAnW2F0dHIuZGVmYXVsdENoZWNrZWRdJzogJ3N3aXRjaFJvb3QuY2hlY2tlZFN0YXRlKCknLFxuICAgICAgICAnW2F0dHIuYXJpYS1jaGVja2VkXSc6ICdzd2l0Y2hSb290LmNoZWNrZWRTdGF0ZSgpJyxcbiAgICAgICAgJ1thdHRyLmFyaWEtaGlkZGVuXSc6ICd0cnVlJyxcbiAgICAgICAgJ1thdHRyLmFyaWEtbGFiZWxdJzogJ3N3aXRjaFJvb3QuYXJpYUxhYmVsKCknLFxuICAgICAgICAnW2F0dHIuYXJpYS1sYWJlbGxlZGJ5XSc6ICdzd2l0Y2hSb290LmFyaWFMYWJlbGxlZEJ5KCknLFxuICAgICAgICAnW2F0dHIuYXJpYS1yZXF1aXJlZF0nOiAnc3dpdGNoUm9vdC5yZXF1aXJlZCgpJyxcbiAgICAgICAgJ1thdHRyLmRhdGEtc3RhdGVdJzogJ3N3aXRjaFJvb3QuY2hlY2tlZFN0YXRlKCkgPyBcImNoZWNrZWRcIiA6IFwidW5jaGVja2VkXCInLFxuICAgICAgICAnW2F0dHIuZGF0YS1kaXNhYmxlZF0nOiAnc3dpdGNoUm9vdC5kaXNhYmxlZFN0YXRlKCkgPyBcInRydWVcIiA6IG51bGwnLFxuICAgICAgICAnW2F0dHIuZGlzYWJsZWRdJzogJ3N3aXRjaFJvb3QuZGlzYWJsZWRTdGF0ZSgpID8gc3dpdGNoUm9vdC5kaXNhYmxlZFN0YXRlKCkgOiBudWxsJyxcbiAgICAgICAgJ1thdHRyLnZhbHVlXSc6ICdzd2l0Y2hSb290LmNoZWNrZWRTdGF0ZSgpID8gXCJvblwiIDogXCJvZmZcIicsXG4gICAgICAgIHN0eWxlOiAndHJhbnNmb3JtOiB0cmFuc2xhdGVYKC0xMDAlKTsgcG9zaXRpb246IGFic29sdXRlOyBvdmVyZmxvdzogaGlkZGVuOyBwb2ludGVyRXZlbnRzOiBub25lOyBvcGFjaXR5OiAwOyBtYXJnaW46IDA7JyxcblxuICAgICAgICAnKGJsdXIpJzogJ29uQmx1cigpJ1xuICAgIH1cbn0pXG5leHBvcnQgY2xhc3MgUmR4U3dpdGNoSW5wdXREaXJlY3RpdmUge1xuICAgIHByb3RlY3RlZCByZWFkb25seSBzd2l0Y2hSb290ID0gaW5qZWN0U3dpdGNoKCk7XG5cbiAgICAvKiogQGlnbm9yZSAqL1xuICAgIHByb3RlY3RlZCBvbkJsdXIoKSB7XG4gICAgICAgIHRoaXMuc3dpdGNoUm9vdC5vblRvdWNoZWQ/LigpO1xuICAgIH1cbn1cbiJdfQ==
@@ -1,53 +1,98 @@
1
- import { booleanAttribute, computed, Directive, inject, InjectionToken, input, model, output } from '@angular/core';
1
+ import { booleanAttribute, computed, Directive, effect, forwardRef, inject, InjectionToken, input, model, output, signal } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
2
3
  import * as i0 from "@angular/core";
3
4
  export const RdxSwitchToken = new InjectionToken('RdxSwitchToken');
4
5
  export function injectSwitch() {
5
6
  return inject(RdxSwitchToken);
6
7
  }
8
+ export const SWITCH_VALUE_ACCESSOR = {
9
+ provide: NG_VALUE_ACCESSOR,
10
+ useExisting: forwardRef(() => RdxSwitchRootDirective),
11
+ multi: true
12
+ };
7
13
  let idIterator = 0;
8
14
  export class RdxSwitchRootDirective {
9
15
  constructor() {
10
16
  this.id = input(`rdx-switch-${idIterator++}`);
11
17
  this.elementId = computed(() => (this.id() ? this.id() : null));
18
+ this.inputId = input(null);
12
19
  /**
13
20
  * When true, indicates that the user must check the switch before the owning form can be submitted.
14
21
  */
15
22
  this.required = input(false, {
16
23
  transform: booleanAttribute
17
24
  });
25
+ this.ariaLabelledBy = input(null, {
26
+ alias: 'aria-labelledby'
27
+ });
28
+ this.ariaLabel = input(null, {
29
+ alias: 'aria-label'
30
+ });
18
31
  /**
19
32
  * The controlled state of the switch. Must be used in conjunction with onCheckedChange.
20
33
  */
21
34
  this.checked = model(false);
35
+ this.defaultChecked = input(false, { transform: booleanAttribute });
36
+ /**
37
+ * The state of the switch.
38
+ * If `defaultChecked` is provided, it takes precedence over the `checked` state.
39
+ * @ignore
40
+ */
41
+ this.checkedState = computed(() => this.checked());
22
42
  /**
23
43
  * When true, prevents the user from interacting with the switch.
24
44
  */
25
45
  this.disabled = input(false, {
26
46
  transform: booleanAttribute
27
47
  });
28
- /*
29
- * @ignore
30
- */
31
- this.disabledState = computed(() => this.disabled());
48
+ /** @ignore */
49
+ this.disabledState = computed(() => this.disabled() || this.accessorDisabled());
32
50
  /**
33
51
  * Event handler called when the state of the switch changes.
34
52
  */
35
53
  this.onCheckedChange = output();
54
+ this.defaultCheckedUsed = computed(() => this.defaultChecked());
55
+ this.accessorDisabled = signal(false);
56
+ this.onChange = () => { };
57
+ effect(() => {
58
+ if (this.defaultCheckedUsed()) {
59
+ this.checked.set(this.defaultChecked());
60
+ }
61
+ }, { allowSignalWrites: true });
36
62
  }
37
63
  /**
38
64
  * Toggles the checked state of the switch.
39
65
  * If the switch is disabled, the function returns early.
66
+ * @ignore
40
67
  */
41
68
  toggle() {
42
69
  if (this.disabledState()) {
43
70
  return;
44
71
  }
45
72
  this.checked.set(!this.checked());
73
+ this.onChange(this.checked());
46
74
  this.onCheckedChange.emit(this.checked());
47
75
  }
76
+ /** @ignore */
77
+ writeValue(value) {
78
+ this.checked.set(value);
79
+ }
80
+ /** @ignore */
81
+ registerOnChange(fn) {
82
+ this.onChange = fn;
83
+ }
84
+ /** @ignore */
85
+ registerOnTouched(fn) {
86
+ this.onTouched = fn;
87
+ }
88
+ /** @ignore */
89
+ setDisabledState(isDisabled) {
90
+ this.accessorDisabled.set(isDisabled);
91
+ }
48
92
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxSwitchRootDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
49
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.11", type: RdxSwitchRootDirective, isStandalone: true, selector: "button[rdxSwitchRoot]", inputs: { id: { classPropertyName: "id", publicName: "id", isSignal: true, isRequired: false, transformFunction: null }, required: { classPropertyName: "required", publicName: "required", isSignal: true, isRequired: false, transformFunction: null }, checked: { classPropertyName: "checked", publicName: "checked", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { checked: "checkedChange", onCheckedChange: "onCheckedChange" }, host: { attributes: { "role": "switch", "type": "button" }, listeners: { "click": "toggle()" }, properties: { "id": "elementId()", "attr.aria-checked": "checked()", "attr.aria-required": "required", "attr.data-state": "checked() ? \"checked\" : \"unchecked\"", "attr.data-disabled": "disabledState() ? \"true\" : null", "attr.disabled": "disabledState() ? disabledState() : null" } }, providers: [
50
- { provide: RdxSwitchToken, useExisting: RdxSwitchRootDirective }
93
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.11", type: RdxSwitchRootDirective, isStandalone: true, selector: "button[rdxSwitchRoot]", inputs: { id: { classPropertyName: "id", publicName: "id", isSignal: true, isRequired: false, transformFunction: null }, inputId: { classPropertyName: "inputId", publicName: "inputId", isSignal: true, isRequired: false, transformFunction: null }, required: { classPropertyName: "required", publicName: "required", isSignal: true, isRequired: false, transformFunction: null }, ariaLabelledBy: { classPropertyName: "ariaLabelledBy", publicName: "aria-labelledby", isSignal: true, isRequired: false, transformFunction: null }, ariaLabel: { classPropertyName: "ariaLabel", publicName: "aria-label", isSignal: true, isRequired: false, transformFunction: null }, checked: { classPropertyName: "checked", publicName: "checked", isSignal: true, isRequired: false, transformFunction: null }, defaultChecked: { classPropertyName: "defaultChecked", publicName: "defaultChecked", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { checked: "checkedChange", onCheckedChange: "onCheckedChange" }, host: { attributes: { "type": "button" }, listeners: { "click": "toggle()" }, properties: { "id": "elementId()", "attr.aria-checked": "checkedState()", "attr.aria-required": "required()", "attr.data-state": "checkedState() ? \"checked\" : \"unchecked\"", "attr.data-disabled": "disabledState() ? \"true\" : null", "attr.disabled": "disabledState() ? disabledState() : null" } }, providers: [
94
+ { provide: RdxSwitchToken, useExisting: RdxSwitchRootDirective },
95
+ SWITCH_VALUE_ACCESSOR
51
96
  ], exportAs: ["rdxSwitchRoot"], ngImport: i0 }); }
52
97
  }
53
98
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxSwitchRootDirective, decorators: [{
@@ -57,19 +102,19 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImpo
57
102
  exportAs: 'rdxSwitchRoot',
58
103
  standalone: true,
59
104
  providers: [
60
- { provide: RdxSwitchToken, useExisting: RdxSwitchRootDirective }
105
+ { provide: RdxSwitchToken, useExisting: RdxSwitchRootDirective },
106
+ SWITCH_VALUE_ACCESSOR
61
107
  ],
62
108
  host: {
63
- role: 'switch',
64
109
  type: 'button',
65
110
  '[id]': 'elementId()',
66
- '[attr.aria-checked]': 'checked()',
67
- '[attr.aria-required]': 'required',
68
- '[attr.data-state]': 'checked() ? "checked" : "unchecked"',
111
+ '[attr.aria-checked]': 'checkedState()',
112
+ '[attr.aria-required]': 'required()',
113
+ '[attr.data-state]': 'checkedState() ? "checked" : "unchecked"',
69
114
  '[attr.data-disabled]': 'disabledState() ? "true" : null',
70
115
  '[attr.disabled]': 'disabledState() ? disabledState() : null',
71
116
  '(click)': 'toggle()'
72
117
  }
73
118
  }]
74
- }] });
75
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3dpdGNoLXJvb3QuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvcHJpbWl0aXZlcy9zd2l0Y2gvc3JjL3N3aXRjaC1yb290LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQ0gsZ0JBQWdCLEVBQ2hCLFFBQVEsRUFDUixTQUFTLEVBQ1QsTUFBTSxFQUNOLGNBQWMsRUFDZCxLQUFLLEVBRUwsS0FBSyxFQUVMLE1BQU0sRUFFVCxNQUFNLGVBQWUsQ0FBQzs7QUFFdkIsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFHLElBQUksY0FBYyxDQUF5QixnQkFBZ0IsQ0FBQyxDQUFDO0FBRTNGLE1BQU0sVUFBVSxZQUFZO0lBQ3hCLE9BQU8sTUFBTSxDQUFDLGNBQWMsQ0FBQyxDQUFDO0FBQ2xDLENBQUM7QUFTRCxJQUFJLFVBQVUsR0FBRyxDQUFDLENBQUM7QUFxQm5CLE1BQU0sT0FBTyxzQkFBc0I7SUFuQm5DO1FBb0JhLE9BQUUsR0FBRyxLQUFLLENBQVMsY0FBYyxVQUFVLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFDdkMsY0FBUyxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO1FBRTlFOztXQUVHO1FBQ00sYUFBUSxHQUFHLEtBQUssQ0FBd0IsS0FBSyxFQUFFO1lBQ3BELFNBQVMsRUFBRSxnQkFBZ0I7U0FDOUIsQ0FBQyxDQUFDO1FBRUg7O1dBRUc7UUFDTSxZQUFPLEdBQUcsS0FBSyxDQUFVLEtBQUssQ0FBQyxDQUFDO1FBRXpDOztXQUVHO1FBQ00sYUFBUSxHQUFHLEtBQUssQ0FBd0IsS0FBSyxFQUFFO1lBQ3BELFNBQVMsRUFBRSxnQkFBZ0I7U0FDOUIsQ0FBQyxDQUFDO1FBRUg7O1dBRUc7UUFDTSxrQkFBYSxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQztRQUV6RDs7V0FFRztRQUNNLG9CQUFlLEdBQUcsTUFBTSxFQUFXLENBQUM7S0FlaEQ7SUFiRzs7O09BR0c7SUFDTyxNQUFNO1FBQ1osSUFBSSxJQUFJLENBQUMsYUFBYSxFQUFFLEVBQUUsQ0FBQztZQUN2QixPQUFPO1FBQ1gsQ0FBQztRQUVELElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUM7UUFFbEMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUM7SUFDOUMsQ0FBQzsrR0E3Q1Esc0JBQXNCO21HQUF0QixzQkFBc0IsMmdDQWZwQjtZQUNQLEVBQUUsT0FBTyxFQUFFLGNBQWMsRUFBRSxXQUFXLEVBQUUsc0JBQXNCLEVBQUU7U0FBQzs7NEZBYzVELHNCQUFzQjtrQkFuQmxDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLHVCQUF1QjtvQkFDakMsUUFBUSxFQUFFLGVBQWU7b0JBQ3pCLFVBQVUsRUFBRSxJQUFJO29CQUNoQixTQUFTLEVBQUU7d0JBQ1AsRUFBRSxPQUFPLEVBQUUsY0FBYyxFQUFFLFdBQVcsd0JBQXdCLEVBQUU7cUJBQUM7b0JBQ3JFLElBQUksRUFBRTt3QkFDRixJQUFJLEVBQUUsUUFBUTt3QkFDZCxJQUFJLEVBQUUsUUFBUTt3QkFDZCxNQUFNLEVBQUUsYUFBYTt3QkFDckIscUJBQXFCLEVBQUUsV0FBVzt3QkFDbEMsc0JBQXNCLEVBQUUsVUFBVTt3QkFDbEMsbUJBQW1CLEVBQUUscUNBQXFDO3dCQUMxRCxzQkFBc0IsRUFBRSxpQ0FBaUM7d0JBQ3pELGlCQUFpQixFQUFFLDBDQUEwQzt3QkFFN0QsU0FBUyxFQUFFLFVBQVU7cUJBQ3hCO2lCQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQm9vbGVhbklucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2NvZXJjaW9uJztcbmltcG9ydCB7XG4gICAgYm9vbGVhbkF0dHJpYnV0ZSxcbiAgICBjb21wdXRlZCxcbiAgICBEaXJlY3RpdmUsXG4gICAgaW5qZWN0LFxuICAgIEluamVjdGlvblRva2VuLFxuICAgIGlucHV0LFxuICAgIElucHV0U2lnbmFsV2l0aFRyYW5zZm9ybSxcbiAgICBtb2RlbCxcbiAgICBNb2RlbFNpZ25hbCxcbiAgICBvdXRwdXQsXG4gICAgT3V0cHV0RW1pdHRlclJlZlxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuZXhwb3J0IGNvbnN0IFJkeFN3aXRjaFRva2VuID0gbmV3IEluamVjdGlvblRva2VuPFJkeFN3aXRjaFJvb3REaXJlY3RpdmU+KCdSZHhTd2l0Y2hUb2tlbicpO1xuXG5leHBvcnQgZnVuY3Rpb24gaW5qZWN0U3dpdGNoKCk6IFJkeFN3aXRjaFJvb3REaXJlY3RpdmUge1xuICAgIHJldHVybiBpbmplY3QoUmR4U3dpdGNoVG9rZW4pO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFN3aXRjaFByb3BzIHtcbiAgICBjaGVja2VkPzogTW9kZWxTaWduYWw8Ym9vbGVhbj47XG4gICAgZGVmYXVsdENoZWNrZWQ/OiBib29sZWFuO1xuICAgIHJlcXVpcmVkPzogSW5wdXRTaWduYWxXaXRoVHJhbnNmb3JtPGJvb2xlYW4sIEJvb2xlYW5JbnB1dD47XG4gICAgb25DaGVja2VkQ2hhbmdlPzogT3V0cHV0RW1pdHRlclJlZjxib29sZWFuPjtcbn1cblxubGV0IGlkSXRlcmF0b3IgPSAwO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ2J1dHRvbltyZHhTd2l0Y2hSb290XScsXG4gICAgZXhwb3J0QXM6ICdyZHhTd2l0Y2hSb290JyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIHByb3ZpZGVyczogW1xuICAgICAgICB7IHByb3ZpZGU6IFJkeFN3aXRjaFRva2VuLCB1c2VFeGlzdGluZzogUmR4U3dpdGNoUm9vdERpcmVjdGl2ZSB9XSxcbiAgICBob3N0OiB7XG4gICAgICAgIHJvbGU6ICdzd2l0Y2gnLFxuICAgICAgICB0eXBlOiAnYnV0dG9uJyxcbiAgICAgICAgJ1tpZF0nOiAnZWxlbWVudElkKCknLFxuICAgICAgICAnW2F0dHIuYXJpYS1jaGVja2VkXSc6ICdjaGVja2VkKCknLFxuICAgICAgICAnW2F0dHIuYXJpYS1yZXF1aXJlZF0nOiAncmVxdWlyZWQnLFxuICAgICAgICAnW2F0dHIuZGF0YS1zdGF0ZV0nOiAnY2hlY2tlZCgpID8gXCJjaGVja2VkXCIgOiBcInVuY2hlY2tlZFwiJyxcbiAgICAgICAgJ1thdHRyLmRhdGEtZGlzYWJsZWRdJzogJ2Rpc2FibGVkU3RhdGUoKSA/IFwidHJ1ZVwiIDogbnVsbCcsXG4gICAgICAgICdbYXR0ci5kaXNhYmxlZF0nOiAnZGlzYWJsZWRTdGF0ZSgpID8gZGlzYWJsZWRTdGF0ZSgpIDogbnVsbCcsXG5cbiAgICAgICAgJyhjbGljayknOiAndG9nZ2xlKCknXG4gICAgfVxufSlcbmV4cG9ydCBjbGFzcyBSZHhTd2l0Y2hSb290RGlyZWN0aXZlIGltcGxlbWVudHMgU3dpdGNoUHJvcHMge1xuICAgIHJlYWRvbmx5IGlkID0gaW5wdXQ8c3RyaW5nPihgcmR4LXN3aXRjaC0ke2lkSXRlcmF0b3IrK31gKTtcbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgZWxlbWVudElkID0gY29tcHV0ZWQoKCkgPT4gKHRoaXMuaWQoKSA/IHRoaXMuaWQoKSA6IG51bGwpKTtcblxuICAgIC8qKlxuICAgICAqIFdoZW4gdHJ1ZSwgaW5kaWNhdGVzIHRoYXQgdGhlIHVzZXIgbXVzdCBjaGVjayB0aGUgc3dpdGNoIGJlZm9yZSB0aGUgb3duaW5nIGZvcm0gY2FuIGJlIHN1Ym1pdHRlZC5cbiAgICAgKi9cbiAgICByZWFkb25seSByZXF1aXJlZCA9IGlucHV0PGJvb2xlYW4sIEJvb2xlYW5JbnB1dD4oZmFsc2UsIHtcbiAgICAgICAgdHJhbnNmb3JtOiBib29sZWFuQXR0cmlidXRlXG4gICAgfSk7XG5cbiAgICAvKipcbiAgICAgKiBUaGUgY29udHJvbGxlZCBzdGF0ZSBvZiB0aGUgc3dpdGNoLiBNdXN0IGJlIHVzZWQgaW4gY29uanVuY3Rpb24gd2l0aCBvbkNoZWNrZWRDaGFuZ2UuXG4gICAgICovXG4gICAgcmVhZG9ubHkgY2hlY2tlZCA9IG1vZGVsPGJvb2xlYW4+KGZhbHNlKTtcblxuICAgIC8qKlxuICAgICAqIFdoZW4gdHJ1ZSwgcHJldmVudHMgdGhlIHVzZXIgZnJvbSBpbnRlcmFjdGluZyB3aXRoIHRoZSBzd2l0Y2guXG4gICAgICovXG4gICAgcmVhZG9ubHkgZGlzYWJsZWQgPSBpbnB1dDxib29sZWFuLCBCb29sZWFuSW5wdXQ+KGZhbHNlLCB7XG4gICAgICAgIHRyYW5zZm9ybTogYm9vbGVhbkF0dHJpYnV0ZVxuICAgIH0pO1xuXG4gICAgLypcbiAgICAgKiBAaWdub3JlXG4gICAgICovXG4gICAgcmVhZG9ubHkgZGlzYWJsZWRTdGF0ZSA9IGNvbXB1dGVkKCgpID0+IHRoaXMuZGlzYWJsZWQoKSk7XG5cbiAgICAvKipcbiAgICAgKiBFdmVudCBoYW5kbGVyIGNhbGxlZCB3aGVuIHRoZSBzdGF0ZSBvZiB0aGUgc3dpdGNoIGNoYW5nZXMuXG4gICAgICovXG4gICAgcmVhZG9ubHkgb25DaGVja2VkQ2hhbmdlID0gb3V0cHV0PGJvb2xlYW4+KCk7XG5cbiAgICAvKipcbiAgICAgKiBUb2dnbGVzIHRoZSBjaGVja2VkIHN0YXRlIG9mIHRoZSBzd2l0Y2guXG4gICAgICogSWYgdGhlIHN3aXRjaCBpcyBkaXNhYmxlZCwgdGhlIGZ1bmN0aW9uIHJldHVybnMgZWFybHkuXG4gICAgICovXG4gICAgcHJvdGVjdGVkIHRvZ2dsZSgpOiB2b2lkIHtcbiAgICAgICAgaWYgKHRoaXMuZGlzYWJsZWRTdGF0ZSgpKSB7XG4gICAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cblxuICAgICAgICB0aGlzLmNoZWNrZWQuc2V0KCF0aGlzLmNoZWNrZWQoKSk7XG5cbiAgICAgICAgdGhpcy5vbkNoZWNrZWRDaGFuZ2UuZW1pdCh0aGlzLmNoZWNrZWQoKSk7XG4gICAgfVxufVxuIl19
119
+ }], ctorParameters: () => [] });
120
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"switch-root.directive.js","sourceRoot":"","sources":["../../../../../packages/primitives/switch/src/switch-root.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { BooleanInput } from '@angular/cdk/coercion';\nimport {\n    booleanAttribute,\n    computed,\n    Directive,\n    effect,\n    forwardRef,\n    inject,\n    InjectionToken,\n    input,\n    InputSignalWithTransform,\n    model,\n    ModelSignal,\n    output,\n    OutputEmitterRef,\n    signal\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nexport const RdxSwitchToken = new InjectionToken<RdxSwitchRootDirective>('RdxSwitchToken');\n\nexport function injectSwitch(): RdxSwitchRootDirective {\n    return inject(RdxSwitchToken);\n}\n\nexport const SWITCH_VALUE_ACCESSOR: any = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => RdxSwitchRootDirective),\n    multi: true\n};\n\nexport interface SwitchProps {\n    checked?: ModelSignal<boolean>;\n    defaultChecked?: InputSignalWithTransform<boolean, BooleanInput>;\n    required?: InputSignalWithTransform<boolean, BooleanInput>;\n    onCheckedChange?: OutputEmitterRef<boolean>;\n}\n\nlet idIterator = 0;\n\n@Directive({\n    selector: 'button[rdxSwitchRoot]',\n    exportAs: 'rdxSwitchRoot',\n    standalone: true,\n    providers: [\n        { provide: RdxSwitchToken, useExisting: RdxSwitchRootDirective },\n        SWITCH_VALUE_ACCESSOR\n    ],\n    host: {\n        type: 'button',\n        '[id]': 'elementId()',\n        '[attr.aria-checked]': 'checkedState()',\n        '[attr.aria-required]': 'required()',\n        '[attr.data-state]': 'checkedState() ? \"checked\" : \"unchecked\"',\n        '[attr.data-disabled]': 'disabledState() ? \"true\" : null',\n        '[attr.disabled]': 'disabledState() ? disabledState() : null',\n\n        '(click)': 'toggle()'\n    }\n})\nexport class RdxSwitchRootDirective implements SwitchProps, ControlValueAccessor {\n    readonly id = input<string | null>(`rdx-switch-${idIterator++}`);\n\n    protected readonly elementId = computed(() => (this.id() ? this.id() : null));\n\n    readonly inputId = input<string | null>(null);\n\n    /**\n     * When true, indicates that the user must check the switch before the owning form can be submitted.\n     */\n    readonly required = input<boolean, BooleanInput>(false, {\n        transform: booleanAttribute\n    });\n\n    readonly ariaLabelledBy = input<string | null>(null, {\n        alias: 'aria-labelledby'\n    });\n\n    readonly ariaLabel = input<string | null>(null, {\n        alias: 'aria-label'\n    });\n\n    /**\n     * The controlled state of the switch. Must be used in conjunction with onCheckedChange.\n     */\n    readonly checked = model<boolean>(false);\n\n    readonly defaultChecked = input<boolean, BooleanInput>(false, { transform: booleanAttribute });\n\n    /**\n     * The state of the switch.\n     * If `defaultChecked` is provided, it takes precedence over the `checked` state.\n     * @ignore\n     */\n    readonly checkedState = computed(() => this.checked());\n\n    /**\n     * When true, prevents the user from interacting with the switch.\n     */\n    readonly disabled = input<boolean, BooleanInput>(false, {\n        transform: booleanAttribute\n    });\n\n    /** @ignore */\n    readonly disabledState = computed(() => this.disabled() || this.accessorDisabled());\n\n    /**\n     * Event handler called when the state of the switch changes.\n     */\n    readonly onCheckedChange = output<boolean>();\n\n    private readonly defaultCheckedUsed = computed(() => this.defaultChecked());\n\n    constructor() {\n        effect(\n            () => {\n                if (this.defaultCheckedUsed()) {\n                    this.checked.set(this.defaultChecked());\n                }\n            },\n            { allowSignalWrites: true }\n        );\n    }\n\n    /**\n     * Toggles the checked state of the switch.\n     * If the switch is disabled, the function returns early.\n     * @ignore\n     */\n    toggle(): void {\n        if (this.disabledState()) {\n            return;\n        }\n\n        this.checked.set(!this.checked());\n\n        this.onChange(this.checked());\n        this.onCheckedChange.emit(this.checked());\n    }\n\n    private readonly accessorDisabled = signal(false);\n\n    private onChange: (value: any) => void = () => {};\n    /** @ignore */\n    onTouched: (() => void) | undefined;\n\n    /** @ignore */\n    writeValue(value: any): void {\n        this.checked.set(value);\n    }\n\n    /** @ignore */\n    registerOnChange(fn: (value: any) => void): void {\n        this.onChange = fn;\n    }\n\n    /** @ignore */\n    registerOnTouched(fn: () => void): void {\n        this.onTouched = fn;\n    }\n\n    /** @ignore */\n    setDisabledState(isDisabled: boolean): void {\n        this.accessorDisabled.set(isDisabled);\n    }\n}\n"]}
@@ -6,7 +6,7 @@ export class RdxSwitchThumbDirective {
6
6
  this.switchRoot = injectSwitch();
7
7
  }
8
8
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxSwitchThumbDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
9
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.11", type: RdxSwitchThumbDirective, isStandalone: true, selector: "span[rdxSwitchThumb]", host: { properties: { "attr.data-disabled": "switchRoot.disabledState() ? \"true\" : null", "attr.data-state": "switchRoot.checked() ? \"checked\" : \"unchecked\"" } }, exportAs: ["rdxSwitchThumb"], ngImport: i0 }); }
9
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.11", type: RdxSwitchThumbDirective, isStandalone: true, selector: "span[rdxSwitchThumb]", host: { properties: { "attr.data-disabled": "switchRoot.disabledState() ? \"true\" : null", "attr.data-state": "switchRoot.checkedState() ? \"checked\" : \"unchecked\"" } }, exportAs: ["rdxSwitchThumb"], ngImport: i0 }); }
10
10
  }
11
11
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxSwitchThumbDirective, decorators: [{
12
12
  type: Directive,
@@ -16,8 +16,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImpo
16
16
  standalone: true,
17
17
  host: {
18
18
  '[attr.data-disabled]': 'switchRoot.disabledState() ? "true" : null',
19
- '[attr.data-state]': 'switchRoot.checked() ? "checked" : "unchecked"'
19
+ '[attr.data-state]': 'switchRoot.checkedState() ? "checked" : "unchecked"'
20
20
  }
21
21
  }]
22
22
  }] });
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3dpdGNoLXRodW1iLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3ByaW1pdGl2ZXMvc3dpdGNoL3NyYy9zd2l0Y2gtdGh1bWIuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHlCQUF5QixDQUFDOztBQVd2RCxNQUFNLE9BQU8sdUJBQXVCO0lBVHBDO1FBVXVCLGVBQVUsR0FBRyxZQUFZLEVBQUUsQ0FBQztLQUNsRDsrR0FGWSx1QkFBdUI7bUdBQXZCLHVCQUF1Qjs7NEZBQXZCLHVCQUF1QjtrQkFUbkMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsc0JBQXNCO29CQUNoQyxRQUFRLEVBQUUsZ0JBQWdCO29CQUMxQixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsSUFBSSxFQUFFO3dCQUNGLHNCQUFzQixFQUFFLDRDQUE0Qzt3QkFDcEUsbUJBQW1CLEVBQUUsZ0RBQWdEO3FCQUN4RTtpQkFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgaW5qZWN0U3dpdGNoIH0gZnJvbSAnLi9zd2l0Y2gtcm9vdC5kaXJlY3RpdmUnO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ3NwYW5bcmR4U3dpdGNoVGh1bWJdJyxcbiAgICBleHBvcnRBczogJ3JkeFN3aXRjaFRodW1iJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGhvc3Q6IHtcbiAgICAgICAgJ1thdHRyLmRhdGEtZGlzYWJsZWRdJzogJ3N3aXRjaFJvb3QuZGlzYWJsZWRTdGF0ZSgpID8gXCJ0cnVlXCIgOiBudWxsJyxcbiAgICAgICAgJ1thdHRyLmRhdGEtc3RhdGVdJzogJ3N3aXRjaFJvb3QuY2hlY2tlZCgpID8gXCJjaGVja2VkXCIgOiBcInVuY2hlY2tlZFwiJ1xuICAgIH1cbn0pXG5leHBvcnQgY2xhc3MgUmR4U3dpdGNoVGh1bWJEaXJlY3RpdmUge1xuICAgIHByb3RlY3RlZCByZWFkb25seSBzd2l0Y2hSb290ID0gaW5qZWN0U3dpdGNoKCk7XG59XG4iXX0=
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3dpdGNoLXRodW1iLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3ByaW1pdGl2ZXMvc3dpdGNoL3NyYy9zd2l0Y2gtdGh1bWIuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHlCQUF5QixDQUFDOztBQVd2RCxNQUFNLE9BQU8sdUJBQXVCO0lBVHBDO1FBVXVCLGVBQVUsR0FBRyxZQUFZLEVBQUUsQ0FBQztLQUNsRDsrR0FGWSx1QkFBdUI7bUdBQXZCLHVCQUF1Qjs7NEZBQXZCLHVCQUF1QjtrQkFUbkMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsc0JBQXNCO29CQUNoQyxRQUFRLEVBQUUsZ0JBQWdCO29CQUMxQixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsSUFBSSxFQUFFO3dCQUNGLHNCQUFzQixFQUFFLDRDQUE0Qzt3QkFDcEUsbUJBQW1CLEVBQUUscURBQXFEO3FCQUM3RTtpQkFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgaW5qZWN0U3dpdGNoIH0gZnJvbSAnLi9zd2l0Y2gtcm9vdC5kaXJlY3RpdmUnO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ3NwYW5bcmR4U3dpdGNoVGh1bWJdJyxcbiAgICBleHBvcnRBczogJ3JkeFN3aXRjaFRodW1iJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGhvc3Q6IHtcbiAgICAgICAgJ1thdHRyLmRhdGEtZGlzYWJsZWRdJzogJ3N3aXRjaFJvb3QuZGlzYWJsZWRTdGF0ZSgpID8gXCJ0cnVlXCIgOiBudWxsJyxcbiAgICAgICAgJ1thdHRyLmRhdGEtc3RhdGVdJzogJ3N3aXRjaFJvb3QuY2hlY2tlZFN0YXRlKCkgPyBcImNoZWNrZWRcIiA6IFwidW5jaGVja2VkXCInXG4gICAgfVxufSlcbmV4cG9ydCBjbGFzcyBSZHhTd2l0Y2hUaHVtYkRpcmVjdGl2ZSB7XG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IHN3aXRjaFJvb3QgPSBpbmplY3RTd2l0Y2goKTtcbn1cbiJdfQ==
@@ -1,3 +1,3 @@
1
- export * from './src/toggle-input.directive';
1
+ export * from './src/toggle-visually-hidden-input.directive';
2
2
  export * from './src/toggle.directive';
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9wcmltaXRpdmVzL3RvZ2dsZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsd0JBQXdCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3NyYy90b2dnbGUtaW5wdXQuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vc3JjL3RvZ2dsZS5kaXJlY3RpdmUnO1xuXG5leHBvcnQgdHlwZSB7IFRvZ2dsZVByb3BzIH0gZnJvbSAnLi9zcmMvdG9nZ2xlLmRpcmVjdGl2ZSc7XG4iXX0=
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9wcmltaXRpdmVzL3RvZ2dsZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsd0JBQXdCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3NyYy90b2dnbGUtdmlzdWFsbHktaGlkZGVuLWlucHV0LmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL3NyYy90b2dnbGUuZGlyZWN0aXZlJztcblxuZXhwb3J0IHR5cGUgeyBEYXRhU3RhdGUsIFRvZ2dsZVByb3BzIH0gZnJvbSAnLi9zcmMvdG9nZ2xlLmRpcmVjdGl2ZSc7XG4iXX0=
@@ -0,0 +1,31 @@
1
+ import { Directive } from '@angular/core';
2
+ import { RdxVisuallyHiddenInputDirective } from '@radix-ng/primitives/visually-hidden';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@radix-ng/primitives/visually-hidden";
5
+ export class RdxToggleVisuallyHiddenInputDirective {
6
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxToggleVisuallyHiddenInputDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
7
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.11", type: RdxToggleVisuallyHiddenInputDirective, isStandalone: true, selector: "input[rdxToggleVisuallyHiddenInput]", host: { attributes: { "type": "checkbox" } }, exportAs: ["rdxToggleVisuallyHiddenInput"], hostDirectives: [{ directive: i1.RdxVisuallyHiddenInputDirective, inputs: ["name", "name", "required", "required", "value", "value", "disabled", "disabled"] }], ngImport: i0 }); }
8
+ }
9
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxToggleVisuallyHiddenInputDirective, decorators: [{
10
+ type: Directive,
11
+ args: [{
12
+ selector: 'input[rdxToggleVisuallyHiddenInput]',
13
+ exportAs: 'rdxToggleVisuallyHiddenInput',
14
+ standalone: true,
15
+ hostDirectives: [
16
+ {
17
+ directive: RdxVisuallyHiddenInputDirective,
18
+ inputs: [
19
+ 'name',
20
+ 'required',
21
+ 'value',
22
+ 'disabled'
23
+ ]
24
+ }
25
+ ],
26
+ host: {
27
+ type: 'checkbox'
28
+ }
29
+ }]
30
+ }] });
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9nZ2xlLXZpc3VhbGx5LWhpZGRlbi1pbnB1dC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9wcmltaXRpdmVzL3RvZ2dsZS9zcmMvdG9nZ2xlLXZpc3VhbGx5LWhpZGRlbi1pbnB1dC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxQyxPQUFPLEVBQUUsK0JBQStCLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQzs7O0FBcUJ2RixNQUFNLE9BQU8scUNBQXFDOytHQUFyQyxxQ0FBcUM7bUdBQXJDLHFDQUFxQzs7NEZBQXJDLHFDQUFxQztrQkFuQmpELFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLHFDQUFxQztvQkFDL0MsUUFBUSxFQUFFLDhCQUE4QjtvQkFDeEMsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLGNBQWMsRUFBRTt3QkFDWjs0QkFDSSxTQUFTLEVBQUUsK0JBQStCOzRCQUMxQyxNQUFNLEVBQUU7Z0NBQ0osTUFBTTtnQ0FDTixVQUFVO2dDQUNWLE9BQU87Z0NBQ1AsVUFBVTs2QkFDYjt5QkFDSjtxQkFDSjtvQkFDRCxJQUFJLEVBQUU7d0JBQ0YsSUFBSSxFQUFFLFVBQVU7cUJBQ25CO2lCQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBSZHhWaXN1YWxseUhpZGRlbklucHV0RGlyZWN0aXZlIH0gZnJvbSAnQHJhZGl4LW5nL3ByaW1pdGl2ZXMvdmlzdWFsbHktaGlkZGVuJztcblxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdpbnB1dFtyZHhUb2dnbGVWaXN1YWxseUhpZGRlbklucHV0XScsXG4gICAgZXhwb3J0QXM6ICdyZHhUb2dnbGVWaXN1YWxseUhpZGRlbklucHV0JyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGhvc3REaXJlY3RpdmVzOiBbXG4gICAgICAgIHtcbiAgICAgICAgICAgIGRpcmVjdGl2ZTogUmR4VmlzdWFsbHlIaWRkZW5JbnB1dERpcmVjdGl2ZSxcbiAgICAgICAgICAgIGlucHV0czogW1xuICAgICAgICAgICAgICAgICduYW1lJyxcbiAgICAgICAgICAgICAgICAncmVxdWlyZWQnLFxuICAgICAgICAgICAgICAgICd2YWx1ZScsXG4gICAgICAgICAgICAgICAgJ2Rpc2FibGVkJ1xuICAgICAgICAgICAgXVxuICAgICAgICB9XG4gICAgXSxcbiAgICBob3N0OiB7XG4gICAgICAgIHR5cGU6ICdjaGVja2JveCdcbiAgICB9XG59KVxuZXhwb3J0IGNsYXNzIFJkeFRvZ2dsZVZpc3VhbGx5SGlkZGVuSW5wdXREaXJlY3RpdmUge31cbiJdfQ==
@@ -1,5 +1,11 @@
1
- import { booleanAttribute, Directive, input, model, output } from '@angular/core';
1
+ import { booleanAttribute, computed, Directive, forwardRef, input, model, output, signal } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
2
3
  import * as i0 from "@angular/core";
4
+ export const TOGGLE_VALUE_ACCESSOR = {
5
+ provide: NG_VALUE_ACCESSOR,
6
+ useExisting: forwardRef(() => RdxToggleDirective),
7
+ multi: true
8
+ };
3
9
  export class RdxToggleDirective {
4
10
  constructor() {
5
11
  /**
@@ -16,19 +22,41 @@ export class RdxToggleDirective {
16
22
  * When true, prevents the user from interacting with the toggle.
17
23
  */
18
24
  this.disabled = input(false, { transform: booleanAttribute });
25
+ /** @ignore */
26
+ this.disabledState = computed(() => this.disabled() || this.accessorDisabled());
27
+ this.dataState = computed(() => {
28
+ return this.pressed() ? 'on' : 'off';
29
+ });
19
30
  /**
20
31
  * Event handler called when the pressed state of the toggle changes.
21
32
  */
22
33
  this.onPressedChange = output();
34
+ this.accessorDisabled = signal(false);
23
35
  }
24
- toggle() {
36
+ togglePressed() {
25
37
  if (!this.disabled()) {
26
38
  this.pressed.set(!this.pressed());
27
39
  this.onPressedChange.emit(this.pressed());
28
40
  }
29
41
  }
42
+ /** @ignore */
43
+ writeValue(value) {
44
+ this.pressed.set(value);
45
+ }
46
+ /** @ignore */
47
+ registerOnChange(fn) {
48
+ this.onChange = fn;
49
+ }
50
+ /** @ignore */
51
+ registerOnTouched(fn) {
52
+ this.onTouched = fn;
53
+ }
54
+ /** @ignore */
55
+ setDisabledState(isDisabled) {
56
+ this.accessorDisabled.set(isDisabled);
57
+ }
30
58
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxToggleDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
31
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.11", type: RdxToggleDirective, isStandalone: true, selector: "[rdxToggle]", inputs: { defaultPressed: { classPropertyName: "defaultPressed", publicName: "defaultPressed", isSignal: true, isRequired: false, transformFunction: null }, pressed: { classPropertyName: "pressed", publicName: "pressed", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { pressed: "pressedChange", onPressedChange: "onPressedChange" }, host: { listeners: { "click": "toggle()" }, properties: { "attr.aria-pressed": "pressed()", "attr.data-state": "pressed() ? \"on\" : \"off\"", "attr.data-disabled": "disabled()", "disabled": "disabled()" } }, exportAs: ["rdxToggle"], ngImport: i0 }); }
59
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.11", type: RdxToggleDirective, isStandalone: true, selector: "[rdxToggle]", inputs: { defaultPressed: { classPropertyName: "defaultPressed", publicName: "defaultPressed", isSignal: true, isRequired: false, transformFunction: null }, pressed: { classPropertyName: "pressed", publicName: "pressed", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { pressed: "pressedChange", onPressedChange: "onPressedChange" }, host: { listeners: { "click": "togglePressed()" }, properties: { "attr.aria-pressed": "pressed()", "attr.data-state": "dataState()", "attr.data-disabled": "disabledState() ? \"\" : undefined", "disabled": "disabledState()" } }, providers: [TOGGLE_VALUE_ACCESSOR], exportAs: ["rdxToggle"], ngImport: i0 }); }
32
60
  }
33
61
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxToggleDirective, decorators: [{
34
62
  type: Directive,
@@ -36,13 +64,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImpo
36
64
  selector: '[rdxToggle]',
37
65
  exportAs: 'rdxToggle',
38
66
  standalone: true,
67
+ providers: [TOGGLE_VALUE_ACCESSOR],
39
68
  host: {
40
69
  '[attr.aria-pressed]': 'pressed()',
41
- '[attr.data-state]': 'pressed() ? "on" : "off"',
42
- '[attr.data-disabled]': 'disabled()',
43
- '[disabled]': 'disabled()',
44
- '(click)': 'toggle()'
70
+ '[attr.data-state]': 'dataState()',
71
+ '[attr.data-disabled]': 'disabledState() ? "" : undefined',
72
+ '[disabled]': 'disabledState()',
73
+ '(click)': 'togglePressed()'
45
74
  }
46
75
  }]
47
76
  }] });
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9nZ2xlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3ByaW1pdGl2ZXMvdG9nZ2xlL3NyYy90b2dnbGUuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQW9CLE1BQU0sZUFBZSxDQUFDOztBQXdDcEcsTUFBTSxPQUFPLGtCQUFrQjtJQWIvQjtRQWNJOzs7V0FHRztRQUNNLG1CQUFjLEdBQUcsS0FBSyxDQUF3QixLQUFLLEVBQUUsRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUUsQ0FBQyxDQUFDO1FBRS9GOzs7V0FHRztRQUNNLFlBQU8sR0FBRyxLQUFLLENBQVUsSUFBSSxDQUFDLGNBQWMsRUFBRSxDQUFDLENBQUM7UUFFekQ7O1dBRUc7UUFDTSxhQUFRLEdBQUcsS0FBSyxDQUF3QixLQUFLLEVBQUUsRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUUsQ0FBQyxDQUFDO1FBRXpGOztXQUVHO1FBQ00sb0JBQWUsR0FBRyxNQUFNLEVBQVcsQ0FBQztLQVFoRDtJQU5hLE1BQU07UUFDWixJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxFQUFFLENBQUM7WUFDbkIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQztZQUNsQyxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQztRQUM5QyxDQUFDO0lBQ0wsQ0FBQzsrR0E1QlEsa0JBQWtCO21HQUFsQixrQkFBa0I7OzRGQUFsQixrQkFBa0I7a0JBYjlCLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLGFBQWE7b0JBQ3ZCLFFBQVEsRUFBRSxXQUFXO29CQUNyQixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsSUFBSSxFQUFFO3dCQUNGLHFCQUFxQixFQUFFLFdBQVc7d0JBQ2xDLG1CQUFtQixFQUFFLDBCQUEwQjt3QkFDL0Msc0JBQXNCLEVBQUUsWUFBWTt3QkFDcEMsWUFBWSxFQUFFLFlBQVk7d0JBRTFCLFNBQVMsRUFBRSxVQUFVO3FCQUN4QjtpQkFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJvb2xlYW5JbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9jb2VyY2lvbic7XG5pbXBvcnQgeyBib29sZWFuQXR0cmlidXRlLCBEaXJlY3RpdmUsIGlucHV0LCBtb2RlbCwgb3V0cHV0LCBPdXRwdXRFbWl0dGVyUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVG9nZ2xlUHJvcHMge1xuICAgIC8qKlxuICAgICAqIFRoZSBjb250cm9sbGVkIHN0YXRlIG9mIHRoZSB0b2dnbGUuXG4gICAgICovXG4gICAgcHJlc3NlZD86IGJvb2xlYW47XG5cbiAgICAvKipcbiAgICAgKiBUaGUgc3RhdGUgb2YgdGhlIHRvZ2dsZSB3aGVuIGluaXRpYWxseSByZW5kZXJlZC4gVXNlIGBkZWZhdWx0UHJlc3NlZGBcbiAgICAgKiBpZiB5b3UgZG8gbm90IG5lZWQgdG8gY29udHJvbCB0aGUgc3RhdGUgb2YgdGhlIHRvZ2dsZS5cbiAgICAgKiBAZGVmYXVsdFZhbHVlIGZhbHNlXG4gICAgICovXG4gICAgZGVmYXVsdFByZXNzZWQ/OiBib29sZWFuO1xuXG4gICAgLyoqXG4gICAgICogVGhlIGNhbGxiYWNrIHRoYXQgZmlyZXMgd2hlbiB0aGUgc3RhdGUgb2YgdGhlIHRvZ2dsZSBjaGFuZ2VzLlxuICAgICAqL1xuICAgIG9uUHJlc3NlZENoYW5nZT86IE91dHB1dEVtaXR0ZXJSZWY8Ym9vbGVhbj47XG5cbiAgICAvKipcbiAgICAgKiBXaGV0aGVyIHRoZSB0b2dnbGUgaXMgZGlzYWJsZWQuXG4gICAgICogQGRlZmF1bHRWYWx1ZSBmYWxzZVxuICAgICAqL1xuICAgIGRpc2FibGVkPzogYm9vbGVhbjtcbn1cblxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdbcmR4VG9nZ2xlXScsXG4gICAgZXhwb3J0QXM6ICdyZHhUb2dnbGUnLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaG9zdDoge1xuICAgICAgICAnW2F0dHIuYXJpYS1wcmVzc2VkXSc6ICdwcmVzc2VkKCknLFxuICAgICAgICAnW2F0dHIuZGF0YS1zdGF0ZV0nOiAncHJlc3NlZCgpID8gXCJvblwiIDogXCJvZmZcIicsXG4gICAgICAgICdbYXR0ci5kYXRhLWRpc2FibGVkXSc6ICdkaXNhYmxlZCgpJyxcbiAgICAgICAgJ1tkaXNhYmxlZF0nOiAnZGlzYWJsZWQoKScsXG5cbiAgICAgICAgJyhjbGljayknOiAndG9nZ2xlKCknXG4gICAgfVxufSlcbmV4cG9ydCBjbGFzcyBSZHhUb2dnbGVEaXJlY3RpdmUge1xuICAgIC8qKlxuICAgICAqIFRoZSBwcmVzc2VkIHN0YXRlIG9mIHRoZSB0b2dnbGUgd2hlbiBpdCBpcyBpbml0aWFsbHkgcmVuZGVyZWQuXG4gICAgICogVXNlIHdoZW4geW91IGRvIG5vdCBuZWVkIHRvIGNvbnRyb2wgaXRzIHByZXNzZWQgc3RhdGUuXG4gICAgICovXG4gICAgcmVhZG9ubHkgZGVmYXVsdFByZXNzZWQgPSBpbnB1dDxib29sZWFuLCBCb29sZWFuSW5wdXQ+KGZhbHNlLCB7IHRyYW5zZm9ybTogYm9vbGVhbkF0dHJpYnV0ZSB9KTtcblxuICAgIC8qKlxuICAgICAqIFRoZSBjb250cm9sbGVkIHByZXNzZWQgc3RhdGUgb2YgdGhlIHRvZ2dsZS5cbiAgICAgKiBNdXN0IGJlIHVzZWQgaW4gY29uanVuY3Rpb24gd2l0aCBgb25QcmVzc2VkQ2hhbmdlYC5cbiAgICAgKi9cbiAgICByZWFkb25seSBwcmVzc2VkID0gbW9kZWw8Ym9vbGVhbj4odGhpcy5kZWZhdWx0UHJlc3NlZCgpKTtcblxuICAgIC8qKlxuICAgICAqIFdoZW4gdHJ1ZSwgcHJldmVudHMgdGhlIHVzZXIgZnJvbSBpbnRlcmFjdGluZyB3aXRoIHRoZSB0b2dnbGUuXG4gICAgICovXG4gICAgcmVhZG9ubHkgZGlzYWJsZWQgPSBpbnB1dDxib29sZWFuLCBCb29sZWFuSW5wdXQ+KGZhbHNlLCB7IHRyYW5zZm9ybTogYm9vbGVhbkF0dHJpYnV0ZSB9KTtcblxuICAgIC8qKlxuICAgICAqIEV2ZW50IGhhbmRsZXIgY2FsbGVkIHdoZW4gdGhlIHByZXNzZWQgc3RhdGUgb2YgdGhlIHRvZ2dsZSBjaGFuZ2VzLlxuICAgICAqL1xuICAgIHJlYWRvbmx5IG9uUHJlc3NlZENoYW5nZSA9IG91dHB1dDxib29sZWFuPigpO1xuXG4gICAgcHJvdGVjdGVkIHRvZ2dsZSgpOiB2b2lkIHtcbiAgICAgICAgaWYgKCF0aGlzLmRpc2FibGVkKCkpIHtcbiAgICAgICAgICAgIHRoaXMucHJlc3NlZC5zZXQoIXRoaXMucHJlc3NlZCgpKTtcbiAgICAgICAgICAgIHRoaXMub25QcmVzc2VkQ2hhbmdlLmVtaXQodGhpcy5wcmVzc2VkKCkpO1xuICAgICAgICB9XG4gICAgfVxufVxuIl19
77
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9nZ2xlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3ByaW1pdGl2ZXMvdG9nZ2xlL3NyYy90b2dnbGUuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFDSCxnQkFBZ0IsRUFDaEIsUUFBUSxFQUNSLFNBQVMsRUFDVCxVQUFVLEVBQ1YsS0FBSyxFQUNMLEtBQUssRUFDTCxNQUFNLEVBRU4sTUFBTSxFQUNULE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBd0IsaUJBQWlCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7QUE2QnpFLE1BQU0sQ0FBQyxNQUFNLHFCQUFxQixHQUFRO0lBQ3RDLE9BQU8sRUFBRSxpQkFBaUI7SUFDMUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQztJQUNqRCxLQUFLLEVBQUUsSUFBSTtDQUNkLENBQUM7QUFnQkYsTUFBTSxPQUFPLGtCQUFrQjtJQWQvQjtRQWVJOzs7V0FHRztRQUNNLG1CQUFjLEdBQUcsS0FBSyxDQUF3QixLQUFLLEVBQUUsRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUUsQ0FBQyxDQUFDO1FBRS9GOzs7V0FHRztRQUNNLFlBQU8sR0FBRyxLQUFLLENBQVUsSUFBSSxDQUFDLGNBQWMsRUFBRSxDQUFDLENBQUM7UUFFekQ7O1dBRUc7UUFDTSxhQUFRLEdBQUcsS0FBSyxDQUF3QixLQUFLLEVBQUUsRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUUsQ0FBQyxDQUFDO1FBRXpGLGNBQWM7UUFDTCxrQkFBYSxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLElBQUksSUFBSSxDQUFDLGdCQUFnQixFQUFFLENBQUMsQ0FBQztRQUVqRSxjQUFTLEdBQUcsUUFBUSxDQUFZLEdBQUcsRUFBRTtZQUNwRCxPQUFPLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUM7UUFDekMsQ0FBQyxDQUFDLENBQUM7UUFFSDs7V0FFRztRQUNNLG9CQUFlLEdBQUcsTUFBTSxFQUFXLENBQUM7UUFTNUIscUJBQWdCLEdBQUcsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO0tBd0JyRDtJQS9CYSxhQUFhO1FBQ25CLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQztZQUNuQixJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO1lBQ2xDLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO1FBQzlDLENBQUM7SUFDTCxDQUFDO0lBT0QsY0FBYztJQUNkLFVBQVUsQ0FBQyxLQUFVO1FBQ2pCLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzVCLENBQUM7SUFFRCxjQUFjO0lBQ2QsZ0JBQWdCLENBQUMsRUFBd0I7UUFDckMsSUFBSSxDQUFDLFFBQVEsR0FBRyxFQUFFLENBQUM7SUFDdkIsQ0FBQztJQUVELGNBQWM7SUFDZCxpQkFBaUIsQ0FBQyxFQUFjO1FBQzVCLElBQUksQ0FBQyxTQUFTLEdBQUcsRUFBRSxDQUFDO0lBQ3hCLENBQUM7SUFFRCxjQUFjO0lBQ2QsZ0JBQWdCLENBQUMsVUFBbUI7UUFDaEMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUMxQyxDQUFDOytHQTVEUSxrQkFBa0I7bUdBQWxCLGtCQUFrQix1d0JBVmhCLENBQUMscUJBQXFCLENBQUM7OzRGQVV6QixrQkFBa0I7a0JBZDlCLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLGFBQWE7b0JBQ3ZCLFFBQVEsRUFBRSxXQUFXO29CQUNyQixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsU0FBUyxFQUFFLENBQUMscUJBQXFCLENBQUM7b0JBQ2xDLElBQUksRUFBRTt3QkFDRixxQkFBcUIsRUFBRSxXQUFXO3dCQUNsQyxtQkFBbUIsRUFBRSxhQUFhO3dCQUNsQyxzQkFBc0IsRUFBRSxrQ0FBa0M7d0JBQzFELFlBQVksRUFBRSxpQkFBaUI7d0JBRS9CLFNBQVMsRUFBRSxpQkFBaUI7cUJBQy9CO2lCQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQm9vbGVhbklucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2NvZXJjaW9uJztcbmltcG9ydCB7XG4gICAgYm9vbGVhbkF0dHJpYnV0ZSxcbiAgICBjb21wdXRlZCxcbiAgICBEaXJlY3RpdmUsXG4gICAgZm9yd2FyZFJlZixcbiAgICBpbnB1dCxcbiAgICBtb2RlbCxcbiAgICBvdXRwdXQsXG4gICAgT3V0cHV0RW1pdHRlclJlZixcbiAgICBzaWduYWxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb250cm9sVmFsdWVBY2Nlc3NvciwgTkdfVkFMVUVfQUNDRVNTT1IgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVG9nZ2xlUHJvcHMge1xuICAgIC8qKlxuICAgICAqIFRoZSBjb250cm9sbGVkIHN0YXRlIG9mIHRoZSB0b2dnbGUuXG4gICAgICovXG4gICAgcHJlc3NlZD86IGJvb2xlYW47XG5cbiAgICAvKipcbiAgICAgKiBUaGUgc3RhdGUgb2YgdGhlIHRvZ2dsZSB3aGVuIGluaXRpYWxseSByZW5kZXJlZC4gVXNlIGBkZWZhdWx0UHJlc3NlZGBcbiAgICAgKiBpZiB5b3UgZG8gbm90IG5lZWQgdG8gY29udHJvbCB0aGUgc3RhdGUgb2YgdGhlIHRvZ2dsZS5cbiAgICAgKiBAZGVmYXVsdFZhbHVlIGZhbHNlXG4gICAgICovXG4gICAgZGVmYXVsdFByZXNzZWQ/OiBib29sZWFuO1xuXG4gICAgLyoqXG4gICAgICogVGhlIGNhbGxiYWNrIHRoYXQgZmlyZXMgd2hlbiB0aGUgc3RhdGUgb2YgdGhlIHRvZ2dsZSBjaGFuZ2VzLlxuICAgICAqL1xuICAgIG9uUHJlc3NlZENoYW5nZT86IE91dHB1dEVtaXR0ZXJSZWY8Ym9vbGVhbj47XG5cbiAgICAvKipcbiAgICAgKiBXaGV0aGVyIHRoZSB0b2dnbGUgaXMgZGlzYWJsZWQuXG4gICAgICogQGRlZmF1bHRWYWx1ZSBmYWxzZVxuICAgICAqL1xuICAgIGRpc2FibGVkPzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IHR5cGUgRGF0YVN0YXRlID0gJ29uJyB8ICdvZmYnO1xuXG5leHBvcnQgY29uc3QgVE9HR0xFX1ZBTFVFX0FDQ0VTU09SOiBhbnkgPSB7XG4gICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXG4gICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gUmR4VG9nZ2xlRGlyZWN0aXZlKSxcbiAgICBtdWx0aTogdHJ1ZVxufTtcblxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdbcmR4VG9nZ2xlXScsXG4gICAgZXhwb3J0QXM6ICdyZHhUb2dnbGUnLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgcHJvdmlkZXJzOiBbVE9HR0xFX1ZBTFVFX0FDQ0VTU09SXSxcbiAgICBob3N0OiB7XG4gICAgICAgICdbYXR0ci5hcmlhLXByZXNzZWRdJzogJ3ByZXNzZWQoKScsXG4gICAgICAgICdbYXR0ci5kYXRhLXN0YXRlXSc6ICdkYXRhU3RhdGUoKScsXG4gICAgICAgICdbYXR0ci5kYXRhLWRpc2FibGVkXSc6ICdkaXNhYmxlZFN0YXRlKCkgPyBcIlwiIDogdW5kZWZpbmVkJyxcbiAgICAgICAgJ1tkaXNhYmxlZF0nOiAnZGlzYWJsZWRTdGF0ZSgpJyxcblxuICAgICAgICAnKGNsaWNrKSc6ICd0b2dnbGVQcmVzc2VkKCknXG4gICAgfVxufSlcbmV4cG9ydCBjbGFzcyBSZHhUb2dnbGVEaXJlY3RpdmUgaW1wbGVtZW50cyBDb250cm9sVmFsdWVBY2Nlc3NvciB7XG4gICAgLyoqXG4gICAgICogVGhlIHByZXNzZWQgc3RhdGUgb2YgdGhlIHRvZ2dsZSB3aGVuIGl0IGlzIGluaXRpYWxseSByZW5kZXJlZC5cbiAgICAgKiBVc2Ugd2hlbiB5b3UgZG8gbm90IG5lZWQgdG8gY29udHJvbCBpdHMgcHJlc3NlZCBzdGF0ZS5cbiAgICAgKi9cbiAgICByZWFkb25seSBkZWZhdWx0UHJlc3NlZCA9IGlucHV0PGJvb2xlYW4sIEJvb2xlYW5JbnB1dD4oZmFsc2UsIHsgdHJhbnNmb3JtOiBib29sZWFuQXR0cmlidXRlIH0pO1xuXG4gICAgLyoqXG4gICAgICogVGhlIGNvbnRyb2xsZWQgcHJlc3NlZCBzdGF0ZSBvZiB0aGUgdG9nZ2xlLlxuICAgICAqIE11c3QgYmUgdXNlZCBpbiBjb25qdW5jdGlvbiB3aXRoIGBvblByZXNzZWRDaGFuZ2VgLlxuICAgICAqL1xuICAgIHJlYWRvbmx5IHByZXNzZWQgPSBtb2RlbDxib29sZWFuPih0aGlzLmRlZmF1bHRQcmVzc2VkKCkpO1xuXG4gICAgLyoqXG4gICAgICogV2hlbiB0cnVlLCBwcmV2ZW50cyB0aGUgdXNlciBmcm9tIGludGVyYWN0aW5nIHdpdGggdGhlIHRvZ2dsZS5cbiAgICAgKi9cbiAgICByZWFkb25seSBkaXNhYmxlZCA9IGlucHV0PGJvb2xlYW4sIEJvb2xlYW5JbnB1dD4oZmFsc2UsIHsgdHJhbnNmb3JtOiBib29sZWFuQXR0cmlidXRlIH0pO1xuXG4gICAgLyoqIEBpZ25vcmUgKi9cbiAgICByZWFkb25seSBkaXNhYmxlZFN0YXRlID0gY29tcHV0ZWQoKCkgPT4gdGhpcy5kaXNhYmxlZCgpIHx8IHRoaXMuYWNjZXNzb3JEaXNhYmxlZCgpKTtcblxuICAgIHByb3RlY3RlZCByZWFkb25seSBkYXRhU3RhdGUgPSBjb21wdXRlZDxEYXRhU3RhdGU+KCgpID0+IHtcbiAgICAgICAgcmV0dXJuIHRoaXMucHJlc3NlZCgpID8gJ29uJyA6ICdvZmYnO1xuICAgIH0pO1xuXG4gICAgLyoqXG4gICAgICogRXZlbnQgaGFuZGxlciBjYWxsZWQgd2hlbiB0aGUgcHJlc3NlZCBzdGF0ZSBvZiB0aGUgdG9nZ2xlIGNoYW5nZXMuXG4gICAgICovXG4gICAgcmVhZG9ubHkgb25QcmVzc2VkQ2hhbmdlID0gb3V0cHV0PGJvb2xlYW4+KCk7XG5cbiAgICBwcm90ZWN0ZWQgdG9nZ2xlUHJlc3NlZCgpOiB2b2lkIHtcbiAgICAgICAgaWYgKCF0aGlzLmRpc2FibGVkKCkpIHtcbiAgICAgICAgICAgIHRoaXMucHJlc3NlZC5zZXQoIXRoaXMucHJlc3NlZCgpKTtcbiAgICAgICAgICAgIHRoaXMub25QcmVzc2VkQ2hhbmdlLmVtaXQodGhpcy5wcmVzc2VkKCkpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHJpdmF0ZSByZWFkb25seSBhY2Nlc3NvckRpc2FibGVkID0gc2lnbmFsKGZhbHNlKTtcblxuICAgIHByaXZhdGUgb25DaGFuZ2U6ICgodmFsdWU6IGFueSkgPT4gdm9pZCkgfCB1bmRlZmluZWQ7XG4gICAgcHJpdmF0ZSBvblRvdWNoZWQ6ICgoKSA9PiB2b2lkKSB8IHVuZGVmaW5lZDtcblxuICAgIC8qKiBAaWdub3JlICovXG4gICAgd3JpdGVWYWx1ZSh2YWx1ZTogYW55KTogdm9pZCB7XG4gICAgICAgIHRoaXMucHJlc3NlZC5zZXQodmFsdWUpO1xuICAgIH1cblxuICAgIC8qKiBAaWdub3JlICovXG4gICAgcmVnaXN0ZXJPbkNoYW5nZShmbjogKHZhbHVlOiBhbnkpID0+IHZvaWQpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5vbkNoYW5nZSA9IGZuO1xuICAgIH1cblxuICAgIC8qKiBAaWdub3JlICovXG4gICAgcmVnaXN0ZXJPblRvdWNoZWQoZm46ICgpID0+IHZvaWQpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5vblRvdWNoZWQgPSBmbjtcbiAgICB9XG5cbiAgICAvKiogQGlnbm9yZSAqL1xuICAgIHNldERpc2FibGVkU3RhdGUoaXNEaXNhYmxlZDogYm9vbGVhbik6IHZvaWQge1xuICAgICAgICB0aGlzLmFjY2Vzc29yRGlzYWJsZWQuc2V0KGlzRGlzYWJsZWQpO1xuICAgIH1cbn1cbiJdfQ==
@@ -1,5 +1,5 @@
1
1
  import * as i0 from '@angular/core';
2
- import { signal, Injectable, Directive, InjectionToken, inject, input, effect, ElementRef, output, computed } from '@angular/core';
2
+ import { signal, Injectable, Directive, InjectionToken, inject, input, computed, effect, ElementRef, output } from '@angular/core';
3
3
 
4
4
  class RdxAvatarRootContext {
5
5
  constructor() {
@@ -46,6 +46,7 @@ class RdxAvatarFallbackDirective {
46
46
  this.avatarRoot = inject(RdxAvatarRootContext);
47
47
  this.config = injectAvatarConfig();
48
48
  this.delayMs = input(this.config.delayMs);
49
+ this.shouldRender = computed(() => this.canRender() && this.avatarRoot.imageLoadingStatus() !== 'loaded');
49
50
  this.canRender = signal(false);
50
51
  this.timeoutId = null;
51
52
  effect(() => {
@@ -55,13 +56,10 @@ class RdxAvatarFallbackDirective {
55
56
  }
56
57
  else {
57
58
  this.clearDelayTimer();
58
- this.canRender.set(false);
59
+ this.canRender.set(true);
59
60
  }
60
61
  }, { allowSignalWrites: true });
61
62
  }
62
- get shouldRender() {
63
- return this.canRender() && this.avatarRoot.imageLoadingStatus() !== 'loaded';
64
- }
65
63
  startDelayTimer() {
66
64
  this.clearDelayTimer();
67
65
  if (this.delayMs() > 0) {
@@ -83,7 +81,7 @@ class RdxAvatarFallbackDirective {
83
81
  this.clearDelayTimer();
84
82
  }
85
83
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxAvatarFallbackDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
86
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.11", type: RdxAvatarFallbackDirective, isStandalone: true, selector: "span[rdxAvatarFallback]", inputs: { delayMs: { classPropertyName: "delayMs", publicName: "delayMs", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "style.display": "shouldRender ? null : \"none\" " } }, exportAs: ["rdxAvatarFallback"], ngImport: i0 }); }
84
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.11", type: RdxAvatarFallbackDirective, isStandalone: true, selector: "span[rdxAvatarFallback]", inputs: { delayMs: { classPropertyName: "delayMs", publicName: "delayMs", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "style.display": "shouldRender() ? null : \"none\" " } }, exportAs: ["rdxAvatarFallback"], ngImport: i0 }); }
87
85
  }
88
86
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxAvatarFallbackDirective, decorators: [{
89
87
  type: Directive,
@@ -92,7 +90,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImpo
92
90
  standalone: true,
93
91
  exportAs: 'rdxAvatarFallback',
94
92
  host: {
95
- '[style.display]': 'shouldRender ? null : "none" '
93
+ '[style.display]': 'shouldRender() ? null : "none" '
96
94
  }
97
95
  }]
98
96
  }], ctorParameters: () => [] });
@@ -101,11 +99,12 @@ class RdxAvatarImageDirective {
101
99
  constructor() {
102
100
  this.avatarRoot = inject(RdxAvatarRootContext);
103
101
  this.elementRef = inject((ElementRef));
104
- this.src = (input.required);
102
+ this.src = input();
105
103
  this.onLoadingStatusChange = output();
106
104
  this.imageLoadingStatus = computed(() => this.avatarRoot.imageLoadingStatus());
107
105
  }
108
106
  ngOnInit() {
107
+ this.nativeElement.src = this.src();
109
108
  if (!this.nativeElement.src) {
110
109
  this.setImageStatus('error');
111
110
  }
@@ -130,7 +129,7 @@ class RdxAvatarImageDirective {
130
129
  return this.elementRef.nativeElement;
131
130
  }
132
131
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxAvatarImageDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
133
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.11", type: RdxAvatarImageDirective, isStandalone: true, selector: "img[rdxAvatarImage]", outputs: { onLoadingStatusChange: "onLoadingStatusChange" }, host: { listeners: { "load": "onLoad()", "error": "onError()" }, properties: { "style.display": "(imageLoadingStatus() === \"loaded\")? null : \"none\"" } }, exportAs: ["rdxAvatarImage"], ngImport: i0 }); }
132
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.11", type: RdxAvatarImageDirective, isStandalone: true, selector: "img[rdxAvatarImage]", inputs: { src: { classPropertyName: "src", publicName: "src", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onLoadingStatusChange: "onLoadingStatusChange" }, host: { listeners: { "load": "onLoad()", "error": "onError()" }, properties: { "style.display": "(imageLoadingStatus() === \"loaded\")? null : \"none\"" } }, exportAs: ["rdxAvatarImage"], ngImport: i0 }); }
134
133
  }
135
134
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxAvatarImageDirective, decorators: [{
136
135
  type: Directive,