Cleanup
This commit is contained in:
parent
5f97e8d16a
commit
f1850defa6
@ -49,19 +49,19 @@ function updateAnkiFormData() {
|
|||||||
|
|
||||||
const ankiDeck = $('#ankiDeck');
|
const ankiDeck = $('#ankiDeck');
|
||||||
ankiDeck.find('option').remove();
|
ankiDeck.find('option').remove();
|
||||||
yomichan.api_getDeckNames((names) => {
|
yomichan.api_getDeckNames({callback: (names) => {
|
||||||
if (names !== null) {
|
if (names !== null) {
|
||||||
names.forEach((name) => ankiDeck.append($('<option/>', {value: name, text: name})));
|
names.forEach((name) => ankiDeck.append($('<option/>', {value: name, text: name})));
|
||||||
}
|
}
|
||||||
});
|
}});
|
||||||
|
|
||||||
const ankiModel = $('#ankiModel');
|
const ankiModel = $('#ankiModel');
|
||||||
ankiModel.find('option').remove();
|
ankiModel.find('option').remove();
|
||||||
yomichan.api_getModelNames((names) => {
|
yomichan.api_getModelNames({callback: (names) => {
|
||||||
if (names !== null) {
|
if (names !== null) {
|
||||||
names.forEach((name) => ankiModel.append($('<option/>', {value: name, text: name})));
|
names.forEach((name) => ankiModel.append($('<option/>', {value: name, text: name})));
|
||||||
}
|
}
|
||||||
});
|
}});
|
||||||
}
|
}
|
||||||
|
|
||||||
function onOptionsChanged() {
|
function onOptionsChanged() {
|
||||||
|
@ -50,11 +50,11 @@ class Yomichan {
|
|||||||
}
|
}
|
||||||
|
|
||||||
onMessage(request, sender, callback) {
|
onMessage(request, sender, callback) {
|
||||||
const {action, params} = request;
|
const {action, params} = request, method = this['api_' + action];
|
||||||
const method = this['api_' + action];
|
|
||||||
|
|
||||||
if (typeof(method) === 'function') {
|
if (typeof(method) === 'function') {
|
||||||
method.call(this, callback, params);
|
params.callback = callback;
|
||||||
|
method.call(this, params);
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
@ -132,39 +132,39 @@ class Yomichan {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
api_addNote(callback, {definition, mode}) {
|
api_addNote({definition, mode, callback}) {
|
||||||
this.ankiInvoke('addNote', {definition: definition, mode: mode}, null, callback);
|
this.ankiInvoke('addNote', {definition: definition, mode: mode}, null, callback);
|
||||||
}
|
}
|
||||||
|
|
||||||
api_canAddNotes(callback, {definitions, modes}) {
|
api_canAddNotes({definitions, modes, callback}) {
|
||||||
this.ankiInvoke('canAddNotes', {definitions: definitions, modes: modes}, 'notes', callback);
|
this.ankiInvoke('canAddNotes', {definitions: definitions, modes: modes}, 'notes', callback);
|
||||||
}
|
}
|
||||||
|
|
||||||
api_findKanji(callback, text) {
|
api_findKanji({text, callback}) {
|
||||||
callback(this.translator.findKanji(text));
|
callback(this.translator.findKanji(text));
|
||||||
}
|
}
|
||||||
|
|
||||||
api_findTerm(callback, text) {
|
api_findTerm({text, callback}) {
|
||||||
callback(this.translator.findTerm(text));
|
callback(this.translator.findTerm(text));
|
||||||
}
|
}
|
||||||
|
|
||||||
api_getDeckNames(callback) {
|
api_getDeckNames({callback}) {
|
||||||
this.ankiInvoke('deckNames', {}, null, callback);
|
this.ankiInvoke('deckNames', {}, null, callback);
|
||||||
}
|
}
|
||||||
|
|
||||||
api_getModelNames(callback) {
|
api_getModelNames({callback}) {
|
||||||
this.ankiInvoke('modelNames', {}, null, callback);
|
this.ankiInvoke('modelNames', {}, null, callback);
|
||||||
}
|
}
|
||||||
|
|
||||||
api_getOptions(callback) {
|
api_getOptions({callback}) {
|
||||||
callback(this.options);
|
callback(this.options);
|
||||||
}
|
}
|
||||||
|
|
||||||
api_getState(callback) {
|
api_getState({callback}) {
|
||||||
callback(this.state);
|
callback(this.state);
|
||||||
}
|
}
|
||||||
|
|
||||||
api_renderText(callback, {template, data}) {
|
api_renderText({template, data, callback}) {
|
||||||
callback(Handlebars.templates[template](data));
|
callback(Handlebars.templates[template](data));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -22,27 +22,27 @@
|
|||||||
//
|
//
|
||||||
|
|
||||||
function bgSendMessage(action, params, callback) {
|
function bgSendMessage(action, params, callback) {
|
||||||
chrome.runtime.sendMessage({action: action, params: params}, callback);
|
chrome.runtime.sendMessage({action, params}, callback);
|
||||||
}
|
}
|
||||||
|
|
||||||
function bgFindTerm(text, callback) {
|
function bgFindTerm(text, callback) {
|
||||||
bgSendMessage('findTerm', text, callback);
|
bgSendMessage('findTerm', {text}, callback);
|
||||||
}
|
}
|
||||||
|
|
||||||
function bgFindKanji(text, callback) {
|
function bgFindKanji(text, callback) {
|
||||||
bgSendMessage('findKanji', text, callback);
|
bgSendMessage('findKanji', {text}, callback);
|
||||||
}
|
}
|
||||||
|
|
||||||
function bgRenderText(data, template, callback) {
|
function bgRenderText(data, template, callback) {
|
||||||
bgSendMessage('renderText', {data: data, template: template}, callback);
|
bgSendMessage('renderText', {data, template}, callback);
|
||||||
}
|
}
|
||||||
|
|
||||||
function bgGetOptions(callback) {
|
function bgGetOptions(callback) {
|
||||||
bgSendMessage('getOptions', null, callback);
|
bgSendMessage('getOptions', {}, callback);
|
||||||
}
|
}
|
||||||
|
|
||||||
function bgGetState(callback) {
|
function bgGetState(callback) {
|
||||||
bgSendMessage('getState', null, callback);
|
bgSendMessage('getState', {}, callback);
|
||||||
}
|
}
|
||||||
|
|
||||||
function bgCanAddNotes(definitions, modes, callback) {
|
function bgCanAddNotes(definitions, modes, callback) {
|
||||||
@ -50,5 +50,5 @@ function bgCanAddNotes(definitions, modes, callback) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function bgAddNote(definition, mode, callback) {
|
function bgAddNote(definition, mode, callback) {
|
||||||
bgSendMessage('addNote', {definition: definition, mode: mode}, callback);
|
bgSendMessage('addNote', {definition, mode}, callback);
|
||||||
}
|
}
|
||||||
|
@ -80,13 +80,9 @@ class Client {
|
|||||||
}
|
}
|
||||||
|
|
||||||
onFrameMessage(e) {
|
onFrameMessage(e) {
|
||||||
const {action, params} = e.data, handlers = {
|
const {action, params} = e.data, method = this['api_' + action];
|
||||||
addNote: ({mode, index}) => this.actionAddNote(index, mode, (data) => e.source.postMessage(data, e.origin)),
|
if (typeof(method) === 'function') {
|
||||||
displayKanji: this.actionDisplayKanji
|
method.call(this, params);
|
||||||
};
|
|
||||||
|
|
||||||
if (handlers.hasOwnProperty(action)) {
|
|
||||||
handlers[action].call(this, params);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -126,40 +122,6 @@ class Client {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
actionAddNote(index, mode, callback) {
|
|
||||||
const state = {};
|
|
||||||
state[mode] = false;
|
|
||||||
|
|
||||||
bgAddNote(this.definitions[index], mode, (success) => {
|
|
||||||
if (success) {
|
|
||||||
this.popup.sendMessage('setActionState', {index: index, state: state, sequence: this.sequence});
|
|
||||||
} else {
|
|
||||||
alert('Note could not be added');
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
actionDisplayKanji(kanji) {
|
|
||||||
bgFindKanji(kanji, (definitions) => {
|
|
||||||
const sequence = ++this.sequence;
|
|
||||||
bgRenderText(
|
|
||||||
{defs: definitions, root: this.fgRoot, options: this.options, sequence: sequence},
|
|
||||||
'kanji-list.html',
|
|
||||||
(content) => {
|
|
||||||
this.definitions = definitions;
|
|
||||||
this.popup.setContent(content, definitions);
|
|
||||||
|
|
||||||
bgCanAddNotes(definitions, ['kanji'], (states) => {
|
|
||||||
if (states !== null) {
|
|
||||||
states.forEach((state, index) => this.popup.sendMessage('setActionState', {index: index, state: state, sequence: sequence}));
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
showPopup(range, content) {
|
showPopup(range, content) {
|
||||||
this.popup.showNextTo(range.getRect(), content);
|
this.popup.showNextTo(range.getRect(), content);
|
||||||
|
|
||||||
@ -190,6 +152,39 @@ class Client {
|
|||||||
setOptions(opts) {
|
setOptions(opts) {
|
||||||
this.options = opts;
|
this.options = opts;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
api_addNote({index, mode}) {
|
||||||
|
const state = {};
|
||||||
|
state[mode] = false;
|
||||||
|
|
||||||
|
bgAddNote(this.definitions[index], mode, (success) => {
|
||||||
|
if (success) {
|
||||||
|
this.popup.sendMessage('setActionState', {index: index, state: state, sequence: this.sequence});
|
||||||
|
} else {
|
||||||
|
alert('Note could not be added');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
api_displayKanji(kanji) {
|
||||||
|
bgFindKanji(kanji, (definitions) => {
|
||||||
|
const sequence = ++this.sequence;
|
||||||
|
bgRenderText(
|
||||||
|
{defs: definitions, root: this.fgRoot, options: this.options, sequence: sequence},
|
||||||
|
'kanji-list.html',
|
||||||
|
(content) => {
|
||||||
|
this.definitions = definitions;
|
||||||
|
this.popup.setContent(content, definitions);
|
||||||
|
|
||||||
|
bgCanAddNotes(definitions, ['kanji'], (states) => {
|
||||||
|
if (states !== null) {
|
||||||
|
states.forEach((state, index) => this.popup.sendMessage('setActionState', {index: index, state: state, sequence: sequence}));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
window.yomiClient = new Client();
|
window.yomiClient = new Client();
|
||||||
|
Loading…
Reference in New Issue
Block a user