@factor_ec/ui 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,327 @@
1
+ import * as i0 from '@angular/core';
2
+ import { Component, Input, HostBinding, Inject, NgModule } from '@angular/core';
3
+ import * as i1 from '@factor_ec/utils';
4
+ import * as i1$1 from '@angular/common';
5
+ import { CommonModule } from '@angular/common';
6
+
7
+ class AvatarComponent {
8
+ constructor(colorService) {
9
+ this.colorService = colorService;
10
+ this.class = '';
11
+ }
12
+ set src(value) {
13
+ if (value && value.trim() != '') {
14
+ this._src = value;
15
+ let image = new Image();
16
+ image.src = value;
17
+ image.onload = () => {
18
+ if ("decode" in image) {
19
+ image.decode().then(() => {
20
+ this.loaded = true;
21
+ });
22
+ }
23
+ else {
24
+ console.error('Image.decode not available.');
25
+ }
26
+ };
27
+ }
28
+ }
29
+ set label(value) {
30
+ this._label = value;
31
+ this.initials = this.getInitials(value);
32
+ }
33
+ get backgroundColor() {
34
+ return this.color || this.colorService.hex(this._label);
35
+ }
36
+ get backgroundImage() {
37
+ return this._src ? `url(${this._src})` : '';
38
+ }
39
+ get hostClasses() {
40
+ return [
41
+ 'ft-avatar',
42
+ this.class
43
+ ].join(' ');
44
+ }
45
+ ngOnInit() {
46
+ }
47
+ getInitials(value) {
48
+ let allInitials = value.match(/\b\w/g) || [];
49
+ let initials = ((allInitials.shift() || '') + (allInitials.pop() || '')).toUpperCase();
50
+ return initials;
51
+ }
52
+ }
53
+ AvatarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: AvatarComponent, deps: [{ token: i1.ColorService }], target: i0.ɵɵFactoryTarget.Component });
54
+ AvatarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.0", type: AvatarComponent, selector: "ft-avatar", inputs: { color: "color", class: "class", src: "src", label: "label" }, host: { properties: { "style.background-color": "this.backgroundColor", "style.background-image": "this.backgroundImage", "class": "this.hostClasses" } }, ngImport: i0, template: "<div *ngIf=\"!loaded\">{{ initials }}</div>\n", styles: [":host{--default-size: var(--size, 3rem);display:inline-flex;align-items:center;justify-content:center;color:#fff;background-size:cover;background-repeat:no-repeat;border-radius:calc(var(--default-size) / 2);font-size:calc(var(--default-size) - var(--default-size) * .6);min-width:var(--default-size);min-height:var(--default-size);cursor:default;-webkit-user-select:none;user-select:none}div{font-size:1em;line-height:1em}\n"], dependencies: [{ kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
55
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: AvatarComponent, decorators: [{
56
+ type: Component,
57
+ args: [{ selector: 'ft-avatar', template: "<div *ngIf=\"!loaded\">{{ initials }}</div>\n", styles: [":host{--default-size: var(--size, 3rem);display:inline-flex;align-items:center;justify-content:center;color:#fff;background-size:cover;background-repeat:no-repeat;border-radius:calc(var(--default-size) / 2);font-size:calc(var(--default-size) - var(--default-size) * .6);min-width:var(--default-size);min-height:var(--default-size);cursor:default;-webkit-user-select:none;user-select:none}div{font-size:1em;line-height:1em}\n"] }]
58
+ }], ctorParameters: function () { return [{ type: i1.ColorService }]; }, propDecorators: { color: [{
59
+ type: Input
60
+ }], class: [{
61
+ type: Input
62
+ }], src: [{
63
+ type: Input
64
+ }], label: [{
65
+ type: Input
66
+ }], backgroundColor: [{
67
+ type: HostBinding,
68
+ args: ['style.background-color']
69
+ }], backgroundImage: [{
70
+ type: HostBinding,
71
+ args: ['style.background-image']
72
+ }], hostClasses: [{
73
+ type: HostBinding,
74
+ args: ['class']
75
+ }] } });
76
+
77
+ class IconComponent {
78
+ constructor(configuration) {
79
+ this.configuration = configuration;
80
+ this.class = '';
81
+ }
82
+ set collection(collection) {
83
+ this._collection = collection;
84
+ this.update();
85
+ }
86
+ set mode(mode) {
87
+ this._mode = mode;
88
+ this.update();
89
+ }
90
+ set name(name) {
91
+ this._name = name;
92
+ this.update();
93
+ }
94
+ set path(path) {
95
+ this._path = path;
96
+ this.update();
97
+ }
98
+ get hostClasses() {
99
+ return [
100
+ 'ft-icon',
101
+ this.class
102
+ ].join(' ');
103
+ }
104
+ ngOnInit() {
105
+ this.update();
106
+ }
107
+ update() {
108
+ // Set the default collection if the mode is external
109
+ if (!this._collection) {
110
+ if (this.configuration.icon && this.configuration.icon.collection) {
111
+ this._collection = this.configuration.icon.collection;
112
+ }
113
+ else if (this._mode === 'external') {
114
+ this._collection = 'icons';
115
+ }
116
+ }
117
+ if (!this._mode) {
118
+ if (this.configuration.icon && this.configuration.icon.mode) {
119
+ this._mode = this.configuration.icon.mode;
120
+ }
121
+ else {
122
+ this._mode = 'external';
123
+ }
124
+ }
125
+ if (this._mode === 'external') {
126
+ // If the icon mode is external
127
+ if (!this._path) {
128
+ if (this.configuration.icon && this.configuration.icon.path) {
129
+ this._path = this.configuration.icon.path;
130
+ }
131
+ else {
132
+ this._path = 'assets';
133
+ }
134
+ }
135
+ this.url = `${this._path}/${this._collection}.svg#${this._name}`;
136
+ }
137
+ else {
138
+ // If the icon mode is inline
139
+ const name = this._collection && this._collection !== 'unset' ? `${this._collection}--${this._name}` : this._name;
140
+ this.url = `#${name}`;
141
+ }
142
+ }
143
+ }
144
+ IconComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: IconComponent, deps: [{ token: 'FactorUiConfiguration' }], target: i0.ɵɵFactoryTarget.Component });
145
+ IconComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.0", type: IconComponent, selector: "ft-icon", inputs: { class: "class", collection: "collection", mode: "mode", name: "name", path: "path", size: "size", src: "src" }, host: { properties: { "class": "this.hostClasses" } }, ngImport: i0, template: "<svg *ngIf=\"!src; else imageTemplate\"><use attr.xlink:href=\"{{ url }}\" attr.href=\"{{ url }}\" /></svg>\n<ng-template #imageTemplate>\n <img [src]=\"src\" />\n</ng-template>", styles: [":host{line-height:0;display:inline-block}:host[size=\"1\"],:host.ft-icon--1{font-size:1rem}:host[size=\"2\"],:host.ft-icon--2{font-size:1.5rem}:host[size=\"3\"],:host.ft-icon--3{font-size:2rem}:host[size=\"4\"],:host.ft-icon--4{font-size:3rem}:host[size=\"5\"],:host.ft-icon--5{font-size:4.5rem}:host[size=\"6\"],:host.ft-icon--6{font-size:8rem}:host[size=\"7\"],:host.ft-icon--7{font-size:16rem}:host[size=\"8\"],:host.ft-icon--8{font-size:32rem}svg{width:1em;height:1em;vertical-align:middle;fill:currentColor}img{height:1em;vertical-align:middle}\n"], dependencies: [{ kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
146
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: IconComponent, decorators: [{
147
+ type: Component,
148
+ args: [{ selector: 'ft-icon', template: "<svg *ngIf=\"!src; else imageTemplate\"><use attr.xlink:href=\"{{ url }}\" attr.href=\"{{ url }}\" /></svg>\n<ng-template #imageTemplate>\n <img [src]=\"src\" />\n</ng-template>", styles: [":host{line-height:0;display:inline-block}:host[size=\"1\"],:host.ft-icon--1{font-size:1rem}:host[size=\"2\"],:host.ft-icon--2{font-size:1.5rem}:host[size=\"3\"],:host.ft-icon--3{font-size:2rem}:host[size=\"4\"],:host.ft-icon--4{font-size:3rem}:host[size=\"5\"],:host.ft-icon--5{font-size:4.5rem}:host[size=\"6\"],:host.ft-icon--6{font-size:8rem}:host[size=\"7\"],:host.ft-icon--7{font-size:16rem}:host[size=\"8\"],:host.ft-icon--8{font-size:32rem}svg{width:1em;height:1em;vertical-align:middle;fill:currentColor}img{height:1em;vertical-align:middle}\n"] }]
149
+ }], ctorParameters: function () { return [{ type: undefined, decorators: [{
150
+ type: Inject,
151
+ args: ['FactorUiConfiguration']
152
+ }] }]; }, propDecorators: { class: [{
153
+ type: Input
154
+ }], collection: [{
155
+ type: Input
156
+ }], mode: [{
157
+ type: Input
158
+ }], name: [{
159
+ type: Input
160
+ }], path: [{
161
+ type: Input
162
+ }], size: [{
163
+ type: Input
164
+ }], src: [{
165
+ type: Input
166
+ }], hostClasses: [{
167
+ type: HostBinding,
168
+ args: ['class']
169
+ }] } });
170
+
171
+ class ImageComponent {
172
+ constructor(element) {
173
+ this.element = element;
174
+ this.class = '';
175
+ this.loading = false;
176
+ this.shown = false;
177
+ }
178
+ ngOnInit() {
179
+ if ("IntersectionObserver" in window) {
180
+ let elementObserver = new IntersectionObserver((entries, observer) => {
181
+ entries.forEach((entry) => {
182
+ if (entry.isIntersecting) {
183
+ let image = new Image();
184
+ image.src = this.src;
185
+ setTimeout(() => {
186
+ if (!this.shown && !this.error) {
187
+ this.loading = true;
188
+ }
189
+ }, 100);
190
+ image.onerror = () => {
191
+ this.error = true;
192
+ this.loading = false;
193
+ };
194
+ image.onload = () => {
195
+ if ("decode" in image) {
196
+ image.decode().then(() => {
197
+ this.loading = false;
198
+ this.shown = true;
199
+ });
200
+ }
201
+ else {
202
+ this.loading = false;
203
+ this.shown = true;
204
+ }
205
+ };
206
+ elementObserver.unobserve(this.element.nativeElement);
207
+ }
208
+ });
209
+ }, {
210
+ rootMargin: "0px 0px 200px 0px"
211
+ });
212
+ elementObserver.observe(this.element.nativeElement);
213
+ }
214
+ else {
215
+ console.error('IntersectionObserver not available.');
216
+ this.loading = false;
217
+ this.shown = true;
218
+ }
219
+ }
220
+ get hostClasses() {
221
+ return [
222
+ 'ft-image',
223
+ this.class
224
+ ].join(' ');
225
+ }
226
+ }
227
+ ImageComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: ImageComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
228
+ ImageComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.0", type: ImageComponent, selector: "ft-image", inputs: { class: "class", src: "src" }, host: { properties: { "class.ft-image--error": "this.error", "class.ft-image--loading": "this.loading", "class": "this.hostClasses" } }, ngImport: i0, template: "<img *ngIf=\"shown\" [src]=\"src\" />\n<ft-icon name=\"warning\" size=\"2\" *ngIf=\"error\"></ft-icon>\n", styles: [":host{display:inline-block;overflow:hidden;display:flex;align-items:center;justify-content:center}:host.ft-image--loading{background-color:#00000008;position:relative;overflow:hidden}:host.ft-image--loading:after{content:\"\";display:block;background-color:#00000005;position:absolute;top:0;bottom:0;width:100%;height:100%;transform:translate(0);animation:1.5s placeholder-loading ease-in-out infinite}:host.ft-image--error{background-color:#ff000008}:host.ft-image--error ft-icon{color:var(--danger)}img{position:relative;z-index:1;max-width:100%;max-height:100%;animation:fade-in .3s}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes placeholder-loading{0%{transform:translate(-100%)}to{transform:translate(100%)}}\n"], dependencies: [{ kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: IconComponent, selector: "ft-icon", inputs: ["class", "collection", "mode", "name", "path", "size", "src"] }] });
229
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: ImageComponent, decorators: [{
230
+ type: Component,
231
+ args: [{ selector: 'ft-image', template: "<img *ngIf=\"shown\" [src]=\"src\" />\n<ft-icon name=\"warning\" size=\"2\" *ngIf=\"error\"></ft-icon>\n", styles: [":host{display:inline-block;overflow:hidden;display:flex;align-items:center;justify-content:center}:host.ft-image--loading{background-color:#00000008;position:relative;overflow:hidden}:host.ft-image--loading:after{content:\"\";display:block;background-color:#00000005;position:absolute;top:0;bottom:0;width:100%;height:100%;transform:translate(0);animation:1.5s placeholder-loading ease-in-out infinite}:host.ft-image--error{background-color:#ff000008}:host.ft-image--error ft-icon{color:var(--danger)}img{position:relative;z-index:1;max-width:100%;max-height:100%;animation:fade-in .3s}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes placeholder-loading{0%{transform:translate(-100%)}to{transform:translate(100%)}}\n"] }]
232
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { class: [{
233
+ type: Input
234
+ }], error: [{
235
+ type: HostBinding,
236
+ args: ['class.ft-image--error']
237
+ }], loading: [{
238
+ type: HostBinding,
239
+ args: ['class.ft-image--loading']
240
+ }], src: [{
241
+ type: Input
242
+ }], hostClasses: [{
243
+ type: HostBinding,
244
+ args: ['class']
245
+ }] } });
246
+
247
+ class ProgressComponent {
248
+ constructor() {
249
+ this.class = '';
250
+ this.mode = 'indeterminate';
251
+ this.overlay = false;
252
+ }
253
+ ngOnInit() {
254
+ this.value = 0;
255
+ }
256
+ get hostClasses() {
257
+ return [
258
+ 'ft-progress',
259
+ this.overlay ? 'ft-progress--overlay' : '',
260
+ this.class
261
+ ].join(' ');
262
+ }
263
+ }
264
+ ProgressComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: ProgressComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
265
+ ProgressComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.0", type: ProgressComponent, selector: "ft-progress", inputs: { class: "class", color: "color", mode: "mode", overlay: "overlay", size: "size", value: "value" }, host: { properties: { "class": "this.hostClasses" } }, ngImport: i0, template: "<svg [ngStyle]=\"{'--bar-color': color}\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 100 100\" preserveAspectRatio=\"xMidYMid\">\n <circle class=\"track\" cx=\"50\" cy=\"50\" r=\"40\" />\n <circle class=\"bar\" [ngClass]=\"mode\" cx=\"50\" cy=\"50\" r=\"40\"\n [ngStyle]=\"{'stroke-dashoffset': mode=='determinate'? 'calc((3.14159265 * 40 * 2 * (100 - '+value+')) / 100)' : null}\">\n </circle>\n</svg>", styles: [":host{--track-color: rgba(0, 0, 0, .08);--bar-color: var(--primary);line-height:0;display:inline-block}:host[size=\"1\"],:host.ft-progress--1{font-size:1rem}:host[size=\"2\"],:host.ft-progress--2{font-size:1.5rem}:host[size=\"3\"],:host.ft-progress--3{font-size:2rem}:host[size=\"4\"],:host.ft-progress--4{font-size:3rem}:host[size=\"5\"],:host.ft-progress--5{font-size:4.5rem}:host[size=\"6\"],:host.ft-progress--6{font-size:8rem}:host[size=\"7\"],:host.ft-progress--7{font-size:16rem}:host[size=\"8\"],:host.ft-progress--8{font-size:32rem}:host.ft-progress--overlay{position:fixed;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:var(--z-index-modal, 1000);top:0;left:0;right:0;bottom:0;font-size:42px}:host.ft-progress--overlay svg{background:rgba(255,255,255,.6);-webkit-backdrop-filter:saturate(50%) blur(3px);backdrop-filter:saturate(50%) blur(3px);box-shadow:0 3px 3px -2px #0003,0 3px 4px #00000024,0 1px 8px #0000001f;border-radius:100vh;padding:.3125rem;animation:progress-reveal .2s;animation-fill-mode:forwards}:host.ft-progress--overlay svg .track{display:none}svg{width:1em;height:1em;vertical-align:middle}svg .track{fill:none;stroke-width:10;stroke:var(--track-color)}svg .bar{fill:none;stroke-opacity:.9;stroke-width:6;stroke:var(--bar-color)}svg .bar.indeterminate{animation:progress-rotation 2s infinite linear}svg .bar.determinate{stroke-dasharray:251.327412288}@keyframes progress-reveal{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes progress-rotation{0%{stroke-dashoffset:0;stroke-dasharray:150.6 100.4}50%{stroke-dasharray:1 250}to{stroke-dashoffset:502;stroke-dasharray:150.6 100.4}}\n"], dependencies: [{ kind: "directive", type: i1$1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1$1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
266
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: ProgressComponent, decorators: [{
267
+ type: Component,
268
+ args: [{ selector: 'ft-progress', template: "<svg [ngStyle]=\"{'--bar-color': color}\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 100 100\" preserveAspectRatio=\"xMidYMid\">\n <circle class=\"track\" cx=\"50\" cy=\"50\" r=\"40\" />\n <circle class=\"bar\" [ngClass]=\"mode\" cx=\"50\" cy=\"50\" r=\"40\"\n [ngStyle]=\"{'stroke-dashoffset': mode=='determinate'? 'calc((3.14159265 * 40 * 2 * (100 - '+value+')) / 100)' : null}\">\n </circle>\n</svg>", styles: [":host{--track-color: rgba(0, 0, 0, .08);--bar-color: var(--primary);line-height:0;display:inline-block}:host[size=\"1\"],:host.ft-progress--1{font-size:1rem}:host[size=\"2\"],:host.ft-progress--2{font-size:1.5rem}:host[size=\"3\"],:host.ft-progress--3{font-size:2rem}:host[size=\"4\"],:host.ft-progress--4{font-size:3rem}:host[size=\"5\"],:host.ft-progress--5{font-size:4.5rem}:host[size=\"6\"],:host.ft-progress--6{font-size:8rem}:host[size=\"7\"],:host.ft-progress--7{font-size:16rem}:host[size=\"8\"],:host.ft-progress--8{font-size:32rem}:host.ft-progress--overlay{position:fixed;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:var(--z-index-modal, 1000);top:0;left:0;right:0;bottom:0;font-size:42px}:host.ft-progress--overlay svg{background:rgba(255,255,255,.6);-webkit-backdrop-filter:saturate(50%) blur(3px);backdrop-filter:saturate(50%) blur(3px);box-shadow:0 3px 3px -2px #0003,0 3px 4px #00000024,0 1px 8px #0000001f;border-radius:100vh;padding:.3125rem;animation:progress-reveal .2s;animation-fill-mode:forwards}:host.ft-progress--overlay svg .track{display:none}svg{width:1em;height:1em;vertical-align:middle}svg .track{fill:none;stroke-width:10;stroke:var(--track-color)}svg .bar{fill:none;stroke-opacity:.9;stroke-width:6;stroke:var(--bar-color)}svg .bar.indeterminate{animation:progress-rotation 2s infinite linear}svg .bar.determinate{stroke-dasharray:251.327412288}@keyframes progress-reveal{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes progress-rotation{0%{stroke-dashoffset:0;stroke-dasharray:150.6 100.4}50%{stroke-dasharray:1 250}to{stroke-dashoffset:502;stroke-dasharray:150.6 100.4}}\n"] }]
269
+ }], ctorParameters: function () { return []; }, propDecorators: { class: [{
270
+ type: Input
271
+ }], color: [{
272
+ type: Input
273
+ }], mode: [{
274
+ type: Input
275
+ }], overlay: [{
276
+ type: Input
277
+ }], size: [{
278
+ type: Input
279
+ }], value: [{
280
+ type: Input
281
+ }], hostClasses: [{
282
+ type: HostBinding,
283
+ args: ['class']
284
+ }] } });
285
+
286
+ class UiModule {
287
+ }
288
+ UiModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: UiModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
289
+ UiModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.0.0", ngImport: i0, type: UiModule, declarations: [AvatarComponent,
290
+ IconComponent,
291
+ ImageComponent,
292
+ ProgressComponent], imports: [CommonModule], exports: [AvatarComponent,
293
+ IconComponent,
294
+ ImageComponent,
295
+ ProgressComponent] });
296
+ UiModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: UiModule, imports: [CommonModule] });
297
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0", ngImport: i0, type: UiModule, decorators: [{
298
+ type: NgModule,
299
+ args: [{
300
+ declarations: [
301
+ AvatarComponent,
302
+ IconComponent,
303
+ ImageComponent,
304
+ ProgressComponent
305
+ ],
306
+ imports: [
307
+ CommonModule
308
+ ],
309
+ exports: [
310
+ AvatarComponent,
311
+ IconComponent,
312
+ ImageComponent,
313
+ ProgressComponent
314
+ ]
315
+ }]
316
+ }] });
317
+
318
+ /*
319
+ * Public API Surface of ui
320
+ */
321
+
322
+ /**
323
+ * Generated bundle index. Do not edit.
324
+ */
325
+
326
+ export { AvatarComponent, IconComponent, ImageComponent, ProgressComponent, UiModule };
327
+ //# sourceMappingURL=factor_ec-ui.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"factor_ec-ui.mjs","sources":["../../../projects/ui/src/lib/avatar/avatar.component.ts","../../../projects/ui/src/lib/avatar/avatar.component.html","../../../projects/ui/src/lib/icon/icon.component.ts","../../../projects/ui/src/lib/icon/icon.component.html","../../../projects/ui/src/lib/image/image.component.ts","../../../projects/ui/src/lib/image/image.component.html","../../../projects/ui/src/lib/progress/progress.component.ts","../../../projects/ui/src/lib/progress/progress.component.html","../../../projects/ui/src/lib/ui.module.ts","../../../projects/ui/src/public-api.ts","../../../projects/ui/src/factor_ec-ui.ts"],"sourcesContent":["import { Component, HostBinding, Input, OnInit } from '@angular/core';\nimport { ColorService } from '@factor_ec/utils';\n\n@Component({\n selector: 'ft-avatar',\n templateUrl: './avatar.component.html',\n styleUrls: ['./avatar.component.scss']\n})\nexport class AvatarComponent implements OnInit {\n _label!: string;\n _src!: string;\n @Input()\n color!: string;\n initials!: string;\n loaded!: boolean;\n @Input()\n class: string = '';\n @Input()\n set src(value: string) {\n if (value && value.trim()!='') {\n this._src = value;\n let image = new Image();\n image.src = value;\n image.onload = () => {\n if (\"decode\" in image) {\n image.decode().then(() => {\n this.loaded = true;\n });\n } else {\n console.error('Image.decode not available.');\n }\n };\n }\n }\n @Input()\n set label(value: string) {\n this._label = value;\n this.initials = this.getInitials(value);\n }\n @HostBinding('style.background-color')\n get backgroundColor(): string {\n return this.color || this.colorService.hex(this._label);\n }\n @HostBinding('style.background-image')\n get backgroundImage(): string {\n return this._src ? `url(${this._src})` : '';\n }\n @HostBinding('class')\n get hostClasses(): string {\n return [\n 'ft-avatar',\n this.class\n ].join(' ');\n }\n\n constructor(\n private colorService: ColorService\n ) { }\n\n ngOnInit() {\n\n }\n getInitials(value: string): string {\n let allInitials: string[] = value.match(/\\b\\w/g) || [];\n let initials: string = ((allInitials.shift() || '') + (allInitials.pop() || '')).toUpperCase();\n return initials;\n }\n\n}\n","<div *ngIf=\"!loaded\">{{ initials }}</div>\n","import { Component, OnInit, Input, Inject, HostBinding } from '@angular/core';\nimport { UiConfiguration } from '../models/ui-configuration';\n\n@Component({\n selector: 'ft-icon',\n templateUrl: './icon.component.html',\n styleUrls: ['./icon.component.scss']\n})\nexport class IconComponent implements OnInit {\n _collection!: string;\n _name!: string;\n _mode!: 'inline' | 'external';\n _path!: string;\n @Input()\n class: string = '';\n @Input()\n set collection(collection: string) {\n this._collection = collection;\n this.update();\n }\n @Input()\n set mode(mode: 'inline' | 'external') {\n this._mode = mode;\n this.update();\n }\n @Input()\n set name(name: string) {\n this._name = name;\n this.update();\n } \n @Input()\n set path(path: string) {\n this._path = path;\n this.update();\n }\n @Input()\n size!: string;\n @Input()\n src!: string;\n url!: string;\n @HostBinding('class')\n get hostClasses(): string {\n return [\n 'ft-icon',\n this.class\n ].join(' ');\n }\n\n constructor(\n @Inject('FactorUiConfiguration') private configuration: UiConfiguration\n ) { }\n\n ngOnInit() {\n this.update();\n }\n private update() {\n // Set the default collection if the mode is external\n if (!this._collection) {\n if (this.configuration.icon && this.configuration.icon.collection) {\n this._collection = this.configuration.icon.collection;\n } else if (this._mode === 'external') {\n this._collection = 'icons';\n }\n }\n if (!this._mode) {\n if (this.configuration.icon && this.configuration.icon.mode) {\n this._mode = this.configuration.icon.mode;\n } else {\n this._mode = 'external';\n }\n }\n if (this._mode === 'external') {\n // If the icon mode is external\n if (!this._path) {\n if (this.configuration.icon && this.configuration.icon.path) {\n this._path = this.configuration.icon.path;\n } else {\n this._path = 'assets';\n }\n }\n this.url = `${ this._path }/${ this._collection }.svg#${this._name}`;\n } else {\n // If the icon mode is inline\n const name = this._collection && this._collection !== 'unset' ? `${this._collection}--${this._name}` : this._name;\n this.url = `#${name}`;\n }\n }\n}\n","<svg *ngIf=\"!src; else imageTemplate\"><use attr.xlink:href=\"{{ url }}\" attr.href=\"{{ url }}\" /></svg>\n<ng-template #imageTemplate>\n <img [src]=\"src\" />\n</ng-template>","import { Component, OnInit, Input, HostBinding, ElementRef } from '@angular/core';\n\n@Component({\n selector: 'ft-image',\n templateUrl: './image.component.html',\n styleUrls: ['./image.component.scss']\n})\nexport class ImageComponent implements OnInit {\n @Input()\n class: string = '';\n @HostBinding('class.ft-image--error')\n error!: boolean;\n @HostBinding('class.ft-image--loading')\n loading: boolean = false;\n @Input()\n src!: string;\n shown: boolean = false;\n\n constructor(\n private element: ElementRef\n ) { }\n\n ngOnInit() {\n if (\"IntersectionObserver\" in window) {\n let elementObserver = new IntersectionObserver((entries, observer) => {\n entries.forEach((entry) => {\n if (entry.isIntersecting) {\n let image = new Image();\n image.src = this.src;\n setTimeout(() => {\n if (!this.shown && !this.error) {\n this.loading = true;\n }\n }, 100);\n image.onerror = () => {\n this.error = true;\n this.loading = false;\n };\n image.onload = () => {\n if (\"decode\" in image) {\n image.decode().then(() => {\n this.loading = false;\n this.shown = true;\n });\n } else {\n this.loading = false;\n this.shown = true;\n }\n };\n elementObserver.unobserve(this.element.nativeElement);\n }\n });\n }, {\n rootMargin: \"0px 0px 200px 0px\"\n });\n elementObserver.observe(this.element.nativeElement);\n } else {\n console.error('IntersectionObserver not available.');\n this.loading = false;\n this.shown = true;\n }\n }\n @HostBinding('class')\n get hostClasses(): string {\n return [\n 'ft-image',\n this.class\n ].join(' ');\n }\n\n}\n","<img *ngIf=\"shown\" [src]=\"src\" />\n<ft-icon name=\"warning\" size=\"2\" *ngIf=\"error\"></ft-icon>\n","import { Component, OnInit, Input, HostBinding } from '@angular/core';\n\n@Component({\n selector: 'ft-progress',\n templateUrl: './progress.component.html',\n styleUrls: ['./progress.component.scss']\n})\nexport class ProgressComponent implements OnInit {\n @Input()\n class: string = '';\n @Input()\n color!: string;\n @Input()\n mode: 'determinate' | 'indeterminate' = 'indeterminate';\n @Input()\n overlay: boolean = false;\n @Input()\n size!: number;\n @Input()\n value!: number;\n\n constructor() { }\n\n ngOnInit() {\n this.value = 0;\n }\n @HostBinding('class')\n get hostClasses(): string {\n return [\n 'ft-progress',\n this.overlay ? 'ft-progress--overlay' : '',\n this.class\n ].join(' ');\n }\n\n}\n","<svg [ngStyle]=\"{'--bar-color': color}\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 100 100\" preserveAspectRatio=\"xMidYMid\">\n <circle class=\"track\" cx=\"50\" cy=\"50\" r=\"40\" />\n <circle class=\"bar\" [ngClass]=\"mode\" cx=\"50\" cy=\"50\" r=\"40\"\n [ngStyle]=\"{'stroke-dashoffset': mode=='determinate'? 'calc((3.14159265 * 40 * 2 * (100 - '+value+')) / 100)' : null}\">\n </circle>\n</svg>","import { CommonModule } from '@angular/common';\nimport { NgModule } from '@angular/core';\nimport { AvatarComponent } from './avatar/avatar.component';\nimport { IconComponent } from './icon/icon.component';\nimport { ImageComponent } from './image/image.component';\nimport { ProgressComponent } from './progress/progress.component';\n\n\n\n@NgModule({\n declarations: [\n AvatarComponent,\n IconComponent,\n ImageComponent,\n ProgressComponent\n ],\n imports: [\n CommonModule\n ],\n exports: [\n AvatarComponent,\n IconComponent,\n ImageComponent,\n ProgressComponent\n ]\n})\nexport class UiModule { }\n","/*\n * Public API Surface of ui\n */\n\nexport * from './lib/avatar/avatar.component';\nexport * from './lib/icon/icon.component';\nexport * from './lib/image/image.component';\nexport * from './lib/progress/progress.component';\nexport * from './lib/ui.module';\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":["i2","i1","i2.IconComponent"],"mappings":"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"}
package/index.d.ts ADDED
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ /// <amd-module name="@factor_ec/ui" />
5
+ export * from './public-api';
@@ -0,0 +1,22 @@
1
+ import { OnInit } from '@angular/core';
2
+ import { ColorService } from '@factor_ec/utils';
3
+ import * as i0 from "@angular/core";
4
+ export declare class AvatarComponent implements OnInit {
5
+ private colorService;
6
+ _label: string;
7
+ _src: string;
8
+ color: string;
9
+ initials: string;
10
+ loaded: boolean;
11
+ class: string;
12
+ set src(value: string);
13
+ set label(value: string);
14
+ get backgroundColor(): string;
15
+ get backgroundImage(): string;
16
+ get hostClasses(): string;
17
+ constructor(colorService: ColorService);
18
+ ngOnInit(): void;
19
+ getInitials(value: string): string;
20
+ static ɵfac: i0.ɵɵFactoryDeclaration<AvatarComponent, never>;
21
+ static ɵcmp: i0.ɵɵComponentDeclaration<AvatarComponent, "ft-avatar", never, { "color": "color"; "class": "class"; "src": "src"; "label": "label"; }, {}, never, never, false>;
22
+ }
@@ -0,0 +1,24 @@
1
+ import { OnInit } from '@angular/core';
2
+ import { UiConfiguration } from '../models/ui-configuration';
3
+ import * as i0 from "@angular/core";
4
+ export declare class IconComponent implements OnInit {
5
+ private configuration;
6
+ _collection: string;
7
+ _name: string;
8
+ _mode: 'inline' | 'external';
9
+ _path: string;
10
+ class: string;
11
+ set collection(collection: string);
12
+ set mode(mode: 'inline' | 'external');
13
+ set name(name: string);
14
+ set path(path: string);
15
+ size: string;
16
+ src: string;
17
+ url: string;
18
+ get hostClasses(): string;
19
+ constructor(configuration: UiConfiguration);
20
+ ngOnInit(): void;
21
+ private update;
22
+ static ɵfac: i0.ɵɵFactoryDeclaration<IconComponent, never>;
23
+ static ɵcmp: i0.ɵɵComponentDeclaration<IconComponent, "ft-icon", never, { "class": "class"; "collection": "collection"; "mode": "mode"; "name": "name"; "path": "path"; "size": "size"; "src": "src"; }, {}, never, never, false>;
24
+ }
@@ -0,0 +1,15 @@
1
+ import { OnInit, ElementRef } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export declare class ImageComponent implements OnInit {
4
+ private element;
5
+ class: string;
6
+ error: boolean;
7
+ loading: boolean;
8
+ src: string;
9
+ shown: boolean;
10
+ constructor(element: ElementRef);
11
+ ngOnInit(): void;
12
+ get hostClasses(): string;
13
+ static ɵfac: i0.ɵɵFactoryDeclaration<ImageComponent, never>;
14
+ static ɵcmp: i0.ɵɵComponentDeclaration<ImageComponent, "ft-image", never, { "class": "class"; "src": "src"; }, {}, never, never, false>;
15
+ }
@@ -0,0 +1,7 @@
1
+ export interface UiConfiguration {
2
+ icon: {
3
+ mode: 'external' | null;
4
+ collection: string;
5
+ path: string;
6
+ };
7
+ }
@@ -0,0 +1,15 @@
1
+ import { OnInit } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export declare class ProgressComponent implements OnInit {
4
+ class: string;
5
+ color: string;
6
+ mode: 'determinate' | 'indeterminate';
7
+ overlay: boolean;
8
+ size: number;
9
+ value: number;
10
+ constructor();
11
+ ngOnInit(): void;
12
+ get hostClasses(): string;
13
+ static ɵfac: i0.ɵɵFactoryDeclaration<ProgressComponent, never>;
14
+ static ɵcmp: i0.ɵɵComponentDeclaration<ProgressComponent, "ft-progress", never, { "class": "class"; "color": "color"; "mode": "mode"; "overlay": "overlay"; "size": "size"; "value": "value"; }, {}, never, never, false>;
15
+ }
@@ -0,0 +1,11 @@
1
+ import * as i0 from "@angular/core";
2
+ import * as i1 from "./avatar/avatar.component";
3
+ import * as i2 from "./icon/icon.component";
4
+ import * as i3 from "./image/image.component";
5
+ import * as i4 from "./progress/progress.component";
6
+ import * as i5 from "@angular/common";
7
+ export declare class UiModule {
8
+ static ɵfac: i0.ɵɵFactoryDeclaration<UiModule, never>;
9
+ static ɵmod: i0.ɵɵNgModuleDeclaration<UiModule, [typeof i1.AvatarComponent, typeof i2.IconComponent, typeof i3.ImageComponent, typeof i4.ProgressComponent], [typeof i5.CommonModule], [typeof i1.AvatarComponent, typeof i2.IconComponent, typeof i3.ImageComponent, typeof i4.ProgressComponent]>;
10
+ static ɵinj: i0.ɵɵInjectorDeclaration<UiModule>;
11
+ }
package/package.json ADDED
@@ -0,0 +1,35 @@
1
+ {
2
+ "name": "@factor_ec/ui",
3
+ "version": "1.0.0",
4
+ "license": "CC-BY-NC-ND-4.0",
5
+ "author": "Factor",
6
+ "private": false,
7
+ "peerDependencies": {
8
+ "@angular/common": "^14.0.0",
9
+ "@angular/core": "^14.0.0",
10
+ "@factor_ec/utils": "^1.0.1"
11
+ },
12
+ "dependencies": {
13
+ "tslib": "^2.3.0"
14
+ },
15
+ "module": "fesm2015/factor_ec-ui.mjs",
16
+ "es2020": "fesm2020/factor_ec-ui.mjs",
17
+ "esm2020": "esm2020/factor_ec-ui.mjs",
18
+ "fesm2020": "fesm2020/factor_ec-ui.mjs",
19
+ "fesm2015": "fesm2015/factor_ec-ui.mjs",
20
+ "typings": "index.d.ts",
21
+ "exports": {
22
+ "./package.json": {
23
+ "default": "./package.json"
24
+ },
25
+ ".": {
26
+ "types": "./index.d.ts",
27
+ "esm2020": "./esm2020/factor_ec-ui.mjs",
28
+ "es2020": "./fesm2020/factor_ec-ui.mjs",
29
+ "es2015": "./fesm2015/factor_ec-ui.mjs",
30
+ "node": "./fesm2015/factor_ec-ui.mjs",
31
+ "default": "./fesm2020/factor_ec-ui.mjs"
32
+ }
33
+ },
34
+ "sideEffects": false
35
+ }
@@ -0,0 +1,5 @@
1
+ export * from './lib/avatar/avatar.component';
2
+ export * from './lib/icon/icon.component';
3
+ export * from './lib/image/image.component';
4
+ export * from './lib/progress/progress.component';
5
+ export * from './lib/ui.module';