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
- const file2 = file; // get the file
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
- const file2 = file; // get the file
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 }); }