@ojiepermana/angular 0.1.1 → 21.0.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 (133) hide show
  1. package/README.md +41 -249
  2. package/collection.json +25 -0
  3. package/fesm2022/ojiepermana-angular-chart.mjs +3714 -0
  4. package/fesm2022/ojiepermana-angular-chart.mjs.map +1 -0
  5. package/fesm2022/ojiepermana-angular-component.mjs +3463 -0
  6. package/fesm2022/ojiepermana-angular-component.mjs.map +1 -0
  7. package/fesm2022/ojiepermana-angular-generator-api.mjs +67 -0
  8. package/fesm2022/ojiepermana-angular-generator-api.mjs.map +1 -0
  9. package/fesm2022/ojiepermana-angular-layout.mjs +296 -408
  10. package/fesm2022/ojiepermana-angular-layout.mjs.map +1 -1
  11. package/fesm2022/ojiepermana-angular-navigation.mjs +2198 -404
  12. package/fesm2022/ojiepermana-angular-navigation.mjs.map +1 -1
  13. package/fesm2022/ojiepermana-angular-theme.mjs +381 -1
  14. package/fesm2022/ojiepermana-angular-theme.mjs.map +1 -1
  15. package/fesm2022/ojiepermana-angular.mjs +16 -1
  16. package/fesm2022/ojiepermana-angular.mjs.map +1 -1
  17. package/generator/api/README.md +183 -0
  18. package/generator/api/bin/schematics/init/index.js +88 -0
  19. package/generator/api/bin/schematics/sdk/index.js +58 -0
  20. package/generator/api/bin/src/config/loader.js +41 -0
  21. package/generator/api/bin/src/config/schema.js +56 -0
  22. package/generator/api/bin/src/emit/client.js +246 -0
  23. package/generator/api/bin/src/emit/metadata.js +295 -0
  24. package/generator/api/bin/src/emit/models.js +106 -0
  25. package/generator/api/bin/src/emit/navigation.js +56 -0
  26. package/generator/api/bin/src/emit/operations.js +122 -0
  27. package/generator/api/bin/src/emit/public-api.js +54 -0
  28. package/generator/api/bin/src/emit/services.js +87 -0
  29. package/generator/api/bin/src/engine.js +65 -0
  30. package/generator/api/bin/src/layout/per-domain.js +346 -0
  31. package/generator/api/bin/src/parser/bundle.js +25 -0
  32. package/generator/api/bin/src/parser/ir.js +320 -0
  33. package/generator/api/bin/src/parser/types.js +7 -0
  34. package/generator/api/bin/src/render/template.js +58 -0
  35. package/generator/api/bin/src/writer/index.js +69 -0
  36. package/generator/api/schematics/init/schema.json +19 -0
  37. package/generator/api/schematics/sdk/schema.json +19 -0
  38. package/generator/api/sdk.config.example.json +22 -0
  39. package/generator/guide/README.md +84 -0
  40. package/generator/guide/bin/schematics/build/index.js +35 -0
  41. package/generator/guide/bin/schematics/init/index.js +70 -0
  42. package/generator/guide/bin/src/config/loader.js +50 -0
  43. package/generator/guide/bin/src/config/schema.js +12 -0
  44. package/generator/guide/bin/src/engine/component.js +73 -0
  45. package/generator/guide/bin/src/engine/frontmatter.js +42 -0
  46. package/generator/guide/bin/src/engine/index.js +42 -0
  47. package/generator/guide/bin/src/engine/naming.js +39 -0
  48. package/generator/guide/bin/src/engine/render.js +18 -0
  49. package/generator/guide/bin/src/engine/routes.js +106 -0
  50. package/generator/guide/bin/src/engine/walk.js +35 -0
  51. package/generator/guide/guide.config.example.json +9 -0
  52. package/generator/guide/schematics/build/schema.json +14 -0
  53. package/generator/guide/schematics/init/schema.json +19 -0
  54. package/package.json +58 -38
  55. package/theme/styles/etos.css +38 -0
  56. package/theme/styles/index.css +32 -8
  57. package/theme/styles/themes/brand/etos/color.css +21 -0
  58. package/theme/styles/themes/brand/etos/style.css +50 -0
  59. package/theme/styles/themes/library/_components.css +63 -0
  60. package/theme/styles/themes/library/_layers.css +15 -0
  61. package/theme/styles/themes/library/_material-overrides.css +254 -0
  62. package/theme/styles/themes/library/_tokens.css +54 -0
  63. package/theme/styles/themes/library/color/amber.css +18 -0
  64. package/theme/styles/themes/library/color/blue.css +23 -0
  65. package/theme/styles/themes/library/color/green.css +18 -0
  66. package/theme/styles/themes/library/color/index.css +9 -0
  67. package/theme/styles/themes/library/color/purple.css +18 -0
  68. package/theme/styles/themes/library/color/red.css +18 -0
  69. package/theme/styles/themes/library/style/brutal.css +47 -0
  70. package/theme/styles/themes/library/style/default.css +51 -0
  71. package/theme/styles/themes/library/style/index.css +8 -0
  72. package/theme/styles/themes/library/style/sharp.css +47 -0
  73. package/theme/styles/themes/library/style/soft.css +47 -0
  74. package/theme/styles/themes/mode/dark.css +20 -0
  75. package/theme/styles/themes/mode/index.css +6 -0
  76. package/theme/styles/themes/mode/light.css +24 -0
  77. package/theme/styles/themes/taildwind.css +109 -0
  78. package/types/ojiepermana-angular-chart.d.ts +1094 -0
  79. package/types/ojiepermana-angular-component.d.ts +1174 -0
  80. package/types/ojiepermana-angular-generator-api.d.ts +85 -0
  81. package/types/ojiepermana-angular-layout.d.ts +125 -76
  82. package/types/ojiepermana-angular-navigation.d.ts +256 -116
  83. package/types/ojiepermana-angular-theme.d.ts +170 -1
  84. package/types/ojiepermana-angular.d.ts +2 -1
  85. package/fesm2022/ojiepermana-angular-internal.mjs +0 -489
  86. package/fesm2022/ojiepermana-angular-internal.mjs.map +0 -1
  87. package/fesm2022/ojiepermana-angular-navigation-horizontal.mjs +0 -721
  88. package/fesm2022/ojiepermana-angular-navigation-horizontal.mjs.map +0 -1
  89. package/fesm2022/ojiepermana-angular-navigation-vertical.mjs +0 -1647
  90. package/fesm2022/ojiepermana-angular-navigation-vertical.mjs.map +0 -1
  91. package/fesm2022/ojiepermana-angular-shell.mjs +0 -19
  92. package/fesm2022/ojiepermana-angular-shell.mjs.map +0 -1
  93. package/fesm2022/ojiepermana-angular-theme-component.mjs +0 -235
  94. package/fesm2022/ojiepermana-angular-theme-component.mjs.map +0 -1
  95. package/fesm2022/ojiepermana-angular-theme-directive.mjs +0 -29
  96. package/fesm2022/ojiepermana-angular-theme-directive.mjs.map +0 -1
  97. package/fesm2022/ojiepermana-angular-theme-service.mjs +0 -241
  98. package/fesm2022/ojiepermana-angular-theme-service.mjs.map +0 -1
  99. package/layout/README.md +0 -144
  100. package/layout/src/component/horizontal/horizontal.css +0 -130
  101. package/layout/src/component/vertical/vertical.css +0 -75
  102. package/layout/src/layout.css +0 -16
  103. package/navigation/README.md +0 -301
  104. package/navigation/horizontal/README.md +0 -49
  105. package/shell/README.md +0 -41
  106. package/styles/index.css +0 -2
  107. package/styles/resets.css +0 -22
  108. package/theme/README.md +0 -379
  109. package/theme/styles/adapters/material-ui/index.css +0 -205
  110. package/theme/styles/modes/dark.css +0 -84
  111. package/theme/styles/presets/colors/blue.css +0 -45
  112. package/theme/styles/presets/colors/brand.css +0 -52
  113. package/theme/styles/presets/colors/cyan.css +0 -45
  114. package/theme/styles/presets/colors/green.css +0 -45
  115. package/theme/styles/presets/colors/index.css +0 -7
  116. package/theme/styles/presets/colors/orange.css +0 -45
  117. package/theme/styles/presets/colors/purple.css +0 -45
  118. package/theme/styles/presets/colors/red.css +0 -45
  119. package/theme/styles/presets/styles/flat.css +0 -61
  120. package/theme/styles/presets/styles/glass.css +0 -28
  121. package/theme/styles/presets/styles/index.css +0 -2
  122. package/theme/styles/roles/index.css +0 -67
  123. package/theme/styles/tokens/foundation.css +0 -136
  124. package/theme/styles/tokens/semantic.css +0 -87
  125. package/theme/styles/utilities/index.css +0 -88
  126. package/types/ojiepermana-angular-internal.d.ts +0 -90
  127. package/types/ojiepermana-angular-navigation-horizontal.d.ts +0 -81
  128. package/types/ojiepermana-angular-navigation-vertical.d.ts +0 -262
  129. package/types/ojiepermana-angular-shell.d.ts +0 -14
  130. package/types/ojiepermana-angular-theme-component.d.ts +0 -46
  131. package/types/ojiepermana-angular-theme-directive.d.ts +0 -10
  132. package/types/ojiepermana-angular-theme-service.d.ts +0 -68
  133. /package/{navigation/vertical → chart}/README.md +0 -0
@@ -1,8 +1,8 @@
1
1
  import * as _angular_core from '@angular/core';
2
- import { EnvironmentProviders, InjectionToken } from '@angular/core';
3
2
  import { Params, QueryParamsHandling, IsActiveMatchOptions } from '@angular/router';
3
+ import { ClassValue } from 'clsx';
4
4
 
5
- type NavigationItemType = 'aside' | 'basic' | 'collapsable' | 'divider' | 'group' | 'spacer';
5
+ type NavigationItemType = 'aside' | 'basic' | 'collapsable' | 'divider' | 'group' | 'mega' | 'spacer';
6
6
  interface NavigationItemClasses {
7
7
  title?: string;
8
8
  subtitle?: string;
@@ -30,7 +30,7 @@ interface NavigationItemBase {
30
30
  tooltip?: string;
31
31
  /** Custom CSS classes */
32
32
  classes?: NavigationItemClasses;
33
- /** Material icon name */
33
+ /** Material Symbols icon name (ligature, e.g. `dashboard`, `menu_book`) */
34
34
  icon?: string;
35
35
  /** Badge configuration */
36
36
  badge?: NavigationItemBadge;
@@ -77,6 +77,16 @@ interface NavigationGroupItem extends NavigationItemBase {
77
77
  type: 'group';
78
78
  children: NavigationItem[];
79
79
  }
80
+ /**
81
+ * Mega menu branch — dirender sebagai panel full-width multi-kolom pada topbar.
82
+ * Children biasanya berupa `NavigationGroupItem` (per kolom) berisi `basic` items.
83
+ */
84
+ interface NavigationMegaItem extends NavigationItemBase {
85
+ type: 'mega';
86
+ /** Jumlah kolom saat viewport >= md (default: 4) */
87
+ columns?: number;
88
+ children: NavigationItem[];
89
+ }
80
90
  interface NavigationDividerItem extends NavigationItemBase {
81
91
  type: 'divider';
82
92
  children?: never;
@@ -85,7 +95,7 @@ interface NavigationSpacerItem extends NavigationItemBase {
85
95
  type: 'spacer';
86
96
  children?: never;
87
97
  }
88
- type NavigationBranchItem = NavigationAsideItem | NavigationCollapsableItem | NavigationGroupItem;
98
+ type NavigationBranchItem = NavigationAsideItem | NavigationCollapsableItem | NavigationGroupItem | NavigationMegaItem;
89
99
  type NavigationLeafItem = NavigationBasicItem | NavigationDividerItem | NavigationSpacerItem;
90
100
  type NavigationItem = NavigationBranchItem | NavigationLeafItem;
91
101
  /**
@@ -96,133 +106,263 @@ type NavigationItem = NavigationBranchItem | NavigationLeafItem;
96
106
  */
97
107
  type NavigationStructuredItem = NavigationItem;
98
108
  /**
99
- * Horizontal Navigation Variants
100
- * - default: standard top navigation treatment
101
- * - mega: roomier top navigation with larger dropdown treatment
102
- */
103
- type HorizontalNavigationVariant = 'default' | 'mega';
104
- /**
105
- * Vertical Navigation Appearances
106
- * - default: 280px width, full labels & icons
107
- * - collapsible: alias variant that currently reuses the default layout
109
+ * Sidebar Appearance
110
+ * - default: full width (lebar penuh) dengan label + icon
111
+ * - thin: icon-only, expand overlay saat hover
108
112
  */
109
- type VerticalNavigationAppearance = 'default' | 'collapsible';
113
+ type SidebarAppearance = 'default' | 'thin';
110
114
  /**
111
- * Vertical Navigation Modes
112
- * - over: Overlay mode (fixed position, z-index tinggi)
113
- * - side: Side mode (relative position, push content)
115
+ * Topbar Appearance
116
+ * - default: horizontal dengan dropdown untuk collapsable
117
+ * - megamenu: full-width panel multi-kolom untuk item `mega`
114
118
  */
115
- type VerticalNavigationMode = 'over' | 'side';
116
- /**
117
- * Vertical Navigation Position
118
- */
119
- type VerticalNavigationPosition = 'left' | 'right';
120
-
121
- interface NgNavigationConfig {
122
- defaultHorizontalVariant: HorizontalNavigationVariant;
123
- defaultVerticalVariant: VerticalNavigationAppearance;
124
- }
125
-
126
- declare function provideNgNavigation(config?: Partial<NgNavigationConfig>): EnvironmentProviders;
127
-
128
- declare class NavigationPreferencesService {
129
- private readonly config;
130
- private readonly document;
131
- private readonly isBrowser;
132
- private readonly storage;
133
- private readonly _horizontalVariant;
134
- private readonly _verticalAppearance;
135
- private readonly _activeItemId;
136
- private readonly _expandedItemIds;
137
- readonly horizontalVariant: _angular_core.Signal<HorizontalNavigationVariant>;
138
- readonly verticalAppearance: _angular_core.Signal<VerticalNavigationAppearance>;
139
- readonly activeItemId: _angular_core.Signal<string | null>;
140
- readonly expandedItemIds: _angular_core.Signal<string[]>;
141
- setHorizontalVariant(value: HorizontalNavigationVariant): void;
142
- setVerticalAppearance(value: VerticalNavigationAppearance): void;
143
- setActiveItem(id: string | null): void;
144
- clearActiveItem(): void;
145
- setExpandedItemIds(ids: readonly string[]): void;
146
- expandItem(id: string): void;
147
- collapseItem(id: string): void;
148
- toggleExpandedItem(id: string): void;
149
- clearExpandedItems(): void;
150
- reset(): void;
151
- syncWithNavigation(navigation: readonly NavigationItem[]): void;
152
- private readActiveItemId;
153
- private readExpandedItemIds;
154
- private readHorizontalVariant;
155
- private readVerticalAppearance;
156
- static ɵfac: _angular_core.ɵɵFactoryDeclaration<NavigationPreferencesService, never>;
157
- static ɵprov: _angular_core.ɵɵInjectableDeclaration<NavigationPreferencesService>;
158
- }
159
-
160
- declare const DEFAULT_NG_NAVIGATION_CONFIG: NgNavigationConfig;
161
- declare const NG_NAVIGATION_CONFIG: InjectionToken<NgNavigationConfig>;
162
-
163
- declare function getNavigationItemAction(item: NavigationItem): NavigationActionHandler | undefined;
164
- declare function getNavigationItemVisibilityHandler(item: NavigationItem): NavigationVisibilityHandler | undefined;
165
- declare function isNavigationItemHidden(item: NavigationItem): boolean;
166
- declare function shouldRenderNavigationItem(item: NavigationItem): boolean;
167
- declare function hasNavigationChildren(item: NavigationItem): item is NavigationBranchItem;
168
- declare function getNavigationChildren(item: NavigationItem): NavigationItem[];
169
- declare function isNavigationRoutableItem(item: NavigationItem): item is NavigationItem & NavigationRoutableItemBase;
119
+ type TopbarAppearance = 'default' | 'megamenu';
120
+ /** Sidebar position */
121
+ type SidebarPosition = 'left' | 'right';
122
+ /** Sidebar display mode */
123
+ type SidebarMode = 'over' | 'side';
124
+ type VerticalNavigationAppearance = SidebarAppearance;
125
+ type VerticalNavigationMode = SidebarMode;
126
+ type VerticalNavigationPosition = SidebarPosition;
170
127
 
128
+ /** Default registry key used when no id is specified. */
129
+ declare const DEFAULT_NAVIGATION_ID = "main";
171
130
  /**
172
- * Navigation Service
131
+ * Signal-based global state untuk navigation (sidebar/topbar).
173
132
  *
174
- * Service ini bertanggung jawab untuk:
175
- * 1. Store dan retrieve navigation data
176
- * 2. Menyediakan state aktif dan expanded item
177
- * 3. Utility functions untuk navigation operations
133
+ * Items disimpan dalam registry ber-key. Key default adalah `'main'`.
134
+ * Komponen `ui-sidebar` / `ui-topbar` memilih registry via input `navigationId`.
178
135
  */
179
136
  declare class NavigationService {
180
- private readonly preferences;
181
- private _navigation;
182
- readonly navigationItems: _angular_core.Signal<NavigationItem[]>;
183
- readonly activeItemId: _angular_core.Signal<string | null>;
184
- readonly flatNavigation: _angular_core.Signal<NavigationItem[]>;
185
- readonly expandedItemIds: _angular_core.Signal<string[]>;
186
- /**
187
- * Store navigation data
188
- * Biasanya dipanggil saat app initialization
189
- */
190
- storeNavigation(navigation: NavigationItem[]): void;
137
+ private readonly router;
138
+ private readonly destroyRef;
139
+ /** Internal version counter — incremented on every registry mutation. */
140
+ private readonly _version;
141
+ /** Internal map of registered navigation trees. */
142
+ private readonly _registry;
191
143
  /**
192
- * Get navigation data dari storage
144
+ * Backward-compatible accessor returns items for the default (`'main'`) key.
145
+ * Prefer `getItems(id)` when working with named registries.
193
146
  */
194
- getNavigation(): NavigationItem[];
147
+ readonly items: _angular_core.Signal<readonly NavigationItem[]>;
148
+ /** Sidebar collapsed (default ↔ thin) toggle untuk desktop. */
149
+ readonly collapsed: _angular_core.WritableSignal<boolean>;
150
+ /** Sheet drawer terbuka di mobile. */
151
+ readonly mobileOpen: _angular_core.WritableSignal<boolean>;
152
+ /** Set id grup / collapsable yang sedang terbuka. */
153
+ readonly openGroups: _angular_core.WritableSignal<ReadonlySet<string>>;
154
+ /** URL aktif terakhir. Update otomatis dari Router `NavigationEnd`. */
155
+ readonly activeUrl: _angular_core.WritableSignal<string>;
156
+ /** Trail id item yang sedang match dengan URL aktif (across ALL registries). */
157
+ readonly activeTrail: _angular_core.Signal<ReadonlySet<string>>;
158
+ constructor();
195
159
  /**
196
- * Delete navigation data dari storage
160
+ * Register items di registry.
161
+ *
162
+ * Overload:
163
+ * - `registerItems(items)` → key `'main'`
164
+ * - `registerItems(id, items)` → key spesifik
197
165
  */
198
- deleteNavigation(): void;
199
- setActiveItem(id: string | null): void;
200
- clearActiveItem(): void;
201
- getActiveItem(navigation?: NavigationItem[]): NavigationItem | null;
202
- expandItem(id: string): void;
203
- collapseItem(id: string): void;
204
- toggleItemExpanded(id: string): void;
205
- isItemExpanded(id: string): boolean;
206
- clearExpandedItems(): void;
166
+ registerItems(items: NavigationItem[]): void;
167
+ registerItems(id: string, items: NavigationItem[]): void;
168
+ /** Remove a named registry entry. */
169
+ removeItems(id: string): void;
207
170
  /**
208
- * Flatten navigation array
209
- * Convert nested structure menjadi flat array (hanya basic items)
210
- * Berguna untuk search, analytics, atau operations lainnya
171
+ * Computed yang mengembalikan items untuk key tertentu.
172
+ * Reactive terhadap perubahan registry.
211
173
  */
212
- getFlatNavigation(navigation: NavigationItem[], flatNavigation?: NavigationItem[]): NavigationItem[];
213
- /**
214
- * Get item by ID dari navigation tree
215
- * Recursive search untuk find item dengan id tertentu
216
- */
217
- getItem(id: string, navigation: NavigationItem[]): NavigationItem | null;
218
- /**
219
- * Get parent dari item dengan id tertentu
220
- * Berguna untuk breadcrumb atau navigation path
221
- */
222
- getItemParent(id: string, navigation: NavigationItem[], parent: NavigationItem[] | NavigationItem): NavigationItem[] | NavigationItem | null;
174
+ getItems(id: string): () => readonly NavigationItem[];
175
+ /** Toggle sidebar collapsed (default ↔ thin). */
176
+ toggleCollapsed(): void;
177
+ setCollapsed(value: boolean): void;
178
+ openMobile(): void;
179
+ closeMobile(): void;
180
+ toggleMobile(): void;
181
+ isGroupOpen(id: string): boolean;
182
+ toggleGroup(id: string): void;
183
+ setGroupOpen(id: string, open: boolean): void;
184
+ /** Apakah id termasuk dalam active trail saat ini. */
185
+ isActive(id: string | undefined): boolean;
223
186
  static ɵfac: _angular_core.ɵɵFactoryDeclaration<NavigationService, never>;
224
187
  static ɵprov: _angular_core.ɵɵInjectableDeclaration<NavigationService>;
225
188
  }
226
189
 
227
- export { DEFAULT_NG_NAVIGATION_CONFIG, NG_NAVIGATION_CONFIG, NavigationPreferencesService, NavigationService, getNavigationChildren, getNavigationItemAction, getNavigationItemVisibilityHandler, hasNavigationChildren, isNavigationItemHidden, isNavigationRoutableItem, provideNgNavigation, shouldRenderNavigationItem };
228
- export type { HorizontalNavigationVariant, NavigationActionHandler, NavigationAsideItem, NavigationBasicItem, NavigationBranchItem, NavigationCollapsableItem, NavigationDividerItem, NavigationGroupItem, NavigationItem, NavigationItemBadge, NavigationItemBase, NavigationItemClasses, NavigationItemType, NavigationLeafItem, NavigationRoutableItemBase, NavigationSpacerItem, NavigationStructuredItem, NavigationVisibilityHandler, NgNavigationConfig, VerticalNavigationAppearance, VerticalNavigationMode, VerticalNavigationPosition };
190
+ /**
191
+ * Material Symbols icon renderer.
192
+ * Menyuntikkan stylesheet font sekali saat dipakai agar consumer tidak perlu
193
+ * menambahkan `<link>` manual di `index.html`.
194
+ */
195
+ declare class UiNavIconComponent {
196
+ private readonly doc;
197
+ private readonly platformId;
198
+ readonly name: _angular_core.InputSignal<string>;
199
+ readonly class: _angular_core.InputSignal<string>;
200
+ readonly size: _angular_core.InputSignal<number | null>;
201
+ protected readonly fontVariationSettings = "\"FILL\" 0, \"wght\" 400, \"GRAD\" 0, \"opsz\" 24";
202
+ constructor();
203
+ protected readonly classes: _angular_core.Signal<string>;
204
+ private ensureFontStylesheet;
205
+ static ɵfac: _angular_core.ɵɵFactoryDeclaration<UiNavIconComponent, never>;
206
+ static ɵcmp: _angular_core.ɵɵComponentDeclaration<UiNavIconComponent, "ui-nav-icon", never, { "name": { "alias": "name"; "required": false; "isSignal": true; }; "class": { "alias": "class"; "required": false; "isSignal": true; }; "size": { "alias": "size"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
207
+ }
208
+
209
+ /** Concatenate and dedupe Tailwind class names. */
210
+ declare function cn(...inputs: ClassValue[]): string;
211
+
212
+ /**
213
+ * Recursive navigation item renderer (vertical context).
214
+ *
215
+ * Menerima item polymorphic dan delegasi ke template sesuai `type`.
216
+ * Mega dirender sebagai group biasa saat muncul di konteks vertical.
217
+ */
218
+ declare class UiNavItemComponent {
219
+ private readonly nav;
220
+ protected readonly cn: typeof cn;
221
+ readonly item: _angular_core.InputSignal<NavigationItem>;
222
+ readonly level: _angular_core.InputSignal<number>;
223
+ /** Compact / icon-only rendering (sidebar `thin`). */
224
+ readonly compact: _angular_core.InputSignal<boolean>;
225
+ protected readonly exactMatch: {
226
+ readonly exact: true;
227
+ readonly paths: "exact";
228
+ readonly queryParams: "exact";
229
+ readonly fragment: "exact";
230
+ readonly matrixParams: "exact";
231
+ };
232
+ protected readonly inexactMatch: {
233
+ readonly paths: "subset";
234
+ readonly queryParams: "subset";
235
+ readonly fragment: "ignored";
236
+ readonly matrixParams: "ignored";
237
+ };
238
+ protected readonly type: _angular_core.Signal<"aside" | "basic" | "collapsable" | "divider" | "group" | "mega" | "spacer">;
239
+ protected readonly groupItem: _angular_core.Signal<NavigationGroupItem>;
240
+ protected readonly collapsableItem: _angular_core.Signal<NavigationCollapsableItem>;
241
+ protected readonly megaItem: _angular_core.Signal<NavigationMegaItem>;
242
+ protected readonly asideItem: _angular_core.Signal<NavigationAsideItem>;
243
+ protected readonly basicItem: _angular_core.Signal<NavigationBasicItem>;
244
+ protected readonly headingId: _angular_core.Signal<string>;
245
+ protected isGroupOpen(): boolean;
246
+ protected isTrailActive(): boolean;
247
+ protected toggleGroup(): void;
248
+ protected runAction(): void;
249
+ static ɵfac: _angular_core.ɵɵFactoryDeclaration<UiNavItemComponent, never>;
250
+ static ɵcmp: _angular_core.ɵɵComponentDeclaration<UiNavItemComponent, "ui-nav-item", never, { "item": { "alias": "item"; "required": true; "isSignal": true; }; "level": { "alias": "level"; "required": false; "isSignal": true; }; "compact": { "alias": "compact"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
251
+ }
252
+
253
+ /**
254
+ * Vertical navigation (sidebar) — shadcn-styled.
255
+ *
256
+ * Variants:
257
+ * - `default`: 17.5rem, label + icon
258
+ * - `thin`: 4rem icon-only; hover memunculkan overlay expand (tidak push konten)
259
+ *
260
+ * Mobile (`< md`): saat `autoMobile=true` (default), host desktop disembunyikan
261
+ * dan konten dirender lewat CDK Overlay drawer dengan focus trap. State buka
262
+ * dikontrol lewat `NavigationService.mobileOpen`.
263
+ */
264
+ declare class SidebarComponent {
265
+ private readonly nav;
266
+ private readonly bp;
267
+ private readonly overlay;
268
+ private readonly vcr;
269
+ private readonly focusTrapFactory;
270
+ private readonly doc;
271
+ private readonly destroyRef;
272
+ readonly items: _angular_core.InputSignal<NavigationItem[]>;
273
+ /** Registry key di `NavigationService`. Default `'main'`. */
274
+ readonly navigationId: _angular_core.InputSignal<string>;
275
+ readonly appearance: _angular_core.InputSignal<SidebarAppearance>;
276
+ readonly position: _angular_core.InputSignal<SidebarPosition>;
277
+ readonly ariaLabel: _angular_core.InputSignal<string>;
278
+ readonly header: _angular_core.InputSignal<boolean>;
279
+ readonly class: _angular_core.InputSignal<string>;
280
+ /** Auto switch ke CDK overlay drawer saat viewport `< md`. */
281
+ readonly autoMobile: _angular_core.InputSignal<boolean>;
282
+ /** Auto-register `items` ke `NavigationService` agar `activeTrail` bekerja. */
283
+ readonly autoRegister: _angular_core.InputSignal<boolean>;
284
+ /** Resolved items: input jika disediakan, fallback ke registry NavigationService. */
285
+ protected readonly resolvedItems: _angular_core.Signal<readonly NavigationItem[]>;
286
+ private readonly hovered;
287
+ private readonly drawerTpl;
288
+ private drawerRef;
289
+ private focusTrap;
290
+ private previouslyFocused;
291
+ /** True saat viewport `< md` (767.98px). */
292
+ protected readonly isMobileMedia: _angular_core.Signal<boolean>;
293
+ protected readonly isMobile: _angular_core.Signal<boolean>;
294
+ protected readonly isExpanded: _angular_core.Signal<boolean>;
295
+ protected readonly isCompact: _angular_core.Signal<boolean>;
296
+ constructor();
297
+ protected readonly hostClasses: _angular_core.Signal<string>;
298
+ protected readonly innerClasses: _angular_core.Signal<string>;
299
+ protected onHoverEnter(): void;
300
+ protected onHoverLeave(): void;
301
+ /** Touch fallback: tap pada strip thin (ketika belum expanded) untuk expand. */
302
+ protected onHostClick(event: MouseEvent): void;
303
+ private openDrawer;
304
+ private closeDrawer;
305
+ static ɵfac: _angular_core.ɵɵFactoryDeclaration<SidebarComponent, never>;
306
+ static ɵcmp: _angular_core.ɵɵComponentDeclaration<SidebarComponent, "ui-sidebar", never, { "items": { "alias": "items"; "required": false; "isSignal": true; }; "navigationId": { "alias": "navigationId"; "required": false; "isSignal": true; }; "appearance": { "alias": "appearance"; "required": false; "isSignal": true; }; "position": { "alias": "position"; "required": false; "isSignal": true; }; "ariaLabel": { "alias": "ariaLabel"; "required": false; "isSignal": true; }; "header": { "alias": "header"; "required": false; "isSignal": true; }; "class": { "alias": "class"; "required": false; "isSignal": true; }; "autoMobile": { "alias": "autoMobile"; "required": false; "isSignal": true; }; "autoRegister": { "alias": "autoRegister"; "required": false; "isSignal": true; }; }, {}, never, ["[ui-sidebar-header]", "[ui-sidebar-footer]"], true, never>;
307
+ }
308
+
309
+ /**
310
+ * Horizontal navigation (topbar) — shadcn-styled.
311
+ *
312
+ * Variants:
313
+ * - `default`: horizontal list; item `collapsable` buka dropdown
314
+ * - `megamenu`: item `mega` buka panel full-width multi-kolom
315
+ */
316
+ declare class TopbarComponent {
317
+ protected readonly nav: NavigationService;
318
+ private readonly overlay;
319
+ private readonly vcr;
320
+ private readonly host;
321
+ private readonly destroyRef;
322
+ readonly items: _angular_core.InputSignal<NavigationItem[]>;
323
+ /** Registry key di `NavigationService`. Default `'main'`. */
324
+ readonly navigationId: _angular_core.InputSignal<string>;
325
+ readonly appearance: _angular_core.InputSignal<TopbarAppearance>;
326
+ readonly ariaLabel: _angular_core.InputSignal<string>;
327
+ readonly class: _angular_core.InputSignal<string>;
328
+ /** Auto-register `items` ke `NavigationService` agar `activeTrail` bekerja. */
329
+ readonly autoRegister: _angular_core.InputSignal<boolean>;
330
+ /** Tampilkan hamburger di `< md` yang men-toggle mobile drawer sidebar. */
331
+ readonly showHamburger: _angular_core.InputSignal<boolean>;
332
+ readonly hamburgerLabel: _angular_core.InputSignal<string>;
333
+ /** Resolved items: input jika disediakan, fallback ke registry NavigationService. */
334
+ protected readonly resolvedItems: _angular_core.Signal<readonly NavigationItem[]>;
335
+ protected readonly openId: _angular_core.WritableSignal<string | null>;
336
+ private active;
337
+ private readonly dropdownTpl;
338
+ private readonly megaTpl;
339
+ constructor();
340
+ protected readonly hostClasses: _angular_core.Signal<string>;
341
+ protected asBasic(i: NavigationItem): NavigationBasicItem;
342
+ protected asCollapsable(i: NavigationItem): NavigationCollapsableItem;
343
+ protected asGroup(i: NavigationItem): NavigationGroupItem;
344
+ protected asMega(i: NavigationItem): NavigationMegaItem;
345
+ protected isItemActive(id: string | undefined): boolean;
346
+ protected megaColsClass(columns?: number): string;
347
+ protected toggleDropdown(trigger: HTMLElement, item: NavigationItem): void;
348
+ protected openDropdown(trigger: HTMLElement, item: NavigationItem): void;
349
+ protected toggleMega(trigger: HTMLElement, item: NavigationItem): void;
350
+ protected openMega(trigger: HTMLElement, item: NavigationItem): void;
351
+ private attach;
352
+ protected closeAll(): void;
353
+ /** Menubar keyboard navigation: ArrowLeft/Right antar trigger, Home/End, ArrowDown fokus panel. */
354
+ protected onMenubarKeydown(event: KeyboardEvent): void;
355
+ /** Arrow-key navigation dalam dropdown/mega panel. */
356
+ protected onPanelKeydown(event: KeyboardEvent): void;
357
+ private collectPanelFocusables;
358
+ private focusFirstInPanel;
359
+ static ɵfac: _angular_core.ɵɵFactoryDeclaration<TopbarComponent, never>;
360
+ static ɵcmp: _angular_core.ɵɵComponentDeclaration<TopbarComponent, "ui-topbar", never, { "items": { "alias": "items"; "required": false; "isSignal": true; }; "navigationId": { "alias": "navigationId"; "required": false; "isSignal": true; }; "appearance": { "alias": "appearance"; "required": false; "isSignal": true; }; "ariaLabel": { "alias": "ariaLabel"; "required": false; "isSignal": true; }; "class": { "alias": "class"; "required": false; "isSignal": true; }; "autoRegister": { "alias": "autoRegister"; "required": false; "isSignal": true; }; "showHamburger": { "alias": "showHamburger"; "required": false; "isSignal": true; }; "hamburgerLabel": { "alias": "hamburgerLabel"; "required": false; "isSignal": true; }; }, {}, never, ["[ui-topbar-start]", "[ui-topbar-end]"], true, never>;
361
+ }
362
+
363
+ declare const DemoNavigationData: NavigationItem[];
364
+
365
+ declare const NAVIGATION_VERSION = "0.0.1";
366
+
367
+ export { DEFAULT_NAVIGATION_ID, DemoNavigationData, NAVIGATION_VERSION, NavigationService, SidebarComponent, TopbarComponent, UiNavIconComponent, UiNavItemComponent };
368
+ export type { NavigationActionHandler, NavigationAsideItem, NavigationBasicItem, NavigationBranchItem, NavigationCollapsableItem, NavigationDividerItem, NavigationGroupItem, NavigationItem, NavigationItemBadge, NavigationItemBase, NavigationItemClasses, NavigationItemType, NavigationLeafItem, NavigationMegaItem, NavigationRoutableItemBase, NavigationSpacerItem, NavigationStructuredItem, NavigationVisibilityHandler, SidebarAppearance, SidebarMode, SidebarPosition, TopbarAppearance, VerticalNavigationAppearance, VerticalNavigationMode, VerticalNavigationPosition };
@@ -1,2 +1,171 @@
1
+ import * as _angular_core from '@angular/core';
2
+ import { InjectionToken, Provider, EnvironmentProviders } from '@angular/core';
1
3
 
2
- export { };
4
+ declare const MODES: readonly ["light", "dark"];
5
+ type ThemeMode = (typeof MODES)[number];
6
+ declare const COLOR_SCHEMES: readonly ["light", "dark", "system"];
7
+ type ColorScheme = (typeof COLOR_SCHEMES)[number];
8
+ declare const COLORS: readonly ["blue", "red", "green", "purple", "amber"];
9
+ type ThemeColor = (typeof COLORS)[number];
10
+ declare const STYLES: readonly ["default", "sharp", "brutal", "soft"];
11
+ type ThemeStyle = (typeof STYLES)[number];
12
+ declare const BRANDS: readonly ["etos"];
13
+ type ThemeBrand = (typeof BRANDS)[number];
14
+ interface ThemeConfig {
15
+ readonly mode: ThemeMode;
16
+ readonly brand: ThemeBrand | null;
17
+ readonly color: ThemeColor;
18
+ readonly style: ThemeStyle;
19
+ }
20
+ interface MaterialThemeConfig {
21
+ /** Initial mode preference. Supports `system` for first-visit OS detection. */
22
+ readonly mode?: ColorScheme;
23
+ /** Initial brand bundle. When set, it replaces the explicit color and style layers. */
24
+ readonly brand?: ThemeBrand | null;
25
+ /** Alias for `brand` to match the persisted `theme-brand` setting. */
26
+ readonly 'theme-brand'?: ThemeBrand | null;
27
+ /** Initial brand color layer. */
28
+ readonly color?: ThemeColor;
29
+ /** Initial style personality layer. */
30
+ readonly style?: ThemeStyle;
31
+ /** @deprecated Use `mode` instead. */
32
+ readonly defaultMode?: ColorScheme;
33
+ /** Default brand bundle. When set, it replaces the explicit color and style layers. */
34
+ readonly defaultBrand?: ThemeBrand | null;
35
+ /** @deprecated Use `color` instead. */
36
+ readonly defaultColor?: ThemeColor;
37
+ /** @deprecated Use `style` instead. */
38
+ readonly defaultStyle?: ThemeStyle;
39
+ /** @deprecated Use `defaultMode` instead. */
40
+ readonly defaultScheme?: ColorScheme;
41
+ /** @deprecated Use `defaultColor` instead. */
42
+ readonly defaultTheme?: ThemeColor | string;
43
+ /** @deprecated Use `modeStorageKey` instead. */
44
+ readonly storageKey?: string | null;
45
+ /** @deprecated Use `modeStorageKey` instead. */
46
+ readonly schemeStorageKey?: string | null;
47
+ /** @deprecated Use `colorStorageKey` instead. */
48
+ readonly themeStorageKey?: string | null;
49
+ /** localStorage key used to persist the mode preference. Set to `null` to disable persistence. */
50
+ readonly modeStorageKey?: string | null;
51
+ /** localStorage key used to persist the brand bundle. Set to `null` to disable persistence. */
52
+ readonly brandStorageKey?: string | null;
53
+ /** localStorage key used to persist the color layer. Set to `null` to disable persistence. */
54
+ readonly colorStorageKey?: string | null;
55
+ /** localStorage key used to persist the style layer. Set to `null` to disable persistence. */
56
+ readonly styleStorageKey?: string | null;
57
+ }
58
+ interface ResolvedMaterialThemeConfig {
59
+ readonly defaultMode: ColorScheme;
60
+ readonly defaultBrand: ThemeBrand | null;
61
+ readonly defaultColor: ThemeColor;
62
+ readonly defaultStyle: ThemeStyle;
63
+ readonly modeStorageKey: string | null;
64
+ readonly brandStorageKey: string | null;
65
+ readonly colorStorageKey: string | null;
66
+ readonly styleStorageKey: string | null;
67
+ }
68
+ declare const MATERIAL_THEME_CONFIG: InjectionToken<MaterialThemeConfig>;
69
+ declare const DEFAULT_MATERIAL_THEME_CONFIG: ResolvedMaterialThemeConfig;
70
+ declare function isColorScheme(value: string | null | undefined): value is ColorScheme;
71
+ declare function isThemeColor(value: string | null | undefined): value is ThemeColor;
72
+ declare function isThemeStyle(value: string | null | undefined): value is ThemeStyle;
73
+ declare function isThemeBrand(value: string | null | undefined): value is ThemeBrand;
74
+
75
+ declare class ThemeService {
76
+ private readonly document;
77
+ private readonly destroyRef;
78
+ private readonly config;
79
+ private readonly initialBrand;
80
+ private readonly _modePreference;
81
+ private readonly _brand;
82
+ private readonly _color;
83
+ private readonly _style;
84
+ private readonly _systemPrefersDark;
85
+ readonly scheme: _angular_core.Signal<"light" | "dark" | "system">;
86
+ readonly brand: _angular_core.Signal<"etos" | null>;
87
+ readonly color: _angular_core.Signal<"blue" | "red" | "green" | "purple" | "amber">;
88
+ readonly theme: _angular_core.Signal<"blue" | "red" | "green" | "purple" | "amber">;
89
+ readonly style: _angular_core.Signal<"default" | "sharp" | "brutal" | "soft">;
90
+ readonly mode: _angular_core.Signal<"light" | "dark">;
91
+ readonly snapshot: _angular_core.Signal<ThemeConfig>;
92
+ readonly isDark: _angular_core.Signal<boolean>;
93
+ constructor();
94
+ setMode(mode: ThemeMode): void;
95
+ setScheme(scheme: ColorScheme): void;
96
+ setBrand(brand: ThemeBrand | null): void;
97
+ setColor(color: ThemeColor): void;
98
+ setTheme(theme: ThemeColor | string): void;
99
+ setStyle(style: ThemeStyle): void;
100
+ setAll(config: Partial<ThemeConfig> & {
101
+ readonly scheme?: ColorScheme;
102
+ }): void;
103
+ toggleScheme(): void;
104
+ toggleMode(): void;
105
+ reset(): void;
106
+ private resolveConfig;
107
+ private resolveMode;
108
+ private prefersDark;
109
+ private watchSystemScheme;
110
+ private readPersistedMode;
111
+ private readPersistedBrand;
112
+ private readPersistedColor;
113
+ private readPersistedStyle;
114
+ private persistMode;
115
+ private persistBrand;
116
+ private persistColor;
117
+ private persistStyle;
118
+ private clearPersistedBrand;
119
+ private clearPersistedColor;
120
+ private clearPersistedStyle;
121
+ private clearPersistedItem;
122
+ static ɵfac: _angular_core.ɵɵFactoryDeclaration<ThemeService, never>;
123
+ static ɵprov: _angular_core.ɵɵInjectableDeclaration<ThemeService>;
124
+ }
125
+
126
+ /**
127
+ * Opaque feature unit consumed by {@link provideMaterialTheme}. Mirrors
128
+ * Angular's router/http feature pattern so add-ons can be composed without
129
+ * widening the primary provider signature.
130
+ */
131
+ interface MaterialThemeFeature {
132
+ readonly providers: Provider[];
133
+ }
134
+ /**
135
+ * Bootstrap the shared theme for any `@ojiepermana/angular/*` entry point.
136
+ *
137
+ * By default wires up the theme config token and eagerly initializes `ThemeService`
138
+ * so root theme attributes are applied during bootstrap. Opt in
139
+ * to Angular Material defaults (ripple / form-field) via
140
+ * {@link withMaterialDefaults}.
141
+ * Supports shorthand `mode`, `color`, and `style` config keys.
142
+ *
143
+ * @example
144
+ * export const appConfig: ApplicationConfig = {
145
+ * providers: [
146
+ * provideAnimations(),
147
+ * provideMaterialTheme(
148
+ * {
149
+ * mode: 'system',
150
+ * color: 'blue',
151
+ * style: 'soft',
152
+ * },
153
+ * withMaterialDefaults(),
154
+ * ),
155
+ * ],
156
+ * };
157
+ */
158
+ declare function provideMaterialTheme(config?: MaterialThemeConfig, ...features: MaterialThemeFeature[]): EnvironmentProviders;
159
+ /**
160
+ * Opt-in Angular Material defaults tuned for the shared theme layer:
161
+ *
162
+ * - Disables the global Material ripple.
163
+ * - Forces `appearance: 'outline'` + `subscriptSizing: 'dynamic'` on every
164
+ * `mat-form-field`.
165
+ *
166
+ * Only apply when your app actually renders Angular Material components.
167
+ */
168
+ declare function withMaterialDefaults(): MaterialThemeFeature;
169
+
170
+ export { BRANDS, COLORS, COLOR_SCHEMES, DEFAULT_MATERIAL_THEME_CONFIG, MATERIAL_THEME_CONFIG, MODES, STYLES, ThemeService, isColorScheme, isThemeBrand, isThemeColor, isThemeStyle, provideMaterialTheme, withMaterialDefaults };
171
+ export type { ColorScheme, MaterialThemeConfig, MaterialThemeFeature, ResolvedMaterialThemeConfig, ThemeBrand, ThemeColor, ThemeConfig, ThemeMode, ThemeStyle };
@@ -1,2 +1,3 @@
1
+ declare const MATERIAL_VERSION = "0.0.1";
1
2
 
2
- export { };
3
+ export { MATERIAL_VERSION };