@ngbase/adk 0.1.2 → 0.1.3

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 (203) hide show
  1. package/a11y/accessibility-group.d.ts +2 -5
  2. package/accordion/accordion-item.d.ts +3 -1
  3. package/autocomplete/autocomplete-input.d.ts +2 -4
  4. package/autocomplete/autocomplete.d.ts +12 -3
  5. package/carousel/carousel.d.ts +2 -2
  6. package/checkbox/checkbox.d.ts +11 -3
  7. package/checkbox/public-api.d.ts +1 -1
  8. package/datepicker/datepicker-trigger.d.ts +22 -5
  9. package/datepicker/datepicker.d.ts +2 -1
  10. package/drag/drag.d.ts +1 -2
  11. package/fesm2022/ngbase-adk-a11y.mjs +29 -26
  12. package/fesm2022/ngbase-adk-a11y.mjs.map +1 -1
  13. package/fesm2022/ngbase-adk-accordion.mjs +12 -2
  14. package/fesm2022/ngbase-adk-accordion.mjs.map +1 -1
  15. package/fesm2022/ngbase-adk-autocomplete.mjs +18 -18
  16. package/fesm2022/ngbase-adk-autocomplete.mjs.map +1 -1
  17. package/fesm2022/ngbase-adk-carousel.mjs +5 -5
  18. package/fesm2022/ngbase-adk-carousel.mjs.map +1 -1
  19. package/fesm2022/ngbase-adk-checkbox.mjs +8 -6
  20. package/fesm2022/ngbase-adk-checkbox.mjs.map +1 -1
  21. package/fesm2022/ngbase-adk-datepicker.mjs +76 -25
  22. package/fesm2022/ngbase-adk-datepicker.mjs.map +1 -1
  23. package/fesm2022/ngbase-adk-dialog.mjs +3 -3
  24. package/fesm2022/ngbase-adk-dialog.mjs.map +1 -1
  25. package/fesm2022/ngbase-adk-drag.mjs +1 -2
  26. package/fesm2022/ngbase-adk-drag.mjs.map +1 -1
  27. package/fesm2022/ngbase-adk-list.mjs +2 -2
  28. package/fesm2022/ngbase-adk-list.mjs.map +1 -1
  29. package/fesm2022/ngbase-adk-mask.mjs +5 -3
  30. package/fesm2022/ngbase-adk-mask.mjs.map +1 -1
  31. package/fesm2022/ngbase-adk-menu.mjs +22 -7
  32. package/fesm2022/ngbase-adk-menu.mjs.map +1 -1
  33. package/fesm2022/ngbase-adk-pagination.mjs +3 -3
  34. package/fesm2022/ngbase-adk-pagination.mjs.map +1 -1
  35. package/fesm2022/ngbase-adk-popover.mjs +25 -22
  36. package/fesm2022/ngbase-adk-popover.mjs.map +1 -1
  37. package/fesm2022/ngbase-adk-portal.mjs +5 -9
  38. package/fesm2022/ngbase-adk-portal.mjs.map +1 -1
  39. package/fesm2022/ngbase-adk-radio.mjs +6 -3
  40. package/fesm2022/ngbase-adk-radio.mjs.map +1 -1
  41. package/fesm2022/ngbase-adk-resizable.mjs.map +1 -1
  42. package/fesm2022/ngbase-adk-select.mjs +21 -13
  43. package/fesm2022/ngbase-adk-select.mjs.map +1 -1
  44. package/fesm2022/ngbase-adk-slider.mjs +4 -1
  45. package/fesm2022/ngbase-adk-slider.mjs.map +1 -1
  46. package/fesm2022/ngbase-adk-stepper.mjs.map +1 -1
  47. package/fesm2022/ngbase-adk-table.mjs +8 -6
  48. package/fesm2022/ngbase-adk-table.mjs.map +1 -1
  49. package/fesm2022/ngbase-adk-tabs.mjs.map +1 -1
  50. package/fesm2022/ngbase-adk-test.mjs +11 -1
  51. package/fesm2022/ngbase-adk-test.mjs.map +1 -1
  52. package/fesm2022/ngbase-adk-tour.mjs +2 -2
  53. package/fesm2022/ngbase-adk-tour.mjs.map +1 -1
  54. package/fesm2022/ngbase-adk-utils.mjs +12 -9
  55. package/fesm2022/ngbase-adk-utils.mjs.map +1 -1
  56. package/mask/mask.d.ts +1 -2
  57. package/menu/menu-trigger.d.ts +1 -1
  58. package/menu/menu.d.ts +8 -2
  59. package/package.json +11 -11
  60. package/pagination/pagination.d.ts +3 -3
  61. package/popover/base-popover.service.d.ts +1 -1
  62. package/popover/popover.d.ts +5 -4
  63. package/portal/portal-base.service.d.ts +3 -3
  64. package/portal/portal-close.directive.d.ts +3 -2
  65. package/radio/radio.d.ts +5 -1
  66. package/select/option.d.ts +1 -1
  67. package/select/select-base.d.ts +8 -6
  68. package/select/select.d.ts +5 -2
  69. package/slider/slider.d.ts +1 -0
  70. package/table/table.d.ts +2 -2
  71. package/test/utils.d.ts +19 -3
  72. package/utils/utils.d.ts +5 -4
  73. package/schematics/collection.json +0 -15
  74. package/schematics/components/files/accordion/accordion.ts.template +0 -53
  75. package/schematics/components/files/accordion/index.ts.template +0 -5
  76. package/schematics/components/files/alert/alert.ts.template +0 -62
  77. package/schematics/components/files/alert/index.ts.template +0 -1
  78. package/schematics/components/files/autocomplete/autocomplete.ts.template +0 -44
  79. package/schematics/components/files/autocomplete/index.ts.template +0 -5
  80. package/schematics/components/files/avatar/avatar.ts.template +0 -31
  81. package/schematics/components/files/avatar/index.ts.template +0 -1
  82. package/schematics/components/files/badge/badge.ts.template +0 -11
  83. package/schematics/components/files/badge/index.ts.template +0 -1
  84. package/schematics/components/files/breadcrumb/breadcrumb.ts.template +0 -49
  85. package/schematics/components/files/breadcrumb/index.ts.template +0 -1
  86. package/schematics/components/files/button/button.ts.template +0 -29
  87. package/schematics/components/files/button/index.ts.template +0 -5
  88. package/schematics/components/files/card/card.ts.template +0 -11
  89. package/schematics/components/files/card/index.ts.template +0 -5
  90. package/schematics/components/files/carousel/carousel.ts.template +0 -44
  91. package/schematics/components/files/carousel/index.ts.template +0 -1
  92. package/schematics/components/files/checkbox/checkbox.ts.template +0 -46
  93. package/schematics/components/files/checkbox/focus-style.directive.ts.template +0 -12
  94. package/schematics/components/files/checkbox/index.ts.template +0 -6
  95. package/schematics/components/files/chip/chip.ts.template +0 -36
  96. package/schematics/components/files/chip/index.ts.template +0 -1
  97. package/schematics/components/files/color-picker/color-picker.ts.template +0 -104
  98. package/schematics/components/files/color-picker/index.ts.template +0 -5
  99. package/schematics/components/files/command/command.ts.template +0 -82
  100. package/schematics/components/files/command/index.ts.template +0 -1
  101. package/schematics/components/files/datepicker/calendar.ts.template +0 -117
  102. package/schematics/components/files/datepicker/datepicker.ts.template +0 -58
  103. package/schematics/components/files/datepicker/index.ts.template +0 -2
  104. package/schematics/components/files/datepicker/time.ts.template +0 -54
  105. package/schematics/components/files/dialog/dialog.ts.template +0 -89
  106. package/schematics/components/files/dialog/index.ts.template +0 -5
  107. package/schematics/components/files/drawer/drawer.ts.template +0 -104
  108. package/schematics/components/files/drawer/index.ts.template +0 -5
  109. package/schematics/components/files/form-field/form-field.ts.template +0 -111
  110. package/schematics/components/files/form-field/index.ts.template +0 -6
  111. package/schematics/components/files/form-field/input-style.directive.ts.template +0 -11
  112. package/schematics/components/files/hover-card/hover-card.ts.template +0 -13
  113. package/schematics/components/files/hover-card/index.ts.template +0 -5
  114. package/schematics/components/files/icon/icon.ts.template +0 -16
  115. package/schematics/components/files/icon/index.ts.template +0 -1
  116. package/schematics/components/files/inline-edit/index.ts.template +0 -1
  117. package/schematics/components/files/inline-edit/inline-edit.ts.template +0 -24
  118. package/schematics/components/files/keys/index.ts.template +0 -5
  119. package/schematics/components/files/keys/key.ts.template +0 -35
  120. package/schematics/components/files/list/index.ts.template +0 -5
  121. package/schematics/components/files/list/list.ts.template +0 -28
  122. package/schematics/components/files/mask/index.ts.template +0 -1
  123. package/schematics/components/files/mask/mask.ts.template +0 -8
  124. package/schematics/components/files/menu/context-menu.ts.template +0 -14
  125. package/schematics/components/files/menu/index.ts.template +0 -8
  126. package/schematics/components/files/menu/mention.ts.template +0 -14
  127. package/schematics/components/files/menu/menu.ts.template +0 -37
  128. package/schematics/components/files/menu/navigation-menu.ts.template +0 -8
  129. package/schematics/components/files/otp/index.ts.template +0 -5
  130. package/schematics/components/files/otp/otp.ts.template +0 -37
  131. package/schematics/components/files/pagination/index.ts.template +0 -1
  132. package/schematics/components/files/pagination/pagination.ts.template +0 -71
  133. package/schematics/components/files/picasa/index.ts.template +0 -1
  134. package/schematics/components/files/picasa/picasa-base.component.ts.template +0 -80
  135. package/schematics/components/files/picasa/picasa.component.ts.template +0 -57
  136. package/schematics/components/files/picasa/picasa.directive.ts.template +0 -41
  137. package/schematics/components/files/picasa/picase.service.ts.template +0 -24
  138. package/schematics/components/files/popover/index.ts.template +0 -1
  139. package/schematics/components/files/popover/popover.ts.template +0 -64
  140. package/schematics/components/files/progress/index.ts.template +0 -5
  141. package/schematics/components/files/progress/progress.ts.template +0 -14
  142. package/schematics/components/files/radio/index.ts.template +0 -5
  143. package/schematics/components/files/radio/radio.ts.template +0 -35
  144. package/schematics/components/files/resizable/index.ts.template +0 -5
  145. package/schematics/components/files/resizable/resizable.ts.template +0 -56
  146. package/schematics/components/files/scroll-area/index.ts.template +0 -1
  147. package/schematics/components/files/scroll-area/scroll-area.ts.template +0 -40
  148. package/schematics/components/files/select/index.ts.template +0 -8
  149. package/schematics/components/files/select/list-selection.ts.template +0 -15
  150. package/schematics/components/files/select/option.ts.template +0 -35
  151. package/schematics/components/files/select/select-input.ts.template +0 -21
  152. package/schematics/components/files/select/select.ts.template +0 -96
  153. package/schematics/components/files/selectable/index.ts.template +0 -1
  154. package/schematics/components/files/selectable/selectable.ts.template +0 -34
  155. package/schematics/components/files/separator/index.ts.template +0 -5
  156. package/schematics/components/files/separator/separator.ts.template +0 -19
  157. package/schematics/components/files/sheet/index.ts.template +0 -5
  158. package/schematics/components/files/sheet/sheet.ts.template +0 -69
  159. package/schematics/components/files/sidenav/index.ts.template +0 -1
  160. package/schematics/components/files/sidenav/sidenav.ts.template +0 -48
  161. package/schematics/components/files/skeleton/index.ts.template +0 -1
  162. package/schematics/components/files/skeleton/skeleton.ts.template +0 -15
  163. package/schematics/components/files/slider/index.ts.template +0 -5
  164. package/schematics/components/files/slider/slider.ts.template +0 -35
  165. package/schematics/components/files/sonner/index.ts.template +0 -5
  166. package/schematics/components/files/sonner/sonner.ts.template +0 -59
  167. package/schematics/components/files/spinner/index.ts.template +0 -1
  168. package/schematics/components/files/spinner/spinner.ts.template +0 -79
  169. package/schematics/components/files/stepper/index.ts.template +0 -1
  170. package/schematics/components/files/stepper/stepper.ts.template +0 -88
  171. package/schematics/components/files/switch/index.ts.template +0 -5
  172. package/schematics/components/files/switch/switch.ts.template +0 -29
  173. package/schematics/components/files/table/body-cell.ts.template +0 -19
  174. package/schematics/components/files/table/body-row.ts.template +0 -21
  175. package/schematics/components/files/table/column.ts.template +0 -8
  176. package/schematics/components/files/table/head-cell.ts.template +0 -19
  177. package/schematics/components/files/table/head-row.ts.template +0 -27
  178. package/schematics/components/files/table/index.ts.template +0 -26
  179. package/schematics/components/files/table/table.ts.template +0 -20
  180. package/schematics/components/files/tabs/index.ts.template +0 -5
  181. package/schematics/components/files/tabs/tab.ts.template +0 -92
  182. package/schematics/components/files/theme/index.ts.template +0 -2
  183. package/schematics/components/files/theme/theme-button.component.ts.template +0 -26
  184. package/schematics/components/files/theme/theme.service.ts.template +0 -33
  185. package/schematics/components/files/toggle/index.ts.template +0 -5
  186. package/schematics/components/files/toggle/toggle.ts.template +0 -13
  187. package/schematics/components/files/toggle-group/index.ts.template +0 -5
  188. package/schematics/components/files/toggle-group/toggle-group.ts.template +0 -25
  189. package/schematics/components/files/tooltip/index.ts.template +0 -5
  190. package/schematics/components/files/tooltip/tooltip.ts.template +0 -45
  191. package/schematics/components/files/tour/index.ts.template +0 -1
  192. package/schematics/components/files/tour/tour.ts.template +0 -19
  193. package/schematics/components/files/tree/index.ts.template +0 -1
  194. package/schematics/components/files/tree/tree.ts.template +0 -66
  195. package/schematics/components/index.d.ts +0 -3
  196. package/schematics/components/index.js +0 -17
  197. package/schematics/components/index.js.map +0 -1
  198. package/schematics/components/index.ts +0 -29
  199. package/schematics/components/schema.d.ts +0 -6
  200. package/schematics/components/schema.js +0 -3
  201. package/schematics/components/schema.js.map +0 -1
  202. package/schematics/components/schema.json +0 -145
  203. package/schematics/components/schema.ts +0 -6
@@ -1,5 +0,0 @@
1
- /*
2
- * Public API Surface of list
3
- */
4
-
5
- export * from './list';
@@ -1,28 +0,0 @@
1
- import { Directive } from '@angular/core';
2
- import { NgbList, NgbListActionGroup, provideList } from '@ngbase/adk/list';
3
-
4
- @Directive({
5
- selector: '[<%= name %>ListStyle]',
6
- host: {
7
- class:
8
- 'flex items-center gap-2 py-2 px-2 hover:bg-muted-background cursor-pointer rounded-md text-left data-[focus="true"]:bg-muted-background',
9
- },
10
- })
11
- export class ListStyle {}
12
-
13
- @Directive({
14
- selector: '[<%= name %>List]',
15
- hostDirectives: [ListStyle],
16
- providers: [provideList(List)],
17
- host: {
18
- role: 'list',
19
- '[class]': 'disabled() ? "pointer-events-none cursor-not-allowed opacity-50" : ""',
20
- },
21
- })
22
- export class List extends NgbList {}
23
-
24
- @Directive({
25
- selector: '[<%= name %>ActionGroup]',
26
- hostDirectives: [NgbListActionGroup],
27
- })
28
- export class ListActionGroup {}
@@ -1 +0,0 @@
1
- export * from './mask';
@@ -1,8 +0,0 @@
1
- import { Directive } from '@angular/core';
2
- import { Mask } from '@ngbase/adk/mask';
3
-
4
- @Directive({
5
- selector: '[<%= name %>Mask]',
6
- hostDirectives: [{ directive: Mask, inputs: ['ngbMask: <%= name %>Mask', 'showMaskType'] }],
7
- })
8
- export class MaskInput {}
@@ -1,14 +0,0 @@
1
- import { Directive } from '@angular/core';
2
- import { NgbContextMenu } from '@ngbase/adk/menu';
3
-
4
- @Directive({
5
- selector: '[<%= name %>ContextMenu]',
6
- hostDirectives: [
7
- {
8
- directive: NgbContextMenu,
9
- inputs: ['ngbContextMenu: <%= name %>ContextMenu'],
10
- outputs: ['ctxOpen', 'ctxClose'],
11
- },
12
- ],
13
- })
14
- export class ContextMenu {}
@@ -1,8 +0,0 @@
1
- /*
2
- * Public API Surface of menu
3
- */
4
-
5
- export * from './menu';
6
- export * from './context-menu';
7
- export * from './navigation-menu';
8
- export * from './mention';
@@ -1,14 +0,0 @@
1
- import { Directive } from '@angular/core';
2
- import { NgbMentionTrigger } from '@ngbase/adk/menu';
3
-
4
- @Directive({
5
- selector: '[<%= name %>MentionTrigger]',
6
- hostDirectives: [
7
- {
8
- directive: NgbMentionTrigger,
9
- inputs: ['ngbMentionTrigger: <%= name %>MentionTrigger', 'key', 'options'],
10
- outputs: ['search'],
11
- },
12
- ],
13
- })
14
- export class MentionTrigger {}
@@ -1,37 +0,0 @@
1
- import { ChangeDetectionStrategy, Component, Directive } from '@angular/core';
2
- import { AccessibleGroup } from '@ngbase/adk/a11y';
3
- import { NgbMenu, NgbMenuTrigger, NgpMenuGroup, aliasMenu } from '@ngbase/adk/menu';
4
-
5
- @Component({
6
- selector: '<%= name %>-menu',
7
- exportAs: '<%= name %>Menu',
8
- changeDetection: ChangeDetectionStrategy.OnPush,
9
- providers: [aliasMenu(Menu)],
10
- imports: [AccessibleGroup, NgpMenuGroup],
11
- template: `
12
- <ng-template #container>
13
- <div ngbMenuGroup class="flex flex-col p-1">
14
- <ng-content />
15
- </div>
16
- </ng-template>
17
- `,
18
- })
19
- export class Menu extends NgbMenu {}
20
-
21
- @Directive({
22
- selector: '[<%= name %>MenuTrigger]',
23
- hostDirectives: [
24
- {
25
- directive: NgbMenuTrigger,
26
- inputs: [
27
- 'ngbMenuTrigger: <%= name %>MenuTrigger',
28
- 'ngbMenuTriggerData: <%= name %>MenuTriggerData',
29
- 'options',
30
- ],
31
- },
32
- ],
33
- host: {
34
- class: 'outline-none',
35
- },
36
- })
37
- export class MenuTrigger {}
@@ -1,8 +0,0 @@
1
- import { Directive } from '@angular/core';
2
- import { NgbNavigationMenu } from '@ngbase/adk/menu';
3
-
4
- @Directive({
5
- selector: '[<%= name %>NavigationMenu]',
6
- hostDirectives: [{ directive: NgbNavigationMenu, inputs: ['hover'] }],
7
- })
8
- export class NavigationMenu {}
@@ -1,5 +0,0 @@
1
- /*
2
- * Public API Surface of input
3
- */
4
-
5
- export * from './otp';
@@ -1,37 +0,0 @@
1
- import { ChangeDetectionStrategy, Component } from '@angular/core';
2
- import { injectDirectionality } from '@ngbase/adk/bidi';
3
- import { NgbInputOtp, NgbOtpInput, NgbOtpValue, aliasInputOtp } from '@ngbase/adk/otp';
4
- import { NumberOnly, RangePipe } from '@ngbase/adk/utils';
5
- import { InputStyle } from '<%= basepath %>/form-field';
6
-
7
- @Component({
8
- selector: '<%= name %>-input-otp',
9
- changeDetection: ChangeDetectionStrategy.OnPush,
10
- providers: [aliasInputOtp(InputOtp)],
11
- imports: [InputStyle, RangePipe, NgbOtpInput, NgbOtpValue, NumberOnly],
12
- template: `
13
- @for (num of size(); track $index; let l = $last) {
14
- @for (n of num | range; track n; let i = $index; let ll = $last) {
15
- <div
16
- <%= name %>InputStyle
17
- ngbOtpValue
18
- class="{{
19
- 'mb-0 aspect-square w-10 rounded-none !px-0 text-center text-base font-semibold data-[disabled]:bg-muted-background/40 data-[disabled]:text-muted data-[focus]:relative' +
20
- ((dir.isRtl() ? ll : i === 0) ? ' !rounded-l-lg' : '') +
21
- ((dir.isRtl() ? i === 0 : ll) ? ' !rounded-r-lg' : '')
22
- }}"
23
- ></div>
24
- }
25
- @if (!l) {
26
- <div class="px-2">-</div>
27
- }
28
- }
29
- <input type="text" ngbOtpInput ngbNumberOnly class="selection:bg-transparent" />
30
- `,
31
- host: {
32
- class: 'inline-flex items-center justify-center rounded-lg relative',
33
- },
34
- })
35
- export class InputOtp extends NgbInputOtp {
36
- readonly dir = injectDirectionality();
37
- }
@@ -1 +0,0 @@
1
- export * from './pagination';
@@ -1,71 +0,0 @@
1
- import { Component, input } from '@angular/core';
2
- import { aliasPagination, NgbPagination, NgbPaginationBtn } from '@ngbase/adk/pagination';
3
- import { Button } from '<%= basepath %>/button';
4
- import { Icon } from '<%= basepath %>/icon';
5
- import { Option, Select } from '<%= basepath %>/select';
6
- import { provideIcons } from '@ng-icons/core';
7
- import {
8
- lucideChevronLeft,
9
- lucideChevronRight,
10
- lucideChevronsLeft,
11
- lucideChevronsRight,
12
- } from '@ng-icons/lucide';
13
-
14
- @Component({
15
- selector: '<%= name %>-pagination',
16
- providers: [aliasPagination(Pagination)],
17
- viewProviders: [
18
- provideIcons({
19
- lucideChevronLeft,
20
- lucideChevronRight,
21
- lucideChevronsLeft,
22
- lucideChevronsRight,
23
- }),
24
- ],
25
- imports: [Button, Icon, Select, Option, NgbPaginationBtn],
26
- template: `
27
- <div class="flex items-center gap-2">
28
- <div>Rows per page</div>
29
- <<%= name %>-select [value]="size()" (valueChange)="sizeChanged($event)" class="w-20 !py-1.5">
30
- @for (size of sizeOptions(); track size) {
31
- <<%= name %>-option [value]="size">
32
- {{ size }}
33
- </<%= name %>-option>
34
- }
35
- </<%= name %>-select>
36
- </div>
37
- <div>Page {{ active() }} of {{ totalSnaps() }}</div>
38
- <div class="flex items-center gap-2">
39
- <button ngbPaginationBtn="prev" <%= name %>Button="outline" class="h-8 w-8 !p-2">
40
- <<%= name %>-icon name="lucideChevronsLeft" />
41
- </button>
42
- <button ngbPaginationBtn="prev" jump="-1" <%= name %>Button="outline" class="h-8 w-8 !p-2">
43
- <<%= name %>-icon name="lucideChevronLeft" />
44
- </button>
45
- @if (showPage()) {
46
- @for (snap of snaps(); track snap) {
47
- <button
48
- ngbPaginationBtn="page"
49
- [jump]="snap"
50
- <%= name %>Button="ghost"
51
- class="min-w-9 !p-2 ring-offset-background aria-[current=page]:bg-muted-background aria-[current=page]:text-primary"
52
- >
53
- {{ snap }}
54
- </button>
55
- }
56
- }
57
- <button ngbPaginationBtn="next" jump="1" <%= name %>Button="outline" class="h-8 w-8 !p-2">
58
- <<%= name %>-icon name="lucideChevronRight" />
59
- </button>
60
- <button ngbPaginationBtn="next" <%= name %>Button="outline" class="h-8 w-8 !p-2">
61
- <<%= name %>-icon name="lucideChevronsRight" />
62
- </button>
63
- </div>
64
- `,
65
- host: {
66
- class: 'flex items-center gap-8 font-semibold',
67
- },
68
- })
69
- export class Pagination extends NgbPagination {
70
- readonly showPage = input<boolean>(false);
71
- }
@@ -1 +0,0 @@
1
- export * from './picasa.directive';
@@ -1,80 +0,0 @@
1
- import {
2
- afterNextRender,
3
- ChangeDetectionStrategy,
4
- Component,
5
- viewChild,
6
- ViewContainerRef,
7
- } from '@angular/core';
8
- import { BaseDialog, DialogOptions } from '@ngbase/adk/portal';
9
- import { createHostAnimation, fadeAnimation } from '@ngbase/adk/utils';
10
- import { Subject } from 'rxjs';
11
-
12
- @Component({
13
- selector: '<%= name %>-dialog',
14
- changeDetection: ChangeDetectionStrategy.OnPush,
15
- template: `
16
- <div class="pointer-events-none flex h-full items-center justify-center">
17
- <div class="pointer-events-auto">
18
- <ng-container #myDialog />
19
- </div>
20
- <div
21
- class="backdropColor pointer-events-auto absolute top-0 -z-10 h-full w-full"
22
- (click)="!options.disableClose && close()"
23
- [@fadeAnimation]=""
24
- ></div>
25
- </div>
26
- `,
27
- host: {
28
- '[ngStyle]': '{ "z-index": options.overrideLowerDialog ? "982" : "980" }',
29
- class: 'fixed block top-0 bottom-0 left-0 right-0 overflow-auto pointer-events-none z-p',
30
- '[@parentAnimation]': '',
31
- },
32
- styles: `
33
- .backdropColor {
34
- background: rgba(0, 0, 0, 0.32);
35
- }
36
-
37
- .full-window {
38
- width: 100vw !important;
39
- height: 100vh;
40
- max-width: initial;
41
- top: 0;
42
- border-radius: 0;
43
- }
44
- `,
45
- animations: [createHostAnimation(['@fadeAnimation']), fadeAnimation('300ms')],
46
- })
47
- export class PicasaBase extends BaseDialog {
48
- myDialog = viewChild('myDialog', { read: ViewContainerRef });
49
-
50
- backdropColor = true;
51
- isSidePopup = true;
52
-
53
- options!: DialogOptions;
54
- classNames = '';
55
- isHideHeader = false;
56
- onDone = new Subject<any>();
57
-
58
- constructor() {
59
- super();
60
- afterNextRender(() => {
61
- this._afterViewSource.next(this.myDialog()!);
62
-
63
- // setTimeout(() => {
64
- // this.show.set(false);
65
- // }, 2000);
66
- });
67
- // this.dialogRef.afterClosed.subscribe(() => {
68
- // setTimeout(() => {
69
- // this.animationDone();
70
- // }, 500);
71
- // });
72
- }
73
-
74
- override setOptions(options: DialogOptions) {
75
- this.options = options;
76
- this.classNames = this.options.classNames?.join(' ') || '';
77
- this.isHideHeader = this.options.header || false;
78
- this.backdropColor = this.options.backdropColor || true;
79
- }
80
- }
@@ -1,57 +0,0 @@
1
- import { Component, ElementRef, afterNextRender, inject, viewChild } from '@angular/core';
2
- import { DialogRef } from '@ngbase/adk/portal';
3
- import { PicasaBase } from './picasa-base.component';
4
-
5
- @Component({
6
- selector: '<%= name %>-picasa',
7
- template: `
8
- <img
9
- #imgEl
10
- [src]="data.data.src"
11
- alt="Placeholder"
12
- class="max-h-[100vh] max-w-[100vw] object-contain"
13
- [style.viewTransitionName]="data.data.id"
14
- />
15
- `,
16
- host: {
17
- class: 'block',
18
- },
19
- })
20
- export class PicasaContainer {
21
- data = inject(DialogRef);
22
- imgEl = viewChild<ElementRef<HTMLImageElement>>('imgEl');
23
- dialogRef = inject(DialogRef);
24
- picasa = inject(PicasaBase);
25
-
26
- constructor() {
27
- let transform = '';
28
- afterNextRender(() => {
29
- const imgEl = this.imgEl()!.nativeElement;
30
- const target = this.data.data.target as HTMLElement;
31
- const { width, height, top, left } = target.getBoundingClientRect();
32
- const { clientWidth, clientHeight } = document.documentElement;
33
- const imgRect = imgEl.getBoundingClientRect();
34
- const scale = Math.max(width / imgRect.width, height / imgRect.height);
35
- imgEl.style.transform = `scale(${scale})`;
36
- const x = left + width / 2 - clientWidth / 2;
37
- const y = top + height / 2 - clientHeight / 2;
38
- transform = `translate3d(${x}px, ${y}px, 0) scale(${scale})`;
39
- imgEl.style.transform = transform;
40
- console.log(transform);
41
- setTimeout(() => {
42
- imgEl.style.transition = '300ms cubic-bezier(0.55, 0.31, 0.15, 0.93)';
43
- imgEl.style.transform = `none`;
44
- });
45
- });
46
-
47
- this.dialogRef.afterClosed.subscribe(() => {
48
- const imgEl = this.imgEl()!.nativeElement;
49
- imgEl.style.transition = '300ms cubic-bezier(0.55, 0.31, 0.15, 0.93)';
50
- imgEl.style.transform = transform;
51
- console.log(transform);
52
- imgEl.addEventListener('transitionend', this.picasa.onClose, {
53
- once: true,
54
- });
55
- });
56
- }
57
- }
@@ -1,41 +0,0 @@
1
- import { Directive, ElementRef, contentChildren, inject, input } from '@angular/core';
2
- import { PicasaContainer } from './picasa.component';
3
- import { picasaPortal } from './picase.service';
4
-
5
- @Directive({
6
- selector: '[<%= name %>Picasa]',
7
- })
8
- export class Picasa {
9
- dialog = picasaPortal();
10
- items = contentChildren(PicasaItem);
11
-
12
- open(src: string, id: string, target: HTMLElement) {
13
- this.dialog.open(PicasaContainer, {
14
- data: { src, id, target },
15
- classNames: ['bg-transparent', 'border-0', 'shadow-none'],
16
- height: '100vh',
17
- });
18
- }
19
- }
20
-
21
- @Directive({
22
- selector: 'img[<%= name %>PicasaItem]',
23
- host: {
24
- '(click)': 'open()',
25
- '[style.viewTransitionName]': 'id',
26
- },
27
- })
28
- export class PicasaItem {
29
- picasa = inject(Picasa);
30
- src = input.required<string>();
31
- el = inject<ElementRef<HTMLElement>>(ElementRef);
32
- id = 'generateId()';
33
-
34
- constructor() {
35
- (this.el.nativeElement.style as any).viewTransitionName = this.id;
36
- }
37
-
38
- open() {
39
- this.picasa.open(this.src(), this.id, this.el.nativeElement);
40
- }
41
- }
@@ -1,24 +0,0 @@
1
- import { basePortal, DialogInput, DialogOptions } from '@ngbase/adk/portal';
2
- import { PicasaBase } from './picasa-base.component';
3
-
4
- export function picasaPortal() {
5
- const NAME = 'picasa';
6
- const base = basePortal(NAME, PicasaBase);
7
-
8
- function open<T>(component: DialogInput, opt?: DialogOptions) {
9
- const { diaRef } = base.open(
10
- component,
11
- (comp, options) => {
12
- comp.instance.setOptions(options);
13
- },
14
- opt,
15
- );
16
-
17
- return diaRef;
18
- }
19
-
20
- function closeAll() {
21
- base.closeAll();
22
- }
23
- return { open, closeAll };
24
- }
@@ -1 +0,0 @@
1
- export * from './popover';
@@ -1,64 +0,0 @@
1
- import { ChangeDetectionStrategy, Component, Directive } from '@angular/core';
2
- import {
3
- aliasPopover,
4
- NgbPopover,
5
- NgbPopoverArrow,
6
- NgbPopoverBackdrop,
7
- NgbPopoverClose,
8
- NgbPopoverMain,
9
- ngbPopoverPortal,
10
- NgbPopoverTrigger,
11
- registerNgbPopover,
12
- } from '@ngbase/adk/popover';
13
-
14
- @Component({
15
- selector: '<%= name %>-popover',
16
- changeDetection: ChangeDetectionStrategy.OnPush,
17
- providers: [aliasPopover(Popover)],
18
- imports: [NgbPopoverBackdrop, NgbPopoverMain, NgbPopoverArrow],
19
- template: ` <div
20
- ngbPopoverMain
21
- [@slideInOutAnimation]
22
- class="menu-container pointer-events-auto fixed z-10 flex flex-col rounded-lg border bg-foreground shadow-md"
23
- >
24
- <div class="flex flex-1 flex-col overflow-auto" ngbPopoverArrow>
25
- <ng-container #myDialog />
26
- </div>
27
- </div>
28
- @if (options().backdrop) {
29
- <div ngbPopoverBackdrop class="pointer-events-auto fixed top-0 h-full w-full"></div>
30
- }`,
31
- host: {
32
- class:
33
- 'fixed top-0 left-0 w-full h-full pointer-events-none z-p flex items-center justify-center',
34
- },
35
- })
36
- class Popover extends NgbPopover {}
37
-
38
- export function registerPopover() {
39
- return registerNgbPopover(Popover);
40
- }
41
-
42
- export const popoverPortal = ngbPopoverPortal;
43
-
44
- @Directive({
45
- selector: '[<%= name %>PopoverTrigger]',
46
- hostDirectives: [
47
- {
48
- directive: NgbPopoverTrigger,
49
- inputs: [
50
- 'ngbPopoverTrigger: <%= name %>PopoverTrigger',
51
- 'ngbPopoverTriggerData: <%= name %>PopoverTriggerData',
52
- 'options',
53
- ],
54
- },
55
- ],
56
- providers: [registerPopover()],
57
- })
58
- export class PopoverTrigger {}
59
-
60
- @Directive({
61
- selector: '[<%= name %>PopoverClose]',
62
- hostDirectives: [NgbPopoverClose],
63
- })
64
- export class PopoverClose {}
@@ -1,5 +0,0 @@
1
- /*
2
- * Public API Surface of progress
3
- */
4
-
5
- export * from './progress';
@@ -1,14 +0,0 @@
1
- import { ChangeDetectionStrategy, Component } from '@angular/core';
2
- import { NgbProgress, NgbProgressBar } from '@ngbase/adk/progress';
3
-
4
- @Component({
5
- selector: '<%= name %>-progress',
6
- changeDetection: ChangeDetectionStrategy.OnPush,
7
- hostDirectives: [{ directive: NgbProgress, inputs: ['value'] }],
8
- imports: [NgbProgressBar],
9
- template: `<div class="h-full bg-primary transition" ngbProgressBar></div>`,
10
- host: {
11
- class: 'block h-2 my-1 bg-muted-background rounded-full',
12
- },
13
- })
14
- export class Progress {}
@@ -1,5 +0,0 @@
1
- /*
2
- * Public API Surface of radio
3
- */
4
-
5
- export * from './radio';
@@ -1,35 +0,0 @@
1
- import { ChangeDetectionStrategy, Component } from '@angular/core';
2
- import { NgbRadio, NgbRadioGroup, NgbRadioIndicator } from '@ngbase/adk/radio';
3
- import { ɵFocusStyle as FocusStyle } from '<%= basepath %>/checkbox';
4
-
5
- @Component({
6
- selector: '<%= name %>-radio-group',
7
- hostDirectives: [{ directive: NgbRadioGroup, inputs: ['value'], outputs: ['valueChange'] }],
8
- template: `<ng-content />`,
9
- host: {
10
- class: 'flex gap-2',
11
- },
12
- })
13
- export class RadioGroup {}
14
-
15
- @Component({
16
- selector: '<%= name %>-radio, [<%= name %>Radio]',
17
- changeDetection: ChangeDetectionStrategy.OnPush,
18
- hostDirectives: [{ directive: NgbRadio, inputs: ['value', 'disabled'] }],
19
- imports: [FocusStyle, NgbRadioIndicator],
20
- template: `
21
- <button
22
- <%= name %>FocusStyle
23
- ngbRadioIndicator
24
- class="custom-radio relative flex h-4 w-4 flex-none items-center justify-center rounded-full border border-primary group-aria-[disabled='true']:border-muted"
25
- >
26
- <div class="h-2 w-2 rounded-full bg-primary group-aria-[disabled='true']:bg-muted"></div>
27
- </button>
28
- <ng-content />
29
- `,
30
- host: {
31
- class:
32
- 'flex items-center gap-2 py-1 cursor-pointer aria-[disabled="true"]:opacity-40 aria-[disabled="true"]:cursor-not-allowed group',
33
- },
34
- })
35
- export class Radio {}
@@ -1,5 +0,0 @@
1
- /*
2
- * Public API Surface of resizable
3
- */
4
-
5
- export * from './resizable';
@@ -1,56 +0,0 @@
1
- import { ChangeDetectionStrategy, Component } from '@angular/core';
2
- import { Icon } from '<%= basepath %>/icon';
3
- import { provideIcons } from '@ng-icons/core';
4
- import { lucideGripVertical } from '@ng-icons/lucide';
5
- import {
6
- NgbGutter,
7
- NgbResizable,
8
- NgbResizableGroup,
9
- aliasResizable,
10
- aliasResizableGroup,
11
- } from '@ngbase/adk/resizable';
12
-
13
- @Component({
14
- selector: '<%= name %>-resizable-group',
15
- exportAs: '<%= name %>ResizableGroup',
16
- changeDetection: ChangeDetectionStrategy.OnPush,
17
- providers: [aliasResizableGroup(ResizableGroup)],
18
- template: `<ng-content select="<%= name %>-resizable" />`,
19
- host: {
20
- class: 'flex w-full',
21
- '[class.flex-col]': "direction() === 'vertical'",
22
- '[attr.id]': 'id',
23
- },
24
- })
25
- export class ResizableGroup extends NgbResizableGroup {}
26
-
27
- @Component({
28
- selector: '<%= name %>-resizable',
29
- exportAs: '<%= name %>Resizable',
30
- changeDetection: ChangeDetectionStrategy.OnPush,
31
- providers: [aliasResizable(Resizable)],
32
- viewProviders: [provideIcons({ lucideGripVertical })],
33
- imports: [Icon, NgbGutter],
34
- template: `<ng-content />
35
- <ng-template #dragElement>
36
- @if (draggable()) {
37
- <div
38
- ngbGutter
39
- class="{{
40
- 'dragElement relative flex cursor-ew-resize items-center justify-center after:absolute after:top-0' +
41
- (resizable.direction() === 'vertical'
42
- ? ' bottom-0 left-0 h-0 w-full cursor-ns-resize border-b after:-mt-1 after:h-2 after:w-full'
43
- : ' right-0 top-0 w-0 cursor-ew-resize border-l after:h-full after:w-2')
44
- }}"
45
- >
46
- <<%= name %>-icon name="lucideGripVertical" class="z-30 rounded-lg border
47
- bg-muted-background py-0.5" size=".75rem" [class]="resizable.direction() === 'vertical' ?
48
- 'rotate-90' : ''" />
49
- </div>
50
- }
51
- </ng-template>`,
52
- host: {
53
- class: 'relative overflow-hidden block flex-none',
54
- },
55
- })
56
- export class Resizable extends NgbResizable {}
@@ -1 +0,0 @@
1
- export * from './scroll-area';