@bravobit/bb-foundation 0.21.5 → 0.21.6

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.
@@ -0,0 +1,9 @@
1
+ import { BehaviorSubject } from 'rxjs';
2
+ import * as i0 from "@angular/core";
3
+ export declare class BbFormSubmitter {
4
+ submitted$: BehaviorSubject<boolean>;
5
+ submit(): void;
6
+ reset(): void;
7
+ static ɵfac: i0.ɵɵFactoryDeclaration<BbFormSubmitter, never>;
8
+ static ɵdir: i0.ɵɵDirectiveDeclaration<BbFormSubmitter, "[bbFormSubmitter]", ["bbFormSubmitter"], {}, {}, never, never, false>;
9
+ }
@@ -3,33 +3,34 @@ import * as i0 from "@angular/core";
3
3
  import * as i1 from "./directives/template.directive";
4
4
  import * as i2 from "./form-error/form-error.component";
5
5
  import * as i3 from "./directives/form-submit.directive";
6
- import * as i4 from "./directives/input.directive";
7
- import * as i5 from "./directives/focus.directive";
8
- import * as i6 from "./directives/focus-trap.directive";
9
- import * as i7 from "./directives/autosize.directive";
10
- import * as i8 from "./directives/addon.directive";
11
- import * as i9 from "./pipes/file-size.pipe";
12
- import * as i10 from "./pipes/file-image.pipe";
13
- import * as i11 from "./pipes/relative-time.pipe";
14
- import * as i12 from "./button/button.component";
15
- import * as i13 from "./spinner/spinner.component";
16
- import * as i14 from "./icon/icon.component";
17
- import * as i15 from "./form-control/form-control.component";
18
- import * as i16 from "./form-group/form-group.component";
19
- import * as i17 from "./checkbox/checkbox.component";
20
- import * as i18 from "./dropdown/dropdown.component";
21
- import * as i19 from "./tag/tag.component";
22
- import * as i20 from "./avatar/avatar.component";
23
- import * as i21 from "./file-picker/file-picker.component";
24
- import * as i22 from "./image-picker/image-picker.component";
25
- import * as i23 from "./date-picker/date-picker.component";
26
- import * as i24 from "@angular/common";
27
- import * as i25 from "@angular/forms";
28
- import * as i26 from "@bravobit/bb-foundation/localize";
6
+ import * as i4 from "./directives/form-submitter.directive";
7
+ import * as i5 from "./directives/input.directive";
8
+ import * as i6 from "./directives/focus.directive";
9
+ import * as i7 from "./directives/focus-trap.directive";
10
+ import * as i8 from "./directives/autosize.directive";
11
+ import * as i9 from "./directives/addon.directive";
12
+ import * as i10 from "./pipes/file-size.pipe";
13
+ import * as i11 from "./pipes/file-image.pipe";
14
+ import * as i12 from "./pipes/relative-time.pipe";
15
+ import * as i13 from "./button/button.component";
16
+ import * as i14 from "./spinner/spinner.component";
17
+ import * as i15 from "./icon/icon.component";
18
+ import * as i16 from "./form-control/form-control.component";
19
+ import * as i17 from "./form-group/form-group.component";
20
+ import * as i18 from "./checkbox/checkbox.component";
21
+ import * as i19 from "./dropdown/dropdown.component";
22
+ import * as i20 from "./tag/tag.component";
23
+ import * as i21 from "./avatar/avatar.component";
24
+ import * as i22 from "./file-picker/file-picker.component";
25
+ import * as i23 from "./image-picker/image-picker.component";
26
+ import * as i24 from "./date-picker/date-picker.component";
27
+ import * as i25 from "@angular/common";
28
+ import * as i26 from "@angular/forms";
29
+ import * as i27 from "@bravobit/bb-foundation/localize";
29
30
  export declare class ElementsModule {
30
31
  static forRoot(): ModuleWithProviders<ElementsModule>;
31
32
  static ɵfac: i0.ɵɵFactoryDeclaration<ElementsModule, never>;
32
- static ɵmod: i0.ɵɵNgModuleDeclaration<ElementsModule, [typeof i1.BbTemplate, typeof i2.BbFormError, typeof i3.BbFormSubmit, typeof i4.BbInput, typeof i4.BbSelect, typeof i5.BbFocus, typeof i6.BbFocusTrap, typeof i7.BbAutosize, typeof i8.BbPrefix, typeof i8.BbSuffix, typeof i9.BbFileSize, typeof i10.BbFileImage, typeof i11.BbRelativeTime, typeof i12.BbButton, typeof i12.BbAnchor, typeof i13.BbSpinner, typeof i14.BbIcon, typeof i15.BbFormControl, typeof i16.BbFormGroup, typeof i17.BbCheckbox, typeof i18.BbDropdown, typeof i18.BbDropdownItem, typeof i19.BbTag, typeof i20.BbAvatar, typeof i21.BbFilePicker, typeof i22.BbImagePicker, typeof i23.BbDatePicker], [typeof i24.CommonModule, typeof i25.ReactiveFormsModule, typeof i26.LocalizeModule], [typeof i1.BbTemplate, typeof i2.BbFormError, typeof i3.BbFormSubmit, typeof i4.BbInput, typeof i4.BbSelect, typeof i5.BbFocus, typeof i6.BbFocusTrap, typeof i7.BbAutosize, typeof i8.BbPrefix, typeof i8.BbSuffix, typeof i9.BbFileSize, typeof i10.BbFileImage, typeof i11.BbRelativeTime, typeof i12.BbButton, typeof i12.BbAnchor, typeof i13.BbSpinner, typeof i14.BbIcon, typeof i15.BbFormControl, typeof i16.BbFormGroup, typeof i17.BbCheckbox, typeof i18.BbDropdown, typeof i18.BbDropdownItem, typeof i19.BbTag, typeof i20.BbAvatar, typeof i21.BbFilePicker, typeof i22.BbImagePicker, typeof i23.BbDatePicker]>;
33
+ static ɵmod: i0.ɵɵNgModuleDeclaration<ElementsModule, [typeof i1.BbTemplate, typeof i2.BbFormError, typeof i3.BbFormSubmit, typeof i4.BbFormSubmitter, typeof i5.BbInput, typeof i5.BbSelect, typeof i6.BbFocus, typeof i7.BbFocusTrap, typeof i8.BbAutosize, typeof i9.BbPrefix, typeof i9.BbSuffix, typeof i10.BbFileSize, typeof i11.BbFileImage, typeof i12.BbRelativeTime, typeof i13.BbButton, typeof i13.BbAnchor, typeof i14.BbSpinner, typeof i15.BbIcon, typeof i16.BbFormControl, typeof i17.BbFormGroup, typeof i18.BbCheckbox, typeof i19.BbDropdown, typeof i19.BbDropdownItem, typeof i20.BbTag, typeof i21.BbAvatar, typeof i22.BbFilePicker, typeof i23.BbImagePicker, typeof i24.BbDatePicker], [typeof i25.CommonModule, typeof i26.ReactiveFormsModule, typeof i27.LocalizeModule], [typeof i1.BbTemplate, typeof i2.BbFormError, typeof i3.BbFormSubmit, typeof i4.BbFormSubmitter, typeof i5.BbInput, typeof i5.BbSelect, typeof i6.BbFocus, typeof i7.BbFocusTrap, typeof i8.BbAutosize, typeof i9.BbPrefix, typeof i9.BbSuffix, typeof i10.BbFileSize, typeof i11.BbFileImage, typeof i12.BbRelativeTime, typeof i13.BbButton, typeof i13.BbAnchor, typeof i14.BbSpinner, typeof i15.BbIcon, typeof i16.BbFormControl, typeof i17.BbFormGroup, typeof i18.BbCheckbox, typeof i19.BbDropdown, typeof i19.BbDropdownItem, typeof i20.BbTag, typeof i21.BbAvatar, typeof i22.BbFilePicker, typeof i23.BbImagePicker, typeof i24.BbDatePicker]>;
33
34
  static ɵinj: i0.ɵɵInjectorDeclaration<ElementsModule>;
34
35
  }
35
36
  export declare const ELEMENTS_MATERIAL_ICON: {
@@ -1,13 +1,15 @@
1
1
  import { EventEmitter, OnInit } from '@angular/core';
2
+ import { BbFormSubmitter } from '../directives/form-submitter.directive';
2
3
  import { ElementsError } from '../elements.interfaces';
3
4
  import { BbFormSubmit } from '../directives/form-submit.directive';
4
5
  import { NgControl } from '@angular/forms';
5
6
  import { Observable } from 'rxjs';
6
7
  import * as i0 from "@angular/core";
7
8
  export declare class BbFormError implements OnInit {
8
- private _form;
9
- private _control;
10
- private _errors;
9
+ private _form?;
10
+ private _control?;
11
+ private _formSubmitter?;
12
+ private _errors?;
11
13
  set control(value: NgControl);
12
14
  get control(): NgControl;
13
15
  errorChange: EventEmitter<{
@@ -19,11 +21,13 @@ export declare class BbFormError implements OnInit {
19
21
  data?: any;
20
22
  } | null>;
21
23
  private _ngControl;
22
- constructor(_form: BbFormSubmit, _control: NgControl, _errors: ElementsError[]);
24
+ constructor(_form?: BbFormSubmit, _control?: NgControl, _formSubmitter?: BbFormSubmitter, _errors?: ElementsError[]);
23
25
  ngOnInit(): void;
24
26
  private getError;
25
27
  private submitStatusChanges;
28
+ private getNativeFormSubmit;
29
+ private getManualFormSubmit;
26
30
  private statusChanges;
27
- static ɵfac: i0.ɵɵFactoryDeclaration<BbFormError, [{ optional: true; }, { optional: true; }, { optional: true; }]>;
31
+ static ɵfac: i0.ɵɵFactoryDeclaration<BbFormError, [{ optional: true; }, { optional: true; }, { optional: true; }, { optional: true; }]>;
28
32
  static ɵcmp: i0.ɵɵComponentDeclaration<BbFormError, "bb-form-error", never, { "control": "control"; }, { "errorChange": "errorChange"; }, never, never, false>;
29
33
  }
@@ -3,6 +3,7 @@ export * from './lib/directives/template.directive';
3
3
  export * from './lib/directives/focus.directive';
4
4
  export * from './lib/directives/focus-trap.directive';
5
5
  export * from './lib/directives/form-submit.directive';
6
+ export * from './lib/directives/form-submitter.directive';
6
7
  export * from './lib/directives/input.directive';
7
8
  export * from './lib/directives/autosize.directive';
8
9
  export * from './lib/directives/addon.directive';
@@ -0,0 +1,25 @@
1
+ import { Directive } from '@angular/core';
2
+ import { BehaviorSubject } from 'rxjs';
3
+ import * as i0 from "@angular/core";
4
+ export class BbFormSubmitter {
5
+ constructor() {
6
+ // State.
7
+ this.submitted$ = new BehaviorSubject(false);
8
+ }
9
+ submit() {
10
+ this.submitted$.next(true);
11
+ }
12
+ reset() {
13
+ this.submitted$.next(false);
14
+ }
15
+ }
16
+ BbFormSubmitter.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.5", ngImport: i0, type: BbFormSubmitter, deps: [], target: i0.ɵɵFactoryTarget.Directive });
17
+ BbFormSubmitter.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.5", type: BbFormSubmitter, selector: "[bbFormSubmitter]", exportAs: ["bbFormSubmitter"], ngImport: i0 });
18
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.5", ngImport: i0, type: BbFormSubmitter, decorators: [{
19
+ type: Directive,
20
+ args: [{
21
+ selector: '[bbFormSubmitter]',
22
+ exportAs: 'bbFormSubmitter'
23
+ }]
24
+ }] });
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1zdWJtaXR0ZXIuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmItZm91bmRhdGlvbi9lbGVtZW50cy9zcmMvbGliL2RpcmVjdGl2ZXMvZm9ybS1zdWJtaXR0ZXIuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDeEMsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLE1BQU0sQ0FBQzs7QUFNckMsTUFBTSxPQUFPLGVBQWU7SUFKNUI7UUFNSSxTQUFTO1FBQ1QsZUFBVSxHQUFHLElBQUksZUFBZSxDQUFVLEtBQUssQ0FBQyxDQUFDO0tBVXBEO0lBUkcsTUFBTTtRQUNGLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQy9CLENBQUM7SUFFRCxLQUFLO1FBQ0QsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDaEMsQ0FBQzs7NEdBWFEsZUFBZTtnR0FBZixlQUFlOzJGQUFmLGVBQWU7a0JBSjNCLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLG1CQUFtQjtvQkFDN0IsUUFBUSxFQUFFLGlCQUFpQjtpQkFDOUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0RpcmVjdGl2ZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0JlaGF2aW9yU3ViamVjdH0gZnJvbSAncnhqcyc7XG5cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnW2JiRm9ybVN1Ym1pdHRlcl0nLFxuICAgIGV4cG9ydEFzOiAnYmJGb3JtU3VibWl0dGVyJ1xufSlcbmV4cG9ydCBjbGFzcyBCYkZvcm1TdWJtaXR0ZXIge1xuXG4gICAgLy8gU3RhdGUuXG4gICAgc3VibWl0dGVkJCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8Ym9vbGVhbj4oZmFsc2UpO1xuXG4gICAgc3VibWl0KCkge1xuICAgICAgICB0aGlzLnN1Ym1pdHRlZCQubmV4dCh0cnVlKTtcbiAgICB9XG5cbiAgICByZXNldCgpIHtcbiAgICAgICAgdGhpcy5zdWJtaXR0ZWQkLm5leHQoZmFsc2UpO1xuICAgIH1cblxufVxuIl19
@@ -1,5 +1,6 @@
1
1
  import { BbDropdown, BbDropdownItem } from './dropdown/dropdown.component';
2
2
  import { ELEMENTS_ERRORS, ELEMENTS_ICONS } from './elements.interfaces';
3
+ import { BbFormSubmitter } from './directives/form-submitter.directive';
3
4
  import { BbImagePicker } from './image-picker/image-picker.component';
4
5
  import { BbFormControl } from './form-control/form-control.component';
5
6
  import { BbFilePicker } from './file-picker/file-picker.component';
@@ -32,6 +33,7 @@ const DECLARATIONS_EXPORTS = [
32
33
  BbTemplate,
33
34
  BbFormError,
34
35
  BbFormSubmit,
36
+ BbFormSubmitter,
35
37
  BbInput,
36
38
  BbSelect,
37
39
  BbFocus,
@@ -76,6 +78,7 @@ ElementsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version:
76
78
  BbTemplate,
77
79
  BbFormError,
78
80
  BbFormSubmit,
81
+ BbFormSubmitter,
79
82
  BbInput,
80
83
  BbSelect,
81
84
  BbFocus,
@@ -106,6 +109,7 @@ ElementsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version:
106
109
  BbTemplate,
107
110
  BbFormError,
108
111
  BbFormSubmit,
112
+ BbFormSubmitter,
109
113
  BbInput,
110
114
  BbSelect,
111
115
  BbFocus,
@@ -174,4 +178,4 @@ export function getErrors() {
174
178
  };
175
179
  return data;
176
180
  }
177
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elements.module.js","sourceRoot":"","sources":["../../../../../projects/bb-foundation/elements/src/lib/elements.module.ts"],"names":[],"mappings":"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","sourcesContent":["import {BbDropdown, BbDropdownItem} from './dropdown/dropdown.component';\nimport {ELEMENTS_ERRORS, ELEMENTS_ICONS} from './elements.interfaces';\nimport {BbImagePicker} from './image-picker/image-picker.component';\nimport {BbFormControl} from './form-control/form-control.component';\nimport {BbFilePicker} from './file-picker/file-picker.component';\nimport {BbDatePicker} from './date-picker/date-picker.component';\nimport {LocalizeModule} from '@bravobit/bb-foundation/localize';\nimport {BbPrefix, BbSuffix} from './directives/addon.directive';\nimport {BbFormSubmit} from './directives/form-submit.directive';\nimport {BbInput, BbSelect} from './directives/input.directive';\nimport {BbFormGroup} from './form-group/form-group.component';\nimport {BbFormError} from './form-error/form-error.component';\nimport {BbFocusTrap} from './directives/focus-trap.directive';\nimport {BbAnchor, BbButton} from './button/button.component';\nimport {ModuleWithProviders, NgModule} from '@angular/core';\nimport {BbTemplate} from './directives/template.directive';\nimport {BbAutosize} from './directives/autosize.directive';\nimport {BbRelativeTime} from './pipes/relative-time.pipe';\nimport {BbCheckbox} from './checkbox/checkbox.component';\nimport {BbSpinner} from './spinner/spinner.component';\nimport {BbFocus} from './directives/focus.directive';\nimport {BbFileImage} from './pipes/file-image.pipe';\nimport {ReactiveFormsModule} from '@angular/forms';\nimport {BbAvatar} from './avatar/avatar.component';\nimport {BbFileSize} from './pipes/file-size.pipe';\nimport {CommonModule} from '@angular/common';\nimport {BbIcon} from './icon/icon.component';\nimport {BbTag} from './tag/tag.component';\n\nconst DECLARATIONS_EXPORTS = [\n    // Directives.\n    BbTemplate,\n    BbFormError,\n    BbFormSubmit,\n    BbInput,\n    BbSelect,\n    BbFocus,\n    BbFocusTrap,\n    BbAutosize,\n    BbPrefix,\n    BbSuffix,\n    // Pipes.\n    BbFileSize,\n    BbFileImage,\n    BbRelativeTime,\n    // Components.\n    BbButton,\n    BbAnchor,\n    BbSpinner,\n    BbIcon,\n    BbFormControl,\n    BbFormGroup,\n    BbCheckbox,\n    BbDropdown,\n    BbDropdownItem,\n    BbTag,\n    BbAvatar,\n    BbFilePicker,\n    BbImagePicker,\n    BbDatePicker\n];\n\n@NgModule({\n    imports: [CommonModule, ReactiveFormsModule, LocalizeModule],\n    declarations: [...DECLARATIONS_EXPORTS],\n    exports: [...DECLARATIONS_EXPORTS]\n})\nexport class ElementsModule {\n\n    static forRoot(): ModuleWithProviders<ElementsModule> {\n        return {\n            ngModule: ElementsModule,\n            providers: [\n                {provide: ELEMENTS_ERRORS, useFactory: getErrors, multi: true},\n                ELEMENTS_MATERIAL_ICON\n            ]\n        };\n    }\n\n}\n\nexport const ELEMENTS_MATERIAL_ICON = {\n    provide: ELEMENTS_ICONS,\n    useValue: {namespace: 'material', className: 'material-icons', uses: 'content', type: 'font'},\n    multi: true\n};\n\nexport function getErrors() {\n    const data = {\n        unknown: () => 'form-control-errors.unknown',\n        required: () => 'form-control-errors.required',\n        pattern: () => 'form-control-errors.pattern',\n        email: () => 'form-control-errors.email',\n        emailTaken: () => 'form-control-errors.emailTaken',\n        passwordMatch: () => 'form-control-errors.passwordMatch',\n        confirm: () => 'form-control-errors.confirm',\n        fullNumber: () => 'form-control-errors.fullNumber',\n        min: ({min}) => ({token: 'form-control-errors.min', data: {min}}),\n        max: ({max}) => ({token: 'form-control-errors.max', data: {max}}),\n        maxFileSize: ({maxSize}) => ({token: 'form-control-errors.maxFileSize', data: {maxSize}}),\n        minDate: ({date}) => ({token: 'form-control-errors.minDate', data: {date}}),\n        maxDate: ({date}) => ({token: 'form-control-errors.maxDate', data: {date}}),\n        invalidDate: () => 'form-control-errors.invalidDate',\n        invalidFileType: () => 'form-control-errors.invalidFileType',\n        minlength: ({requiredLength, actualLength}) => ({\n            token: 'form-control-errors.minlength',\n            data: {requiredLength, actualLength}\n        }),\n        maxlength: ({requiredLength, actualLength}) => ({\n            token: 'form-control-errors.maxlength',\n            data: {requiredLength, actualLength}\n        })\n    };\n\n    return data;\n}\n"]}
181
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elements.module.js","sourceRoot":"","sources":["../../../../../projects/bb-foundation/elements/src/lib/elements.module.ts"],"names":[],"mappings":"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","sourcesContent":["import {BbDropdown, BbDropdownItem} from './dropdown/dropdown.component';\nimport {ELEMENTS_ERRORS, ELEMENTS_ICONS} from './elements.interfaces';\nimport {BbFormSubmitter} from './directives/form-submitter.directive';\nimport {BbImagePicker} from './image-picker/image-picker.component';\nimport {BbFormControl} from './form-control/form-control.component';\nimport {BbFilePicker} from './file-picker/file-picker.component';\nimport {BbDatePicker} from './date-picker/date-picker.component';\nimport {LocalizeModule} from '@bravobit/bb-foundation/localize';\nimport {BbPrefix, BbSuffix} from './directives/addon.directive';\nimport {BbFormSubmit} from './directives/form-submit.directive';\nimport {BbInput, BbSelect} from './directives/input.directive';\nimport {BbFormGroup} from './form-group/form-group.component';\nimport {BbFormError} from './form-error/form-error.component';\nimport {BbFocusTrap} from './directives/focus-trap.directive';\nimport {BbAnchor, BbButton} from './button/button.component';\nimport {ModuleWithProviders, NgModule} from '@angular/core';\nimport {BbTemplate} from './directives/template.directive';\nimport {BbAutosize} from './directives/autosize.directive';\nimport {BbRelativeTime} from './pipes/relative-time.pipe';\nimport {BbCheckbox} from './checkbox/checkbox.component';\nimport {BbSpinner} from './spinner/spinner.component';\nimport {BbFocus} from './directives/focus.directive';\nimport {BbFileImage} from './pipes/file-image.pipe';\nimport {ReactiveFormsModule} from '@angular/forms';\nimport {BbAvatar} from './avatar/avatar.component';\nimport {BbFileSize} from './pipes/file-size.pipe';\nimport {CommonModule} from '@angular/common';\nimport {BbIcon} from './icon/icon.component';\nimport {BbTag} from './tag/tag.component';\n\nconst DECLARATIONS_EXPORTS = [\n    // Directives.\n    BbTemplate,\n    BbFormError,\n    BbFormSubmit,\n    BbFormSubmitter,\n    BbInput,\n    BbSelect,\n    BbFocus,\n    BbFocusTrap,\n    BbAutosize,\n    BbPrefix,\n    BbSuffix,\n    // Pipes.\n    BbFileSize,\n    BbFileImage,\n    BbRelativeTime,\n    // Components.\n    BbButton,\n    BbAnchor,\n    BbSpinner,\n    BbIcon,\n    BbFormControl,\n    BbFormGroup,\n    BbCheckbox,\n    BbDropdown,\n    BbDropdownItem,\n    BbTag,\n    BbAvatar,\n    BbFilePicker,\n    BbImagePicker,\n    BbDatePicker\n];\n\n@NgModule({\n    imports: [CommonModule, ReactiveFormsModule, LocalizeModule],\n    declarations: [...DECLARATIONS_EXPORTS],\n    exports: [...DECLARATIONS_EXPORTS]\n})\nexport class ElementsModule {\n\n    static forRoot(): ModuleWithProviders<ElementsModule> {\n        return {\n            ngModule: ElementsModule,\n            providers: [\n                {provide: ELEMENTS_ERRORS, useFactory: getErrors, multi: true},\n                ELEMENTS_MATERIAL_ICON\n            ]\n        };\n    }\n\n}\n\nexport const ELEMENTS_MATERIAL_ICON = {\n    provide: ELEMENTS_ICONS,\n    useValue: {namespace: 'material', className: 'material-icons', uses: 'content', type: 'font'},\n    multi: true\n};\n\nexport function getErrors() {\n    const data = {\n        unknown: () => 'form-control-errors.unknown',\n        required: () => 'form-control-errors.required',\n        pattern: () => 'form-control-errors.pattern',\n        email: () => 'form-control-errors.email',\n        emailTaken: () => 'form-control-errors.emailTaken',\n        passwordMatch: () => 'form-control-errors.passwordMatch',\n        confirm: () => 'form-control-errors.confirm',\n        fullNumber: () => 'form-control-errors.fullNumber',\n        min: ({min}) => ({token: 'form-control-errors.min', data: {min}}),\n        max: ({max}) => ({token: 'form-control-errors.max', data: {max}}),\n        maxFileSize: ({maxSize}) => ({token: 'form-control-errors.maxFileSize', data: {maxSize}}),\n        minDate: ({date}) => ({token: 'form-control-errors.minDate', data: {date}}),\n        maxDate: ({date}) => ({token: 'form-control-errors.maxDate', data: {date}}),\n        invalidDate: () => 'form-control-errors.invalidDate',\n        invalidFileType: () => 'form-control-errors.invalidFileType',\n        minlength: ({requiredLength, actualLength}) => ({\n            token: 'form-control-errors.minlength',\n            data: {requiredLength, actualLength}\n        }),\n        maxlength: ({requiredLength, actualLength}) => ({\n            token: 'form-control-errors.maxlength',\n            data: {requiredLength, actualLength}\n        })\n    };\n\n    return data;\n}\n"]}
@@ -5,12 +5,14 @@ import { combineLatest, EMPTY, of } from 'rxjs';
5
5
  import * as i0 from "@angular/core";
6
6
  import * as i1 from "../directives/form-submit.directive";
7
7
  import * as i2 from "@angular/forms";
8
- import * as i3 from "@angular/common";
9
- import * as i4 from "@bravobit/bb-foundation/localize";
8
+ import * as i3 from "../directives/form-submitter.directive";
9
+ import * as i4 from "@angular/common";
10
+ import * as i5 from "@bravobit/bb-foundation/localize";
10
11
  export class BbFormError {
11
- constructor(_form, _control, _errors) {
12
+ constructor(_form, _control, _formSubmitter, _errors) {
12
13
  this._form = _form;
13
14
  this._control = _control;
15
+ this._formSubmitter = _formSubmitter;
14
16
  this._errors = _errors;
15
17
  // Outputs.
16
18
  this.errorChange = new EventEmitter();
@@ -69,11 +71,22 @@ export class BbFormError {
69
71
  return errorFunction(error);
70
72
  }
71
73
  submitStatusChanges() {
74
+ const native$ = this.getNativeFormSubmit();
75
+ const manual$ = this.getManualFormSubmit();
76
+ return combineLatest([native$, manual$]).pipe(map(([native, manual]) => native || manual), distinctUntilChanged());
77
+ }
78
+ getNativeFormSubmit() {
72
79
  if (!this._form) {
73
80
  return of(true);
74
81
  }
75
82
  return this._form.submitStatus$;
76
83
  }
84
+ getManualFormSubmit() {
85
+ if (!this._formSubmitter) {
86
+ return of(false);
87
+ }
88
+ return this._formSubmitter.submitted$.pipe(distinctUntilChanged());
89
+ }
77
90
  statusChanges() {
78
91
  if (!this.control) {
79
92
  return EMPTY;
@@ -84,8 +97,8 @@ export class BbFormError {
84
97
  return this.control.statusChanges.pipe(startWith(this.control.status), delay(0));
85
98
  }
86
99
  }
87
- BbFormError.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.5", ngImport: i0, type: BbFormError, deps: [{ token: i1.BbFormSubmit, optional: true }, { token: i2.NgControl, optional: true }, { token: ELEMENTS_ERRORS, optional: true }], target: i0.ɵɵFactoryTarget.Component });
88
- BbFormError.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.5", type: BbFormError, selector: "bb-form-error", inputs: { control: "control" }, outputs: { errorChange: "errorChange" }, host: { classAttribute: "bb-form-error" }, ngImport: i0, template: "<ng-container *ngIf=\"error$ | async as error\">\n <p *ngIf=\"error?.token | bbLocalize:{optional: true, data: error?.data} as message\"\n class=\"bb-form-error-message\">\n {{ message }}\n </p>\n</ng-container>", styles: [".bb-form-error{display:block}.bb-form-error-message{color:#c23934;display:block;font-size:13px;margin-top:4px}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.BbLocalize, name: "bbLocalize" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
100
+ BbFormError.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.5", ngImport: i0, type: BbFormError, deps: [{ token: i1.BbFormSubmit, optional: true }, { token: i2.NgControl, optional: true }, { token: i3.BbFormSubmitter, optional: true }, { token: ELEMENTS_ERRORS, optional: true }], target: i0.ɵɵFactoryTarget.Component });
101
+ BbFormError.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.5", type: BbFormError, selector: "bb-form-error", inputs: { control: "control" }, outputs: { errorChange: "errorChange" }, host: { classAttribute: "bb-form-error" }, ngImport: i0, template: "<ng-container *ngIf=\"error$ | async as error\">\n <p *ngIf=\"error?.token | bbLocalize:{optional: true, data: error?.data} as message\"\n class=\"bb-form-error-message\">\n {{ message }}\n </p>\n</ng-container>", styles: [".bb-form-error{display:block}.bb-form-error-message{color:#c23934;display:block;font-size:13px;margin-top:4px}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i5.BbLocalize, name: "bbLocalize" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
89
102
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.5", ngImport: i0, type: BbFormError, decorators: [{
90
103
  type: Component,
91
104
  args: [{ selector: 'bb-form-error', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: {
@@ -95,6 +108,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.5", ngImpor
95
108
  type: Optional
96
109
  }] }, { type: i2.NgControl, decorators: [{
97
110
  type: Optional
111
+ }] }, { type: i3.BbFormSubmitter, decorators: [{
112
+ type: Optional
98
113
  }] }, { type: undefined, decorators: [{
99
114
  type: Optional
100
115
  }, {
@@ -105,4 +120,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.5", ngImpor
105
120
  }], errorChange: [{
106
121
  type: Output
107
122
  }] } });
108
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-error.component.js","sourceRoot":"","sources":["../../../../../../projects/bb-foundation/elements/src/lib/form-error/form-error.component.ts","../../../../../../projects/bb-foundation/elements/src/lib/form-error/form-error.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    Inject,\n    Input,\n    OnInit,\n    Optional,\n    Output,\n    ViewEncapsulation\n} from '@angular/core';\nimport {delay, distinctUntilChanged, map, startWith, tap} from 'rxjs/operators';\nimport {ELEMENTS_ERRORS, ElementsError} from '../elements.interfaces';\nimport {BbFormSubmit} from '../directives/form-submit.directive';\nimport {NgControl, ValidationErrors} from '@angular/forms';\nimport {combineLatest, EMPTY, Observable, of} from 'rxjs';\n\n@Component({\n    selector: 'bb-form-error',\n    templateUrl: './form-error.component.html',\n    styleUrls: ['./form-error.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    host: {\n        'class': 'bb-form-error'\n    },\n    preserveWhitespaces: false\n})\nexport class BbFormError implements OnInit {\n\n    // Inputs.\n    @Input()\n    set control(value: NgControl) {\n        this._ngControl = value;\n    }\n\n    get control() {\n        return this._ngControl;\n    }\n\n    // Outputs.\n    @Output() errorChange = new EventEmitter<{ token: string, data?: any } | null>();\n\n    // State.\n    error$: Observable<{ token: string, data?: any } | null>;\n\n    // Subscriptions.\n    private _ngControl: NgControl | null = null;\n\n    constructor(@Optional() private _form: BbFormSubmit,\n                @Optional() private _control: NgControl,\n                @Optional() @Inject(ELEMENTS_ERRORS) private _errors: ElementsError[]) {\n    }\n\n    ngOnInit() {\n        // Set the control if it was not set before.\n        if (!this.control) {\n            this.control = this._control;\n        }\n\n        // Listen for the submit changes\n        const submitStatus$ = this.submitStatusChanges();\n\n        // An observable that emits error changes.\n        const errorChanges$ = this.statusChanges().pipe(\n            map(() => this.getError(this.control.errors)),\n            distinctUntilChanged(),\n            map(error => typeof error === 'string' ? {token: error} : error)\n        );\n\n        // Whenever the user submitted the form we want to\n        // listen for any error changes.\n        this.error$ = combineLatest([submitStatus$, errorChanges$]).pipe(\n            map(([submitted, error]) => {\n                // If not submitted return null.\n                if (!submitted) {\n                    return null;\n                }\n\n                // Return the error if submitted.\n                return error;\n            }),\n            tap(value => this.errorChange.emit(value))\n        );\n    }\n\n    private getError(errors?: ValidationErrors) {\n        // Validate the errors exist.\n        if (!errors) {\n            return null;\n        }\n\n        // Get the first error in the errors.\n        const [errorName] = Object.keys(errors);\n        const error = errors[errorName];\n\n        // Validate the error exists.\n        if (!error) {\n            return null;\n        }\n\n        // Map the arrays into a object so we can\n        // access the functions by a key-lookup.\n        const errorFunctions = this._errors.reduce((previous, current) => ({...previous, ...current}), {});\n\n        // Get the error function.\n        const errorFunction = errorFunctions[errorName] || errorFunctions['unknown'];\n\n        // Validate the error function exists.\n        if (!errorFunction) {\n            return null;\n        }\n\n        // Return the parsed error.\n        return errorFunction(error);\n    }\n\n    private submitStatusChanges() {\n        if (!this._form) {\n            return of(true);\n        }\n\n        return this._form.submitStatus$;\n    }\n\n    private statusChanges() {\n        if (!this.control) {\n            return EMPTY;\n        }\n\n        if (!this.control.statusChanges) {\n            return EMPTY;\n        }\n\n        return this.control.statusChanges.pipe(\n            startWith(this.control.status as unknown),\n            delay(0)\n        );\n    }\n\n}\n","<ng-container *ngIf=\"error$ | async as error\">\n    <p *ngIf=\"error?.token | bbLocalize:{optional: true, data: error?.data} as message\"\n       class=\"bb-form-error-message\">\n        {{ message }}\n    </p>\n</ng-container>"]}
123
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-error.component.js","sourceRoot":"","sources":["../../../../../../projects/bb-foundation/elements/src/lib/form-error/form-error.component.ts","../../../../../../projects/bb-foundation/elements/src/lib/form-error/form-error.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    Inject,\n    Input,\n    OnInit,\n    Optional,\n    Output,\n    ViewEncapsulation\n} from '@angular/core';\nimport {delay, distinctUntilChanged, map, startWith, tap} from 'rxjs/operators';\nimport {BbFormSubmitter} from '../directives/form-submitter.directive';\nimport {ELEMENTS_ERRORS, ElementsError} from '../elements.interfaces';\nimport {BbFormSubmit} from '../directives/form-submit.directive';\nimport {NgControl, ValidationErrors} from '@angular/forms';\nimport {combineLatest, EMPTY, Observable, of} from 'rxjs';\n\n@Component({\n    selector: 'bb-form-error',\n    templateUrl: './form-error.component.html',\n    styleUrls: ['./form-error.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    host: {\n        'class': 'bb-form-error'\n    },\n    preserveWhitespaces: false\n})\nexport class BbFormError implements OnInit {\n\n    // Inputs.\n    @Input()\n    set control(value: NgControl) {\n        this._ngControl = value;\n    }\n\n    get control() {\n        return this._ngControl;\n    }\n\n    // Outputs.\n    @Output() errorChange = new EventEmitter<{ token: string, data?: any } | null>();\n\n    // State.\n    error$: Observable<{ token: string, data?: any } | null>;\n\n    // Subscriptions.\n    private _ngControl: NgControl | null = null;\n\n    constructor(@Optional() private _form?: BbFormSubmit,\n                @Optional() private _control?: NgControl,\n                @Optional() private _formSubmitter?: BbFormSubmitter,\n                @Optional() @Inject(ELEMENTS_ERRORS) private _errors?: ElementsError[]) {\n    }\n\n    ngOnInit() {\n        // Set the control if it was not set before.\n        if (!this.control) {\n            this.control = this._control;\n        }\n\n        // Listen for the submit changes\n        const submitStatus$ = this.submitStatusChanges();\n\n        // An observable that emits error changes.\n        const errorChanges$ = this.statusChanges().pipe(\n            map(() => this.getError(this.control.errors)),\n            distinctUntilChanged(),\n            map(error => typeof error === 'string' ? {token: error} : error)\n        );\n\n        // Whenever the user submitted the form we want to\n        // listen for any error changes.\n        this.error$ = combineLatest([submitStatus$, errorChanges$]).pipe(\n            map(([submitted, error]) => {\n                // If not submitted return null.\n                if (!submitted) {\n                    return null;\n                }\n\n                // Return the error if submitted.\n                return error;\n            }),\n            tap(value => this.errorChange.emit(value))\n        );\n    }\n\n    private getError(errors?: ValidationErrors) {\n        // Validate the errors exist.\n        if (!errors) {\n            return null;\n        }\n\n        // Get the first error in the errors.\n        const [errorName] = Object.keys(errors);\n        const error = errors[errorName];\n\n        // Validate the error exists.\n        if (!error) {\n            return null;\n        }\n\n        // Map the arrays into a object so we can\n        // access the functions by a key-lookup.\n        const errorFunctions = this._errors.reduce((previous, current) => ({...previous, ...current}), {});\n\n        // Get the error function.\n        const errorFunction = errorFunctions[errorName] || errorFunctions['unknown'];\n\n        // Validate the error function exists.\n        if (!errorFunction) {\n            return null;\n        }\n\n        // Return the parsed error.\n        return errorFunction(error);\n    }\n\n    private submitStatusChanges() {\n        const native$ = this.getNativeFormSubmit();\n        const manual$ = this.getManualFormSubmit();\n        return combineLatest([native$, manual$]).pipe(\n            map(([native, manual]) => native || manual),\n            distinctUntilChanged()\n        );\n    }\n\n    private getNativeFormSubmit() {\n        if (!this._form) {\n            return of(true);\n        }\n\n        return this._form.submitStatus$;\n    }\n\n    private getManualFormSubmit() {\n        if (!this._formSubmitter) {\n            return of(false);\n        }\n\n        return this._formSubmitter.submitted$.pipe(\n            distinctUntilChanged()\n        );\n    }\n\n    private statusChanges() {\n        if (!this.control) {\n            return EMPTY;\n        }\n\n        if (!this.control.statusChanges) {\n            return EMPTY;\n        }\n\n        return this.control.statusChanges.pipe(\n            startWith(this.control.status as unknown),\n            delay(0)\n        );\n    }\n\n}\n","<ng-container *ngIf=\"error$ | async as error\">\n    <p *ngIf=\"error?.token | bbLocalize:{optional: true, data: error?.data} as message\"\n       class=\"bb-form-error-message\">\n        {{ message }}\n    </p>\n</ng-container>"]}
@@ -3,6 +3,7 @@ export * from './lib/directives/template.directive';
3
3
  export * from './lib/directives/focus.directive';
4
4
  export * from './lib/directives/focus-trap.directive';
5
5
  export * from './lib/directives/form-submit.directive';
6
+ export * from './lib/directives/form-submitter.directive';
6
7
  export * from './lib/directives/input.directive';
7
8
  export * from './lib/directives/autosize.directive';
8
9
  export * from './lib/directives/addon.directive';
@@ -23,4 +24,4 @@ export * from './lib/image-picker/image-picker.component';
23
24
  export * from './lib/date-picker/date-picker.component';
24
25
  export * from './lib/dropdown/dropdown.component';
25
26
  export * from './lib/elements.interfaces';
26
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2JiLWZvdW5kYXRpb24vZWxlbWVudHMvc3JjL3B1YmxpY19hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsa0NBQWtDLENBQUM7QUFDakQsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLHdDQUF3QyxDQUFDO0FBQ3ZELGNBQWMsa0NBQWtDLENBQUM7QUFDakQsY0FBYyxxQ0FBcUMsQ0FBQztBQUNwRCxjQUFjLGtDQUFrQyxDQUFDO0FBQ2pELGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLHVDQUF1QyxDQUFDO0FBQ3RELGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsbUNBQW1DLENBQUM7QUFFbEQsY0FBYywyQkFBMkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL2VsZW1lbnRzLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL3RlbXBsYXRlLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL2ZvY3VzLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL2ZvY3VzLXRyYXAuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpcmVjdGl2ZXMvZm9ybS1zdWJtaXQuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpcmVjdGl2ZXMvaW5wdXQuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpcmVjdGl2ZXMvYXV0b3NpemUuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpcmVjdGl2ZXMvYWRkb24uZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3BpcGVzL2ZpbGUtc2l6ZS5waXBlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3BpcGVzL2ZpbGUtaW1hZ2UucGlwZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9waXBlcy9yZWxhdGl2ZS10aW1lLnBpcGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc3Bpbm5lci9zcGlubmVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9idXR0b24vYnV0dG9uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9pY29uL2ljb24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Zvcm0tY29udHJvbC9mb3JtLWNvbnRyb2wuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Zvcm0tZ3JvdXAvZm9ybS1ncm91cC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZm9ybS1lcnJvci9mb3JtLWVycm9yLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGVja2JveC9jaGVja2JveC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGFnL3RhZy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXZhdGFyL2F2YXRhci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZmlsZS1waWNrZXIvZmlsZS1waWNrZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ltYWdlLXBpY2tlci9pbWFnZS1waWNrZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RhdGUtcGlja2VyL2RhdGUtcGlja2VyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kcm9wZG93bi9kcm9wZG93bi5jb21wb25lbnQnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9lbGVtZW50cy5pbnRlcmZhY2VzJztcbiJdfQ==
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2JiLWZvdW5kYXRpb24vZWxlbWVudHMvc3JjL3B1YmxpY19hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsa0NBQWtDLENBQUM7QUFDakQsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLHdDQUF3QyxDQUFDO0FBQ3ZELGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyxrQ0FBa0MsQ0FBQztBQUNqRCxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsa0NBQWtDLENBQUM7QUFDakQsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsZ0NBQWdDLENBQUM7QUFDL0MsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLHVDQUF1QyxDQUFDO0FBQ3RELGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyxtQ0FBbUMsQ0FBQztBQUVsRCxjQUFjLDJCQUEyQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvZWxlbWVudHMubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpcmVjdGl2ZXMvdGVtcGxhdGUuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpcmVjdGl2ZXMvZm9jdXMuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpcmVjdGl2ZXMvZm9jdXMtdHJhcC5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGlyZWN0aXZlcy9mb3JtLXN1Ym1pdC5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGlyZWN0aXZlcy9mb3JtLXN1Ym1pdHRlci5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGlyZWN0aXZlcy9pbnB1dC5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGlyZWN0aXZlcy9hdXRvc2l6ZS5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGlyZWN0aXZlcy9hZGRvbi5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcGlwZXMvZmlsZS1zaXplLnBpcGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcGlwZXMvZmlsZS1pbWFnZS5waXBlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3BpcGVzL3JlbGF0aXZlLXRpbWUucGlwZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zcGlubmVyL3NwaW5uZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2J1dHRvbi9idXR0b24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ljb24vaWNvbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZm9ybS1jb250cm9sL2Zvcm0tY29udHJvbC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZm9ybS1ncm91cC9mb3JtLWdyb3VwLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9mb3JtLWVycm9yL2Zvcm0tZXJyb3IuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoZWNrYm94L2NoZWNrYm94LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90YWcvdGFnLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hdmF0YXIvYXZhdGFyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWxlLXBpY2tlci9maWxlLXBpY2tlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvaW1hZ2UtcGlja2VyL2ltYWdlLXBpY2tlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGF0ZS1waWNrZXIvZGF0ZS1waWNrZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Ryb3Bkb3duL2Ryb3Bkb3duLmNvbXBvbmVudCc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL2VsZW1lbnRzLmludGVyZmFjZXMnO1xuIl19
@@ -10,7 +10,7 @@ import { mixinDisabled, mixinLoad, mixinGrouped, mixinFocused, mixinReadonly, mi
10
10
  import * as i2 from '@angular/forms';
11
11
  import { NG_VALUE_ACCESSOR, NgControl, NG_VALIDATORS, Validators, FormGroup, FormControl, ReactiveFormsModule } from '@angular/forms';
12
12
  import { map, startWith, distinctUntilChanged, shareReplay, tap, delay } from 'rxjs/operators';
13
- import * as i4 from '@bravobit/bb-foundation/localize';
13
+ import * as i1$2 from '@bravobit/bb-foundation/localize';
14
14
  import { LocalizeModule } from '@bravobit/bb-foundation/localize';
15
15
  import * as i2$1 from '@angular/platform-browser';
16
16
  import { coerceBooleanProperty } from '@angular/cdk/coercion';
@@ -117,6 +117,28 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.5", ngImpor
117
117
  const ELEMENTS_ICONS = new InjectionToken('elements_icons');
118
118
  const ELEMENTS_ERRORS = new InjectionToken('elements_errors');
119
119
 
120
+ class BbFormSubmitter {
121
+ constructor() {
122
+ // State.
123
+ this.submitted$ = new BehaviorSubject(false);
124
+ }
125
+ submit() {
126
+ this.submitted$.next(true);
127
+ }
128
+ reset() {
129
+ this.submitted$.next(false);
130
+ }
131
+ }
132
+ BbFormSubmitter.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.5", ngImport: i0, type: BbFormSubmitter, deps: [], target: i0.ɵɵFactoryTarget.Directive });
133
+ BbFormSubmitter.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.5", type: BbFormSubmitter, selector: "[bbFormSubmitter]", exportAs: ["bbFormSubmitter"], ngImport: i0 });
134
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.5", ngImport: i0, type: BbFormSubmitter, decorators: [{
135
+ type: Directive,
136
+ args: [{
137
+ selector: '[bbFormSubmitter]',
138
+ exportAs: 'bbFormSubmitter'
139
+ }]
140
+ }] });
141
+
120
142
  class BbSpinnerBase {
121
143
  }
122
144
  const BbSpinnerMixinBase = mixinDisabled(BbSpinnerBase);
@@ -372,9 +394,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.5", ngImpor
372
394
  } });
373
395
 
374
396
  class BbFormError {
375
- constructor(_form, _control, _errors) {
397
+ constructor(_form, _control, _formSubmitter, _errors) {
376
398
  this._form = _form;
377
399
  this._control = _control;
400
+ this._formSubmitter = _formSubmitter;
378
401
  this._errors = _errors;
379
402
  // Outputs.
380
403
  this.errorChange = new EventEmitter();
@@ -433,11 +456,22 @@ class BbFormError {
433
456
  return errorFunction(error);
434
457
  }
435
458
  submitStatusChanges() {
459
+ const native$ = this.getNativeFormSubmit();
460
+ const manual$ = this.getManualFormSubmit();
461
+ return combineLatest([native$, manual$]).pipe(map(([native, manual]) => native || manual), distinctUntilChanged());
462
+ }
463
+ getNativeFormSubmit() {
436
464
  if (!this._form) {
437
465
  return of(true);
438
466
  }
439
467
  return this._form.submitStatus$;
440
468
  }
469
+ getManualFormSubmit() {
470
+ if (!this._formSubmitter) {
471
+ return of(false);
472
+ }
473
+ return this._formSubmitter.submitted$.pipe(distinctUntilChanged());
474
+ }
441
475
  statusChanges() {
442
476
  if (!this.control) {
443
477
  return EMPTY;
@@ -448,8 +482,8 @@ class BbFormError {
448
482
  return this.control.statusChanges.pipe(startWith(this.control.status), delay(0));
449
483
  }
450
484
  }
451
- BbFormError.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.5", ngImport: i0, type: BbFormError, deps: [{ token: BbFormSubmit, optional: true }, { token: i2.NgControl, optional: true }, { token: ELEMENTS_ERRORS, optional: true }], target: i0.ɵɵFactoryTarget.Component });
452
- BbFormError.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.5", type: BbFormError, selector: "bb-form-error", inputs: { control: "control" }, outputs: { errorChange: "errorChange" }, host: { classAttribute: "bb-form-error" }, ngImport: i0, template: "<ng-container *ngIf=\"error$ | async as error\">\n <p *ngIf=\"error?.token | bbLocalize:{optional: true, data: error?.data} as message\"\n class=\"bb-form-error-message\">\n {{ message }}\n </p>\n</ng-container>", styles: [".bb-form-error{display:block}.bb-form-error-message{color:#c23934;display:block;font-size:13px;margin-top:4px}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.BbLocalize, name: "bbLocalize" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
485
+ BbFormError.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.5", ngImport: i0, type: BbFormError, deps: [{ token: BbFormSubmit, optional: true }, { token: i2.NgControl, optional: true }, { token: BbFormSubmitter, optional: true }, { token: ELEMENTS_ERRORS, optional: true }], target: i0.ɵɵFactoryTarget.Component });
486
+ BbFormError.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.5", type: BbFormError, selector: "bb-form-error", inputs: { control: "control" }, outputs: { errorChange: "errorChange" }, host: { classAttribute: "bb-form-error" }, ngImport: i0, template: "<ng-container *ngIf=\"error$ | async as error\">\n <p *ngIf=\"error?.token | bbLocalize:{optional: true, data: error?.data} as message\"\n class=\"bb-form-error-message\">\n {{ message }}\n </p>\n</ng-container>", styles: [".bb-form-error{display:block}.bb-form-error-message{color:#c23934;display:block;font-size:13px;margin-top:4px}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i1$2.BbLocalize, name: "bbLocalize" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
453
487
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.5", ngImport: i0, type: BbFormError, decorators: [{
454
488
  type: Component,
455
489
  args: [{ selector: 'bb-form-error', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: {
@@ -460,6 +494,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.5", ngImpor
460
494
  type: Optional
461
495
  }] }, { type: i2.NgControl, decorators: [{
462
496
  type: Optional
497
+ }] }, { type: BbFormSubmitter, decorators: [{
498
+ type: Optional
463
499
  }] }, { type: undefined, decorators: [{
464
500
  type: Optional
465
501
  }, {
@@ -731,7 +767,7 @@ BbFilePicker.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version:
731
767
  useExisting: BbFilePicker,
732
768
  multi: true
733
769
  }
734
- ], queries: [{ propertyName: "extraTemplate", first: true, predicate: ["extra"], descendants: true }], viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<!-- The label of the input. -->\n<label *ngIf=\"label as labelContent\"\n [for]=\"labelId\"\n class=\"bb-file-picker-label\">\n <ng-template [bbTemplate]=\"labelContent\">\n {{ labelContent }}\n </ng-template>\n</label>\n\n<!-- The input that can open the file picker. -->\n<input #fileInput\n [accept]=\"accept\"\n [disabled]=\"disabled\"\n (change)=\"onFileChange($event)\"\n class=\"bb-file-picker-input\"\n type=\"file\"\n tabindex=\"-1\">\n\n<div *ngIf=\"value$ | async as data\"\n class=\"bb-file-picker-wrapper\">\n <!-- The button that accepts files. -->\n <div class=\"bb-file-picker-container\">\n <button [class.destructive]=\"!!data?.file\"\n [class.standalone]=\"!allowDragging\"\n [disabled]=\"disabled\"\n [id]=\"labelId\"\n (click)=\"onButtonPressed(data?.file)\"\n type=\"button\"\n class=\"bb-file-picker-button\">\n <ng-container *ngTemplateOutlet=\"data?.file ? closeIcon : uploadIcon\"></ng-container>\n {{ (data?.file ? 'file-picker.remove' : 'file-picker.choose') | bbLocalize }}\n </button>\n <div *ngIf=\"allowDragging\"\n class=\"bb-file-picker-zone\">\n {{ 'file-picker.drop' | bbLocalize }}\n </div>\n </div>\n\n <ng-container *ngIf=\"!!extraTemplate\">\n <ng-container *ngTemplateOutlet=\"extraTemplate; context: {$implicit: data?.file}\"></ng-container>\n </ng-container>\n\n <ng-container *ngIf=\"showImages\">\n <div *ngIf=\"data?.file | bbFileImage | async as image\"\n class=\"bb-file-picker-image-container\">\n <div class=\"bb-file-picker-image-wrapper\">\n <div [@bbFilePickerImageAnimation]=\"true\"\n [style.padding-top.%]=\"image?.aspectRatio * 100\"\n [style.background-image]=\"image?.background\"\n class=\"bb-file-picker-image\">\n </div>\n </div>\n </div>\n </ng-container>\n\n <!-- Extra information of the file. -->\n <div [class.visible]=\"!!data?.file\"\n class=\"bb-file-picker-info\">\n <span *ngIf=\"data?.file?.name as name\">{{ name }}</span>\n <span *ngIf=\"data?.file?.size as size\">{{ size | bbFileSize }}</span>\n </div>\n</div>\n\n<bb-form-error *ngIf=\"!hideErrors\"\n (errorChange)=\"onErrorChange($event)\">\n</bb-form-error>\n\n<!-- The file picker hint. -->\n<p *ngIf=\"hint as hintContent\"\n class=\"bb-file-picker-hint\">\n <ng-template [bbTemplate]=\"hintContent\">\n {{ hintContent }}\n </ng-template>\n</p>\n\n<!-- Upload icon. -->\n<ng-template #uploadIcon>\n <svg xmlns=\"http://www.w3.org/2000/svg\"\n class=\"bb-file-picker-icon\"\n width=\"24\"\n height=\"24\">\n <path fill=\"currentColor\"\n d=\"M2 12.5C2 9.46 4.46 7 7.5 7H18c2.21 0 4 1.79 4 4s-1.79 4-4 4H9.5a2.5 2.5 0 010-5H17v2H9.41c-.55 0-.55 1 0 1H18c1.1 0 2-.9 2-2s-.9-2-2-2H7.5C5.57 9 4 10.57 4 12.5S5.57 16 7.5 16H17v2H7.5C4.46 18 2 15.54 2 12.5z\"></path>\n <path fill=\"none\" d=\"M0 0h24v24H0V0z\"></path>\n </svg>\n</ng-template>\n\n<!-- Close icon. -->\n<ng-template #closeIcon>\n <svg xmlns=\"http://www.w3.org/2000/svg\"\n class=\"bb-file-picker-icon\"\n width=\"24\"\n height=\"24\">\n <path fill=\"currentColor\"\n d=\"M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z\"></path>\n <path d=\"M0 0h24v24H0z\" fill=\"none\"></path>\n </svg>\n</ng-template>\n", styles: [".bb-file-picker{display:block}.bb-file-picker.disabled>.bb-file-picker-wrapper{cursor:default;background-color:#cccccca3}.bb-file-picker.grouped{margin-bottom:20px}.bb-file-picker.full>.bb-file-picker-wrapper{width:100%}.bb-file-picker:not(.disabled) .bb-file-picker-button{background-color:#fff}.bb-file-picker:not(.disabled):focus>.bb-file-picker-wrapper,.bb-file-picker:not(.disabled).hovered>.bb-file-picker-wrapper{box-shadow:inset 0 3px #b7bcc233,0 6px 6px -6px #0000001a,0 0 0 3px #007bff33}.bb-file-picker.required>.bb-file-picker-label:after{content:\"*\";color:#c23934;font-size:12px;line-height:1.5}.bb-file-picker.error>.bb-file-picker-label{color:#c23934}.bb-file-picker.error>.bb-file-picker-hint{display:none}.bb-file-picker.error>.bb-file-picker-wrapper{border:1px solid #962b26;background-color:#c2393440!important;box-shadow:inset 0 3px #b7bcc233,0 6px 6px -6px #0000001a,0 0 0 3px #c2393466!important}.bb-file-picker.error .bb-file-picker-button{background-color:transparent}.bb-file-picker-wrapper{max-width:100%;-webkit-user-select:none;user-select:none;border-radius:3px;display:inline-flex;flex-direction:column;border:1px solid #b6bbc1;background-color:#fff8ff;transition:box-shadow .2s cubic-bezier(0,0,.2,1);box-shadow:inset 0 3px #b7bcc233,0 6px 6px -6px #0000001a}.bb-file-picker-label{color:#000;display:block;position:relative;margin-bottom:4px}.bb-file-picker-input{opacity:0;z-index:-1;width:.1px;height:.1px;overflow:hidden;position:absolute}.bb-file-picker-container{min-height:38px;display:inline-flex}.bb-file-picker-button{margin:0;z-index:1;border:none;color:#2196f3;line-height:1;cursor:pointer;padding:0 12px;-webkit-appearance:none;appearance:none;font-weight:500;align-items:center;white-space:nowrap;display:inline-flex;border-top-left-radius:3px;border-bottom-left-radius:3px;border-right:1px solid #b6bbc1;background-color:#ffffff80;transition:box-shadow .2s cubic-bezier(0,0,.2,1)}.bb-file-picker-button:focus{box-shadow:0 0 0 3px #007bff33}.bb-file-picker-button:disabled{cursor:default}.bb-file-picker-button.destructive{color:#f55656}.bb-file-picker-button.standalone{width:100%;border-right:none;border-top-right-radius:3px;border-bottom-right-radius:3px}.bb-file-picker-icon{margin-right:4px}.bb-file-picker-zone{flex:1;color:#848f99;font-size:14px;padding:8px 12px;line-height:18px;align-items:center;display:inline-flex;justify-content:center}.bb-file-picker-info{height:0;color:#848f99;padding:0 12px;overflow:hidden;line-height:36px;align-items:center;display:inline-flex;background-color:#fff8ff;border-top:0 solid #b6bbc1;transition:height .2s cubic-bezier(0,0,.2,1)}.bb-file-picker-info.visible{height:38px;border-top-width:1px}.bb-file-picker-info>span{opacity:.4;max-width:100%;font-size:14px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.bb-file-picker-info>span:first-child{flex:1}.bb-file-picker-info>span:last-child{margin-left:12px}.bb-file-picker-image-container{overflow:hidden;border-top:1px solid #b6bbc1}.bb-file-picker-image-wrapper{width:100%;max-width:40%;margin:20px auto}.bb-file-picker-image{width:100%;display:flex;overflow:hidden;position:relative;border-radius:4px;will-change:opacity;background-size:cover;background-position:center;background-repeat:no-repeat}.bb-file-picker-hint{display:block;color:#738694;font-size:13px;margin-top:4px}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: BbTemplate, selector: "[bbTemplate]", inputs: ["bbTemplate"] }, { kind: "component", type: BbFormError, selector: "bb-form-error", inputs: ["control"], outputs: ["errorChange"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.BbLocalize, name: "bbLocalize" }, { kind: "pipe", type: BbFileSize, name: "bbFileSize" }, { kind: "pipe", type: BbFileImage, name: "bbFileImage" }], animations: [
770
+ ], queries: [{ propertyName: "extraTemplate", first: true, predicate: ["extra"], descendants: true }], viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<!-- The label of the input. -->\n<label *ngIf=\"label as labelContent\"\n [for]=\"labelId\"\n class=\"bb-file-picker-label\">\n <ng-template [bbTemplate]=\"labelContent\">\n {{ labelContent }}\n </ng-template>\n</label>\n\n<!-- The input that can open the file picker. -->\n<input #fileInput\n [accept]=\"accept\"\n [disabled]=\"disabled\"\n (change)=\"onFileChange($event)\"\n class=\"bb-file-picker-input\"\n type=\"file\"\n tabindex=\"-1\">\n\n<div *ngIf=\"value$ | async as data\"\n class=\"bb-file-picker-wrapper\">\n <!-- The button that accepts files. -->\n <div class=\"bb-file-picker-container\">\n <button [class.destructive]=\"!!data?.file\"\n [class.standalone]=\"!allowDragging\"\n [disabled]=\"disabled\"\n [id]=\"labelId\"\n (click)=\"onButtonPressed(data?.file)\"\n type=\"button\"\n class=\"bb-file-picker-button\">\n <ng-container *ngTemplateOutlet=\"data?.file ? closeIcon : uploadIcon\"></ng-container>\n {{ (data?.file ? 'file-picker.remove' : 'file-picker.choose') | bbLocalize }}\n </button>\n <div *ngIf=\"allowDragging\"\n class=\"bb-file-picker-zone\">\n {{ 'file-picker.drop' | bbLocalize }}\n </div>\n </div>\n\n <ng-container *ngIf=\"!!extraTemplate\">\n <ng-container *ngTemplateOutlet=\"extraTemplate; context: {$implicit: data?.file}\"></ng-container>\n </ng-container>\n\n <ng-container *ngIf=\"showImages\">\n <div *ngIf=\"data?.file | bbFileImage | async as image\"\n class=\"bb-file-picker-image-container\">\n <div class=\"bb-file-picker-image-wrapper\">\n <div [@bbFilePickerImageAnimation]=\"true\"\n [style.padding-top.%]=\"image?.aspectRatio * 100\"\n [style.background-image]=\"image?.background\"\n class=\"bb-file-picker-image\">\n </div>\n </div>\n </div>\n </ng-container>\n\n <!-- Extra information of the file. -->\n <div [class.visible]=\"!!data?.file\"\n class=\"bb-file-picker-info\">\n <span *ngIf=\"data?.file?.name as name\">{{ name }}</span>\n <span *ngIf=\"data?.file?.size as size\">{{ size | bbFileSize }}</span>\n </div>\n</div>\n\n<bb-form-error *ngIf=\"!hideErrors\"\n (errorChange)=\"onErrorChange($event)\">\n</bb-form-error>\n\n<!-- The file picker hint. -->\n<p *ngIf=\"hint as hintContent\"\n class=\"bb-file-picker-hint\">\n <ng-template [bbTemplate]=\"hintContent\">\n {{ hintContent }}\n </ng-template>\n</p>\n\n<!-- Upload icon. -->\n<ng-template #uploadIcon>\n <svg xmlns=\"http://www.w3.org/2000/svg\"\n class=\"bb-file-picker-icon\"\n width=\"24\"\n height=\"24\">\n <path fill=\"currentColor\"\n d=\"M2 12.5C2 9.46 4.46 7 7.5 7H18c2.21 0 4 1.79 4 4s-1.79 4-4 4H9.5a2.5 2.5 0 010-5H17v2H9.41c-.55 0-.55 1 0 1H18c1.1 0 2-.9 2-2s-.9-2-2-2H7.5C5.57 9 4 10.57 4 12.5S5.57 16 7.5 16H17v2H7.5C4.46 18 2 15.54 2 12.5z\"></path>\n <path fill=\"none\" d=\"M0 0h24v24H0V0z\"></path>\n </svg>\n</ng-template>\n\n<!-- Close icon. -->\n<ng-template #closeIcon>\n <svg xmlns=\"http://www.w3.org/2000/svg\"\n class=\"bb-file-picker-icon\"\n width=\"24\"\n height=\"24\">\n <path fill=\"currentColor\"\n d=\"M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z\"></path>\n <path d=\"M0 0h24v24H0z\" fill=\"none\"></path>\n </svg>\n</ng-template>\n", styles: [".bb-file-picker{display:block}.bb-file-picker.disabled>.bb-file-picker-wrapper{cursor:default;background-color:#cccccca3}.bb-file-picker.grouped{margin-bottom:20px}.bb-file-picker.full>.bb-file-picker-wrapper{width:100%}.bb-file-picker:not(.disabled) .bb-file-picker-button{background-color:#fff}.bb-file-picker:not(.disabled):focus>.bb-file-picker-wrapper,.bb-file-picker:not(.disabled).hovered>.bb-file-picker-wrapper{box-shadow:inset 0 3px #b7bcc233,0 6px 6px -6px #0000001a,0 0 0 3px #007bff33}.bb-file-picker.required>.bb-file-picker-label:after{content:\"*\";color:#c23934;font-size:12px;line-height:1.5}.bb-file-picker.error>.bb-file-picker-label{color:#c23934}.bb-file-picker.error>.bb-file-picker-hint{display:none}.bb-file-picker.error>.bb-file-picker-wrapper{border:1px solid #962b26;background-color:#c2393440!important;box-shadow:inset 0 3px #b7bcc233,0 6px 6px -6px #0000001a,0 0 0 3px #c2393466!important}.bb-file-picker.error .bb-file-picker-button{background-color:transparent}.bb-file-picker-wrapper{max-width:100%;-webkit-user-select:none;user-select:none;border-radius:3px;display:inline-flex;flex-direction:column;border:1px solid #b6bbc1;background-color:#fff8ff;transition:box-shadow .2s cubic-bezier(0,0,.2,1);box-shadow:inset 0 3px #b7bcc233,0 6px 6px -6px #0000001a}.bb-file-picker-label{color:#000;display:block;position:relative;margin-bottom:4px}.bb-file-picker-input{opacity:0;z-index:-1;width:.1px;height:.1px;overflow:hidden;position:absolute}.bb-file-picker-container{min-height:38px;display:inline-flex}.bb-file-picker-button{margin:0;z-index:1;border:none;color:#2196f3;line-height:1;cursor:pointer;padding:0 12px;-webkit-appearance:none;appearance:none;font-weight:500;align-items:center;white-space:nowrap;display:inline-flex;border-top-left-radius:3px;border-bottom-left-radius:3px;border-right:1px solid #b6bbc1;background-color:#ffffff80;transition:box-shadow .2s cubic-bezier(0,0,.2,1)}.bb-file-picker-button:focus{box-shadow:0 0 0 3px #007bff33}.bb-file-picker-button:disabled{cursor:default}.bb-file-picker-button.destructive{color:#f55656}.bb-file-picker-button.standalone{width:100%;border-right:none;border-top-right-radius:3px;border-bottom-right-radius:3px}.bb-file-picker-icon{margin-right:4px}.bb-file-picker-zone{flex:1;color:#848f99;font-size:14px;padding:8px 12px;line-height:18px;align-items:center;display:inline-flex;justify-content:center}.bb-file-picker-info{height:0;color:#848f99;padding:0 12px;overflow:hidden;line-height:36px;align-items:center;display:inline-flex;background-color:#fff8ff;border-top:0 solid #b6bbc1;transition:height .2s cubic-bezier(0,0,.2,1)}.bb-file-picker-info.visible{height:38px;border-top-width:1px}.bb-file-picker-info>span{opacity:.4;max-width:100%;font-size:14px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.bb-file-picker-info>span:first-child{flex:1}.bb-file-picker-info>span:last-child{margin-left:12px}.bb-file-picker-image-container{overflow:hidden;border-top:1px solid #b6bbc1}.bb-file-picker-image-wrapper{width:100%;max-width:40%;margin:20px auto}.bb-file-picker-image{width:100%;display:flex;overflow:hidden;position:relative;border-radius:4px;will-change:opacity;background-size:cover;background-position:center;background-repeat:no-repeat}.bb-file-picker-hint{display:block;color:#738694;font-size:13px;margin-top:4px}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: BbTemplate, selector: "[bbTemplate]", inputs: ["bbTemplate"] }, { kind: "component", type: BbFormError, selector: "bb-form-error", inputs: ["control"], outputs: ["errorChange"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i1$2.BbLocalize, name: "bbLocalize" }, { kind: "pipe", type: BbFileSize, name: "bbFileSize" }, { kind: "pipe", type: BbFileImage, name: "bbFileImage" }], animations: [
735
771
  trigger('bbFilePickerImageAnimation', [
736
772
  transition(':enter', [
737
773
  style({ opacity: 0 }),
@@ -1508,7 +1544,7 @@ class BbRelativeTime {
1508
1544
  });
1509
1545
  }
1510
1546
  }
1511
- BbRelativeTime.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.5", ngImport: i0, type: BbRelativeTime, deps: [{ token: i4.Localize, optional: true }, { token: LOCALE_ID }], target: i0.ɵɵFactoryTarget.Pipe });
1547
+ BbRelativeTime.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.5", ngImport: i0, type: BbRelativeTime, deps: [{ token: i1$2.Localize, optional: true }, { token: LOCALE_ID }], target: i0.ɵɵFactoryTarget.Pipe });
1512
1548
  BbRelativeTime.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "14.0.5", ngImport: i0, type: BbRelativeTime, name: "bbRelativeTime" });
1513
1549
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.5", ngImport: i0, type: BbRelativeTime, decorators: [{
1514
1550
  type: Pipe,
@@ -1516,7 +1552,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.5", ngImpor
1516
1552
  name: 'bbRelativeTime'
1517
1553
  }]
1518
1554
  }], ctorParameters: function () {
1519
- return [{ type: i4.Localize, decorators: [{
1555
+ return [{ type: i1$2.Localize, decorators: [{
1520
1556
  type: Optional
1521
1557
  }] }, { type: undefined, decorators: [{
1522
1558
  type: Inject,
@@ -1888,6 +1924,7 @@ const DECLARATIONS_EXPORTS = [
1888
1924
  BbTemplate,
1889
1925
  BbFormError,
1890
1926
  BbFormSubmit,
1927
+ BbFormSubmitter,
1891
1928
  BbInput,
1892
1929
  BbSelect,
1893
1930
  BbFocus,
@@ -1932,6 +1969,7 @@ ElementsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version:
1932
1969
  BbTemplate,
1933
1970
  BbFormError,
1934
1971
  BbFormSubmit,
1972
+ BbFormSubmitter,
1935
1973
  BbInput,
1936
1974
  BbSelect,
1937
1975
  BbFocus,
@@ -1963,6 +2001,7 @@ ElementsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version:
1963
2001
  BbTemplate,
1964
2002
  BbFormError,
1965
2003
  BbFormSubmit,
2004
+ BbFormSubmitter,
1966
2005
  BbInput,
1967
2006
  BbSelect,
1968
2007
  BbFocus,
@@ -2037,5 +2076,5 @@ function getErrors() {
2037
2076
  * Generated bundle index. Do not edit.
2038
2077
  */
2039
2078
 
2040
- export { BbAnchor, BbAutosize, BbAvatar, BbButton, BbCheckbox, BbDatePicker, BbDropdown, BbDropdownItem, BbFileImage, BbFilePicker, BbFileSize, BbFocus, BbFocusTrap, BbFormControl, BbFormError, BbFormGroup, BbFormSubmit, BbIcon, BbImagePicker, BbInput, BbPrefix, BbRelativeTime, BbSelect, BbSpinner, BbSuffix, BbTag, BbTemplate, ELEMENTS_ERRORS, ELEMENTS_ICONS, ELEMENTS_MATERIAL_ICON, ElementsModule, getErrors };
2079
+ export { BbAnchor, BbAutosize, BbAvatar, BbButton, BbCheckbox, BbDatePicker, BbDropdown, BbDropdownItem, BbFileImage, BbFilePicker, BbFileSize, BbFocus, BbFocusTrap, BbFormControl, BbFormError, BbFormGroup, BbFormSubmit, BbFormSubmitter, BbIcon, BbImagePicker, BbInput, BbPrefix, BbRelativeTime, BbSelect, BbSpinner, BbSuffix, BbTag, BbTemplate, ELEMENTS_ERRORS, ELEMENTS_ICONS, ELEMENTS_MATERIAL_ICON, ElementsModule, getErrors };
2041
2080
  //# sourceMappingURL=bravobit-bb-foundation-elements.mjs.map