@theseam/ui-common 0.4.22 → 0.4.24-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (154) hide show
  1. package/breadcrumbs/breadcrumbs/breadcrumbs.component.scss +1 -1
  2. package/datatable/datatable/datatable.component.d.ts +10 -1
  3. package/datatable/models/action-item-column-position.d.ts +13 -0
  4. package/datatable/services/columns-manager.service.d.ts +7 -0
  5. package/datatable/utils/create-action-menu-column.d.ts +1 -1
  6. package/esm2020/breadcrumbs/breadcrumbs/breadcrumbs.component.mjs +2 -2
  7. package/esm2020/datatable/datatable/datatable.component.mjs +20 -4
  8. package/esm2020/datatable/datatable-action-menu/datatable-action-menu.component.mjs +2 -2
  9. package/esm2020/datatable/datatable-column-preferences-button/datatable-column-preferences-button.component.mjs +1 -1
  10. package/esm2020/datatable/datatable-export-button/datatable-export-button.component.mjs +1 -1
  11. package/esm2020/datatable/models/action-item-column-position.mjs +5 -0
  12. package/esm2020/datatable/services/columns-manager.service.mjs +27 -2
  13. package/esm2020/datatable/utils/create-action-menu-column.mjs +4 -3
  14. package/esm2020/datatable-dynamic/datatable-dynamic-action-menu/datatable-dynamic-action-menu.component.mjs +1 -1
  15. package/esm2020/datatable-dynamic/datatable-dynamic.component.mjs +1 -1
  16. package/esm2020/form-field/form-field-required-indicator.component.mjs +22 -7
  17. package/esm2020/form-field/input.directive.mjs +19 -16
  18. package/esm2020/form-field/testing/form-field.harness.mjs +45 -0
  19. package/esm2020/form-field/testing/index.mjs +2 -1
  20. package/esm2020/framework/base-layout/base-layout.component.mjs +14 -4
  21. package/esm2020/framework/base-layout/base-layout.module.mjs +6 -1
  22. package/esm2020/framework/base-layout/directives/base-layout-nav-toggle.directive.mjs +21 -5
  23. package/esm2020/framework/base-layout/directives/base-layout-side-bar-header.directive.mjs +16 -0
  24. package/esm2020/framework/base-layout/index.mjs +2 -1
  25. package/esm2020/framework/nav/horizontal-nav/horizontal-nav.component.mjs +55 -0
  26. package/esm2020/framework/nav/index.mjs +6 -0
  27. package/esm2020/framework/nav/nav-item/nav-item.component.mjs +227 -0
  28. package/esm2020/framework/nav/nav-utils.mjs +107 -0
  29. package/esm2020/framework/nav/nav.models.mjs +2 -0
  30. package/esm2020/framework/nav/nav.module.mjs +67 -0
  31. package/esm2020/framework/nav/nav.service.mjs +204 -0
  32. package/esm2020/framework/public-api.mjs +2 -1
  33. package/esm2020/framework/schema-form-controls/schema-form-submit-split/schema-form-submit-split.component.mjs +2 -2
  34. package/esm2020/framework/side-nav/side-nav-item/side-nav-item.component.mjs +28 -67
  35. package/esm2020/framework/side-nav/side-nav-toggle/side-nav-toggle.component.mjs +12 -5
  36. package/esm2020/framework/side-nav/side-nav.component.mjs +116 -38
  37. package/esm2020/framework/side-nav/side-nav.models.mjs +1 -1
  38. package/esm2020/framework/side-nav/side-nav.module.mjs +9 -39
  39. package/esm2020/framework/side-nav/side-nav.service.mjs +1 -1
  40. package/esm2020/framework/top-bar/index.mjs +3 -1
  41. package/esm2020/framework/top-bar/top-bar-compact-menu-btn-detail.directive.mjs +16 -0
  42. package/esm2020/framework/top-bar/top-bar-item.directive.mjs +10 -4
  43. package/esm2020/framework/top-bar/top-bar-menu-button/top-bar-menu-button.component.mjs +6 -4
  44. package/esm2020/framework/top-bar/top-bar-nav-toggle-btn-detail.directive.mjs +16 -0
  45. package/esm2020/framework/top-bar/top-bar.component.mjs +55 -11
  46. package/esm2020/framework/top-bar/top-bar.module.mjs +15 -5
  47. package/esm2020/google-maps/google-maps-places-autocomplete/google-maps-places-autocomplete.component.mjs +3 -3
  48. package/esm2020/layout/layout.service.mjs +12 -2
  49. package/esm2020/menu/menu-toggle.directive.mjs +7 -2
  50. package/esm2020/story-helpers/story-modal-container.component.mjs +3 -3
  51. package/esm2020/tabbed/tabbed.component.mjs +25 -18
  52. package/esm2020/table-cell-types/table-cell-type-string/table-cell-type-string.component.mjs +4 -2
  53. package/esm2020/utils/geo-json/coerce-feature-collection.mjs +1 -1
  54. package/esm2020/utils/geo-json/is-feature-collection.validator.mjs +1 -1
  55. package/esm2020/utils/geo-json/is-only-geometry-types.mjs +1 -1
  56. package/esm2020/utils/geo-json/merge-polygons.mjs +1 -1
  57. package/esm2020/utils/geo-json/no-inner-rings.validator.mjs +1 -1
  58. package/esm2020/utils/geo-json/split-multi-polygons.mjs +1 -1
  59. package/fesm2015/theseam-ui-common-breadcrumbs.mjs +2 -2
  60. package/fesm2015/theseam-ui-common-breadcrumbs.mjs.map +1 -1
  61. package/fesm2015/theseam-ui-common-datatable-dynamic.mjs +2 -2
  62. package/fesm2015/theseam-ui-common-datatable-dynamic.mjs.map +1 -1
  63. package/fesm2015/theseam-ui-common-datatable.mjs +56 -10
  64. package/fesm2015/theseam-ui-common-datatable.mjs.map +1 -1
  65. package/fesm2015/theseam-ui-common-form-field.mjs +92 -27
  66. package/fesm2015/theseam-ui-common-form-field.mjs.map +1 -1
  67. package/fesm2015/theseam-ui-common-framework.mjs +905 -156
  68. package/fesm2015/theseam-ui-common-framework.mjs.map +1 -1
  69. package/fesm2015/theseam-ui-common-google-maps.mjs +2 -2
  70. package/fesm2015/theseam-ui-common-google-maps.mjs.map +1 -1
  71. package/fesm2015/theseam-ui-common-layout.mjs +11 -2
  72. package/fesm2015/theseam-ui-common-layout.mjs.map +1 -1
  73. package/fesm2015/theseam-ui-common-menu.mjs +6 -1
  74. package/fesm2015/theseam-ui-common-menu.mjs.map +1 -1
  75. package/fesm2015/theseam-ui-common-story-helpers.mjs +2 -2
  76. package/fesm2015/theseam-ui-common-story-helpers.mjs.map +1 -1
  77. package/fesm2015/theseam-ui-common-tabbed.mjs +26 -19
  78. package/fesm2015/theseam-ui-common-tabbed.mjs.map +1 -1
  79. package/fesm2015/theseam-ui-common-table-cell-types.mjs +3 -1
  80. package/fesm2015/theseam-ui-common-table-cell-types.mjs.map +1 -1
  81. package/fesm2015/theseam-ui-common-utils.mjs.map +1 -1
  82. package/fesm2020/theseam-ui-common-breadcrumbs.mjs +2 -2
  83. package/fesm2020/theseam-ui-common-breadcrumbs.mjs.map +1 -1
  84. package/fesm2020/theseam-ui-common-datatable-dynamic.mjs +2 -2
  85. package/fesm2020/theseam-ui-common-datatable-dynamic.mjs.map +1 -1
  86. package/fesm2020/theseam-ui-common-datatable.mjs +56 -10
  87. package/fesm2020/theseam-ui-common-datatable.mjs.map +1 -1
  88. package/fesm2020/theseam-ui-common-form-field.mjs +88 -27
  89. package/fesm2020/theseam-ui-common-form-field.mjs.map +1 -1
  90. package/fesm2020/theseam-ui-common-framework.mjs +907 -156
  91. package/fesm2020/theseam-ui-common-framework.mjs.map +1 -1
  92. package/fesm2020/theseam-ui-common-google-maps.mjs +2 -2
  93. package/fesm2020/theseam-ui-common-google-maps.mjs.map +1 -1
  94. package/fesm2020/theseam-ui-common-layout.mjs +11 -2
  95. package/fesm2020/theseam-ui-common-layout.mjs.map +1 -1
  96. package/fesm2020/theseam-ui-common-menu.mjs +6 -1
  97. package/fesm2020/theseam-ui-common-menu.mjs.map +1 -1
  98. package/fesm2020/theseam-ui-common-story-helpers.mjs +2 -2
  99. package/fesm2020/theseam-ui-common-story-helpers.mjs.map +1 -1
  100. package/fesm2020/theseam-ui-common-tabbed.mjs +24 -17
  101. package/fesm2020/theseam-ui-common-tabbed.mjs.map +1 -1
  102. package/fesm2020/theseam-ui-common-table-cell-types.mjs +3 -1
  103. package/fesm2020/theseam-ui-common-table-cell-types.mjs.map +1 -1
  104. package/fesm2020/theseam-ui-common-utils.mjs.map +1 -1
  105. package/form-field/form-field-required-indicator.component.d.ts +6 -1
  106. package/form-field/input.directive.d.ts +9 -15
  107. package/form-field/testing/form-field.harness.d.ts +14 -0
  108. package/form-field/testing/index.d.ts +1 -0
  109. package/framework/base-layout/base-layout.component.d.ts +4 -2
  110. package/framework/base-layout/base-layout.component.scss +18 -10
  111. package/framework/base-layout/base-layout.module.d.ts +11 -10
  112. package/framework/base-layout/directives/base-layout-nav-toggle.directive.d.ts +8 -3
  113. package/framework/base-layout/directives/base-layout-side-bar-header.directive.d.ts +9 -0
  114. package/framework/base-layout/index.d.ts +1 -0
  115. package/framework/base-layout/styles/_variables.scss +21 -0
  116. package/framework/nav/_nav-theme.scss +4 -0
  117. package/framework/nav/horizontal-nav/horizontal-nav.component.d.ts +25 -0
  118. package/framework/nav/horizontal-nav/horizontal-nav.component.scss +50 -0
  119. package/framework/nav/index.d.ts +5 -0
  120. package/framework/nav/nav-item/nav-item.component.d.ts +74 -0
  121. package/framework/nav/nav-item/nav-item.component.scss +203 -0
  122. package/framework/nav/nav-utils.d.ts +20 -0
  123. package/framework/nav/nav.models.d.ts +77 -0
  124. package/framework/nav/nav.module.d.ts +17 -0
  125. package/framework/nav/nav.service.d.ts +27 -0
  126. package/framework/nav/styles/_themes/light/_variables.scss +56 -0
  127. package/framework/nav/styles/_themes/primary/_variables.scss +56 -0
  128. package/framework/nav/styles/_utilities.scss +3 -0
  129. package/framework/nav/styles/_variables.scss +2 -0
  130. package/framework/public-api.d.ts +1 -0
  131. package/framework/side-nav/side-nav-item/side-nav-item.component.d.ts +7 -14
  132. package/framework/side-nav/side-nav-item/side-nav-item.component.scss +7 -5
  133. package/framework/side-nav/side-nav-toggle/side-nav-toggle.component.d.ts +5 -3
  134. package/framework/side-nav/side-nav-toggle/side-nav-toggle.component.scss +3 -6
  135. package/framework/side-nav/side-nav.component.d.ts +13 -1
  136. package/framework/side-nav/side-nav.component.scss +0 -1
  137. package/framework/side-nav/side-nav.models.d.ts +7 -1
  138. package/framework/side-nav/side-nav.module.d.ts +1 -9
  139. package/framework/side-nav/styles/_themes/light/_variables.scss +24 -14
  140. package/framework/side-nav/styles/_themes/primary/_variables.scss +8 -0
  141. package/framework/top-bar/index.d.ts +2 -0
  142. package/framework/top-bar/top-bar-compact-menu-btn-detail.directive.d.ts +8 -0
  143. package/framework/top-bar/top-bar-item.directive.d.ts +4 -1
  144. package/framework/top-bar/top-bar-menu-button/top-bar-menu-button.component.d.ts +5 -2
  145. package/framework/top-bar/top-bar-nav-toggle-btn-detail.directive.d.ts +8 -0
  146. package/framework/top-bar/top-bar.component.d.ts +25 -3
  147. package/framework/top-bar/top-bar.component.scss +7 -2
  148. package/framework/top-bar/top-bar.module.d.ts +10 -8
  149. package/layout/layout.service.d.ts +9 -1
  150. package/menu/menu-toggle.directive.d.ts +2 -1
  151. package/package.json +2 -2
  152. package/styles/vendor/ngx-datatable/_ngx-datatable.scss +57 -14
  153. package/styles/vendor/ngx-datatable/_themes/bootstrap/_variables.scss +33 -5
  154. package/tabbed/tabbed.component.d.ts +9 -4
@@ -0,0 +1,204 @@
1
+ import { Injectable } from '@angular/core';
2
+ import { NavigationEnd } from '@angular/router';
3
+ import { BehaviorSubject, defer, Observable, Subject } from 'rxjs';
4
+ import { distinctUntilChanged, filter, map, shareReplay, startWith, switchMap } from 'rxjs/operators';
5
+ import { hasProperty, notNullOrUndefined } from '@theseam/ui-common/utils';
6
+ import { areSameHorizontalNavItem, getHorizontalNavItemStateProp, horizontalNavItemCanExpand, horizontalNavItemHasActiveChild, horizontalNavItemHasChildren, horizontalNavItemHasExpandedChild, isHorizontalNavItemActive, isHorizontalNavItemType, setDefaultHorizontalNavItemState, setHorizontalNavItemStateProp } from './nav-utils';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "@angular/router";
9
+ export class TheSeamNavService {
10
+ constructor(_router) {
11
+ this._router = _router;
12
+ this._updatingCount = new BehaviorSubject(0);
13
+ this.itemChanged = new Subject();
14
+ this.loading$ = this._updatingCount.pipe(map(count => count > 0), distinctUntilChanged(), shareReplay({ bufferSize: 1, refCount: true }));
15
+ }
16
+ createItemsObservable(items) {
17
+ return defer(() => {
18
+ this.updateItemsStates(items);
19
+ this.updateRouterFocusedItem(items);
20
+ return new Observable((subscriber) => {
21
+ const stateChangeSub = this.itemChanged.pipe(switchMap(change => {
22
+ if (change.prop === 'focused' && change.newValue) {
23
+ this.updateFocusedItem(items, change.item);
24
+ }
25
+ return this.loading$.pipe(filter(loading => !loading));
26
+ })).subscribe(() => {
27
+ subscriber.next(items);
28
+ });
29
+ try {
30
+ this.updateItemsStates(items);
31
+ }
32
+ catch (err) {
33
+ subscriber.error(err);
34
+ }
35
+ const routeChangeSub = this._router.events.pipe(filter(event => event instanceof NavigationEnd)).subscribe(event => {
36
+ try {
37
+ this.updateItemsStates(items);
38
+ this.updateRouterFocusedItem(items);
39
+ }
40
+ catch (err) {
41
+ subscriber.error(err);
42
+ }
43
+ });
44
+ return () => {
45
+ stateChangeSub.unsubscribe();
46
+ routeChangeSub.unsubscribe();
47
+ };
48
+ }).pipe(startWith(items));
49
+ });
50
+ }
51
+ _incUpdatingCount() {
52
+ this._updatingCount.next(this._updatingCount.value + 1);
53
+ }
54
+ _decrUpdatingCount() {
55
+ this._updatingCount.next(this._updatingCount.value - 1);
56
+ }
57
+ updateItemsStates(items) {
58
+ this._incUpdatingCount();
59
+ try {
60
+ for (const item of items) {
61
+ if (horizontalNavItemHasChildren(item)) {
62
+ this.updateItemsStates(item.children);
63
+ }
64
+ this.updateItemState(item);
65
+ }
66
+ this._decrUpdatingCount();
67
+ }
68
+ catch (err) {
69
+ this._decrUpdatingCount();
70
+ throw err;
71
+ }
72
+ }
73
+ updateItemState(item) {
74
+ this._incUpdatingCount();
75
+ try {
76
+ setDefaultHorizontalNavItemState(item);
77
+ this.setItemStateProp(item, 'active', this.horizontalNavLinkActive(item));
78
+ // TODO: Implement this in a more optimized way. Unless our apps start
79
+ // having large navs constantly updating their state, this shouldn't
80
+ // have much impact on performance.
81
+ this._updateItemExpandedState(item);
82
+ this._decrUpdatingCount();
83
+ }
84
+ catch (err) {
85
+ this._decrUpdatingCount();
86
+ throw err;
87
+ }
88
+ }
89
+ horizontalNavLinkActive(item) {
90
+ if (isHorizontalNavItemType(item, 'link')) {
91
+ const url = this._getUrl(item);
92
+ if (notNullOrUndefined(url)) {
93
+ const opts = this._getMatchOptions(item);
94
+ return this._router.isActive(url, opts);
95
+ }
96
+ }
97
+ return false;
98
+ }
99
+ _updateItemsExpandedState(items) {
100
+ for (const item of items) {
101
+ if (horizontalNavItemHasChildren(item)) {
102
+ this._updateItemsExpandedState(item.children);
103
+ }
104
+ this._updateItemExpandedState(item);
105
+ }
106
+ }
107
+ _updateItemExpandedState(item) {
108
+ if (!horizontalNavItemCanExpand(item)) {
109
+ if (getHorizontalNavItemStateProp(item, 'expanded')) {
110
+ this.setItemStateProp(item, 'expanded', false);
111
+ }
112
+ return;
113
+ }
114
+ if (horizontalNavItemHasChildren(item)) {
115
+ this._updateItemsExpandedState(item.children);
116
+ }
117
+ if (horizontalNavItemHasActiveChild(item) || horizontalNavItemHasExpandedChild(item)) {
118
+ if (!getHorizontalNavItemStateProp(item, 'expanded')) {
119
+ this.setItemStateProp(item, 'expanded', true);
120
+ }
121
+ }
122
+ else {
123
+ if (getHorizontalNavItemStateProp(item, 'expanded')) {
124
+ this.setItemStateProp(item, 'expanded', false);
125
+ }
126
+ }
127
+ }
128
+ updateRouterFocusedItem(items) {
129
+ const focusedItem = items.find(i => isHorizontalNavItemActive(i)) || items.find(i => horizontalNavItemHasActiveChild(i));
130
+ if (notNullOrUndefined(focusedItem)) {
131
+ this.updateFocusedItem(items, focusedItem);
132
+ }
133
+ }
134
+ updateFocusedItem(items, focusedItem) {
135
+ for (const item of items) {
136
+ if (areSameHorizontalNavItem(item, focusedItem)) {
137
+ setHorizontalNavItemStateProp(item, 'focused', true);
138
+ }
139
+ else {
140
+ setHorizontalNavItemStateProp(item, 'focused', false);
141
+ }
142
+ }
143
+ }
144
+ _getNavExtras(item) {
145
+ const navigationExtras = {};
146
+ if (hasProperty(item, 'queryParams')) {
147
+ navigationExtras.queryParams = item.queryParams;
148
+ }
149
+ if (hasProperty(item, 'fragment')) {
150
+ navigationExtras.fragment = item.fragment;
151
+ }
152
+ if (hasProperty(item, 'queryParamsHandling')) {
153
+ navigationExtras.queryParamsHandling = item.queryParamsHandling;
154
+ }
155
+ if (hasProperty(item, 'preserveFragment')) {
156
+ navigationExtras.preserveFragment = item.preserveFragment;
157
+ }
158
+ return navigationExtras;
159
+ }
160
+ _getUrl(item) {
161
+ const link = item.link;
162
+ if (typeof link === 'string') {
163
+ return this._router.createUrlTree([link], this._getNavExtras(item)).toString();
164
+ }
165
+ else if (Array.isArray(link)) {
166
+ return this._router.createUrlTree(link, this._getNavExtras(item)).toString();
167
+ }
168
+ return null;
169
+ }
170
+ _getMatchOptions(item) {
171
+ const defaultMatchOpts = {
172
+ paths: 'subset',
173
+ queryParams: 'subset',
174
+ fragment: 'ignored',
175
+ matrixParams: 'ignored'
176
+ };
177
+ if (hasProperty(item, 'matchOptions')) {
178
+ return {
179
+ ...defaultMatchOpts,
180
+ ...item.matchOptions
181
+ };
182
+ }
183
+ return defaultMatchOpts;
184
+ }
185
+ setItemStateProp(item, prop, value) {
186
+ const currentValue = getHorizontalNavItemStateProp(item, prop);
187
+ if (currentValue !== value) {
188
+ setHorizontalNavItemStateProp(item, prop, value);
189
+ const changed = {
190
+ item,
191
+ prop,
192
+ prevValue: currentValue,
193
+ newValue: value
194
+ };
195
+ this.itemChanged.next(changed);
196
+ }
197
+ }
198
+ }
199
+ TheSeamNavService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: TheSeamNavService, deps: [{ token: i1.Router }], target: i0.ɵɵFactoryTarget.Injectable });
200
+ TheSeamNavService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: TheSeamNavService });
201
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: TheSeamNavService, decorators: [{
202
+ type: Injectable
203
+ }], ctorParameters: function () { return [{ type: i1.Router }]; } });
204
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav.service.js","sourceRoot":"","sources":["../../../../../projects/ui-common/framework/nav/nav.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core'\nimport { IsActiveMatchOptions, NavigationEnd, Router, UrlCreationOptions } from '@angular/router'\nimport { BehaviorSubject, defer, Observable, Subject, Subscriber } from 'rxjs'\nimport { distinctUntilChanged, filter, map, shareReplay, startWith, switchMap } from 'rxjs/operators'\n\nimport { hasProperty, notNullOrUndefined } from '@theseam/ui-common/utils'\n\nimport {\n  areSameHorizontalNavItem,\n  getHorizontalNavItemStateProp,\n  horizontalNavItemCanExpand,\n  horizontalNavItemHasActiveChild,\n  horizontalNavItemHasChildren,\n  horizontalNavItemHasExpandedChild,\n  isHorizontalNavItemActive,\n  isHorizontalNavItemType,\n  setDefaultHorizontalNavItemState,\n  setHorizontalNavItemStateProp\n} from './nav-utils'\nimport { INavItem, INavItemState, INavLink, NavItemStateChanged } from './nav.models'\n\n@Injectable()\nexport class TheSeamNavService {\n\n  private readonly _updatingCount = new BehaviorSubject<number>(0)\n\n  public readonly loading$: Observable<boolean>\n\n  public readonly itemChanged = new Subject<NavItemStateChanged>()\n\n  constructor(\n    private readonly _router: Router\n  ) {\n    this.loading$ = this._updatingCount.pipe(\n      map(count => count > 0),\n      distinctUntilChanged(),\n      shareReplay({ bufferSize: 1, refCount: true })\n    )\n  }\n\n  public createItemsObservable(items: INavItem[]): Observable<INavItem[]> {\n    return defer(() => {\n      this.updateItemsStates(items)\n      this.updateRouterFocusedItem(items)\n      return new Observable((subscriber: Subscriber<INavItem[]>) => {\n        const stateChangeSub = this.itemChanged.pipe(\n          switchMap(change => {\n            if (change.prop === 'focused' && change.newValue) {\n              this.updateFocusedItem(items, change.item)\n            }\n            return this.loading$.pipe(filter(loading => !loading))\n          })\n        ).subscribe(() => {\n          subscriber.next(items)\n        })\n\n        try {\n          this.updateItemsStates(items)\n        } catch (err) {\n          subscriber.error(err)\n        }\n\n        const routeChangeSub = this._router.events.pipe(\n          filter(event => event instanceof NavigationEnd),\n        ).subscribe(event => {\n          try {\n            this.updateItemsStates(items)\n            this.updateRouterFocusedItem(items)\n          } catch (err) {\n            subscriber.error(err)\n          }\n        })\n\n        return () => {\n          stateChangeSub.unsubscribe()\n          routeChangeSub.unsubscribe()\n        }\n      }).pipe(startWith(items))\n    })\n  }\n\n  private _incUpdatingCount(): void {\n    this._updatingCount.next(this._updatingCount.value + 1)\n  }\n\n  private _decrUpdatingCount(): void {\n    this._updatingCount.next(this._updatingCount.value - 1)\n  }\n\n  public updateItemsStates(items: INavItem[]): void {\n    this._incUpdatingCount()\n\n    try {\n      for (const item of items) {\n        if (horizontalNavItemHasChildren(item)) {\n          this.updateItemsStates(item.children)\n        }\n\n        this.updateItemState(item)\n      }\n\n      this._decrUpdatingCount()\n    } catch (err) {\n      this._decrUpdatingCount()\n      throw err\n    }\n  }\n\n  public updateItemState(item: INavItem): void {\n    this._incUpdatingCount()\n\n    try {\n      setDefaultHorizontalNavItemState(item)\n\n      this.setItemStateProp(item, 'active', this.horizontalNavLinkActive(item))\n\n      // TODO: Implement this in a more optimized way. Unless our apps start\n      // having large navs constantly updating their state, this shouldn't\n      // have much impact on performance.\n      this._updateItemExpandedState(item)\n\n      this._decrUpdatingCount()\n    } catch (err) {\n      this._decrUpdatingCount()\n      throw err\n    }\n  }\n\n  public horizontalNavLinkActive(item: INavItem): boolean {\n    if (isHorizontalNavItemType(item, 'link')) {\n      const url = this._getUrl(item)\n      if (notNullOrUndefined(url)) {\n        const opts = this._getMatchOptions(item)\n        return this._router.isActive(url, opts)\n      }\n    }\n    return false\n  }\n\n  private _updateItemsExpandedState(items: INavItem[]): void {\n    for (const item of items) {\n      if (horizontalNavItemHasChildren(item)) {\n        this._updateItemsExpandedState(item.children)\n      }\n      this._updateItemExpandedState(item)\n    }\n  }\n\n  private _updateItemExpandedState(item: INavItem): void {\n    if (!horizontalNavItemCanExpand(item)) {\n      if (getHorizontalNavItemStateProp(item, 'expanded')) {\n        this.setItemStateProp(item, 'expanded', false)\n      }\n      return\n    }\n\n    if (horizontalNavItemHasChildren(item)) {\n      this._updateItemsExpandedState(item.children)\n    }\n\n    if (horizontalNavItemHasActiveChild(item) || horizontalNavItemHasExpandedChild(item)) {\n      if (!getHorizontalNavItemStateProp(item, 'expanded')) {\n        this.setItemStateProp(item, 'expanded', true)\n      }\n    } else {\n      if (getHorizontalNavItemStateProp(item, 'expanded')) {\n        this.setItemStateProp(item, 'expanded', false)\n      }\n    }\n  }\n\n  public updateRouterFocusedItem(items: INavItem[]) {\n    const focusedItem = items.find(i => isHorizontalNavItemActive(i)) || items.find(i => horizontalNavItemHasActiveChild(i))\n    if (notNullOrUndefined(focusedItem)) {\n      this.updateFocusedItem(items, focusedItem)\n    }\n  }\n\n  public updateFocusedItem(items: INavItem[], focusedItem: INavItem | undefined): void {\n    for (const item of items) {\n      if (areSameHorizontalNavItem(item, focusedItem)) {\n        setHorizontalNavItemStateProp(item, 'focused', true)\n      } else {\n        setHorizontalNavItemStateProp(item, 'focused', false)\n      }\n    }\n  }\n\n  private _getNavExtras(item: INavLink): UrlCreationOptions {\n    const navigationExtras: UrlCreationOptions = { }\n    if (hasProperty(item, 'queryParams')) {\n      navigationExtras.queryParams = item.queryParams\n    }\n    if (hasProperty(item, 'fragment')) {\n      navigationExtras.fragment = item.fragment\n    }\n    if (hasProperty(item, 'queryParamsHandling')) {\n      navigationExtras.queryParamsHandling = item.queryParamsHandling\n    }\n    if (hasProperty(item, 'preserveFragment')) {\n      navigationExtras.preserveFragment = item.preserveFragment\n    }\n    return navigationExtras\n  }\n\n  private _getUrl(item: INavLink): string | null {\n    const link = item.link\n\n    if (typeof link === 'string') {\n      return this._router.createUrlTree([ link ], this._getNavExtras(item)).toString()\n    } else if (Array.isArray(link)) {\n      return this._router.createUrlTree(link, this._getNavExtras(item)).toString()\n    }\n\n    return null\n  }\n\n  private _getMatchOptions(item: INavLink): IsActiveMatchOptions {\n    const defaultMatchOpts: IsActiveMatchOptions = {\n      paths: 'subset',\n      queryParams: 'subset',\n      fragment: 'ignored',\n      matrixParams: 'ignored'\n    }\n\n    if (hasProperty(item, 'matchOptions')) {\n      return {\n        ...defaultMatchOpts,\n        ...item.matchOptions\n      }\n    }\n\n    return defaultMatchOpts\n  }\n\n  public setItemStateProp<K extends keyof INavItemState>(item: INavItem, prop: K, value: INavItemState[K]): void {\n    const currentValue = getHorizontalNavItemStateProp(item, prop)\n    if (currentValue !== value) {\n      setHorizontalNavItemStateProp(item, prop, value)\n\n      const changed: NavItemStateChanged = {\n        item,\n        prop,\n        prevValue: currentValue,\n        newValue: value\n      }\n      this.itemChanged.next(changed)\n    }\n  }\n}\n"]}
@@ -4,4 +4,5 @@ export * from './side-nav/index';
4
4
  export * from './top-bar/index';
5
5
  export * from './dynamic-router/index';
6
6
  export * from './schema-form/index';
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi9mcmFtZXdvcmsvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHFCQUFxQixDQUFBO0FBQ25DLGNBQWMsbUJBQW1CLENBQUE7QUFDakMsY0FBYyxrQkFBa0IsQ0FBQTtBQUNoQyxjQUFjLGlCQUFpQixDQUFBO0FBQy9CLGNBQWMsd0JBQXdCLENBQUE7QUFDdEMsY0FBYyxxQkFBcUIsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYmFzZS1sYXlvdXQvaW5kZXgnXG5leHBvcnQgKiBmcm9tICcuL2Rhc2hib2FyZC9pbmRleCdcbmV4cG9ydCAqIGZyb20gJy4vc2lkZS1uYXYvaW5kZXgnXG5leHBvcnQgKiBmcm9tICcuL3RvcC1iYXIvaW5kZXgnXG5leHBvcnQgKiBmcm9tICcuL2R5bmFtaWMtcm91dGVyL2luZGV4J1xuZXhwb3J0ICogZnJvbSAnLi9zY2hlbWEtZm9ybS9pbmRleCdcbiJdfQ==
7
+ export * from './nav/index';
8
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi9mcmFtZXdvcmsvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHFCQUFxQixDQUFBO0FBQ25DLGNBQWMsbUJBQW1CLENBQUE7QUFDakMsY0FBYyxrQkFBa0IsQ0FBQTtBQUNoQyxjQUFjLGlCQUFpQixDQUFBO0FBQy9CLGNBQWMsd0JBQXdCLENBQUE7QUFDdEMsY0FBYyxxQkFBcUIsQ0FBQTtBQUNuQyxjQUFjLGFBQWEsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYmFzZS1sYXlvdXQvaW5kZXgnXG5leHBvcnQgKiBmcm9tICcuL2Rhc2hib2FyZC9pbmRleCdcbmV4cG9ydCAqIGZyb20gJy4vc2lkZS1uYXYvaW5kZXgnXG5leHBvcnQgKiBmcm9tICcuL3RvcC1iYXIvaW5kZXgnXG5leHBvcnQgKiBmcm9tICcuL2R5bmFtaWMtcm91dGVyL2luZGV4J1xuZXhwb3J0ICogZnJvbSAnLi9zY2hlbWEtZm9ybS9pbmRleCdcbmV4cG9ydCAqIGZyb20gJy4vbmF2L2luZGV4J1xuIl19
@@ -135,7 +135,7 @@ export class TheSeamSchemaFormSubmitSplitComponent {
135
135
  }
136
136
  }
137
137
  TheSeamSchemaFormSubmitSplitComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: TheSeamSchemaFormSubmitSplitComponent, deps: [{ token: i1.JsonSchemaFormService }], target: i0.ɵɵFactoryTarget.Component });
138
- TheSeamSchemaFormSubmitSplitComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: TheSeamSchemaFormSubmitSplitComponent, isStandalone: true, selector: "seam-schema-form-submit-split", inputs: { layoutNode: "layoutNode", layoutIndex: "layoutIndex", dataIndex: "dataIndex" }, ngImport: i0, template: "<div\n [class]=\"options?.htmlClass || ''\">\n <div [class.btn-group]=\"_dropdownObj\">\n <button seamButton theme=\"primary\" type=\"submit\"\n [attr.aria-describedby]=\"'control' + layoutNode?._id + 'Status'\"\n [attr.readonly]=\"options?.readonly ? 'readonly' : null\"\n [attr.required]=\"options?.required\"\n [class]=\"'btn btn-primary ' + (options?.fieldHtmlClass || '')\"\n [disabled]=\"controlDisabled\"\n [id]=\"'control' + layoutNode?._id\"\n [name]=\"controlName\"\n [value]=\"controlValue\"\n (click)=\"updateValue($event)\">\n {{ _buttonLabel }}\n <span *ngIf=\"_selectedItem\">\n [{{ _selectedItem.name }}]\n </span>\n </button>\n <ng-container *ngIf=\"_dropdownObj\">\n <button\n [seamMenuToggle]=\"menu\" seamButton theme=\"primary\"\n class=\"dropdown-toggle dropdown-toggle-split\"\n [disabled]=\"_dropdownDisabled\">\n <span class=\"sr-only\">Toggle Dropdown</span>\n </button>\n <seam-menu #menu>\n <ng-container *ngFor=\"let item of _selectList\">\n <button seamMenuItem\n [class.active]=\"item.checked\"\n (click)=\"_setDropdownValue(item.value)\">\n {{ item.name }}\n </button>\n </ng-container>\n </seam-menu>\n </ng-container>\n </div>\n</div>\n", styles: [":host{display:block}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "ngmodule", type: JsonSchemaFormModule }, { kind: "ngmodule", type: TheSeamFormFieldModule }, { kind: "ngmodule", type: TheSeamMenuModule }, { kind: "component", type: i3.MenuComponent, selector: "seam-menu", inputs: ["menuClass", "baseWidth", "animationType"], outputs: ["closed"], exportAs: ["seamMenu"] }, { kind: "directive", type: i3.MenuToggleDirective, selector: "[seamMenuToggle]", inputs: ["seamMenuToggle", "positions", "seamMenuTogglePositionsOffsetY"], outputs: ["menuOpened", "menuClosed"], exportAs: ["seamMenuToggle"] }, { kind: "component", type: i3.MenuItemComponent, selector: "[seamMenuItem]", inputs: ["disabled", "role", "icon", "iconClass", "sublevelIcon", "subLevelIconClass", "badgeText", "badgeTheme"], exportAs: ["seamMenuItem"] }, { kind: "ngmodule", type: TheSeamButtonsModule }, { kind: "component", type: i4.TheSeamButtonComponent, selector: "button[seamButton]", inputs: ["disabled", "theme", "size", "type"], exportAs: ["seamButton"] }] });
138
+ TheSeamSchemaFormSubmitSplitComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: TheSeamSchemaFormSubmitSplitComponent, isStandalone: true, selector: "seam-schema-form-submit-split", inputs: { layoutNode: "layoutNode", layoutIndex: "layoutIndex", dataIndex: "dataIndex" }, ngImport: i0, template: "<div\n [class]=\"options?.htmlClass || ''\">\n <div [class.btn-group]=\"_dropdownObj\">\n <button seamButton theme=\"primary\" type=\"submit\"\n [attr.aria-describedby]=\"'control' + layoutNode?._id + 'Status'\"\n [attr.readonly]=\"options?.readonly ? 'readonly' : null\"\n [attr.required]=\"options?.required\"\n [class]=\"'btn btn-primary ' + (options?.fieldHtmlClass || '')\"\n [disabled]=\"controlDisabled\"\n [id]=\"'control' + layoutNode?._id\"\n [name]=\"controlName\"\n [value]=\"controlValue\"\n (click)=\"updateValue($event)\">\n {{ _buttonLabel }}\n <span *ngIf=\"_selectedItem\">\n [{{ _selectedItem.name }}]\n </span>\n </button>\n <ng-container *ngIf=\"_dropdownObj\">\n <button\n [seamMenuToggle]=\"menu\" seamButton theme=\"primary\"\n class=\"dropdown-toggle dropdown-toggle-split\"\n [disabled]=\"_dropdownDisabled\">\n <span class=\"sr-only\">Toggle Dropdown</span>\n </button>\n <seam-menu #menu>\n <ng-container *ngFor=\"let item of _selectList\">\n <button seamMenuItem\n [class.active]=\"item.checked\"\n (click)=\"_setDropdownValue(item.value)\">\n {{ item.name }}\n </button>\n </ng-container>\n </seam-menu>\n </ng-container>\n </div>\n</div>\n", styles: [":host{display:block}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "ngmodule", type: JsonSchemaFormModule }, { kind: "ngmodule", type: TheSeamFormFieldModule }, { kind: "ngmodule", type: TheSeamMenuModule }, { kind: "component", type: i3.MenuComponent, selector: "seam-menu", inputs: ["menuClass", "baseWidth", "animationType"], outputs: ["closed"], exportAs: ["seamMenu"] }, { kind: "directive", type: i3.MenuToggleDirective, selector: "[seamMenuToggle]", inputs: ["seamMenuToggle", "positions", "seamMenuTogglePositionsOffsetY"], outputs: ["menuToggle", "menuOpened", "menuClosed"], exportAs: ["seamMenuToggle"] }, { kind: "component", type: i3.MenuItemComponent, selector: "[seamMenuItem]", inputs: ["disabled", "role", "icon", "iconClass", "sublevelIcon", "subLevelIconClass", "badgeText", "badgeTheme"], exportAs: ["seamMenuItem"] }, { kind: "ngmodule", type: TheSeamButtonsModule }, { kind: "component", type: i4.TheSeamButtonComponent, selector: "button[seamButton]", inputs: ["disabled", "theme", "size", "type"], exportAs: ["seamButton"] }] });
139
139
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: TheSeamSchemaFormSubmitSplitComponent, decorators: [{
140
140
  type: Component,
141
141
  args: [{ selector: 'seam-schema-form-submit-split', standalone: true, imports: [
@@ -153,4 +153,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
153
153
  }], dataIndex: [{
154
154
  type: Input
155
155
  }] } });
156
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"schema-form-submit-split.component.js","sourceRoot":"","sources":["../../../../../../projects/ui-common/framework/schema-form-controls/schema-form-submit-split/schema-form-submit-split.component.ts","../../../../../../projects/ui-common/framework/schema-form-controls/schema-form-submit-split/schema-form-submit-split.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, isDevMode, OnDestroy, OnInit } from '@angular/core'\nimport { CommonModule } from '@angular/common'\nimport { AbstractControl, ReactiveFormsModule, UntypedFormControl } from '@angular/forms'\nimport { Subject } from 'rxjs'\nimport { takeUntil } from 'rxjs/operators'\n\nimport { buildTitleMap, hasOwn, JsonSchemaFormModule, JsonSchemaFormService, TitleMapItem } from '@ajsf/core'\nimport { observeControlStatus, observeControlValue } from '@theseam/ui-common/utils'\nimport { TheSeamSchemaFormControlWidget, TheSeamSchemaFormWidgetLayoutNodeOptions } from '../../schema-form'\nimport { TheSeamFormFieldModule } from '@theseam/ui-common/form-field'\nimport { TheSeamMenuModule } from '@theseam/ui-common/menu'\nimport { TheSeamButtonsModule } from '@theseam/ui-common/buttons'\n\n// NOTE: This is aliasing TitleMapItem, because we may want to extend it's\n// options. For simplicity, I am letting this work similar to a 'select' widget.\nexport type TheSeamSchemaFormSubmitSplitItem = TitleMapItem\n\n// NOTE: This component is a little hacky, because I am basically creating a\n// data widget that acts like a data and 'submit' widget at the same time.\n//\n// TODO: Try and think of a nicer way to implement this, but still make sense\n// from a schema definition. The library may need to me forked to actually\n// support this in the way I expect, but maybe there is another way.\n@Component({\n  selector: 'seam-schema-form-submit-split',\n  templateUrl: './schema-form-submit-split.component.html',\n  styleUrls: ['./schema-form-submit-split.component.scss'],\n  // changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    JsonSchemaFormModule,\n    TheSeamFormFieldModule,\n    TheSeamMenuModule,\n    TheSeamButtonsModule,\n  ],\n})\nexport class TheSeamSchemaFormSubmitSplitComponent implements OnInit, OnDestroy, TheSeamSchemaFormControlWidget {\n\n  /** @ignore */\n  private readonly _ngUnsubscribe = new Subject<void>()\n\n  formControl?: AbstractControl\n  controlName?: string\n  controlValue?: any\n  controlDisabled = false\n  boundControl = false\n  options?: TheSeamSchemaFormWidgetLayoutNodeOptions\n\n  @Input() layoutNode: TheSeamSchemaFormControlWidget['layoutNode']\n  @Input() layoutIndex: TheSeamSchemaFormControlWidget['layoutIndex']\n  @Input() dataIndex: TheSeamSchemaFormControlWidget['dataIndex']\n\n  _buttonLabel = ''\n\n  _dropdownObj: any\n  _dropdownDisabled = false\n  _selectList: TheSeamSchemaFormSubmitSplitItem[] = []\n  _selectedItem?: TheSeamSchemaFormSubmitSplitItem\n\n  constructor(\n    private readonly _jsf: JsonSchemaFormService\n  ) { }\n\n  /** @ignore */\n  ngOnInit() {\n    this.options = this.layoutNode?.options || {} as TheSeamSchemaFormWidgetLayoutNodeOptions\n    this._jsf.initializeControl(this)\n\n    // NOTE: This is commented out, because there is a bug with submit widgets\n    // manually defined in layout. All nodes initialized from the provided\n    // layout have their options populated from the defaults and 'disabled' is\n    // on of the default properties, so the 'disableInvalidSubmit' condition\n    // never gets reached.\n    //\n    // My initial idea for fixing would be to check if the disabled property\n    // exists and is a boolean, or possibly anything defined that can coerce\n    // into a boolean. I can't think of a reason disabled should be anything\n    // else, so that may be an acceptable fix, but I don't want to enable that\n    // yet.\n    //\n    // if (hasOwn(this.options, 'disabled')) {\n    //   console.log('[TheSeamSchemaFormSubmitSplitComponent] hasDisabled', this.options.disabled)\n    //   this.controlDisabled = this.options.disabled\n    // } else\n    if (this._jsf.formOptions.disableInvalidSubmit) {\n      this.controlDisabled = !this._jsf.isValid\n      this._jsf.isValidChanges.subscribe(isValid => this.controlDisabled = !isValid)\n    }\n    if (this.controlValue === null || this.controlValue === undefined) {\n      this.controlValue = this.options.title\n    }\n\n    if (hasOwn(this.options, 'title')) {\n      this._buttonLabel = this.options.title\n    }\n\n    this._initDropdown()\n\n    // console.log('this', this)\n  }\n\n  /** @ignore */\n  ngOnDestroy(): void {\n    this._ngUnsubscribe.next(undefined)\n    this._ngUnsubscribe.complete()\n  }\n\n  updateValue(event: any) {\n    if (typeof this.options?.onClick === 'function') {\n      this.options.onClick(event)\n    } else {\n      this._jsf.updateValue(this, event.target.value)\n    }\n  }\n\n  private _initDropdown(): void {\n    if (!hasOwn(this.layoutNode, 'items') || !(this.layoutNode?.items || []).length) {\n      return\n    }\n\n    if (isDevMode()) {\n      if (this.layoutNode?.items && this.layoutNode?.items.length > 1) {\n        // eslint-disable-next-line no-console\n        console.warn(\n          `TheSeamSchemaFormSubmitSplitComponent only supports one item.` +\n          ` items after index 0 will be ignored.`\n        )\n      }\n    }\n\n    const idx = 0\n    const item = (this.layoutNode?.items as any)[idx] || {}\n    this._dropdownObj = {\n      layoutNode: item,\n      layoutIndex: (this.layoutIndex || []).concat(idx),\n      dataIndex: this.layoutNode?.dataType === 'array' ? (this.dataIndex || []).concat(idx) : this.dataIndex,\n\n      options: item.options || {}\n    }\n\n    this._jsf.initializeControl(this._dropdownObj)\n\n    const items = buildTitleMap(\n      this._dropdownObj.options.titleMap || this._dropdownObj.options.enumNames,\n      this._dropdownObj.options.enum,\n      !!this._dropdownObj.options.required,\n      !!this._dropdownObj.options.flatList\n    )\n\n    this._selectList = items\n\n    // TODO: Should this be checking if the control is bound?\n    const dropdownControl = this._getDropdownControl()\n    if (!dropdownControl) {\n      return\n    }\n\n    observeControlValue(dropdownControl).pipe(\n      takeUntil(this._ngUnsubscribe)\n    ).subscribe(value => {\n      this._setSelectListCheckedProp(value)\n      this._selectedItem = this._getSelectedItem()\n    })\n\n    observeControlStatus(dropdownControl).pipe(\n      takeUntil(this._ngUnsubscribe)\n    ).subscribe(value => {\n      this._dropdownDisabled = dropdownControl.disabled\n    })\n  }\n\n  private _getDropdownControl(): UntypedFormControl | undefined {\n    return this._dropdownObj.formControl as UntypedFormControl\n  }\n\n  private _setSelectListCheckedProp(value: any) {\n    const items = this._selectList\n    for (const item of items) {\n      if (item.value === value) {\n        item.checked = true\n      } else if (item.checked) {\n        item.checked = false\n      }\n    }\n    this._selectList = [ ...items ]\n  }\n\n  private _getSelectedItem(): TheSeamSchemaFormSubmitSplitItem | undefined {\n    return (this._selectList || []).find(x => x.checked === true)\n  }\n\n  _setDropdownValue(value: any) {\n    const formControl = this._getDropdownControl()\n    formControl?.setValue(value)\n  }\n\n}\n","<div\n  [class]=\"options?.htmlClass || ''\">\n  <div [class.btn-group]=\"_dropdownObj\">\n    <button seamButton theme=\"primary\" type=\"submit\"\n      [attr.aria-describedby]=\"'control' + layoutNode?._id + 'Status'\"\n      [attr.readonly]=\"options?.readonly ? 'readonly' : null\"\n      [attr.required]=\"options?.required\"\n      [class]=\"'btn btn-primary ' + (options?.fieldHtmlClass || '')\"\n      [disabled]=\"controlDisabled\"\n      [id]=\"'control' + layoutNode?._id\"\n      [name]=\"controlName\"\n      [value]=\"controlValue\"\n      (click)=\"updateValue($event)\">\n      {{ _buttonLabel }}\n      <span *ngIf=\"_selectedItem\">\n        [{{ _selectedItem.name }}]\n      </span>\n    </button>\n    <ng-container *ngIf=\"_dropdownObj\">\n      <button\n        [seamMenuToggle]=\"menu\" seamButton theme=\"primary\"\n        class=\"dropdown-toggle dropdown-toggle-split\"\n        [disabled]=\"_dropdownDisabled\">\n        <span class=\"sr-only\">Toggle Dropdown</span>\n      </button>\n      <seam-menu #menu>\n        <ng-container *ngFor=\"let item of _selectList\">\n          <button seamMenuItem\n            [class.active]=\"item.checked\"\n            (click)=\"_setDropdownValue(item.value)\">\n            {{ item.name }}\n          </button>\n        </ng-container>\n      </seam-menu>\n    </ng-container>\n  </div>\n</div>\n"]}
156
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"schema-form-submit-split.component.js","sourceRoot":"","sources":["../../../../../../projects/ui-common/framework/schema-form-controls/schema-form-submit-split/schema-form-submit-split.component.ts","../../../../../../projects/ui-common/framework/schema-form-controls/schema-form-submit-split/schema-form-submit-split.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, isDevMode, OnDestroy, OnInit } from '@angular/core'\nimport { CommonModule } from '@angular/common'\nimport { AbstractControl, ReactiveFormsModule, UntypedFormControl } from '@angular/forms'\nimport { Subject } from 'rxjs'\nimport { takeUntil } from 'rxjs/operators'\n\nimport { buildTitleMap, hasOwn, JsonSchemaFormModule, JsonSchemaFormService, TitleMapItem } from '@ajsf/core'\nimport { observeControlStatus, observeControlValue } from '@theseam/ui-common/utils'\nimport { TheSeamSchemaFormControlWidget, TheSeamSchemaFormWidgetLayoutNodeOptions } from '../../schema-form'\nimport { TheSeamFormFieldModule } from '@theseam/ui-common/form-field'\nimport { TheSeamMenuModule } from '@theseam/ui-common/menu'\nimport { TheSeamButtonsModule } from '@theseam/ui-common/buttons'\n\n// NOTE: This is aliasing TitleMapItem, because we may want to extend it's\n// options. For simplicity, I am letting this work similar to a 'select' widget.\nexport type TheSeamSchemaFormSubmitSplitItem = TitleMapItem\n\n// NOTE: This component is a little hacky, because I am basically creating a\n// data widget that acts like a data and 'submit' widget at the same time.\n//\n// TODO: Try and think of a nicer way to implement this, but still make sense\n// from a schema definition. The library may need to me forked to actually\n// support this in the way I expect, but maybe there is another way.\n@Component({\n  selector: 'seam-schema-form-submit-split',\n  templateUrl: './schema-form-submit-split.component.html',\n  styleUrls: ['./schema-form-submit-split.component.scss'],\n  // changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    JsonSchemaFormModule,\n    TheSeamFormFieldModule,\n    TheSeamMenuModule,\n    TheSeamButtonsModule,\n  ],\n})\nexport class TheSeamSchemaFormSubmitSplitComponent implements OnInit, OnDestroy, TheSeamSchemaFormControlWidget {\n\n  /** @ignore */\n  private readonly _ngUnsubscribe = new Subject<void>()\n\n  formControl?: AbstractControl\n  controlName?: string\n  controlValue?: any\n  controlDisabled = false\n  boundControl = false\n  options?: TheSeamSchemaFormWidgetLayoutNodeOptions\n\n  @Input() layoutNode: TheSeamSchemaFormControlWidget['layoutNode']\n  @Input() layoutIndex: TheSeamSchemaFormControlWidget['layoutIndex']\n  @Input() dataIndex: TheSeamSchemaFormControlWidget['dataIndex']\n\n  _buttonLabel = ''\n\n  _dropdownObj: any\n  _dropdownDisabled = false\n  _selectList: TheSeamSchemaFormSubmitSplitItem[] = []\n  _selectedItem?: TheSeamSchemaFormSubmitSplitItem\n\n  constructor(\n    private readonly _jsf: JsonSchemaFormService\n  ) { }\n\n  /** @ignore */\n  ngOnInit() {\n    this.options = this.layoutNode?.options || {} as TheSeamSchemaFormWidgetLayoutNodeOptions\n    this._jsf.initializeControl(this)\n\n    // NOTE: This is commented out, because there is a bug with submit widgets\n    // manually defined in layout. All nodes initialized from the provided\n    // layout have their options populated from the defaults and 'disabled' is\n    // on of the default properties, so the 'disableInvalidSubmit' condition\n    // never gets reached.\n    //\n    // My initial idea for fixing would be to check if the disabled property\n    // exists and is a boolean, or possibly anything defined that can coerce\n    // into a boolean. I can't think of a reason disabled should be anything\n    // else, so that may be an acceptable fix, but I don't want to enable that\n    // yet.\n    //\n    // if (hasOwn(this.options, 'disabled')) {\n    //   console.log('[TheSeamSchemaFormSubmitSplitComponent] hasDisabled', this.options.disabled)\n    //   this.controlDisabled = this.options.disabled\n    // } else\n    if (this._jsf.formOptions.disableInvalidSubmit) {\n      this.controlDisabled = !this._jsf.isValid\n      this._jsf.isValidChanges.subscribe(isValid => this.controlDisabled = !isValid)\n    }\n    if (this.controlValue === null || this.controlValue === undefined) {\n      this.controlValue = this.options.title\n    }\n\n    if (hasOwn(this.options, 'title')) {\n      this._buttonLabel = this.options.title\n    }\n\n    this._initDropdown()\n\n    // console.log('this', this)\n  }\n\n  /** @ignore */\n  ngOnDestroy(): void {\n    this._ngUnsubscribe.next(undefined)\n    this._ngUnsubscribe.complete()\n  }\n\n  updateValue(event: any) {\n    if (typeof this.options?.onClick === 'function') {\n      this.options.onClick(event)\n    } else {\n      this._jsf.updateValue(this, event.target.value)\n    }\n  }\n\n  private _initDropdown(): void {\n    if (!hasOwn(this.layoutNode, 'items') || !(this.layoutNode?.items || []).length) {\n      return\n    }\n\n    if (isDevMode()) {\n      if (this.layoutNode?.items && this.layoutNode?.items.length > 1) {\n        // eslint-disable-next-line no-console\n        console.warn(\n          `TheSeamSchemaFormSubmitSplitComponent only supports one item.` +\n          ` items after index 0 will be ignored.`\n        )\n      }\n    }\n\n    const idx = 0\n    const item = (this.layoutNode?.items as any)[idx] || {}\n    this._dropdownObj = {\n      layoutNode: item,\n      layoutIndex: (this.layoutIndex || []).concat(idx),\n      dataIndex: this.layoutNode?.dataType === 'array' ? (this.dataIndex || []).concat(idx) : this.dataIndex,\n\n      options: item.options || {}\n    }\n\n    this._jsf.initializeControl(this._dropdownObj)\n\n    const items = buildTitleMap(\n      this._dropdownObj.options.titleMap || this._dropdownObj.options.enumNames,\n      this._dropdownObj.options.enum,\n      !!this._dropdownObj.options.required,\n      !!this._dropdownObj.options.flatList\n    )\n\n    this._selectList = items\n\n    // TODO: Should this be checking if the control is bound?\n    const dropdownControl = this._getDropdownControl()\n    if (!dropdownControl) {\n      return\n    }\n\n    observeControlValue(dropdownControl).pipe(\n      takeUntil(this._ngUnsubscribe)\n    ).subscribe(value => {\n      this._setSelectListCheckedProp(value)\n      this._selectedItem = this._getSelectedItem()\n    })\n\n    observeControlStatus(dropdownControl).pipe(\n      takeUntil(this._ngUnsubscribe)\n    ).subscribe(value => {\n      this._dropdownDisabled = dropdownControl.disabled\n    })\n  }\n\n  private _getDropdownControl(): UntypedFormControl | undefined {\n    return this._dropdownObj.formControl as UntypedFormControl\n  }\n\n  private _setSelectListCheckedProp(value: any) {\n    const items = this._selectList\n    for (const item of items) {\n      if (item.value === value) {\n        item.checked = true\n      } else if (item.checked) {\n        item.checked = false\n      }\n    }\n    this._selectList = [ ...items ]\n  }\n\n  private _getSelectedItem(): TheSeamSchemaFormSubmitSplitItem | undefined {\n    return (this._selectList || []).find(x => x.checked === true)\n  }\n\n  _setDropdownValue(value: any) {\n    const formControl = this._getDropdownControl()\n    formControl?.setValue(value)\n  }\n\n}\n","<div\n  [class]=\"options?.htmlClass || ''\">\n  <div [class.btn-group]=\"_dropdownObj\">\n    <button seamButton theme=\"primary\" type=\"submit\"\n      [attr.aria-describedby]=\"'control' + layoutNode?._id + 'Status'\"\n      [attr.readonly]=\"options?.readonly ? 'readonly' : null\"\n      [attr.required]=\"options?.required\"\n      [class]=\"'btn btn-primary ' + (options?.fieldHtmlClass || '')\"\n      [disabled]=\"controlDisabled\"\n      [id]=\"'control' + layoutNode?._id\"\n      [name]=\"controlName\"\n      [value]=\"controlValue\"\n      (click)=\"updateValue($event)\">\n      {{ _buttonLabel }}\n      <span *ngIf=\"_selectedItem\">\n        [{{ _selectedItem.name }}]\n      </span>\n    </button>\n    <ng-container *ngIf=\"_dropdownObj\">\n      <button\n        [seamMenuToggle]=\"menu\" seamButton theme=\"primary\"\n        class=\"dropdown-toggle dropdown-toggle-split\"\n        [disabled]=\"_dropdownDisabled\">\n        <span class=\"sr-only\">Toggle Dropdown</span>\n      </button>\n      <seam-menu #menu>\n        <ng-container *ngFor=\"let item of _selectList\">\n          <button seamMenuItem\n            [class.active]=\"item.checked\"\n            (click)=\"_setDropdownValue(item.value)\">\n            {{ item.name }}\n          </button>\n        </ng-container>\n      </seam-menu>\n    </ng-container>\n  </div>\n</div>\n"]}