From 77dc373b41fb5fee9fb7acdb511564043494bb10 Mon Sep 17 00:00:00 2001 From: jcesarmobile Date: Thu, 14 Dec 2023 16:19:31 +0100 Subject: [PATCH] fix(camera): reject promise on web input cancel event (#1964) Co-authored-by: Andrzej Sulkowski <111314156+andrzejSulkowski@users.noreply.github.com> --- camera/src/web.ts | 28 ++++++++++++++++++++-------- 1 file changed, 20 insertions(+), 8 deletions(-) diff --git a/camera/src/web.ts b/camera/src/web.ts index f1fa00e01..10e7e3fad 100644 --- a/camera/src/web.ts +++ b/camera/src/web.ts @@ -15,7 +15,7 @@ export class CameraWeb extends WebPlugin implements CameraPlugin { // eslint-disable-next-line no-async-promise-executor return new Promise(async (resolve, reject) => { if (options.webUseInput || options.source === CameraSource.Photos) { - this.fileInputExperience(options, resolve); + this.fileInputExperience(options, resolve, reject); } else if (options.source === CameraSource.Prompt) { let actionSheet: any = document.querySelector('pwa-action-sheet'); if (!actionSheet) { @@ -31,7 +31,7 @@ export class CameraWeb extends WebPlugin implements CameraPlugin { actionSheet.addEventListener('onSelection', async (e: any) => { const selection = e.detail; if (selection === 0) { - this.fileInputExperience(options, resolve); + this.fileInputExperience(options, resolve, reject); } else { this.cameraExperience(options, resolve, reject); } @@ -44,8 +44,8 @@ export class CameraWeb extends WebPlugin implements CameraPlugin { async pickImages(_options: GalleryImageOptions): Promise { // eslint-disable-next-line no-async-promise-executor - return new Promise(async resolve => { - this.multipleFileInputExperience(resolve); + return new Promise(async (resolve, reject) => { + this.multipleFileInputExperience(resolve, reject); }); } @@ -78,17 +78,21 @@ export class CameraWeb extends WebPlugin implements CameraPlugin { cameraModal.present(); } catch (e) { - this.fileInputExperience(options, resolve); + this.fileInputExperience(options, resolve, reject); } } else { console.error( `Unable to load PWA Element 'pwa-camera-modal'. See the docs: https://capacitorjs.com/docs/web/pwa-elements.`, ); - this.fileInputExperience(options, resolve); + this.fileInputExperience(options, resolve, reject); } } - private fileInputExperience(options: ImageOptions, resolve: any) { + private fileInputExperience( + options: ImageOptions, + resolve: any, + reject: any, + ) { let input = document.querySelector( '#_capacitor-camera-input', ) as HTMLInputElement; @@ -145,6 +149,10 @@ export class CameraWeb extends WebPlugin implements CameraPlugin { cleanup(); } }); + input.addEventListener('cancel', (_e: any) => { + reject(new CapacitorException('User cancelled photos app')); + cleanup(); + }); } input.accept = 'image/*'; @@ -164,7 +172,7 @@ export class CameraWeb extends WebPlugin implements CameraPlugin { input.click(); } - private multipleFileInputExperience(resolve: any) { + private multipleFileInputExperience(resolve: any, reject: any) { let input = document.querySelector( '#_capacitor-camera-input-multiple', ) as HTMLInputElement; @@ -200,6 +208,10 @@ export class CameraWeb extends WebPlugin implements CameraPlugin { resolve({ photos }); cleanup(); }); + input.addEventListener('cancel', (_e: any) => { + reject(new CapacitorException('User cancelled photos app')); + cleanup(); + }); } input.accept = 'image/*';