@bravobit/bb-foundation 0.16.1 → 0.16.2
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/controls/lib/checkbox/checkbox/checkbox.component.d.ts +47 -0
- package/controls/lib/checkbox/checkbox-group/checkbox-group.component.d.ts +18 -0
- package/controls/lib/checkbox/checkbox.module.d.ts +4 -4
- package/controls/public_api.d.ts +2 -1
- package/esm2020/collections/lib/providers/api-collection.provider.mjs +4 -1
- package/esm2020/controls/lib/checkbox/checkbox/checkbox.component.mjs +153 -0
- package/esm2020/controls/lib/checkbox/checkbox-group/checkbox-group.component.mjs +48 -0
- package/esm2020/controls/lib/checkbox/checkbox.module.mjs +8 -8
- package/esm2020/controls/public_api.mjs +3 -2
- package/esm2020/elements/lib/checkbox/checkbox.component.mjs +2 -2
- package/esm2020/elements/lib/directives/input.directive.mjs +2 -2
- package/esm2020/elements/lib/icon/icon.component.mjs +2 -2
- package/esm2020/lib/core/mixins/can-disable.mjs +2 -2
- package/esm2020/lib/core/mixins/can-hide-errors.mjs +2 -2
- package/esm2020/lib/core/mixins/can-load.mjs +2 -2
- package/esm2020/lib/core/mixins/has-error.mjs +2 -2
- package/esm2020/lib/core/mixins/is-focused.mjs +2 -2
- package/esm2020/lib/core/mixins/is-grouped.mjs +2 -2
- package/esm2020/lib/core/mixins/is-readonly.mjs +2 -2
- package/esm2020/lib/core/mixins/is-required.mjs +2 -2
- package/esm2020/public_api.mjs +1 -2
- package/fesm2015/bravobit-bb-foundation-collections.mjs +3 -0
- package/fesm2015/bravobit-bb-foundation-collections.mjs.map +1 -1
- package/fesm2015/bravobit-bb-foundation-controls.mjs +152 -40
- package/fesm2015/bravobit-bb-foundation-controls.mjs.map +1 -1
- package/fesm2015/bravobit-bb-foundation-elements.mjs +2 -1
- package/fesm2015/bravobit-bb-foundation-elements.mjs.map +1 -1
- package/fesm2015/bravobit-bb-foundation.mjs +2 -5
- package/fesm2015/bravobit-bb-foundation.mjs.map +1 -1
- package/fesm2020/bravobit-bb-foundation-collections.mjs +3 -0
- package/fesm2020/bravobit-bb-foundation-collections.mjs.map +1 -1
- package/fesm2020/bravobit-bb-foundation-controls.mjs +152 -40
- package/fesm2020/bravobit-bb-foundation-controls.mjs.map +1 -1
- package/fesm2020/bravobit-bb-foundation-elements.mjs +2 -1
- package/fesm2020/bravobit-bb-foundation-elements.mjs.map +1 -1
- package/fesm2020/bravobit-bb-foundation.mjs +2 -5
- package/fesm2020/bravobit-bb-foundation.mjs.map +1 -1
- package/package.json +4 -3
- package/public_api.d.ts +0 -1
- package/controls/lib/checkbox/checkbox.component.d.ts +0 -27
- package/esm2020/controls/lib/checkbox/checkbox.component.mjs +0 -86
- package/esm2020/lib/core/coercions/boolean-coercion.mjs +0 -4
- package/lib/core/coercions/boolean-coercion.d.ts +0 -1
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { AfterViewInit, ChangeDetectorRef, ElementRef, EventEmitter, Renderer2 } from '@angular/core';
|
|
2
|
+
import { BooleanInput } from '@angular/cdk/coercion';
|
|
3
|
+
import { ControlValueAccessor } from '@angular/forms';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export declare class BbiCheckbox implements ControlValueAccessor, AfterViewInit {
|
|
6
|
+
private _renderer;
|
|
7
|
+
private _changeDetectorRef;
|
|
8
|
+
readonly labelId: string;
|
|
9
|
+
inputElementRef: ElementRef<HTMLInputElement>;
|
|
10
|
+
checkedChange: EventEmitter<boolean>;
|
|
11
|
+
indeterminateChange: EventEmitter<boolean>;
|
|
12
|
+
get checked(): boolean;
|
|
13
|
+
set checked(value: boolean);
|
|
14
|
+
private _checked;
|
|
15
|
+
get disabled(): unknown;
|
|
16
|
+
set disabled(value: unknown);
|
|
17
|
+
private _disabled;
|
|
18
|
+
get grouped(): unknown;
|
|
19
|
+
set grouped(value: unknown);
|
|
20
|
+
private _grouped;
|
|
21
|
+
get indeterminate(): unknown;
|
|
22
|
+
set indeterminate(value: unknown);
|
|
23
|
+
private _indeterminate;
|
|
24
|
+
get required(): unknown;
|
|
25
|
+
set required(value: unknown);
|
|
26
|
+
private _required;
|
|
27
|
+
onChange: (newValue: boolean) => void;
|
|
28
|
+
onTouched: () => void;
|
|
29
|
+
constructor(_renderer: Renderer2, _changeDetectorRef: ChangeDetectorRef);
|
|
30
|
+
ngAfterViewInit(): void;
|
|
31
|
+
registerOnChange(fn: (newValue: boolean) => void): void;
|
|
32
|
+
registerOnTouched(fn: () => void): void;
|
|
33
|
+
setDisabledState(isDisabled: boolean): void;
|
|
34
|
+
writeValue(newValue: boolean): void;
|
|
35
|
+
toggle(): void;
|
|
36
|
+
onClickEvent(event: Event): void;
|
|
37
|
+
onChangeEvent(event: Event): void;
|
|
38
|
+
private emitChangeEvent;
|
|
39
|
+
private syncField;
|
|
40
|
+
static ngAcceptInputType_checked: BooleanInput;
|
|
41
|
+
static ngAcceptInputType_disabled: BooleanInput;
|
|
42
|
+
static ngAcceptInputType_required: BooleanInput;
|
|
43
|
+
static ngAcceptInputType_grouped: BooleanInput;
|
|
44
|
+
static ngAcceptInputType_indeterminate: BooleanInput;
|
|
45
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<BbiCheckbox, never>;
|
|
46
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<BbiCheckbox, "bbi-checkbox", never, { "checked": "checked"; "disabled": "disabled"; "grouped": "grouped"; "indeterminate": "indeterminate"; "required": "required"; }, { "checkedChange": "checkedChange"; "indeterminateChange": "indeterminateChange"; }, never, ["*"]>;
|
|
47
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { ChangeDetectorRef } from '@angular/core';
|
|
2
|
+
import { BooleanInput } from '@angular/cdk/coercion';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare class BbiCheckboxGroup {
|
|
5
|
+
private _changeDetectorRef;
|
|
6
|
+
label: string | null;
|
|
7
|
+
get grouped(): unknown;
|
|
8
|
+
set grouped(value: unknown);
|
|
9
|
+
private _grouped;
|
|
10
|
+
get required(): unknown;
|
|
11
|
+
set required(value: unknown);
|
|
12
|
+
private _required;
|
|
13
|
+
constructor(_changeDetectorRef: ChangeDetectorRef);
|
|
14
|
+
static ngAcceptInputType_grouped: BooleanInput;
|
|
15
|
+
static ngAcceptInputType_required: BooleanInput;
|
|
16
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<BbiCheckboxGroup, never>;
|
|
17
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<BbiCheckboxGroup, "bbi-checkbox-group", never, { "label": "label"; "grouped": "grouped"; "required": "required"; }, {}, never, ["bbi-checkbox"]>;
|
|
18
|
+
}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import * as i0 from "@angular/core";
|
|
2
|
-
import * as i1 from "./checkbox.component";
|
|
3
|
-
import * as i2 from "
|
|
4
|
-
import * as i3 from "@angular/
|
|
2
|
+
import * as i1 from "./checkbox/checkbox.component";
|
|
3
|
+
import * as i2 from "./checkbox-group/checkbox-group.component";
|
|
4
|
+
import * as i3 from "@angular/common";
|
|
5
5
|
export declare class CheckboxModule {
|
|
6
6
|
static ɵfac: i0.ɵɵFactoryDeclaration<CheckboxModule, never>;
|
|
7
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<CheckboxModule, [typeof i1.BbiCheckbox
|
|
7
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<CheckboxModule, [typeof i1.BbiCheckbox, typeof i2.BbiCheckboxGroup], [typeof i3.CommonModule], [typeof i1.BbiCheckbox, typeof i2.BbiCheckboxGroup]>;
|
|
8
8
|
static ɵinj: i0.ɵɵInjectorDeclaration<CheckboxModule>;
|
|
9
9
|
}
|
package/controls/public_api.d.ts
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
-
export * from './lib/checkbox/checkbox.component';
|
|
1
|
+
export * from './lib/checkbox/checkbox-group/checkbox-group.component';
|
|
2
|
+
export * from './lib/checkbox/checkbox/checkbox.component';
|
|
2
3
|
export * from './lib/checkbox/checkbox.module';
|
|
3
4
|
export * from './lib/controls.module';
|
|
@@ -47,6 +47,9 @@ export class ApiCollectionProvider extends CollectionProvider {
|
|
|
47
47
|
const observables$ = keys.map(key => params?.[key]);
|
|
48
48
|
return combineLatest(observables$).pipe(map(data => {
|
|
49
49
|
return data.reduce((previous, current, index) => {
|
|
50
|
+
if (current === null || current === undefined) {
|
|
51
|
+
return previous;
|
|
52
|
+
}
|
|
50
53
|
const key = keys?.[index];
|
|
51
54
|
return { ...previous, [key]: current };
|
|
52
55
|
}, {});
|
|
@@ -65,4 +68,4 @@ export class ApiCollectionProvider extends CollectionProvider {
|
|
|
65
68
|
};
|
|
66
69
|
}
|
|
67
70
|
}
|
|
68
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
71
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api-collection.provider.js","sourceRoot":"","sources":["../../../../../../projects/bb-foundation/collections/src/lib/providers/api-collection.provider.ts"],"names":[],"mappings":"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","sourcesContent":["import {CollectionApiResponse, CollectionData, CollectionRequest} from '../interfaces/collection.interface';\nimport {combineLatest, isObservable, Observable, of} from 'rxjs';\nimport {CollectionProvider} from './collection.provider';\nimport {HttpClient} from '@angular/common/http';\nimport {map, switchMap} from 'rxjs/operators';\n\nexport class ApiCollectionProvider<T> extends CollectionProvider<T> {\n\n    // State.\n    private _extraParams: { [name: string]: Observable<string | number | boolean | ReadonlyArray<string | number | boolean>> } = {};\n\n    constructor(private readonly _endpoint: string | Observable<string>,\n                private readonly _httpClient: HttpClient) {\n        super();\n    }\n\n    append(name: string, value: string | number | boolean | ReadonlyArray<string | number | boolean> | Observable<string | number | boolean | ReadonlyArray<string | number | boolean>>) {\n        this._extraParams[name] = isObservable(value) ? value : of(value);\n        return this;\n    }\n\n    transform(request: CollectionRequest) {\n        const endpoint$ = isObservable(this._endpoint) ? this._endpoint : of(this._endpoint);\n        const params = this.getBackendFormat(request);\n        const extraParams$ = this.getExtraParams(this._extraParams);\n\n        return combineLatest([endpoint$, extraParams$]).pipe(\n            switchMap(([endpoint, extraParams]) => {\n                return this._httpClient.get<CollectionApiResponse<T> | T[]>(endpoint, {\n                    params: {...params, ...extraParams}\n                });\n            }),\n            map(response => this.formatToCollectionData(response))\n        );\n    }\n\n    private getExtraParams(params: { [name: string]: Observable<string | number | boolean | ReadonlyArray<string | number | boolean>> }) {\n        const keys = Object.keys(params ?? {});\n        if (keys.length <= 0) {\n            return of({});\n        }\n\n        const observables$ = keys.map(key => params?.[key]);\n        return combineLatest(observables$).pipe(\n            map(data => {\n                return data.reduce((previous, current, index) => {\n                    if (current === null || current === undefined) {\n                        return previous;\n                    }\n                    const key = keys?.[index];\n                    return {...previous, [key]: current};\n                }, {});\n            })\n        );\n    }\n\n    private formatToCollectionData(response: CollectionApiResponse<T> | T[]) {\n        if (Array.isArray(response)) {\n            return this.formatArrayToCollectionData(response);\n        }\n\n        return <CollectionData<T>>{\n            pageSize: response?.['page_size'] as number,\n            pageNumber: response?.['page_number'] as number,\n            totalPages: response?.['total_pages'] as number,\n            totalEntries: response?.['total_entries'] as number,\n            data: response?.['data'] as T[]\n        };\n    }\n\n    private getBackendFormat = (request: CollectionRequest) => {\n        const params = {};\n\n        params['page'] = request?.pageNumber ?? 1;\n        params['page_size'] = request?.pageSize ?? 25;\n\n        if (request?.sort) {\n            const sort = Array.isArray(request?.sort) ? request?.sort : [request?.sort];\n            const filteredSort = sort?.filter(item => !!item?.name && !!item?.direction);\n\n            params['sort'] = filteredSort?.map(item => item?.name)?.join(',');\n            params['sort_direction'] = filteredSort?.map(item => item?.direction)?.join(',');\n        }\n\n        if (request?.query && request?.query?.length > 0 && request?.queryFields && request?.queryFields?.length > 0) {\n            params['query'] = request?.query;\n            params['query_fields'] = request?.queryFields?.join(',');\n        }\n\n        return params;\n    };\n\n}\n"]}
|
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core';
|
|
2
|
+
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
3
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
let nextUniqueId = 0;
|
|
6
|
+
export class BbiCheckbox {
|
|
7
|
+
constructor(_renderer, _changeDetectorRef) {
|
|
8
|
+
this._renderer = _renderer;
|
|
9
|
+
this._changeDetectorRef = _changeDetectorRef;
|
|
10
|
+
// Readonly data.
|
|
11
|
+
this.labelId = `bbi-checkbox-${nextUniqueId++}`;
|
|
12
|
+
// Outputs.
|
|
13
|
+
this.checkedChange = new EventEmitter();
|
|
14
|
+
this.indeterminateChange = new EventEmitter();
|
|
15
|
+
this._checked = false;
|
|
16
|
+
this._disabled = false;
|
|
17
|
+
this._grouped = false;
|
|
18
|
+
this._indeterminate = false;
|
|
19
|
+
this._required = false;
|
|
20
|
+
// Methods.
|
|
21
|
+
this.onChange = () => ({});
|
|
22
|
+
this.onTouched = () => ({});
|
|
23
|
+
}
|
|
24
|
+
// Checked.
|
|
25
|
+
get checked() { return this._checked; }
|
|
26
|
+
set checked(value) {
|
|
27
|
+
const newValue = coerceBooleanProperty(value);
|
|
28
|
+
if (newValue !== this.checked) {
|
|
29
|
+
this._checked = newValue;
|
|
30
|
+
this._changeDetectorRef.markForCheck();
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
// Disabled.
|
|
34
|
+
get disabled() { return this._disabled; }
|
|
35
|
+
set disabled(value) {
|
|
36
|
+
const newValue = coerceBooleanProperty(value);
|
|
37
|
+
if (newValue !== this.disabled) {
|
|
38
|
+
this._disabled = newValue;
|
|
39
|
+
this._changeDetectorRef.markForCheck();
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
// Grouped.
|
|
43
|
+
get grouped() { return this._grouped; }
|
|
44
|
+
set grouped(value) {
|
|
45
|
+
const newValue = coerceBooleanProperty(value);
|
|
46
|
+
if (newValue !== this.grouped) {
|
|
47
|
+
this._grouped = newValue;
|
|
48
|
+
this._changeDetectorRef.markForCheck();
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
// Indeterminate.
|
|
52
|
+
get indeterminate() { return this._indeterminate; }
|
|
53
|
+
set indeterminate(value) {
|
|
54
|
+
this._indeterminate = coerceBooleanProperty(value);
|
|
55
|
+
this.syncField('indeterminate', this._indeterminate);
|
|
56
|
+
}
|
|
57
|
+
// Required.
|
|
58
|
+
get required() { return this._required; }
|
|
59
|
+
set required(value) {
|
|
60
|
+
const newValue = coerceBooleanProperty(value);
|
|
61
|
+
if (newValue !== this.required) {
|
|
62
|
+
this._required = newValue;
|
|
63
|
+
this._changeDetectorRef.markForCheck();
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
ngAfterViewInit() {
|
|
67
|
+
this.syncField('indeterminate', this._indeterminate);
|
|
68
|
+
}
|
|
69
|
+
registerOnChange(fn) {
|
|
70
|
+
this.onChange = fn;
|
|
71
|
+
}
|
|
72
|
+
registerOnTouched(fn) {
|
|
73
|
+
this.onTouched = fn;
|
|
74
|
+
}
|
|
75
|
+
setDisabledState(isDisabled) {
|
|
76
|
+
this.disabled = isDisabled;
|
|
77
|
+
}
|
|
78
|
+
writeValue(newValue) {
|
|
79
|
+
this.checked = !!newValue;
|
|
80
|
+
}
|
|
81
|
+
toggle() {
|
|
82
|
+
this.checked = !this.checked;
|
|
83
|
+
}
|
|
84
|
+
onClickEvent(event) {
|
|
85
|
+
event.stopPropagation();
|
|
86
|
+
if (this.disabled) {
|
|
87
|
+
return;
|
|
88
|
+
}
|
|
89
|
+
// When user manually click on the checkbox, `indeterminate` is set to false.
|
|
90
|
+
if (this.indeterminate) {
|
|
91
|
+
Promise.resolve().then(() => {
|
|
92
|
+
this._indeterminate = false;
|
|
93
|
+
this.indeterminateChange.emit(this._indeterminate);
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
this.toggle();
|
|
97
|
+
// Emit our custom change event if the native input emitted one.
|
|
98
|
+
// It is important to only emit it, if the native input triggered one, because
|
|
99
|
+
// we don't want to trigger a change event, when the `checked` variable changes for example.
|
|
100
|
+
this.emitChangeEvent();
|
|
101
|
+
}
|
|
102
|
+
onChangeEvent(event) {
|
|
103
|
+
// We always have to stop propagation on the change event.
|
|
104
|
+
// Otherwise the change event, from the input element, will bubble up and
|
|
105
|
+
// emit its event object to the `change` output.
|
|
106
|
+
event.stopPropagation();
|
|
107
|
+
}
|
|
108
|
+
emitChangeEvent() {
|
|
109
|
+
this.onChange?.(this.checked);
|
|
110
|
+
this.checkedChange.emit(this.checked);
|
|
111
|
+
this.syncField('checked', this.checked);
|
|
112
|
+
}
|
|
113
|
+
syncField(field, value) {
|
|
114
|
+
const element = this.inputElementRef?.nativeElement;
|
|
115
|
+
if (!element) {
|
|
116
|
+
return;
|
|
117
|
+
}
|
|
118
|
+
this._renderer.setProperty(element, field, value);
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
BbiCheckbox.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.0", ngImport: i0, type: BbiCheckbox, deps: [{ token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
122
|
+
BbiCheckbox.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.0", type: BbiCheckbox, selector: "bbi-checkbox", inputs: { checked: "checked", disabled: "disabled", grouped: "grouped", indeterminate: "indeterminate", required: "required" }, outputs: { checkedChange: "checkedChange", indeterminateChange: "indeterminateChange" }, host: { properties: { "class.grouped": "grouped", "class.indeterminate": "indeterminate", "class.required": "required" }, classAttribute: "bbi-checkbox" }, providers: [
|
|
123
|
+
{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => BbiCheckbox), multi: true }
|
|
124
|
+
], viewQueries: [{ propertyName: "inputElementRef", first: true, predicate: ["input"], descendants: true, static: true }], ngImport: i0, template: "<input #input\n [id]=\"labelId\"\n [disabled]=\"disabled\"\n [checked]=\"checked\"\n (change)=\"onChangeEvent($event)\"\n (click)=\"onClickEvent($event)\"\n (blur)=\"onTouched()\"\n class=\"bbi-checkbox-input\"\n type=\"checkbox\">\n<label [attr.for]=\"labelId\"\n class=\"bbi-checkbox-label\">\n <span class=\"bbi-checkbox-text\"><ng-content></ng-content></span>\n</label>\n", styles: [".bbi-checkbox{display:block}.bbi-checkbox.grouped{margin-bottom:20px}.bbi-checkbox.required>.bbi-checkbox-label>.bbi-checkbox-text:after{content:\"*\";color:#c23934;font-size:12px;line-height:1.5;margin-left:3px}.bbi-checkbox-input{border:0;width:1px;padding:0;height:1px;margin:-1px;overflow:hidden;position:absolute;visibility:inherit;white-space:nowrap;clip:rect(0,0,0,0)}.bbi-checkbox-input:checked+.bbi-checkbox-label:before,.bbi-checkbox-input:indeterminate+.bbi-checkbox-label:before{border:1px solid var(--checkbox-accent-color, #1565c0);background-color:var(--checkbox-accent-color, #1565c0)}.bbi-checkbox-input:checked+.bbi-checkbox-label:after,.bbi-checkbox-input:indeterminate+.bbi-checkbox-label:after{opacity:1;transform:scale(1) rotate(-45deg)}.bbi-checkbox-input:indeterminate+.bbi-checkbox-label:after{top:-1px;left:5px;width:10px;transform:scale(1) rotate(0);border-left:0 solid var(--checkbox-check-color, white);border-bottom:2px solid var(--checkbox-check-color, white)}.bbi-checkbox-input:focus+.bbi-checkbox-label:before{outline-color:var(--checkbox-accent-color, #1565c0)}.bbi-checkbox-input:disabled+.bbi-checkbox-label{cursor:not-allowed;color:var(--checkbox-disabled-color, #c6c6c6)}.bbi-checkbox-input:disabled+.bbi-checkbox-label:before{border-color:var(--checkbox-disabled-color, #c6c6c6)}.bbi-checkbox-input:disabled+.bbi-checkbox-label>.bbi-checkbox-text{color:var(--checkbox-disabled-color, #c6c6c6)}.bbi-checkbox-input:checked:disabled+.bbi-checkbox-label:before,.bbi-checkbox-input:indeterminate:disabled+.bbi-checkbox-label:before{background-color:var(--checkbox-disabled-color, #c6c6c6)}.bbi-checkbox-label{border:0;margin:0;display:flex;cursor:pointer;font-size:16px;font-weight:400;line-height:1.28;-webkit-user-select:none;user-select:none;position:relative;padding-left:20px;font-family:inherit;vertical-align:initial}.bbi-checkbox-label:before{left:0;width:20px;content:\"\";height:20px;position:absolute;border-radius:4px;outline-offset:1px;background-color:initial;outline:2px solid transparent;border:1px solid var(--checkbox-border-color, #111111);transition:outline-color .2s cubic-bezier(0,0,.2,1),background-color .18s cubic-bezier(0,0,.2,1),border-color .18s cubic-bezier(0,0,.2,1)}.bbi-checkbox-label:after{left:4px;opacity:0;width:12px;height:6px;content:\"\";margin-top:6px;background:none;position:absolute;transform-origin:center;transform:scale(.85) rotate(-60deg);border-left:2px solid var(--checkbox-check-color, white);border-bottom:2px solid var(--checkbox-check-color, white);transition:opacity .12s cubic-bezier(0,0,.2,1),transform .18s cubic-bezier(0,0,.2,1)}.bbi-checkbox-text{padding-left:6px;color:var(--checkbox-label-color, #111111)}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
125
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.0", ngImport: i0, type: BbiCheckbox, decorators: [{
|
|
126
|
+
type: Component,
|
|
127
|
+
args: [{ selector: 'bbi-checkbox', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, providers: [
|
|
128
|
+
{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => BbiCheckbox), multi: true }
|
|
129
|
+
], host: {
|
|
130
|
+
'class': 'bbi-checkbox',
|
|
131
|
+
'[class.grouped]': 'grouped',
|
|
132
|
+
'[class.indeterminate]': 'indeterminate',
|
|
133
|
+
'[class.required]': 'required'
|
|
134
|
+
}, preserveWhitespaces: false, template: "<input #input\n [id]=\"labelId\"\n [disabled]=\"disabled\"\n [checked]=\"checked\"\n (change)=\"onChangeEvent($event)\"\n (click)=\"onClickEvent($event)\"\n (blur)=\"onTouched()\"\n class=\"bbi-checkbox-input\"\n type=\"checkbox\">\n<label [attr.for]=\"labelId\"\n class=\"bbi-checkbox-label\">\n <span class=\"bbi-checkbox-text\"><ng-content></ng-content></span>\n</label>\n", styles: [".bbi-checkbox{display:block}.bbi-checkbox.grouped{margin-bottom:20px}.bbi-checkbox.required>.bbi-checkbox-label>.bbi-checkbox-text:after{content:\"*\";color:#c23934;font-size:12px;line-height:1.5;margin-left:3px}.bbi-checkbox-input{border:0;width:1px;padding:0;height:1px;margin:-1px;overflow:hidden;position:absolute;visibility:inherit;white-space:nowrap;clip:rect(0,0,0,0)}.bbi-checkbox-input:checked+.bbi-checkbox-label:before,.bbi-checkbox-input:indeterminate+.bbi-checkbox-label:before{border:1px solid var(--checkbox-accent-color, #1565c0);background-color:var(--checkbox-accent-color, #1565c0)}.bbi-checkbox-input:checked+.bbi-checkbox-label:after,.bbi-checkbox-input:indeterminate+.bbi-checkbox-label:after{opacity:1;transform:scale(1) rotate(-45deg)}.bbi-checkbox-input:indeterminate+.bbi-checkbox-label:after{top:-1px;left:5px;width:10px;transform:scale(1) rotate(0);border-left:0 solid var(--checkbox-check-color, white);border-bottom:2px solid var(--checkbox-check-color, white)}.bbi-checkbox-input:focus+.bbi-checkbox-label:before{outline-color:var(--checkbox-accent-color, #1565c0)}.bbi-checkbox-input:disabled+.bbi-checkbox-label{cursor:not-allowed;color:var(--checkbox-disabled-color, #c6c6c6)}.bbi-checkbox-input:disabled+.bbi-checkbox-label:before{border-color:var(--checkbox-disabled-color, #c6c6c6)}.bbi-checkbox-input:disabled+.bbi-checkbox-label>.bbi-checkbox-text{color:var(--checkbox-disabled-color, #c6c6c6)}.bbi-checkbox-input:checked:disabled+.bbi-checkbox-label:before,.bbi-checkbox-input:indeterminate:disabled+.bbi-checkbox-label:before{background-color:var(--checkbox-disabled-color, #c6c6c6)}.bbi-checkbox-label{border:0;margin:0;display:flex;cursor:pointer;font-size:16px;font-weight:400;line-height:1.28;-webkit-user-select:none;user-select:none;position:relative;padding-left:20px;font-family:inherit;vertical-align:initial}.bbi-checkbox-label:before{left:0;width:20px;content:\"\";height:20px;position:absolute;border-radius:4px;outline-offset:1px;background-color:initial;outline:2px solid transparent;border:1px solid var(--checkbox-border-color, #111111);transition:outline-color .2s cubic-bezier(0,0,.2,1),background-color .18s cubic-bezier(0,0,.2,1),border-color .18s cubic-bezier(0,0,.2,1)}.bbi-checkbox-label:after{left:4px;opacity:0;width:12px;height:6px;content:\"\";margin-top:6px;background:none;position:absolute;transform-origin:center;transform:scale(.85) rotate(-60deg);border-left:2px solid var(--checkbox-check-color, white);border-bottom:2px solid var(--checkbox-check-color, white);transition:opacity .12s cubic-bezier(0,0,.2,1),transform .18s cubic-bezier(0,0,.2,1)}.bbi-checkbox-text{padding-left:6px;color:var(--checkbox-label-color, #111111)}\n"] }]
|
|
135
|
+
}], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { inputElementRef: [{
|
|
136
|
+
type: ViewChild,
|
|
137
|
+
args: ['input', { static: true }]
|
|
138
|
+
}], checkedChange: [{
|
|
139
|
+
type: Output
|
|
140
|
+
}], indeterminateChange: [{
|
|
141
|
+
type: Output
|
|
142
|
+
}], checked: [{
|
|
143
|
+
type: Input
|
|
144
|
+
}], disabled: [{
|
|
145
|
+
type: Input
|
|
146
|
+
}], grouped: [{
|
|
147
|
+
type: Input
|
|
148
|
+
}], indeterminate: [{
|
|
149
|
+
type: Input
|
|
150
|
+
}], required: [{
|
|
151
|
+
type: Input
|
|
152
|
+
}] } });
|
|
153
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox.component.js","sourceRoot":"","sources":["../../../../../../../projects/bb-foundation/controls/src/lib/checkbox/checkbox/checkbox.component.ts","../../../../../../../projects/bb-foundation/controls/src/lib/checkbox/checkbox/checkbox.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    Input, Output,\n    Renderer2,\n    ViewChild,\n    ViewEncapsulation\n} from '@angular/core';\nimport {BooleanInput, coerceBooleanProperty} from '@angular/cdk/coercion';\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR} from '@angular/forms';\n\nlet nextUniqueId = 0;\n\n@Component({\n    selector: 'bbi-checkbox',\n    templateUrl: './checkbox.component.html',\n    styleUrls: ['./checkbox.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    providers: [\n        {provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => BbiCheckbox), multi: true}\n    ],\n    host: {\n        'class': 'bbi-checkbox',\n        '[class.grouped]': 'grouped',\n        '[class.indeterminate]': 'indeterminate',\n        '[class.required]': 'required'\n    },\n    preserveWhitespaces: false\n})\nexport class BbiCheckbox implements ControlValueAccessor, AfterViewInit {\n\n    // Readonly data.\n    readonly labelId = `bbi-checkbox-${nextUniqueId++}`;\n\n    // Views.\n    @ViewChild('input', {static: true}) inputElementRef: ElementRef<HTMLInputElement>;\n\n    // Outputs.\n    @Output() checkedChange = new EventEmitter<boolean>();\n    @Output() indeterminateChange = new EventEmitter<boolean>();\n\n    // Checked.\n    @Input()\n    get checked() { return this._checked;}\n\n    set checked(value: boolean) {\n        const newValue = coerceBooleanProperty(value);\n        if (newValue !== this.checked) {\n            this._checked = newValue;\n            this._changeDetectorRef.markForCheck();\n        }\n    }\n\n    private _checked: boolean = false;\n\n    // Disabled.\n    @Input()\n    get disabled() { return this._disabled; }\n\n    set disabled(value: unknown) {\n        const newValue = coerceBooleanProperty(value);\n        if (newValue !== this.disabled) {\n            this._disabled = newValue;\n            this._changeDetectorRef.markForCheck();\n        }\n    }\n\n    private _disabled = false;\n\n    // Grouped.\n    @Input()\n    get grouped() { return this._grouped; }\n\n    set grouped(value: unknown) {\n        const newValue = coerceBooleanProperty(value);\n        if (newValue !== this.grouped) {\n            this._grouped = newValue;\n            this._changeDetectorRef.markForCheck();\n        }\n    }\n\n    private _grouped = false;\n\n    // Indeterminate.\n    @Input()\n    get indeterminate() { return this._indeterminate; }\n\n    set indeterminate(value: unknown) {\n        this._indeterminate = coerceBooleanProperty(value);\n        this.syncField('indeterminate', this._indeterminate);\n    }\n\n    private _indeterminate = false;\n\n    // Required.\n    @Input()\n    get required() { return this._required; }\n\n    set required(value: unknown) {\n        const newValue = coerceBooleanProperty(value);\n        if (newValue !== this.required) {\n            this._required = newValue;\n            this._changeDetectorRef.markForCheck();\n        }\n    }\n\n    private _required = false;\n\n    // Methods.\n    onChange: (newValue: boolean) => void = () => ({});\n    onTouched: () => void = () => ({});\n\n    constructor(private _renderer: Renderer2,\n                private _changeDetectorRef: ChangeDetectorRef) {\n    }\n\n    ngAfterViewInit() {\n        this.syncField('indeterminate', this._indeterminate);\n    }\n\n    registerOnChange(fn: (newValue: boolean) => void) {\n        this.onChange = fn;\n    }\n\n    registerOnTouched(fn: () => void) {\n        this.onTouched = fn;\n    }\n\n    setDisabledState(isDisabled: boolean) {\n        this.disabled = isDisabled;\n    }\n\n    writeValue(newValue: boolean) {\n        this.checked = !!newValue;\n    }\n\n    toggle() {\n        this.checked = !this.checked;\n    }\n\n    onClickEvent(event: Event) {\n        event.stopPropagation();\n        if (this.disabled) {\n            return;\n        }\n\n        // When user manually click on the checkbox, `indeterminate` is set to false.\n        if (this.indeterminate) {\n            Promise.resolve().then(() => {\n                this._indeterminate = false;\n                this.indeterminateChange.emit(this._indeterminate);\n            });\n        }\n\n        this.toggle();\n\n        // Emit our custom change event if the native input emitted one.\n        // It is important to only emit it, if the native input triggered one, because\n        // we don't want to trigger a change event, when the `checked` variable changes for example.\n        this.emitChangeEvent();\n    }\n\n    onChangeEvent(event: Event) {\n        // We always have to stop propagation on the change event.\n        // Otherwise the change event, from the input element, will bubble up and\n        // emit its event object to the `change` output.\n        event.stopPropagation();\n    }\n\n    private emitChangeEvent() {\n        this.onChange?.(this.checked);\n        this.checkedChange.emit(this.checked);\n        this.syncField('checked', this.checked);\n    }\n\n    private syncField(field: string, value: boolean) {\n        const element = this.inputElementRef?.nativeElement;\n        if (!element) {\n            return;\n        }\n        this._renderer.setProperty(element, field, value);\n    }\n\n    // Required so that the template type checker can infer the type of the coerced inputs.\n    static ngAcceptInputType_checked: BooleanInput;\n    static ngAcceptInputType_disabled: BooleanInput;\n    static ngAcceptInputType_required: BooleanInput;\n    static ngAcceptInputType_grouped: BooleanInput;\n    static ngAcceptInputType_indeterminate: BooleanInput;\n\n}\n","<input #input\n       [id]=\"labelId\"\n       [disabled]=\"disabled\"\n       [checked]=\"checked\"\n       (change)=\"onChangeEvent($event)\"\n       (click)=\"onClickEvent($event)\"\n       (blur)=\"onTouched()\"\n       class=\"bbi-checkbox-input\"\n       type=\"checkbox\">\n<label [attr.for]=\"labelId\"\n       class=\"bbi-checkbox-label\">\n    <span class=\"bbi-checkbox-text\"><ng-content></ng-content></span>\n</label>\n"]}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input, ViewEncapsulation } from '@angular/core';
|
|
2
|
+
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
export class BbiCheckboxGroup {
|
|
6
|
+
constructor(_changeDetectorRef) {
|
|
7
|
+
this._changeDetectorRef = _changeDetectorRef;
|
|
8
|
+
// Inputs.
|
|
9
|
+
this.label = null; // TODO(Stan): Add template possibilities here.
|
|
10
|
+
this._grouped = false;
|
|
11
|
+
this._required = false;
|
|
12
|
+
}
|
|
13
|
+
// Grouped.
|
|
14
|
+
get grouped() { return this._grouped; }
|
|
15
|
+
set grouped(value) {
|
|
16
|
+
const newValue = coerceBooleanProperty(value);
|
|
17
|
+
if (newValue !== this.grouped) {
|
|
18
|
+
this._grouped = newValue;
|
|
19
|
+
this._changeDetectorRef.markForCheck();
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
// Required.
|
|
23
|
+
get required() { return this._required; }
|
|
24
|
+
set required(value) {
|
|
25
|
+
const newValue = coerceBooleanProperty(value);
|
|
26
|
+
if (newValue !== this.required) {
|
|
27
|
+
this._required = newValue;
|
|
28
|
+
this._changeDetectorRef.markForCheck();
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
BbiCheckboxGroup.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.0", ngImport: i0, type: BbiCheckboxGroup, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
33
|
+
BbiCheckboxGroup.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.0", type: BbiCheckboxGroup, selector: "bbi-checkbox-group", inputs: { label: "label", grouped: "grouped", required: "required" }, host: { properties: { "class.grouped": "grouped", "class.required": "required" }, classAttribute: "bbi-checkbox-group" }, ngImport: i0, template: "<label *ngIf=\"label as label\"\n class=\"bbi-checkbox-group-label\">\n {{ label }}\n</label>\n\n<div class=\"bbi-checkbox-group-items\">\n <ng-content select=\"bbi-checkbox\"></ng-content>\n</div>\n", styles: [".bbi-checkbox-group{display:block}.bbi-checkbox-group.grouped{margin-bottom:20px}.bbi-checkbox-group.required>.bbi-checkbox-group-label:after{content:\"*\";color:#c23934;font-size:12px;line-height:1.5}.bbi-checkbox-group-label{border:0;padding:0;line-height:1.33;margin-bottom:4px;font-family:inherit;display:inline-block;box-sizing:border-box;vertical-align:initial;color:var(--checkbox-group-label-color, #525252);font-size:var(--checkbox-group-label-size, 14px);font-weight:var(--checkbox-group-label-weight, 400)}.bbi-checkbox-group-items{display:flex;flex-direction:column}.bbi-checkbox-group-items:not(:empty){margin-bottom:-4px}.bbi-checkbox-group-items>*{margin-bottom:4px}@media only screen and (min-width: 768px){.bbi-checkbox-group:not(.vertical)>.bbi-checkbox-group-items{flex-wrap:wrap;flex-direction:row}.bbi-checkbox-group:not(.vertical)>.bbi-checkbox-group-items>*:not(:last-child){margin-right:10px}}\n"], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
34
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.0", ngImport: i0, type: BbiCheckboxGroup, decorators: [{
|
|
35
|
+
type: Component,
|
|
36
|
+
args: [{ selector: 'bbi-checkbox-group', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: {
|
|
37
|
+
'class': 'bbi-checkbox-group',
|
|
38
|
+
'[class.grouped]': 'grouped',
|
|
39
|
+
'[class.required]': 'required'
|
|
40
|
+
}, preserveWhitespaces: false, template: "<label *ngIf=\"label as label\"\n class=\"bbi-checkbox-group-label\">\n {{ label }}\n</label>\n\n<div class=\"bbi-checkbox-group-items\">\n <ng-content select=\"bbi-checkbox\"></ng-content>\n</div>\n", styles: [".bbi-checkbox-group{display:block}.bbi-checkbox-group.grouped{margin-bottom:20px}.bbi-checkbox-group.required>.bbi-checkbox-group-label:after{content:\"*\";color:#c23934;font-size:12px;line-height:1.5}.bbi-checkbox-group-label{border:0;padding:0;line-height:1.33;margin-bottom:4px;font-family:inherit;display:inline-block;box-sizing:border-box;vertical-align:initial;color:var(--checkbox-group-label-color, #525252);font-size:var(--checkbox-group-label-size, 14px);font-weight:var(--checkbox-group-label-weight, 400)}.bbi-checkbox-group-items{display:flex;flex-direction:column}.bbi-checkbox-group-items:not(:empty){margin-bottom:-4px}.bbi-checkbox-group-items>*{margin-bottom:4px}@media only screen and (min-width: 768px){.bbi-checkbox-group:not(.vertical)>.bbi-checkbox-group-items{flex-wrap:wrap;flex-direction:row}.bbi-checkbox-group:not(.vertical)>.bbi-checkbox-group-items>*:not(:last-child){margin-right:10px}}\n"] }]
|
|
41
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { label: [{
|
|
42
|
+
type: Input
|
|
43
|
+
}], grouped: [{
|
|
44
|
+
type: Input
|
|
45
|
+
}], required: [{
|
|
46
|
+
type: Input
|
|
47
|
+
}] } });
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3gtZ3JvdXAuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmItZm91bmRhdGlvbi9jb250cm9scy9zcmMvbGliL2NoZWNrYm94L2NoZWNrYm94LWdyb3VwL2NoZWNrYm94LWdyb3VwLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JiLWZvdW5kYXRpb24vY29udHJvbHMvc3JjL2xpYi9jaGVja2JveC9jaGVja2JveC1ncm91cC9jaGVja2JveC1ncm91cC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsdUJBQXVCLEVBQXFCLFNBQVMsRUFBRSxLQUFLLEVBQUUsaUJBQWlCLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDOUcsT0FBTyxFQUFlLHFCQUFxQixFQUFDLE1BQU0sdUJBQXVCLENBQUM7OztBQWUxRSxNQUFNLE9BQU8sZ0JBQWdCO0lBaUN6QixZQUFvQixrQkFBcUM7UUFBckMsdUJBQWtCLEdBQWxCLGtCQUFrQixDQUFtQjtRQS9CekQsVUFBVTtRQUNELFVBQUssR0FBa0IsSUFBSSxDQUFDLENBQUMsK0NBQStDO1FBYzdFLGFBQVEsR0FBRyxLQUFLLENBQUM7UUFjakIsY0FBUyxHQUFHLEtBQUssQ0FBQztJQUcxQixDQUFDO0lBN0JELFdBQVc7SUFDWCxJQUNJLE9BQU8sS0FBSyxPQUFPLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDO0lBRXZDLElBQUksT0FBTyxDQUFDLEtBQWM7UUFDdEIsTUFBTSxRQUFRLEdBQUcscUJBQXFCLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDOUMsSUFBSSxRQUFRLEtBQUssSUFBSSxDQUFDLE9BQU8sRUFBRTtZQUMzQixJQUFJLENBQUMsUUFBUSxHQUFHLFFBQVEsQ0FBQztZQUN6QixJQUFJLENBQUMsa0JBQWtCLENBQUMsWUFBWSxFQUFFLENBQUM7U0FDMUM7SUFDTCxDQUFDO0lBSUQsWUFBWTtJQUNaLElBQ0ksUUFBUSxLQUFLLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUM7SUFFekMsSUFBSSxRQUFRLENBQUMsS0FBYztRQUN2QixNQUFNLFFBQVEsR0FBRyxxQkFBcUIsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUM5QyxJQUFJLFFBQVEsS0FBSyxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQzVCLElBQUksQ0FBQyxTQUFTLEdBQUcsUUFBUSxDQUFDO1lBQzFCLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxZQUFZLEVBQUUsQ0FBQztTQUMxQztJQUNMLENBQUM7OzZHQTdCUSxnQkFBZ0I7aUdBQWhCLGdCQUFnQiwwUENoQjdCLHFOQVFBOzJGRFFhLGdCQUFnQjtrQkFiNUIsU0FBUzsrQkFDSSxvQkFBb0IsbUJBR2IsdUJBQXVCLENBQUMsTUFBTSxpQkFDaEMsaUJBQWlCLENBQUMsSUFBSSxRQUMvQjt3QkFDRixPQUFPLEVBQUUsb0JBQW9CO3dCQUM3QixpQkFBaUIsRUFBRSxTQUFTO3dCQUM1QixrQkFBa0IsRUFBRSxVQUFVO3FCQUNqQyx1QkFDb0IsS0FBSzt3R0FLakIsS0FBSztzQkFBYixLQUFLO2dCQUlGLE9BQU87c0JBRFYsS0FBSztnQkFlRixRQUFRO3NCQURYLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDaGFuZ2VEZXRlY3RvclJlZiwgQ29tcG9uZW50LCBJbnB1dCwgVmlld0VuY2Fwc3VsYXRpb259IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtCb29sZWFuSW5wdXQsIGNvZXJjZUJvb2xlYW5Qcm9wZXJ0eX0gZnJvbSAnQGFuZ3VsYXIvY2RrL2NvZXJjaW9uJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdiYmktY2hlY2tib3gtZ3JvdXAnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9jaGVja2JveC1ncm91cC5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vY2hlY2tib3gtZ3JvdXAuY29tcG9uZW50LnNjc3MnXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICAgIGhvc3Q6IHtcbiAgICAgICAgJ2NsYXNzJzogJ2JiaS1jaGVja2JveC1ncm91cCcsXG4gICAgICAgICdbY2xhc3MuZ3JvdXBlZF0nOiAnZ3JvdXBlZCcsXG4gICAgICAgICdbY2xhc3MucmVxdWlyZWRdJzogJ3JlcXVpcmVkJ1xuICAgIH0sXG4gICAgcHJlc2VydmVXaGl0ZXNwYWNlczogZmFsc2Vcbn0pXG5leHBvcnQgY2xhc3MgQmJpQ2hlY2tib3hHcm91cCB7XG5cbiAgICAvLyBJbnB1dHMuXG4gICAgQElucHV0KCkgbGFiZWw6IHN0cmluZyB8IG51bGwgPSBudWxsOyAvLyBUT0RPKFN0YW4pOiBBZGQgdGVtcGxhdGUgcG9zc2liaWxpdGllcyBoZXJlLlxuXG4gICAgLy8gR3JvdXBlZC5cbiAgICBASW5wdXQoKVxuICAgIGdldCBncm91cGVkKCkgeyByZXR1cm4gdGhpcy5fZ3JvdXBlZDsgfVxuXG4gICAgc2V0IGdyb3VwZWQodmFsdWU6IHVua25vd24pIHtcbiAgICAgICAgY29uc3QgbmV3VmFsdWUgPSBjb2VyY2VCb29sZWFuUHJvcGVydHkodmFsdWUpO1xuICAgICAgICBpZiAobmV3VmFsdWUgIT09IHRoaXMuZ3JvdXBlZCkge1xuICAgICAgICAgICAgdGhpcy5fZ3JvdXBlZCA9IG5ld1ZhbHVlO1xuICAgICAgICAgICAgdGhpcy5fY2hhbmdlRGV0ZWN0b3JSZWYubWFya0ZvckNoZWNrKCk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBwcml2YXRlIF9ncm91cGVkID0gZmFsc2U7XG5cbiAgICAvLyBSZXF1aXJlZC5cbiAgICBASW5wdXQoKVxuICAgIGdldCByZXF1aXJlZCgpIHsgcmV0dXJuIHRoaXMuX3JlcXVpcmVkOyB9XG5cbiAgICBzZXQgcmVxdWlyZWQodmFsdWU6IHVua25vd24pIHtcbiAgICAgICAgY29uc3QgbmV3VmFsdWUgPSBjb2VyY2VCb29sZWFuUHJvcGVydHkodmFsdWUpO1xuICAgICAgICBpZiAobmV3VmFsdWUgIT09IHRoaXMucmVxdWlyZWQpIHtcbiAgICAgICAgICAgIHRoaXMuX3JlcXVpcmVkID0gbmV3VmFsdWU7XG4gICAgICAgICAgICB0aGlzLl9jaGFuZ2VEZXRlY3RvclJlZi5tYXJrRm9yQ2hlY2soKTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHByaXZhdGUgX3JlcXVpcmVkID0gZmFsc2U7XG5cbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIF9jaGFuZ2VEZXRlY3RvclJlZjogQ2hhbmdlRGV0ZWN0b3JSZWYpIHtcbiAgICB9XG5cbiAgICAvLyBSZXF1aXJlZCBzbyB0aGF0IHRoZSB0ZW1wbGF0ZSB0eXBlIGNoZWNrZXIgY2FuIGluZmVyIHRoZSB0eXBlIG9mIHRoZSBjb2VyY2VkIGlucHV0cy5cbiAgICBzdGF0aWMgbmdBY2NlcHRJbnB1dFR5cGVfZ3JvdXBlZDogQm9vbGVhbklucHV0O1xuICAgIHN0YXRpYyBuZ0FjY2VwdElucHV0VHlwZV9yZXF1aXJlZDogQm9vbGVhbklucHV0O1xuXG59XG4iLCI8bGFiZWwgKm5nSWY9XCJsYWJlbCBhcyBsYWJlbFwiXG4gICAgICAgY2xhc3M9XCJiYmktY2hlY2tib3gtZ3JvdXAtbGFiZWxcIj5cbiAgICB7eyBsYWJlbCB9fVxuPC9sYWJlbD5cblxuPGRpdiBjbGFzcz1cImJiaS1jaGVja2JveC1ncm91cC1pdGVtc1wiPlxuICAgIDxuZy1jb250ZW50IHNlbGVjdD1cImJiaS1jaGVja2JveFwiPjwvbmctY29udGVudD5cbjwvZGl2PlxuIl19
|
|
@@ -1,19 +1,19 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { BbiCheckbox } from './checkbox.component';
|
|
1
|
+
import { BbiCheckboxGroup } from './checkbox-group/checkbox-group.component';
|
|
2
|
+
import { BbiCheckbox } from './checkbox/checkbox.component';
|
|
3
3
|
import { CommonModule } from '@angular/common';
|
|
4
4
|
import { NgModule } from '@angular/core';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
export class CheckboxModule {
|
|
7
7
|
}
|
|
8
8
|
CheckboxModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.0", ngImport: i0, type: CheckboxModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
9
|
-
CheckboxModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.1.0", ngImport: i0, type: CheckboxModule, declarations: [BbiCheckbox], imports: [CommonModule
|
|
10
|
-
CheckboxModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.1.0", ngImport: i0, type: CheckboxModule, imports: [[CommonModule
|
|
9
|
+
CheckboxModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.1.0", ngImport: i0, type: CheckboxModule, declarations: [BbiCheckbox, BbiCheckboxGroup], imports: [CommonModule], exports: [BbiCheckbox, BbiCheckboxGroup] });
|
|
10
|
+
CheckboxModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.1.0", ngImport: i0, type: CheckboxModule, imports: [[CommonModule]] });
|
|
11
11
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.0", ngImport: i0, type: CheckboxModule, decorators: [{
|
|
12
12
|
type: NgModule,
|
|
13
13
|
args: [{
|
|
14
|
-
imports: [CommonModule
|
|
15
|
-
declarations: [BbiCheckbox],
|
|
16
|
-
exports: [BbiCheckbox]
|
|
14
|
+
imports: [CommonModule],
|
|
15
|
+
declarations: [BbiCheckbox, BbiCheckboxGroup],
|
|
16
|
+
exports: [BbiCheckbox, BbiCheckboxGroup]
|
|
17
17
|
}]
|
|
18
18
|
}] });
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3gubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmItZm91bmRhdGlvbi9jb250cm9scy9zcmMvbGliL2NoZWNrYm94L2NoZWNrYm94Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQztBQUMzRSxPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0sK0JBQStCLENBQUM7QUFDMUQsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7O0FBT3ZDLE1BQU0sT0FBTyxjQUFjOzsyR0FBZCxjQUFjOzRHQUFkLGNBQWMsaUJBSFIsV0FBVyxFQUFFLGdCQUFnQixhQURsQyxZQUFZLGFBRVosV0FBVyxFQUFFLGdCQUFnQjs0R0FFOUIsY0FBYyxZQUpkLENBQUMsWUFBWSxDQUFDOzJGQUlkLGNBQWM7a0JBTDFCLFFBQVE7bUJBQUM7b0JBQ04sT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO29CQUN2QixZQUFZLEVBQUUsQ0FBQyxXQUFXLEVBQUUsZ0JBQWdCLENBQUM7b0JBQzdDLE9BQU8sRUFBRSxDQUFDLFdBQVcsRUFBRSxnQkFBZ0IsQ0FBQztpQkFDM0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0JiaUNoZWNrYm94R3JvdXB9IGZyb20gJy4vY2hlY2tib3gtZ3JvdXAvY2hlY2tib3gtZ3JvdXAuY29tcG9uZW50JztcbmltcG9ydCB7QmJpQ2hlY2tib3h9IGZyb20gJy4vY2hlY2tib3gvY2hlY2tib3guY29tcG9uZW50JztcbmltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBOZ01vZHVsZSh7XG4gICAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gICAgZGVjbGFyYXRpb25zOiBbQmJpQ2hlY2tib3gsIEJiaUNoZWNrYm94R3JvdXBdLFxuICAgIGV4cG9ydHM6IFtCYmlDaGVja2JveCwgQmJpQ2hlY2tib3hHcm91cF1cbn0pXG5leHBvcnQgY2xhc3MgQ2hlY2tib3hNb2R1bGUge1xufVxuIl19
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
export * from './lib/checkbox/checkbox.component';
|
|
1
|
+
export * from './lib/checkbox/checkbox-group/checkbox-group.component';
|
|
2
|
+
export * from './lib/checkbox/checkbox/checkbox.component';
|
|
2
3
|
export * from './lib/checkbox/checkbox.module';
|
|
3
4
|
export * from './lib/controls.module';
|
|
4
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2JiLWZvdW5kYXRpb24vY29udHJvbHMvc3JjL3B1YmxpY19hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx3REFBd0QsQ0FBQztBQUN2RSxjQUFjLDRDQUE0QyxDQUFDO0FBQzNELGNBQWMsZ0NBQWdDLENBQUM7QUFFL0MsY0FBYyx1QkFBdUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL2NoZWNrYm94L2NoZWNrYm94LWdyb3VwL2NoZWNrYm94LWdyb3VwLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGVja2JveC9jaGVja2JveC9jaGVja2JveC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY2hlY2tib3gvY2hlY2tib3gubW9kdWxlJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29udHJvbHMubW9kdWxlJztcbiJdfQ==
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { mixinDisabled, mixinGrouped } from '@bravobit/bb-foundation';
|
|
2
2
|
import { ChangeDetectionStrategy, Component, forwardRef, Input, ViewEncapsulation } from '@angular/core';
|
|
3
3
|
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
4
|
-
import { coerceBooleanProperty } from '@
|
|
4
|
+
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
let nextUniqueId = 0;
|
|
7
7
|
class BbCheckboxBase {
|
|
@@ -70,4 +70,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.0", ngImpor
|
|
|
70
70
|
}], checked: [{
|
|
71
71
|
type: Input
|
|
72
72
|
}] } });
|
|
73
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
73
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3guY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmItZm91bmRhdGlvbi9lbGVtZW50cy9zcmMvbGliL2NoZWNrYm94L2NoZWNrYm94LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JiLWZvdW5kYXRpb24vZWxlbWVudHMvc3JjL2xpYi9jaGVja2JveC9jaGVja2JveC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBR0gsYUFBYSxFQUdiLFlBQVksRUFDZixNQUFNLHlCQUF5QixDQUFDO0FBQ2pDLE9BQU8sRUFDSCx1QkFBdUIsRUFFdkIsU0FBUyxFQUNULFVBQVUsRUFDVixLQUFLLEVBQ0wsaUJBQWlCLEVBQ3BCLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBdUIsaUJBQWlCLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUN2RSxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSx1QkFBdUIsQ0FBQzs7QUFFNUQsSUFBSSxZQUFZLEdBQUcsQ0FBQyxDQUFDO0FBRXJCLE1BQU0sY0FBYztDQUNuQjtBQUVELE1BQU0sbUJBQW1CLEdBR25CLGFBQWEsQ0FBQyxZQUFZLENBQUMsY0FBYyxDQUFDLENBQUMsQ0FBQztBQWtCbEQsTUFBTSxPQUFPLFVBQVcsU0FBUSxtQkFBbUI7SUFvQi9DLFlBQW9CLGdCQUFtQztRQUNuRCxLQUFLLEVBQUUsQ0FBQztRQURRLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBbUI7UUFsQnZELFFBQVE7UUFDUixZQUFPLEdBQUcsZUFBZSxZQUFZLEVBQUUsRUFBRSxDQUFDO1FBZWxDLGFBQVEsR0FBWSxLQUFLLENBQUM7UUFNbEMsV0FBVztRQUNYLGFBQVEsR0FBZ0MsR0FBRyxFQUFFO1FBQzdDLENBQUMsQ0FBQztRQUVGLGNBQVMsR0FBZSxHQUFHLEVBQUU7UUFDN0IsQ0FBQyxDQUFDO0lBUEYsQ0FBQztJQWRELElBQUksT0FBTztRQUNQLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQztJQUN6QixDQUFDO0lBRUQsSUFDSSxPQUFPLENBQUMsS0FBVTtRQUNsQixJQUFJLENBQUMsUUFBUSxHQUFHLHFCQUFxQixDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzdDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUN6QyxDQUFDO0lBZUQsZ0JBQWdCLENBQUMsRUFBTztRQUNwQixJQUFJLENBQUMsUUFBUSxHQUFHLEVBQUUsQ0FBQztJQUN2QixDQUFDO0lBRUQsaUJBQWlCLENBQUMsRUFBTztRQUNyQixJQUFJLENBQUMsU0FBUyxHQUFHLEVBQUUsQ0FBQztJQUN4QixDQUFDO0lBRUQsZ0JBQWdCLENBQUMsVUFBbUI7UUFDaEMsSUFBSSxDQUFDLFFBQVEsR0FBRyxVQUFVLENBQUM7UUFDM0IsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFlBQVksRUFBRSxDQUFDO0lBQ3pDLENBQUM7SUFFRCxVQUFVLENBQUMsUUFBaUI7UUFDeEIsSUFBSSxDQUFDLE9BQU8sR0FBRyxRQUFRLENBQUM7SUFDNUIsQ0FBQztJQUVELGtCQUFrQixDQUFDLEtBQVk7UUFDM0IsdURBQXVEO1FBQ3ZELEtBQUssQ0FBQyxlQUFlLEVBQUUsQ0FBQztJQUM1QixDQUFDO0lBRUQsWUFBWSxDQUFDLEtBQVk7UUFDckIsdURBQXVEO1FBQ3ZELEtBQUssQ0FBQyxlQUFlLEVBQUUsQ0FBQztRQUV4QixvQkFBb0I7UUFDcEIsSUFBSSxDQUFDLE9BQU8sR0FBRyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUM7UUFFN0IseUJBQXlCO1FBQ3pCLElBQUksQ0FBQyxRQUFRLElBQUksSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDakQsQ0FBQzs7dUdBOURRLFVBQVU7MkZBQVYsVUFBVSwyTkFWUjtRQUNQLEVBQUMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsVUFBVSxDQUFDLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBQztLQUN2RixpRENyQ0wscXNCQXdCQTsyRkRxQmEsVUFBVTtrQkFoQnRCLFNBQVM7K0JBQ0ksYUFBYSxtQkFHTix1QkFBdUIsQ0FBQyxNQUFNLGlCQUNoQyxpQkFBaUIsQ0FBQyxJQUFJLGFBQzFCO3dCQUNQLEVBQUMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLFdBQVcsQ0FBQyxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUM7cUJBQ3ZGLFFBQ0s7d0JBQ0YsT0FBTyxFQUFFLGFBQWE7d0JBQ3RCLGlCQUFpQixFQUFFLFNBQVM7cUJBQy9CLFVBQ08sQ0FBQyxTQUFTLEVBQUUsVUFBVSxDQUFDLHVCQUNWLEtBQUs7d0dBUWpCLFFBQVE7c0JBQWhCLEtBQUs7Z0JBT0YsT0FBTztzQkFEVixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgICBDYW5EaXNhYmxlLFxuICAgIENhbkRpc2FibGVDb25zdHJ1Y3RvcixcbiAgICBtaXhpbkRpc2FibGVkLFxuICAgIElzR3JvdXBlZCxcbiAgICBJc0dyb3VwZWRDb25zdHJ1Y3RvcixcbiAgICBtaXhpbkdyb3VwZWRcbn0gZnJvbSAnQGJyYXZvYml0L2JiLWZvdW5kYXRpb24nO1xuaW1wb3J0IHtcbiAgICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgICBDaGFuZ2VEZXRlY3RvclJlZixcbiAgICBDb21wb25lbnQsXG4gICAgZm9yd2FyZFJlZixcbiAgICBJbnB1dCxcbiAgICBWaWV3RW5jYXBzdWxhdGlvblxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7Q29udHJvbFZhbHVlQWNjZXNzb3IsIE5HX1ZBTFVFX0FDQ0VTU09SfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQge2NvZXJjZUJvb2xlYW5Qcm9wZXJ0eX0gZnJvbSAnQGFuZ3VsYXIvY2RrL2NvZXJjaW9uJztcblxubGV0IG5leHRVbmlxdWVJZCA9IDA7XG5cbmNsYXNzIEJiQ2hlY2tib3hCYXNlIHtcbn1cblxuY29uc3QgQmJDaGVja2JveE1peGluQmFzZTogSXNHcm91cGVkQ29uc3RydWN0b3JcbiAgICAmIENhbkRpc2FibGVDb25zdHJ1Y3RvclxuICAgICYgdHlwZW9mIEJiQ2hlY2tib3hCYXNlXG4gICAgPSBtaXhpbkRpc2FibGVkKG1peGluR3JvdXBlZChCYkNoZWNrYm94QmFzZSkpO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2JiLWNoZWNrYm94JyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vY2hlY2tib3guY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL2NoZWNrYm94LmNvbXBvbmVudC5zY3NzJ10sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gICAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgICBwcm92aWRlcnM6IFtcbiAgICAgICAge3Byb3ZpZGU6IE5HX1ZBTFVFX0FDQ0VTU09SLCB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBCYkNoZWNrYm94KSwgbXVsdGk6IHRydWV9XG4gICAgXSxcbiAgICBob3N0OiB7XG4gICAgICAgICdjbGFzcyc6ICdiYi1jaGVja2JveCcsXG4gICAgICAgICdbY2xhc3MuZ3JvdXBlZF0nOiAnZ3JvdXBlZCdcbiAgICB9LFxuICAgIGlucHV0czogWydncm91cGVkJywgJ2Rpc2FibGVkJ10sXG4gICAgcHJlc2VydmVXaGl0ZXNwYWNlczogZmFsc2Vcbn0pXG5leHBvcnQgY2xhc3MgQmJDaGVja2JveCBleHRlbmRzIEJiQ2hlY2tib3hNaXhpbkJhc2UgaW1wbGVtZW50cyBDb250cm9sVmFsdWVBY2Nlc3NvciwgSXNHcm91cGVkLCBDYW5EaXNhYmxlIHtcblxuICAgIC8vIERhdGEuXG4gICAgbGFiZWxJZCA9IGBiYi1jaGVja2JveC0ke25leHRVbmlxdWVJZCsrfWA7XG5cbiAgICAvLyBJbnB1dHMuXG4gICAgQElucHV0KCkgdGFiSW5kZXg6IG51bWJlcjtcblxuICAgIGdldCBjaGVja2VkKCkge1xuICAgICAgICByZXR1cm4gdGhpcy5fY2hlY2tlZDtcbiAgICB9XG5cbiAgICBASW5wdXQoKVxuICAgIHNldCBjaGVja2VkKHZhbHVlOiBhbnkpIHtcbiAgICAgICAgdGhpcy5fY2hlY2tlZCA9IGNvZXJjZUJvb2xlYW5Qcm9wZXJ0eSh2YWx1ZSk7XG4gICAgICAgIHRoaXMuX2NoYW5nZURldGVjdGlvbi5tYXJrRm9yQ2hlY2soKTtcbiAgICB9XG5cbiAgICBwcml2YXRlIF9jaGVja2VkOiBib29sZWFuID0gZmFsc2U7XG5cbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIF9jaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdG9yUmVmKSB7XG4gICAgICAgIHN1cGVyKCk7XG4gICAgfVxuXG4gICAgLy8gTWV0aG9kcy5cbiAgICBvbkNoYW5nZTogKG5ld1ZhbHVlOiBib29sZWFuKSA9PiB2b2lkID0gKCkgPT4ge1xuICAgIH07XG5cbiAgICBvblRvdWNoZWQ6ICgpID0+IHZvaWQgPSAoKSA9PiB7XG4gICAgfTtcblxuICAgIHJlZ2lzdGVyT25DaGFuZ2UoZm46IGFueSk6IHZvaWQge1xuICAgICAgICB0aGlzLm9uQ2hhbmdlID0gZm47XG4gICAgfVxuXG4gICAgcmVnaXN0ZXJPblRvdWNoZWQoZm46IGFueSk6IHZvaWQge1xuICAgICAgICB0aGlzLm9uVG91Y2hlZCA9IGZuO1xuICAgIH1cblxuICAgIHNldERpc2FibGVkU3RhdGUoaXNEaXNhYmxlZDogYm9vbGVhbikge1xuICAgICAgICB0aGlzLmRpc2FibGVkID0gaXNEaXNhYmxlZDtcbiAgICAgICAgdGhpcy5fY2hhbmdlRGV0ZWN0aW9uLm1hcmtGb3JDaGVjaygpO1xuICAgIH1cblxuICAgIHdyaXRlVmFsdWUobmV3VmFsdWU6IGJvb2xlYW4pIHtcbiAgICAgICAgdGhpcy5jaGVja2VkID0gbmV3VmFsdWU7XG4gICAgfVxuXG4gICAgb25JbnRlcmFjdGlvbkV2ZW50KGV2ZW50OiBFdmVudCkge1xuICAgICAgICAvLyBTdG9wIHRoZSBwcm9wYWdhdGlvbiB0byBwcmV2ZW50IGl0IGZyb20gYnViYmxpbmcgdXAuXG4gICAgICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xuICAgIH1cblxuICAgIG9uSW5wdXRDbGljayhldmVudDogRXZlbnQpIHtcbiAgICAgICAgLy8gU3RvcCB0aGUgcHJvcGFnYXRpb24gdG8gcHJldmVudCBpdCBmcm9tIGJ1YmJsaW5nIHVwLlxuICAgICAgICBldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcblxuICAgICAgICAvLyBUb2dnbGUgdGhlIHZhbHVlLlxuICAgICAgICB0aGlzLmNoZWNrZWQgPSAhdGhpcy5jaGVja2VkO1xuXG4gICAgICAgIC8vIEVtaXQgdGhlIGNoYW5nZSBldmVudC5cbiAgICAgICAgdGhpcy5vbkNoYW5nZSAmJiB0aGlzLm9uQ2hhbmdlKHRoaXMuY2hlY2tlZCk7XG4gICAgfVxuXG59XG4iLCI8aW5wdXQgW2lkXT1cImxhYmVsSWRcIlxuICAgICAgIFtjaGVja2VkXT1cImNoZWNrZWRcIlxuICAgICAgIFtkaXNhYmxlZF09XCJkaXNhYmxlZFwiXG4gICAgICAgKGNoYW5nZSk9XCJvbkludGVyYWN0aW9uRXZlbnQoJGV2ZW50KVwiXG4gICAgICAgKGNsaWNrKT1cIm9uSW5wdXRDbGljaygkZXZlbnQpXCJcbiAgICAgICBjbGFzcz1cImJiLWNoZWNrYm94LWlucHV0XCJcbiAgICAgICB0YWJpbmRleD1cIi0xXCJcbiAgICAgICB0eXBlPVwiY2hlY2tib3hcIj5cblxuPGxhYmVsIFtmb3JdPVwibGFiZWxJZFwiXG4gICAgICAgW2F0dHIudGFiaW5kZXhdPVwiZGlzYWJsZWQgPyAtMSA6ICh0YWJJbmRleCB8fCAwKVwiXG4gICAgICAgKGtleXVwLnNwYWNlKT1cIm9uSW5wdXRDbGljaygkZXZlbnQpXCJcbiAgICAgICBjbGFzcz1cImJiLWNoZWNrYm94LWxhYmVsXCI+XG4gICAgPHNwYW4+XG4gICAgICAgIDxzdmcgd2lkdGg9XCIxMnB4XCJcbiAgICAgICAgICAgICBoZWlnaHQ9XCIxMHB4XCJcbiAgICAgICAgICAgICB2aWV3Ym94PVwiMCAwIDEyIDEwXCI+XG4gICAgICAgICAgICA8cG9seWxpbmUgcG9pbnRzPVwiMS41IDYgNC41IDkgMTAuNSAxXCI+PC9wb2x5bGluZT5cbiAgICAgICAgPC9zdmc+XG4gICAgPC9zcGFuPlxuICAgIDxzcGFuPlxuICAgICAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4gICAgPC9zcGFuPlxuPC9sYWJlbD5cbiJdfQ==
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Directive, Host, HostBinding, Input, Optional, Self } from '@angular/core';
|
|
2
|
-
import { coerceBooleanProperty } from '@
|
|
2
|
+
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "@angular/forms";
|
|
5
5
|
import * as i2 from "../form-control/form-control.component";
|
|
@@ -133,4 +133,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.0", ngImpor
|
|
|
133
133
|
}] }]; }, propDecorators: { readonly: [{
|
|
134
134
|
type: Input
|
|
135
135
|
}] } });
|
|
136
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
136
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.directive.js","sourceRoot":"","sources":["../../../../../../projects/bb-foundation/elements/src/lib/directives/input.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Directive,\n    DoCheck,\n    ElementRef,\n    Host,\n    HostBinding,\n    Input,\n    OnDestroy,\n    OnInit,\n    Optional,\n    Self\n} from '@angular/core';\nimport {BbFormControl} from '../form-control/form-control.component';\nimport {coerceBooleanProperty} from '@angular/cdk/coercion';\nimport {NgControl} from '@angular/forms';\nimport {Subscription} from 'rxjs';\n\n@Directive({\n    selector: 'select[bbInput]',\n    host: {\n        '[disabled]': 'disabled',\n        '(focus)': 'setFocus(true)',\n        '(blur)': 'setFocus(false)'\n    }\n})\nexport class BbSelect implements OnInit, DoCheck, OnDestroy {\n\n    protected hasArrow: boolean = true;\n\n    private _subscription: Subscription;\n\n    constructor(protected _elementRef: ElementRef,\n                @Optional() @Self() protected _ngControl: NgControl,\n                @Optional() @Host() protected _formControl: BbFormControl) {\n    }\n\n    ngOnInit() {\n        // Set an arrow on the form control if\n        // it requires one.\n        this._formControl.arrow = this.hasArrow;\n    }\n\n    ngDoCheck() {\n        if (this._ngControl) {\n            this.disabled = this._ngControl.disabled;\n        }\n    }\n\n    ngOnDestroy() {\n        this._subscription?.unsubscribe();\n    }\n\n    focus() {\n        return this._elementRef?.nativeElement?.focus();\n    }\n\n    setFocus(hasFocus: boolean) {\n        if (!this._formControl) {\n            return;\n        }\n\n        this._formControl.focused = hasFocus;\n    }\n\n    @HostBinding('attr.id')\n    get id() {\n        return this._formControl?.labelId ?? null;\n    }\n\n    get disabled() {\n        if (this._ngControl && this._ngControl.disabled !== null) {\n            return this._ngControl.disabled;\n        }\n\n        return this._disabled;\n    }\n\n    @Input()\n    set disabled(newValue: boolean) {\n        this._disabled = coerceBooleanProperty(newValue);\n\n        if (!this._formControl) {\n            return;\n        }\n\n        this._formControl.disabled = this._disabled;\n    }\n\n    private _disabled = false;\n\n    get required() {\n        return this._required;\n    }\n\n    @Input()\n    set required(newValue: boolean) {\n        this._required = coerceBooleanProperty(newValue);\n\n        if (!this._formControl) {\n            return;\n        }\n\n        this._formControl.required = this._required;\n    }\n\n    private _required = false;\n\n}\n\n@Directive({\n    selector: 'input[bbInput], textarea[bbInput]',\n    host: {\n        '[disabled]': 'disabled',\n        '[readonly]': 'readonly',\n        '(focus)': 'setFocus(true)',\n        '(blur)': 'setFocus(false)'\n    }\n})\nexport class BbInput extends BbSelect {\n\n    protected override hasArrow: boolean = false;\n\n    constructor(protected override _elementRef: ElementRef,\n                @Optional() @Self() protected override _ngControl: NgControl,\n                @Optional() @Host() protected override _formControl: BbFormControl) {\n        super(_elementRef, _ngControl, _formControl);\n    }\n\n    get readonly() {\n        return this._readonly;\n    }\n\n    @Input()\n    set readonly(newValue: boolean) {\n        this._readonly = coerceBooleanProperty(newValue);\n\n        if (!this._formControl) {\n            return;\n        }\n\n        this._formControl.readonly = this._readonly;\n    }\n\n    private _readonly = false;\n\n}\n"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, Inject, Input, Optional, ViewEncapsulation } from '@angular/core';
|
|
2
2
|
import { ELEMENTS_ICONS } from '../elements.interfaces';
|
|
3
|
-
import { coerceBooleanProperty } from '@
|
|
3
|
+
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
4
4
|
import { BehaviorSubject } from 'rxjs';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "@angular/common";
|
|
@@ -99,4 +99,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.0", ngImpor
|
|
|
99
99
|
}], ariaHidden: [{
|
|
100
100
|
type: Input
|
|
101
101
|
}] } });
|
|
102
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
102
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icon.component.js","sourceRoot":"","sources":["../../../../../../projects/bb-foundation/elements/src/lib/icon/icon.component.ts","../../../../../../projects/bb-foundation/elements/src/lib/icon/icon.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, Inject, Input, Optional, ViewEncapsulation} from '@angular/core';\nimport {ELEMENTS_ICONS, ElementsIcon} from '../elements.interfaces';\nimport {coerceBooleanProperty} from '@angular/cdk/coercion';\nimport {BehaviorSubject} from 'rxjs';\n\n@Component({\n    selector: 'bb-icon',\n    templateUrl: './icon.component.html',\n    styleUrls: ['./icon.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    host: {\n        'class': 'bb-icon',\n        '[attr.aria-hidden]': 'ariaHidden',\n        '[style.width.px]': 'size',\n        '[style.height.px]': 'size',\n        '[style.min-width.px]': 'size',\n        '[style.min-height.px]': 'size',\n        '[style.font-size.px]': 'size'\n    },\n    preserveWhitespaces: false\n})\nexport class BbIcon {\n\n    // Data.\n    private _src: string | null = null;\n\n    // State.\n    state$ = new BehaviorSubject<any>(null);\n\n    @Input() alt: string | null = null;\n    @Input() size: number = 24;\n\n    @Input()\n    set src(newValue: string | null) {\n        this.state$.next(this.convert(newValue));\n        this._src = newValue;\n    }\n\n    get src() {\n        return this._src;\n    }\n\n    @Input()\n    set ariaHidden(newValue: boolean) {\n        this._ariaHidden = coerceBooleanProperty(newValue);\n    }\n\n    get ariaHidden() {\n        return this._ariaHidden;\n    }\n\n    private _ariaHidden = true;\n\n    constructor(@Optional() @Inject(ELEMENTS_ICONS) private _registry: ElementsIcon[]) {\n    }\n\n    private convert(src: string | null) {\n        const [namespace, value] = (src || '').split(':');\n\n        const onError = () => {\n            this.warn(`ElementsModule: The icon with src \"${src}\" could not be rendered correctly; Did you put a correct src attribute?`);\n            return {type: 'unknown'};\n        };\n\n        if (!namespace || !value || !this._registry) {\n            return onError();\n        }\n\n        // Try to find a image icon.\n        const imageIcon = this.findImageIcon(namespace, value);\n        if (imageIcon) {\n            return imageIcon;\n        }\n\n        // Try to find a font icon.\n        const fontIcon = this.findFontIcon(namespace, value);\n        if (fontIcon) {\n            return fontIcon;\n        }\n\n        // Return the on error function.\n        return onError();\n    }\n\n    private findImageIcon(namespace: string, value: string) {\n        const data = this._registry.find(item => item['namespace'] === namespace && item['name'] === value);\n\n        if (!data) {\n            return null;\n        }\n\n        return {type: data['type'], src: data['src']};\n    }\n\n    private findFontIcon(namespace: string, content: string) {\n        const data = this._registry.find(item => item['namespace'] === namespace);\n\n        if (!data) {\n            return null;\n        }\n\n        const uses = data['uses'];\n        if (uses === 'data-attribute') {\n            return {type: data['type'], className: data['className'], attribute: content};\n        }\n\n        return {type: data['type'], className: data['className'], content};\n    }\n\n    private warn = (content: string) => {\n        return console && console.warn && console.warn(content);\n    };\n\n}\n","<ng-container *ngIf=\"state$ | async as data\"\n              [ngSwitch]=\"data?.type\">\n    <i *ngSwitchCase=\"'font'\"\n       [attr.data-icon]=\"data?.attribute\"\n       [class]=\"data?.className\">\n        {{ data?.content }}\n    </i>\n    <img *ngSwitchCase=\"'image'\"\n         [src]=\"data?.src\"\n         [alt]=\"alt\">\n    <svg *ngSwitchCase=\"'unknown'\"\n         viewBox=\"0 0 1 1\">\n        <rect x=\"0\" y=\"0\" width=\"1\" height=\"1\" fill=\"#c5c5c5\"></rect>\n    </svg>\n</ng-container>\n"]}
|