@rlucan/ui 14.2.6 → 16.2.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/README.md +24 -24
- package/esm2022/lib/action-button/action-button.component.mjs +99 -99
- package/esm2022/lib/action-icon/action-icon.component.mjs +36 -36
- package/esm2022/lib/autocomplete/autocomplete.component.mjs +390 -390
- package/esm2022/lib/avatar/avatar.component.mjs +34 -34
- package/esm2022/lib/button/button.component.mjs +56 -56
- package/esm2022/lib/checkbox/checkbox.component.mjs +38 -38
- package/esm2022/lib/checkbox-group/checkbox-group.component.mjs +90 -90
- package/esm2022/lib/currency/currency.component.mjs +150 -150
- package/esm2022/lib/date/date.component.mjs +67 -67
- package/esm2022/lib/dialog/dialog.component.mjs +36 -36
- package/esm2022/lib/directives/force-visibility/force-visibility.directive.mjs +104 -104
- package/esm2022/lib/editor/editor.component.mjs +118 -118
- package/esm2022/lib/elements/burger/burger.component.mjs +20 -20
- package/esm2022/lib/elements/expander/expander.component.mjs +27 -27
- package/esm2022/lib/elements/validation-message/validation-message.component.mjs +46 -46
- package/esm2022/lib/file/file.component.mjs +144 -144
- package/esm2022/lib/file-uploader/ui-file-uploader.component.mjs +404 -404
- package/esm2022/lib/input/input.component.mjs +264 -264
- package/esm2022/lib/input-autocomplete/input-autocomplete.component.mjs +276 -276
- package/esm2022/lib/layouts/base/ui-base-layout.component.mjs +21 -21
- package/esm2022/lib/layouts/base/ui-base.component.mjs +73 -73
- package/esm2022/lib/layouts/simple/ui-simple-layout.component.mjs +17 -17
- package/esm2022/lib/layouts/simple/ui-simple.component.mjs +165 -165
- package/esm2022/lib/radio/radio.component.mjs +20 -20
- package/esm2022/lib/radio-group/radio-group.component.mjs +53 -53
- package/esm2022/lib/select/select.component.mjs +126 -115
- package/esm2022/lib/services/message-box.service.mjs +110 -110
- package/esm2022/lib/services/toast.service.mjs +23 -23
- package/esm2022/lib/services/ui-file.service.mjs +70 -70
- package/esm2022/lib/services/ui-translate.service.mjs +31 -31
- package/esm2022/lib/submit-button/submit-button.component.mjs +71 -71
- package/esm2022/lib/table/table.component.mjs +97 -97
- package/esm2022/lib/text-area/text-area.component.mjs +45 -45
- package/esm2022/lib/ui.model.mjs +1 -1
- package/esm2022/lib/ui.module.mjs +268 -268
- package/esm2022/public-api.mjs +34 -34
- package/esm2022/rlucan-ui.mjs +4 -4
- package/fesm2022/rlucan-ui.mjs +3285 -3274
- package/fesm2022/rlucan-ui.mjs.map +1 -1
- package/index.d.ts +5 -5
- package/lib/action-button/action-button.component.d.ts +28 -32
- package/lib/action-icon/action-icon.component.d.ts +15 -15
- package/lib/autocomplete/autocomplete.component.d.ts +57 -57
- package/lib/avatar/avatar.component.d.ts +14 -14
- package/lib/button/button.component.d.ts +18 -18
- package/lib/checkbox/checkbox.component.d.ts +15 -15
- package/lib/checkbox-group/checkbox-group.component.d.ts +18 -18
- package/lib/currency/currency.component.d.ts +31 -31
- package/lib/date/date.component.d.ts +24 -24
- package/lib/dialog/dialog.component.d.ts +13 -13
- package/lib/directives/force-visibility/force-visibility.directive.d.ts +22 -22
- package/lib/editor/editor.component.d.ts +24 -24
- package/lib/elements/burger/burger.component.d.ts +9 -9
- package/lib/elements/expander/expander.component.d.ts +10 -10
- package/lib/elements/validation-message/validation-message.component.d.ts +12 -12
- package/lib/file/file.component.d.ts +35 -35
- package/lib/file-uploader/ui-file-uploader.component.d.ts +102 -102
- package/lib/input/input.component.d.ts +42 -42
- package/lib/input-autocomplete/input-autocomplete.component.d.ts +44 -44
- package/lib/layouts/base/ui-base-layout.component.d.ts +8 -8
- package/lib/layouts/base/ui-base.component.d.ts +23 -23
- package/lib/layouts/simple/ui-simple-layout.component.d.ts +8 -8
- package/lib/layouts/simple/ui-simple.component.d.ts +40 -40
- package/lib/radio/radio.component.d.ts +8 -8
- package/lib/radio-group/radio-group.component.d.ts +18 -18
- package/lib/select/select.component.d.ts +37 -35
- package/lib/services/message-box.service.d.ts +58 -58
- package/lib/services/toast.service.d.ts +13 -13
- package/lib/services/ui-file.service.d.ts +33 -33
- package/lib/services/ui-translate.service.d.ts +11 -11
- package/lib/submit-button/submit-button.component.d.ts +21 -21
- package/lib/table/table.component.d.ts +36 -36
- package/lib/text-area/text-area.component.d.ts +18 -18
- package/lib/ui.model.d.ts +2 -2
- package/lib/ui.module.d.ts +59 -59
- package/package.json +1 -1
- package/public-api.d.ts +29 -29
- package/src/js/editorjs.mjs +9634 -9634
|
@@ -1,145 +1,145 @@
|
|
|
1
|
-
import { Component, HostBinding, Inject, Input, Optional } from '@angular/core';
|
|
2
|
-
import { UI_FILESERVICE } from '../services/ui-file.service';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "@angular/platform-browser";
|
|
5
|
-
import * as i2 from "../services/ui-file.service";
|
|
6
|
-
import * as i3 from "@angular/common";
|
|
7
|
-
import * as i4 from "@angular/material/progress-spinner";
|
|
8
|
-
export class FileComponent {
|
|
9
|
-
get fitImageFileSize() {
|
|
10
|
-
if (!this.fileServiceConfig.imageSizes[this.fileSize]) {
|
|
11
|
-
console.error('Missing filesize for ' + this.fileSize);
|
|
12
|
-
}
|
|
13
|
-
return this.fileServiceConfig.imageSizes[this.fileSize][0] < 0 || this.fileServiceConfig.imageSizes[this.fileSize][1] < 0;
|
|
14
|
-
}
|
|
15
|
-
get width() {
|
|
16
|
-
if (this.fitImageFileSize) {
|
|
17
|
-
if (this.nativeFileSizeRatio === -1) {
|
|
18
|
-
return '100%';
|
|
19
|
-
}
|
|
20
|
-
else {
|
|
21
|
-
return this.nativeFileWidth + 'px';
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
else {
|
|
25
|
-
return this.fileServiceConfig.imageSizes[this.fileSize] ? this.fileServiceConfig.imageSizes[this.fileSize][0] + 'px' : undefined;
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
get maxWidth() {
|
|
29
|
-
if (this.fileServiceConfig.imageSizes[this.fileSize][0] < 0) {
|
|
30
|
-
return this.width;
|
|
31
|
-
}
|
|
32
|
-
return this.fileServiceConfig.imageSizes[this.fileSize] ? this.fileServiceConfig.imageSizes[this.fileSize][0] + 'px' : undefined;
|
|
33
|
-
}
|
|
34
|
-
get height() {
|
|
35
|
-
if (this.fitImageFileSize) {
|
|
36
|
-
if (this.nativeFileSizeRatio === -1) {
|
|
37
|
-
return '100%';
|
|
38
|
-
}
|
|
39
|
-
else {
|
|
40
|
-
return this.nativeFileHeight + 'px';
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
else {
|
|
44
|
-
return this.fileServiceConfig.imageSizes[this.fileSize] ? this.fileServiceConfig.imageSizes[this.fileSize][1] + 'px' : undefined;
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
get maxHeight() {
|
|
48
|
-
if (this.fileServiceConfig.imageSizes[this.fileSize][1] < 0) {
|
|
49
|
-
return this.height;
|
|
50
|
-
}
|
|
51
|
-
return this.fileServiceConfig.imageSizes[this.fileSize] ? this.fileServiceConfig.imageSizes[this.fileSize][1] + 'px' : undefined;
|
|
52
|
-
}
|
|
53
|
-
get isVideo() {
|
|
54
|
-
return this.mime.startsWith('video/');
|
|
55
|
-
}
|
|
56
|
-
get mime() {
|
|
57
|
-
if (this.srcUrlMimeType) {
|
|
58
|
-
return this.srcUrlMimeType;
|
|
59
|
-
}
|
|
60
|
-
else {
|
|
61
|
-
if (this.srcData.nativeFile) {
|
|
62
|
-
return this.srcData.nativeFile.type;
|
|
63
|
-
}
|
|
64
|
-
return this.fileServiceConfig.getMimeType(this.srcData);
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
get useRetinaSrc() {
|
|
68
|
-
return this.fileServiceConfig.useRetinaSrc;
|
|
69
|
-
}
|
|
70
|
-
constructor(fileServiceConfig, domSanitizer, fileService) {
|
|
71
|
-
this.fileServiceConfig = fileServiceConfig;
|
|
72
|
-
this.domSanitizer = domSanitizer;
|
|
73
|
-
this.fileService = fileService;
|
|
74
|
-
this.fileSize = 'default';
|
|
75
|
-
this.visible = false;
|
|
76
|
-
this.nativeFileSizeRatio = -1;
|
|
77
|
-
}
|
|
78
|
-
ngOnInit() {
|
|
79
|
-
}
|
|
80
|
-
ngOnChanges(changes) {
|
|
81
|
-
if (changes.srcData) {
|
|
82
|
-
this.nativeFileSizeRatio = -1;
|
|
83
|
-
if (changes.srcData.currentValue.nativeFile) {
|
|
84
|
-
this.src = this.domSanitizer.bypassSecurityTrustUrl(URL.createObjectURL(changes.srcData.currentValue.nativeFile));
|
|
85
|
-
const img = new Image();
|
|
86
|
-
img.onload = () => {
|
|
87
|
-
if (this.fitImageFileSize) {
|
|
88
|
-
this.nativeFileSizeRatio = Math.max(img.width / this.fileServiceConfig.imageSizes[this.fileSize][0], img.height / this.fileServiceConfig.imageSizes[this.fileSize][1], 1);
|
|
89
|
-
}
|
|
90
|
-
else {
|
|
91
|
-
this.nativeFileSizeRatio = 1;
|
|
92
|
-
}
|
|
93
|
-
this.nativeFileWidth = img.width / this.nativeFileSizeRatio;
|
|
94
|
-
this.nativeFileHeight = img.height / this.nativeFileSizeRatio;
|
|
95
|
-
URL.revokeObjectURL(img.src);
|
|
96
|
-
};
|
|
97
|
-
img.src = URL.createObjectURL(changes.srcData.currentValue.nativeFile);
|
|
98
|
-
}
|
|
99
|
-
else {
|
|
100
|
-
this.src = this.fileServiceConfig.getMediaSrc(this.fileSize, changes.srcData.currentValue, this.srcOptions);
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
if (changes.srcUrl) {
|
|
104
|
-
this.src = changes.srcUrl.currentValue?.src;
|
|
105
|
-
if (this.src) {
|
|
106
|
-
this.srcUrlMimeType = changes.srcUrl.currentValue?.mimeType || 'image/png';
|
|
107
|
-
}
|
|
108
|
-
else {
|
|
109
|
-
this.srcUrlMimeType = undefined;
|
|
110
|
-
}
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: FileComponent, deps: [{ token: UI_FILESERVICE, optional: true }, { token: i1.DomSanitizer }, { token: i2.UiFileService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
114
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.11", type: FileComponent, selector: "ui-file", inputs: { fileSize: "fileSize", srcOptions: "srcOptions", srcData: "srcData", srcUrl: "srcUrl" }, host: { properties: { "style.width": "this.width", "style.maxWidth": "this.maxWidth", "style.height": "this.height", "style.maxHeight": "this.maxHeight" } }, usesOnChanges: true, ngImport: i0, template: "<mat-spinner *ngIf=\"visible\"></mat-spinner>\r\n<img *ngIf=\"!isVideo && useRetinaSrc\" [src]=\"src\" [srcset]=\"src + ' 2x'\"/>\r\n<img *ngIf=\"!isVideo && !useRetinaSrc\" [src]=\"src\"/>\r\n<video *ngIf=\"isVideo\" muted controls [src]=\"src\"></video>\r\n\r\n", styles: [":host{display:flex;align-items:center;justify-content:center;position:relative}:host img,:host video{max-width:100%;max-height:100%}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }] }); }
|
|
115
|
-
}
|
|
116
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: FileComponent, decorators: [{
|
|
117
|
-
type: Component,
|
|
118
|
-
args: [{ selector: 'ui-file', template: "<mat-spinner *ngIf=\"visible\"></mat-spinner>\r\n<img *ngIf=\"!isVideo && useRetinaSrc\" [src]=\"src\" [srcset]=\"src + ' 2x'\"/>\r\n<img *ngIf=\"!isVideo && !useRetinaSrc\" [src]=\"src\"/>\r\n<video *ngIf=\"isVideo\" muted controls [src]=\"src\"></video>\r\n\r\n", styles: [":host{display:flex;align-items:center;justify-content:center;position:relative}:host img,:host video{max-width:100%;max-height:100%}\n"] }]
|
|
119
|
-
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
120
|
-
type: Optional
|
|
121
|
-
}, {
|
|
122
|
-
type: Inject,
|
|
123
|
-
args: [UI_FILESERVICE]
|
|
124
|
-
}] }, { type: i1.DomSanitizer }, { type: i2.UiFileService }]; }, propDecorators: { fileSize: [{
|
|
125
|
-
type: Input
|
|
126
|
-
}], srcOptions: [{
|
|
127
|
-
type: Input
|
|
128
|
-
}], srcData: [{
|
|
129
|
-
type: Input
|
|
130
|
-
}], srcUrl: [{
|
|
131
|
-
type: Input
|
|
132
|
-
}], width: [{
|
|
133
|
-
type: HostBinding,
|
|
134
|
-
args: ['style.width']
|
|
135
|
-
}], maxWidth: [{
|
|
136
|
-
type: HostBinding,
|
|
137
|
-
args: ['style.maxWidth']
|
|
138
|
-
}], height: [{
|
|
139
|
-
type: HostBinding,
|
|
140
|
-
args: ['style.height']
|
|
141
|
-
}], maxHeight: [{
|
|
142
|
-
type: HostBinding,
|
|
143
|
-
args: ['style.maxHeight']
|
|
144
|
-
}] } });
|
|
1
|
+
import { Component, HostBinding, Inject, Input, Optional } from '@angular/core';
|
|
2
|
+
import { UI_FILESERVICE } from '../services/ui-file.service';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/platform-browser";
|
|
5
|
+
import * as i2 from "../services/ui-file.service";
|
|
6
|
+
import * as i3 from "@angular/common";
|
|
7
|
+
import * as i4 from "@angular/material/progress-spinner";
|
|
8
|
+
export class FileComponent {
|
|
9
|
+
get fitImageFileSize() {
|
|
10
|
+
if (!this.fileServiceConfig.imageSizes[this.fileSize]) {
|
|
11
|
+
console.error('Missing filesize for ' + this.fileSize);
|
|
12
|
+
}
|
|
13
|
+
return this.fileServiceConfig.imageSizes[this.fileSize][0] < 0 || this.fileServiceConfig.imageSizes[this.fileSize][1] < 0;
|
|
14
|
+
}
|
|
15
|
+
get width() {
|
|
16
|
+
if (this.fitImageFileSize) {
|
|
17
|
+
if (this.nativeFileSizeRatio === -1) {
|
|
18
|
+
return '100%';
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
return this.nativeFileWidth + 'px';
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
else {
|
|
25
|
+
return this.fileServiceConfig.imageSizes[this.fileSize] ? this.fileServiceConfig.imageSizes[this.fileSize][0] + 'px' : undefined;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
get maxWidth() {
|
|
29
|
+
if (this.fileServiceConfig.imageSizes[this.fileSize][0] < 0) {
|
|
30
|
+
return this.width;
|
|
31
|
+
}
|
|
32
|
+
return this.fileServiceConfig.imageSizes[this.fileSize] ? this.fileServiceConfig.imageSizes[this.fileSize][0] + 'px' : undefined;
|
|
33
|
+
}
|
|
34
|
+
get height() {
|
|
35
|
+
if (this.fitImageFileSize) {
|
|
36
|
+
if (this.nativeFileSizeRatio === -1) {
|
|
37
|
+
return '100%';
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
return this.nativeFileHeight + 'px';
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
else {
|
|
44
|
+
return this.fileServiceConfig.imageSizes[this.fileSize] ? this.fileServiceConfig.imageSizes[this.fileSize][1] + 'px' : undefined;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
get maxHeight() {
|
|
48
|
+
if (this.fileServiceConfig.imageSizes[this.fileSize][1] < 0) {
|
|
49
|
+
return this.height;
|
|
50
|
+
}
|
|
51
|
+
return this.fileServiceConfig.imageSizes[this.fileSize] ? this.fileServiceConfig.imageSizes[this.fileSize][1] + 'px' : undefined;
|
|
52
|
+
}
|
|
53
|
+
get isVideo() {
|
|
54
|
+
return this.mime.startsWith('video/');
|
|
55
|
+
}
|
|
56
|
+
get mime() {
|
|
57
|
+
if (this.srcUrlMimeType) {
|
|
58
|
+
return this.srcUrlMimeType;
|
|
59
|
+
}
|
|
60
|
+
else {
|
|
61
|
+
if (this.srcData.nativeFile) {
|
|
62
|
+
return this.srcData.nativeFile.type;
|
|
63
|
+
}
|
|
64
|
+
return this.fileServiceConfig.getMimeType(this.srcData);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
get useRetinaSrc() {
|
|
68
|
+
return this.fileServiceConfig.useRetinaSrc;
|
|
69
|
+
}
|
|
70
|
+
constructor(fileServiceConfig, domSanitizer, fileService) {
|
|
71
|
+
this.fileServiceConfig = fileServiceConfig;
|
|
72
|
+
this.domSanitizer = domSanitizer;
|
|
73
|
+
this.fileService = fileService;
|
|
74
|
+
this.fileSize = 'default';
|
|
75
|
+
this.visible = false;
|
|
76
|
+
this.nativeFileSizeRatio = -1;
|
|
77
|
+
}
|
|
78
|
+
ngOnInit() {
|
|
79
|
+
}
|
|
80
|
+
ngOnChanges(changes) {
|
|
81
|
+
if (changes.srcData) {
|
|
82
|
+
this.nativeFileSizeRatio = -1;
|
|
83
|
+
if (changes.srcData.currentValue.nativeFile) {
|
|
84
|
+
this.src = this.domSanitizer.bypassSecurityTrustUrl(URL.createObjectURL(changes.srcData.currentValue.nativeFile));
|
|
85
|
+
const img = new Image();
|
|
86
|
+
img.onload = () => {
|
|
87
|
+
if (this.fitImageFileSize) {
|
|
88
|
+
this.nativeFileSizeRatio = Math.max(img.width / this.fileServiceConfig.imageSizes[this.fileSize][0], img.height / this.fileServiceConfig.imageSizes[this.fileSize][1], 1);
|
|
89
|
+
}
|
|
90
|
+
else {
|
|
91
|
+
this.nativeFileSizeRatio = 1;
|
|
92
|
+
}
|
|
93
|
+
this.nativeFileWidth = img.width / this.nativeFileSizeRatio;
|
|
94
|
+
this.nativeFileHeight = img.height / this.nativeFileSizeRatio;
|
|
95
|
+
URL.revokeObjectURL(img.src);
|
|
96
|
+
};
|
|
97
|
+
img.src = URL.createObjectURL(changes.srcData.currentValue.nativeFile);
|
|
98
|
+
}
|
|
99
|
+
else {
|
|
100
|
+
this.src = this.fileServiceConfig.getMediaSrc(this.fileSize, changes.srcData.currentValue, this.srcOptions);
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
if (changes.srcUrl) {
|
|
104
|
+
this.src = changes.srcUrl.currentValue?.src;
|
|
105
|
+
if (this.src) {
|
|
106
|
+
this.srcUrlMimeType = changes.srcUrl.currentValue?.mimeType || 'image/png';
|
|
107
|
+
}
|
|
108
|
+
else {
|
|
109
|
+
this.srcUrlMimeType = undefined;
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: FileComponent, deps: [{ token: UI_FILESERVICE, optional: true }, { token: i1.DomSanitizer }, { token: i2.UiFileService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
114
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.11", type: FileComponent, selector: "ui-file", inputs: { fileSize: "fileSize", srcOptions: "srcOptions", srcData: "srcData", srcUrl: "srcUrl" }, host: { properties: { "style.width": "this.width", "style.maxWidth": "this.maxWidth", "style.height": "this.height", "style.maxHeight": "this.maxHeight" } }, usesOnChanges: true, ngImport: i0, template: "<mat-spinner *ngIf=\"visible\"></mat-spinner>\r\n<img *ngIf=\"!isVideo && useRetinaSrc\" [src]=\"src\" [srcset]=\"src + ' 2x'\"/>\r\n<img *ngIf=\"!isVideo && !useRetinaSrc\" [src]=\"src\"/>\r\n<video *ngIf=\"isVideo\" muted controls [src]=\"src\"></video>\r\n\r\n", styles: [":host{display:flex;align-items:center;justify-content:center;position:relative}:host img,:host video{max-width:100%;max-height:100%}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }] }); }
|
|
115
|
+
}
|
|
116
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: FileComponent, decorators: [{
|
|
117
|
+
type: Component,
|
|
118
|
+
args: [{ selector: 'ui-file', template: "<mat-spinner *ngIf=\"visible\"></mat-spinner>\r\n<img *ngIf=\"!isVideo && useRetinaSrc\" [src]=\"src\" [srcset]=\"src + ' 2x'\"/>\r\n<img *ngIf=\"!isVideo && !useRetinaSrc\" [src]=\"src\"/>\r\n<video *ngIf=\"isVideo\" muted controls [src]=\"src\"></video>\r\n\r\n", styles: [":host{display:flex;align-items:center;justify-content:center;position:relative}:host img,:host video{max-width:100%;max-height:100%}\n"] }]
|
|
119
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
120
|
+
type: Optional
|
|
121
|
+
}, {
|
|
122
|
+
type: Inject,
|
|
123
|
+
args: [UI_FILESERVICE]
|
|
124
|
+
}] }, { type: i1.DomSanitizer }, { type: i2.UiFileService }]; }, propDecorators: { fileSize: [{
|
|
125
|
+
type: Input
|
|
126
|
+
}], srcOptions: [{
|
|
127
|
+
type: Input
|
|
128
|
+
}], srcData: [{
|
|
129
|
+
type: Input
|
|
130
|
+
}], srcUrl: [{
|
|
131
|
+
type: Input
|
|
132
|
+
}], width: [{
|
|
133
|
+
type: HostBinding,
|
|
134
|
+
args: ['style.width']
|
|
135
|
+
}], maxWidth: [{
|
|
136
|
+
type: HostBinding,
|
|
137
|
+
args: ['style.maxWidth']
|
|
138
|
+
}], height: [{
|
|
139
|
+
type: HostBinding,
|
|
140
|
+
args: ['style.height']
|
|
141
|
+
}], maxHeight: [{
|
|
142
|
+
type: HostBinding,
|
|
143
|
+
args: ['style.maxHeight']
|
|
144
|
+
}] } });
|
|
145
145
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file.component.js","sourceRoot":"","sources":["../../../../../projects/ui/src/lib/file/file.component.ts","../../../../../projects/ui/src/lib/file/file.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostBinding, Inject, Input, OnChanges, OnInit, Optional, SimpleChanges } from '@angular/core';\r\nimport { IUiFileService, UI_FILESERVICE, UiFileService } from '../services/ui-file.service';\r\nimport { DomSanitizer } from '@angular/platform-browser';\r\n\r\n@Component({\r\n  selector: 'ui-file',\r\n  templateUrl: './file.component.html',\r\n  styleUrls: ['./file.component.scss']\r\n})\r\nexport class FileComponent implements OnInit, OnChanges {\r\n\r\n  @Input() fileSize = 'default';\r\n  @Input() srcOptions;\r\n  @Input() srcData: any;\r\n  @Input() srcUrl: { src: string, mimeType?: string };\r\n  get fitImageFileSize() {\r\n    if (!this.fileServiceConfig.imageSizes[this.fileSize]) {\r\n      console.error('Missing filesize for ' + this.fileSize);\r\n    }\r\n    return this.fileServiceConfig.imageSizes[this.fileSize][0] < 0 || this.fileServiceConfig.imageSizes[this.fileSize][1] < 0\r\n  }\r\n\r\n  visible = false;\r\n  src;\r\n  srcUrlMimeType;\r\n  nativeFileSizeRatio = -1;\r\n  nativeFileWidth;\r\n  nativeFileHeight;\r\n\r\n  @HostBinding('style.width')\r\n  get width(): string {\r\n    if (this.fitImageFileSize) {\r\n      if (this.nativeFileSizeRatio === -1) {\r\n        return '100%';\r\n      } else {\r\n        return this.nativeFileWidth + 'px'\r\n      }\r\n    } else {\r\n      return this.fileServiceConfig.imageSizes[this.fileSize] ? this.fileServiceConfig.imageSizes[this.fileSize][0] + 'px' : undefined;\r\n    }\r\n  }\r\n\r\n  @HostBinding('style.maxWidth')\r\n  get maxWidth(): string {\r\n    if (this.fileServiceConfig.imageSizes[this.fileSize][0] < 0) {\r\n      return this.width;\r\n    }\r\n    return this.fileServiceConfig.imageSizes[this.fileSize] ? this.fileServiceConfig.imageSizes[this.fileSize][0] + 'px' : undefined;\r\n  }\r\n\r\n  @HostBinding('style.height')\r\n  get height(): string {\r\n    if (this.fitImageFileSize) {\r\n      if (this.nativeFileSizeRatio === -1) {\r\n        return '100%';\r\n      } else {\r\n        return this.nativeFileHeight + 'px';\r\n      }\r\n    } else {\r\n      return this.fileServiceConfig.imageSizes[this.fileSize] ? this.fileServiceConfig.imageSizes[this.fileSize][1] + 'px' : undefined;\r\n    }\r\n  }\r\n\r\n  @HostBinding('style.maxHeight')\r\n  get maxHeight(): string {\r\n    if (this.fileServiceConfig.imageSizes[this.fileSize][1] < 0) {\r\n      return this.height;\r\n    }\r\n    return this.fileServiceConfig.imageSizes[this.fileSize] ? this.fileServiceConfig.imageSizes[this.fileSize][1] + 'px' : undefined;\r\n  }\r\n\r\n  get isVideo() {\r\n    return this.mime.startsWith('video/');\r\n  }\r\n\r\n  get mime() {\r\n    if (this.srcUrlMimeType) {\r\n      return this.srcUrlMimeType\r\n    } else {\r\n      if (this.srcData.nativeFile) {\r\n        return this.srcData.nativeFile.type;\r\n      }\r\n      return this.fileServiceConfig.getMimeType(this.srcData);\r\n    }\r\n  }\r\n\r\n  get useRetinaSrc() {\r\n    return this.fileServiceConfig.useRetinaSrc\r\n  }\r\n\r\n  constructor(@Optional() @Inject(UI_FILESERVICE) private fileServiceConfig: IUiFileService,\r\n              private domSanitizer: DomSanitizer,\r\n              private fileService: UiFileService) { }\r\n\r\n  ngOnInit(): void {\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes.srcData) {\r\n      this.nativeFileSizeRatio = -1;\r\n      if (changes.srcData.currentValue.nativeFile) {\r\n        this.src = this.domSanitizer.bypassSecurityTrustUrl(URL.createObjectURL(changes.srcData.currentValue.nativeFile));\r\n\r\n        const img = new Image();\r\n\r\n        img.onload = () => {\r\n          if (this.fitImageFileSize) {\r\n            this.nativeFileSizeRatio = Math.max(img.width / this.fileServiceConfig.imageSizes[this.fileSize][0],\r\n                img.height / this.fileServiceConfig.imageSizes[this.fileSize][1], 1);\r\n          } else {\r\n            this.nativeFileSizeRatio = 1;\r\n          }\r\n          this.nativeFileWidth = img.width / this.nativeFileSizeRatio;\r\n          this.nativeFileHeight = img.height / this.nativeFileSizeRatio;\r\n          URL.revokeObjectURL(img.src);\r\n        };\r\n\r\n        img.src = URL.createObjectURL(changes.srcData.currentValue.nativeFile);\r\n\r\n      } else {\r\n        this.src = this.fileServiceConfig.getMediaSrc(this.fileSize, changes.srcData.currentValue, this.srcOptions);\r\n      }\r\n    }\r\n    if (changes.srcUrl) {\r\n      this.src = changes.srcUrl.currentValue?.src;\r\n      if (this.src) {\r\n        this.srcUrlMimeType = changes.srcUrl.currentValue?.mimeType || 'image/png';\r\n      } else {\r\n        this.srcUrlMimeType = undefined;\r\n      }\r\n    }\r\n  }\r\n}\r\n","<mat-spinner *ngIf=\"visible\"></mat-spinner>\r\n<img *ngIf=\"!isVideo && useRetinaSrc\" [src]=\"src\" [srcset]=\"src + ' 2x'\"/>\r\n<img *ngIf=\"!isVideo && !useRetinaSrc\" [src]=\"src\"/>\r\n<video *ngIf=\"isVideo\" muted controls [src]=\"src\"></video>\r\n\r\n"]}
|