Skip to content

Latest commit

 

History

History
90 lines (70 loc) · 4.12 KB

README.org

File metadata and controls

90 lines (70 loc) · 4.12 KB

Yomichan Data Exporter

Background

Yomichan is a very cool pop-up dictionary for web browsers. However, it has been sunset.

Yomitan is a fork of Yomichan by Yomidevs which is actively maintained.

Migration from Yomichan to Yomitan is going to require people to be able to move their dictionaries (of which there could be numerous) from Yomichan into Yomitan. Yomichan lacks export support for dictionaries so people would have to track down the individual dictionaries they imported and re-import them. This has in fact been a sore point without concerning Yomitan as Yomichan has always missed the migration story for when people want to move between devices or browsers because dictionaries had to be imported one at a time every time.

Yomitan supports exporting and importing the entire collection of dictionaries. However, the existing Yomichan extension installations don’t have the code that lets you export the database. Which means that we have no choice but to inject and run the code on top of the extension somehow. This repository is just to provide a method that works without much headache for the end-user to that end.

Steps to export the data

On Firefox

  • Open Yomichan’s setting page (click the gear icon from Yomichan’s popup)
  • Open the web developer onsole
    • Hit F12 or CTRL + SHIFT + I on Windows and Linux; CMD + OPT + I on MacOS
  • Switch to the console tab
  • Paste the following into the console and wait for the export + download to finish:
fetch("https://github.com/yomidevs/yomichan-data-exporter/releases/latest/download/yomichan-data-exporter.min.js")
  .then((resp) => resp.text())
  .then((srcText) => {
    eval(srcText);
  })
  .then(async () => await exportDatabase())
  .catch((e) => console.error(e));
  • If you run into errors for the above somehow, try the same steps as Chrome below.

On Chrome

  • Open Yomichan’s setting page (click the gear icon from Yomichan’s popup)
  • Open the web developer onsole
    • Hit F12 or CTRL + SHIFT + I on Windows and Linux; CMD + OPT + I on MacOS
  • Switch to the console tab
  • Unfortunately(?!), Yomichan released on Chrome doesn’t have permission to actually inject code (I tried a whole bunch of different approaches and the permissions are just lacking) so you are going to have to paste the contents of the exporter code into the console.

    It is a very long “one-liner” and apparently github is pretty bad at handling all of it being put into a code box so you may want to open the raw file, select all, then copy and paste into the console. Link to the raw.

  • Finally, paste the following into the console and wait for the export + download to finish:
await exportDatabase();

Steps to import the exported Yomichan dictionaries data

You can actually import the exported dictionaries into existing installations of Yomichan, but it is going to require similarly annoying console one-offs.

Instead, I strongly recommend migrating to Yomitan where there is first-class support for importing (and exporting) this data in the Backup section of the settings page. The UI there should be self-explanatory, but refer to the Yomitan documentation page and Yomitan’s welcome page for more information.

Dependencies

dexie 3.2.4

dexie-export-import 4.0.7

downloadJS 4.21