web-view-init.ts 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. import { IPC_MESSAGES } from '@electron/internal/common/ipc-messages';
  2. import { ipcRendererInternal } from '@electron/internal/renderer/ipc-renderer-internal';
  3. import type * as guestViewInternalModule from '@electron/internal/renderer/web-view/guest-view-internal';
  4. import type * as webViewElementModule from '@electron/internal/renderer/web-view/web-view-element';
  5. const v8Util = process._linkedBinding('electron_common_v8_util');
  6. const { mainFrame: webFrame } = process._linkedBinding('electron_renderer_web_frame');
  7. function handleFocusBlur () {
  8. // Note that while Chromium content APIs have observer for focus/blur, they
  9. // unfortunately do not work for webview.
  10. window.addEventListener('focus', () => {
  11. ipcRendererInternal.send(IPC_MESSAGES.GUEST_VIEW_MANAGER_FOCUS_CHANGE, true);
  12. });
  13. window.addEventListener('blur', () => {
  14. ipcRendererInternal.send(IPC_MESSAGES.GUEST_VIEW_MANAGER_FOCUS_CHANGE, false);
  15. });
  16. }
  17. export function webViewInit (webviewTag: boolean, isWebView: boolean) {
  18. // Don't allow recursive `<webview>`.
  19. if (webviewTag && !isWebView) {
  20. const guestViewInternal = require('@electron/internal/renderer/web-view/guest-view-internal') as typeof guestViewInternalModule;
  21. if (process.contextIsolated) {
  22. v8Util.setHiddenValue(window, 'guestViewInternal', guestViewInternal);
  23. } else {
  24. const { setupWebView } = require('@electron/internal/renderer/web-view/web-view-element') as typeof webViewElementModule;
  25. setupWebView({
  26. guestViewInternal,
  27. allowGuestViewElementDefinition: webFrame.allowGuestViewElementDefinition,
  28. setIsWebView: iframe => v8Util.setHiddenValue(iframe, 'isWebView', true)
  29. });
  30. }
  31. }
  32. if (isWebView) {
  33. // Report focus/blur events of webview to browser.
  34. handleFocusBlur();
  35. }
  36. }