@ng-formworks/core 16.6.2 → 16.6.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.
@@ -15,6 +15,7 @@ import { SectionComponent } from './section.component';
15
15
  import { SelectFrameworkComponent } from './select-framework.component';
16
16
  import { SelectWidgetComponent } from './select-widget.component';
17
17
  import { SelectComponent } from './select.component';
18
+ import { SelectCheckboxComponent } from './selectcheckbox.component';
18
19
  import { SubmitComponent } from './submit.component';
19
20
  import { TabComponent } from './tab.component';
20
21
  import { TabsComponent } from './tabs.component';
@@ -26,7 +27,7 @@ export const BASIC_WIDGETS = [
26
27
  MessageComponent, NoneComponent, NumberComponent, RadiosComponent,
27
28
  RootComponent, SectionComponent, SelectComponent, SelectFrameworkComponent,
28
29
  SelectWidgetComponent, SubmitComponent, TabComponent, TabsComponent,
29
- TemplateComponent, TextareaComponent
30
+ TemplateComponent, TextareaComponent, SelectCheckboxComponent
30
31
  ];
31
32
  export { AddReferenceComponent } from './add-reference.component';
32
33
  export { ButtonComponent } from './button.component';
@@ -47,10 +48,11 @@ export { SectionComponent } from './section.component';
47
48
  export { SelectFrameworkComponent } from './select-framework.component';
48
49
  export { SelectWidgetComponent } from './select-widget.component';
49
50
  export { SelectComponent } from './select.component';
51
+ export { SelectCheckboxComponent } from './selectcheckbox.component';
50
52
  export { SubmitComponent } from './submit.component';
51
53
  export { TabComponent } from './tab.component';
52
54
  export { TabsComponent } from './tabs.component';
53
55
  export { TemplateComponent } from './template.component';
54
56
  export { TextareaComponent } from './textarea.component';
55
57
  export { WidgetLibraryService } from './widget-library.service';
56
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1mb3Jtd29ya3MtY29yZS9zcmMvbGliL3dpZGdldC1saWJyYXJ5L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN6RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUM3RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDakQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNuRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN2RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDakQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUNwRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDckQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ2pELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3ZELE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ3hFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDckQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNqRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN6RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUV6RCxNQUFNLENBQUMsTUFBTSxhQUFhLEdBQUc7SUFDM0IscUJBQXFCLEVBQUUsY0FBYyxFQUFFLGVBQWUsRUFBRSxpQkFBaUI7SUFDekUsbUJBQW1CLEVBQUUsYUFBYSxFQUFFLGVBQWUsRUFBRSxjQUFjO0lBQ25FLGdCQUFnQixFQUFFLGFBQWEsRUFBRSxlQUFlLEVBQUUsZUFBZTtJQUNqRSxhQUFhLEVBQUUsZ0JBQWdCLEVBQUUsZUFBZSxFQUFFLHdCQUF3QjtJQUMxRSxxQkFBcUIsRUFBRSxlQUFlLEVBQUUsWUFBWSxFQUFFLGFBQWE7SUFDbkUsaUJBQWlCLEVBQUUsaUJBQWlCO0NBQ3JDLENBQUM7QUFFRixPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDckQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDekQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDN0QsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDMUUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ2pELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDbkQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ2pELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDcEQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNqRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN2RCxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUN4RSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDckQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDakQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDekQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDekQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMEJBQTBCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBZGRSZWZlcmVuY2VDb21wb25lbnQgfSBmcm9tICcuL2FkZC1yZWZlcmVuY2UuY29tcG9uZW50JztcclxuaW1wb3J0IHsgQnV0dG9uQ29tcG9uZW50IH0gZnJvbSAnLi9idXR0b24uY29tcG9uZW50JztcclxuaW1wb3J0IHsgQ2hlY2tib3hDb21wb25lbnQgfSBmcm9tICcuL2NoZWNrYm94LmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IENoZWNrYm94ZXNDb21wb25lbnQgfSBmcm9tICcuL2NoZWNrYm94ZXMuY29tcG9uZW50JztcclxuaW1wb3J0IHsgRmlsZUNvbXBvbmVudCB9IGZyb20gJy4vZmlsZS5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBIaWRkZW5Db21wb25lbnQgfSBmcm9tICcuL2hpZGRlbi5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBJbnB1dENvbXBvbmVudCB9IGZyb20gJy4vaW5wdXQuY29tcG9uZW50JztcclxuaW1wb3J0IHsgTWVzc2FnZUNvbXBvbmVudCB9IGZyb20gJy4vbWVzc2FnZS5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBOb25lQ29tcG9uZW50IH0gZnJvbSAnLi9ub25lLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IE51bWJlckNvbXBvbmVudCB9IGZyb20gJy4vbnVtYmVyLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IE9uZU9mQ29tcG9uZW50IH0gZnJvbSAnLi9vbmUtb2YuY29tcG9uZW50JztcclxuaW1wb3J0IHsgUmFkaW9zQ29tcG9uZW50IH0gZnJvbSAnLi9yYWRpb3MuY29tcG9uZW50JztcclxuaW1wb3J0IHsgUm9vdENvbXBvbmVudCB9IGZyb20gJy4vcm9vdC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBTZWN0aW9uQ29tcG9uZW50IH0gZnJvbSAnLi9zZWN0aW9uLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IFNlbGVjdEZyYW1ld29ya0NvbXBvbmVudCB9IGZyb20gJy4vc2VsZWN0LWZyYW1ld29yay5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBTZWxlY3RXaWRnZXRDb21wb25lbnQgfSBmcm9tICcuL3NlbGVjdC13aWRnZXQuY29tcG9uZW50JztcclxuaW1wb3J0IHsgU2VsZWN0Q29tcG9uZW50IH0gZnJvbSAnLi9zZWxlY3QuY29tcG9uZW50JztcclxuaW1wb3J0IHsgU3VibWl0Q29tcG9uZW50IH0gZnJvbSAnLi9zdWJtaXQuY29tcG9uZW50JztcclxuaW1wb3J0IHsgVGFiQ29tcG9uZW50IH0gZnJvbSAnLi90YWIuY29tcG9uZW50JztcclxuaW1wb3J0IHsgVGFic0NvbXBvbmVudCB9IGZyb20gJy4vdGFicy5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBUZW1wbGF0ZUNvbXBvbmVudCB9IGZyb20gJy4vdGVtcGxhdGUuY29tcG9uZW50JztcclxuaW1wb3J0IHsgVGV4dGFyZWFDb21wb25lbnQgfSBmcm9tICcuL3RleHRhcmVhLmNvbXBvbmVudCc7XHJcblxyXG5leHBvcnQgY29uc3QgQkFTSUNfV0lER0VUUyA9IFtcclxuICBBZGRSZWZlcmVuY2VDb21wb25lbnQsIE9uZU9mQ29tcG9uZW50LCBCdXR0b25Db21wb25lbnQsIENoZWNrYm94Q29tcG9uZW50LFxyXG4gIENoZWNrYm94ZXNDb21wb25lbnQsIEZpbGVDb21wb25lbnQsIEhpZGRlbkNvbXBvbmVudCwgSW5wdXRDb21wb25lbnQsXHJcbiAgTWVzc2FnZUNvbXBvbmVudCwgTm9uZUNvbXBvbmVudCwgTnVtYmVyQ29tcG9uZW50LCBSYWRpb3NDb21wb25lbnQsXHJcbiAgUm9vdENvbXBvbmVudCwgU2VjdGlvbkNvbXBvbmVudCwgU2VsZWN0Q29tcG9uZW50LCBTZWxlY3RGcmFtZXdvcmtDb21wb25lbnQsXHJcbiAgU2VsZWN0V2lkZ2V0Q29tcG9uZW50LCBTdWJtaXRDb21wb25lbnQsIFRhYkNvbXBvbmVudCwgVGFic0NvbXBvbmVudCxcclxuICBUZW1wbGF0ZUNvbXBvbmVudCwgVGV4dGFyZWFDb21wb25lbnRcclxuXTtcclxuXHJcbmV4cG9ydCB7IEFkZFJlZmVyZW5jZUNvbXBvbmVudCB9IGZyb20gJy4vYWRkLXJlZmVyZW5jZS5jb21wb25lbnQnO1xyXG5leHBvcnQgeyBCdXR0b25Db21wb25lbnQgfSBmcm9tICcuL2J1dHRvbi5jb21wb25lbnQnO1xyXG5leHBvcnQgeyBDaGVja2JveENvbXBvbmVudCB9IGZyb20gJy4vY2hlY2tib3guY29tcG9uZW50JztcclxuZXhwb3J0IHsgQ2hlY2tib3hlc0NvbXBvbmVudCB9IGZyb20gJy4vY2hlY2tib3hlcy5jb21wb25lbnQnO1xyXG5leHBvcnQgeyBFbGVtZW50QXR0cmlidXRlRGlyZWN0aXZlIH0gZnJvbSAnLi9lbGVtZW50LWF0dHJpYnV0ZS5kaXJlY3RpdmUnO1xyXG5leHBvcnQgeyBGaWxlQ29tcG9uZW50IH0gZnJvbSAnLi9maWxlLmNvbXBvbmVudCc7XHJcbmV4cG9ydCB7IEhpZGRlbkNvbXBvbmVudCB9IGZyb20gJy4vaGlkZGVuLmNvbXBvbmVudCc7XHJcbmV4cG9ydCB7IElucHV0Q29tcG9uZW50IH0gZnJvbSAnLi9pbnB1dC5jb21wb25lbnQnO1xyXG5leHBvcnQgeyBNZXNzYWdlQ29tcG9uZW50IH0gZnJvbSAnLi9tZXNzYWdlLmNvbXBvbmVudCc7XHJcbmV4cG9ydCB7IE5vbmVDb21wb25lbnQgfSBmcm9tICcuL25vbmUuY29tcG9uZW50JztcclxuZXhwb3J0IHsgTnVtYmVyQ29tcG9uZW50IH0gZnJvbSAnLi9udW1iZXIuY29tcG9uZW50JztcclxuZXhwb3J0IHsgT25lT2ZDb21wb25lbnQgfSBmcm9tICcuL29uZS1vZi5jb21wb25lbnQnO1xyXG5leHBvcnQgeyBPcmRlcmFibGVEaXJlY3RpdmUgfSBmcm9tICcuL29yZGVyYWJsZS5kaXJlY3RpdmUnO1xyXG5leHBvcnQgeyBSYWRpb3NDb21wb25lbnQgfSBmcm9tICcuL3JhZGlvcy5jb21wb25lbnQnO1xyXG5leHBvcnQgeyBSb290Q29tcG9uZW50IH0gZnJvbSAnLi9yb290LmNvbXBvbmVudCc7XHJcbmV4cG9ydCB7IFNlY3Rpb25Db21wb25lbnQgfSBmcm9tICcuL3NlY3Rpb24uY29tcG9uZW50JztcclxuZXhwb3J0IHsgU2VsZWN0RnJhbWV3b3JrQ29tcG9uZW50IH0gZnJvbSAnLi9zZWxlY3QtZnJhbWV3b3JrLmNvbXBvbmVudCc7XHJcbmV4cG9ydCB7IFNlbGVjdFdpZGdldENvbXBvbmVudCB9IGZyb20gJy4vc2VsZWN0LXdpZGdldC5jb21wb25lbnQnO1xyXG5leHBvcnQgeyBTZWxlY3RDb21wb25lbnQgfSBmcm9tICcuL3NlbGVjdC5jb21wb25lbnQnO1xyXG5leHBvcnQgeyBTdWJtaXRDb21wb25lbnQgfSBmcm9tICcuL3N1Ym1pdC5jb21wb25lbnQnO1xyXG5leHBvcnQgeyBUYWJDb21wb25lbnQgfSBmcm9tICcuL3RhYi5jb21wb25lbnQnO1xyXG5leHBvcnQgeyBUYWJzQ29tcG9uZW50IH0gZnJvbSAnLi90YWJzLmNvbXBvbmVudCc7XHJcbmV4cG9ydCB7IFRlbXBsYXRlQ29tcG9uZW50IH0gZnJvbSAnLi90ZW1wbGF0ZS5jb21wb25lbnQnO1xyXG5leHBvcnQgeyBUZXh0YXJlYUNvbXBvbmVudCB9IGZyb20gJy4vdGV4dGFyZWEuY29tcG9uZW50JztcclxuZXhwb3J0IHsgV2lkZ2V0TGlicmFyeVNlcnZpY2UgfSBmcm9tICcuL3dpZGdldC1saWJyYXJ5LnNlcnZpY2UnO1xyXG5cclxuIl19
58
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../projects/ng-formworks-core/src/lib/widget-library/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { AddReferenceComponent } from './add-reference.component';\r\nimport { ButtonComponent } from './button.component';\r\nimport { CheckboxComponent } from './checkbox.component';\r\nimport { CheckboxesComponent } from './checkboxes.component';\r\nimport { FileComponent } from './file.component';\r\nimport { HiddenComponent } from './hidden.component';\r\nimport { InputComponent } from './input.component';\r\nimport { MessageComponent } from './message.component';\r\nimport { NoneComponent } from './none.component';\r\nimport { NumberComponent } from './number.component';\r\nimport { OneOfComponent } from './one-of.component';\r\nimport { RadiosComponent } from './radios.component';\r\nimport { RootComponent } from './root.component';\r\nimport { SectionComponent } from './section.component';\r\nimport { SelectFrameworkComponent } from './select-framework.component';\r\nimport { SelectWidgetComponent } from './select-widget.component';\r\nimport { SelectComponent } from './select.component';\r\nimport { SelectCheckboxComponent } from './selectcheckbox.component';\r\nimport { SubmitComponent } from './submit.component';\r\nimport { TabComponent } from './tab.component';\r\nimport { TabsComponent } from './tabs.component';\r\nimport { TemplateComponent } from './template.component';\r\nimport { TextareaComponent } from './textarea.component';\r\n\r\nexport const BASIC_WIDGETS = [\r\n  AddReferenceComponent, OneOfComponent, ButtonComponent, CheckboxComponent,\r\n  CheckboxesComponent, FileComponent, HiddenComponent, InputComponent,\r\n  MessageComponent, NoneComponent, NumberComponent, RadiosComponent,\r\n  RootComponent, SectionComponent, SelectComponent, SelectFrameworkComponent,\r\n  SelectWidgetComponent, SubmitComponent, TabComponent, TabsComponent,\r\n  TemplateComponent, TextareaComponent,SelectCheckboxComponent\r\n];\r\n\r\nexport { AddReferenceComponent } from './add-reference.component';\r\nexport { ButtonComponent } from './button.component';\r\nexport { CheckboxComponent } from './checkbox.component';\r\nexport { CheckboxesComponent } from './checkboxes.component';\r\nexport { ElementAttributeDirective } from './element-attribute.directive';\r\nexport { FileComponent } from './file.component';\r\nexport { HiddenComponent } from './hidden.component';\r\nexport { InputComponent } from './input.component';\r\nexport { MessageComponent } from './message.component';\r\nexport { NoneComponent } from './none.component';\r\nexport { NumberComponent } from './number.component';\r\nexport { OneOfComponent } from './one-of.component';\r\nexport { OrderableDirective } from './orderable.directive';\r\nexport { RadiosComponent } from './radios.component';\r\nexport { RootComponent } from './root.component';\r\nexport { SectionComponent } from './section.component';\r\nexport { SelectFrameworkComponent } from './select-framework.component';\r\nexport { SelectWidgetComponent } from './select-widget.component';\r\nexport { SelectComponent } from './select.component';\r\nexport { SelectCheckboxComponent } from './selectcheckbox.component';\r\nexport { SubmitComponent } from './submit.component';\r\nexport { TabComponent } from './tab.component';\r\nexport { TabsComponent } from './tabs.component';\r\nexport { TemplateComponent } from './template.component';\r\nexport { TextareaComponent } from './textarea.component';\r\nexport { WidgetLibraryService } from './widget-library.service';\r\n\r\n"]}
@@ -53,7 +53,7 @@ export class OneOfComponent {
53
53
  let controlSchema = JsonPointer.get(this.jsf.schema, parts.join("/"));
54
54
  let schemaPointer = parts.join("/");
55
55
  let dPointer = schemaPointer.replace(/(anyOf|allOf|oneOf|none)\/[\d]+\//g, '')
56
- .replace(/(if|then|else|properties)\//g, '');
56
+ .replace(/(if|then|else|properties)\//g, '').replace(/\/items\//g, '/-/');
57
57
  //JsonPointer.toDataPointer(parts.join("/"),this.jsf.schema);
58
58
  let dVal = JsonPointer.get(this.jsf.formValues, dPointer);
59
59
  let compareVal = dVal; //formValue;
@@ -116,4 +116,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
116
116
  }], dataIndex: [{
117
117
  type: Input
118
118
  }] } });
119
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"one-of.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-formworks-core/src/lib/widget-library/one-of.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\r\nimport { AbstractControl } from '@angular/forms';\r\n\r\nimport { isEqual, isObject, pick } from 'lodash';\r\nimport { JsonSchemaFormService } from '../json-schema-form.service';\r\nimport { hasNonNullValue, hasOwn, JsonPointer, path2ControlKey } from '../shared';\r\n\r\n// TODO: Add this control\r\n\r\n@Component({\r\n    // tslint:disable-next-line:component-selector\r\n    selector: 'one-of-widget',\r\n    template: `<h4>{{this.options?.description}}</h4>\r\n    <tabs-widget #tabs [layoutNode]=\"layoutNode\" \r\n    [layoutIndex]=\"layoutIndex\" \r\n    [dataIndex]=\"dataIndex\" >\r\n    </tabs-widget>`,\r\n    standalone: false\r\n})\r\nexport class OneOfComponent implements OnInit {\r\n  formControl: AbstractControl;\r\n  controlName: string;\r\n  controlValue: any;\r\n  controlDisabled = false;\r\n  boundControl = false;\r\n  options: any;\r\n  @Input() layoutNode: any;\r\n  @Input() layoutIndex: number[];\r\n  @Input() dataIndex: number[];\r\n\r\n  constructor(\r\n    private jsf: JsonSchemaFormService\r\n  ) { }\r\n\r\n  ngOnInit() {\r\n    this.options = this.layoutNode.options || {};\r\n    this.options.tabMode=\"oneOfMode\";\r\n    this.options.selectedTab=this.findSelectedTab();\r\n    //this.options.description=this.options.description||\"choose one of\";\r\n    this.jsf.initializeControl(this);\r\n  }\r\n\r\n    findSelectedTab(){\r\n        //TODO test- this.jsf.formValues seems to be the initial data supplied to the form\r\n        //while the jsf.formGroup value is derived from the actual controls\r\n        //let formValue=this.jsf.getFormControlValue(this);\r\n        let foundInd=-1;\r\n        //seach for non null value\r\n        if(this.layoutNode.items){\r\n          this.layoutNode.items.forEach((layoutItem,ind)=>{\r\n            let formValue=JsonPointer.get(this.jsf.formValues,layoutItem.dataPointer);\r\n              if(layoutItem.oneOfPointer){\r\n                let controlKey=path2ControlKey(layoutItem.oneOfPointer);\r\n                let fname=layoutItem.name;\r\n                if(hasOwn(this.jsf.formGroup.controls,controlKey)&&\r\n                  (formValue || hasNonNullValue(this.jsf.formGroup.controls[controlKey].value))\r\n                  //hasOwn(formValue,fname) && hasOwn(this.jsf.formGroup.controls,controlKey) \r\n                // && (formValue[fname] || this.jsf.formGroup.controls[controlKey].value)\r\n                  //&&isEqual(formValue[fname],this.jsf.formGroup.controls[controlKey].value)\r\n                ){\r\n                    foundInd=ind;\r\n                }\r\n                //foundInd=formValue[controlKey]!=null?ind:foundInd;\r\n                //if no exact match found, then search in descendant values\r\n                //to see which one of item matches\r\n                if(foundInd==-1){\r\n                  //find all descendant oneof paths\r\n                  let descendantOneOfControlNames=Object.keys(this.jsf.formGroup.controls).filter(controlName=>{\r\n                    return controlName.startsWith(controlKey);\r\n                  })\r\n                  descendantOneOfControlNames.forEach(controlName=>{\r\n                    let parts=controlName.split('$');\r\n                    let fieldName=parts[parts.length-1];\r\n                    let controlValue=this.jsf.formGroup.controls[controlName].value;\r\n                    let controlSchema=JsonPointer.get(this.jsf.schema,parts.join(\"/\"));\r\n                    let schemaPointer=parts.join(\"/\");\r\n                    let dPointer=schemaPointer.replace(/(anyOf|allOf|oneOf|none)\\/[\\d]+\\//g, '')\r\n                    .replace(/(if|then|else|properties)\\//g, '');\r\n                    //JsonPointer.toDataPointer(parts.join(\"/\"),this.jsf.schema);\r\n                    let dVal=JsonPointer.get(this.jsf.formValues,dPointer);\r\n                    let compareVal=dVal;//formValue;\r\n                    //compare only values that are in the subschema properties\r\n                    if(controlSchema && controlSchema.properties){\r\n                      compareVal=isObject(dVal) && hasOwn(dVal,fieldName)?\r\n                      pick(dVal[fieldName],Object.keys(controlSchema.properties))\r\n                      :pick(dVal,Object.keys(controlSchema.properties))\r\n                    }\r\n                    /*\r\n                    if(isObject(compareVal) && hasOwn(compareVal,fieldName) && \r\n                    isEqual(compareVal[fieldName],controlValue)\r\n                  ){\r\n                      foundInd=ind;\r\n                    }else //if(formValue || controlValue){\r\n                    if(isEqual(compareVal,controlValue)){\r\n                      foundInd=ind;\r\n                    }\r\n                    */\r\n                    if(isEqual(compareVal,controlValue)){\r\n                      foundInd=ind;\r\n                    }\r\n                  })\r\n                  //now need to compare values\r\n                }\r\n              }\r\n          })\r\n        }\r\n        return Math.max(foundInd,0);\r\n      }\r\n\r\n  updateValue(event) {\r\n    this.jsf.updateValue(this, event.target.value);\r\n  }\r\n\r\n  ngOnDestroy () {\r\n    //this.jsf.updateValue(this, null);\r\n  }\r\n}\r\n"]}
119
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"one-of.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-formworks-core/src/lib/widget-library/one-of.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\r\nimport { AbstractControl } from '@angular/forms';\r\n\r\nimport { isEqual, isObject, pick } from 'lodash';\r\nimport { JsonSchemaFormService } from '../json-schema-form.service';\r\nimport { hasNonNullValue, hasOwn, JsonPointer, path2ControlKey } from '../shared';\r\n\r\n// TODO: Add this control\r\n\r\n@Component({\r\n    // tslint:disable-next-line:component-selector\r\n    selector: 'one-of-widget',\r\n    template: `<h4>{{this.options?.description}}</h4>\r\n    <tabs-widget #tabs [layoutNode]=\"layoutNode\" \r\n    [layoutIndex]=\"layoutIndex\" \r\n    [dataIndex]=\"dataIndex\" >\r\n    </tabs-widget>`,\r\n    standalone: false\r\n})\r\nexport class OneOfComponent implements OnInit {\r\n  formControl: AbstractControl;\r\n  controlName: string;\r\n  controlValue: any;\r\n  controlDisabled = false;\r\n  boundControl = false;\r\n  options: any;\r\n  @Input() layoutNode: any;\r\n  @Input() layoutIndex: number[];\r\n  @Input() dataIndex: number[];\r\n\r\n  constructor(\r\n    private jsf: JsonSchemaFormService\r\n  ) { }\r\n\r\n  ngOnInit() {\r\n    this.options = this.layoutNode.options || {};\r\n    this.options.tabMode=\"oneOfMode\";\r\n    this.options.selectedTab=this.findSelectedTab();\r\n    //this.options.description=this.options.description||\"choose one of\";\r\n    this.jsf.initializeControl(this);\r\n  }\r\n\r\n    findSelectedTab(){\r\n        //TODO test- this.jsf.formValues seems to be the initial data supplied to the form\r\n        //while the jsf.formGroup value is derived from the actual controls\r\n        //let formValue=this.jsf.getFormControlValue(this);\r\n        let foundInd=-1;\r\n        //seach for non null value\r\n        if(this.layoutNode.items){\r\n          this.layoutNode.items.forEach((layoutItem,ind)=>{\r\n            let formValue=JsonPointer.get(this.jsf.formValues,layoutItem.dataPointer);\r\n              if(layoutItem.oneOfPointer){\r\n                let controlKey=path2ControlKey(layoutItem.oneOfPointer);\r\n                let fname=layoutItem.name;\r\n                if(hasOwn(this.jsf.formGroup.controls,controlKey)&&\r\n                  (formValue || hasNonNullValue(this.jsf.formGroup.controls[controlKey].value))\r\n                  //hasOwn(formValue,fname) && hasOwn(this.jsf.formGroup.controls,controlKey) \r\n                // && (formValue[fname] || this.jsf.formGroup.controls[controlKey].value)\r\n                  //&&isEqual(formValue[fname],this.jsf.formGroup.controls[controlKey].value)\r\n                ){\r\n                    foundInd=ind;\r\n                }\r\n                //foundInd=formValue[controlKey]!=null?ind:foundInd;\r\n                //if no exact match found, then search in descendant values\r\n                //to see which one of item matches\r\n                if(foundInd==-1){\r\n                  //find all descendant oneof paths\r\n                  let descendantOneOfControlNames=Object.keys(this.jsf.formGroup.controls).filter(controlName=>{\r\n                    return controlName.startsWith(controlKey);\r\n                  })\r\n                  descendantOneOfControlNames.forEach(controlName=>{\r\n                    let parts=controlName.split('$');\r\n                    let fieldName=parts[parts.length-1];\r\n                    let controlValue=this.jsf.formGroup.controls[controlName].value;\r\n                    let controlSchema=JsonPointer.get(this.jsf.schema,parts.join(\"/\"));\r\n                    let schemaPointer=parts.join(\"/\");\r\n                    let dPointer=schemaPointer.replace(/(anyOf|allOf|oneOf|none)\\/[\\d]+\\//g, '')\r\n                    .replace(/(if|then|else|properties)\\//g, '').replace(/\\/items\\//g,'/-/');\r\n                    //JsonPointer.toDataPointer(parts.join(\"/\"),this.jsf.schema);\r\n                    let dVal=JsonPointer.get(this.jsf.formValues,dPointer);\r\n                    let compareVal=dVal;//formValue;\r\n                    //compare only values that are in the subschema properties\r\n                    if(controlSchema && controlSchema.properties){\r\n                      compareVal=isObject(dVal) && hasOwn(dVal,fieldName)?\r\n                      pick(dVal[fieldName],Object.keys(controlSchema.properties))\r\n                      :pick(dVal,Object.keys(controlSchema.properties))\r\n                    }\r\n                    /*\r\n                    if(isObject(compareVal) && hasOwn(compareVal,fieldName) && \r\n                    isEqual(compareVal[fieldName],controlValue)\r\n                  ){\r\n                      foundInd=ind;\r\n                    }else //if(formValue || controlValue){\r\n                    if(isEqual(compareVal,controlValue)){\r\n                      foundInd=ind;\r\n                    }\r\n                    */\r\n                    if(isEqual(compareVal,controlValue)){\r\n                      foundInd=ind;\r\n                    }\r\n                  })\r\n                  //now need to compare values\r\n                }\r\n              }\r\n          })\r\n        }\r\n        return Math.max(foundInd,0);\r\n      }\r\n\r\n  updateValue(event) {\r\n    this.jsf.updateValue(this, event.target.value);\r\n  }\r\n\r\n  ngOnDestroy () {\r\n    //this.jsf.updateValue(this, null);\r\n  }\r\n}\r\n"]}
@@ -39,6 +39,7 @@ export class RootComponent {
39
39
  }
40
40
  sortableInit(sortable) {
41
41
  this.sortableObj = sortable;
42
+ //Sortable.utils.on(this.sortableObj.el,"nulling",(s)=>{console.log("event nulling sortablejs")})
42
43
  ///NB issue caused by sortablejs when it its destroyed
43
44
  //this mainly affects checkboxes coupled with conditions
44
45
  //-the value is rechecked
@@ -218,4 +219,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
218
219
  }], isFlexItem: [{
219
220
  type: Input
220
221
  }] } });
221
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"root.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-formworks-core/src/lib/widget-library/root.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnDestroy, OnInit } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { JsonSchemaFormService } from '../json-schema-form.service';\r\n\r\n@Component({\r\n  // tslint:disable-next-line:component-selector\r\n  selector: 'root-widget',\r\n  template: `\r\n    <div [class.flex-inherit]=\"true\" #sortableContainter [nxtSortablejs]=\"layout\" [config]=\"sortableConfig\" (init)=\"sortableInit($event)\">\r\n      <div *ngFor=\"let layoutItem of layout; let i = index\"\r\n        [class.form-flex-item]=\"isFlexItem\"\r\n        [style.align-self]=\"(layoutItem.options || {})['align-self']\"\r\n        [style.flex-basis]=\"getFlexAttribute(layoutItem, 'flex-basis')\"\r\n        [style.flex-grow]=\"getFlexAttribute(layoutItem, 'flex-grow')\"\r\n        [style.flex-shrink]=\"getFlexAttribute(layoutItem, 'flex-shrink')\"\r\n        [style.order]=\"(layoutItem.options || {}).order\"\r\n        [class.sortable-filter]=\"!isDraggable(layoutItem)\"\r\n        [class.sortable-fixed]=\"isFixed(layoutItem)\"\r\n        >\r\n        <!--NB orderable directive is not used but has been left in for now and set to false\r\n          otherwise the compiler won't recognize dataIndex and other dependent attributes\r\n        -->\r\n        <div \r\n          [dataIndex]=\"layoutItem?.arrayItem ? (dataIndex || []).concat(i) : (dataIndex || [])\"\r\n          [layoutIndex]=\"(layoutIndex || []).concat(i)\"\r\n          [layoutNode]=\"layoutItem\"\r\n          [orderable]=\"false\"\r\n          [class.sortable-filter]=\"!isDraggable(layoutItem)\"\r\n          [class.sortable-fixed]=\"isFixed(layoutItem)\"\r\n          >\r\n          <select-framework-widget *ngIf=\"showWidget(layoutItem)\"\r\n            [dataIndex]=\"layoutItem?.arrayItem ? (dataIndex || []).concat(i) : (dataIndex || [])\"\r\n            [layoutIndex]=\"(layoutIndex || []).concat(i)\"\r\n            [layoutNode]=\"layoutItem\"></select-framework-widget>\r\n        </div>\r\n      </div>\r\n    </div>\r\n    `,\r\n  styles: [`\r\n    [draggable=true] {\r\n      transition: all 150ms cubic-bezier(.4, 0, .2, 1);\r\n    }\r\n    [draggable=true]:hover {\r\n      cursor: move;\r\n      box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.2);\r\n      position: relative; z-index: 10;\r\n      margin-top: -1px;\r\n      margin-left: -1px;\r\n      margin-right: 1px;\r\n      margin-bottom: 1px;\r\n    }\r\n    [draggable=true].drag-target-top {\r\n      box-shadow: 0 -2px 0 #000;\r\n      position: relative; z-index: 20;\r\n    }\r\n    [draggable=true].drag-target-bottom {\r\n      box-shadow: 0 2px 0 #000;\r\n      position: relative; z-index: 20;\r\n    }\r\n    .flex-inherit{\r\n      display:inherit;\r\n      flex-flow:inherit;\r\n      flex-wrap:inherit;\r\n      flex-direction:inherit;\r\n      width:100%\r\n    }\r\n  `],\r\n  standalone: false\r\n})\r\n\r\n\r\nexport class RootComponent implements OnInit, OnDestroy{\r\n  options: any;\r\n  @Input() dataIndex: number[];\r\n  @Input() layoutIndex: number[];\r\n  @Input() layout: any[];\r\n  @Input() isOrderable: boolean;\r\n  @Input() isFlexItem = false;\r\n\r\n  constructor(\r\n    private jsf: JsonSchemaFormService\r\n  ) { }\r\n  // @ViewChild('sortableContainter', {})\r\n  // sortableContainterElt: ElementRef;\r\n\r\n  sortableObj: any;\r\n  sortableConfig:any={\r\n    filter:\".sortable-filter\",//needed to disable dragging on input range elements, class needs to be added to the element or its parent\r\n    preventOnFilter: false,//needed for input range elements slider do still work\r\n    onEnd: (/**Event*/evt)=> {\r\n      evt.newIndex // most likely why this event is used is to get the dragging element's current index\r\n      // same properties as onEnd\r\n      //console.log(`sortablejs event:${evt}`);\r\n      let srcInd=evt.oldIndex;\r\n      let trgInd=evt.newIndex;\r\n      let layoutItem=this.layout[trgInd];\r\n      let dataInd=layoutItem?.arrayItem ? (this.dataIndex || []).concat(trgInd) : (this.dataIndex || []);\r\n      let layoutInd=(this.layoutIndex || []).concat(trgInd)\r\n      let itemCtx:any={\r\n        dataIndex:dataInd,\r\n        layoutIndex:layoutInd,\r\n        layoutNode:layoutItem,\r\n      }\r\n      //must set moveLayout to false as nxtSortable already moves it\r\n      this.jsf.moveArrayItem(itemCtx, evt.oldIndex, evt.newIndex,false);\r\n      \r\n    },\r\n    onMove: function (/**Event*/evt, /**Event*/originalEvent) {\r\n      if(evt.related.classList.contains(\"sortable-fixed\")){\r\n       //console.log(evt.related);\r\n       return false;\r\n     }\r\n   }\r\n  }\r\n  private sortableOptionsSubscription: Subscription;\r\n  sortableInit(sortable) {\r\n    this.sortableObj = sortable;\r\n    ///NB issue caused by sortablejs when it its destroyed\r\n    //this mainly affects checkboxes coupled with conditions\r\n    //-the value is rechecked\r\n    //-see https://github.com/SortableJS/Sortable/issues/1052#issuecomment-369613072\r\n    /* attempt to monkey patch sortable js \r\n    const originalMethod = sortable._nulling;\r\n    let zone=this.zone;\r\n    sortable._nulling=function() {\r\n      console.log(`pluginEvent 2 ${pluginEvent}`)\r\n            zone.runOutsideAngular(() => {\r\n              console.log(`pluginEvent3 ${pluginEvent}`)\r\n      pluginEvent('nulling', this);\r\n  \r\n      rootEl =\r\n      dragEl =\r\n      parentEl =\r\n      ghostEl =\r\n      nextEl =\r\n      cloneEl =\r\n      lastDownEl =\r\n      cloneHidden =\r\n  \r\n      tapEvt =\r\n      touchEvt =\r\n  \r\n      moved =\r\n      newIndex =\r\n      newDraggableIndex =\r\n      oldIndex =\r\n      oldDraggableIndex =\r\n  \r\n      lastTarget =\r\n      lastDirection =\r\n  \r\n      putSortable =\r\n      activeGroup =\r\n      Sortable.dragged =\r\n      Sortable.ghost =\r\n      Sortable.clone =\r\n      Sortable.active = null;\r\n  \r\n    \r\n        let el = this.el;\r\n        savedInputChecked.forEach(function (checkEl) {\r\n          if (el.contains(checkEl)) {\r\n            checkEl.checked = true;\r\n          }\r\n        });\r\n    \r\n        savedInputChecked.length =\r\n        lastDx =\r\n        lastDy = 0;\r\n\r\n      })\r\n\r\n    }.bind(sortable)\r\n    */\r\n  }\r\n\r\n  isDraggable(node: any): boolean {\r\n    let result=node.arrayItem && node.type !== '$ref' &&\r\n    node.arrayItemType === 'list' && this.isOrderable !== false;\r\n    if (this.sortableObj) {\r\n      //this.sortableObj.option(\"disabled\",true);\r\n      //this.sortableObj.option(\"sort\",false);\r\n      //this.sortableObj.option(\"disabled\",!result);\r\n    }\r\n\r\n    return result;\r\n  }\r\n\r\n  //TODO also need to think of other types such as button which can be\r\n  //created by an arbitrary layout\r\n  isFixed(node: any): boolean {\r\n    let result=node.type == '$ref';\r\n    return result;\r\n  }\r\n\r\n  // Set attributes for flexbox child\r\n  // (container attributes are set in section.component)\r\n  getFlexAttribute(node: any, attribute: string) {\r\n    const index = ['flex-grow', 'flex-shrink', 'flex-basis'].indexOf(attribute);\r\n    return ((node.options || {}).flex || '').split(/\\s+/)[index] ||\r\n      (node.options || {})[attribute] || ['1', '1', 'auto'][index];\r\n  }\r\n\r\n  showWidget(layoutNode: any): boolean {\r\n    return this.jsf.evaluateCondition(layoutNode, this.dataIndex);\r\n  }\r\n  ngOnInit(): void {\r\n    // Subscribe to the draggable state\r\n    this.sortableOptionsSubscription = this.jsf.sortableOptions$.subscribe(\r\n      (optsValue) => {\r\n        if (this.sortableObj) {\r\n          Object.keys(optsValue).forEach(opt=>{\r\n            let optVal=optsValue[opt];\r\n            this.sortableObj.option(opt,optVal);\r\n          })\r\n          //this.sortableObj.option(\"disabled\",true);\r\n          //this.sortableObj.option(\"sort\",false);\r\n        }\r\n      }\r\n    );\r\n  }\r\n  ngOnDestroy(): void {\r\n    if (this.sortableOptionsSubscription) {\r\n      this.sortableOptionsSubscription.unsubscribe();\r\n    }\r\n  }\r\n}\r\n"]}
222
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"root.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-formworks-core/src/lib/widget-library/root.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnDestroy, OnInit } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { JsonSchemaFormService } from '../json-schema-form.service';\r\n@Component({\r\n  // tslint:disable-next-line:component-selector\r\n  selector: 'root-widget',\r\n  template: `\r\n    <div [class.flex-inherit]=\"true\" #sortableContainter [nxtSortablejs]=\"layout\" [config]=\"sortableConfig\" (init)=\"sortableInit($event)\">\r\n      <div *ngFor=\"let layoutItem of layout; let i = index\"\r\n        [class.form-flex-item]=\"isFlexItem\"\r\n        [style.align-self]=\"(layoutItem.options || {})['align-self']\"\r\n        [style.flex-basis]=\"getFlexAttribute(layoutItem, 'flex-basis')\"\r\n        [style.flex-grow]=\"getFlexAttribute(layoutItem, 'flex-grow')\"\r\n        [style.flex-shrink]=\"getFlexAttribute(layoutItem, 'flex-shrink')\"\r\n        [style.order]=\"(layoutItem.options || {}).order\"\r\n        [class.sortable-filter]=\"!isDraggable(layoutItem)\"\r\n        [class.sortable-fixed]=\"isFixed(layoutItem)\"\r\n        >\r\n        <!--NB orderable directive is not used but has been left in for now and set to false\r\n          otherwise the compiler won't recognize dataIndex and other dependent attributes\r\n        -->\r\n        <div \r\n          [dataIndex]=\"layoutItem?.arrayItem ? (dataIndex || []).concat(i) : (dataIndex || [])\"\r\n          [layoutIndex]=\"(layoutIndex || []).concat(i)\"\r\n          [layoutNode]=\"layoutItem\"\r\n          [orderable]=\"false\"\r\n          [class.sortable-filter]=\"!isDraggable(layoutItem)\"\r\n          [class.sortable-fixed]=\"isFixed(layoutItem)\"\r\n          >\r\n          <select-framework-widget *ngIf=\"showWidget(layoutItem)\"\r\n            [dataIndex]=\"layoutItem?.arrayItem ? (dataIndex || []).concat(i) : (dataIndex || [])\"\r\n            [layoutIndex]=\"(layoutIndex || []).concat(i)\"\r\n            [layoutNode]=\"layoutItem\"></select-framework-widget>\r\n        </div>\r\n      </div>\r\n    </div>\r\n    `,\r\n  styles: [`\r\n    [draggable=true] {\r\n      transition: all 150ms cubic-bezier(.4, 0, .2, 1);\r\n    }\r\n    [draggable=true]:hover {\r\n      cursor: move;\r\n      box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.2);\r\n      position: relative; z-index: 10;\r\n      margin-top: -1px;\r\n      margin-left: -1px;\r\n      margin-right: 1px;\r\n      margin-bottom: 1px;\r\n    }\r\n    [draggable=true].drag-target-top {\r\n      box-shadow: 0 -2px 0 #000;\r\n      position: relative; z-index: 20;\r\n    }\r\n    [draggable=true].drag-target-bottom {\r\n      box-shadow: 0 2px 0 #000;\r\n      position: relative; z-index: 20;\r\n    }\r\n    .flex-inherit{\r\n      display:inherit;\r\n      flex-flow:inherit;\r\n      flex-wrap:inherit;\r\n      flex-direction:inherit;\r\n      width:100%\r\n    }\r\n  `],\r\n  standalone: false\r\n})\r\n\r\n\r\nexport class RootComponent implements OnInit, OnDestroy{\r\n  options: any;\r\n  @Input() dataIndex: number[];\r\n  @Input() layoutIndex: number[];\r\n  @Input() layout: any[];\r\n  @Input() isOrderable: boolean;\r\n  @Input() isFlexItem = false;\r\n\r\n  constructor(\r\n    private jsf: JsonSchemaFormService\r\n  ) { }\r\n  // @ViewChild('sortableContainter', {})\r\n  // sortableContainterElt: ElementRef;\r\n\r\n  sortableObj: any;\r\n  sortableConfig:any={\r\n    filter:\".sortable-filter\",//needed to disable dragging on input range elements, class needs to be added to the element or its parent\r\n    preventOnFilter: false,//needed for input range elements slider do still work\r\n    onEnd: (/**Event*/evt)=> {\r\n      evt.newIndex // most likely why this event is used is to get the dragging element's current index\r\n      // same properties as onEnd\r\n      //console.log(`sortablejs event:${evt}`);\r\n      let srcInd=evt.oldIndex;\r\n      let trgInd=evt.newIndex;\r\n      let layoutItem=this.layout[trgInd];\r\n      let dataInd=layoutItem?.arrayItem ? (this.dataIndex || []).concat(trgInd) : (this.dataIndex || []);\r\n      let layoutInd=(this.layoutIndex || []).concat(trgInd)\r\n      let itemCtx:any={\r\n        dataIndex:dataInd,\r\n        layoutIndex:layoutInd,\r\n        layoutNode:layoutItem,\r\n      }\r\n      //must set moveLayout to false as nxtSortable already moves it\r\n      this.jsf.moveArrayItem(itemCtx, evt.oldIndex, evt.newIndex,false);\r\n      \r\n    },\r\n    onMove: function (/**Event*/evt, /**Event*/originalEvent) {\r\n      if(evt.related.classList.contains(\"sortable-fixed\")){\r\n       //console.log(evt.related);\r\n       return false;\r\n     }\r\n   }\r\n  }\r\n  private sortableOptionsSubscription: Subscription;\r\n  sortableInit(sortable) {\r\n    this.sortableObj = sortable;\r\n    //Sortable.utils.on(this.sortableObj.el,\"nulling\",(s)=>{console.log(\"event nulling sortablejs\")})\r\n    ///NB issue caused by sortablejs when it its destroyed\r\n    //this mainly affects checkboxes coupled with conditions\r\n    //-the value is rechecked\r\n    //-see https://github.com/SortableJS/Sortable/issues/1052#issuecomment-369613072\r\n    /* attempt to monkey patch sortable js \r\n    const originalMethod = sortable._nulling;\r\n    let zone=this.zone;\r\n    sortable._nulling=function() {\r\n      console.log(`pluginEvent 2 ${pluginEvent}`)\r\n            zone.runOutsideAngular(() => {\r\n              console.log(`pluginEvent3 ${pluginEvent}`)\r\n      pluginEvent('nulling', this);\r\n  \r\n      rootEl =\r\n      dragEl =\r\n      parentEl =\r\n      ghostEl =\r\n      nextEl =\r\n      cloneEl =\r\n      lastDownEl =\r\n      cloneHidden =\r\n  \r\n      tapEvt =\r\n      touchEvt =\r\n  \r\n      moved =\r\n      newIndex =\r\n      newDraggableIndex =\r\n      oldIndex =\r\n      oldDraggableIndex =\r\n  \r\n      lastTarget =\r\n      lastDirection =\r\n  \r\n      putSortable =\r\n      activeGroup =\r\n      Sortable.dragged =\r\n      Sortable.ghost =\r\n      Sortable.clone =\r\n      Sortable.active = null;\r\n  \r\n    \r\n        let el = this.el;\r\n        savedInputChecked.forEach(function (checkEl) {\r\n          if (el.contains(checkEl)) {\r\n            checkEl.checked = true;\r\n          }\r\n        });\r\n    \r\n        savedInputChecked.length =\r\n        lastDx =\r\n        lastDy = 0;\r\n\r\n      })\r\n\r\n    }.bind(sortable)\r\n    */\r\n  }\r\n\r\n  isDraggable(node: any): boolean {\r\n    let result=node.arrayItem && node.type !== '$ref' &&\r\n    node.arrayItemType === 'list' && this.isOrderable !== false;\r\n    if (this.sortableObj) {\r\n      //this.sortableObj.option(\"disabled\",true);\r\n      //this.sortableObj.option(\"sort\",false);\r\n      //this.sortableObj.option(\"disabled\",!result);\r\n    }\r\n\r\n    return result;\r\n  }\r\n\r\n  //TODO also need to think of other types such as button which can be\r\n  //created by an arbitrary layout\r\n  isFixed(node: any): boolean {\r\n    let result=node.type == '$ref';\r\n    return result;\r\n  }\r\n\r\n  // Set attributes for flexbox child\r\n  // (container attributes are set in section.component)\r\n  getFlexAttribute(node: any, attribute: string) {\r\n    const index = ['flex-grow', 'flex-shrink', 'flex-basis'].indexOf(attribute);\r\n    return ((node.options || {}).flex || '').split(/\\s+/)[index] ||\r\n      (node.options || {})[attribute] || ['1', '1', 'auto'][index];\r\n  }\r\n\r\n  showWidget(layoutNode: any): boolean {\r\n    return this.jsf.evaluateCondition(layoutNode, this.dataIndex);\r\n  }\r\n  ngOnInit(): void {\r\n    // Subscribe to the draggable state\r\n    this.sortableOptionsSubscription = this.jsf.sortableOptions$.subscribe(\r\n      (optsValue) => {\r\n        if (this.sortableObj) {\r\n          Object.keys(optsValue).forEach(opt=>{\r\n            let optVal=optsValue[opt];\r\n            this.sortableObj.option(opt,optVal);\r\n          })\r\n          //this.sortableObj.option(\"disabled\",true);\r\n          //this.sortableObj.option(\"sort\",false);\r\n        }\r\n      }\r\n    );\r\n  }\r\n  ngOnDestroy(): void {\r\n    if (this.sortableOptionsSubscription) {\r\n      this.sortableOptionsSubscription.unsubscribe();\r\n    }\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,186 @@
1
+ import { Component, inject, Input } from '@angular/core';
2
+ import { FrameworkLibraryService } from '../framework-library/framework-library.service';
3
+ import { JsonSchemaFormService } from '../json-schema-form.service';
4
+ import { buildTitleMap, isArray } from '../shared';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/common";
7
+ import * as i2 from "@angular/forms";
8
+ //component created as a fallback for the checkbox/sortabljs issue
9
+ //its meant to display a select as a checkbox
10
+ export class SelectCheckboxComponent {
11
+ constructor() {
12
+ this.jsf = inject(JsonSchemaFormService);
13
+ this.jsfFLService = inject(FrameworkLibraryService);
14
+ this.controlDisabled = false;
15
+ this.boundControl = false;
16
+ this.selectList = [];
17
+ this.selectListFlatGroup = [];
18
+ this.isArray = isArray;
19
+ this.frameworkStyles = {
20
+ daisyui: { selectClass: "select-box", optionClass: "checkbox tw:dui-checkbox", optionChecked: "active", optionUnchecked: "" },
21
+ "bootstrap-3": { selectClass: "select-box", optionClass: "bs3-option checkbox display-inline-block", optionChecked: "active", optionUnchecked: "" },
22
+ "bootstrap-4": { selectClass: "select-box", optionClass: "bs4-option checkbox display-inline-block", optionChecked: "active", optionUnchecked: "" },
23
+ "bootstrap-5": { selectClass: " select-box", optionClass: "form-check-input display-inline-block", optionChecked: "active", optionUnchecked: "" },
24
+ //"material-design":{selectClass:" ",optionClass:" "}
25
+ };
26
+ }
27
+ ngOnInit() {
28
+ this.options = this.layoutNode.options || {};
29
+ this.activeFramework = this.jsfFLService.activeFramework.name;
30
+ this.selectList = buildTitleMap(
31
+ //this.options.titleMap || this.options.enumNames,
32
+ //TODO review-title is set to null in the setTitle() method of CssFrameworkComponent
33
+ this.options.enumNames || (this.options?.title && [this.options?.title])
34
+ || [this.layoutNode.name],
35
+ //this.options.enum,
36
+ [true],
37
+ //make required true to avoid creating 'none' select option
38
+ true, !!this.options.flatList);
39
+ //the selectListFlatGroup array will be used to update the formArray values
40
+ //while the selectList array will be bound to the form select
41
+ //as either a grouped select or a flat select
42
+ /*
43
+ this.selectListFlatGroup = buildTitleMap(
44
+ this.options.titleMap || this.options.enumNames,
45
+ this.options.enum, !!this.options.required, true
46
+ )
47
+ */
48
+ this.jsf.initializeControl(this);
49
+ this.selectValue = [this.controlValue];
50
+ }
51
+ deselectAll() {
52
+ this.selectListFlatGroup.forEach(selItem => {
53
+ selItem.checked = false;
54
+ });
55
+ }
56
+ updateValue(event) {
57
+ this.options.showErrors = true;
58
+ this.controlValue = this.selectValue[0];
59
+ this.jsf.updateValue(this, this.controlValue);
60
+ }
61
+ onSelectClicked($event) {
62
+ this.selectValue = this.selectValue && this.selectValue[0] ? [false] : [true];
63
+ this.controlValue = this.selectValue[0];
64
+ this.jsf.updateValue(this, this.controlValue);
65
+ }
66
+ ngOnDestroy() {
67
+ let nullVal = this.options.multiple ? [null] : null;
68
+ this.formControl.reset(nullVal);
69
+ this.controlValue = null;
70
+ }
71
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SelectCheckboxComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
72
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: SelectCheckboxComponent, selector: "selectcheckbox-widget", inputs: { layoutNode: "layoutNode", layoutIndex: "layoutIndex", dataIndex: "dataIndex" }, ngImport: i0, template: `
73
+ <div
74
+ [class]="options?.htmlClass || ''">
75
+ <select *ngIf="boundControl"
76
+ [attr.aria-describedby]="'control' + layoutNode?._id + 'Status'"
77
+ [attr.readonly]="options?.readonly ? 'readonly' : null"
78
+ [attr.required]="options?.required"
79
+ [class]=" frameworkStyles[activeFramework].selectClass"
80
+ [multiple]="true"
81
+ [id]="'control' + layoutNode?._id"
82
+ [name]="controlName"
83
+ [ngModel]="selectValue"
84
+ >
85
+ <ng-template ngFor let-selectItem [ngForOf]="selectList">
86
+ <option *ngIf="!isArray(selectItem?.items)"
87
+ [class]="frameworkStyles[activeFramework].optionClass"
88
+ [class.active]="selectItem?.value === controlValue"
89
+ [class.unchecked-notusing]="selectItem?.value != controlValue"
90
+ [value]="selectItem?.value"
91
+ (click)="onSelectClicked($event)"
92
+ type="checkbox"
93
+ >
94
+ </option>
95
+ <!--NB the text is out of the option element to display besides the checkbox-->
96
+ <span [innerHTML]="selectItem?.name"></span>
97
+ </ng-template>
98
+ </select>
99
+ <select *ngIf="!boundControl"
100
+ [attr.aria-describedby]="'control' + layoutNode?._id + 'Status'"
101
+ [attr.readonly]="options?.readonly ? 'readonly' : null"
102
+ [attr.required]="options?.required"
103
+ [class]="frameworkStyles[activeFramework].selectClass +' select-box'"
104
+ [multiple]="true"
105
+ [disabled]="controlDisabled"
106
+ [id]="'control' + layoutNode?._id"
107
+ [name]="controlName"
108
+ (change)="updateValue($event)">
109
+ <ng-template ngFor let-selectItem [ngForOf]="selectList">
110
+ <option *ngIf="!isArray(selectItem?.items)"
111
+ [selected]="selectItem?.value === controlValue"
112
+ [class]="frameworkStyles[activeFramework].optionClass"
113
+ [class.checked-notusing]="selectItem?.value === controlValue"
114
+ [class.unchecked-notusing]]="selectItem?.value != controlValue"
115
+ [value]="selectItem?.value"
116
+ type="checkbox">
117
+ </option>
118
+ <!--NB the text is out of the option element to display besides the checkbox-->
119
+ <span [innerHTML]="selectItem?.name"></span>
120
+ </ng-template>
121
+ </select>
122
+
123
+ </div>`, isInline: true, styles: [".select-box{font-size:16px;border:none;appearance:none;-webkit-appearance:none;-moz-appearance:none;height:25px;overflow:hidden;text-overflow:ellipsis;background-color:#fff;color:#000;background-color:transparent}.select-box:focus{outline:none}.select-option{font-size:20px;color:#000;background-color:#fff;display:inline-block}.unchecked:before{content:\"\\2610\";left:5px;top:50%;transform:translateY(-50%);font-size:30px}.checked:before{content:\"\\2611\";left:5px;top:50%;transform:translateY(-50%);font-size:30px}.select-option:checked{background-image:linear-gradient(0deg,#fff 0% 100%);color:#000}.select-box[multiple]:focus{background-color:transparent;color:#00f;-webkit-text-fill-color:black}.display-inline-block{display:inline-block}.bs4-option,.bs3-option{width:14px;height:14px;border:solid 1px;color:#a9a9a9;min-block-size:auto;border-radius:3px}.bs4-option:checked[type=checkbox],.bs3-option:checked[type=checkbox]{background-image:url(data:image/svg+xml,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3C!--%20License%3A%20MIT.%20Made%20by%20jaynewey%3A%20https%3A%2F%2Fgithub.com%2Fjaynewey%2Fcharm-icons%20--%3E%3Csvg%20viewBox%3D%220%200%2016%2016%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20version%3D%221.1%22%20fill%3D%22none%22%20stroke%3D%22%23000000%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20stroke-width%3D%222.5%22%3E%3Cpolyline%20points%3D%224%208.75%2C6.25%2012.25%2C13.25%203.5%22%2F%3E%3C%2Fsvg%3E);background-color:#00ced1}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.SelectMultipleControlValueAccessor, selector: "select[multiple][formControlName],select[multiple][formControl],select[multiple][ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); }
124
+ }
125
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SelectCheckboxComponent, decorators: [{
126
+ type: Component,
127
+ args: [{ selector: 'selectcheckbox-widget', template: `
128
+ <div
129
+ [class]="options?.htmlClass || ''">
130
+ <select *ngIf="boundControl"
131
+ [attr.aria-describedby]="'control' + layoutNode?._id + 'Status'"
132
+ [attr.readonly]="options?.readonly ? 'readonly' : null"
133
+ [attr.required]="options?.required"
134
+ [class]=" frameworkStyles[activeFramework].selectClass"
135
+ [multiple]="true"
136
+ [id]="'control' + layoutNode?._id"
137
+ [name]="controlName"
138
+ [ngModel]="selectValue"
139
+ >
140
+ <ng-template ngFor let-selectItem [ngForOf]="selectList">
141
+ <option *ngIf="!isArray(selectItem?.items)"
142
+ [class]="frameworkStyles[activeFramework].optionClass"
143
+ [class.active]="selectItem?.value === controlValue"
144
+ [class.unchecked-notusing]="selectItem?.value != controlValue"
145
+ [value]="selectItem?.value"
146
+ (click)="onSelectClicked($event)"
147
+ type="checkbox"
148
+ >
149
+ </option>
150
+ <!--NB the text is out of the option element to display besides the checkbox-->
151
+ <span [innerHTML]="selectItem?.name"></span>
152
+ </ng-template>
153
+ </select>
154
+ <select *ngIf="!boundControl"
155
+ [attr.aria-describedby]="'control' + layoutNode?._id + 'Status'"
156
+ [attr.readonly]="options?.readonly ? 'readonly' : null"
157
+ [attr.required]="options?.required"
158
+ [class]="frameworkStyles[activeFramework].selectClass +' select-box'"
159
+ [multiple]="true"
160
+ [disabled]="controlDisabled"
161
+ [id]="'control' + layoutNode?._id"
162
+ [name]="controlName"
163
+ (change)="updateValue($event)">
164
+ <ng-template ngFor let-selectItem [ngForOf]="selectList">
165
+ <option *ngIf="!isArray(selectItem?.items)"
166
+ [selected]="selectItem?.value === controlValue"
167
+ [class]="frameworkStyles[activeFramework].optionClass"
168
+ [class.checked-notusing]="selectItem?.value === controlValue"
169
+ [class.unchecked-notusing]]="selectItem?.value != controlValue"
170
+ [value]="selectItem?.value"
171
+ type="checkbox">
172
+ </option>
173
+ <!--NB the text is out of the option element to display besides the checkbox-->
174
+ <span [innerHTML]="selectItem?.name"></span>
175
+ </ng-template>
176
+ </select>
177
+
178
+ </div>`, standalone: false, styles: [".select-box{font-size:16px;border:none;appearance:none;-webkit-appearance:none;-moz-appearance:none;height:25px;overflow:hidden;text-overflow:ellipsis;background-color:#fff;color:#000;background-color:transparent}.select-box:focus{outline:none}.select-option{font-size:20px;color:#000;background-color:#fff;display:inline-block}.unchecked:before{content:\"\\2610\";left:5px;top:50%;transform:translateY(-50%);font-size:30px}.checked:before{content:\"\\2611\";left:5px;top:50%;transform:translateY(-50%);font-size:30px}.select-option:checked{background-image:linear-gradient(0deg,#fff 0% 100%);color:#000}.select-box[multiple]:focus{background-color:transparent;color:#00f;-webkit-text-fill-color:black}.display-inline-block{display:inline-block}.bs4-option,.bs3-option{width:14px;height:14px;border:solid 1px;color:#a9a9a9;min-block-size:auto;border-radius:3px}.bs4-option:checked[type=checkbox],.bs3-option:checked[type=checkbox]{background-image:url(data:image/svg+xml,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3C!--%20License%3A%20MIT.%20Made%20by%20jaynewey%3A%20https%3A%2F%2Fgithub.com%2Fjaynewey%2Fcharm-icons%20--%3E%3Csvg%20viewBox%3D%220%200%2016%2016%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20version%3D%221.1%22%20fill%3D%22none%22%20stroke%3D%22%23000000%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20stroke-width%3D%222.5%22%3E%3Cpolyline%20points%3D%224%208.75%2C6.25%2012.25%2C13.25%203.5%22%2F%3E%3C%2Fsvg%3E);background-color:#00ced1}\n"] }]
179
+ }], propDecorators: { layoutNode: [{
180
+ type: Input
181
+ }], layoutIndex: [{
182
+ type: Input
183
+ }], dataIndex: [{
184
+ type: Input
185
+ }] } });
186
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selectcheckbox.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-formworks-core/src/lib/widget-library/selectcheckbox.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, inject, Input, OnDestroy, OnInit } from '@angular/core';\r\nimport { AbstractControl } from '@angular/forms';\r\nimport { FrameworkLibraryService } from '../framework-library/framework-library.service';\r\nimport { JsonSchemaFormService } from '../json-schema-form.service';\r\nimport { buildTitleMap, isArray } from '../shared';\r\n\r\n//component created as a fallback for the checkbox/sortabljs issue\r\n//its meant to display a select as a checkbox\r\n@Component({\r\n  // tslint:disable-next-line:component-selector\r\n  selector: 'selectcheckbox-widget',\r\n  template: `\r\n    <div \r\n      [class]=\"options?.htmlClass || ''\">\r\n      <select *ngIf=\"boundControl\"\r\n        [attr.aria-describedby]=\"'control' + layoutNode?._id + 'Status'\"\r\n        [attr.readonly]=\"options?.readonly ? 'readonly' : null\"\r\n        [attr.required]=\"options?.required\"\r\n        [class]=\" frameworkStyles[activeFramework].selectClass\"\r\n        [multiple]=\"true\"\r\n        [id]=\"'control' + layoutNode?._id\"\r\n        [name]=\"controlName\"\r\n        [ngModel]=\"selectValue\"   \r\n        >\r\n        <ng-template ngFor let-selectItem [ngForOf]=\"selectList\">\r\n          <option *ngIf=\"!isArray(selectItem?.items)\"\r\n            [class]=\"frameworkStyles[activeFramework].optionClass\"\r\n            [class.active]=\"selectItem?.value === controlValue\"\r\n            [class.unchecked-notusing]=\"selectItem?.value != controlValue\"\r\n            [value]=\"selectItem?.value\"\r\n            (click)=\"onSelectClicked($event)\"\r\n            type=\"checkbox\"\r\n            >\r\n          </option>\r\n          <!--NB the text is out of the option element to display besides the checkbox-->\r\n          <span [innerHTML]=\"selectItem?.name\"></span>\r\n        </ng-template>\r\n      </select>\r\n      <select *ngIf=\"!boundControl\"\r\n        [attr.aria-describedby]=\"'control' + layoutNode?._id + 'Status'\"\r\n        [attr.readonly]=\"options?.readonly ? 'readonly' : null\"\r\n        [attr.required]=\"options?.required\"\r\n        [class]=\"frameworkStyles[activeFramework].selectClass +' select-box'\"\r\n        [multiple]=\"true\"\r\n        [disabled]=\"controlDisabled\"\r\n        [id]=\"'control' + layoutNode?._id\"\r\n        [name]=\"controlName\"\r\n        (change)=\"updateValue($event)\">\r\n        <ng-template ngFor let-selectItem [ngForOf]=\"selectList\">\r\n          <option *ngIf=\"!isArray(selectItem?.items)\"\r\n            [selected]=\"selectItem?.value === controlValue\"\r\n            [class]=\"frameworkStyles[activeFramework].optionClass\"\r\n            [class.checked-notusing]=\"selectItem?.value === controlValue\"\r\n            [class.unchecked-notusing]]=\"selectItem?.value != controlValue\"\r\n            [value]=\"selectItem?.value\"\r\n            type=\"checkbox\">\r\n          </option>\r\n          <!--NB the text is out of the option element to display besides the checkbox-->\r\n          <span [innerHTML]=\"selectItem?.name\"></span>\r\n        </ng-template>\r\n      </select>\r\n      \r\n    </div>`,\r\n    styles:[`\r\n        /* Style the select element */\r\n        .select-box {\r\n            font-size: 16px;\r\n            border: none;\r\n            appearance: none;\r\n            -webkit-appearance: none;\r\n            -moz-appearance: none;\r\n            height: 25px;  /*Height equal to the size of a single option */\r\n            overflow: hidden; /* Hide scrollbars */\r\n            text-overflow: ellipsis; /* For overflowing text inside options */\r\n            background-color: white; /* Set background to white */\r\n            color: black; /* Ensure text is black */\r\n            /* White gradient background */\r\n            /*\r\n            background-image: linear-gradient(0deg, white 0%, white 100%); \r\n            */\r\n            background-color:transparent;\r\n          }\r\n\r\n        /* Remove the default focus outline */\r\n        .select-box:focus {\r\n            outline: none;\r\n        }\r\n\r\n        /* Style the option element */\r\n        .select-option {\r\n            font-size: 20px; /* Adjust size of the checkbox */\r\n            color: black; /* Ensure text color is black */\r\n            background-color: white; /* Ensure background is white */\r\n            display:inline-block;\r\n        }\r\n\r\n        /* Empty box when unchecked */\r\n        .unchecked::before {\r\n            content: '☐'; /* Empty box Unicode */\r\n            left: 5px;\r\n            top: 50%;\r\n            transform: translateY(-50%);\r\n            font-size: 30px; /* Adjust size */\r\n        }\r\n\r\n        /* Checked box when selected */\r\n        .checked::before {\r\n            content: '☑'; /* Checked box with tick Unicode */\r\n            left: 5px;\r\n            top: 50%;\r\n            transform: translateY(-50%);\r\n            font-size: 30px;\r\n        }\r\n\r\n        /* Maintain the text and background color when the option is selected */\r\n        .select-option:checked {\r\n            background-image: linear-gradient(0deg, white 0%, white 100%);\r\n            color: black;\r\n        }\r\n\r\n        /* Style the select element when focused */\r\n        .select-box[multiple]:focus {\r\n          /*\r\n            background-image: linear-gradient(0deg, white 0%, white 100%);\r\n            */\r\n           background-color:transparent;\r\n            color: blue;\r\n            -webkit-text-fill-color: black;\r\n        }\r\n        \r\n        .display-inline-block{\r\n           display:inline-block;\r\n        }\r\n\r\n        .bs4-option, .bs3-option{\r\n          width: 14px;\r\n          height: 14px;\r\n          border: solid 1px;\r\n          color: darkgrey;\r\n          min-block-size: auto;\r\n          border-radius: 3px;\r\n          \r\n        }\r\n        .bs4-option:checked[type=checkbox], .bs3-option:checked[type=checkbox] {\r\n           \r\n        background-image: url(data:image/svg+xml,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3C!--%20License%3A%20MIT.%20Made%20by%20jaynewey%3A%20https%3A%2F%2Fgithub.com%2Fjaynewey%2Fcharm-icons%20--%3E%3Csvg%20viewBox%3D%220%200%2016%2016%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20version%3D%221.1%22%20fill%3D%22none%22%20stroke%3D%22%23000000%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20stroke-width%3D%222.5%22%3E%3Cpolyline%20points%3D%224%208.75%2C6.25%2012.25%2C13.25%203.5%22%2F%3E%3C%2Fsvg%3E);\r\n        background-color:darkturquoise;\r\n        }\r\n      \r\n      `],\r\n  standalone: false\r\n})\r\nexport class SelectCheckboxComponent implements OnInit, OnDestroy {\r\n  private jsf = inject(JsonSchemaFormService);\r\n  private jsfFLService = inject(FrameworkLibraryService);\r\n\r\n  formControl: AbstractControl;\r\n  controlName: string;\r\n  controlValue: any;\r\n  controlDisabled = false;\r\n  boundControl = false;\r\n  options: any;\r\n  selectList: any[] = [];\r\n  selectListFlatGroup: any[] = [];\r\n  selectValue: any;\r\n  isArray = isArray;\r\n  @Input() layoutNode: any;\r\n  @Input() layoutIndex: number[];\r\n  @Input() dataIndex: number[];\r\n\r\n frameworkStyles={\r\n    daisyui:{selectClass:\"select-box\",optionClass:\"checkbox tw:dui-checkbox\",optionChecked:\"active\",optionUnchecked:\"\"},\r\n    \"bootstrap-3\":{selectClass:\"select-box\",optionClass:\"bs3-option checkbox display-inline-block\",optionChecked:\"active\",optionUnchecked:\"\"},\r\n    \"bootstrap-4\":{selectClass:\"select-box\",optionClass:\"bs4-option checkbox display-inline-block\",optionChecked:\"active\",optionUnchecked:\"\"},\r\n    \"bootstrap-5\":{selectClass:\" select-box\",optionClass:\"form-check-input display-inline-block\",optionChecked:\"active\",optionUnchecked:\"\"},\r\n    //\"material-design\":{selectClass:\" \",optionClass:\" \"}\r\n\r\n }\r\n\r\n activeFramework:string;\r\n\r\n  ngOnInit() {\r\n    this.options = this.layoutNode.options || {};\r\n    this.activeFramework= this.jsfFLService.activeFramework.name;\r\n    this.selectList = buildTitleMap(\r\n      //this.options.titleMap || this.options.enumNames,\r\n      //TODO review-title is set to null in the setTitle() method of CssFrameworkComponent\r\n      this.options.enumNames || (this.options?.title && [this.options?.title]) \r\n      || [this.layoutNode.name],\r\n      //this.options.enum, \r\n      [true],\r\n      //make required true to avoid creating 'none' select option\r\n      true, !!this.options.flatList\r\n    );\r\n\r\n\r\n\r\n\r\n    //the selectListFlatGroup array will be used to update the formArray values\r\n    //while the selectList array will be bound to the form select\r\n    //as either a grouped select or a flat select\r\n    /*\r\n    this.selectListFlatGroup = buildTitleMap(\r\n      this.options.titleMap || this.options.enumNames,\r\n      this.options.enum, !!this.options.required, true\r\n    )\r\n    */\r\n    \r\n    this.jsf.initializeControl(this);\r\n    this.selectValue=[this.controlValue];\r\n  }\r\n\r\n  deselectAll() {\r\n    this.selectListFlatGroup.forEach(selItem => {\r\n      selItem.checked = false;\r\n    })\r\n  }\r\n\r\n  updateValue(event) {\r\n    this.options.showErrors = true;\r\n    this.controlValue=this.selectValue[0];\r\n    this.jsf.updateValue(this, this.controlValue);\r\n  }\r\n\r\n  onSelectClicked($event){\r\n    this.selectValue=this.selectValue && this.selectValue[0]?[false]:[true];\r\n    this.controlValue=this.selectValue[0];\r\n    this.jsf.updateValue(this, this.controlValue);\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    let nullVal=this.options.multiple?[null]:null;\r\n    this.formControl.reset(nullVal)\r\n    this.controlValue=null;\r\n  }\r\n}\r\n"]}
@@ -28,10 +28,11 @@ import * as i19 from "./tab.component";
28
28
  import * as i20 from "./tabs.component";
29
29
  import * as i21 from "./template.component";
30
30
  import * as i22 from "./textarea.component";
31
- import * as i23 from "nxt-sortablejs";
31
+ import * as i23 from "./selectcheckbox.component";
32
+ import * as i24 from "nxt-sortablejs";
32
33
  export class WidgetLibraryModule {
33
34
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: WidgetLibraryModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
34
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: WidgetLibraryModule, declarations: [i1.AddReferenceComponent, i2.OneOfComponent, i3.ButtonComponent, i4.CheckboxComponent, i5.CheckboxesComponent, i6.FileComponent, i7.HiddenComponent, i8.InputComponent, i9.MessageComponent, i10.NoneComponent, i11.NumberComponent, i12.RadiosComponent, i13.RootComponent, i14.SectionComponent, i15.SelectComponent, i16.SelectFrameworkComponent, i17.SelectWidgetComponent, i18.SubmitComponent, i19.TabComponent, i20.TabsComponent, i21.TemplateComponent, i22.TextareaComponent, OrderableDirective, ElementAttributeDirective], imports: [CommonModule, FormsModule, ReactiveFormsModule, i23.SortablejsModule], exports: [i1.AddReferenceComponent, i2.OneOfComponent, i3.ButtonComponent, i4.CheckboxComponent, i5.CheckboxesComponent, i6.FileComponent, i7.HiddenComponent, i8.InputComponent, i9.MessageComponent, i10.NoneComponent, i11.NumberComponent, i12.RadiosComponent, i13.RootComponent, i14.SectionComponent, i15.SelectComponent, i16.SelectFrameworkComponent, i17.SelectWidgetComponent, i18.SubmitComponent, i19.TabComponent, i20.TabsComponent, i21.TemplateComponent, i22.TextareaComponent, OrderableDirective, ElementAttributeDirective] }); }
35
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: WidgetLibraryModule, declarations: [i1.AddReferenceComponent, i2.OneOfComponent, i3.ButtonComponent, i4.CheckboxComponent, i5.CheckboxesComponent, i6.FileComponent, i7.HiddenComponent, i8.InputComponent, i9.MessageComponent, i10.NoneComponent, i11.NumberComponent, i12.RadiosComponent, i13.RootComponent, i14.SectionComponent, i15.SelectComponent, i16.SelectFrameworkComponent, i17.SelectWidgetComponent, i18.SubmitComponent, i19.TabComponent, i20.TabsComponent, i21.TemplateComponent, i22.TextareaComponent, i23.SelectCheckboxComponent, OrderableDirective, ElementAttributeDirective], imports: [CommonModule, FormsModule, ReactiveFormsModule, i24.SortablejsModule], exports: [i1.AddReferenceComponent, i2.OneOfComponent, i3.ButtonComponent, i4.CheckboxComponent, i5.CheckboxesComponent, i6.FileComponent, i7.HiddenComponent, i8.InputComponent, i9.MessageComponent, i10.NoneComponent, i11.NumberComponent, i12.RadiosComponent, i13.RootComponent, i14.SectionComponent, i15.SelectComponent, i16.SelectFrameworkComponent, i17.SelectWidgetComponent, i18.SubmitComponent, i19.TabComponent, i20.TabsComponent, i21.TemplateComponent, i22.TextareaComponent, i23.SelectCheckboxComponent, OrderableDirective, ElementAttributeDirective] }); }
35
36
  static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: WidgetLibraryModule, imports: [CommonModule, FormsModule, ReactiveFormsModule,
36
37
  SortablejsModule.forRoot({
37
38
  //disabled:false,
@@ -66,4 +67,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
66
67
  exports: [...BASIC_WIDGETS, OrderableDirective, ElementAttributeDirective]
67
68
  }]
68
69
  }] });
69
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2lkZ2V0LWxpYnJhcnkubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctZm9ybXdvcmtzLWNvcmUvc3JjL2xpYi93aWRnZXQtbGlicmFyeS93aWRnZXQtbGlicmFyeS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xELE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQzFFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFDeEMsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFtQjNELE1BQU0sT0FBTyxtQkFBbUI7K0dBQW5CLG1CQUFtQjtnSEFBbkIsbUJBQW1CLDBlQUhLLGtCQUFrQixFQUFDLHlCQUF5QixhQWJuRSxZQUFZLEVBQUUsV0FBVyxFQUFFLG1CQUFtQiw0ZkFjNUIsa0JBQWtCLEVBQUMseUJBQXlCO2dIQUUvRCxtQkFBbUIsWUFoQmxCLFlBQVksRUFBRSxXQUFXLEVBQUUsbUJBQW1CO1lBQ3BELGdCQUFnQixDQUFDLE9BQU8sQ0FBQztnQkFDekIsaUJBQWlCO2dCQUNqQiw0SUFBNEk7Z0JBQzVJLE1BQU0sRUFBQyxrQkFBa0I7Z0JBQ3pCLGVBQWUsRUFBRSxLQUFLO2dCQUN0QixNQUFNLEVBQUUsVUFBVSxVQUFVLENBQUEsR0FBRyxFQUFFLFVBQVUsQ0FBQSxhQUFhO29CQUNqRCxJQUFHLEdBQUcsQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxnQkFBZ0IsQ0FBQyxFQUFDO3dCQUNuRCwyQkFBMkI7d0JBQzNCLE9BQU8sS0FBSyxDQUFDO3FCQUNkO2dCQUNILENBQUM7YUFDTixDQUFDOzs0RkFJSyxtQkFBbUI7a0JBakIvQixRQUFRO21CQUFDO29CQUNOLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxXQUFXLEVBQUUsbUJBQW1CO3dCQUNwRCxnQkFBZ0IsQ0FBQyxPQUFPLENBQUM7NEJBQ3pCLGlCQUFpQjs0QkFDakIsNElBQTRJOzRCQUM1SSxNQUFNLEVBQUMsa0JBQWtCOzRCQUN6QixlQUFlLEVBQUUsS0FBSzs0QkFDdEIsTUFBTSxFQUFFLFVBQVUsVUFBVSxDQUFBLEdBQUcsRUFBRSxVQUFVLENBQUEsYUFBYTtnQ0FDakQsSUFBRyxHQUFHLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsZ0JBQWdCLENBQUMsRUFBQztvQ0FDbkQsMkJBQTJCO29DQUMzQixPQUFPLEtBQUssQ0FBQztpQ0FDZDs0QkFDSCxDQUFDO3lCQUNOLENBQUMsQ0FBQztvQkFDTCxZQUFZLEVBQUUsQ0FBQyxHQUFHLGFBQWEsRUFBRSxrQkFBa0IsRUFBQyx5QkFBeUIsQ0FBQztvQkFDOUUsT0FBTyxFQUFFLENBQUMsR0FBRyxhQUFhLEVBQUUsa0JBQWtCLEVBQUMseUJBQXlCLENBQUM7aUJBQzVFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IFNvcnRhYmxlanNNb2R1bGUgfSBmcm9tICdueHQtc29ydGFibGVqcyc7XHJcbmltcG9ydCB7IEVsZW1lbnRBdHRyaWJ1dGVEaXJlY3RpdmUgfSBmcm9tICcuL2VsZW1lbnQtYXR0cmlidXRlLmRpcmVjdGl2ZSc7XHJcbmltcG9ydCB7IEJBU0lDX1dJREdFVFMgfSBmcm9tICcuL2luZGV4JztcclxuaW1wb3J0IHsgT3JkZXJhYmxlRGlyZWN0aXZlIH0gZnJvbSAnLi9vcmRlcmFibGUuZGlyZWN0aXZlJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSxcclxuICAgICAgICBTb3J0YWJsZWpzTW9kdWxlLmZvclJvb3Qoe1xyXG4gICAgICAgIC8vZGlzYWJsZWQ6ZmFsc2UsXHJcbiAgICAgICAgLy9kcmFnZ2FibGU6XCIuZHJhZ2dhYmxlaXRlbVwiLC8vXCI+Om5vdCgubm9uc29ydClcIiwvL1wiPi5kcmFnZ2FibGUtaXRlbVwiLC8vXCI6bm90KC5ub25zb3J0KVwiLC8vXCI+KlwiLC8vXCI6bm90KC5ub25zb3J0KVwiLC8vXCI6bm90KC5ub24tZHJhZ2dhYmxlKVwiLFxyXG4gICAgICAgIGZpbHRlcjpcIi5zb3J0YWJsZS1maWx0ZXJcIiwvL25lZWRlZCB0byBkaXNhYmxlIGRyYWdnaW5nIG9uIGlucHV0IHJhbmdlIGVsZW1lbnRzLCBjbGFzcyBuZWVkcyB0byBiZSBhZGRlZCB0byB0aGUgZWxlbWVudCBvciBpdHMgcGFyZW50XHJcbiAgICAgICAgcHJldmVudE9uRmlsdGVyOiBmYWxzZSwvL25lZWRlZCBmb3IgaW5wdXQgcmFuZ2UgZWxlbWVudHMgc2xpZGVyIGRvIHN0aWxsIHdvcmtcclxuICAgICAgICBvbk1vdmU6IGZ1bmN0aW9uICgvKipFdmVudCovZXZ0LCAvKipFdmVudCovb3JpZ2luYWxFdmVudCkge1xyXG4gICAgICAgICAgICAgICBpZihldnQucmVsYXRlZC5jbGFzc0xpc3QuY29udGFpbnMoXCJzb3J0YWJsZS1maXhlZFwiKSl7XHJcbiAgICAgICAgICAgICAgICAvL2NvbnNvbGUubG9nKGV2dC5yZWxhdGVkKTtcclxuICAgICAgICAgICAgICAgIHJldHVybiBmYWxzZTtcclxuICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgfSldLFxyXG4gICAgZGVjbGFyYXRpb25zOiBbLi4uQkFTSUNfV0lER0VUUywgT3JkZXJhYmxlRGlyZWN0aXZlLEVsZW1lbnRBdHRyaWJ1dGVEaXJlY3RpdmVdLFxyXG4gICAgZXhwb3J0czogWy4uLkJBU0lDX1dJREdFVFMsIE9yZGVyYWJsZURpcmVjdGl2ZSxFbGVtZW50QXR0cmlidXRlRGlyZWN0aXZlXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgV2lkZ2V0TGlicmFyeU1vZHVsZSB7XHJcbn1cclxuIl19
70
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2lkZ2V0LWxpYnJhcnkubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctZm9ybXdvcmtzLWNvcmUvc3JjL2xpYi93aWRnZXQtbGlicmFyeS93aWRnZXQtbGlicmFyeS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xELE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQzFFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFDeEMsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBbUIzRCxNQUFNLE9BQU8sbUJBQW1COytHQUFuQixtQkFBbUI7Z0hBQW5CLG1CQUFtQix1Z0JBSEssa0JBQWtCLEVBQUMseUJBQXlCLGFBYm5FLFlBQVksRUFBRSxXQUFXLEVBQUUsbUJBQW1CLHloQkFjNUIsa0JBQWtCLEVBQUMseUJBQXlCO2dIQUUvRCxtQkFBbUIsWUFoQmxCLFlBQVksRUFBRSxXQUFXLEVBQUUsbUJBQW1CO1lBQ3BELGdCQUFnQixDQUFDLE9BQU8sQ0FBQztnQkFDekIsaUJBQWlCO2dCQUNqQiw0SUFBNEk7Z0JBQzVJLE1BQU0sRUFBQyxrQkFBa0I7Z0JBQ3pCLGVBQWUsRUFBRSxLQUFLO2dCQUN0QixNQUFNLEVBQUUsVUFBVSxVQUFVLENBQUEsR0FBRyxFQUFFLFVBQVUsQ0FBQSxhQUFhO29CQUNqRCxJQUFHLEdBQUcsQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxnQkFBZ0IsQ0FBQyxFQUFDO3dCQUNuRCwyQkFBMkI7d0JBQzNCLE9BQU8sS0FBSyxDQUFDO3FCQUNkO2dCQUNILENBQUM7YUFDTixDQUFDOzs0RkFJSyxtQkFBbUI7a0JBakIvQixRQUFRO21CQUFDO29CQUNOLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxXQUFXLEVBQUUsbUJBQW1CO3dCQUNwRCxnQkFBZ0IsQ0FBQyxPQUFPLENBQUM7NEJBQ3pCLGlCQUFpQjs0QkFDakIsNElBQTRJOzRCQUM1SSxNQUFNLEVBQUMsa0JBQWtCOzRCQUN6QixlQUFlLEVBQUUsS0FBSzs0QkFDdEIsTUFBTSxFQUFFLFVBQVUsVUFBVSxDQUFBLEdBQUcsRUFBRSxVQUFVLENBQUEsYUFBYTtnQ0FDakQsSUFBRyxHQUFHLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsZ0JBQWdCLENBQUMsRUFBQztvQ0FDbkQsMkJBQTJCO29DQUMzQixPQUFPLEtBQUssQ0FBQztpQ0FDZDs0QkFDSCxDQUFDO3lCQUNOLENBQUMsQ0FBQztvQkFDTCxZQUFZLEVBQUUsQ0FBQyxHQUFHLGFBQWEsRUFBRSxrQkFBa0IsRUFBQyx5QkFBeUIsQ0FBQztvQkFDOUUsT0FBTyxFQUFFLENBQUMsR0FBRyxhQUFhLEVBQUUsa0JBQWtCLEVBQUMseUJBQXlCLENBQUM7aUJBQzVFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IFNvcnRhYmxlanNNb2R1bGUgfSBmcm9tICdueHQtc29ydGFibGVqcyc7XHJcbmltcG9ydCB7IEVsZW1lbnRBdHRyaWJ1dGVEaXJlY3RpdmUgfSBmcm9tICcuL2VsZW1lbnQtYXR0cmlidXRlLmRpcmVjdGl2ZSc7XHJcbmltcG9ydCB7IEJBU0lDX1dJREdFVFMgfSBmcm9tICcuL2luZGV4JztcclxuaW1wb3J0IHsgT3JkZXJhYmxlRGlyZWN0aXZlIH0gZnJvbSAnLi9vcmRlcmFibGUuZGlyZWN0aXZlJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSxcclxuICAgICAgICBTb3J0YWJsZWpzTW9kdWxlLmZvclJvb3Qoe1xyXG4gICAgICAgIC8vZGlzYWJsZWQ6ZmFsc2UsXHJcbiAgICAgICAgLy9kcmFnZ2FibGU6XCIuZHJhZ2dhYmxlaXRlbVwiLC8vXCI+Om5vdCgubm9uc29ydClcIiwvL1wiPi5kcmFnZ2FibGUtaXRlbVwiLC8vXCI6bm90KC5ub25zb3J0KVwiLC8vXCI+KlwiLC8vXCI6bm90KC5ub25zb3J0KVwiLC8vXCI6bm90KC5ub24tZHJhZ2dhYmxlKVwiLFxyXG4gICAgICAgIGZpbHRlcjpcIi5zb3J0YWJsZS1maWx0ZXJcIiwvL25lZWRlZCB0byBkaXNhYmxlIGRyYWdnaW5nIG9uIGlucHV0IHJhbmdlIGVsZW1lbnRzLCBjbGFzcyBuZWVkcyB0byBiZSBhZGRlZCB0byB0aGUgZWxlbWVudCBvciBpdHMgcGFyZW50XHJcbiAgICAgICAgcHJldmVudE9uRmlsdGVyOiBmYWxzZSwvL25lZWRlZCBmb3IgaW5wdXQgcmFuZ2UgZWxlbWVudHMgc2xpZGVyIGRvIHN0aWxsIHdvcmtcclxuICAgICAgICBvbk1vdmU6IGZ1bmN0aW9uICgvKipFdmVudCovZXZ0LCAvKipFdmVudCovb3JpZ2luYWxFdmVudCkge1xyXG4gICAgICAgICAgICAgICBpZihldnQucmVsYXRlZC5jbGFzc0xpc3QuY29udGFpbnMoXCJzb3J0YWJsZS1maXhlZFwiKSl7XHJcbiAgICAgICAgICAgICAgICAvL2NvbnNvbGUubG9nKGV2dC5yZWxhdGVkKTtcclxuICAgICAgICAgICAgICAgIHJldHVybiBmYWxzZTtcclxuICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgfSldLFxyXG4gICAgZGVjbGFyYXRpb25zOiBbLi4uQkFTSUNfV0lER0VUUywgT3JkZXJhYmxlRGlyZWN0aXZlLEVsZW1lbnRBdHRyaWJ1dGVEaXJlY3RpdmVdLFxyXG4gICAgZXhwb3J0czogWy4uLkJBU0lDX1dJREdFVFMsIE9yZGVyYWJsZURpcmVjdGl2ZSxFbGVtZW50QXR0cmlidXRlRGlyZWN0aXZlXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgV2lkZ2V0TGlicmFyeU1vZHVsZSB7XHJcbn1cclxuIl19