barsa-novin-ray-core 2.2.9 → 2.2.11
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.
|
@@ -83,70 +83,75 @@ export class UploadService {
|
|
|
83
83
|
const formData = new FormData();
|
|
84
84
|
return new Promise((resolve, reject) => {
|
|
85
85
|
files.forEach((file, index) => {
|
|
86
|
-
|
|
87
|
-
const blobURL = URL.createObjectURL(file2);
|
|
88
|
-
const img = new Image();
|
|
89
|
-
img.src = blobURL;
|
|
90
|
-
const biggerThan1MB = file.size / 1024 > 1000;
|
|
91
|
-
console.log(`file size ${biggerThan1MB}`);
|
|
92
|
-
const mimeTypeJpg = 'image/jpeg';
|
|
93
|
-
const MAX_WIDTH = 1920;
|
|
94
|
-
const MAX_HEIGHT = 1080;
|
|
95
|
-
const MIME_TYPE = biggerThan1MB ? mimeTypeJpg : file.type;
|
|
96
|
-
const QUALITY = biggerThan1MB && file.type === mimeTypeJpg ? 0.5 : 1;
|
|
97
|
-
if (MIME_TYPE === file.type && QUALITY === 1) {
|
|
98
|
-
formData.append('file', file, file.name);
|
|
99
|
-
if (index === files.length - 1) {
|
|
100
|
-
resolve(formData);
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
img.onerror = function () {
|
|
104
|
-
URL.revokeObjectURL(img.src);
|
|
105
|
-
// Handle the failure properly
|
|
106
|
-
console.log('Cannot load image');
|
|
107
|
-
reject(new Error('Cannot load image'));
|
|
108
|
-
};
|
|
109
|
-
img.onload = function () {
|
|
110
|
-
URL.revokeObjectURL(img.src);
|
|
111
|
-
const [newWidth, newHeight] = calculateSize(img, MAX_WIDTH, MAX_HEIGHT);
|
|
112
|
-
const canvas = document.createElement('canvas');
|
|
113
|
-
canvas.width = newWidth;
|
|
114
|
-
canvas.height = newHeight;
|
|
115
|
-
const ctx = canvas.getContext('2d');
|
|
116
|
-
ctx?.drawImage(img, 0, 0, newWidth, newHeight);
|
|
117
|
-
canvas.toBlob((blob) => {
|
|
118
|
-
// Handle the compressed image. es. upload or save in local state
|
|
119
|
-
if (blob) {
|
|
120
|
-
// formData.append(
|
|
121
|
-
// 'unicFileName',
|
|
122
|
-
// 'x' + BarsaApi.Common.Util.GetNewMetaGuid() + ';;;' + file.name
|
|
123
|
-
// );
|
|
124
|
-
formData.append('file', blob, file.name);
|
|
125
|
-
}
|
|
126
|
-
if (index === files.length - 1) {
|
|
127
|
-
resolve(formData);
|
|
128
|
-
}
|
|
129
|
-
}, MIME_TYPE, QUALITY);
|
|
130
|
-
};
|
|
131
|
-
function calculateSize(img1, maxWidth, maxHeight) {
|
|
132
|
-
let width = img1.width;
|
|
133
|
-
let height = img1.height;
|
|
134
|
-
// calculate the width and height, constraining the proportions
|
|
135
|
-
if (width > height) {
|
|
136
|
-
if (width > maxWidth) {
|
|
137
|
-
height = Math.round((height * maxWidth) / width);
|
|
138
|
-
width = maxWidth;
|
|
139
|
-
}
|
|
140
|
-
}
|
|
141
|
-
else {
|
|
142
|
-
if (height > maxHeight) {
|
|
143
|
-
width = Math.round((width * maxHeight) / height);
|
|
144
|
-
height = maxHeight;
|
|
145
|
-
}
|
|
146
|
-
}
|
|
147
|
-
return [width, height];
|
|
148
|
-
}
|
|
86
|
+
formData.append('file', file, file.name);
|
|
149
87
|
});
|
|
88
|
+
resolve(formData);
|
|
89
|
+
// const file2 = file; // get the file
|
|
90
|
+
// const blobURL = URL.createObjectURL(file2);
|
|
91
|
+
// const img = new Image();
|
|
92
|
+
// img.src = blobURL;
|
|
93
|
+
// const biggerThan1MB = file.size / 1024 > 1000;
|
|
94
|
+
// const mimeTypeJpg = 'image/jpeg';
|
|
95
|
+
// const MAX_WIDTH = 1920;
|
|
96
|
+
// const MAX_HEIGHT = 1080;
|
|
97
|
+
// const MIME_TYPE = biggerThan1MB ? mimeTypeJpg : file.type;
|
|
98
|
+
// const QUALITY = biggerThan1MB && file.type === mimeTypeJpg ? 0.5 : 1;
|
|
99
|
+
// if (MIME_TYPE === file.type && QUALITY === 1) {
|
|
100
|
+
// formData.append('file', file, file.name);
|
|
101
|
+
// if (index === files.length - 1) {
|
|
102
|
+
// resolve(formData);
|
|
103
|
+
// }
|
|
104
|
+
// }
|
|
105
|
+
// img.onerror = function (): void {
|
|
106
|
+
// URL.revokeObjectURL(img.src);
|
|
107
|
+
// // Handle the failure properly
|
|
108
|
+
// console.log('Cannot load image');
|
|
109
|
+
// reject(new Error('Cannot load image'));
|
|
110
|
+
// };
|
|
111
|
+
// img.onload = function (): void {
|
|
112
|
+
// URL.revokeObjectURL(img.src);
|
|
113
|
+
// const [newWidth, newHeight] = calculateSize(img, MAX_WIDTH, MAX_HEIGHT);
|
|
114
|
+
// const canvas = document.createElement('canvas');
|
|
115
|
+
// canvas.width = newWidth;
|
|
116
|
+
// canvas.height = newHeight;
|
|
117
|
+
// const ctx = canvas.getContext('2d');
|
|
118
|
+
// ctx?.drawImage(img, 0, 0, newWidth, newHeight);
|
|
119
|
+
// canvas.toBlob(
|
|
120
|
+
// (blob) => {
|
|
121
|
+
// // Handle the compressed image. es. upload or save in local state
|
|
122
|
+
// if (blob) {
|
|
123
|
+
// // formData.append(
|
|
124
|
+
// // 'unicFileName',
|
|
125
|
+
// // 'x' + BarsaApi.Common.Util.GetNewMetaGuid() + ';;;' + file.name
|
|
126
|
+
// // );
|
|
127
|
+
// formData.append('file', blob, file.name);
|
|
128
|
+
// }
|
|
129
|
+
// if (index === files.length - 1) {
|
|
130
|
+
// resolve(formData);
|
|
131
|
+
// }
|
|
132
|
+
// },
|
|
133
|
+
// MIME_TYPE,
|
|
134
|
+
// QUALITY
|
|
135
|
+
// );
|
|
136
|
+
// };
|
|
137
|
+
// function calculateSize(img1, maxWidth, maxHeight): number[] {
|
|
138
|
+
// let width = img1.width;
|
|
139
|
+
// let height = img1.height;
|
|
140
|
+
// // calculate the width and height, constraining the proportions
|
|
141
|
+
// if (width > height) {
|
|
142
|
+
// if (width > maxWidth) {
|
|
143
|
+
// height = Math.round((height * maxWidth) / width);
|
|
144
|
+
// width = maxWidth;
|
|
145
|
+
// }
|
|
146
|
+
// } else {
|
|
147
|
+
// if (height > maxHeight) {
|
|
148
|
+
// width = Math.round((width * maxHeight) / height);
|
|
149
|
+
// height = maxHeight;
|
|
150
|
+
// }
|
|
151
|
+
// }
|
|
152
|
+
// return [width, height];
|
|
153
|
+
// }
|
|
154
|
+
// });
|
|
150
155
|
});
|
|
151
156
|
}
|
|
152
157
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UploadService, deps: [{ token: i1.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
@@ -158,4 +163,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
158
163
|
providedIn: 'root'
|
|
159
164
|
}]
|
|
160
165
|
}], ctorParameters: () => [{ type: i1.HttpClient }] });
|
|
161
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upload.service.js","sourceRoot":"","sources":["../../../../../projects/barsa-novin-ray-core/src/lib/services/upload.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { HttpClient, HttpErrorResponse, HttpEventType } from '@angular/common/http';\n\nimport { Subject, Observable, throwError, from } from 'rxjs';\nimport { catchError, finalize, map, takeUntil } from 'rxjs/operators';\nimport { BarsaApi, IUploadingState } from '../abstract-classes';\n\n@Injectable({\n    providedIn: 'root'\n})\nexport class UploadService {\n    private _uploadingStateSource = new Subject<IUploadingState>();\n    uploadingState$ = this._uploadingStateSource.asObservable();\n    cancelation$ = new Subject<void>();\n    uploadURL = `/Fields/File/Base/FileUploadFormMulti.ashx`;\n    constructor(private httpClient: HttpClient) {}\n\n    public upload(data: FormData, fdId: string, key: string = ''): Observable<IUploadingState> {\n        let state: IUploadingState = {\n            key,\n            progress: 0,\n            state: 'Start',\n            uploading: false\n        };\n        this._setUploadingStatus(state);\n        return this.httpClient\n            .post<any>(this.uploadURL, data, {\n                reportProgress: true,\n                observe: 'events',\n                headers: { fdId, IsPortal: 'true' }\n            })\n            .pipe(\n                map((event) => {\n                    switch (event.type) {\n                        case HttpEventType.UploadProgress: {\n                            const total = event.total || 0;\n                            const progress = Math.round((100 * event.loaded) / total);\n                            return { status: 'progress', message: progress };\n                        }\n                        case HttpEventType.Response:\n                            return event.body;\n                        default:\n                            return `Unhandled event: ${event.type}`;\n                    }\n                }),\n                map((res) => {\n                    if (Array.isArray(res)) {\n                        state = this._setUploadingStatus({ ...state, state: 'Complete', uploading: false });\n                    } else if (res !== null && typeof res === 'object') {\n                        if (res.status === 'error') {\n                            state = this._setUploadingStatus({ ...state, state: 'Error', uploading: false });\n                        } else if (res.status === 'progress') {\n                            state = this._setUploadingStatus({\n                                ...state,\n                                state: 'Uploading',\n                                uploading: true,\n                                progress: res.message\n                            });\n                        }\n                    }\n                    return res;\n                }),\n                takeUntil(this.cancelation$.asObservable()),\n                catchError((err) => {\n                    if (err instanceof HttpErrorResponse) {\n                        BarsaApi.Bw.Toast.Error(`${err.status} : ${err.message}`);\n                    }\n\n                    return throwError(() => new Error(err));\n                }),\n                finalize(() => {\n                    state = this._setUploadingStatus({\n                        ...state,\n                        uploading: false\n                    });\n                })\n            );\n    }\n\n    public compressFiles$(files: File[]): Observable<FormData> {\n        return from(this.compressFiles(files));\n    }\n    private _setUploadingStatus(state: IUploadingState): IUploadingState {\n        if (state.state === 'Start') {\n            state.uploading = true;\n        }\n        this._uploadingStateSource.next(state);\n        return state;\n    }\n    private compressFiles(files: File[]): Promise<FormData> {\n        const formData = new FormData();\n        return new Promise((resolve, reject) => {\n            files.forEach((file, index) => {\n                const file2 = file; // get the file\n                const blobURL = URL.createObjectURL(file2);\n                const img = new Image();\n                img.src = blobURL;\n                const biggerThan1MB = file.size / 1024 > 1000;\n                console.log(`file size ${biggerThan1MB}`);\n                const mimeTypeJpg = 'image/jpeg';\n                const MAX_WIDTH = 1920;\n                const MAX_HEIGHT = 1080;\n                const MIME_TYPE = biggerThan1MB ? mimeTypeJpg : file.type;\n                const QUALITY = biggerThan1MB && file.type === mimeTypeJpg ? 0.5 : 1;\n                if (MIME_TYPE === file.type && QUALITY === 1) {\n                    formData.append('file', file, file.name);\n                    if (index === files.length - 1) {\n                        resolve(formData);\n                    }\n                }\n                img.onerror = function (): void {\n                    URL.revokeObjectURL(img.src);\n                    // Handle the failure properly\n                    console.log('Cannot load image');\n                    reject(new Error('Cannot load image'));\n                };\n                img.onload = function (): void {\n                    URL.revokeObjectURL(img.src);\n                    const [newWidth, newHeight] = calculateSize(img, MAX_WIDTH, MAX_HEIGHT);\n                    const canvas = document.createElement('canvas');\n                    canvas.width = newWidth;\n                    canvas.height = newHeight;\n                    const ctx = canvas.getContext('2d');\n                    ctx?.drawImage(img, 0, 0, newWidth, newHeight);\n                    canvas.toBlob(\n                        (blob) => {\n                            // Handle the compressed image. es. upload or save in local state\n                            if (blob) {\n                                // formData.append(\n                                //     'unicFileName',\n                                //     'x' + BarsaApi.Common.Util.GetNewMetaGuid() + ';;;' + file.name\n                                // );\n                                formData.append('file', blob, file.name);\n                            }\n                            if (index === files.length - 1) {\n                                resolve(formData);\n                            }\n                        },\n                        MIME_TYPE,\n                        QUALITY\n                    );\n                };\n                function calculateSize(img1, maxWidth, maxHeight): number[] {\n                    let width = img1.width;\n                    let height = img1.height;\n\n                    // calculate the width and height, constraining the proportions\n                    if (width > height) {\n                        if (width > maxWidth) {\n                            height = Math.round((height * maxWidth) / width);\n                            width = maxWidth;\n                        }\n                    } else {\n                        if (height > maxHeight) {\n                            width = Math.round((width * maxHeight) / height);\n                            height = maxHeight;\n                        }\n                    }\n                    return [width, height];\n                }\n            });\n        });\n    }\n}\n"]}
|
|
166
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upload.service.js","sourceRoot":"","sources":["../../../../../projects/barsa-novin-ray-core/src/lib/services/upload.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { HttpClient, HttpErrorResponse, HttpEventType } from '@angular/common/http';\r\n\r\nimport { Subject, Observable, throwError, from } from 'rxjs';\r\nimport { catchError, finalize, map, takeUntil } from 'rxjs/operators';\r\nimport { BarsaApi, IUploadingState } from '../abstract-classes';\r\n\r\n@Injectable({\r\n    providedIn: 'root'\r\n})\r\nexport class UploadService {\r\n    private _uploadingStateSource = new Subject<IUploadingState>();\r\n    uploadingState$ = this._uploadingStateSource.asObservable();\r\n    cancelation$ = new Subject<void>();\r\n    uploadURL = `/Fields/File/Base/FileUploadFormMulti.ashx`;\r\n    constructor(private httpClient: HttpClient) {}\r\n\r\n    public upload(data: FormData, fdId: string, key: string = ''): Observable<IUploadingState> {\r\n        let state: IUploadingState = {\r\n            key,\r\n            progress: 0,\r\n            state: 'Start',\r\n            uploading: false\r\n        };\r\n        this._setUploadingStatus(state);\r\n        return this.httpClient\r\n            .post<any>(this.uploadURL, data, {\r\n                reportProgress: true,\r\n                observe: 'events',\r\n                headers: { fdId, IsPortal: 'true' }\r\n            })\r\n            .pipe(\r\n                map((event) => {\r\n                    switch (event.type) {\r\n                        case HttpEventType.UploadProgress: {\r\n                            const total = event.total || 0;\r\n                            const progress = Math.round((100 * event.loaded) / total);\r\n                            return { status: 'progress', message: progress };\r\n                        }\r\n                        case HttpEventType.Response:\r\n                            return event.body;\r\n                        default:\r\n                            return `Unhandled event: ${event.type}`;\r\n                    }\r\n                }),\r\n                map((res) => {\r\n                    if (Array.isArray(res)) {\r\n                        state = this._setUploadingStatus({ ...state, state: 'Complete', uploading: false });\r\n                    } else if (res !== null && typeof res === 'object') {\r\n                        if (res.status === 'error') {\r\n                            state = this._setUploadingStatus({ ...state, state: 'Error', uploading: false });\r\n                        } else if (res.status === 'progress') {\r\n                            state = this._setUploadingStatus({\r\n                                ...state,\r\n                                state: 'Uploading',\r\n                                uploading: true,\r\n                                progress: res.message\r\n                            });\r\n                        }\r\n                    }\r\n                    return res;\r\n                }),\r\n                takeUntil(this.cancelation$.asObservable()),\r\n                catchError((err) => {\r\n                    if (err instanceof HttpErrorResponse) {\r\n                        BarsaApi.Bw.Toast.Error(`${err.status} : ${err.message}`);\r\n                    }\r\n\r\n                    return throwError(() => new Error(err));\r\n                }),\r\n                finalize(() => {\r\n                    state = this._setUploadingStatus({\r\n                        ...state,\r\n                        uploading: false\r\n                    });\r\n                })\r\n            );\r\n    }\r\n\r\n    public compressFiles$(files: File[]): Observable<FormData> {\r\n        return from(this.compressFiles(files));\r\n    }\r\n    private _setUploadingStatus(state: IUploadingState): IUploadingState {\r\n        if (state.state === 'Start') {\r\n            state.uploading = true;\r\n        }\r\n        this._uploadingStateSource.next(state);\r\n        return state;\r\n    }\r\n    private compressFiles(files: File[]): Promise<FormData> {\r\n        const formData = new FormData();\r\n        return new Promise((resolve, reject) => {\r\n            files.forEach((file, index) => {\r\n                formData.append('file', file, file.name);\r\n            });\r\n            resolve(formData);\r\n            //     const file2 = file; // get the file\r\n            //     const blobURL = URL.createObjectURL(file2);\r\n            //     const img = new Image();\r\n            //     img.src = blobURL;\r\n            //     const biggerThan1MB = file.size / 1024 > 1000;\r\n            //     const mimeTypeJpg = 'image/jpeg';\r\n            //     const MAX_WIDTH = 1920;\r\n            //     const MAX_HEIGHT = 1080;\r\n            //     const MIME_TYPE = biggerThan1MB ? mimeTypeJpg : file.type;\r\n            //     const QUALITY = biggerThan1MB && file.type === mimeTypeJpg ? 0.5 : 1;\r\n            //     if (MIME_TYPE === file.type && QUALITY === 1) {\r\n            //         formData.append('file', file, file.name);\r\n            //         if (index === files.length - 1) {\r\n            //             resolve(formData);\r\n            //         }\r\n            //     }\r\n            //     img.onerror = function (): void {\r\n            //         URL.revokeObjectURL(img.src);\r\n            //         // Handle the failure properly\r\n            //         console.log('Cannot load image');\r\n            //         reject(new Error('Cannot load image'));\r\n            //     };\r\n            //     img.onload = function (): void {\r\n            //         URL.revokeObjectURL(img.src);\r\n            //         const [newWidth, newHeight] = calculateSize(img, MAX_WIDTH, MAX_HEIGHT);\r\n            //         const canvas = document.createElement('canvas');\r\n            //         canvas.width = newWidth;\r\n            //         canvas.height = newHeight;\r\n            //         const ctx = canvas.getContext('2d');\r\n            //         ctx?.drawImage(img, 0, 0, newWidth, newHeight);\r\n            //         canvas.toBlob(\r\n            //             (blob) => {\r\n            //                 // Handle the compressed image. es. upload or save in local state\r\n            //                 if (blob) {\r\n            //                     // formData.append(\r\n            //                     //     'unicFileName',\r\n            //                     //     'x' + BarsaApi.Common.Util.GetNewMetaGuid() + ';;;' + file.name\r\n            //                     // );\r\n            //                     formData.append('file', blob, file.name);\r\n            //                 }\r\n            //                 if (index === files.length - 1) {\r\n            //                     resolve(formData);\r\n            //                 }\r\n            //             },\r\n            //             MIME_TYPE,\r\n            //             QUALITY\r\n            //         );\r\n            //     };\r\n            //     function calculateSize(img1, maxWidth, maxHeight): number[] {\r\n            //         let width = img1.width;\r\n            //         let height = img1.height;\r\n\r\n            //         // calculate the width and height, constraining the proportions\r\n            //         if (width > height) {\r\n            //             if (width > maxWidth) {\r\n            //                 height = Math.round((height * maxWidth) / width);\r\n            //                 width = maxWidth;\r\n            //             }\r\n            //         } else {\r\n            //             if (height > maxHeight) {\r\n            //                 width = Math.round((width * maxHeight) / height);\r\n            //                 height = maxHeight;\r\n            //             }\r\n            //         }\r\n            //         return [width, height];\r\n            //     }\r\n            // });\r\n        });\r\n    }\r\n}\r\n"]}
|
|
@@ -6447,70 +6447,75 @@ class UploadService {
|
|
|
6447
6447
|
const formData = new FormData();
|
|
6448
6448
|
return new Promise((resolve, reject) => {
|
|
6449
6449
|
files.forEach((file, index) => {
|
|
6450
|
-
|
|
6451
|
-
const blobURL = URL.createObjectURL(file2);
|
|
6452
|
-
const img = new Image();
|
|
6453
|
-
img.src = blobURL;
|
|
6454
|
-
const biggerThan1MB = file.size / 1024 > 1000;
|
|
6455
|
-
console.log(`file size ${biggerThan1MB}`);
|
|
6456
|
-
const mimeTypeJpg = 'image/jpeg';
|
|
6457
|
-
const MAX_WIDTH = 1920;
|
|
6458
|
-
const MAX_HEIGHT = 1080;
|
|
6459
|
-
const MIME_TYPE = biggerThan1MB ? mimeTypeJpg : file.type;
|
|
6460
|
-
const QUALITY = biggerThan1MB && file.type === mimeTypeJpg ? 0.5 : 1;
|
|
6461
|
-
if (MIME_TYPE === file.type && QUALITY === 1) {
|
|
6462
|
-
formData.append('file', file, file.name);
|
|
6463
|
-
if (index === files.length - 1) {
|
|
6464
|
-
resolve(formData);
|
|
6465
|
-
}
|
|
6466
|
-
}
|
|
6467
|
-
img.onerror = function () {
|
|
6468
|
-
URL.revokeObjectURL(img.src);
|
|
6469
|
-
// Handle the failure properly
|
|
6470
|
-
console.log('Cannot load image');
|
|
6471
|
-
reject(new Error('Cannot load image'));
|
|
6472
|
-
};
|
|
6473
|
-
img.onload = function () {
|
|
6474
|
-
URL.revokeObjectURL(img.src);
|
|
6475
|
-
const [newWidth, newHeight] = calculateSize(img, MAX_WIDTH, MAX_HEIGHT);
|
|
6476
|
-
const canvas = document.createElement('canvas');
|
|
6477
|
-
canvas.width = newWidth;
|
|
6478
|
-
canvas.height = newHeight;
|
|
6479
|
-
const ctx = canvas.getContext('2d');
|
|
6480
|
-
ctx?.drawImage(img, 0, 0, newWidth, newHeight);
|
|
6481
|
-
canvas.toBlob((blob) => {
|
|
6482
|
-
// Handle the compressed image. es. upload or save in local state
|
|
6483
|
-
if (blob) {
|
|
6484
|
-
// formData.append(
|
|
6485
|
-
// 'unicFileName',
|
|
6486
|
-
// 'x' + BarsaApi.Common.Util.GetNewMetaGuid() + ';;;' + file.name
|
|
6487
|
-
// );
|
|
6488
|
-
formData.append('file', blob, file.name);
|
|
6489
|
-
}
|
|
6490
|
-
if (index === files.length - 1) {
|
|
6491
|
-
resolve(formData);
|
|
6492
|
-
}
|
|
6493
|
-
}, MIME_TYPE, QUALITY);
|
|
6494
|
-
};
|
|
6495
|
-
function calculateSize(img1, maxWidth, maxHeight) {
|
|
6496
|
-
let width = img1.width;
|
|
6497
|
-
let height = img1.height;
|
|
6498
|
-
// calculate the width and height, constraining the proportions
|
|
6499
|
-
if (width > height) {
|
|
6500
|
-
if (width > maxWidth) {
|
|
6501
|
-
height = Math.round((height * maxWidth) / width);
|
|
6502
|
-
width = maxWidth;
|
|
6503
|
-
}
|
|
6504
|
-
}
|
|
6505
|
-
else {
|
|
6506
|
-
if (height > maxHeight) {
|
|
6507
|
-
width = Math.round((width * maxHeight) / height);
|
|
6508
|
-
height = maxHeight;
|
|
6509
|
-
}
|
|
6510
|
-
}
|
|
6511
|
-
return [width, height];
|
|
6512
|
-
}
|
|
6450
|
+
formData.append('file', file, file.name);
|
|
6513
6451
|
});
|
|
6452
|
+
resolve(formData);
|
|
6453
|
+
// const file2 = file; // get the file
|
|
6454
|
+
// const blobURL = URL.createObjectURL(file2);
|
|
6455
|
+
// const img = new Image();
|
|
6456
|
+
// img.src = blobURL;
|
|
6457
|
+
// const biggerThan1MB = file.size / 1024 > 1000;
|
|
6458
|
+
// const mimeTypeJpg = 'image/jpeg';
|
|
6459
|
+
// const MAX_WIDTH = 1920;
|
|
6460
|
+
// const MAX_HEIGHT = 1080;
|
|
6461
|
+
// const MIME_TYPE = biggerThan1MB ? mimeTypeJpg : file.type;
|
|
6462
|
+
// const QUALITY = biggerThan1MB && file.type === mimeTypeJpg ? 0.5 : 1;
|
|
6463
|
+
// if (MIME_TYPE === file.type && QUALITY === 1) {
|
|
6464
|
+
// formData.append('file', file, file.name);
|
|
6465
|
+
// if (index === files.length - 1) {
|
|
6466
|
+
// resolve(formData);
|
|
6467
|
+
// }
|
|
6468
|
+
// }
|
|
6469
|
+
// img.onerror = function (): void {
|
|
6470
|
+
// URL.revokeObjectURL(img.src);
|
|
6471
|
+
// // Handle the failure properly
|
|
6472
|
+
// console.log('Cannot load image');
|
|
6473
|
+
// reject(new Error('Cannot load image'));
|
|
6474
|
+
// };
|
|
6475
|
+
// img.onload = function (): void {
|
|
6476
|
+
// URL.revokeObjectURL(img.src);
|
|
6477
|
+
// const [newWidth, newHeight] = calculateSize(img, MAX_WIDTH, MAX_HEIGHT);
|
|
6478
|
+
// const canvas = document.createElement('canvas');
|
|
6479
|
+
// canvas.width = newWidth;
|
|
6480
|
+
// canvas.height = newHeight;
|
|
6481
|
+
// const ctx = canvas.getContext('2d');
|
|
6482
|
+
// ctx?.drawImage(img, 0, 0, newWidth, newHeight);
|
|
6483
|
+
// canvas.toBlob(
|
|
6484
|
+
// (blob) => {
|
|
6485
|
+
// // Handle the compressed image. es. upload or save in local state
|
|
6486
|
+
// if (blob) {
|
|
6487
|
+
// // formData.append(
|
|
6488
|
+
// // 'unicFileName',
|
|
6489
|
+
// // 'x' + BarsaApi.Common.Util.GetNewMetaGuid() + ';;;' + file.name
|
|
6490
|
+
// // );
|
|
6491
|
+
// formData.append('file', blob, file.name);
|
|
6492
|
+
// }
|
|
6493
|
+
// if (index === files.length - 1) {
|
|
6494
|
+
// resolve(formData);
|
|
6495
|
+
// }
|
|
6496
|
+
// },
|
|
6497
|
+
// MIME_TYPE,
|
|
6498
|
+
// QUALITY
|
|
6499
|
+
// );
|
|
6500
|
+
// };
|
|
6501
|
+
// function calculateSize(img1, maxWidth, maxHeight): number[] {
|
|
6502
|
+
// let width = img1.width;
|
|
6503
|
+
// let height = img1.height;
|
|
6504
|
+
// // calculate the width and height, constraining the proportions
|
|
6505
|
+
// if (width > height) {
|
|
6506
|
+
// if (width > maxWidth) {
|
|
6507
|
+
// height = Math.round((height * maxWidth) / width);
|
|
6508
|
+
// width = maxWidth;
|
|
6509
|
+
// }
|
|
6510
|
+
// } else {
|
|
6511
|
+
// if (height > maxHeight) {
|
|
6512
|
+
// width = Math.round((width * maxHeight) / height);
|
|
6513
|
+
// height = maxHeight;
|
|
6514
|
+
// }
|
|
6515
|
+
// }
|
|
6516
|
+
// return [width, height];
|
|
6517
|
+
// }
|
|
6518
|
+
// });
|
|
6514
6519
|
});
|
|
6515
6520
|
}
|
|
6516
6521
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UploadService, deps: [{ token: i1$1.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable }); }
|