@radix-ng/primitives 0.7.2 → 0.8.2

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 (89) hide show
  1. package/accordion/README.md +1 -0
  2. package/accordion/index.d.ts +5 -0
  3. package/accordion/src/accordion-content.directive.d.ts +64 -0
  4. package/accordion/src/accordion-header.directive.d.ts +23 -0
  5. package/accordion/src/accordion-item.directive.d.ts +36 -0
  6. package/accordion/src/accordion-root.directive.d.ts +57 -0
  7. package/accordion/src/accordion-trigger.directive.d.ts +31 -0
  8. package/checkbox/index.d.ts +2 -0
  9. package/checkbox/src/checkbox-button.directive.d.ts +8 -0
  10. package/checkbox/src/checkbox-indicator.directive.d.ts +1 -1
  11. package/checkbox/src/checkbox-input.directive.d.ts +9 -0
  12. package/checkbox/src/checkbox.directive.d.ts +7 -5
  13. package/dropdown-menu/README.md +1 -0
  14. package/dropdown-menu/index.d.ts +5 -0
  15. package/dropdown-menu/src/dropdown-menu-content.directive.d.ts +6 -0
  16. package/dropdown-menu/src/dropdown-menu-item.directive.d.ts +8 -0
  17. package/dropdown-menu/src/dropdown-menu-label.directive.d.ts +5 -0
  18. package/dropdown-menu/src/dropdown-menu-separator.directive.d.ts +6 -0
  19. package/dropdown-menu/src/dropdown-menu-trigger.directive.d.ts +12 -0
  20. package/esm2022/accordion/index.mjs +6 -0
  21. package/esm2022/accordion/radix-ng-primitives-accordion.mjs +5 -0
  22. package/esm2022/accordion/src/accordion-content.directive.mjs +139 -0
  23. package/esm2022/accordion/src/accordion-header.directive.mjs +44 -0
  24. package/esm2022/accordion/src/accordion-item.directive.mjs +75 -0
  25. package/esm2022/accordion/src/accordion-root.directive.mjs +120 -0
  26. package/esm2022/accordion/src/accordion-trigger.directive.mjs +61 -0
  27. package/esm2022/checkbox/index.mjs +3 -1
  28. package/esm2022/checkbox/src/checkbox-button.directive.mjs +33 -0
  29. package/esm2022/checkbox/src/checkbox-indicator.directive.mjs +4 -3
  30. package/esm2022/checkbox/src/checkbox-input.directive.mjs +41 -0
  31. package/esm2022/checkbox/src/checkbox.directive.mjs +16 -20
  32. package/esm2022/dropdown-menu/index.mjs +6 -0
  33. package/esm2022/dropdown-menu/radix-ng-primitives-dropdown-menu.mjs +5 -0
  34. package/esm2022/dropdown-menu/src/dropdown-menu-content.directive.mjs +17 -0
  35. package/esm2022/dropdown-menu/src/dropdown-menu-item.directive.mjs +26 -0
  36. package/esm2022/dropdown-menu/src/dropdown-menu-label.directive.mjs +14 -0
  37. package/esm2022/dropdown-menu/src/dropdown-menu-separator.directive.mjs +21 -0
  38. package/esm2022/dropdown-menu/src/dropdown-menu-trigger.directive.mjs +52 -0
  39. package/esm2022/label/src/label-root.directive.mjs +7 -8
  40. package/esm2022/menu/src/menu-item.directive.mjs +10 -4
  41. package/esm2022/menubar/src/menubar-trigger.directive.mjs +3 -3
  42. package/esm2022/radio/src/radio-item.directive.mjs +1 -2
  43. package/esm2022/switch/index.mjs +2 -1
  44. package/esm2022/switch/src/switch-input.directive.mjs +8 -6
  45. package/esm2022/switch/src/switch-root.directive.mjs +42 -18
  46. package/esm2022/switch/src/switch-thumb.directive.mjs +3 -3
  47. package/esm2022/tabs/index.mjs +38 -0
  48. package/esm2022/tabs/radix-ng-primitives-tabs.mjs +5 -0
  49. package/esm2022/tabs/src/tabs-content.directive.mjs +29 -0
  50. package/esm2022/tabs/src/tabs-context.service.mjs +43 -0
  51. package/esm2022/tabs/src/tabs-list.directive.mjs +23 -0
  52. package/esm2022/tabs/src/tabs-root.directive.mjs +54 -0
  53. package/esm2022/tabs/src/tabs-trigger.directive.mjs +52 -0
  54. package/esm2022/toggle-group/src/toggle-group-button.directive.mjs +10 -1
  55. package/esm2022/toggle-group/src/toggle-group-multi.directive.mjs +17 -7
  56. package/fesm2022/radix-ng-primitives-accordion.mjs +431 -0
  57. package/fesm2022/radix-ng-primitives-accordion.mjs.map +1 -0
  58. package/fesm2022/radix-ng-primitives-checkbox.mjs +87 -22
  59. package/fesm2022/radix-ng-primitives-checkbox.mjs.map +1 -1
  60. package/fesm2022/radix-ng-primitives-dropdown-menu.mjs +125 -0
  61. package/fesm2022/radix-ng-primitives-dropdown-menu.mjs.map +1 -0
  62. package/fesm2022/radix-ng-primitives-label.mjs +6 -7
  63. package/fesm2022/radix-ng-primitives-label.mjs.map +1 -1
  64. package/fesm2022/radix-ng-primitives-menu.mjs +9 -3
  65. package/fesm2022/radix-ng-primitives-menu.mjs.map +1 -1
  66. package/fesm2022/radix-ng-primitives-menubar.mjs +2 -2
  67. package/fesm2022/radix-ng-primitives-menubar.mjs.map +1 -1
  68. package/fesm2022/radix-ng-primitives-radio.mjs +0 -1
  69. package/fesm2022/radix-ng-primitives-radio.mjs.map +1 -1
  70. package/fesm2022/radix-ng-primitives-switch.mjs +50 -24
  71. package/fesm2022/radix-ng-primitives-switch.mjs.map +1 -1
  72. package/fesm2022/radix-ng-primitives-tabs.mjs +222 -0
  73. package/fesm2022/radix-ng-primitives-tabs.mjs.map +1 -0
  74. package/fesm2022/radix-ng-primitives-toggle-group.mjs +25 -6
  75. package/fesm2022/radix-ng-primitives-toggle-group.mjs.map +1 -1
  76. package/label/src/label-root.directive.d.ts +3 -2
  77. package/menu/README.md +1 -0
  78. package/menu/src/menu-item.directive.d.ts +2 -1
  79. package/package.json +19 -1
  80. package/switch/index.d.ts +1 -0
  81. package/switch/src/switch-root.directive.d.ts +26 -9
  82. package/tabs/index.d.ts +15 -0
  83. package/tabs/src/tabs-content.directive.d.ts +8 -0
  84. package/tabs/src/tabs-context.service.d.ts +22 -0
  85. package/tabs/src/tabs-list.directive.d.ts +6 -0
  86. package/tabs/src/tabs-root.directive.d.ts +37 -0
  87. package/tabs/src/tabs-trigger.directive.d.ts +19 -0
  88. package/toggle-group/src/toggle-group-button.directive.d.ts +9 -0
  89. package/toggle-group/src/toggle-group-multi.directive.d.ts +19 -6
@@ -0,0 +1 @@
1
+ # @radix-ng/primitives/accordion
@@ -0,0 +1,5 @@
1
+ export * from './src/accordion-root.directive';
2
+ export * from './src/accordion-item.directive';
3
+ export * from './src/accordion-header.directive';
4
+ export * from './src/accordion-trigger.directive';
5
+ export * from './src/accordion-content.directive';
@@ -0,0 +1,64 @@
1
+ import { CdkAccordionItem } from '@angular/cdk/accordion';
2
+ import { InjectionToken, OnInit } from '@angular/core';
3
+ import { RdxAccordionItemState } from './accordion-item.directive';
4
+ import { RdxAccordionOrientation } from './accordion-root.directive';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/cdk/accordion";
7
+ export declare const RdxAccordionContentToken: InjectionToken<RdxAccordionContentDirective>;
8
+ export declare class RdxAccordionContentDirective implements OnInit {
9
+ /**
10
+ * @ignore
11
+ */
12
+ private readonly elementRef;
13
+ /**
14
+ * @ignore
15
+ */
16
+ private initialized;
17
+ /**
18
+ * Current item state
19
+ */
20
+ state: import("@angular/core").WritableSignal<RdxAccordionItemState>;
21
+ /**
22
+ * When true, prevents the user from interacting with the accordion and all its items.
23
+ */
24
+ disabled: import("@angular/core").InputSignal<boolean>;
25
+ /**
26
+ * @ignore
27
+ */
28
+ accordionItem: CdkAccordionItem;
29
+ /**
30
+ * @ignore
31
+ */
32
+ orientation: RdxAccordionOrientation;
33
+ constructor();
34
+ /**
35
+ * @ignore
36
+ */
37
+ ngOnInit(): void;
38
+ /**
39
+ * @ignore
40
+ */
41
+ setOpen(state?: RdxAccordionItemState | undefined): void;
42
+ /**
43
+ * @ignore
44
+ */
45
+ private initialize;
46
+ /**
47
+ * @ignore
48
+ */
49
+ private setPresence;
50
+ /**
51
+ * @ignore
52
+ */
53
+ private togglePresence;
54
+ /**
55
+ * @ignore
56
+ */
57
+ private show;
58
+ /**
59
+ * @ignore
60
+ */
61
+ private hide;
62
+ static ɵfac: i0.ɵɵFactoryDeclaration<RdxAccordionContentDirective, never>;
63
+ static ɵdir: i0.ɵɵDirectiveDeclaration<RdxAccordionContentDirective, "[AccordionContent]", ["AccordionContent"], { "disabled": { "alias": "disabled"; "required": false; "isSignal": true; }; }, {}, never, never, true, [{ directive: typeof i1.CdkAccordionItem; inputs: {}; outputs: {}; }]>;
64
+ }
@@ -0,0 +1,23 @@
1
+ import { RdxAccordionItemState } from './accordion-item.directive';
2
+ import { RdxAccordionOrientation } from './accordion-root.directive';
3
+ import * as i0 from "@angular/core";
4
+ export declare class RdxAccordionHeaderDirective {
5
+ /**
6
+ * @ignore
7
+ */
8
+ private readonly accordionItem;
9
+ /**
10
+ * @ignore
11
+ */
12
+ getState(): RdxAccordionItemState;
13
+ /**
14
+ * @ignore
15
+ */
16
+ getDisabled(): string | undefined;
17
+ /**
18
+ * @ignore
19
+ */
20
+ getOrientation(): RdxAccordionOrientation;
21
+ static ɵfac: i0.ɵɵFactoryDeclaration<RdxAccordionHeaderDirective, never>;
22
+ static ɵdir: i0.ɵɵDirectiveDeclaration<RdxAccordionHeaderDirective, "[AccordionHeader]", never, {}, {}, never, never, true, never>;
23
+ }
@@ -0,0 +1,36 @@
1
+ import { InjectionToken } from '@angular/core';
2
+ import { RdxAccordionOrientation } from './accordion-root.directive';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/cdk/accordion";
5
+ export type RdxAccordionItemState = 'open' | 'closed';
6
+ export declare const RdxAccordionItemToken: InjectionToken<RdxAccordionItemDirective>;
7
+ export declare function injectAccordionItem(): RdxAccordionItemDirective;
8
+ export declare class RdxAccordionItemDirective {
9
+ /**
10
+ * @ignore
11
+ */
12
+ private accordionContent;
13
+ /**
14
+ * Current item state
15
+ */
16
+ state: import("@angular/core").WritableSignal<RdxAccordionItemState>;
17
+ /**
18
+ * When true, prevents the user from interacting with the item.
19
+ */
20
+ disabled: import("@angular/core").InputSignal<boolean>;
21
+ /**
22
+ * @ignore
23
+ */
24
+ orientation: RdxAccordionOrientation;
25
+ value?: string;
26
+ /**
27
+ * Changes current item state
28
+ */
29
+ setOpen(state?: RdxAccordionItemState): void;
30
+ /**
31
+ * @ignore
32
+ */
33
+ setOrientation(orientation: RdxAccordionOrientation): void;
34
+ static ɵfac: i0.ɵɵFactoryDeclaration<RdxAccordionItemDirective, never>;
35
+ static ɵdir: i0.ɵɵDirectiveDeclaration<RdxAccordionItemDirective, "[AccordionItem]", ["AccordionItem"], { "disabled": { "alias": "disabled"; "required": false; "isSignal": true; }; "value": { "alias": "value"; "required": false; }; }, {}, ["accordionContent"], never, true, [{ directive: typeof i1.CdkAccordion; inputs: {}; outputs: {}; }]>;
36
+ }
@@ -0,0 +1,57 @@
1
+ import { InjectionToken, OnInit } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export type RdxAccordionType = 'single' | 'multiple';
4
+ export type RdxAccordionOrientation = 'horizontal' | 'vertical';
5
+ export declare const RdxAccordionRootToken: InjectionToken<RdxAccordionRootDirective>;
6
+ export declare function injectAccordionRoot(): RdxAccordionRootDirective;
7
+ export declare class RdxAccordionRootDirective implements OnInit {
8
+ /**
9
+ * @private
10
+ * @ignore
11
+ */
12
+ private readonly accordionItems;
13
+ /**
14
+ * @private
15
+ * @ignore
16
+ */
17
+ private _orientation;
18
+ /**
19
+ * @private
20
+ * @ignore
21
+ */
22
+ private _value;
23
+ /**
24
+ * The value of the item to expand when initially rendered and type is "single". Use when you do not need to control the state of the items.
25
+ */
26
+ defaultValue?: string[];
27
+ /**
28
+ * Determines whether one or multiple items can be opened at the same time.
29
+ */
30
+ type: RdxAccordionType;
31
+ /**
32
+ * @ignore
33
+ */
34
+ collapsible: boolean;
35
+ /**
36
+ * The controlled value of the item to expand
37
+ */
38
+ set value(value: string | string[] | undefined);
39
+ /**
40
+ * The orientation of the accordion.
41
+ */
42
+ set orientation(orientation: RdxAccordionOrientation | undefined);
43
+ /**
44
+ * @ignore
45
+ */
46
+ ngOnInit(): void;
47
+ /**
48
+ * @ignore
49
+ */
50
+ onValueChange(value: string[]): void;
51
+ /**
52
+ * @ignore
53
+ */
54
+ getOrientation(): RdxAccordionOrientation;
55
+ static ɵfac: i0.ɵɵFactoryDeclaration<RdxAccordionRootDirective, never>;
56
+ static ɵdir: i0.ɵɵDirectiveDeclaration<RdxAccordionRootDirective, "[AccordionRoot]", never, { "defaultValue": { "alias": "defaultValue"; "required": false; }; "type": { "alias": "type"; "required": false; }; "collapsible": { "alias": "collapsible"; "required": false; }; "value": { "alias": "value"; "required": false; }; "orientation": { "alias": "orientation"; "required": false; }; }, {}, ["accordionItems"], never, true, never>;
57
+ }
@@ -0,0 +1,31 @@
1
+ import { RdxAccordionItemState } from './accordion-item.directive';
2
+ import { RdxAccordionOrientation } from './accordion-root.directive';
3
+ import * as i0 from "@angular/core";
4
+ export declare class RdxAccordionTriggerDirective {
5
+ /**
6
+ * @ignore
7
+ */
8
+ private readonly accordionRoot;
9
+ /**
10
+ * @ignore
11
+ */
12
+ private readonly accordionItem;
13
+ /**
14
+ * Fires when trigger clicked
15
+ */
16
+ onClick(): void;
17
+ /**
18
+ * @ignore
19
+ */
20
+ getState(): RdxAccordionItemState;
21
+ /**
22
+ * @ignore
23
+ */
24
+ getDisabled(): boolean | undefined;
25
+ /**
26
+ * @ignore
27
+ */
28
+ getOrientation(): RdxAccordionOrientation;
29
+ static ɵfac: i0.ɵɵFactoryDeclaration<RdxAccordionTriggerDirective, never>;
30
+ static ɵdir: i0.ɵɵDirectiveDeclaration<RdxAccordionTriggerDirective, "[AccordionTrigger]", never, {}, {}, never, never, true, never>;
31
+ }
@@ -1,3 +1,5 @@
1
+ export * from './src/checkbox-input.directive';
2
+ export * from './src/checkbox-button.directive';
1
3
  export * from './src/checkbox-indicator.directive';
2
4
  export * from './src/checkbox.directive';
3
5
  export * from './src/checkbox.token';
@@ -0,0 +1,8 @@
1
+ import * as i0 from "@angular/core";
2
+ export declare class RdxCheckboxButtonDirective {
3
+ protected readonly checkbox: import("@radix-ng/primitives/checkbox").RdxCheckboxDirective;
4
+ readonly id: import("@angular/core").InputSignal<string | null>;
5
+ protected readonly elementId: import("@angular/core").Signal<string | null>;
6
+ static ɵfac: i0.ɵɵFactoryDeclaration<RdxCheckboxButtonDirective, never>;
7
+ static ɵdir: i0.ɵɵDirectiveDeclaration<RdxCheckboxButtonDirective, "button[CheckboxButton]", never, { "id": { "alias": "id"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
8
+ }
@@ -2,5 +2,5 @@ import * as i0 from "@angular/core";
2
2
  export declare class RdxCheckboxIndicatorDirective {
3
3
  protected readonly checkbox: import("@radix-ng/primitives/checkbox").RdxCheckboxDirective;
4
4
  static ɵfac: i0.ɵɵFactoryDeclaration<RdxCheckboxIndicatorDirective, never>;
5
- static ɵdir: i0.ɵɵDirectiveDeclaration<RdxCheckboxIndicatorDirective, "[rdxCheckboxIndicator]", never, {}, {}, never, never, true, never>;
5
+ static ɵdir: i0.ɵɵDirectiveDeclaration<RdxCheckboxIndicatorDirective, "[CheckboxIndicator]", never, {}, {}, never, never, true, never>;
6
6
  }
@@ -0,0 +1,9 @@
1
+ import * as i0 from "@angular/core";
2
+ export declare class RdxCheckboxInputDirective {
3
+ protected readonly checkbox: import("@radix-ng/primitives/checkbox").RdxCheckboxDirective;
4
+ readonly id: import("@angular/core").InputSignal<string | undefined>;
5
+ protected readonly elementId: import("@angular/core").Signal<string | undefined>;
6
+ protected readonly value: import("@angular/core").Signal<"" | "on" | "off">;
7
+ static ɵfac: i0.ɵɵFactoryDeclaration<RdxCheckboxInputDirective, never>;
8
+ static ɵdir: i0.ɵɵDirectiveDeclaration<RdxCheckboxInputDirective, "input[CheckboxInput]", never, { "id": { "alias": "id"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
9
+ }
@@ -4,7 +4,7 @@ import * as i0 from "@angular/core";
4
4
  export type CheckboxState = 'unchecked' | 'checked' | 'indeterminate';
5
5
  export declare class RdxCheckboxDirective implements ControlValueAccessor, OnChanges {
6
6
  /**
7
- * Defines whether the checkbox is checked.
7
+ * The controlled checked state of the checkbox. Must be used in conjunction with onCheckedChange.
8
8
  */
9
9
  checked: boolean;
10
10
  /**
@@ -15,6 +15,7 @@ export declare class RdxCheckboxDirective implements ControlValueAccessor, OnCha
15
15
  * Defines whether the checkbox is disabled.
16
16
  */
17
17
  disabled: boolean;
18
+ required: boolean;
18
19
  /**
19
20
  * Event emitted when the checkbox checked state changes.
20
21
  */
@@ -37,9 +38,9 @@ export declare class RdxCheckboxDirective implements ControlValueAccessor, OnCha
37
38
  * @internal
38
39
  */
39
40
  private onTouched?;
40
- onKeydown(event: KeyboardEvent): void;
41
- onClick(): void;
42
- onBlur(): void;
41
+ protected onKeyDown(event: KeyboardEvent): void;
42
+ protected onClick($event: MouseEvent): void;
43
+ protected onBlur(): void;
43
44
  ngOnChanges(changes: SimpleChanges): void;
44
45
  /**
45
46
  * Sets the checked state of the checkbox.
@@ -66,8 +67,9 @@ export declare class RdxCheckboxDirective implements ControlValueAccessor, OnCha
66
67
  */
67
68
  setDisabledState(isDisabled: boolean): void;
68
69
  static ɵfac: i0.ɵɵFactoryDeclaration<RdxCheckboxDirective, never>;
69
- static ɵdir: i0.ɵɵDirectiveDeclaration<RdxCheckboxDirective, "button[rdxCheckbox]", never, { "checked": { "alias": "checked"; "required": false; }; "indeterminate": { "alias": "indeterminate"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; }, { "checkedChange": "checkedChange"; "indeterminateChange": "indeterminateChange"; }, never, never, true, never>;
70
+ static ɵdir: i0.ɵɵDirectiveDeclaration<RdxCheckboxDirective, "[CheckboxRoot]", never, { "checked": { "alias": "checked"; "required": false; }; "indeterminate": { "alias": "indeterminate"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "required": { "alias": "required"; "required": false; }; }, { "checkedChange": "checkedChange"; "indeterminateChange": "indeterminateChange"; }, never, never, true, never>;
70
71
  static ngAcceptInputType_checked: unknown;
71
72
  static ngAcceptInputType_indeterminate: unknown;
72
73
  static ngAcceptInputType_disabled: unknown;
74
+ static ngAcceptInputType_required: unknown;
73
75
  }
@@ -0,0 +1 @@
1
+ # @radix-ng/primitives/dropdown-menu
@@ -0,0 +1,5 @@
1
+ export * from './src/dropdown-menu-trigger.directive';
2
+ export * from './src/dropdown-menu-item.directive';
3
+ export * from './src/dropdown-menu-separator.directive';
4
+ export * from './src/dropdown-menu-content.directive';
5
+ export * from './src/dropdown-menu-label.directive';
@@ -0,0 +1,6 @@
1
+ import * as i0 from "@angular/core";
2
+ import * as i1 from "@radix-ng/primitives/menu";
3
+ export declare class RdxDropdownMenuContentDirective {
4
+ static ɵfac: i0.ɵɵFactoryDeclaration<RdxDropdownMenuContentDirective, never>;
5
+ static ɵdir: i0.ɵɵDirectiveDeclaration<RdxDropdownMenuContentDirective, "[DropdownMenuContent]", never, {}, {}, never, never, true, [{ directive: typeof i1.RdxMenuContentDirective; inputs: {}; outputs: {}; }]>;
6
+ }
@@ -0,0 +1,8 @@
1
+ import { BooleanInput } from '@angular/cdk/coercion';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "@radix-ng/primitives/menu";
4
+ export declare class RdxDropdownMenuItemDirective {
5
+ readonly disabled: import("@angular/core").InputSignalWithTransform<boolean, BooleanInput>;
6
+ static ɵfac: i0.ɵɵFactoryDeclaration<RdxDropdownMenuItemDirective, never>;
7
+ static ɵdir: i0.ɵɵDirectiveDeclaration<RdxDropdownMenuItemDirective, "[DropdownMenuItem]", never, { "disabled": { "alias": "rdxDisabled"; "required": false; "isSignal": true; }; }, {}, never, never, true, [{ directive: typeof i1.RdxMenuItemDirective; inputs: { "rdxDisabled": "disabled"; }; outputs: {}; }]>;
8
+ }
@@ -0,0 +1,5 @@
1
+ import * as i0 from "@angular/core";
2
+ export declare class RdxDropdownMenuLabelDirective {
3
+ static ɵfac: i0.ɵɵFactoryDeclaration<RdxDropdownMenuLabelDirective, never>;
4
+ static ɵdir: i0.ɵɵDirectiveDeclaration<RdxDropdownMenuLabelDirective, "div[DropdownMenuLabel]", never, {}, {}, never, never, true, never>;
5
+ }
@@ -0,0 +1,6 @@
1
+ import * as i0 from "@angular/core";
2
+ import * as i1 from "@radix-ng/primitives/menu";
3
+ export declare class RdxDropdownMenuSeparatorDirective {
4
+ static ɵfac: i0.ɵɵFactoryDeclaration<RdxDropdownMenuSeparatorDirective, never>;
5
+ static ɵdir: i0.ɵɵDirectiveDeclaration<RdxDropdownMenuSeparatorDirective, "[DropdownMenuSeparator]", never, {}, {}, never, never, true, [{ directive: typeof i1.RdxMenuSeparatorDirective; inputs: {}; outputs: {}; }]>;
6
+ }
@@ -0,0 +1,12 @@
1
+ import { BooleanInput } from '@angular/cdk/coercion';
2
+ import { CdkMenuTrigger } from '@angular/cdk/menu';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/cdk/menu";
5
+ export declare class RdxDropdownMenuTriggerDirective {
6
+ protected readonly cdkMenuTrigger: CdkMenuTrigger;
7
+ readonly disabled: import("@angular/core").InputSignalWithTransform<boolean, BooleanInput>;
8
+ onOpenChange: import("@angular/core").OutputRef<void>;
9
+ onPointerDown($event: MouseEvent): void;
10
+ static ɵfac: i0.ɵɵFactoryDeclaration<RdxDropdownMenuTriggerDirective, never>;
11
+ static ɵdir: i0.ɵɵDirectiveDeclaration<RdxDropdownMenuTriggerDirective, "[DropdownMenuTrigger]", never, { "disabled": { "alias": "disabled"; "required": false; "isSignal": true; }; }, { "onOpenChange": "onOpenChange"; }, never, never, true, [{ directive: typeof i1.CdkMenuTrigger; inputs: { "cdkMenuTriggerFor": "DropdownMenuTrigger"; }; outputs: {}; }]>;
12
+ }
@@ -0,0 +1,6 @@
1
+ export * from './src/accordion-root.directive';
2
+ export * from './src/accordion-item.directive';
3
+ export * from './src/accordion-header.directive';
4
+ export * from './src/accordion-trigger.directive';
5
+ export * from './src/accordion-content.directive';
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9wcmltaXRpdmVzL2FjY29yZGlvbi9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMsZ0NBQWdDLENBQUM7QUFDL0MsY0FBYyxrQ0FBa0MsQ0FBQztBQUNqRCxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMsbUNBQW1DLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3NyYy9hY2NvcmRpb24tcm9vdC5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9zcmMvYWNjb3JkaW9uLWl0ZW0uZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vc3JjL2FjY29yZGlvbi1oZWFkZXIuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vc3JjL2FjY29yZGlvbi10cmlnZ2VyLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL3NyYy9hY2NvcmRpb24tY29udGVudC5kaXJlY3RpdmUnO1xuIl19
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './index';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFkaXgtbmctcHJpbWl0aXZlcy1hY2NvcmRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9wcmltaXRpdmVzL2FjY29yZGlvbi9yYWRpeC1uZy1wcmltaXRpdmVzLWFjY29yZGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
@@ -0,0 +1,139 @@
1
+ import { CdkAccordionItem } from '@angular/cdk/accordion';
2
+ import { Directive, effect, ElementRef, inject, InjectionToken, input, signal } from '@angular/core';
3
+ import { animationFrameScheduler } from 'rxjs';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@angular/cdk/accordion";
6
+ export const RdxAccordionContentToken = new InjectionToken('RdxAccordionContentToken');
7
+ export class RdxAccordionContentDirective {
8
+ constructor() {
9
+ /**
10
+ * @ignore
11
+ */
12
+ this.elementRef = inject(ElementRef);
13
+ /**
14
+ * @ignore
15
+ */
16
+ this.initialized = signal(false);
17
+ /**
18
+ * Current item state
19
+ */
20
+ this.state = signal('closed');
21
+ /**
22
+ * When true, prevents the user from interacting with the accordion and all its items.
23
+ */
24
+ this.disabled = input(false);
25
+ /**
26
+ * @ignore
27
+ */
28
+ this.accordionItem = inject(CdkAccordionItem);
29
+ /**
30
+ * @ignore
31
+ */
32
+ this.orientation = 'vertical';
33
+ effect(() => {
34
+ if (this.state()) {
35
+ this.setPresence();
36
+ }
37
+ });
38
+ }
39
+ /**
40
+ * @ignore
41
+ */
42
+ ngOnInit() {
43
+ this.togglePresence();
44
+ }
45
+ /**
46
+ * @ignore
47
+ */
48
+ setOpen(state) {
49
+ if (this.disabled()) {
50
+ return;
51
+ }
52
+ if (state === undefined) {
53
+ this.state.update(() => (this.state() === 'open' ? 'closed' : 'open'));
54
+ }
55
+ else {
56
+ this.state.update(() => state);
57
+ }
58
+ }
59
+ /**
60
+ * @ignore
61
+ */
62
+ initialize() {
63
+ if (!this.initialized()) {
64
+ this.togglePresence();
65
+ animationFrameScheduler.schedule(() => {
66
+ this.elementRef.nativeElement
67
+ .getAnimations()
68
+ .forEach((animation) => animation.cancel());
69
+ this.initialized.set(true);
70
+ });
71
+ }
72
+ }
73
+ /**
74
+ * @ignore
75
+ */
76
+ setPresence() {
77
+ if (!this.initialized()) {
78
+ this.initialize();
79
+ return;
80
+ }
81
+ animationFrameScheduler.schedule(() => {
82
+ const animations = this.elementRef.nativeElement.getAnimations();
83
+ const hidden = this.elementRef.nativeElement.hasAttribute('hidden');
84
+ if (hidden) {
85
+ this.show();
86
+ const rect = this.elementRef.nativeElement.getBoundingClientRect();
87
+ const height = `${this.elementRef.nativeElement.scrollHeight /*rect.height*/}px`;
88
+ const width = `${rect.width}px`;
89
+ this.elementRef.nativeElement.style.setProperty('--radix-accordion-content-height', height);
90
+ this.elementRef.nativeElement.style.setProperty('--radix-accordion-content-width', width);
91
+ this.hide();
92
+ }
93
+ Promise.all(animations.map((animation) => animation.finished)).then(() => {
94
+ this.togglePresence();
95
+ });
96
+ });
97
+ }
98
+ /**
99
+ * @ignore
100
+ */
101
+ togglePresence() {
102
+ if (this.state() === 'open') {
103
+ this.show();
104
+ }
105
+ else {
106
+ this.hide();
107
+ }
108
+ }
109
+ /**
110
+ * @ignore
111
+ */
112
+ show() {
113
+ this.elementRef.nativeElement.removeAttribute('hidden');
114
+ }
115
+ /**
116
+ * @ignore
117
+ */
118
+ hide() {
119
+ this.elementRef.nativeElement.setAttribute('hidden', '');
120
+ }
121
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.4", ngImport: i0, type: RdxAccordionContentDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
122
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.0.4", type: RdxAccordionContentDirective, isStandalone: true, selector: "[AccordionContent]", inputs: { disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "attr.data-state": "state()", "attr.data-disabled": "disabled() ? \"\" : undefined", "attr.data-orientation": "orientation" } }, providers: [{ provide: RdxAccordionContentToken, useExisting: RdxAccordionContentDirective }], exportAs: ["AccordionContent"], hostDirectives: [{ directive: i1.CdkAccordionItem }], ngImport: i0 }); }
123
+ }
124
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.4", ngImport: i0, type: RdxAccordionContentDirective, decorators: [{
125
+ type: Directive,
126
+ args: [{
127
+ selector: '[AccordionContent]',
128
+ standalone: true,
129
+ exportAs: 'AccordionContent',
130
+ providers: [{ provide: RdxAccordionContentToken, useExisting: RdxAccordionContentDirective }],
131
+ host: {
132
+ '[attr.data-state]': 'state()',
133
+ '[attr.data-disabled]': 'disabled() ? "" : undefined',
134
+ '[attr.data-orientation]': 'orientation'
135
+ },
136
+ hostDirectives: [CdkAccordionItem]
137
+ }]
138
+ }], ctorParameters: () => [] });
139
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"accordion-content.directive.js","sourceRoot":"","sources":["../../../../../packages/primitives/accordion/src/accordion-content.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { CdkAccordionItem } from '@angular/cdk/accordion';\nimport {\n    Directive,\n    effect,\n    ElementRef,\n    inject,\n    InjectionToken,\n    input,\n    OnInit,\n    signal\n} from '@angular/core';\nimport { animationFrameScheduler } from 'rxjs';\n\nimport { RdxAccordionItemState } from './accordion-item.directive';\nimport { RdxAccordionOrientation } from './accordion-root.directive';\n\nexport const RdxAccordionContentToken = new InjectionToken<RdxAccordionContentDirective>(\n    'RdxAccordionContentToken'\n);\n\n@Directive({\n    selector: '[AccordionContent]',\n    standalone: true,\n    exportAs: 'AccordionContent',\n    providers: [{ provide: RdxAccordionContentToken, useExisting: RdxAccordionContentDirective }],\n    host: {\n        '[attr.data-state]': 'state()',\n        '[attr.data-disabled]': 'disabled() ? \"\" : undefined',\n        '[attr.data-orientation]': 'orientation'\n    },\n    hostDirectives: [CdkAccordionItem]\n})\nexport class RdxAccordionContentDirective implements OnInit {\n    /**\n     * @ignore\n     */\n    private readonly elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n    /**\n     * @ignore\n     */\n    private initialized = signal(false);\n    /**\n     * Current item state\n     */\n    state = signal<RdxAccordionItemState>('closed');\n    /**\n     * When true, prevents the user from interacting with the accordion and all its items.\n     */\n    disabled = input(false);\n    /**\n     * @ignore\n     */\n    accordionItem = inject(CdkAccordionItem);\n    /**\n     * @ignore\n     */\n    orientation: RdxAccordionOrientation = 'vertical';\n\n    constructor() {\n        effect(() => {\n            if (this.state()) {\n                this.setPresence();\n            }\n        });\n    }\n\n    /**\n     * @ignore\n     */\n    ngOnInit(): void {\n        this.togglePresence();\n    }\n\n    /**\n     * @ignore\n     */\n    setOpen(state?: RdxAccordionItemState | undefined): void {\n        if (this.disabled()) {\n            return;\n        }\n\n        if (state === undefined) {\n            this.state.update(() => (this.state() === 'open' ? 'closed' : 'open'));\n        } else {\n            this.state.update(() => state);\n        }\n    }\n\n    /**\n     * @ignore\n     */\n    private initialize(): void {\n        if (!this.initialized()) {\n            this.togglePresence();\n\n            animationFrameScheduler.schedule(() => {\n                this.elementRef.nativeElement\n                    .getAnimations()\n                    .forEach((animation) => animation.cancel());\n\n                this.initialized.set(true);\n            });\n        }\n    }\n\n    /**\n     * @ignore\n     */\n    private setPresence(): void {\n        if (!this.initialized()) {\n            this.initialize();\n\n            return;\n        }\n\n        animationFrameScheduler.schedule(() => {\n            const animations = this.elementRef.nativeElement.getAnimations();\n\n            const hidden = this.elementRef.nativeElement.hasAttribute('hidden');\n\n            if (hidden) {\n                this.show();\n\n                const rect = this.elementRef.nativeElement.getBoundingClientRect();\n                const height = `${this.elementRef.nativeElement.scrollHeight /*rect.height*/}px`;\n                const width = `${rect.width}px`;\n\n                this.elementRef.nativeElement.style.setProperty(\n                    '--radix-accordion-content-height',\n                    height\n                );\n\n                this.elementRef.nativeElement.style.setProperty(\n                    '--radix-accordion-content-width',\n                    width\n                );\n\n                this.hide();\n            }\n\n            Promise.all(animations.map((animation) => animation.finished)).then(() => {\n                this.togglePresence();\n            });\n        });\n    }\n\n    /**\n     * @ignore\n     */\n    private togglePresence(): void {\n        if (this.state() === 'open') {\n            this.show();\n        } else {\n            this.hide();\n        }\n    }\n\n    /**\n     * @ignore\n     */\n    private show(): void {\n        this.elementRef.nativeElement.removeAttribute('hidden');\n    }\n\n    /**\n     * @ignore\n     */\n    private hide(): void {\n        this.elementRef.nativeElement.setAttribute('hidden', '');\n    }\n}\n"]}
@@ -0,0 +1,44 @@
1
+ import { Directive } from '@angular/core';
2
+ import { injectAccordionItem } from './accordion-item.directive';
3
+ import * as i0 from "@angular/core";
4
+ export class RdxAccordionHeaderDirective {
5
+ constructor() {
6
+ /**
7
+ * @ignore
8
+ */
9
+ this.accordionItem = injectAccordionItem();
10
+ }
11
+ /**
12
+ * @ignore
13
+ */
14
+ getState() {
15
+ return this.accordionItem.state();
16
+ }
17
+ /**
18
+ * @ignore
19
+ */
20
+ getDisabled() {
21
+ return this.accordionItem.disabled() ? '' : undefined;
22
+ }
23
+ /**
24
+ * @ignore
25
+ */
26
+ getOrientation() {
27
+ return this.accordionItem.orientation;
28
+ }
29
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.4", ngImport: i0, type: RdxAccordionHeaderDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
30
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.4", type: RdxAccordionHeaderDirective, isStandalone: true, selector: "[AccordionHeader]", host: { properties: { "attr.data-state": "getState()", "attr.data-disabled": "getDisabled()", "attr.data-orientation": "getOrientation()" } }, ngImport: i0 }); }
31
+ }
32
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.4", ngImport: i0, type: RdxAccordionHeaderDirective, decorators: [{
33
+ type: Directive,
34
+ args: [{
35
+ selector: '[AccordionHeader]',
36
+ standalone: true,
37
+ host: {
38
+ '[attr.data-state]': 'getState()',
39
+ '[attr.data-disabled]': 'getDisabled()',
40
+ '[attr.data-orientation]': 'getOrientation()'
41
+ }
42
+ }]
43
+ }] });
44
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNjb3JkaW9uLWhlYWRlci5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9wcmltaXRpdmVzL2FjY29yZGlvbi9zcmMvYWNjb3JkaW9uLWhlYWRlci5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUxQyxPQUFPLEVBQUUsbUJBQW1CLEVBQXlCLE1BQU0sNEJBQTRCLENBQUM7O0FBWXhGLE1BQU0sT0FBTywyQkFBMkI7SUFUeEM7UUFVSTs7V0FFRztRQUNjLGtCQUFhLEdBQUcsbUJBQW1CLEVBQUUsQ0FBQztLQXNCMUQ7SUFwQkc7O09BRUc7SUFDSCxRQUFRO1FBQ0osT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQ3RDLENBQUM7SUFFRDs7T0FFRztJQUNILFdBQVc7UUFDUCxPQUFPLElBQUksQ0FBQyxhQUFhLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDO0lBQzFELENBQUM7SUFFRDs7T0FFRztJQUNILGNBQWM7UUFDVixPQUFPLElBQUksQ0FBQyxhQUFhLENBQUMsV0FBVyxDQUFDO0lBQzFDLENBQUM7OEdBekJRLDJCQUEyQjtrR0FBM0IsMkJBQTJCOzsyRkFBM0IsMkJBQTJCO2tCQVR2QyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxtQkFBbUI7b0JBQzdCLFVBQVUsRUFBRSxJQUFJO29CQUNoQixJQUFJLEVBQUU7d0JBQ0YsbUJBQW1CLEVBQUUsWUFBWTt3QkFDakMsc0JBQXNCLEVBQUUsZUFBZTt3QkFDdkMseUJBQXlCLEVBQUUsa0JBQWtCO3FCQUNoRDtpQkFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBpbmplY3RBY2NvcmRpb25JdGVtLCBSZHhBY2NvcmRpb25JdGVtU3RhdGUgfSBmcm9tICcuL2FjY29yZGlvbi1pdGVtLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBSZHhBY2NvcmRpb25PcmllbnRhdGlvbiB9IGZyb20gJy4vYWNjb3JkaW9uLXJvb3QuZGlyZWN0aXZlJztcblxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdbQWNjb3JkaW9uSGVhZGVyXScsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBob3N0OiB7XG4gICAgICAgICdbYXR0ci5kYXRhLXN0YXRlXSc6ICdnZXRTdGF0ZSgpJyxcbiAgICAgICAgJ1thdHRyLmRhdGEtZGlzYWJsZWRdJzogJ2dldERpc2FibGVkKCknLFxuICAgICAgICAnW2F0dHIuZGF0YS1vcmllbnRhdGlvbl0nOiAnZ2V0T3JpZW50YXRpb24oKSdcbiAgICB9XG59KVxuZXhwb3J0IGNsYXNzIFJkeEFjY29yZGlvbkhlYWRlckRpcmVjdGl2ZSB7XG4gICAgLyoqXG4gICAgICogQGlnbm9yZVxuICAgICAqL1xuICAgIHByaXZhdGUgcmVhZG9ubHkgYWNjb3JkaW9uSXRlbSA9IGluamVjdEFjY29yZGlvbkl0ZW0oKTtcblxuICAgIC8qKlxuICAgICAqIEBpZ25vcmVcbiAgICAgKi9cbiAgICBnZXRTdGF0ZSgpOiBSZHhBY2NvcmRpb25JdGVtU3RhdGUge1xuICAgICAgICByZXR1cm4gdGhpcy5hY2NvcmRpb25JdGVtLnN0YXRlKCk7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQGlnbm9yZVxuICAgICAqL1xuICAgIGdldERpc2FibGVkKCk6IHN0cmluZyB8IHVuZGVmaW5lZCB7XG4gICAgICAgIHJldHVybiB0aGlzLmFjY29yZGlvbkl0ZW0uZGlzYWJsZWQoKSA/ICcnIDogdW5kZWZpbmVkO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIEBpZ25vcmVcbiAgICAgKi9cbiAgICBnZXRPcmllbnRhdGlvbigpOiBSZHhBY2NvcmRpb25PcmllbnRhdGlvbiB7XG4gICAgICAgIHJldHVybiB0aGlzLmFjY29yZGlvbkl0ZW0ub3JpZW50YXRpb247XG4gICAgfVxufVxuIl19