Skip to content

Commit

Permalink
🐛 force native spell check until Electron issue is fixed (#464)
Browse files Browse the repository at this point in the history
electron/electron#44336

Signed-off-by: Marc Nuri <[email protected]>
  • Loading branch information
manusa authored Dec 9, 2024
1 parent 226093e commit 77a96a2
Show file tree
Hide file tree
Showing 3 changed files with 14 additions and 1 deletion.
3 changes: 3 additions & 0 deletions src/__tests__/electron.js
Original file line number Diff line number Diff line change
Expand Up @@ -87,10 +87,13 @@ const mockElectronInstance = ({...overriddenProps} = {}) => {
const webContentsViewInstance = mockWebContentsViewInstance();
const baseWindowInstance = mockBaseWindowInstance();
const sessionInstance = {
availableSpellCheckerLanguages: [],
clearCache: jest.fn(),
clearCodeCaches: jest.fn(),
clearHostResolverCache: jest.fn(),
clearStorageData: jest.fn(),
setSpellCheckerEnabled: jest.fn(),
setSpellCheckerLanguages: jest.fn(),
userAgentInterceptor: true
};
const trayInstance = {
Expand Down
4 changes: 4 additions & 0 deletions src/settings/settings.spell-check.browser.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,10 @@ export const SpellCheckPane = ({dispatch, state}) => {
checked=${useNative}
onClick=${toggleProperty({dispatch, property: 'useNativeSpellChecker'})}
/>
<div data-testid='settings-todo-native-spell-check' style=${{'font-size': '1.1rem', 'padding-left': '0.5rem'}}>
<p>NOTE: Currently, the Native Spell Checker is <strong>always</strong> used due to a bug in Electron:</p>
<p><a href='https://github.com/electron/electron/issues/44336'>electron/issues/44336</a></p>
</div>
<${Card.Divider} />
<div class='settings__dictionaries'>${
Object.entries(dictionaries(state))
Expand Down
8 changes: 7 additions & 1 deletion src/spell-check/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -87,7 +87,13 @@ const getAvailableNativeDictionaries = () =>
const handleGetMisspelled = async (_event, words) =>
fakeRendererWorker.webContents.executeJavaScript(`getMisspelled(${JSON.stringify(words)})`);

const getUseNativeSpellChecker = () => loadSettings().useNativeSpellChecker;
const getUseNativeSpellChecker = () => {
// eslint-disable-next-line no-warning-comments
// TODO: always use native spellcheck until there's a fix for
// https://github.com/electron/electron/issues/44336
return true;
// return loadSettings().useNativeSpellChecker;
};

const getEnabledDictionaries = () => loadSettings().enabledDictionaries;

Expand Down

0 comments on commit 77a96a2

Please sign in to comment.