@itwin/core-electron 4.0.0-dev.8 → 4.0.0-dev.81

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.
Files changed (44) hide show
  1. package/CHANGELOG.md +49 -1
  2. package/lib/cjs/ElectronBackend.d.ts +1 -1
  3. package/lib/cjs/ElectronBackend.js +21 -17
  4. package/lib/cjs/ElectronBackend.js.map +1 -1
  5. package/lib/cjs/ElectronFrontend.d.ts +1 -1
  6. package/lib/cjs/ElectronFrontend.js +21 -17
  7. package/lib/cjs/ElectronFrontend.js.map +1 -1
  8. package/lib/cjs/__DOC_ONLY__.d.ts +3 -3
  9. package/lib/cjs/__DOC_ONLY__.js +26 -22
  10. package/lib/cjs/__DOC_ONLY__.js.map +1 -1
  11. package/lib/cjs/backend/ElectronHost.d.ts +104 -104
  12. package/lib/cjs/backend/ElectronHost.d.ts.map +1 -1
  13. package/lib/cjs/backend/ElectronHost.js +240 -243
  14. package/lib/cjs/backend/ElectronHost.js.map +1 -1
  15. package/lib/cjs/backend/ElectronPreload.d.ts +1 -1
  16. package/lib/cjs/backend/ElectronPreload.js +39 -39
  17. package/lib/cjs/common/ElectronIpcInterface.d.ts +7 -7
  18. package/lib/cjs/common/ElectronIpcInterface.d.ts.map +1 -1
  19. package/lib/cjs/common/ElectronIpcInterface.js +5 -5
  20. package/lib/cjs/common/ElectronIpcTransport.d.ts +44 -44
  21. package/lib/cjs/common/ElectronIpcTransport.js +186 -186
  22. package/lib/cjs/common/ElectronIpcTransport.js.map +1 -1
  23. package/lib/cjs/common/ElectronManagerLoggerCategory.d.ts +10 -10
  24. package/lib/cjs/common/ElectronManagerLoggerCategory.js +18 -18
  25. package/lib/cjs/common/ElectronPush.d.ts +20 -20
  26. package/lib/cjs/common/ElectronPush.js +48 -48
  27. package/lib/cjs/common/ElectronPush.js.map +1 -1
  28. package/lib/cjs/common/ElectronRpcManager.d.ts +26 -26
  29. package/lib/cjs/common/ElectronRpcManager.d.ts.map +1 -1
  30. package/lib/cjs/common/ElectronRpcManager.js +59 -65
  31. package/lib/cjs/common/ElectronRpcManager.js.map +1 -1
  32. package/lib/cjs/common/ElectronRpcProtocol.d.ts +34 -34
  33. package/lib/cjs/common/ElectronRpcProtocol.js +58 -58
  34. package/lib/cjs/common/ElectronRpcProtocol.js.map +1 -1
  35. package/lib/cjs/common/ElectronRpcRequest.d.ts +19 -19
  36. package/lib/cjs/common/ElectronRpcRequest.js +56 -56
  37. package/lib/cjs/common/ITwinElectronApi.d.ts +10 -10
  38. package/lib/cjs/common/ITwinElectronApi.d.ts.map +1 -1
  39. package/lib/cjs/common/ITwinElectronApi.js +6 -6
  40. package/lib/cjs/frontend/ElectronApp.d.ts +35 -35
  41. package/lib/cjs/frontend/ElectronApp.d.ts.map +1 -1
  42. package/lib/cjs/frontend/ElectronApp.js +73 -75
  43. package/lib/cjs/frontend/ElectronApp.js.map +1 -1
  44. package/package.json +25 -27
@@ -1,57 +1,57 @@
1
- "use strict";
2
- /*---------------------------------------------------------------------------------------------
3
- * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
4
- * See LICENSE.md in the project root for license terms and full copyright notice.
5
- *--------------------------------------------------------------------------------------------*/
6
- Object.defineProperty(exports, "__esModule", { value: true });
7
- exports.ElectronRpcRequest = void 0;
8
- const core_common_1 = require("@itwin/core-common");
9
- /* eslint-disable deprecation/deprecation */
10
- /** @internal */
11
- class ElectronRpcRequest extends core_common_1.RpcRequest {
12
- constructor() {
13
- super(...arguments);
14
- this._res = () => undefined;
15
- this._fulfillment = undefined;
16
- /** Convenience access to the protocol of this request. */
17
- this.protocol = this.client.configuration.protocol;
18
- }
19
- /** Sends the request. */
20
- async send() {
21
- try {
22
- this.protocol.requests.set(this.id, this);
23
- const request = await this.protocol.serialize(this);
24
- this.protocol.transport.sendRequest(request);
25
- }
26
- catch (e) {
27
- this.protocol.events.raiseEvent(core_common_1.RpcProtocolEvent.ConnectionErrorReceived, this);
28
- }
29
- return new Promise((resolve) => {
30
- this._res = resolve;
31
- });
32
- }
33
- /** Loads the request. */
34
- async load() {
35
- const fulfillment = this._fulfillment;
36
- if (!fulfillment) {
37
- throw new Error("No request fulfillment available.");
38
- }
39
- return fulfillment.result;
40
- }
41
- /** Sets request header values. */
42
- setHeader(_name, _value) {
43
- // No implementation
44
- }
45
- /** @internal */
46
- notifyResponse(fulfillment) {
47
- this._fulfillment = fulfillment;
48
- this._res(fulfillment.status);
49
- }
50
- /** @internal */
51
- dispose() {
52
- this.protocol.requests.delete(this.id);
53
- super.dispose();
54
- }
55
- }
56
- exports.ElectronRpcRequest = ElectronRpcRequest;
1
+ "use strict";
2
+ /*---------------------------------------------------------------------------------------------
3
+ * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
4
+ * See LICENSE.md in the project root for license terms and full copyright notice.
5
+ *--------------------------------------------------------------------------------------------*/
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.ElectronRpcRequest = void 0;
8
+ const core_common_1 = require("@itwin/core-common");
9
+ /* eslint-disable deprecation/deprecation */
10
+ /** @internal */
11
+ class ElectronRpcRequest extends core_common_1.RpcRequest {
12
+ constructor() {
13
+ super(...arguments);
14
+ this._res = () => undefined;
15
+ this._fulfillment = undefined;
16
+ /** Convenience access to the protocol of this request. */
17
+ this.protocol = this.client.configuration.protocol;
18
+ }
19
+ /** Sends the request. */
20
+ async send() {
21
+ try {
22
+ this.protocol.requests.set(this.id, this);
23
+ const request = await this.protocol.serialize(this);
24
+ this.protocol.transport.sendRequest(request);
25
+ }
26
+ catch (e) {
27
+ this.protocol.events.raiseEvent(core_common_1.RpcProtocolEvent.ConnectionErrorReceived, this);
28
+ }
29
+ return new Promise((resolve) => {
30
+ this._res = resolve;
31
+ });
32
+ }
33
+ /** Loads the request. */
34
+ async load() {
35
+ const fulfillment = this._fulfillment;
36
+ if (!fulfillment) {
37
+ throw new Error("No request fulfillment available.");
38
+ }
39
+ return fulfillment.result;
40
+ }
41
+ /** Sets request header values. */
42
+ setHeader(_name, _value) {
43
+ // No implementation
44
+ }
45
+ /** @internal */
46
+ notifyResponse(fulfillment) {
47
+ this._fulfillment = fulfillment;
48
+ this._res(fulfillment.status);
49
+ }
50
+ /** @internal */
51
+ dispose() {
52
+ this.protocol.requests.delete(this.id);
53
+ super.dispose();
54
+ }
55
+ }
56
+ exports.ElectronRpcRequest = ElectronRpcRequest;
57
57
  //# sourceMappingURL=ElectronRpcRequest.js.map
@@ -1,11 +1,11 @@
1
- import type { IpcRendererEvent } from "electron";
2
- /** These methods are stored on `window.itwinjs` */
3
- export interface ITwinElectronApi {
4
- addListener: (channel: string, listener: ElectronListener) => void;
5
- removeListener: (channel: string, listener: ElectronListener) => void;
6
- invoke: (channel: string, ...data: any[]) => Promise<any>;
7
- once: (channel: string, listener: (event: any, ...args: any[]) => void) => void;
8
- send: (channel: string, ...data: any[]) => void;
9
- }
10
- export declare type ElectronListener = (event: IpcRendererEvent, ...args: any[]) => void;
1
+ import type { IpcRendererEvent } from "electron";
2
+ /** These methods are stored on `window.itwinjs` */
3
+ export interface ITwinElectronApi {
4
+ addListener: (channel: string, listener: ElectronListener) => void;
5
+ removeListener: (channel: string, listener: ElectronListener) => void;
6
+ invoke: (channel: string, ...data: any[]) => Promise<any>;
7
+ once: (channel: string, listener: (event: any, ...args: any[]) => void) => void;
8
+ send: (channel: string, ...data: any[]) => void;
9
+ }
10
+ export type ElectronListener = (event: IpcRendererEvent, ...args: any[]) => void;
11
11
  //# sourceMappingURL=ITwinElectronApi.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"ITwinElectronApi.d.ts","sourceRoot":"","sources":["../../../src/common/ITwinElectronApi.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAC;AAEjD,mDAAmD;AACnD,MAAM,WAAW,gBAAgB;IAC/B,WAAW,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,gBAAgB,KAAK,IAAI,CAAC;IACnE,cAAc,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,gBAAgB,KAAK,IAAI,CAAC;IACtE,MAAM,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,OAAO,CAAC,GAAG,CAAC,CAAC;IAC1D,IAAI,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,IAAI,KAAK,IAAI,CAAC;IAChF,IAAI,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,IAAI,CAAC;CACjD;AAED,oBAAY,gBAAgB,GAAG,CAAC,KAAK,EAAE,gBAAgB,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,IAAI,CAAC"}
1
+ {"version":3,"file":"ITwinElectronApi.d.ts","sourceRoot":"","sources":["../../../src/common/ITwinElectronApi.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAC;AAEjD,mDAAmD;AACnD,MAAM,WAAW,gBAAgB;IAC/B,WAAW,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,gBAAgB,KAAK,IAAI,CAAC;IACnE,cAAc,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,gBAAgB,KAAK,IAAI,CAAC;IACtE,MAAM,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,OAAO,CAAC,GAAG,CAAC,CAAC;IAC1D,IAAI,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,IAAI,KAAK,IAAI,CAAC;IAChF,IAAI,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,IAAI,CAAC;CACjD;AAED,MAAM,MAAM,gBAAgB,GAAG,CAAC,KAAK,EAAE,gBAAgB,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,IAAI,CAAC"}
@@ -1,7 +1,7 @@
1
- "use strict";
2
- /*---------------------------------------------------------------------------------------------
3
- * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
4
- * See LICENSE.md in the project root for license terms and full copyright notice.
5
- *--------------------------------------------------------------------------------------------*/
6
- Object.defineProperty(exports, "__esModule", { value: true });
1
+ "use strict";
2
+ /*---------------------------------------------------------------------------------------------
3
+ * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
4
+ * See LICENSE.md in the project root for license terms and full copyright notice.
5
+ *--------------------------------------------------------------------------------------------*/
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
7
  //# sourceMappingURL=ITwinElectronApi.js.map
@@ -1,36 +1,36 @@
1
- import { PromiseReturnType } from "@itwin/core-bentley";
2
- import { NativeAppOpts } from "@itwin/core-frontend";
3
- import { DialogModuleMethod } from "../common/ElectronIpcInterface";
4
- import type { ITwinElectronApi } from "../common/ITwinElectronApi";
5
- declare global {
6
- interface Window {
7
- itwinjs: ITwinElectronApi;
8
- }
9
- }
10
- /** @beta */
11
- export declare type ElectronAppOpts = NativeAppOpts;
12
- /**
13
- * Frontend of an Electron App.
14
- * @beta
15
- */
16
- export declare class ElectronApp {
17
- private static _ipc?;
18
- static get isValid(): boolean;
19
- /**
20
- * Start the frontend of an Electron application.
21
- * @param opts Options for your ElectronApp
22
- * @note This method must only be called from the frontend of an Electron app (i.e. when [ProcessDetector.isElectronAppFrontend]($bentley) is `true`).
23
- */
24
- static startup(opts?: ElectronAppOpts): Promise<void>;
25
- static shutdown(): Promise<void>;
26
- /**
27
- * Call an asynchronous method in the [Electron.Dialog](https://www.electronjs.org/docs/api/dialog) interface from a previously initialized ElectronFrontend.
28
- * @param methodName the name of the method to call
29
- * @param args arguments to method
30
- * @deprecated in 3.x. use [[dialogIpc]]
31
- */
32
- static callDialog<T extends DialogModuleMethod>(methodName: T, ...args: Parameters<Electron.Dialog[T]>): Promise<PromiseReturnType<Electron.Dialog[T]>>;
33
- /** Proxy object for calling methods of `Electron.Dialog` */
34
- static dialogIpc: import("@itwin/core-bentley").PickAsyncMethods<Electron.Dialog>;
35
- }
1
+ import { PromiseReturnType } from "@itwin/core-bentley";
2
+ import { NativeAppOpts } from "@itwin/core-frontend";
3
+ import { DialogModuleMethod } from "../common/ElectronIpcInterface";
4
+ import type { ITwinElectronApi } from "../common/ITwinElectronApi";
5
+ declare global {
6
+ interface Window {
7
+ itwinjs: ITwinElectronApi;
8
+ }
9
+ }
10
+ /** @beta */
11
+ export type ElectronAppOpts = NativeAppOpts;
12
+ /**
13
+ * Frontend of an Electron App.
14
+ * @beta
15
+ */
16
+ export declare class ElectronApp {
17
+ private static _ipc?;
18
+ static get isValid(): boolean;
19
+ /**
20
+ * Start the frontend of an Electron application.
21
+ * @param opts Options for your ElectronApp
22
+ * @note This method must only be called from the frontend of an Electron app (i.e. when [ProcessDetector.isElectronAppFrontend]($bentley) is `true`).
23
+ */
24
+ static startup(opts?: ElectronAppOpts): Promise<void>;
25
+ static shutdown(): Promise<void>;
26
+ /**
27
+ * Call an asynchronous method in the [Electron.Dialog](https://www.electronjs.org/docs/api/dialog) interface from a previously initialized ElectronFrontend.
28
+ * @param methodName the name of the method to call
29
+ * @param args arguments to method
30
+ * @deprecated in 3.x. use [[dialogIpc]]
31
+ */
32
+ static callDialog<T extends DialogModuleMethod>(methodName: T, ...args: Parameters<Electron.Dialog[T]>): Promise<PromiseReturnType<Electron.Dialog[T]>>;
33
+ /** Proxy object for calling methods of `Electron.Dialog` */
34
+ static dialogIpc: import("@itwin/core-bentley").PickAsyncMethods<Electron.Dialog>;
35
+ }
36
36
  //# sourceMappingURL=ElectronApp.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"ElectronApp.d.ts","sourceRoot":"","sources":["../../../src/frontend/ElectronApp.ts"],"names":[],"mappings":"AAIA,OAAO,EAAmB,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAEzE,OAAO,EAAqB,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAExE,OAAO,EAAiB,kBAAkB,EAAE,MAAM,gCAAgC,CAAC;AAEnF,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,4BAA4B,CAAC;AAEnE,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,MAAM;QACd,OAAO,EAAE,gBAAgB,CAAC;KAC3B;CACF;AA4BD,YAAY;AACZ,oBAAY,eAAe,GAAG,aAAa,CAAC;AAE5C;;;GAGG;AACH,qBAAa,WAAW;IACtB,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAc;IAClC,WAAkB,OAAO,IAAI,OAAO,CAAoC;IAExE;;;;OAIG;WACiB,OAAO,CAAC,IAAI,CAAC,EAAE,eAAe;WAU9B,QAAQ;IAM5B;;;;;OAKG;WACiB,UAAU,CAAC,CAAC,SAAS,kBAAkB,EAAE,UAAU,EAAE,CAAC,EAAE,GAAG,IAAI,EAAE,UAAU,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;IAInH,4DAA4D;IAC5D,OAAc,SAAS,kEAA6E;CACrG"}
1
+ {"version":3,"file":"ElectronApp.d.ts","sourceRoot":"","sources":["../../../src/frontend/ElectronApp.ts"],"names":[],"mappings":"AAIA,OAAO,EAAmB,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAEzE,OAAO,EAAqB,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAExE,OAAO,EAAiB,kBAAkB,EAAE,MAAM,gCAAgC,CAAC;AAEnF,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,4BAA4B,CAAC;AAEnE,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,MAAM;QACd,OAAO,EAAE,gBAAgB,CAAC;KAC3B;CACF;AA4BD,YAAY;AACZ,MAAM,MAAM,eAAe,GAAG,aAAa,CAAC;AAE5C;;;GAGG;AACH,qBAAa,WAAW;IACtB,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAc;IAClC,WAAkB,OAAO,IAAI,OAAO,CAAoC;IAExE;;;;OAIG;WACiB,OAAO,CAAC,IAAI,CAAC,EAAE,eAAe;WAU9B,QAAQ;IAM5B;;;;;OAKG;WACiB,UAAU,CAAC,CAAC,SAAS,kBAAkB,EAAE,UAAU,EAAE,CAAC,EAAE,GAAG,IAAI,EAAE,UAAU,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;IAInH,4DAA4D;IAC5D,OAAc,SAAS,kEAA6E;CACrG"}
@@ -1,76 +1,74 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.ElectronApp = void 0;
4
- /*---------------------------------------------------------------------------------------------
5
- * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
6
- * See LICENSE.md in the project root for license terms and full copyright notice.
7
- *--------------------------------------------------------------------------------------------*/
8
- const core_bentley_1 = require("@itwin/core-bentley");
9
- const core_frontend_1 = require("@itwin/core-frontend");
10
- const ElectronIpcInterface_1 = require("../common/ElectronIpcInterface");
11
- const ElectronRpcManager_1 = require("../common/ElectronRpcManager");
12
- /**
13
- * Frontend Ipc support for Electron apps.
14
- */
15
- class ElectronIpc {
16
- constructor() {
17
- var _a;
18
- // use the methods on window.itwinjs exposed by ElectronPreload.ts, or ipcRenderer directly if running with nodeIntegration=true (**only** for tests).
19
- // Note that `require("electron")` doesn't work with nodeIntegration=false - that's what it stops
20
- // eslint-disable-next-line @typescript-eslint/no-var-requires
21
- this._api = (_a = window.itwinjs) !== null && _a !== void 0 ? _a : require("electron").ipcRenderer;
22
- }
23
- addListener(channelName, listener) {
24
- this._api.addListener(channelName, listener);
25
- return () => this._api.removeListener(channelName, listener);
26
- }
27
- removeListener(channelName, listener) {
28
- this._api.removeListener(channelName, listener);
29
- }
30
- send(channel, ...data) {
31
- this._api.send(channel, ...data);
32
- }
33
- async invoke(channel, ...args) {
34
- return this._api.invoke(channel, ...args);
35
- }
36
- }
37
- /**
38
- * Frontend of an Electron App.
39
- * @beta
40
- */
41
- class ElectronApp {
42
- static get isValid() { return undefined !== this._ipc; }
43
- /**
44
- * Start the frontend of an Electron application.
45
- * @param opts Options for your ElectronApp
46
- * @note This method must only be called from the frontend of an Electron app (i.e. when [ProcessDetector.isElectronAppFrontend]($bentley) is `true`).
47
- */
48
- static async startup(opts) {
49
- var _a;
50
- if (!core_bentley_1.ProcessDetector.isElectronAppFrontend)
51
- throw new Error("Not running under Electron");
52
- if (!this.isValid) {
53
- this._ipc = new ElectronIpc();
54
- ElectronRpcManager_1.ElectronRpcManager.initializeFrontend(this._ipc, (_a = opts === null || opts === void 0 ? void 0 : opts.iModelApp) === null || _a === void 0 ? void 0 : _a.rpcInterfaces);
55
- }
56
- await core_frontend_1.NativeApp.startup(this._ipc, opts);
57
- }
58
- static async shutdown() {
59
- this._ipc = undefined;
60
- await core_frontend_1.NativeApp.shutdown();
61
- ElectronRpcManager_1.ElectronRpcManager.terminateFrontend();
62
- }
63
- /**
64
- * Call an asynchronous method in the [Electron.Dialog](https://www.electronjs.org/docs/api/dialog) interface from a previously initialized ElectronFrontend.
65
- * @param methodName the name of the method to call
66
- * @param args arguments to method
67
- * @deprecated in 3.x. use [[dialogIpc]]
68
- */
69
- static async callDialog(methodName, ...args) {
70
- return core_frontend_1.IpcApp.callIpcChannel(ElectronIpcInterface_1.dialogChannel, "callDialog", methodName, ...args);
71
- }
72
- }
73
- exports.ElectronApp = ElectronApp;
74
- /** Proxy object for calling methods of `Electron.Dialog` */
75
- ElectronApp.dialogIpc = core_frontend_1.IpcApp.makeIpcFunctionProxy(ElectronIpcInterface_1.dialogChannel, "callDialog");
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ElectronApp = void 0;
4
+ /*---------------------------------------------------------------------------------------------
5
+ * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
6
+ * See LICENSE.md in the project root for license terms and full copyright notice.
7
+ *--------------------------------------------------------------------------------------------*/
8
+ const core_bentley_1 = require("@itwin/core-bentley");
9
+ const core_frontend_1 = require("@itwin/core-frontend");
10
+ const ElectronIpcInterface_1 = require("../common/ElectronIpcInterface");
11
+ const ElectronRpcManager_1 = require("../common/ElectronRpcManager");
12
+ /**
13
+ * Frontend Ipc support for Electron apps.
14
+ */
15
+ class ElectronIpc {
16
+ addListener(channelName, listener) {
17
+ this._api.addListener(channelName, listener);
18
+ return () => this._api.removeListener(channelName, listener);
19
+ }
20
+ removeListener(channelName, listener) {
21
+ this._api.removeListener(channelName, listener);
22
+ }
23
+ send(channel, ...data) {
24
+ this._api.send(channel, ...data);
25
+ }
26
+ async invoke(channel, ...args) {
27
+ return this._api.invoke(channel, ...args);
28
+ }
29
+ constructor() {
30
+ // use the methods on window.itwinjs exposed by ElectronPreload.ts, or ipcRenderer directly if running with nodeIntegration=true (**only** for tests).
31
+ // Note that `require("electron")` doesn't work with nodeIntegration=false - that's what it stops
32
+ // eslint-disable-next-line @typescript-eslint/no-var-requires
33
+ this._api = window.itwinjs ?? require("electron").ipcRenderer;
34
+ }
35
+ }
36
+ /**
37
+ * Frontend of an Electron App.
38
+ * @beta
39
+ */
40
+ class ElectronApp {
41
+ static get isValid() { return undefined !== this._ipc; }
42
+ /**
43
+ * Start the frontend of an Electron application.
44
+ * @param opts Options for your ElectronApp
45
+ * @note This method must only be called from the frontend of an Electron app (i.e. when [ProcessDetector.isElectronAppFrontend]($bentley) is `true`).
46
+ */
47
+ static async startup(opts) {
48
+ if (!core_bentley_1.ProcessDetector.isElectronAppFrontend)
49
+ throw new Error("Not running under Electron");
50
+ if (!this.isValid) {
51
+ this._ipc = new ElectronIpc();
52
+ ElectronRpcManager_1.ElectronRpcManager.initializeFrontend(this._ipc, opts?.iModelApp?.rpcInterfaces); // eslint-disable-line deprecation/deprecation
53
+ }
54
+ await core_frontend_1.NativeApp.startup(this._ipc, opts);
55
+ }
56
+ static async shutdown() {
57
+ this._ipc = undefined;
58
+ await core_frontend_1.NativeApp.shutdown();
59
+ ElectronRpcManager_1.ElectronRpcManager.terminateFrontend();
60
+ }
61
+ /**
62
+ * Call an asynchronous method in the [Electron.Dialog](https://www.electronjs.org/docs/api/dialog) interface from a previously initialized ElectronFrontend.
63
+ * @param methodName the name of the method to call
64
+ * @param args arguments to method
65
+ * @deprecated in 3.x. use [[dialogIpc]]
66
+ */
67
+ static async callDialog(methodName, ...args) {
68
+ return core_frontend_1.IpcApp.callIpcChannel(ElectronIpcInterface_1.dialogChannel, "callDialog", methodName, ...args);
69
+ }
70
+ }
71
+ /** Proxy object for calling methods of `Electron.Dialog` */
72
+ ElectronApp.dialogIpc = core_frontend_1.IpcApp.makeIpcFunctionProxy(ElectronIpcInterface_1.dialogChannel, "callDialog");
73
+ exports.ElectronApp = ElectronApp;
76
74
  //# sourceMappingURL=ElectronApp.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"ElectronApp.js","sourceRoot":"","sources":["../../../src/frontend/ElectronApp.ts"],"names":[],"mappings":";;;AAAA;;;+FAG+F;AAC/F,sDAAyE;AAEzE,wDAAwE;AAExE,yEAAmF;AACnF,qEAAkE;AASlE;;GAEG;AACH,MAAM,WAAW;IAef;;QACE,sJAAsJ;QACtJ,iGAAiG;QACjG,8DAA8D;QAC9D,IAAI,CAAC,IAAI,GAAG,MAAA,MAAM,CAAC,OAAO,mCAAI,OAAO,CAAC,UAAU,CAAC,CAAC,WAAW,CAAC;IAChE,CAAC;IAlBM,WAAW,CAAC,WAAmB,EAAE,QAAqB;QAC3D,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;QAC7C,OAAO,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;IAC/D,CAAC;IACM,cAAc,CAAC,WAAmB,EAAE,QAAqB;QAC9D,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;IAClD,CAAC;IACM,IAAI,CAAC,OAAe,EAAE,GAAG,IAAW;QACzC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,CAAC;IACnC,CAAC;IACM,KAAK,CAAC,MAAM,CAAC,OAAe,EAAE,GAAG,IAAW;QACjD,OAAO,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,CAAC;IAC5C,CAAC;CAOF;AAKD;;;GAGG;AACH,MAAa,WAAW;IAEf,MAAM,KAAK,OAAO,KAAc,OAAO,SAAS,KAAK,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IAExE;;;;OAIG;IACI,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,IAAsB;;QAChD,IAAI,CAAC,8BAAe,CAAC,qBAAqB;YACxC,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC;QAChD,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YACjB,IAAI,CAAC,IAAI,GAAG,IAAI,WAAW,EAAE,CAAC;YAC9B,uCAAkB,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,EAAE,MAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,SAAS,0CAAE,aAAa,CAAC,CAAC;SAClF;QACD,MAAM,yBAAS,CAAC,OAAO,CAAC,IAAI,CAAC,IAAK,EAAE,IAAI,CAAC,CAAC;IAC5C,CAAC;IAEM,MAAM,CAAC,KAAK,CAAC,QAAQ;QAC1B,IAAI,CAAC,IAAI,GAAG,SAAS,CAAC;QACtB,MAAM,yBAAS,CAAC,QAAQ,EAAE,CAAC;QAC3B,uCAAkB,CAAC,iBAAiB,EAAE,CAAC;IACzC,CAAC;IAED;;;;;OAKG;IACI,MAAM,CAAC,KAAK,CAAC,UAAU,CAA+B,UAAa,EAAE,GAAG,IAAoC;QACjH,OAAO,sBAAM,CAAC,cAAc,CAAC,oCAAa,EAAE,YAAY,EAAE,UAAU,EAAE,GAAG,IAAI,CAA0C,CAAC;IAC1H,CAAC;;AAjCH,kCAqCC;AAFC,4DAA4D;AAC9C,qBAAS,GAAG,sBAAM,CAAC,oBAAoB,CAAkB,oCAAa,EAAE,YAAY,CAAC,CAAC","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\nimport { ProcessDetector, PromiseReturnType } from \"@itwin/core-bentley\";\r\nimport { IpcListener, IpcSocketFrontend } from \"@itwin/core-common\";\r\nimport { IpcApp, NativeApp, NativeAppOpts } from \"@itwin/core-frontend\";\r\nimport type { IpcRenderer } from \"electron\";\r\nimport { dialogChannel, DialogModuleMethod } from \"../common/ElectronIpcInterface\";\r\nimport { ElectronRpcManager } from \"../common/ElectronRpcManager\";\r\nimport type { ITwinElectronApi } from \"../common/ITwinElectronApi\";\r\n\r\ndeclare global {\r\n interface Window {\r\n itwinjs: ITwinElectronApi;\r\n }\r\n}\r\n\r\n/**\r\n * Frontend Ipc support for Electron apps.\r\n */\r\nclass ElectronIpc implements IpcSocketFrontend {\r\n private _api: ITwinElectronApi | IpcRenderer;\r\n public addListener(channelName: string, listener: IpcListener) {\r\n this._api.addListener(channelName, listener);\r\n return () => this._api.removeListener(channelName, listener);\r\n }\r\n public removeListener(channelName: string, listener: IpcListener) {\r\n this._api.removeListener(channelName, listener);\r\n }\r\n public send(channel: string, ...data: any[]) {\r\n this._api.send(channel, ...data);\r\n }\r\n public async invoke(channel: string, ...args: any[]) {\r\n return this._api.invoke(channel, ...args);\r\n }\r\n constructor() {\r\n // use the methods on window.itwinjs exposed by ElectronPreload.ts, or ipcRenderer directly if running with nodeIntegration=true (**only** for tests).\r\n // Note that `require(\"electron\")` doesn't work with nodeIntegration=false - that's what it stops\r\n // eslint-disable-next-line @typescript-eslint/no-var-requires\r\n this._api = window.itwinjs ?? require(\"electron\").ipcRenderer;\r\n }\r\n}\r\n\r\n/** @beta */\r\nexport type ElectronAppOpts = NativeAppOpts;\r\n\r\n/**\r\n * Frontend of an Electron App.\r\n * @beta\r\n */\r\nexport class ElectronApp {\r\n private static _ipc?: ElectronIpc;\r\n public static get isValid(): boolean { return undefined !== this._ipc; }\r\n\r\n /**\r\n * Start the frontend of an Electron application.\r\n * @param opts Options for your ElectronApp\r\n * @note This method must only be called from the frontend of an Electron app (i.e. when [ProcessDetector.isElectronAppFrontend]($bentley) is `true`).\r\n */\r\n public static async startup(opts?: ElectronAppOpts) {\r\n if (!ProcessDetector.isElectronAppFrontend)\r\n throw new Error(\"Not running under Electron\");\r\n if (!this.isValid) {\r\n this._ipc = new ElectronIpc();\r\n ElectronRpcManager.initializeFrontend(this._ipc, opts?.iModelApp?.rpcInterfaces);\r\n }\r\n await NativeApp.startup(this._ipc!, opts);\r\n }\r\n\r\n public static async shutdown() {\r\n this._ipc = undefined;\r\n await NativeApp.shutdown();\r\n ElectronRpcManager.terminateFrontend();\r\n }\r\n\r\n /**\r\n * Call an asynchronous method in the [Electron.Dialog](https://www.electronjs.org/docs/api/dialog) interface from a previously initialized ElectronFrontend.\r\n * @param methodName the name of the method to call\r\n * @param args arguments to method\r\n * @deprecated in 3.x. use [[dialogIpc]]\r\n */\r\n public static async callDialog<T extends DialogModuleMethod>(methodName: T, ...args: Parameters<Electron.Dialog[T]>) {\r\n return IpcApp.callIpcChannel(dialogChannel, \"callDialog\", methodName, ...args) as PromiseReturnType<Electron.Dialog[T]>;\r\n }\r\n\r\n /** Proxy object for calling methods of `Electron.Dialog` */\r\n public static dialogIpc = IpcApp.makeIpcFunctionProxy<Electron.Dialog>(dialogChannel, \"callDialog\");\r\n}\r\n"]}
1
+ {"version":3,"file":"ElectronApp.js","sourceRoot":"","sources":["../../../src/frontend/ElectronApp.ts"],"names":[],"mappings":";;;AAAA;;;+FAG+F;AAC/F,sDAAyE;AAEzE,wDAAwE;AAExE,yEAAmF;AACnF,qEAAkE;AASlE;;GAEG;AACH,MAAM,WAAW;IAER,WAAW,CAAC,WAAmB,EAAE,QAAqB;QAC3D,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;QAC7C,OAAO,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;IAC/D,CAAC;IACM,cAAc,CAAC,WAAmB,EAAE,QAAqB;QAC9D,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;IAClD,CAAC;IACM,IAAI,CAAC,OAAe,EAAE,GAAG,IAAW;QACzC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,CAAC;IACnC,CAAC;IACM,KAAK,CAAC,MAAM,CAAC,OAAe,EAAE,GAAG,IAAW;QACjD,OAAO,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,CAAC;IAC5C,CAAC;IACD;QACE,sJAAsJ;QACtJ,iGAAiG;QACjG,8DAA8D;QAC9D,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC,OAAO,IAAI,OAAO,CAAC,UAAU,CAAC,CAAC,WAAW,CAAC;IAChE,CAAC;CACF;AAKD;;;GAGG;AACH,MAAa,WAAW;IAEf,MAAM,KAAK,OAAO,KAAc,OAAO,SAAS,KAAK,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IAExE;;;;OAIG;IACI,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,IAAsB;QAChD,IAAI,CAAC,8BAAe,CAAC,qBAAqB;YACxC,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC;QAChD,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YACjB,IAAI,CAAC,IAAI,GAAG,IAAI,WAAW,EAAE,CAAC;YAC9B,uCAAkB,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE,aAAa,CAAC,CAAC,CAAC,8CAA8C;SACjI;QACD,MAAM,yBAAS,CAAC,OAAO,CAAC,IAAI,CAAC,IAAK,EAAE,IAAI,CAAC,CAAC;IAC5C,CAAC;IAEM,MAAM,CAAC,KAAK,CAAC,QAAQ;QAC1B,IAAI,CAAC,IAAI,GAAG,SAAS,CAAC;QACtB,MAAM,yBAAS,CAAC,QAAQ,EAAE,CAAC;QAC3B,uCAAkB,CAAC,iBAAiB,EAAE,CAAC;IACzC,CAAC;IAED;;;;;OAKG;IACI,MAAM,CAAC,KAAK,CAAC,UAAU,CAA+B,UAAa,EAAE,GAAG,IAAoC;QACjH,OAAO,sBAAM,CAAC,cAAc,CAAC,oCAAa,EAAE,YAAY,EAAE,UAAU,EAAE,GAAG,IAAI,CAA0C,CAAC;IAC1H,CAAC;;AAED,4DAA4D;AAC9C,qBAAS,GAAG,sBAAM,CAAC,oBAAoB,CAAkB,oCAAa,EAAE,YAAY,CAAC,CAAC;AApCzF,kCAAW","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\nimport { ProcessDetector, PromiseReturnType } from \"@itwin/core-bentley\";\r\nimport { IpcListener, IpcSocketFrontend } from \"@itwin/core-common\";\r\nimport { IpcApp, NativeApp, NativeAppOpts } from \"@itwin/core-frontend\";\r\nimport type { IpcRenderer } from \"electron\";\r\nimport { dialogChannel, DialogModuleMethod } from \"../common/ElectronIpcInterface\";\r\nimport { ElectronRpcManager } from \"../common/ElectronRpcManager\";\r\nimport type { ITwinElectronApi } from \"../common/ITwinElectronApi\";\r\n\r\ndeclare global {\r\n interface Window {\r\n itwinjs: ITwinElectronApi;\r\n }\r\n}\r\n\r\n/**\r\n * Frontend Ipc support for Electron apps.\r\n */\r\nclass ElectronIpc implements IpcSocketFrontend {\r\n private _api: ITwinElectronApi | IpcRenderer;\r\n public addListener(channelName: string, listener: IpcListener) {\r\n this._api.addListener(channelName, listener);\r\n return () => this._api.removeListener(channelName, listener);\r\n }\r\n public removeListener(channelName: string, listener: IpcListener) {\r\n this._api.removeListener(channelName, listener);\r\n }\r\n public send(channel: string, ...data: any[]) {\r\n this._api.send(channel, ...data);\r\n }\r\n public async invoke(channel: string, ...args: any[]) {\r\n return this._api.invoke(channel, ...args);\r\n }\r\n constructor() {\r\n // use the methods on window.itwinjs exposed by ElectronPreload.ts, or ipcRenderer directly if running with nodeIntegration=true (**only** for tests).\r\n // Note that `require(\"electron\")` doesn't work with nodeIntegration=false - that's what it stops\r\n // eslint-disable-next-line @typescript-eslint/no-var-requires\r\n this._api = window.itwinjs ?? require(\"electron\").ipcRenderer;\r\n }\r\n}\r\n\r\n/** @beta */\r\nexport type ElectronAppOpts = NativeAppOpts;\r\n\r\n/**\r\n * Frontend of an Electron App.\r\n * @beta\r\n */\r\nexport class ElectronApp {\r\n private static _ipc?: ElectronIpc;\r\n public static get isValid(): boolean { return undefined !== this._ipc; }\r\n\r\n /**\r\n * Start the frontend of an Electron application.\r\n * @param opts Options for your ElectronApp\r\n * @note This method must only be called from the frontend of an Electron app (i.e. when [ProcessDetector.isElectronAppFrontend]($bentley) is `true`).\r\n */\r\n public static async startup(opts?: ElectronAppOpts) {\r\n if (!ProcessDetector.isElectronAppFrontend)\r\n throw new Error(\"Not running under Electron\");\r\n if (!this.isValid) {\r\n this._ipc = new ElectronIpc();\r\n ElectronRpcManager.initializeFrontend(this._ipc, opts?.iModelApp?.rpcInterfaces); // eslint-disable-line deprecation/deprecation\r\n }\r\n await NativeApp.startup(this._ipc!, opts);\r\n }\r\n\r\n public static async shutdown() {\r\n this._ipc = undefined;\r\n await NativeApp.shutdown();\r\n ElectronRpcManager.terminateFrontend();\r\n }\r\n\r\n /**\r\n * Call an asynchronous method in the [Electron.Dialog](https://www.electronjs.org/docs/api/dialog) interface from a previously initialized ElectronFrontend.\r\n * @param methodName the name of the method to call\r\n * @param args arguments to method\r\n * @deprecated in 3.x. use [[dialogIpc]]\r\n */\r\n public static async callDialog<T extends DialogModuleMethod>(methodName: T, ...args: Parameters<Electron.Dialog[T]>) {\r\n return IpcApp.callIpcChannel(dialogChannel, \"callDialog\", methodName, ...args) as PromiseReturnType<Electron.Dialog[T]>;\r\n }\r\n\r\n /** Proxy object for calling methods of `Electron.Dialog` */\r\n public static dialogIpc = IpcApp.makeIpcFunctionProxy<Electron.Dialog>(dialogChannel, \"callDialog\");\r\n}\r\n"]}
package/package.json CHANGED
@@ -1,14 +1,15 @@
1
1
  {
2
2
  "name": "@itwin/core-electron",
3
- "version": "4.0.0-dev.8",
3
+ "version": "4.0.0-dev.81",
4
4
  "description": "iTwin.js ElectronHost and ElectronApp",
5
5
  "license": "MIT",
6
6
  "engines": {
7
- "node": ">=16.13.0 < 19.0"
7
+ "node": "^18.0.0"
8
8
  },
9
9
  "repository": {
10
10
  "type": "git",
11
- "url": "https://github.com/iTwin/itwinjs-core/tree/master/core/core-electron"
11
+ "url": "https://github.com/iTwin/itwinjs-core.git",
12
+ "directory": "core/electron"
12
13
  },
13
14
  "keywords": [
14
15
  "Bentley",
@@ -20,33 +21,32 @@
20
21
  "url": "http://www.bentley.com"
21
22
  },
22
23
  "peerDependencies": {
23
- "@itwin/core-backend": "^4.0.0-dev.8",
24
- "@itwin/core-bentley": "^4.0.0-dev.8",
25
- "@itwin/core-common": "^4.0.0-dev.8",
26
- "@itwin/core-frontend": "^4.0.0-dev.8",
27
- "@itwin/presentation-common": "^4.0.0-dev.8",
28
- "electron": ">=14.0.0 <18.0.0 || >=22.0.0 <23.0.0"
24
+ "@itwin/core-backend": "^4.0.0-dev.81",
25
+ "@itwin/core-bentley": "^4.0.0-dev.81",
26
+ "@itwin/core-common": "^4.0.0-dev.81",
27
+ "@itwin/core-frontend": "^4.0.0-dev.81",
28
+ "electron": ">=23.0.0 <25.0.0"
29
29
  },
30
30
  "devDependencies": {
31
- "@itwin/build-tools": "4.0.0-dev.8",
32
- "@itwin/certa": "4.0.0-dev.8",
33
- "@itwin/core-backend": "4.0.0-dev.8",
34
- "@itwin/core-bentley": "4.0.0-dev.8",
35
- "@itwin/core-common": "4.0.0-dev.8",
36
- "@itwin/core-frontend": "4.0.0-dev.8",
37
- "@itwin/eslint-plugin": "4.0.0-dev.8",
38
- "@itwin/presentation-common": "4.0.0-dev.8",
31
+ "@itwin/build-tools": "4.0.0-dev.81",
32
+ "@itwin/certa": "4.0.0-dev.81",
33
+ "@itwin/core-backend": "4.0.0-dev.81",
34
+ "@itwin/core-bentley": "4.0.0-dev.81",
35
+ "@itwin/core-common": "4.0.0-dev.81",
36
+ "@itwin/core-frontend": "4.0.0-dev.81",
37
+ "@itwin/eslint-plugin": "^4.0.0-dev.33",
39
38
  "@types/chai": "4.3.1",
40
39
  "@types/mocha": "^8.2.2",
41
- "@types/node": "18.11.5",
40
+ "@types/node": "^18.11.5",
42
41
  "chai": "^4.1.2",
43
- "electron": "^22.0.0",
44
- "eslint": "^7.11.0",
42
+ "electron": "^24.0.0",
43
+ "eslint": "^8.36.0",
45
44
  "mocha": "^10.0.0",
46
45
  "rimraf": "^3.0.2",
47
46
  "source-map-loader": "^4.0.0",
48
- "typescript": "~4.4.0",
49
- "webpack": "^5.64.4"
47
+ "typescript": "~5.0.2",
48
+ "webpack": "^5.76.0",
49
+ "webpack-cli": "^5.0.1"
50
50
  },
51
51
  "dependencies": {
52
52
  "@openid/appauth": "^1.2.6",
@@ -60,19 +60,17 @@
60
60
  "extends": "plugin:@itwin/itwinjs-recommended"
61
61
  },
62
62
  "scripts": {
63
- "build": "npm run -s build:cjs",
64
- "build:ci": "npm run -s build",
63
+ "build": "npm run -s build:cjs && npm run -s webpack:test",
65
64
  "build:cjs": "tsc 1>&2 --outDir lib/cjs",
66
65
  "clean": "rimraf lib .rush/temp/package-deps*.json",
67
66
  "docs": "betools docs --includes=../../generated-docs/extract --json=../../generated-docs/core/core-electron/file.json --tsIndexFile=./__DOC_ONLY__.ts --onlyJson",
68
67
  "extract-api": "betools extract-api --entry=__DOC_ONLY__",
69
68
  "lint": "eslint -f visualstudio \"./src/**/*.ts\" 1>&2",
70
69
  "test": "",
71
- "test:integration": "npm run test:integration:backend && npm run test:integration:frontend:ci",
70
+ "test:integration": "npm run test:integration:backend && npm run test:integration:frontend",
72
71
  "test:integration:backend": "mocha --config src/test/backend/.mocharc.json",
73
- "test:integration:frontend:ci": "npm run -s webpack:frontend-test && npm run test:integration:frontend",
74
72
  "test:integration:frontend": "certa -r electron --config src/test/frontend/utils/certa.json",
75
- "webpack:frontend-test": "webpack --config ./src/test/frontend/utils/webpack.config.js 1>&2",
73
+ "webpack:test": "webpack --config ./src/test/frontend/utils/webpack.config.js 1>&2",
76
74
  "cover": ""
77
75
  },
78
76
  "readme": "# @itwin/core-electron\r\n\r\nCopyright © Bentley Systems, Incorporated. All rights reserved. See LICENSE.md for license terms and full copyright notice.\r\n\r\n## Description\r\n\r\nThe __@itwin/core-electron__ package contains the electron utilities to write an iTwin.js application based on Electron.\r\n\r\n## Documentation\r\n\r\nSee the [iTwin.js](https://www.itwinjs.org) documentation for more information.\r\n"