From e138f5f915653966c3ec5779c9e4952cc08401bb Mon Sep 17 00:00:00 2001 From: David Sanders Date: Wed, 17 May 2023 10:33:30 -0700 Subject: [PATCH] docs: fix typing of message box type value (#38336) * docs: fix typing of dialog type value * test: add smoke tests * test: update test --- docs/api/dialog.md | 16 ++++++++-------- spec/api-dialog-spec.ts | 2 +- spec/ts-smoke/electron/main.ts | 18 ++++++++++++++++++ 3 files changed, 27 insertions(+), 9 deletions(-) diff --git a/docs/api/dialog.md b/docs/api/dialog.md index bc536e15baee..04960ed2dcf8 100644 --- a/docs/api/dialog.md +++ b/docs/api/dialog.md @@ -223,10 +223,10 @@ expanding and collapsing the dialog. * `browserWindow` [BrowserWindow](browser-window.md) (optional) * `options` Object * `message` string - Content of the message box. - * `type` string (optional) - Can be `"none"`, `"info"`, `"error"`, `"question"` or - `"warning"`. On Windows, `"question"` displays the same icon as `"info"`, unless - you set an icon using the `"icon"` option. On macOS, both `"warning"` and - `"error"` display the same warning icon. + * `type` string (optional) - Can be `none`, `info`, `error`, `question` or + `warning`. On Windows, `question` displays the same icon as `info`, unless + you set an icon using the `icon` option. On macOS, both `warning` and + `error` display the same warning icon. * `buttons` string[] (optional) - Array of texts for buttons. On Windows, an empty array will result in one button labeled "OK". * `defaultId` Integer (optional) - Index of the button in the buttons array which will @@ -266,10 +266,10 @@ If `browserWindow` is not shown dialog will not be attached to it. In such case * `browserWindow` [BrowserWindow](browser-window.md) (optional) * `options` Object * `message` string - Content of the message box. - * `type` string (optional) - Can be `"none"`, `"info"`, `"error"`, `"question"` or - `"warning"`. On Windows, `"question"` displays the same icon as `"info"`, unless - you set an icon using the `"icon"` option. On macOS, both `"warning"` and - `"error"` display the same warning icon. + * `type` string (optional) - Can be `none`, `info`, `error`, `question` or + `warning`. On Windows, `question` displays the same icon as `info`, unless + you set an icon using the `icon` option. On macOS, both `warning` and + `error` display the same warning icon. * `buttons` string[] (optional) - Array of texts for buttons. On Windows, an empty array will result in one button labeled "OK". * `defaultId` Integer (optional) - Index of the button in the buttons array which will diff --git a/spec/api-dialog-spec.ts b/spec/api-dialog-spec.ts index 2230b2f7fa12..72cb18573f14 100644 --- a/spec/api-dialog-spec.ts +++ b/spec/api-dialog-spec.ts @@ -97,7 +97,7 @@ describe('dialog module', () => { it('throws errors when the options are invalid', () => { expect(() => { - dialog.showMessageBox(undefined as any, { type: 'not-a-valid-type', message: '' }); + dialog.showMessageBox(undefined as any, { type: 'not-a-valid-type' as any, message: '' }); }).to.throw(/Invalid message box type/); expect(() => { diff --git a/spec/ts-smoke/electron/main.ts b/spec/ts-smoke/electron/main.ts index 9dfe9e819fa9..dba7fb341420 100644 --- a/spec/ts-smoke/electron/main.ts +++ b/spec/ts-smoke/electron/main.ts @@ -503,6 +503,24 @@ dialog.showOpenDialog(win3, { console.log(ret); }); +// variants without browserWindow +dialog.showMessageBox({ message: 'test', type: 'warning' }); +dialog.showMessageBoxSync({ message: 'test', type: 'error' }); + +// @ts-expect-error Invalid type value +dialog.showMessageBox({ message: 'test', type: 'foo' }); +// @ts-expect-error Invalid type value +dialog.showMessageBoxSync({ message: 'test', type: 'foo' }); + +// variants with browserWindow +dialog.showMessageBox(win3, { message: 'test', type: 'question' }); +dialog.showMessageBoxSync(win3, { message: 'test', type: 'info' }); + +// @ts-expect-error Invalid type value +dialog.showMessageBox(win3, { message: 'test', type: 'foo' }); +// @ts-expect-error Invalid type value +dialog.showMessageBoxSync(win3, { message: 'test', type: 'foo' }); + // desktopCapturer // https://github.com/electron/electron/blob/main/docs/api/desktop-capturer.md