aboutsummaryrefslogtreecommitdiffstats
path: root/src/webview/plugin.js
blob: 72530733dc7db84de41b71f8ff37d3706bd9b251 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
import { ipcRenderer } from 'electron';
import path from 'path';

import RecipeWebview from './lib/RecipeWebview';

import spellchecker, { switchDict, disable as disableSpellchecker } from './spellchecker';
import { injectDarkModeStyle, isDarkModeStyleInjected, removeDarkModeStyle } from './darkmode';
import contextMenu from './contextMenu';
import './notifications';

const debug = require('debug')('Franz:Plugin');

window.franzSettings = {};
let serviceData;

ipcRenderer.on('initializeRecipe', (e, data) => {
  const modulePath = path.join(data.recipe.path, 'webview.js');
  // Delete module from cache
  delete require.cache[require.resolve(modulePath)];
  try {
    // eslint-disable-next-line
    require(modulePath)(new RecipeWebview(), data);
    debug('Initialize Recipe', data);

    serviceData = data;

    if (data.isDarkModeEnabled) {
      injectDarkModeStyle(data.recipe.path);
      debug('Add dark theme styles');
    }
  } catch (err) {
    debug('Recipe initialization failed', err);
  }
});

// Needs to run asap to intialize dictionaries
(async () => {
  const spellcheckingProvider = await spellchecker();
  contextMenu(spellcheckingProvider);
})();

ipcRenderer.on('settings-update', async (e, data) => {
  debug('Settings update received', data);

  if (data.enableSpellchecking) {
    switchDict(data.spellcheckerLanguage);
  } else {
    disableSpellchecker();
  }

  window.franzSettings = data;
});

ipcRenderer.on('service-settings-update', (e, data) => {
  debug('Service settings update received', data);

  if (data.isDarkModeEnabled && !isDarkModeStyleInjected()) {
    injectDarkModeStyle(serviceData.recipe.path);

    debug('Enable service dark mode');
  } else if (!data.isDarkModeEnabled && isDarkModeStyleInjected()) {
    removeDarkModeStyle();

    debug('Disable service dark mode');
  }
});

// Needed for current implementation of electrons 'login' event 🤦‍
ipcRenderer.on('get-service-id', (event) => {
  debug('Asking for service id', event);

  event.sender.send('service-id', serviceData.id);
});


document.addEventListener('DOMContentLoaded', () => {
  ipcRenderer.sendToHost('hello');
}, false);

// Patching window.open
const originalWindowOpen = window.open;

window.open = (url, frameName, features) => {
  // We need to differentiate if the link should be opened in a popup or in the systems default browser
  if (!frameName && !features) {
    return ipcRenderer.sendToHost('new-window', url);
  }

  return originalWindowOpen(url, frameName, features);
};