@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.
- package/elements/lib/directives/form-submitter.directive.d.ts +9 -0
- package/elements/lib/elements.module.d.ts +25 -24
- package/elements/lib/form-error/form-error.component.d.ts +9 -5
- package/elements/public_api.d.ts +1 -0
- package/esm2020/elements/lib/directives/form-submitter.directive.mjs +25 -0
- package/esm2020/elements/lib/elements.module.mjs +5 -1
- package/esm2020/elements/lib/form-error/form-error.component.mjs +21 -6
- package/esm2020/elements/public_api.mjs +2 -1
- package/fesm2015/bravobit-bb-foundation-elements.mjs +47 -8
- package/fesm2015/bravobit-bb-foundation-elements.mjs.map +1 -1
- package/fesm2020/bravobit-bb-foundation-elements.mjs +47 -8
- package/fesm2020/bravobit-bb-foundation-elements.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -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/
|
|
7
|
-
import * as i5 from "./directives/
|
|
8
|
-
import * as i6 from "./directives/focus
|
|
9
|
-
import * as i7 from "./directives/
|
|
10
|
-
import * as i8 from "./directives/
|
|
11
|
-
import * as i9 from "./
|
|
12
|
-
import * as i10 from "./pipes/file-
|
|
13
|
-
import * as i11 from "./pipes/
|
|
14
|
-
import * as i12 from "./
|
|
15
|
-
import * as i13 from "./
|
|
16
|
-
import * as i14 from "./
|
|
17
|
-
import * as i15 from "./
|
|
18
|
-
import * as i16 from "./form-
|
|
19
|
-
import * as i17 from "./
|
|
20
|
-
import * as i18 from "./
|
|
21
|
-
import * as i19 from "./
|
|
22
|
-
import * as i20 from "./
|
|
23
|
-
import * as i21 from "./
|
|
24
|
-
import * as i22 from "./
|
|
25
|
-
import * as i23 from "./
|
|
26
|
-
import * as i24 from "
|
|
27
|
-
import * as i25 from "@angular/
|
|
28
|
-
import * as i26 from "@
|
|
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
|
|
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
|
|
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
|
|
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
|
}
|
package/elements/public_api.d.ts
CHANGED
|
@@ -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 "
|
|
9
|
-
import * as i4 from "@
|
|
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:
|
|
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,
|
|
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
|
|
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:
|
|
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:
|
|
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:
|
|
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:
|
|
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
|