mirror of
https://github.com/laurent22/joplin.git
synced 2025-01-05 12:50:29 +02:00
Tools: Added eslint rule arrow-parens
This commit is contained in:
parent
c34f762507
commit
0b6f5581f0
@ -100,6 +100,7 @@ module.exports = {
|
|||||||
"space-before-blocks": "error",
|
"space-before-blocks": "error",
|
||||||
"spaced-comment": ["error", "always"],
|
"spaced-comment": ["error", "always"],
|
||||||
"keyword-spacing": ["error", { "before": true, "after": true }],
|
"keyword-spacing": ["error", { "before": true, "after": true }],
|
||||||
|
"arrow-parens": ["error"],
|
||||||
},
|
},
|
||||||
"plugins": [
|
"plugins": [
|
||||||
"react",
|
"react",
|
||||||
|
@ -45,7 +45,7 @@ class ResourceServer {
|
|||||||
this.server_ = http.createServer();
|
this.server_ = http.createServer();
|
||||||
|
|
||||||
this.server_.on('request', async (request, response) => {
|
this.server_.on('request', async (request, response) => {
|
||||||
const writeResponse = message => {
|
const writeResponse = (message) => {
|
||||||
response.write(message);
|
response.write(message);
|
||||||
response.end();
|
response.end();
|
||||||
};
|
};
|
||||||
@ -73,7 +73,7 @@ class ResourceServer {
|
|||||||
response.end();
|
response.end();
|
||||||
});
|
});
|
||||||
|
|
||||||
this.server_.on('error', error => {
|
this.server_.on('error', (error) => {
|
||||||
this.logger().error('Resource server:', error);
|
this.logger().error('Resource server:', error);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -61,7 +61,7 @@ class AppGui {
|
|||||||
|
|
||||||
this.renderer_ = new Renderer(this.term(), this.rootWidget_);
|
this.renderer_ = new Renderer(this.term(), this.rootWidget_);
|
||||||
|
|
||||||
this.app_.on('modelAction', async event => {
|
this.app_.on('modelAction', async (event) => {
|
||||||
await this.handleModelAction(event.action);
|
await this.handleModelAction(event.action);
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -131,7 +131,7 @@ class AppGui {
|
|||||||
};
|
};
|
||||||
folderList.name = 'folderList';
|
folderList.name = 'folderList';
|
||||||
folderList.vStretch = true;
|
folderList.vStretch = true;
|
||||||
folderList.on('currentItemChange', async event => {
|
folderList.on('currentItemChange', async (event) => {
|
||||||
const item = folderList.currentItem;
|
const item = folderList.currentItem;
|
||||||
|
|
||||||
if (item === '-') {
|
if (item === '-') {
|
||||||
@ -166,7 +166,7 @@ class AppGui {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
this.rootWidget_.connect(folderList, state => {
|
this.rootWidget_.connect(folderList, (state) => {
|
||||||
return {
|
return {
|
||||||
selectedFolderId: state.selectedFolderId,
|
selectedFolderId: state.selectedFolderId,
|
||||||
selectedTagId: state.selectedTagId,
|
selectedTagId: state.selectedTagId,
|
||||||
@ -193,7 +193,7 @@ class AppGui {
|
|||||||
id: note ? note.id : null,
|
id: note ? note.id : null,
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
this.rootWidget_.connect(noteList, state => {
|
this.rootWidget_.connect(noteList, (state) => {
|
||||||
return {
|
return {
|
||||||
selectedNoteId: state.selectedNoteIds.length ? state.selectedNoteIds[0] : null,
|
selectedNoteId: state.selectedNoteIds.length ? state.selectedNoteIds[0] : null,
|
||||||
items: state.notes,
|
items: state.notes,
|
||||||
@ -207,7 +207,7 @@ class AppGui {
|
|||||||
borderBottomWidth: 1,
|
borderBottomWidth: 1,
|
||||||
borderLeftWidth: 1,
|
borderLeftWidth: 1,
|
||||||
};
|
};
|
||||||
this.rootWidget_.connect(noteText, state => {
|
this.rootWidget_.connect(noteText, (state) => {
|
||||||
return {
|
return {
|
||||||
noteId: state.selectedNoteIds.length ? state.selectedNoteIds[0] : null,
|
noteId: state.selectedNoteIds.length ? state.selectedNoteIds[0] : null,
|
||||||
notes: state.notes,
|
notes: state.notes,
|
||||||
@ -222,7 +222,7 @@ class AppGui {
|
|||||||
borderLeftWidth: 1,
|
borderLeftWidth: 1,
|
||||||
borderRightWidth: 1,
|
borderRightWidth: 1,
|
||||||
};
|
};
|
||||||
this.rootWidget_.connect(noteMetadata, state => {
|
this.rootWidget_.connect(noteMetadata, (state) => {
|
||||||
return { noteId: state.selectedNoteIds.length ? state.selectedNoteIds[0] : null };
|
return { noteId: state.selectedNoteIds.length ? state.selectedNoteIds[0] : null };
|
||||||
});
|
});
|
||||||
noteMetadata.hide();
|
noteMetadata.hide();
|
||||||
|
@ -117,11 +117,11 @@ class Application extends BaseApplication {
|
|||||||
}
|
}
|
||||||
|
|
||||||
setupCommand(cmd) {
|
setupCommand(cmd) {
|
||||||
cmd.setStdout(text => {
|
cmd.setStdout((text) => {
|
||||||
return this.stdout(text);
|
return this.stdout(text);
|
||||||
});
|
});
|
||||||
|
|
||||||
cmd.setDispatcher(action => {
|
cmd.setDispatcher((action) => {
|
||||||
if (this.store()) {
|
if (this.store()) {
|
||||||
return this.store().dispatch(action);
|
return this.store().dispatch(action);
|
||||||
} else {
|
} else {
|
||||||
@ -176,7 +176,7 @@ class Application extends BaseApplication {
|
|||||||
|
|
||||||
commands(uiType = null) {
|
commands(uiType = null) {
|
||||||
if (!this.allCommandsLoaded_) {
|
if (!this.allCommandsLoaded_) {
|
||||||
fs.readdirSync(__dirname).forEach(path => {
|
fs.readdirSync(__dirname).forEach((path) => {
|
||||||
if (path.indexOf('command-') !== 0) return;
|
if (path.indexOf('command-') !== 0) return;
|
||||||
const ext = fileExtension(path);
|
const ext = fileExtension(path);
|
||||||
if (ext != 'js') return;
|
if (ext != 'js') return;
|
||||||
@ -275,7 +275,7 @@ class Application extends BaseApplication {
|
|||||||
},
|
},
|
||||||
showConsole: () => {},
|
showConsole: () => {},
|
||||||
maximizeConsole: () => {},
|
maximizeConsole: () => {},
|
||||||
stdout: text => {
|
stdout: (text) => {
|
||||||
console.info(text);
|
console.info(text);
|
||||||
},
|
},
|
||||||
fullScreen: () => {},
|
fullScreen: () => {},
|
||||||
@ -370,7 +370,7 @@ class Application extends BaseApplication {
|
|||||||
// Map reserved shortcuts to their equivalent key
|
// Map reserved shortcuts to their equivalent key
|
||||||
// https://github.com/cronvel/terminal-kit/issues/101
|
// https://github.com/cronvel/terminal-kit/issues/101
|
||||||
for (let i = 0; i < output.length; i++) {
|
for (let i = 0; i < output.length; i++) {
|
||||||
const newKeys = output[i].keys.map(k => {
|
const newKeys = output[i].keys.map((k) => {
|
||||||
k = k.replace(/CTRL_H/g, 'BACKSPACE');
|
k = k.replace(/CTRL_H/g, 'BACKSPACE');
|
||||||
k = k.replace(/CTRL_I/g, 'TAB');
|
k = k.replace(/CTRL_I/g, 'TAB');
|
||||||
k = k.replace(/CTRL_M/g, 'ENTER');
|
k = k.replace(/CTRL_M/g, 'ENTER');
|
||||||
|
@ -14,11 +14,11 @@ async function handleAutocompletionPromise(line) {
|
|||||||
// should look for commands it could be
|
// should look for commands it could be
|
||||||
if (words.length == 1) {
|
if (words.length == 1) {
|
||||||
if (names.indexOf(words[0]) === -1) {
|
if (names.indexOf(words[0]) === -1) {
|
||||||
const x = names.filter(n => n.indexOf(words[0]) === 0);
|
const x = names.filter((n) => n.indexOf(words[0]) === 0);
|
||||||
if (x.length === 1) {
|
if (x.length === 1) {
|
||||||
return `${x[0]} `;
|
return `${x[0]} `;
|
||||||
}
|
}
|
||||||
return x.length > 0 ? x.map(a => `${a} `) : line;
|
return x.length > 0 ? x.map((a) => `${a} `) : line;
|
||||||
} else {
|
} else {
|
||||||
return line;
|
return line;
|
||||||
}
|
}
|
||||||
@ -60,14 +60,14 @@ async function handleAutocompletionPromise(line) {
|
|||||||
if (l.length === 0) {
|
if (l.length === 0) {
|
||||||
return line;
|
return line;
|
||||||
}
|
}
|
||||||
const ret = l.map(a => toCommandLine(a));
|
const ret = l.map((a) => toCommandLine(a));
|
||||||
ret.prefix = `${toCommandLine(words.slice(0, -1))} `;
|
ret.prefix = `${toCommandLine(words.slice(0, -1))} `;
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
// Complete an argument
|
// Complete an argument
|
||||||
// Determine the number of positional arguments by counting the number of
|
// Determine the number of positional arguments by counting the number of
|
||||||
// words that don't start with a - less one for the command name
|
// words that don't start with a - less one for the command name
|
||||||
const positionalArgs = words.filter(a => a.indexOf('-') !== 0).length - 1;
|
const positionalArgs = words.filter((a) => a.indexOf('-') !== 0).length - 1;
|
||||||
|
|
||||||
const cmdUsage = yargParser(metadata.usage)['_'];
|
const cmdUsage = yargParser(metadata.usage)['_'];
|
||||||
cmdUsage.splice(0, 1);
|
cmdUsage.splice(0, 1);
|
||||||
@ -80,23 +80,23 @@ async function handleAutocompletionPromise(line) {
|
|||||||
|
|
||||||
if (argName == 'note' || argName == 'note-pattern') {
|
if (argName == 'note' || argName == 'note-pattern') {
|
||||||
const notes = currentFolder ? await Note.previews(currentFolder.id, { titlePattern: `${next}*` }) : [];
|
const notes = currentFolder ? await Note.previews(currentFolder.id, { titlePattern: `${next}*` }) : [];
|
||||||
l.push(...notes.map(n => n.title));
|
l.push(...notes.map((n) => n.title));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (argName == 'notebook') {
|
if (argName == 'notebook') {
|
||||||
const folders = await Folder.search({ titlePattern: `${next}*` });
|
const folders = await Folder.search({ titlePattern: `${next}*` });
|
||||||
l.push(...folders.map(n => n.title));
|
l.push(...folders.map((n) => n.title));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (argName == 'item') {
|
if (argName == 'item') {
|
||||||
const notes = currentFolder ? await Note.previews(currentFolder.id, { titlePattern: `${next}*` }) : [];
|
const notes = currentFolder ? await Note.previews(currentFolder.id, { titlePattern: `${next}*` }) : [];
|
||||||
const folders = await Folder.search({ titlePattern: `${next}*` });
|
const folders = await Folder.search({ titlePattern: `${next}*` });
|
||||||
l.push(...notes.map(n => n.title), folders.map(n => n.title));
|
l.push(...notes.map((n) => n.title), folders.map((n) => n.title));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (argName == 'tag') {
|
if (argName == 'tag') {
|
||||||
const tags = await Tag.search({ titlePattern: `${next}*` });
|
const tags = await Tag.search({ titlePattern: `${next}*` });
|
||||||
l.push(...tags.map(n => n.title));
|
l.push(...tags.map((n) => n.title));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (argName == 'file') {
|
if (argName == 'file') {
|
||||||
@ -117,7 +117,7 @@ async function handleAutocompletionPromise(line) {
|
|||||||
if (l.length === 1) {
|
if (l.length === 1) {
|
||||||
return toCommandLine([...words.slice(0, -1), l[0]]);
|
return toCommandLine([...words.slice(0, -1), l[0]]);
|
||||||
} else if (l.length > 1) {
|
} else if (l.length > 1) {
|
||||||
const ret = l.map(a => toCommandLine(a));
|
const ret = l.map((a) => toCommandLine(a));
|
||||||
ret.prefix = `${toCommandLine(words.slice(0, -1))} `;
|
ret.prefix = `${toCommandLine(words.slice(0, -1))} `;
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -49,7 +49,7 @@ function renderCommand(cmd) {
|
|||||||
|
|
||||||
function getCommands() {
|
function getCommands() {
|
||||||
const output = [];
|
const output = [];
|
||||||
fs.readdirSync(__dirname).forEach(path => {
|
fs.readdirSync(__dirname).forEach((path) => {
|
||||||
if (path.indexOf('command-') !== 0) return;
|
if (path.indexOf('command-') !== 0) return;
|
||||||
const ext = fileExtension(path);
|
const ext = fileExtension(path);
|
||||||
if (ext != 'js') return;
|
if (ext != 'js') return;
|
||||||
@ -134,6 +134,6 @@ async function main() {
|
|||||||
console.info(`${headerText}\n\n` + 'USAGE' + `\n\n${commandsText}\n\n${footerText}`);
|
console.info(`${headerText}\n\n` + 'USAGE' + `\n\n${commandsText}\n\n${footerText}`);
|
||||||
}
|
}
|
||||||
|
|
||||||
main().catch(error => {
|
main().catch((error) => {
|
||||||
console.error(error);
|
console.error(error);
|
||||||
});
|
});
|
||||||
|
@ -236,7 +236,7 @@ async function main() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
main(process.argv).catch(error => {
|
main(process.argv).catch((error) => {
|
||||||
console.info('');
|
console.info('');
|
||||||
logger.error(error);
|
logger.error(error);
|
||||||
});
|
});
|
||||||
|
@ -143,7 +143,7 @@ cliUtils.promptMcq = function(message, answers) {
|
|||||||
message += _('Your choice: ');
|
message += _('Your choice: ');
|
||||||
|
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
rl.question(message, answer => {
|
rl.question(message, (answer) => {
|
||||||
rl.close();
|
rl.close();
|
||||||
|
|
||||||
if (!(answer in answers)) {
|
if (!(answer in answers)) {
|
||||||
@ -168,7 +168,7 @@ cliUtils.promptConfirm = function(message, answers = null) {
|
|||||||
message += ` (${answers.join('/')})`;
|
message += ` (${answers.join('/')})`;
|
||||||
|
|
||||||
return new Promise((resolve) => {
|
return new Promise((resolve) => {
|
||||||
rl.question(`${message} `, answer => {
|
rl.question(`${message} `, (answer) => {
|
||||||
const ok = !answer || answer.toLowerCase() == answers[0].toLowerCase();
|
const ok = !answer || answer.toLowerCase() == answers[0].toLowerCase();
|
||||||
rl.close();
|
rl.close();
|
||||||
resolve(ok);
|
resolve(ok);
|
||||||
@ -202,7 +202,7 @@ cliUtils.prompt = function(initialText = '', promptString = ':', options = null)
|
|||||||
return new Promise((resolve) => {
|
return new Promise((resolve) => {
|
||||||
mutableStdout.muted = false;
|
mutableStdout.muted = false;
|
||||||
|
|
||||||
rl.question(promptString, answer => {
|
rl.question(promptString, (answer) => {
|
||||||
rl.close();
|
rl.close();
|
||||||
if (options.secure) this.stdout_('');
|
if (options.secure) this.stdout_('');
|
||||||
resolve(answer);
|
resolve(answer);
|
||||||
|
@ -25,7 +25,7 @@ class Command extends BaseCommand {
|
|||||||
{
|
{
|
||||||
name: 'type',
|
name: 'type',
|
||||||
label: 'Type',
|
label: 'Type',
|
||||||
filter: value => {
|
filter: (value) => {
|
||||||
return Database.enumName('fieldType', value);
|
return Database.enumName('fieldType', value);
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -69,7 +69,7 @@ class Command extends BaseCommand {
|
|||||||
const isImport = args.options.import || args.options.importFile;
|
const isImport = args.options.import || args.options.importFile;
|
||||||
const importFile = args.options.importFile;
|
const importFile = args.options.importFile;
|
||||||
|
|
||||||
const renderKeyValue = name => {
|
const renderKeyValue = (name) => {
|
||||||
const md = Setting.settingMetadata(name);
|
const md = Setting.settingMetadata(name);
|
||||||
let value = Setting.value(name);
|
let value = Setting.value(name);
|
||||||
if (typeof value === 'object' || Array.isArray(value)) value = JSON.stringify(value);
|
if (typeof value === 'object' || Array.isArray(value)) value = JSON.stringify(value);
|
||||||
|
@ -31,7 +31,7 @@ class Command extends BaseCommand {
|
|||||||
async action(args) {
|
async action(args) {
|
||||||
const options = args.options;
|
const options = args.options;
|
||||||
|
|
||||||
const askForMasterKey = async error => {
|
const askForMasterKey = async (error) => {
|
||||||
const masterKeyId = error.masterKeyId;
|
const masterKeyId = error.masterKeyId;
|
||||||
const password = await this.prompt(_('Enter master password:'), { type: 'string', secure: true });
|
const password = await this.prompt(_('Enter master password:'), { type: 'string', secure: true });
|
||||||
if (!password) {
|
if (!password) {
|
||||||
@ -147,7 +147,7 @@ class Command extends BaseCommand {
|
|||||||
|
|
||||||
const dirPaths = function(targetPath) {
|
const dirPaths = function(targetPath) {
|
||||||
const paths = [];
|
const paths = [];
|
||||||
fs.readdirSync(targetPath).forEach(path => {
|
fs.readdirSync(targetPath).forEach((path) => {
|
||||||
paths.push(path);
|
paths.push(path);
|
||||||
});
|
});
|
||||||
return paths;
|
return paths;
|
||||||
|
@ -17,8 +17,8 @@ class Command extends BaseCommand {
|
|||||||
const service = new InteropService();
|
const service = new InteropService();
|
||||||
const formats = service
|
const formats = service
|
||||||
.modules()
|
.modules()
|
||||||
.filter(m => m.type === 'exporter')
|
.filter((m) => m.type === 'exporter')
|
||||||
.map(m => m.format + (m.description ? ` (${m.description})` : ''));
|
.map((m) => m.format + (m.description ? ` (${m.description})` : ''));
|
||||||
|
|
||||||
return [['--format <format>', _('Destination format: %s', formats.join(', '))], ['--note <note>', _('Exports only the given note.')], ['--notebook <notebook>', _('Exports only the given notebook.')]];
|
return [['--format <format>', _('Destination format: %s', formats.join(', '))], ['--note <note>', _('Exports only the given note.')], ['--notebook <notebook>', _('Exports only the given notebook.')]];
|
||||||
}
|
}
|
||||||
@ -32,17 +32,17 @@ class Command extends BaseCommand {
|
|||||||
if (args.options.note) {
|
if (args.options.note) {
|
||||||
const notes = await app().loadItems(BaseModel.TYPE_NOTE, args.options.note, { parent: app().currentFolder() });
|
const notes = await app().loadItems(BaseModel.TYPE_NOTE, args.options.note, { parent: app().currentFolder() });
|
||||||
if (!notes.length) throw new Error(_('Cannot find "%s".', args.options.note));
|
if (!notes.length) throw new Error(_('Cannot find "%s".', args.options.note));
|
||||||
exportOptions.sourceNoteIds = notes.map(n => n.id);
|
exportOptions.sourceNoteIds = notes.map((n) => n.id);
|
||||||
} else if (args.options.notebook) {
|
} else if (args.options.notebook) {
|
||||||
const folders = await app().loadItems(BaseModel.TYPE_FOLDER, args.options.notebook);
|
const folders = await app().loadItems(BaseModel.TYPE_FOLDER, args.options.notebook);
|
||||||
if (!folders.length) throw new Error(_('Cannot find "%s".', args.options.notebook));
|
if (!folders.length) throw new Error(_('Cannot find "%s".', args.options.notebook));
|
||||||
exportOptions.sourceFolderIds = folders.map(n => n.id);
|
exportOptions.sourceFolderIds = folders.map((n) => n.id);
|
||||||
}
|
}
|
||||||
|
|
||||||
const service = new InteropService();
|
const service = new InteropService();
|
||||||
const result = await service.export(exportOptions);
|
const result = await service.export(exportOptions);
|
||||||
|
|
||||||
result.warnings.map(w => this.stdout(w));
|
result.warnings.map((w) => this.stdout(w));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -52,21 +52,21 @@ class Command extends BaseCommand {
|
|||||||
|
|
||||||
for (let i = 0; i < keymap.length; i++) {
|
for (let i = 0; i < keymap.length; i++) {
|
||||||
const item = keymap[i];
|
const item = keymap[i];
|
||||||
const keys = item.keys.map(k => (k === ' ' ? '(SPACE)' : k));
|
const keys = item.keys.map((k) => (k === ' ' ? '(SPACE)' : k));
|
||||||
rows.push([keys.join(', '), item.command]);
|
rows.push([keys.join(', '), item.command]);
|
||||||
}
|
}
|
||||||
|
|
||||||
cliUtils.printArray(this.stdout.bind(this), rows);
|
cliUtils.printArray(this.stdout.bind(this), rows);
|
||||||
} else if (args.command === 'all') {
|
} else if (args.command === 'all') {
|
||||||
const commands = this.allCommands();
|
const commands = this.allCommands();
|
||||||
const output = commands.map(c => renderCommandHelp(c));
|
const output = commands.map((c) => renderCommandHelp(c));
|
||||||
this.stdout(output.join('\n\n'));
|
this.stdout(output.join('\n\n'));
|
||||||
} else if (args.command) {
|
} else if (args.command) {
|
||||||
const command = app().findCommandByName(args['command']);
|
const command = app().findCommandByName(args['command']);
|
||||||
if (!command) throw new Error(_('Cannot find "%s".', args.command));
|
if (!command) throw new Error(_('Cannot find "%s".', args.command));
|
||||||
this.stdout(renderCommandHelp(command, stdoutWidth));
|
this.stdout(renderCommandHelp(command, stdoutWidth));
|
||||||
} else {
|
} else {
|
||||||
const commandNames = this.allCommands().map(a => a.name());
|
const commandNames = this.allCommands().map((a) => a.name());
|
||||||
|
|
||||||
this.stdout(_('Type `help [command]` for more information about a command; or type `help all` for the complete usage information.'));
|
this.stdout(_('Type `help [command]` for more information about a command; or type `help all` for the complete usage information.'));
|
||||||
this.stdout('');
|
this.stdout('');
|
||||||
|
@ -18,8 +18,8 @@ class Command extends BaseCommand {
|
|||||||
const service = new InteropService();
|
const service = new InteropService();
|
||||||
const formats = service
|
const formats = service
|
||||||
.modules()
|
.modules()
|
||||||
.filter(m => m.type === 'importer')
|
.filter((m) => m.type === 'importer')
|
||||||
.map(m => m.format);
|
.map((m) => m.format);
|
||||||
|
|
||||||
return [['--format <format>', _('Source format: %s', ['auto'].concat(formats).join(', '))], ['-f, --force', _('Do not ask for confirmation.')]];
|
return [['--format <format>', _('Source format: %s', ['auto'].concat(formats).join(', '))], ['-f, --force', _('Do not ask for confirmation.')]];
|
||||||
}
|
}
|
||||||
@ -38,7 +38,7 @@ class Command extends BaseCommand {
|
|||||||
|
|
||||||
// onProgress/onError supported by Enex import only
|
// onProgress/onError supported by Enex import only
|
||||||
|
|
||||||
importOptions.onProgress = progressState => {
|
importOptions.onProgress = (progressState) => {
|
||||||
const line = [];
|
const line = [];
|
||||||
line.push(_('Found: %d.', progressState.loaded));
|
line.push(_('Found: %d.', progressState.loaded));
|
||||||
line.push(_('Created: %d.', progressState.created));
|
line.push(_('Created: %d.', progressState.created));
|
||||||
@ -50,7 +50,7 @@ class Command extends BaseCommand {
|
|||||||
cliUtils.redraw(lastProgress);
|
cliUtils.redraw(lastProgress);
|
||||||
};
|
};
|
||||||
|
|
||||||
importOptions.onError = error => {
|
importOptions.onError = (error) => {
|
||||||
const s = error.trace ? error.trace : error.toString();
|
const s = error.trace ? error.trace : error.toString();
|
||||||
this.stdout(s);
|
this.stdout(s);
|
||||||
};
|
};
|
||||||
@ -61,7 +61,7 @@ class Command extends BaseCommand {
|
|||||||
this.stdout(_('Importing notes...'));
|
this.stdout(_('Importing notes...'));
|
||||||
const service = new InteropService();
|
const service = new InteropService();
|
||||||
const result = await service.import(importOptions);
|
const result = await service.import(importOptions);
|
||||||
result.warnings.map(w => this.stdout(w));
|
result.warnings.map((w) => this.stdout(w));
|
||||||
cliUtils.redrawDone();
|
cliUtils.redrawDone();
|
||||||
if (lastProgress) this.stdout(_('The notes have been imported: %s', lastProgress));
|
if (lastProgress) this.stdout(_('The notes have been imported: %s', lastProgress));
|
||||||
}
|
}
|
||||||
|
@ -26,7 +26,7 @@ class Command extends BaseCommand {
|
|||||||
|
|
||||||
const ok = force ? true : await this.prompt(notes.length > 1 ? _('%d notes match this pattern. Delete them?', notes.length) : _('Delete note?'), { booleanAnswerDefault: 'n' });
|
const ok = force ? true : await this.prompt(notes.length > 1 ? _('%d notes match this pattern. Delete them?', notes.length) : _('Delete note?'), { booleanAnswerDefault: 'n' });
|
||||||
if (!ok) return;
|
if (!ok) return;
|
||||||
const ids = notes.map(n => n.id);
|
const ids = notes.map((n) => n.id);
|
||||||
await Note.batchDelete(ids);
|
await Note.batchDelete(ids);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -162,11 +162,11 @@ class Command extends BaseCommand {
|
|||||||
const sync = await syncTarget.synchronizer();
|
const sync = await syncTarget.synchronizer();
|
||||||
|
|
||||||
const options = {
|
const options = {
|
||||||
onProgress: report => {
|
onProgress: (report) => {
|
||||||
const lines = Synchronizer.reportToLines(report);
|
const lines = Synchronizer.reportToLines(report);
|
||||||
if (lines.length) cliUtils.redraw(lines.join(' '));
|
if (lines.length) cliUtils.redraw(lines.join(' '));
|
||||||
},
|
},
|
||||||
onMessage: msg => {
|
onMessage: (msg) => {
|
||||||
cliUtils.redrawDone();
|
cliUtils.redrawDone();
|
||||||
this.stdout(msg);
|
this.stdout(msg);
|
||||||
},
|
},
|
||||||
|
@ -47,7 +47,7 @@ class Command extends BaseCommand {
|
|||||||
} else if (command == 'list') {
|
} else if (command == 'list') {
|
||||||
if (tag) {
|
if (tag) {
|
||||||
const notes = await Tag.notes(tag.id);
|
const notes = await Tag.notes(tag.id);
|
||||||
notes.map(note => {
|
notes.map((note) => {
|
||||||
let line = '';
|
let line = '';
|
||||||
if (options.long) {
|
if (options.long) {
|
||||||
line += BaseModel.shortId(note.id);
|
line += BaseModel.shortId(note.id);
|
||||||
@ -71,7 +71,7 @@ class Command extends BaseCommand {
|
|||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
const tags = await Tag.all();
|
const tags = await Tag.all();
|
||||||
tags.map(tag => {
|
tags.map((tag) => {
|
||||||
this.stdout(tag.title);
|
this.stdout(tag.title);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -80,7 +80,7 @@ class Command extends BaseCommand {
|
|||||||
const note = await app().loadItem(BaseModel.TYPE_NOTE, args.tag);
|
const note = await app().loadItem(BaseModel.TYPE_NOTE, args.tag);
|
||||||
if (!note) throw new Error(_('Cannot find "%s".', args.tag));
|
if (!note) throw new Error(_('Cannot find "%s".', args.tag));
|
||||||
const tags = await Tag.tagsByNoteId(note.id);
|
const tags = await Tag.tagsByNoteId(note.id);
|
||||||
tags.map(tag => {
|
tags.map((tag) => {
|
||||||
this.stdout(tag.title);
|
this.stdout(tag.title);
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
|
@ -2328,11 +2328,11 @@ async function main() {
|
|||||||
clients[clientId].activeCommandCount++;
|
clients[clientId].activeCommandCount++;
|
||||||
|
|
||||||
execRandomCommand(clients[clientId])
|
execRandomCommand(clients[clientId])
|
||||||
.catch(error => {
|
.catch((error) => {
|
||||||
logger.info(`Client ${clientId}:`);
|
logger.info(`Client ${clientId}:`);
|
||||||
logger.error(error);
|
logger.error(error);
|
||||||
})
|
})
|
||||||
.then(r => {
|
.then((r) => {
|
||||||
if (r) {
|
if (r) {
|
||||||
logger.info(`Client ${clientId}:\n${r.trim()}`);
|
logger.info(`Client ${clientId}:\n${r.trim()}`);
|
||||||
}
|
}
|
||||||
@ -2397,6 +2397,6 @@ async function main() {
|
|||||||
}, 100);
|
}, 100);
|
||||||
}
|
}
|
||||||
|
|
||||||
main(process.argv).catch(error => {
|
main(process.argv).catch((error) => {
|
||||||
logger.error(error);
|
logger.error(error);
|
||||||
});
|
});
|
||||||
|
@ -19,7 +19,7 @@ class FolderListWidget extends ListWidget {
|
|||||||
this.updateItems_ = false;
|
this.updateItems_ = false;
|
||||||
this.trimItemTitle = false;
|
this.trimItemTitle = false;
|
||||||
|
|
||||||
this.itemRenderer = item => {
|
this.itemRenderer = (item) => {
|
||||||
const output = [];
|
const output = [];
|
||||||
if (item === '-') {
|
if (item === '-') {
|
||||||
output.push('-'.repeat(this.innerWidth));
|
output.push('-'.repeat(this.innerWidth));
|
||||||
@ -134,7 +134,7 @@ class FolderListWidget extends ListWidget {
|
|||||||
const previousParentType = this.notesParentType;
|
const previousParentType = this.notesParentType;
|
||||||
|
|
||||||
let newItems = [];
|
let newItems = [];
|
||||||
const orderFolders = parentId => {
|
const orderFolders = (parentId) => {
|
||||||
for (let i = 0; i < this.folders.length; i++) {
|
for (let i = 0; i < this.folders.length; i++) {
|
||||||
const f = this.folders[i];
|
const f = this.folders[i];
|
||||||
const folderParentId = f.parent_id ? f.parent_id : '';
|
const folderParentId = f.parent_id ? f.parent_id : '';
|
||||||
|
@ -8,7 +8,7 @@ class NoteListWidget extends ListWidget {
|
|||||||
|
|
||||||
this.updateIndexFromSelectedNoteId_ = false;
|
this.updateIndexFromSelectedNoteId_ = false;
|
||||||
|
|
||||||
this.itemRenderer = note => {
|
this.itemRenderer = (note) => {
|
||||||
let label = Note.displayTitle(note); // + ' ' + note.id;
|
let label = Note.displayTitle(note); // + ' ' + note.id;
|
||||||
if (note.is_todo) {
|
if (note.is_todo) {
|
||||||
label = `[${note.todo_completed ? 'X' : ' '}] ${label}`;
|
label = `[${note.todo_completed ? 'X' : ' '}] ${label}`;
|
||||||
|
@ -86,7 +86,7 @@ class StatusBarWidget extends BaseWidget {
|
|||||||
|
|
||||||
// const textStyle = this.promptActive ? (s) => s : chalk.bgBlueBright.white;
|
// const textStyle = this.promptActive ? (s) => s : chalk.bgBlueBright.white;
|
||||||
// const textStyle = (s) => s;
|
// const textStyle = (s) => s;
|
||||||
const textStyle = this.promptActive ? s => s : chalk.gray;
|
const textStyle = this.promptActive ? (s) => s : chalk.gray;
|
||||||
|
|
||||||
this.term.drawHLine(this.absoluteInnerX, this.absoluteInnerY, this.innerWidth, textStyle(' '));
|
this.term.drawHLine(this.absoluteInnerX, this.absoluteInnerY, this.innerWidth, textStyle(' '));
|
||||||
|
|
||||||
|
@ -41,7 +41,7 @@ function renderCommandHelp(cmd, width = null) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (cmd.name() === 'config') {
|
if (cmd.name() === 'config') {
|
||||||
const renderMetadata = md => {
|
const renderMetadata = (md) => {
|
||||||
const desc = [];
|
const desc = [];
|
||||||
|
|
||||||
if (md.label) {
|
if (md.label) {
|
||||||
|
@ -71,7 +71,7 @@ process.stdout.on('error', function(err) {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
application.start(process.argv).catch(error => {
|
application.start(process.argv).catch((error) => {
|
||||||
if (error.code == 'flagError') {
|
if (error.code == 'flagError') {
|
||||||
console.error(error.message);
|
console.error(error.message);
|
||||||
console.error(_('Type `joplin help` for usage information.'));
|
console.error(_('Type `joplin help` for usage information.'));
|
||||||
|
@ -84,7 +84,7 @@ describe('integration_TagList', function() {
|
|||||||
|
|
||||||
// check the tag list is updated
|
// check the tag list is updated
|
||||||
state = testApp.store().getState();
|
state = testApp.store().getState();
|
||||||
const tagIds = state.selectedNoteTags.map(n => n.id).sort();
|
const tagIds = state.selectedNoteTags.map((n) => n.id).sort();
|
||||||
const expectedTagIds = [tags[0].id, tags[2].id].sort();
|
const expectedTagIds = [tags[0].id, tags[2].id].sort();
|
||||||
expect(state.selectedNoteTags.length).toEqual(2);
|
expect(state.selectedNoteTags.length).toEqual(2);
|
||||||
expect(tagIds).toEqual(expectedTagIds);
|
expect(tagIds).toEqual(expectedTagIds);
|
||||||
|
@ -173,7 +173,7 @@ describe('models_Note', function() {
|
|||||||
expect(allAfterDelete.length).toBe(expectedLength);
|
expect(allAfterDelete.length).toBe(expectedLength);
|
||||||
|
|
||||||
// Common elements between the to-be-deleted notes and the notes and folders remaining after the delete
|
// Common elements between the to-be-deleted notes and the notes and folders remaining after the delete
|
||||||
const intersection = [...notesToRemoveFromFolder1, ...notesToRemoveFromFolder2].filter(x => allAfterDelete.includes(x));
|
const intersection = [...notesToRemoveFromFolder1, ...notesToRemoveFromFolder2].filter((x) => allAfterDelete.includes(x));
|
||||||
// Should be empty
|
// Should be empty
|
||||||
expect(intersection.length).toBe(0);
|
expect(intersection.length).toBe(0);
|
||||||
}));
|
}));
|
||||||
|
@ -128,22 +128,22 @@ describe('models_Tag', function() {
|
|||||||
expect(commonTags.length).toBe(0);
|
expect(commonTags.length).toBe(0);
|
||||||
|
|
||||||
commonTags = await Tag.commonTagsByNoteIds([note0.id, note1.id, note2.id, note3.id]);
|
commonTags = await Tag.commonTagsByNoteIds([note0.id, note1.id, note2.id, note3.id]);
|
||||||
let commonTagIds = commonTags.map(t => t.id);
|
let commonTagIds = commonTags.map((t) => t.id);
|
||||||
expect(commonTagIds.length).toBe(0);
|
expect(commonTagIds.length).toBe(0);
|
||||||
|
|
||||||
commonTags = await Tag.commonTagsByNoteIds([note1.id, note2.id, note3.id]);
|
commonTags = await Tag.commonTagsByNoteIds([note1.id, note2.id, note3.id]);
|
||||||
commonTagIds = commonTags.map(t => t.id);
|
commonTagIds = commonTags.map((t) => t.id);
|
||||||
expect(commonTagIds.length).toBe(1);
|
expect(commonTagIds.length).toBe(1);
|
||||||
expect(commonTagIds.includes(taga.id)).toBe(true);
|
expect(commonTagIds.includes(taga.id)).toBe(true);
|
||||||
|
|
||||||
commonTags = await Tag.commonTagsByNoteIds([note2.id, note3.id]);
|
commonTags = await Tag.commonTagsByNoteIds([note2.id, note3.id]);
|
||||||
commonTagIds = commonTags.map(t => t.id);
|
commonTagIds = commonTags.map((t) => t.id);
|
||||||
expect(commonTagIds.length).toBe(2);
|
expect(commonTagIds.length).toBe(2);
|
||||||
expect(commonTagIds.includes(taga.id)).toBe(true);
|
expect(commonTagIds.includes(taga.id)).toBe(true);
|
||||||
expect(commonTagIds.includes(tagb.id)).toBe(true);
|
expect(commonTagIds.includes(tagb.id)).toBe(true);
|
||||||
|
|
||||||
commonTags = await Tag.commonTagsByNoteIds([note3.id]);
|
commonTags = await Tag.commonTagsByNoteIds([note3.id]);
|
||||||
commonTagIds = commonTags.map(t => t.id);
|
commonTagIds = commonTags.map((t) => t.id);
|
||||||
expect(commonTags.length).toBe(3);
|
expect(commonTags.length).toBe(3);
|
||||||
expect(commonTagIds.includes(taga.id)).toBe(true);
|
expect(commonTagIds.includes(taga.id)).toBe(true);
|
||||||
expect(commonTagIds.includes(tagb.id)).toBe(true);
|
expect(commonTagIds.includes(tagb.id)).toBe(true);
|
||||||
|
@ -526,8 +526,8 @@ describe('Reducer', function() {
|
|||||||
// current = 3
|
// current = 3
|
||||||
state = goBackWard(state);
|
state = goBackWard(state);
|
||||||
|
|
||||||
expect(state.backwardHistoryNotes.map(n=>n.id)).toEqual([notes[0], notes[1], notes[2], notes[3], notes[2], notes[3], notes[2]].map(n=>n.id));
|
expect(state.backwardHistoryNotes.map((n)=>n.id)).toEqual([notes[0], notes[1], notes[2], notes[3], notes[2], notes[3], notes[2]].map((n)=>n.id));
|
||||||
expect(state.forwardHistoryNotes.map(n=>n.id)).toEqual([notes[3], notes[2], notes[3], notes[2]].map(n=>n.id));
|
expect(state.forwardHistoryNotes.map((n)=>n.id)).toEqual([notes[3], notes[2], notes[3], notes[2]].map((n)=>n.id));
|
||||||
expect(state.selectedNoteIds).toEqual([notes[3].id]);
|
expect(state.selectedNoteIds).toEqual([notes[3].id]);
|
||||||
|
|
||||||
// delete third note
|
// delete third note
|
||||||
@ -547,8 +547,8 @@ describe('Reducer', function() {
|
|||||||
// backward = 0 1
|
// backward = 0 1
|
||||||
// forward =
|
// forward =
|
||||||
// current = 3
|
// current = 3
|
||||||
expect(state.backwardHistoryNotes.map(x => x.id)).toEqual([notes[0].id, notes[1].id]);
|
expect(state.backwardHistoryNotes.map((x) => x.id)).toEqual([notes[0].id, notes[1].id]);
|
||||||
expect(state.forwardHistoryNotes.map(x => x.id)).toEqual([]);
|
expect(state.forwardHistoryNotes.map((x) => x.id)).toEqual([]);
|
||||||
expect(state.selectedNoteIds).toEqual([notes[3].id]);
|
expect(state.selectedNoteIds).toEqual([notes[3].id]);
|
||||||
}));
|
}));
|
||||||
|
|
||||||
@ -565,7 +565,7 @@ describe('Reducer', function() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
expect(state.backwardHistoryNotes.length).toEqual(MAX_HISTORY);
|
expect(state.backwardHistoryNotes.length).toEqual(MAX_HISTORY);
|
||||||
expect(state.forwardHistoryNotes.map(x => x.id)).toEqual([]);
|
expect(state.forwardHistoryNotes.map((x) => x.id)).toEqual([]);
|
||||||
|
|
||||||
for (let i = 0; i < 2 * MAX_HISTORY; i++) {
|
for (let i = 0; i < 2 * MAX_HISTORY; i++) {
|
||||||
state = goBackWard(state);
|
state = goBackWard(state);
|
||||||
@ -579,6 +579,6 @@ describe('Reducer', function() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
expect(state.backwardHistoryNotes.length).toEqual(MAX_HISTORY);
|
expect(state.backwardHistoryNotes.length).toEqual(MAX_HISTORY);
|
||||||
expect(state.forwardHistoryNotes.map(x => x.id)).toEqual([]);
|
expect(state.forwardHistoryNotes.map((x) => x.id)).toEqual([]);
|
||||||
}));
|
}));
|
||||||
});
|
});
|
||||||
|
@ -146,7 +146,7 @@ describe('services_EncryptionService', function() {
|
|||||||
const needUpgrade = service.masterKeysThatNeedUpgrading(await MasterKey.all());
|
const needUpgrade = service.masterKeysThatNeedUpgrading(await MasterKey.all());
|
||||||
|
|
||||||
expect(needUpgrade.length).toBe(2);
|
expect(needUpgrade.length).toBe(2);
|
||||||
expect(needUpgrade.map(k => k.id).sort()).toEqual([masterKey1.id, masterKey2.id].sort());
|
expect(needUpgrade.map((k) => k.id).sort()).toEqual([masterKey1.id, masterKey2.id].sort());
|
||||||
}));
|
}));
|
||||||
|
|
||||||
it('should encrypt and decrypt with a master key', asyncTest(async () => {
|
it('should encrypt and decrypt with a master key', asyncTest(async () => {
|
||||||
|
@ -101,7 +101,7 @@ describe('services_KvStore', function() {
|
|||||||
const results = await store.searchByPrefix('testing:');
|
const results = await store.searchByPrefix('testing:');
|
||||||
expect(results.length).toBe(2);
|
expect(results.length).toBe(2);
|
||||||
|
|
||||||
const numbers = results.map(r => r.value).sort();
|
const numbers = results.map((r) => r.value).sort();
|
||||||
expect(numbers[0]).toBe(1);
|
expect(numbers[0]).toBe(1);
|
||||||
expect(numbers[1]).toBe(2);
|
expect(numbers[1]).toBe(2);
|
||||||
}));
|
}));
|
||||||
|
@ -110,7 +110,7 @@ describe('services_SearchEngine', function() {
|
|||||||
const rows = await engine.search(testCase[0]);
|
const rows = await engine.search(testCase[0]);
|
||||||
|
|
||||||
for (let i = 0; i < notes.length; i++) {
|
for (let i = 0; i < notes.length; i++) {
|
||||||
const row = rows.find(row => row.id === notes[i].id);
|
const row = rows.find((row) => row.id === notes[i].id);
|
||||||
const actual = row ? row.fields.sort().join(',') : '';
|
const actual = row ? row.fields.sort().join(',') : '';
|
||||||
const expected = testCase[i + 1].sort().join(',');
|
const expected = testCase[i + 1].sort().join(',');
|
||||||
expect(expected).toBe(actual);
|
expect(expected).toBe(actual);
|
||||||
@ -330,9 +330,9 @@ describe('services_SearchEngine', function() {
|
|||||||
const expected = t[1];
|
const expected = t[1];
|
||||||
const actual = engine.parseQuery(input);
|
const actual = engine.parseQuery(input);
|
||||||
|
|
||||||
const _Values = actual.terms._ ? actual.terms._.map(v => v.value) : undefined;
|
const _Values = actual.terms._ ? actual.terms._.map((v) => v.value) : undefined;
|
||||||
const titleValues = actual.terms.title ? actual.terms.title.map(v => v.value) : undefined;
|
const titleValues = actual.terms.title ? actual.terms.title.map((v) => v.value) : undefined;
|
||||||
const bodyValues = actual.terms.body ? actual.terms.body.map(v => v.value) : undefined;
|
const bodyValues = actual.terms.body ? actual.terms.body.map((v) => v.value) : undefined;
|
||||||
|
|
||||||
expect(JSON.stringify(_Values)).toBe(JSON.stringify(expected._), `Test case (_) ${i}`);
|
expect(JSON.stringify(_Values)).toBe(JSON.stringify(expected._), `Test case (_) ${i}`);
|
||||||
expect(JSON.stringify(titleValues)).toBe(JSON.stringify(expected.title), `Test case (title) ${i}`);
|
expect(JSON.stringify(titleValues)).toBe(JSON.stringify(expected.title), `Test case (title) ${i}`);
|
||||||
|
@ -426,7 +426,7 @@ function id(a) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function ids(a) {
|
function ids(a) {
|
||||||
return a.map(n => n.id);
|
return a.map((n) => n.id);
|
||||||
}
|
}
|
||||||
|
|
||||||
function sortedIds(a) {
|
function sortedIds(a) {
|
||||||
|
@ -76,7 +76,7 @@ describe('urlUtils', function() {
|
|||||||
const result = urlUtils.extractResourceUrls(t[0]);
|
const result = urlUtils.extractResourceUrls(t[0]);
|
||||||
const expected = t[1];
|
const expected = t[1];
|
||||||
|
|
||||||
const itemIds = result.map(r => r.itemId);
|
const itemIds = result.map((r) => r.itemId);
|
||||||
expect(itemIds.sort().join(',')).toBe(expected.sort().join(','));
|
expect(itemIds.sort().join(',')).toBe(expected.sort().join(','));
|
||||||
}
|
}
|
||||||
}));
|
}));
|
||||||
|
@ -266,7 +266,7 @@
|
|||||||
|
|
||||||
for (const preElement of preElements) {
|
for (const preElement of preElements) {
|
||||||
const fontFamily = getComputedStyle(preElement).getPropertyValue('font-family');
|
const fontFamily = getComputedStyle(preElement).getPropertyValue('font-family');
|
||||||
const fontFamilyArray = fontFamily.split(',').map(f => f.toLowerCase().trim());
|
const fontFamilyArray = fontFamily.split(',').map((f) => f.toLowerCase().trim());
|
||||||
if (fontFamilyArray.indexOf('monospace') >= 0) {
|
if (fontFamilyArray.indexOf('monospace') >= 0) {
|
||||||
preElement.style.fontFamily = fontFamily;
|
preElement.style.fontFamily = fontFamily;
|
||||||
}
|
}
|
||||||
|
@ -30,7 +30,7 @@ const dotenvFiles = [
|
|||||||
// that have already been set. Variable expansion is supported in .env files.
|
// that have already been set. Variable expansion is supported in .env files.
|
||||||
// https://github.com/motdotla/dotenv
|
// https://github.com/motdotla/dotenv
|
||||||
// https://github.com/motdotla/dotenv-expand
|
// https://github.com/motdotla/dotenv-expand
|
||||||
dotenvFiles.forEach(dotenvFile => {
|
dotenvFiles.forEach((dotenvFile) => {
|
||||||
if (fs.existsSync(dotenvFile)) {
|
if (fs.existsSync(dotenvFile)) {
|
||||||
require('dotenv-expand')(
|
require('dotenv-expand')(
|
||||||
require('dotenv').config({
|
require('dotenv').config({
|
||||||
@ -52,8 +52,8 @@ dotenvFiles.forEach(dotenvFile => {
|
|||||||
const appDirectory = fs.realpathSync(process.cwd());
|
const appDirectory = fs.realpathSync(process.cwd());
|
||||||
process.env.NODE_PATH = (process.env.NODE_PATH || '')
|
process.env.NODE_PATH = (process.env.NODE_PATH || '')
|
||||||
.split(path.delimiter)
|
.split(path.delimiter)
|
||||||
.filter(folder => folder && !path.isAbsolute(folder))
|
.filter((folder) => folder && !path.isAbsolute(folder))
|
||||||
.map(folder => path.resolve(appDirectory, folder))
|
.map((folder) => path.resolve(appDirectory, folder))
|
||||||
.join(path.delimiter);
|
.join(path.delimiter);
|
||||||
|
|
||||||
// Grab NODE_ENV and REACT_APP_* environment variables and prepare them to be
|
// Grab NODE_ENV and REACT_APP_* environment variables and prepare them to be
|
||||||
@ -62,7 +62,7 @@ const REACT_APP = /^REACT_APP_/i;
|
|||||||
|
|
||||||
function getClientEnvironment(publicUrl) {
|
function getClientEnvironment(publicUrl) {
|
||||||
const raw = Object.keys(process.env)
|
const raw = Object.keys(process.env)
|
||||||
.filter(key => REACT_APP.test(key))
|
.filter((key) => REACT_APP.test(key))
|
||||||
.reduce(
|
.reduce(
|
||||||
(env, key) => {
|
(env, key) => {
|
||||||
env[key] = process.env[key];
|
env[key] = process.env[key];
|
||||||
|
@ -7,7 +7,7 @@ const url = require('url');
|
|||||||
// Make sure any symlinks in the project folder are resolved:
|
// Make sure any symlinks in the project folder are resolved:
|
||||||
// https://github.com/facebook/create-react-app/issues/637
|
// https://github.com/facebook/create-react-app/issues/637
|
||||||
const appDirectory = fs.realpathSync(process.cwd());
|
const appDirectory = fs.realpathSync(process.cwd());
|
||||||
const resolveApp = relativePath => path.resolve(appDirectory, relativePath);
|
const resolveApp = (relativePath) => path.resolve(appDirectory, relativePath);
|
||||||
|
|
||||||
const envPublicUrl = process.env.PUBLIC_URL;
|
const envPublicUrl = process.env.PUBLIC_URL;
|
||||||
|
|
||||||
@ -22,7 +22,7 @@ function ensureSlash(inputPath, needsSlash) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const getPublicUrl = appPackageJson =>
|
const getPublicUrl = (appPackageJson) =>
|
||||||
envPublicUrl || require(appPackageJson).homepage;
|
envPublicUrl || require(appPackageJson).homepage;
|
||||||
|
|
||||||
// We use `PUBLIC_URL` environment variable or "homepage" field to infer
|
// We use `PUBLIC_URL` environment variable or "homepage" field to infer
|
||||||
@ -54,7 +54,7 @@ const moduleFileExtensions = [
|
|||||||
|
|
||||||
// Resolve file paths in the same order as webpack
|
// Resolve file paths in the same order as webpack
|
||||||
const resolveModule = (resolveFn, filePath) => {
|
const resolveModule = (resolveFn, filePath) => {
|
||||||
const extension = moduleFileExtensions.find(extension =>
|
const extension = moduleFileExtensions.find((extension) =>
|
||||||
fs.existsSync(resolveFn(`${filePath}.${extension}`))
|
fs.existsSync(resolveFn(`${filePath}.${extension}`))
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -7,7 +7,7 @@ process.env.NODE_ENV = 'development';
|
|||||||
// Makes the script crash on unhandled rejections instead of silently
|
// Makes the script crash on unhandled rejections instead of silently
|
||||||
// ignoring them. In the future, promise rejections that are not handled will
|
// ignoring them. In the future, promise rejections that are not handled will
|
||||||
// terminate the Node.js process with a non-zero exit code.
|
// terminate the Node.js process with a non-zero exit code.
|
||||||
process.on('unhandledRejection', err => {
|
process.on('unhandledRejection', (err) => {
|
||||||
throw err;
|
throw err;
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -70,7 +70,7 @@ checkBrowsers(paths.appPath, isInteractive)
|
|||||||
// run on a different port. `choosePort()` Promise resolves to the next free port.
|
// run on a different port. `choosePort()` Promise resolves to the next free port.
|
||||||
return choosePort(HOST, DEFAULT_PORT);
|
return choosePort(HOST, DEFAULT_PORT);
|
||||||
})
|
})
|
||||||
.then(port => {
|
.then((port) => {
|
||||||
if (port == null) {
|
if (port == null) {
|
||||||
// We have not found a port.
|
// We have not found a port.
|
||||||
return;
|
return;
|
||||||
@ -82,9 +82,9 @@ checkBrowsers(paths.appPath, isInteractive)
|
|||||||
const tscCompileOnError = process.env.TSC_COMPILE_ON_ERROR === 'true';
|
const tscCompileOnError = process.env.TSC_COMPILE_ON_ERROR === 'true';
|
||||||
const urls = prepareUrls(protocol, HOST, port);
|
const urls = prepareUrls(protocol, HOST, port);
|
||||||
const devSocket = {
|
const devSocket = {
|
||||||
warnings: warnings =>
|
warnings: (warnings) =>
|
||||||
devServer.sockWrite(devServer.sockets, 'warnings', warnings),
|
devServer.sockWrite(devServer.sockets, 'warnings', warnings),
|
||||||
errors: errors =>
|
errors: (errors) =>
|
||||||
devServer.sockWrite(devServer.sockets, 'errors', errors),
|
devServer.sockWrite(devServer.sockets, 'errors', errors),
|
||||||
};
|
};
|
||||||
// Create a webpack compiler that is configured with custom messages.
|
// Create a webpack compiler that is configured with custom messages.
|
||||||
@ -108,7 +108,7 @@ checkBrowsers(paths.appPath, isInteractive)
|
|||||||
);
|
);
|
||||||
const devServer = new WebpackDevServer(compiler, serverConfig);
|
const devServer = new WebpackDevServer(compiler, serverConfig);
|
||||||
// Launch WebpackDevServer.
|
// Launch WebpackDevServer.
|
||||||
devServer.listen(port, HOST, err => {
|
devServer.listen(port, HOST, (err) => {
|
||||||
if (err) {
|
if (err) {
|
||||||
return console.log(err);
|
return console.log(err);
|
||||||
}
|
}
|
||||||
@ -139,7 +139,7 @@ checkBrowsers(paths.appPath, isInteractive)
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
})
|
})
|
||||||
.catch(err => {
|
.catch((err) => {
|
||||||
if (err && err.message) {
|
if (err && err.message) {
|
||||||
console.log(err.message);
|
console.log(err.message);
|
||||||
}
|
}
|
||||||
|
@ -8,7 +8,7 @@ process.env.PUBLIC_URL = '';
|
|||||||
// Makes the script crash on unhandled rejections instead of silently
|
// Makes the script crash on unhandled rejections instead of silently
|
||||||
// ignoring them. In the future, promise rejections that are not handled will
|
// ignoring them. In the future, promise rejections that are not handled will
|
||||||
// terminate the Node.js process with a non-zero exit code.
|
// terminate the Node.js process with a non-zero exit code.
|
||||||
process.on('unhandledRejection', err => {
|
process.on('unhandledRejection', (err) => {
|
||||||
throw err;
|
throw err;
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -21,7 +21,7 @@ const defaultState = {
|
|||||||
isProbablyReaderable: true,
|
isProbablyReaderable: true,
|
||||||
};
|
};
|
||||||
|
|
||||||
const reduxMiddleware = store => next => async (action) => {
|
const reduxMiddleware = (store) => (next) => async (action) => {
|
||||||
const result = next(action);
|
const result = next(action);
|
||||||
const newState = store.getState();
|
const newState = store.getState();
|
||||||
|
|
||||||
|
@ -1137,7 +1137,7 @@ class Application extends BaseApplication {
|
|||||||
// It seems the "visible" property of separators is ignored by Electron, making
|
// It seems the "visible" property of separators is ignored by Electron, making
|
||||||
// it display separators that we want hidden. So this function iterates through
|
// it display separators that we want hidden. So this function iterates through
|
||||||
// them and remove them completely.
|
// them and remove them completely.
|
||||||
const cleanUpSeparators = items => {
|
const cleanUpSeparators = (items) => {
|
||||||
const output = [];
|
const output = [];
|
||||||
for (const item of items) {
|
for (const item of items) {
|
||||||
if ('visible' in item && item.type === 'separator' && !item.visible) continue;
|
if ('visible' in item && item.type === 'separator' && !item.visible) continue;
|
||||||
|
@ -157,7 +157,7 @@ function checkForUpdates(inBackground, window, logFilePath, options) {
|
|||||||
if (buttonIndex === 0) require('electron').shell.openExternal(release.downloadUrl ? release.downloadUrl : release.pageUrl);
|
if (buttonIndex === 0) require('electron').shell.openExternal(release.downloadUrl ? release.downloadUrl : release.pageUrl);
|
||||||
if (buttonIndex === 2) require('electron').shell.openExternal(release.pageUrl);
|
if (buttonIndex === 2) require('electron').shell.openExternal(release.pageUrl);
|
||||||
}
|
}
|
||||||
}).catch(error => {
|
}).catch((error) => {
|
||||||
autoUpdateLogger_.error(error);
|
autoUpdateLogger_.error(error);
|
||||||
if (!checkInBackground_) showErrorMessageBox(error.message);
|
if (!checkInBackground_) showErrorMessageBox(error.message);
|
||||||
}).then(() => {
|
}).then(() => {
|
||||||
|
@ -143,7 +143,7 @@ class ClipperConfigScreenComponent extends React.Component {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const mapStateToProps = state => {
|
const mapStateToProps = (state) => {
|
||||||
return {
|
return {
|
||||||
theme: state.settings.theme,
|
theme: state.settings.theme,
|
||||||
clipperServer: state.clipperServer,
|
clipperServer: state.clipperServer,
|
||||||
|
@ -314,7 +314,7 @@ class ConfigScreenComponent extends React.Component {
|
|||||||
<select
|
<select
|
||||||
value={value}
|
value={value}
|
||||||
style={selectStyle}
|
style={selectStyle}
|
||||||
onChange={event => {
|
onChange={(event) => {
|
||||||
updateSettingValue(key, event.target.value);
|
updateSettingValue(key, event.target.value);
|
||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
@ -338,12 +338,12 @@ class ConfigScreenComponent extends React.Component {
|
|||||||
id={`setting_checkbox_${key}`}
|
id={`setting_checkbox_${key}`}
|
||||||
type="checkbox"
|
type="checkbox"
|
||||||
checked={!!value}
|
checked={!!value}
|
||||||
onChange={event => {
|
onChange={(event) => {
|
||||||
onCheckboxClick(event);
|
onCheckboxClick(event);
|
||||||
}}
|
}}
|
||||||
/>
|
/>
|
||||||
<label
|
<label
|
||||||
onClick={event => {
|
onClick={(event) => {
|
||||||
onCheckboxClick(event);
|
onCheckboxClick(event);
|
||||||
}}
|
}}
|
||||||
style={checkboxLabelStyle}
|
style={checkboxLabelStyle}
|
||||||
@ -365,13 +365,13 @@ class ConfigScreenComponent extends React.Component {
|
|||||||
if (md.subType === 'file_path_and_args') {
|
if (md.subType === 'file_path_and_args') {
|
||||||
inputStyle.marginBottom = subLabel.marginBottom;
|
inputStyle.marginBottom = subLabel.marginBottom;
|
||||||
|
|
||||||
const splitCmd = cmdString => {
|
const splitCmd = (cmdString) => {
|
||||||
const path = pathUtils.extractExecutablePath(cmdString);
|
const path = pathUtils.extractExecutablePath(cmdString);
|
||||||
const args = cmdString.substr(path.length + 1);
|
const args = cmdString.substr(path.length + 1);
|
||||||
return [pathUtils.unquotePath(path), args];
|
return [pathUtils.unquotePath(path), args];
|
||||||
};
|
};
|
||||||
|
|
||||||
const joinCmd = cmdArray => {
|
const joinCmd = (cmdArray) => {
|
||||||
if (!cmdArray[0] && !cmdArray[1]) return '';
|
if (!cmdArray[0] && !cmdArray[1]) return '';
|
||||||
let cmdString = pathUtils.quotePath(cmdArray[0]);
|
let cmdString = pathUtils.quotePath(cmdArray[0]);
|
||||||
if (!cmdString) cmdString = '""';
|
if (!cmdString) cmdString = '""';
|
||||||
@ -379,13 +379,13 @@ class ConfigScreenComponent extends React.Component {
|
|||||||
return cmdString;
|
return cmdString;
|
||||||
};
|
};
|
||||||
|
|
||||||
const onPathChange = event => {
|
const onPathChange = (event) => {
|
||||||
const cmd = splitCmd(this.state.settings[key]);
|
const cmd = splitCmd(this.state.settings[key]);
|
||||||
cmd[0] = event.target.value;
|
cmd[0] = event.target.value;
|
||||||
updateSettingValue(key, joinCmd(cmd));
|
updateSettingValue(key, joinCmd(cmd));
|
||||||
};
|
};
|
||||||
|
|
||||||
const onArgsChange = event => {
|
const onArgsChange = (event) => {
|
||||||
const cmd = splitCmd(this.state.settings[key]);
|
const cmd = splitCmd(this.state.settings[key]);
|
||||||
cmd[1] = event.target.value;
|
cmd[1] = event.target.value;
|
||||||
updateSettingValue(key, joinCmd(cmd));
|
updateSettingValue(key, joinCmd(cmd));
|
||||||
@ -418,7 +418,7 @@ class ConfigScreenComponent extends React.Component {
|
|||||||
<input
|
<input
|
||||||
type={inputType}
|
type={inputType}
|
||||||
style={Object.assign({}, inputStyle, { marginBottom: 0 })}
|
style={Object.assign({}, inputStyle, { marginBottom: 0 })}
|
||||||
onChange={event => {
|
onChange={(event) => {
|
||||||
onPathChange(event);
|
onPathChange(event);
|
||||||
}}
|
}}
|
||||||
value={cmd[0]}
|
value={cmd[0]}
|
||||||
@ -430,7 +430,7 @@ class ConfigScreenComponent extends React.Component {
|
|||||||
<input
|
<input
|
||||||
type={inputType}
|
type={inputType}
|
||||||
style={inputStyle}
|
style={inputStyle}
|
||||||
onChange={event => {
|
onChange={(event) => {
|
||||||
onArgsChange(event);
|
onArgsChange(event);
|
||||||
}}
|
}}
|
||||||
value={cmd[1]}
|
value={cmd[1]}
|
||||||
@ -449,7 +449,7 @@ class ConfigScreenComponent extends React.Component {
|
|||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
const onTextChange = event => {
|
const onTextChange = (event) => {
|
||||||
updateSettingValue(key, event.target.value);
|
updateSettingValue(key, event.target.value);
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -462,7 +462,7 @@ class ConfigScreenComponent extends React.Component {
|
|||||||
type={inputType}
|
type={inputType}
|
||||||
style={inputStyle}
|
style={inputStyle}
|
||||||
value={this.state.settings[key]}
|
value={this.state.settings[key]}
|
||||||
onChange={event => {
|
onChange={(event) => {
|
||||||
onTextChange(event);
|
onTextChange(event);
|
||||||
}}
|
}}
|
||||||
/>
|
/>
|
||||||
@ -471,7 +471,7 @@ class ConfigScreenComponent extends React.Component {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
} else if (md.type === Setting.TYPE_INT) {
|
} else if (md.type === Setting.TYPE_INT) {
|
||||||
const onNumChange = event => {
|
const onNumChange = (event) => {
|
||||||
updateSettingValue(key, event.target.value);
|
updateSettingValue(key, event.target.value);
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -489,7 +489,7 @@ class ConfigScreenComponent extends React.Component {
|
|||||||
type="number"
|
type="number"
|
||||||
style={inputStyle}
|
style={inputStyle}
|
||||||
value={this.state.settings[key]}
|
value={this.state.settings[key]}
|
||||||
onChange={event => {
|
onChange={(event) => {
|
||||||
onNumChange(event);
|
onNumChange(event);
|
||||||
}}
|
}}
|
||||||
min={md.minimum}
|
min={md.minimum}
|
||||||
@ -620,7 +620,7 @@ class ConfigScreenComponent extends React.Component {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const mapStateToProps = state => {
|
const mapStateToProps = (state) => {
|
||||||
return {
|
return {
|
||||||
theme: state.settings.theme,
|
theme: state.settings.theme,
|
||||||
settings: state.settings,
|
settings: state.settings,
|
||||||
|
@ -10,7 +10,7 @@ class DropboxLoginScreenComponent extends React.Component {
|
|||||||
constructor() {
|
constructor() {
|
||||||
super();
|
super();
|
||||||
|
|
||||||
this.shared_ = new Shared(this, msg => bridge().showInfoMessageBox(msg), msg => bridge().showErrorMessageBox(msg));
|
this.shared_ = new Shared(this, (msg) => bridge().showInfoMessageBox(msg), (msg) => bridge().showErrorMessageBox(msg));
|
||||||
}
|
}
|
||||||
|
|
||||||
UNSAFE_componentWillMount() {
|
UNSAFE_componentWillMount() {
|
||||||
@ -51,7 +51,7 @@ class DropboxLoginScreenComponent extends React.Component {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const mapStateToProps = state => {
|
const mapStateToProps = (state) => {
|
||||||
return {
|
return {
|
||||||
theme: state.settings.theme,
|
theme: state.settings.theme,
|
||||||
};
|
};
|
||||||
|
@ -48,7 +48,7 @@ class EncryptionConfigScreenComponent extends React.Component {
|
|||||||
return shared.onSavePasswordClick(this, mk);
|
return shared.onSavePasswordClick(this, mk);
|
||||||
};
|
};
|
||||||
|
|
||||||
const onPasswordChange = event => {
|
const onPasswordChange = (event) => {
|
||||||
return shared.onPasswordChange(this, mk, event.target.value);
|
return shared.onPasswordChange(this, mk, event.target.value);
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -64,7 +64,7 @@ class EncryptionConfigScreenComponent extends React.Component {
|
|||||||
<td style={theme.textStyle}>{time.formatMsToLocal(mk.created_time)}</td>
|
<td style={theme.textStyle}>{time.formatMsToLocal(mk.created_time)}</td>
|
||||||
<td style={theme.textStyle}>{time.formatMsToLocal(mk.updated_time)}</td>
|
<td style={theme.textStyle}>{time.formatMsToLocal(mk.updated_time)}</td>
|
||||||
<td style={theme.textStyle}>
|
<td style={theme.textStyle}>
|
||||||
<input type="password" style={passwordStyle} value={password} onChange={event => onPasswordChange(event)} />{' '}
|
<input type="password" style={passwordStyle} value={password} onChange={(event) => onPasswordChange(event)} />{' '}
|
||||||
<button style={theme.buttonStyle} onClick={() => onSaveClick()}>
|
<button style={theme.buttonStyle} onClick={() => onSaveClick()}>
|
||||||
{_('Save')}
|
{_('Save')}
|
||||||
</button>
|
</button>
|
||||||
@ -287,7 +287,7 @@ class EncryptionConfigScreenComponent extends React.Component {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const mapStateToProps = state => {
|
const mapStateToProps = (state) => {
|
||||||
return {
|
return {
|
||||||
theme: state.settings.theme,
|
theme: state.settings.theme,
|
||||||
masterKeys: state.masterKeys,
|
masterKeys: state.masterKeys,
|
||||||
|
@ -17,13 +17,13 @@ class HeaderComponent extends React.Component {
|
|||||||
this.searchOnQuery_ = null;
|
this.searchOnQuery_ = null;
|
||||||
this.searchElement_ = null;
|
this.searchElement_ = null;
|
||||||
|
|
||||||
const triggerOnQuery = query => {
|
const triggerOnQuery = (query) => {
|
||||||
clearTimeout(this.scheduleSearchChangeEventIid_);
|
clearTimeout(this.scheduleSearchChangeEventIid_);
|
||||||
if (this.searchOnQuery_) this.searchOnQuery_(query);
|
if (this.searchOnQuery_) this.searchOnQuery_(query);
|
||||||
this.scheduleSearchChangeEventIid_ = null;
|
this.scheduleSearchChangeEventIid_ = null;
|
||||||
};
|
};
|
||||||
|
|
||||||
this.search_onChange = event => {
|
this.search_onChange = (event) => {
|
||||||
this.setState({ searchQuery: event.target.value });
|
this.setState({ searchQuery: event.target.value });
|
||||||
|
|
||||||
if (this.scheduleSearchChangeEventIid_) clearTimeout(this.scheduleSearchChangeEventIid_);
|
if (this.scheduleSearchChangeEventIid_) clearTimeout(this.scheduleSearchChangeEventIid_);
|
||||||
@ -55,7 +55,7 @@ class HeaderComponent extends React.Component {
|
|||||||
}, 5000);
|
}, 5000);
|
||||||
};
|
};
|
||||||
|
|
||||||
this.search_keyDown = event => {
|
this.search_keyDown = (event) => {
|
||||||
if (event.keyCode === 27) {
|
if (event.keyCode === 27) {
|
||||||
// ESCAPE
|
// ESCAPE
|
||||||
this.resetSearch();
|
this.resetSearch();
|
||||||
@ -261,7 +261,7 @@ class HeaderComponent extends React.Component {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<div key={key} style={containerStyle}>
|
<div key={key} style={containerStyle}>
|
||||||
<input type="text" style={inputStyle} placeholder={options.title} value={state.searchQuery} onChange={this.search_onChange} ref={elem => (this.searchElement_ = elem)} onFocus={this.search_onFocus} onBlur={this.search_onBlur} onKeyDown={this.search_keyDown} />
|
<input type="text" style={inputStyle} placeholder={options.title} value={state.searchQuery} onChange={this.search_onChange} ref={(elem) => (this.searchElement_ = elem)} onFocus={this.search_onFocus} onBlur={this.search_onBlur} onKeyDown={this.search_keyDown} />
|
||||||
<a href="#" style={searchButton} onClick={this.search_onClear}>
|
<a href="#" style={searchButton} onClick={this.search_onClear}>
|
||||||
{icon}
|
{icon}
|
||||||
</a>
|
</a>
|
||||||
@ -326,7 +326,7 @@ class HeaderComponent extends React.Component {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const mapStateToProps = state => {
|
const mapStateToProps = (state) => {
|
||||||
return {
|
return {
|
||||||
theme: state.settings.theme,
|
theme: state.settings.theme,
|
||||||
windowCommand: state.windowCommand,
|
windowCommand: state.windowCommand,
|
||||||
|
@ -27,7 +27,7 @@ class HelpButtonComponent extends React.Component {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const mapStateToProps = state => {
|
const mapStateToProps = (state) => {
|
||||||
return {
|
return {
|
||||||
theme: state.settings.theme,
|
theme: state.settings.theme,
|
||||||
};
|
};
|
||||||
|
@ -67,7 +67,7 @@ class ImportScreenComponent extends React.Component {
|
|||||||
let lastProgress = '';
|
let lastProgress = '';
|
||||||
|
|
||||||
const options = {
|
const options = {
|
||||||
onProgress: progressState => {
|
onProgress: (progressState) => {
|
||||||
const line = [];
|
const line = [];
|
||||||
line.push(_('Found: %d.', progressState.loaded));
|
line.push(_('Found: %d.', progressState.loaded));
|
||||||
line.push(_('Created: %d.', progressState.created));
|
line.push(_('Created: %d.', progressState.created));
|
||||||
@ -78,7 +78,7 @@ class ImportScreenComponent extends React.Component {
|
|||||||
lastProgress = line.join(' ');
|
lastProgress = line.join(' ');
|
||||||
this.addMessage('progress', lastProgress);
|
this.addMessage('progress', lastProgress);
|
||||||
},
|
},
|
||||||
onError: error => {
|
onError: (error) => {
|
||||||
// Don't display the error directly because most of the time it doesn't matter
|
// Don't display the error directly because most of the time it doesn't matter
|
||||||
// (eg. for weird broken HTML, but the note is still imported)
|
// (eg. for weird broken HTML, but the note is still imported)
|
||||||
console.warn('When importing ENEX file', error);
|
console.warn('When importing ENEX file', error);
|
||||||
@ -123,7 +123,7 @@ class ImportScreenComponent extends React.Component {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const mapStateToProps = state => {
|
const mapStateToProps = (state) => {
|
||||||
return {
|
return {
|
||||||
theme: state.settings.theme,
|
theme: state.settings.theme,
|
||||||
};
|
};
|
||||||
|
@ -172,7 +172,7 @@ class MainScreenComponent extends React.Component {
|
|||||||
this.setState({
|
this.setState({
|
||||||
promptOptions: {
|
promptOptions: {
|
||||||
label: _('Notebook title:'),
|
label: _('Notebook title:'),
|
||||||
onClose: async answer => {
|
onClose: async (answer) => {
|
||||||
if (answer) {
|
if (answer) {
|
||||||
let folder = null;
|
let folder = null;
|
||||||
try {
|
try {
|
||||||
@ -197,7 +197,7 @@ class MainScreenComponent extends React.Component {
|
|||||||
} else if (command.name === 'setTags') {
|
} else if (command.name === 'setTags') {
|
||||||
const tags = await Tag.commonTagsByNoteIds(command.noteIds);
|
const tags = await Tag.commonTagsByNoteIds(command.noteIds);
|
||||||
const startTags = tags
|
const startTags = tags
|
||||||
.map(a => {
|
.map((a) => {
|
||||||
return { value: a.id, label: a.title };
|
return { value: a.id, label: a.title };
|
||||||
})
|
})
|
||||||
.sort((a, b) => {
|
.sort((a, b) => {
|
||||||
@ -206,7 +206,7 @@ class MainScreenComponent extends React.Component {
|
|||||||
return a.label.localeCompare(b.label, undefined, { sensitivity: 'accent' });
|
return a.label.localeCompare(b.label, undefined, { sensitivity: 'accent' });
|
||||||
});
|
});
|
||||||
const allTags = await Tag.allWithNotes();
|
const allTags = await Tag.allWithNotes();
|
||||||
const tagSuggestions = allTags.map(a => {
|
const tagSuggestions = allTags.map((a) => {
|
||||||
return { value: a.id, label: a.title };
|
return { value: a.id, label: a.title };
|
||||||
})
|
})
|
||||||
.sort((a, b) => {
|
.sort((a, b) => {
|
||||||
@ -221,24 +221,24 @@ class MainScreenComponent extends React.Component {
|
|||||||
inputType: 'tags',
|
inputType: 'tags',
|
||||||
value: startTags,
|
value: startTags,
|
||||||
autocomplete: tagSuggestions,
|
autocomplete: tagSuggestions,
|
||||||
onClose: async answer => {
|
onClose: async (answer) => {
|
||||||
if (answer !== null) {
|
if (answer !== null) {
|
||||||
const endTagTitles = answer.map(a => {
|
const endTagTitles = answer.map((a) => {
|
||||||
return a.label.trim();
|
return a.label.trim();
|
||||||
});
|
});
|
||||||
if (command.noteIds.length === 1) {
|
if (command.noteIds.length === 1) {
|
||||||
await Tag.setNoteTagsByTitles(command.noteIds[0], endTagTitles);
|
await Tag.setNoteTagsByTitles(command.noteIds[0], endTagTitles);
|
||||||
} else {
|
} else {
|
||||||
const startTagTitles = startTags.map(a => { return a.label.trim(); });
|
const startTagTitles = startTags.map((a) => { return a.label.trim(); });
|
||||||
const addTags = endTagTitles.filter(value => !startTagTitles.includes(value));
|
const addTags = endTagTitles.filter((value) => !startTagTitles.includes(value));
|
||||||
const delTags = startTagTitles.filter(value => !endTagTitles.includes(value));
|
const delTags = startTagTitles.filter((value) => !endTagTitles.includes(value));
|
||||||
|
|
||||||
// apply the tag additions and deletions to each selected note
|
// apply the tag additions and deletions to each selected note
|
||||||
for (let i = 0; i < command.noteIds.length; i++) {
|
for (let i = 0; i < command.noteIds.length; i++) {
|
||||||
const tags = await Tag.tagsByNoteId(command.noteIds[i]);
|
const tags = await Tag.tagsByNoteId(command.noteIds[i]);
|
||||||
let tagTitles = tags.map(a => { return a.title; });
|
let tagTitles = tags.map((a) => { return a.title; });
|
||||||
tagTitles = tagTitles.concat(addTags);
|
tagTitles = tagTitles.concat(addTags);
|
||||||
tagTitles = tagTitles.filter(value => !delTags.includes(value));
|
tagTitles = tagTitles.filter((value) => !delTags.includes(value));
|
||||||
await Tag.setNoteTagsByTitles(command.noteIds[i], tagTitles);
|
await Tag.setNoteTagsByTitles(command.noteIds[i], tagTitles);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -268,7 +268,7 @@ class MainScreenComponent extends React.Component {
|
|||||||
inputType: 'dropdown',
|
inputType: 'dropdown',
|
||||||
value: '',
|
value: '',
|
||||||
autocomplete: startFolders,
|
autocomplete: startFolders,
|
||||||
onClose: async answer => {
|
onClose: async (answer) => {
|
||||||
if (answer != null) {
|
if (answer != null) {
|
||||||
for (let i = 0; i < command.noteIds.length; i++) {
|
for (let i = 0; i < command.noteIds.length; i++) {
|
||||||
await Note.moveToFolder(command.noteIds[i], answer.value);
|
await Note.moveToFolder(command.noteIds[i], answer.value);
|
||||||
@ -286,7 +286,7 @@ class MainScreenComponent extends React.Component {
|
|||||||
promptOptions: {
|
promptOptions: {
|
||||||
label: _('Rename notebook:'),
|
label: _('Rename notebook:'),
|
||||||
value: folder.title,
|
value: folder.title,
|
||||||
onClose: async answer => {
|
onClose: async (answer) => {
|
||||||
if (answer !== null) {
|
if (answer !== null) {
|
||||||
try {
|
try {
|
||||||
folder.title = answer;
|
folder.title = answer;
|
||||||
@ -307,7 +307,7 @@ class MainScreenComponent extends React.Component {
|
|||||||
promptOptions: {
|
promptOptions: {
|
||||||
label: _('Rename tag:'),
|
label: _('Rename tag:'),
|
||||||
value: tag.title,
|
value: tag.title,
|
||||||
onClose: async answer => {
|
onClose: async (answer) => {
|
||||||
if (answer !== null) {
|
if (answer !== null) {
|
||||||
try {
|
try {
|
||||||
tag.title = answer;
|
tag.title = answer;
|
||||||
@ -439,7 +439,7 @@ class MainScreenComponent extends React.Component {
|
|||||||
inputType: 'dropdown',
|
inputType: 'dropdown',
|
||||||
value: this.props.templates[0], // Need to start with some value
|
value: this.props.templates[0], // Need to start with some value
|
||||||
autocomplete: this.props.templates,
|
autocomplete: this.props.templates,
|
||||||
onClose: async answer => {
|
onClose: async (answer) => {
|
||||||
if (answer) {
|
if (answer) {
|
||||||
if (command.noteType === 'note' || command.noteType === 'todo') {
|
if (command.noteType === 'note' || command.noteType === 'todo') {
|
||||||
createNewNote(answer.value, command.noteType === 'todo');
|
createNewNote(answer.value, command.noteType === 'todo');
|
||||||
@ -839,7 +839,7 @@ class MainScreenComponent extends React.Component {
|
|||||||
headerItems.push({
|
headerItems.push({
|
||||||
title: _('Search...'),
|
title: _('Search...'),
|
||||||
iconName: 'fa-search',
|
iconName: 'fa-search',
|
||||||
onQuery: query => {
|
onQuery: (query) => {
|
||||||
this.doCommand({ name: 'search', query: query });
|
this.doCommand({ name: 'search', query: query });
|
||||||
},
|
},
|
||||||
type: 'search',
|
type: 'search',
|
||||||
@ -887,7 +887,7 @@ class MainScreenComponent extends React.Component {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const mapStateToProps = state => {
|
const mapStateToProps = (state) => {
|
||||||
return {
|
return {
|
||||||
theme: state.settings.theme,
|
theme: state.settings.theme,
|
||||||
settingEditorCodeView: state.settings['editor.codeView'],
|
settingEditorCodeView: state.settings['editor.codeView'],
|
||||||
|
@ -44,7 +44,7 @@ class NavigatorComponent extends Component {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const Navigator = connect(state => {
|
const Navigator = connect((state) => {
|
||||||
return {
|
return {
|
||||||
route: state.route,
|
route: state.route,
|
||||||
};
|
};
|
||||||
|
@ -337,7 +337,7 @@ function AceEditor(props: NoteBodyEditorProps, ref: any) {
|
|||||||
}, [wrapSelectionWithStrings]);
|
}, [wrapSelectionWithStrings]);
|
||||||
|
|
||||||
const onEditorKeyDown = useCallback((event: any) => {
|
const onEditorKeyDown = useCallback((event: any) => {
|
||||||
setLastKeys(prevLastKeys => {
|
setLastKeys((prevLastKeys) => {
|
||||||
const keys = prevLastKeys.slice();
|
const keys = prevLastKeys.slice();
|
||||||
keys.push(event.key);
|
keys.push(event.key);
|
||||||
while (keys.length > 2) keys.splice(0, 1);
|
while (keys.length > 2) keys.splice(0, 1);
|
||||||
|
@ -252,7 +252,7 @@ function NoteEditor(props: NoteEditorProps) {
|
|||||||
const onBodyWillChange = useCallback((event: any) => {
|
const onBodyWillChange = useCallback((event: any) => {
|
||||||
handleProvisionalFlag();
|
handleProvisionalFlag();
|
||||||
|
|
||||||
setFormNote(prev => {
|
setFormNote((prev) => {
|
||||||
return {
|
return {
|
||||||
...prev,
|
...prev,
|
||||||
bodyWillChangeId: event.changeId,
|
bodyWillChangeId: event.changeId,
|
||||||
@ -286,7 +286,7 @@ function NoteEditor(props: NoteEditorProps) {
|
|||||||
}, [formNote]);
|
}, [formNote]);
|
||||||
|
|
||||||
const onNotePropertyChange = useCallback((event) => {
|
const onNotePropertyChange = useCallback((event) => {
|
||||||
setFormNote(formNote => {
|
setFormNote((formNote) => {
|
||||||
if (formNote.id !== event.note.id) return formNote;
|
if (formNote.id !== event.note.id) return formNote;
|
||||||
|
|
||||||
const newFormNote: FormNote = { ...formNote };
|
const newFormNote: FormNote = { ...formNote };
|
||||||
|
@ -118,7 +118,7 @@ class NoteListComponent extends React.Component {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
const onDragStart = event => {
|
const onDragStart = (event) => {
|
||||||
let noteIds = [];
|
let noteIds = [];
|
||||||
|
|
||||||
// Here there is two cases:
|
// Here there is two cases:
|
||||||
@ -138,7 +138,7 @@ class NoteListComponent extends React.Component {
|
|||||||
event.dataTransfer.setData('text/x-jop-note-ids', JSON.stringify(noteIds));
|
event.dataTransfer.setData('text/x-jop-note-ids', JSON.stringify(noteIds));
|
||||||
};
|
};
|
||||||
|
|
||||||
const onCheckboxClick = async event => {
|
const onCheckboxClick = async (event) => {
|
||||||
const checked = event.target.checked;
|
const checked = event.target.checked;
|
||||||
const newNote = {
|
const newNote = {
|
||||||
id: item.id,
|
id: item.id,
|
||||||
@ -173,7 +173,7 @@ class NoteListComponent extends React.Component {
|
|||||||
style={{ margin: 0, marginBottom: 1, marginRight: 5 }}
|
style={{ margin: 0, marginBottom: 1, marginRight: 5 }}
|
||||||
type="checkbox"
|
type="checkbox"
|
||||||
defaultChecked={!!item.todo_completed}
|
defaultChecked={!!item.todo_completed}
|
||||||
onClick={event => {
|
onClick={(event) => {
|
||||||
onCheckboxClick(event, item);
|
onCheckboxClick(event, item);
|
||||||
}}
|
}}
|
||||||
/>
|
/>
|
||||||
@ -232,14 +232,14 @@ class NoteListComponent extends React.Component {
|
|||||||
{checkbox}
|
{checkbox}
|
||||||
<a
|
<a
|
||||||
ref={ref}
|
ref={ref}
|
||||||
onContextMenu={event => this.itemContextMenu(event)}
|
onContextMenu={(event) => this.itemContextMenu(event)}
|
||||||
href="#"
|
href="#"
|
||||||
draggable={true}
|
draggable={true}
|
||||||
style={listItemTitleStyle}
|
style={listItemTitleStyle}
|
||||||
onClick={event => {
|
onClick={(event) => {
|
||||||
onTitleClick(event, item);
|
onTitleClick(event, item);
|
||||||
}}
|
}}
|
||||||
onDragStart={event => onDragStart(event)}
|
onDragStart={(event) => onDragStart(event)}
|
||||||
data-id={item.id}
|
data-id={item.id}
|
||||||
>
|
>
|
||||||
{watchedIcon}
|
{watchedIcon}
|
||||||
@ -365,7 +365,7 @@ class NoteListComponent extends React.Component {
|
|||||||
event.preventDefault();
|
event.preventDefault();
|
||||||
|
|
||||||
const notes = BaseModel.modelsByIds(this.props.notes, noteIds);
|
const notes = BaseModel.modelsByIds(this.props.notes, noteIds);
|
||||||
const todos = notes.filter(n => !!n.is_todo);
|
const todos = notes.filter((n) => !!n.is_todo);
|
||||||
if (!todos.length) return;
|
if (!todos.length) return;
|
||||||
|
|
||||||
for (let i = 0; i < todos.length; i++) {
|
for (let i = 0; i < todos.length; i++) {
|
||||||
@ -457,7 +457,7 @@ class NoteListComponent extends React.Component {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const mapStateToProps = state => {
|
const mapStateToProps = (state) => {
|
||||||
return {
|
return {
|
||||||
notes: state.notes,
|
notes: state.notes,
|
||||||
folders: state.folders,
|
folders: state.folders,
|
||||||
|
@ -232,7 +232,7 @@ class NotePropertiesDialog extends React.Component {
|
|||||||
let editCompHandler = null;
|
let editCompHandler = null;
|
||||||
let editCompIcon = null;
|
let editCompIcon = null;
|
||||||
|
|
||||||
const onKeyDown = event => {
|
const onKeyDown = (event) => {
|
||||||
if (event.keyCode === 13) {
|
if (event.keyCode === 13) {
|
||||||
this.saveProperty();
|
this.saveProperty();
|
||||||
} else if (event.keyCode === 27) {
|
} else if (event.keyCode === 27) {
|
||||||
@ -249,10 +249,10 @@ class NotePropertiesDialog extends React.Component {
|
|||||||
dateFormat={time.dateFormat()}
|
dateFormat={time.dateFormat()}
|
||||||
timeFormat={time.timeFormat()}
|
timeFormat={time.timeFormat()}
|
||||||
inputProps={{
|
inputProps={{
|
||||||
onKeyDown: event => onKeyDown(event, key),
|
onKeyDown: (event) => onKeyDown(event, key),
|
||||||
style: styles.input,
|
style: styles.input,
|
||||||
}}
|
}}
|
||||||
onChange={momentObject => {
|
onChange={(momentObject) => {
|
||||||
this.setState({ editedValue: momentObject });
|
this.setState({ editedValue: momentObject });
|
||||||
}}
|
}}
|
||||||
/>
|
/>
|
||||||
@ -268,10 +268,10 @@ class NotePropertiesDialog extends React.Component {
|
|||||||
defaultValue={value}
|
defaultValue={value}
|
||||||
type="text"
|
type="text"
|
||||||
ref="editField"
|
ref="editField"
|
||||||
onChange={event => {
|
onChange={(event) => {
|
||||||
this.setState({ editedValue: event.target.value });
|
this.setState({ editedValue: event.target.value });
|
||||||
}}
|
}}
|
||||||
onKeyDown={event => onKeyDown(event)}
|
onKeyDown={(event) => onKeyDown(event)}
|
||||||
style={styles.input}
|
style={styles.input}
|
||||||
/>
|
/>
|
||||||
);
|
);
|
||||||
|
@ -211,7 +211,7 @@ class NoteRevisionViewerComponent extends React.PureComponent {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const mapStateToProps = state => {
|
const mapStateToProps = (state) => {
|
||||||
return {
|
return {
|
||||||
theme: state.settings.theme,
|
theme: state.settings.theme,
|
||||||
};
|
};
|
||||||
|
@ -170,7 +170,7 @@ class NoteSearchBarComponent extends React.Component {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const mapStateToProps = state => {
|
const mapStateToProps = (state) => {
|
||||||
return {
|
return {
|
||||||
theme: state.settings.theme,
|
theme: state.settings.theme,
|
||||||
};
|
};
|
||||||
|
@ -23,7 +23,7 @@ class NoteStatusBarComponent extends React.Component {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const mapStateToProps = state => {
|
const mapStateToProps = (state) => {
|
||||||
return {
|
return {
|
||||||
// notes: state.notes,
|
// notes: state.notes,
|
||||||
// folders: state.folders,
|
// folders: state.folders,
|
||||||
|
@ -167,7 +167,7 @@ class NoteTextViewerComponent extends React.Component {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const mapStateToProps = state => {
|
const mapStateToProps = (state) => {
|
||||||
return {
|
return {
|
||||||
theme: state.settings.theme,
|
theme: state.settings.theme,
|
||||||
};
|
};
|
||||||
|
@ -19,7 +19,7 @@ class OneDriveLoginScreenComponent extends React.Component {
|
|||||||
|
|
||||||
async componentDidMount() {
|
async componentDidMount() {
|
||||||
const log = (s) => {
|
const log = (s) => {
|
||||||
this.setState(state => {
|
this.setState((state) => {
|
||||||
const authLog = state.authLog.slice();
|
const authLog = state.authLog.slice();
|
||||||
authLog.push({ key: (Date.now() + Math.random()).toString(), text: s });
|
authLog.push({ key: (Date.now() + Math.random()).toString(), text: s });
|
||||||
return { authLog: authLog };
|
return { authLog: authLog };
|
||||||
@ -76,7 +76,7 @@ class OneDriveLoginScreenComponent extends React.Component {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const mapStateToProps = state => {
|
const mapStateToProps = (state) => {
|
||||||
return {
|
return {
|
||||||
theme: state.settings.theme,
|
theme: state.settings.theme,
|
||||||
};
|
};
|
||||||
|
@ -100,18 +100,18 @@ class PromptDialog extends React.Component {
|
|||||||
};
|
};
|
||||||
|
|
||||||
this.styles_.select = {
|
this.styles_.select = {
|
||||||
control: provided =>
|
control: (provided) =>
|
||||||
Object.assign(provided, {
|
Object.assign(provided, {
|
||||||
minWidth: width * 0.2,
|
minWidth: width * 0.2,
|
||||||
maxWidth: width * 0.5,
|
maxWidth: width * 0.5,
|
||||||
fontFamily: theme.fontFamily,
|
fontFamily: theme.fontFamily,
|
||||||
}),
|
}),
|
||||||
input: provided =>
|
input: (provided) =>
|
||||||
Object.assign(provided, {
|
Object.assign(provided, {
|
||||||
minWidth: '20px',
|
minWidth: '20px',
|
||||||
color: theme.color,
|
color: theme.color,
|
||||||
}),
|
}),
|
||||||
menu: provided =>
|
menu: (provided) =>
|
||||||
Object.assign(provided, {
|
Object.assign(provided, {
|
||||||
color: theme.color,
|
color: theme.color,
|
||||||
fontFamily: theme.fontFamily,
|
fontFamily: theme.fontFamily,
|
||||||
@ -123,17 +123,17 @@ class PromptDialog extends React.Component {
|
|||||||
fontFamily: theme.fontFamily,
|
fontFamily: theme.fontFamily,
|
||||||
paddingLeft: `${10 + (state.data.indentDepth || 0) * 20}px`,
|
paddingLeft: `${10 + (state.data.indentDepth || 0) * 20}px`,
|
||||||
}),
|
}),
|
||||||
multiValueLabel: provided =>
|
multiValueLabel: (provided) =>
|
||||||
Object.assign(provided, {
|
Object.assign(provided, {
|
||||||
fontFamily: theme.fontFamily,
|
fontFamily: theme.fontFamily,
|
||||||
}),
|
}),
|
||||||
multiValueRemove: provided =>
|
multiValueRemove: (provided) =>
|
||||||
Object.assign(provided, {
|
Object.assign(provided, {
|
||||||
color: theme.color,
|
color: theme.color,
|
||||||
}),
|
}),
|
||||||
};
|
};
|
||||||
|
|
||||||
this.styles_.selectTheme = tagTheme =>
|
this.styles_.selectTheme = (tagTheme) =>
|
||||||
Object.assign(tagTheme, {
|
Object.assign(tagTheme, {
|
||||||
borderRadius: 2,
|
borderRadius: 2,
|
||||||
colors: Object.assign(tagTheme.colors, {
|
colors: Object.assign(tagTheme.colors, {
|
||||||
@ -181,7 +181,7 @@ class PromptDialog extends React.Component {
|
|||||||
this.setState({ visible: false, answer: '' });
|
this.setState({ visible: false, answer: '' });
|
||||||
};
|
};
|
||||||
|
|
||||||
const onChange = event => {
|
const onChange = (event) => {
|
||||||
this.setState({ answer: event.target.value });
|
this.setState({ answer: event.target.value });
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -194,16 +194,16 @@ class PromptDialog extends React.Component {
|
|||||||
// return m.isValid() ? m.toDate() : null;
|
// return m.isValid() ? m.toDate() : null;
|
||||||
// }
|
// }
|
||||||
|
|
||||||
const onDateTimeChange = momentObject => {
|
const onDateTimeChange = (momentObject) => {
|
||||||
this.setState({ answer: momentObject });
|
this.setState({ answer: momentObject });
|
||||||
};
|
};
|
||||||
|
|
||||||
const onSelectChange = newValue => {
|
const onSelectChange = (newValue) => {
|
||||||
this.setState({ answer: newValue });
|
this.setState({ answer: newValue });
|
||||||
this.focusInput_ = true;
|
this.focusInput_ = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
const onKeyDown = event => {
|
const onKeyDown = (event) => {
|
||||||
if (event.key === 'Enter') {
|
if (event.key === 'Enter') {
|
||||||
if (this.props.inputType !== 'tags' && this.props.inputType !== 'dropdown') {
|
if (this.props.inputType !== 'tags' && this.props.inputType !== 'dropdown') {
|
||||||
onClose(true);
|
onClose(true);
|
||||||
@ -221,13 +221,13 @@ class PromptDialog extends React.Component {
|
|||||||
let inputComp = null;
|
let inputComp = null;
|
||||||
|
|
||||||
if (this.props.inputType === 'datetime') {
|
if (this.props.inputType === 'datetime') {
|
||||||
inputComp = <Datetime value={this.state.answer} inputProps={{ style: styles.input }} dateFormat={time.dateFormat()} timeFormat={time.timeFormat()} onChange={momentObject => onDateTimeChange(momentObject)} />;
|
inputComp = <Datetime value={this.state.answer} inputProps={{ style: styles.input }} dateFormat={time.dateFormat()} timeFormat={time.timeFormat()} onChange={(momentObject) => onDateTimeChange(momentObject)} />;
|
||||||
} else if (this.props.inputType === 'tags') {
|
} else if (this.props.inputType === 'tags') {
|
||||||
inputComp = <CreatableSelect styles={styles.select} theme={styles.selectTheme} ref={this.answerInput_} value={this.state.answer} placeholder="" components={makeAnimated()} isMulti={true} isClearable={false} backspaceRemovesValue={true} options={this.props.autocomplete} onChange={onSelectChange} onKeyDown={event => onKeyDown(event)} />;
|
inputComp = <CreatableSelect styles={styles.select} theme={styles.selectTheme} ref={this.answerInput_} value={this.state.answer} placeholder="" components={makeAnimated()} isMulti={true} isClearable={false} backspaceRemovesValue={true} options={this.props.autocomplete} onChange={onSelectChange} onKeyDown={(event) => onKeyDown(event)} />;
|
||||||
} else if (this.props.inputType === 'dropdown') {
|
} else if (this.props.inputType === 'dropdown') {
|
||||||
inputComp = <Select styles={styles.select} theme={styles.selectTheme} ref={this.answerInput_} components={makeAnimated()} value={this.props.answer} defaultValue={this.props.defaultValue} isClearable={false} options={this.props.autocomplete} onChange={onSelectChange} onKeyDown={event => onKeyDown(event)} />;
|
inputComp = <Select styles={styles.select} theme={styles.selectTheme} ref={this.answerInput_} components={makeAnimated()} value={this.props.answer} defaultValue={this.props.defaultValue} isClearable={false} options={this.props.autocomplete} onChange={onSelectChange} onKeyDown={(event) => onKeyDown(event)} />;
|
||||||
} else {
|
} else {
|
||||||
inputComp = <input style={styles.input} ref={this.answerInput_} value={this.state.answer} type="text" onChange={event => onChange(event)} onKeyDown={event => onKeyDown(event)} />;
|
inputComp = <input style={styles.input} ref={this.answerInput_} value={this.state.answer} type="text" onChange={(event) => onChange(event)} onKeyDown={(event) => onKeyDown(event)} />;
|
||||||
}
|
}
|
||||||
|
|
||||||
const buttonComps = [];
|
const buttonComps = [];
|
||||||
|
@ -98,7 +98,7 @@ class RootComponent extends React.Component {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const mapStateToProps = state => {
|
const mapStateToProps = (state) => {
|
||||||
return {
|
return {
|
||||||
size: state.windowContentSize,
|
size: state.windowContentSize,
|
||||||
zoomFactor: state.settings.windowContentZoomFactor / 100,
|
zoomFactor: state.settings.windowContentZoomFactor / 100,
|
||||||
|
@ -20,7 +20,7 @@ class SideBarComponent extends React.Component {
|
|||||||
constructor() {
|
constructor() {
|
||||||
super();
|
super();
|
||||||
|
|
||||||
this.onFolderDragStart_ = event => {
|
this.onFolderDragStart_ = (event) => {
|
||||||
const folderId = event.currentTarget.getAttribute('folderid');
|
const folderId = event.currentTarget.getAttribute('folderid');
|
||||||
if (!folderId) return;
|
if (!folderId) return;
|
||||||
|
|
||||||
@ -29,12 +29,12 @@ class SideBarComponent extends React.Component {
|
|||||||
event.dataTransfer.setData('text/x-jop-folder-ids', JSON.stringify([folderId]));
|
event.dataTransfer.setData('text/x-jop-folder-ids', JSON.stringify([folderId]));
|
||||||
};
|
};
|
||||||
|
|
||||||
this.onFolderDragOver_ = event => {
|
this.onFolderDragOver_ = (event) => {
|
||||||
if (event.dataTransfer.types.indexOf('text/x-jop-note-ids') >= 0) event.preventDefault();
|
if (event.dataTransfer.types.indexOf('text/x-jop-note-ids') >= 0) event.preventDefault();
|
||||||
if (event.dataTransfer.types.indexOf('text/x-jop-folder-ids') >= 0) event.preventDefault();
|
if (event.dataTransfer.types.indexOf('text/x-jop-folder-ids') >= 0) event.preventDefault();
|
||||||
};
|
};
|
||||||
|
|
||||||
this.onFolderDrop_ = async event => {
|
this.onFolderDrop_ = async (event) => {
|
||||||
const folderId = event.currentTarget.getAttribute('folderid');
|
const folderId = event.currentTarget.getAttribute('folderid');
|
||||||
const dt = event.dataTransfer;
|
const dt = event.dataTransfer;
|
||||||
if (!dt) return;
|
if (!dt) return;
|
||||||
@ -62,7 +62,7 @@ class SideBarComponent extends React.Component {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
this.onTagDrop_ = async event => {
|
this.onTagDrop_ = async (event) => {
|
||||||
const tagId = event.currentTarget.getAttribute('tagid');
|
const tagId = event.currentTarget.getAttribute('tagid');
|
||||||
const dt = event.dataTransfer;
|
const dt = event.dataTransfer;
|
||||||
if (!dt) return;
|
if (!dt) return;
|
||||||
@ -77,7 +77,7 @@ class SideBarComponent extends React.Component {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
this.onFolderToggleClick_ = async event => {
|
this.onFolderToggleClick_ = async (event) => {
|
||||||
const folderId = event.currentTarget.getAttribute('folderid');
|
const folderId = event.currentTarget.getAttribute('folderid');
|
||||||
|
|
||||||
this.props.dispatch({
|
this.props.dispatch({
|
||||||
@ -489,7 +489,7 @@ class SideBarComponent extends React.Component {
|
|||||||
href="#"
|
href="#"
|
||||||
data-id={folder.id}
|
data-id={folder.id}
|
||||||
data-type={BaseModel.TYPE_FOLDER}
|
data-type={BaseModel.TYPE_FOLDER}
|
||||||
onContextMenu={event => this.itemContextMenu(event)}
|
onContextMenu={(event) => this.itemContextMenu(event)}
|
||||||
style={style}
|
style={style}
|
||||||
folderid={folder.id}
|
folderid={folder.id}
|
||||||
onClick={() => {
|
onClick={() => {
|
||||||
@ -517,7 +517,7 @@ class SideBarComponent extends React.Component {
|
|||||||
ref={anchorRef}
|
ref={anchorRef}
|
||||||
data-id={tag.id}
|
data-id={tag.id}
|
||||||
data-type={BaseModel.TYPE_TAG}
|
data-type={BaseModel.TYPE_TAG}
|
||||||
onContextMenu={event => this.itemContextMenu(event)}
|
onContextMenu={(event) => this.itemContextMenu(event)}
|
||||||
tagid={tag.id}
|
tagid={tag.id}
|
||||||
key={tag.id}
|
key={tag.id}
|
||||||
style={style}
|
style={style}
|
||||||
@ -586,7 +586,7 @@ class SideBarComponent extends React.Component {
|
|||||||
style={style}
|
style={style}
|
||||||
key={key}
|
key={key}
|
||||||
{...extraProps}
|
{...extraProps}
|
||||||
onClick={event => {
|
onClick={(event) => {
|
||||||
// if a custom click event is attached, trigger that.
|
// if a custom click event is attached, trigger that.
|
||||||
if (headerClick) {
|
if (headerClick) {
|
||||||
headerClick(key, event);
|
headerClick(key, event);
|
||||||
@ -832,7 +832,7 @@ class SideBarComponent extends React.Component {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const mapStateToProps = state => {
|
const mapStateToProps = (state) => {
|
||||||
return {
|
return {
|
||||||
folders: state.folders,
|
folders: state.folders,
|
||||||
tags: state.tags,
|
tags: state.tags,
|
||||||
|
@ -146,7 +146,7 @@ class StatusScreenComponent extends React.Component {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const mapStateToProps = state => {
|
const mapStateToProps = (state) => {
|
||||||
return {
|
return {
|
||||||
theme: state.settings.theme,
|
theme: state.settings.theme,
|
||||||
settings: state.settings,
|
settings: state.settings,
|
||||||
|
@ -12,7 +12,7 @@ class TagItemComponent extends React.Component {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const mapStateToProps = state => {
|
const mapStateToProps = (state) => {
|
||||||
return { theme: state.settings.theme };
|
return { theme: state.settings.theme };
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -41,7 +41,7 @@ class TagListComponent extends React.Component {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const mapStateToProps = state => {
|
const mapStateToProps = (state) => {
|
||||||
return { theme: state.settings.theme };
|
return { theme: state.settings.theme };
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -51,7 +51,7 @@ class ToolbarComponent extends React.Component {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const mapStateToProps = state => {
|
const mapStateToProps = (state) => {
|
||||||
return { theme: state.settings.theme };
|
return { theme: state.settings.theme };
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -21,7 +21,7 @@ ipcRenderer.on('setMarkers', (event, keywords, options) => {
|
|||||||
window.postMessage({ target: 'webview', name: 'setMarkers', data: { keywords: keywords, options: options } }, '*');
|
window.postMessage({ target: 'webview', name: 'setMarkers', data: { keywords: keywords, options: options } }, '*');
|
||||||
});
|
});
|
||||||
|
|
||||||
window.addEventListener('message', event => {
|
window.addEventListener('message', (event) => {
|
||||||
// Here we only deal with messages that are sent from the webview to the main Electron process
|
// Here we only deal with messages that are sent from the webview to the main Electron process
|
||||||
if (!event.data || event.data.target !== 'main') return;
|
if (!event.data || event.data.target !== 'main') return;
|
||||||
|
|
||||||
|
@ -12,7 +12,7 @@ const { substrWithEllipsis } = require('lib/string-utils');
|
|||||||
|
|
||||||
class NoteListUtils {
|
class NoteListUtils {
|
||||||
static makeContextMenu(noteIds, props) {
|
static makeContextMenu(noteIds, props) {
|
||||||
const notes = noteIds.map(id => BaseModel.byId(props.notes, id));
|
const notes = noteIds.map((id) => BaseModel.byId(props.notes, id));
|
||||||
|
|
||||||
let hasEncrypted = false;
|
let hasEncrypted = false;
|
||||||
for (let i = 0; i < notes.length; i++) {
|
for (let i = 0; i < notes.length; i++) {
|
||||||
|
@ -81,11 +81,11 @@ shimInit();
|
|||||||
|
|
||||||
// Disable drag and drop of links inside application (which would
|
// Disable drag and drop of links inside application (which would
|
||||||
// open it as if the whole app was a browser)
|
// open it as if the whole app was a browser)
|
||||||
document.addEventListener('dragover', event => event.preventDefault());
|
document.addEventListener('dragover', (event) => event.preventDefault());
|
||||||
document.addEventListener('drop', event => event.preventDefault());
|
document.addEventListener('drop', (event) => event.preventDefault());
|
||||||
|
|
||||||
// Disable middle-click (which would open a new browser window, but we don't want this)
|
// Disable middle-click (which would open a new browser window, but we don't want this)
|
||||||
document.addEventListener('auxclick', event => event.preventDefault());
|
document.addEventListener('auxclick', (event) => event.preventDefault());
|
||||||
|
|
||||||
// Each link (rendered as a button or list item) has its own custom click event
|
// Each link (rendered as a button or list item) has its own custom click event
|
||||||
// so disable the default. In particular this will disable Ctrl+Clicking a link
|
// so disable the default. In particular this will disable Ctrl+Clicking a link
|
||||||
|
@ -208,7 +208,7 @@ class Dialog extends React.PureComponent {
|
|||||||
searchQuery = this.makeSearchQuery(this.state.query);
|
searchQuery = this.makeSearchQuery(this.state.query);
|
||||||
results = await SearchEngine.instance().search(searchQuery);
|
results = await SearchEngine.instance().search(searchQuery);
|
||||||
|
|
||||||
resultsInBody = !!results.find(row => row.fields.includes('body'));
|
resultsInBody = !!results.find((row) => row.fields.includes('body'));
|
||||||
|
|
||||||
if (!resultsInBody) {
|
if (!resultsInBody) {
|
||||||
for (let i = 0; i < results.length; i++) {
|
for (let i = 0; i < results.length; i++) {
|
||||||
@ -219,7 +219,7 @@ class Dialog extends React.PureComponent {
|
|||||||
} else {
|
} else {
|
||||||
const limit = 20;
|
const limit = 20;
|
||||||
const searchKeywords = this.keywords(searchQuery);
|
const searchKeywords = this.keywords(searchQuery);
|
||||||
const notes = await Note.byIds(results.map(result => result.id).slice(0, limit), { fields: ['id', 'body'] });
|
const notes = await Note.byIds(results.map((result) => result.id).slice(0, limit), { fields: ['id', 'body'] });
|
||||||
const notesById = notes.reduce((obj, { id, body }) => ((obj[[id]] = body), obj), {});
|
const notesById = notes.reduce((obj, { id, body }) => ((obj[[id]] = body), obj), {});
|
||||||
|
|
||||||
for (let i = 0; i < results.length; i++) {
|
for (let i = 0; i < results.length; i++) {
|
||||||
@ -247,7 +247,7 @@ class Dialog extends React.PureComponent {
|
|||||||
// e.g. 'Joplin is a free, open source' and 'open source note taking application'
|
// e.g. 'Joplin is a free, open source' and 'open source note taking application'
|
||||||
// will result in 'Joplin is a free, open source note taking application'
|
// will result in 'Joplin is a free, open source note taking application'
|
||||||
const mergedIndices = mergeOverlappingIntervals(indices, 3);
|
const mergedIndices = mergeOverlappingIntervals(indices, 3);
|
||||||
fragments = mergedIndices.map(f => body.slice(f[0], f[1])).join(' ... ');
|
fragments = mergedIndices.map((f) => body.slice(f[0], f[1])).join(' ... ');
|
||||||
// Add trailing ellipsis if the final fragment doesn't end where the note is ending
|
// Add trailing ellipsis if the final fragment doesn't end where the note is ending
|
||||||
if (mergedIndices.length && mergedIndices[mergedIndices.length - 1][1] !== body.length) fragments += ' ...';
|
if (mergedIndices.length && mergedIndices[mergedIndices.length - 1][1] !== body.length) fragments += ' ...';
|
||||||
}
|
}
|
||||||
|
@ -9,7 +9,7 @@ async function main() {
|
|||||||
await fs.mkdirp(destDir);
|
await fs.mkdirp(destDir);
|
||||||
await fs.copy(sourceDir, destDir);
|
await fs.copy(sourceDir, destDir);
|
||||||
|
|
||||||
const supportedLocales = glob.sync(`${sourceDir}/*.js`).map(s => {
|
const supportedLocales = glob.sync(`${sourceDir}/*.js`).map((s) => {
|
||||||
s = s.split('/');
|
s = s.split('/');
|
||||||
s = s[s.length - 1];
|
s = s[s.length - 1];
|
||||||
s = s.split('.');
|
s = s.split('.');
|
||||||
|
@ -110,7 +110,7 @@ export default class MarkdownEditor extends React.Component {
|
|||||||
if (this.props.onMarkdownChange) this.props.onMarkdownChange(input);
|
if (this.props.onMarkdownChange) this.props.onMarkdownChange(input);
|
||||||
};
|
};
|
||||||
|
|
||||||
onSelectionChange = event => {
|
onSelectionChange = (event) => {
|
||||||
this.setState({ selection: event.nativeEvent.selection });
|
this.setState({ selection: event.nativeEvent.selection });
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -358,7 +358,7 @@ class BaseApplication {
|
|||||||
}
|
}
|
||||||
|
|
||||||
generalMiddlewareFn() {
|
generalMiddlewareFn() {
|
||||||
const middleware = store => next => action => {
|
const middleware = (store) => (next) => (action) => {
|
||||||
return this.generalMiddleware(store, next, action);
|
return this.generalMiddleware(store, next, action);
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -690,7 +690,7 @@ class BaseApplication {
|
|||||||
if (!Setting.value('api.token')) {
|
if (!Setting.value('api.token')) {
|
||||||
EncryptionService.instance()
|
EncryptionService.instance()
|
||||||
.randomHexString(64)
|
.randomHexString(64)
|
||||||
.then(token => {
|
.then((token) => {
|
||||||
Setting.setValue('api.token', token);
|
Setting.setValue('api.token', token);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -158,7 +158,7 @@ class BaseModel {
|
|||||||
if (options.where) sql += ` WHERE ${options.where}`;
|
if (options.where) sql += ` WHERE ${options.where}`;
|
||||||
return this.db()
|
return this.db()
|
||||||
.selectOne(sql)
|
.selectOne(sql)
|
||||||
.then(r => {
|
.then((r) => {
|
||||||
return r ? r['total'] : 0;
|
return r ? r['total'] : 0;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -198,7 +198,7 @@ class BaseModel {
|
|||||||
static async allIds(options = null) {
|
static async allIds(options = null) {
|
||||||
const q = this.applySqlOptions(options, `SELECT id FROM \`${this.tableName()}\``);
|
const q = this.applySqlOptions(options, `SELECT id FROM \`${this.tableName()}\``);
|
||||||
const rows = await this.db().selectAll(q.sql, q.params);
|
const rows = await this.db().selectAll(q.sql, q.params);
|
||||||
return rows.map(r => r.id);
|
return rows.map((r) => r.id);
|
||||||
}
|
}
|
||||||
|
|
||||||
static async all(options = null) {
|
static async all(options = null) {
|
||||||
@ -253,7 +253,7 @@ class BaseModel {
|
|||||||
if (params === null) params = [];
|
if (params === null) params = [];
|
||||||
return this.db()
|
return this.db()
|
||||||
.selectOne(sql, params)
|
.selectOne(sql, params)
|
||||||
.then(model => {
|
.then((model) => {
|
||||||
return this.filter(this.addModelMd(model));
|
return this.filter(this.addModelMd(model));
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -262,7 +262,7 @@ class BaseModel {
|
|||||||
if (params === null) params = [];
|
if (params === null) params = [];
|
||||||
return this.db()
|
return this.db()
|
||||||
.selectAll(sql, params)
|
.selectAll(sql, params)
|
||||||
.then(models => {
|
.then((models) => {
|
||||||
return this.filterArray(this.addModelMd(models));
|
return this.filterArray(this.addModelMd(models));
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -189,7 +189,7 @@ class ClipperServer {
|
|||||||
if (request.method === 'POST' || request.method === 'PUT') {
|
if (request.method === 'POST' || request.method === 'PUT') {
|
||||||
let body = '';
|
let body = '';
|
||||||
|
|
||||||
request.on('data', data => {
|
request.on('data', (data) => {
|
||||||
body += data;
|
body += data;
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
const fs = require('fs-extra');
|
const fs = require('fs-extra');
|
||||||
|
|
||||||
const loadCustomCss = async filePath => {
|
const loadCustomCss = async (filePath) => {
|
||||||
let cssString = '';
|
let cssString = '';
|
||||||
if (await fs.pathExists(filePath)) {
|
if (await fs.pathExists(filePath)) {
|
||||||
try {
|
try {
|
||||||
@ -16,7 +16,7 @@ const loadCustomCss = async filePath => {
|
|||||||
return cssString;
|
return cssString;
|
||||||
};
|
};
|
||||||
|
|
||||||
const injectCustomStyles = async cssFilePath => {
|
const injectCustomStyles = async (cssFilePath) => {
|
||||||
const css = await loadCustomCss(cssFilePath);
|
const css = await loadCustomCss(cssFilePath);
|
||||||
const styleTag = document.createElement('style');
|
const styleTag = document.createElement('style');
|
||||||
styleTag.type = 'text/css';
|
styleTag.type = 'text/css';
|
||||||
|
@ -165,7 +165,7 @@ class DropboxApi {
|
|||||||
};
|
};
|
||||||
|
|
||||||
// Creates an error object with as much data as possible as it will appear in the log, which will make debugging easier
|
// Creates an error object with as much data as possible as it will appear in the log, which will make debugging easier
|
||||||
const newError = message => {
|
const newError = (message) => {
|
||||||
const json = loadResponseJson();
|
const json = loadResponseJson();
|
||||||
let code = '';
|
let code = '';
|
||||||
if (json && json.error_summary) {
|
if (json && json.error_summary) {
|
||||||
|
@ -6,7 +6,7 @@ class HtmlToMd {
|
|||||||
const turndownPluginGfm = require('joplin-turndown-plugin-gfm').gfm;
|
const turndownPluginGfm = require('joplin-turndown-plugin-gfm').gfm;
|
||||||
const turndown = new TurndownService({
|
const turndown = new TurndownService({
|
||||||
headingStyle: 'atx',
|
headingStyle: 'atx',
|
||||||
anchorNames: options.anchorNames ? options.anchorNames.map(n => n.trim().toLowerCase()) : [],
|
anchorNames: options.anchorNames ? options.anchorNames.map((n) => n.trim().toLowerCase()) : [],
|
||||||
codeBlockStyle: 'fenced',
|
codeBlockStyle: 'fenced',
|
||||||
preserveImageTagsWithSize: !!options.preserveImageTagsWithSize,
|
preserveImageTagsWithSize: !!options.preserveImageTagsWithSize,
|
||||||
bulletListMarker: '-',
|
bulletListMarker: '-',
|
||||||
|
@ -50,7 +50,7 @@ class SyncTargetDropbox extends BaseSyncTarget {
|
|||||||
secret: params.secret,
|
secret: params.secret,
|
||||||
});
|
});
|
||||||
|
|
||||||
api.on('authRefreshed', auth => {
|
api.on('authRefreshed', (auth) => {
|
||||||
this.logger().info('Saving updated Dropbox auth.');
|
this.logger().info('Saving updated Dropbox auth.');
|
||||||
Setting.setValue(`sync.${SyncTargetDropbox.id()}.auth`, auth ? auth : null);
|
Setting.setValue(`sync.${SyncTargetDropbox.id()}.auth`, auth ? auth : null);
|
||||||
});
|
});
|
||||||
|
@ -49,7 +49,7 @@ class SyncTargetOneDrive extends BaseSyncTarget {
|
|||||||
this.api_ = new OneDriveApi(this.oneDriveParameters().id, this.oneDriveParameters().secret, isPublic);
|
this.api_ = new OneDriveApi(this.oneDriveParameters().id, this.oneDriveParameters().secret, isPublic);
|
||||||
this.api_.setLogger(this.logger());
|
this.api_.setLogger(this.logger());
|
||||||
|
|
||||||
this.api_.on('authRefreshed', a => {
|
this.api_.on('authRefreshed', (a) => {
|
||||||
this.logger().info('Saving updated OneDrive auth.');
|
this.logger().info('Saving updated OneDrive auth.');
|
||||||
Setting.setValue(`sync.${this.syncTargetId()}.auth`, a ? JSON.stringify(a) : null);
|
Setting.setValue(`sync.${this.syncTargetId()}.auth`, a ? JSON.stringify(a) : null);
|
||||||
});
|
});
|
||||||
|
@ -55,10 +55,10 @@ class TaskQueue {
|
|||||||
|
|
||||||
task
|
task
|
||||||
.callback()
|
.callback()
|
||||||
.then(result => {
|
.then((result) => {
|
||||||
completeTask(task, result, null);
|
completeTask(task, result, null);
|
||||||
})
|
})
|
||||||
.catch(error => {
|
.catch((error) => {
|
||||||
if (!error) error = new Error('Unknown error');
|
if (!error) error = new Error('Unknown error');
|
||||||
completeTask(task, null, error);
|
completeTask(task, null, error);
|
||||||
});
|
});
|
||||||
@ -68,7 +68,7 @@ class TaskQueue {
|
|||||||
}
|
}
|
||||||
|
|
||||||
isWaiting(taskId) {
|
isWaiting(taskId) {
|
||||||
return this.waitingTasks_.find(task => task.id === taskId);
|
return this.waitingTasks_.find((task) => task.id === taskId);
|
||||||
}
|
}
|
||||||
|
|
||||||
isProcessing(taskId) {
|
isProcessing(taskId) {
|
||||||
|
@ -7,7 +7,7 @@ const TemplateUtils = {};
|
|||||||
|
|
||||||
// Mustache escapes strings (including /) with the html code by default
|
// Mustache escapes strings (including /) with the html code by default
|
||||||
// This isn't useful for markdown so it's disabled
|
// This isn't useful for markdown so it's disabled
|
||||||
Mustache.escape = text => {
|
Mustache.escape = (text) => {
|
||||||
return text;
|
return text;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -47,7 +47,7 @@ TemplateUtils.loadTemplates = async function(filePath) {
|
|||||||
// sensitivity ensures that the sort will ignore case
|
// sensitivity ensures that the sort will ignore case
|
||||||
files.sort((a, b) => { return a.path.localeCompare(b.path, undefined, { sensitivity: 'accent' }); });
|
files.sort((a, b) => { return a.path.localeCompare(b.path, undefined, { sensitivity: 'accent' }); });
|
||||||
|
|
||||||
files.forEach(async file => {
|
files.forEach(async (file) => {
|
||||||
if (file.path.endsWith('.md')) {
|
if (file.path.endsWith('.md')) {
|
||||||
try {
|
try {
|
||||||
const fileString = await shim.fsDriver().readFile(`${filePath}/${file.path}`, 'utf-8');
|
const fileString = await shim.fsDriver().readFile(`${filePath}/${file.path}`, 'utf-8');
|
||||||
|
@ -85,7 +85,7 @@ class WebDavApi {
|
|||||||
async xmlToJson(xml) {
|
async xmlToJson(xml) {
|
||||||
const davNamespaces = []; // Yes, there can be more than one... xmlns:a="DAV:" xmlns:D="DAV:"
|
const davNamespaces = []; // Yes, there can be more than one... xmlns:a="DAV:" xmlns:D="DAV:"
|
||||||
|
|
||||||
const nameProcessor = name => {
|
const nameProcessor = (name) => {
|
||||||
if (name.indexOf('xmlns') !== 0) {
|
if (name.indexOf('xmlns') !== 0) {
|
||||||
// Check if the current name is within the DAV namespace. If it is, normalise it
|
// Check if the current name is within the DAV namespace. If it is, normalise it
|
||||||
// by moving it to the "d:" namespace, which is what all the functions are using.
|
// by moving it to the "d:" namespace, which is what all the functions are using.
|
||||||
|
@ -170,7 +170,7 @@ class CameraView extends Component {
|
|||||||
<View style={{ position: 'absolute', backgroundColor: '#000000', width: '100%', height: '100%' }}/>
|
<View style={{ position: 'absolute', backgroundColor: '#000000', width: '100%', height: '100%' }}/>
|
||||||
<RNCamera
|
<RNCamera
|
||||||
style={Object.assign({ position: 'absolute' }, cameraRect)}
|
style={Object.assign({ position: 'absolute' }, cameraRect)}
|
||||||
ref={ref => {
|
ref={(ref) => {
|
||||||
this.camera = ref;
|
this.camera = ref;
|
||||||
}}
|
}}
|
||||||
type={this.props.cameraType}
|
type={this.props.cameraType}
|
||||||
@ -223,7 +223,7 @@ class CameraView extends Component {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const mapStateToProps = state => {
|
const mapStateToProps = (state) => {
|
||||||
return {
|
return {
|
||||||
cameraRatio: state.settings['camera.ratio'],
|
cameraRatio: state.settings['camera.ratio'],
|
||||||
cameraType: state.settings['camera.type'],
|
cameraType: state.settings['camera.type'],
|
||||||
|
@ -90,7 +90,7 @@ class Dropdown extends React.Component {
|
|||||||
this.setState({ listVisible: false });
|
this.setState({ listVisible: false });
|
||||||
};
|
};
|
||||||
|
|
||||||
const itemRenderer = item => {
|
const itemRenderer = (item) => {
|
||||||
return (
|
return (
|
||||||
<TouchableOpacity
|
<TouchableOpacity
|
||||||
style={itemWrapperStyle}
|
style={itemWrapperStyle}
|
||||||
@ -111,7 +111,7 @@ class Dropdown extends React.Component {
|
|||||||
<View style={{ flex: 1, flexDirection: 'column' }}>
|
<View style={{ flex: 1, flexDirection: 'column' }}>
|
||||||
<TouchableOpacity
|
<TouchableOpacity
|
||||||
style={headerWrapperStyle}
|
style={headerWrapperStyle}
|
||||||
ref={ref => (this.headerRef_ = ref)}
|
ref={(ref) => (this.headerRef_ = ref)}
|
||||||
disabled={this.props.disabled}
|
disabled={this.props.disabled}
|
||||||
onPress={() => {
|
onPress={() => {
|
||||||
this.updateHeaderCoordinates();
|
this.updateHeaderCoordinates();
|
||||||
@ -141,7 +141,7 @@ class Dropdown extends React.Component {
|
|||||||
style={itemListStyle}
|
style={itemListStyle}
|
||||||
items={this.props.items}
|
items={this.props.items}
|
||||||
itemHeight={itemHeight}
|
itemHeight={itemHeight}
|
||||||
itemRenderer={item => {
|
itemRenderer={(item) => {
|
||||||
return itemRenderer(item);
|
return itemRenderer(item);
|
||||||
}}
|
}}
|
||||||
/>
|
/>
|
||||||
|
@ -93,11 +93,11 @@ class ItemList extends React.Component {
|
|||||||
return (
|
return (
|
||||||
<ScrollView
|
<ScrollView
|
||||||
scrollEventThrottle={500}
|
scrollEventThrottle={500}
|
||||||
onLayout={event => {
|
onLayout={(event) => {
|
||||||
this.onLayout(event);
|
this.onLayout(event);
|
||||||
}}
|
}}
|
||||||
style={style}
|
style={style}
|
||||||
onScroll={event => {
|
onScroll={(event) => {
|
||||||
this.onScroll(event);
|
this.onScroll(event);
|
||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
|
@ -123,7 +123,7 @@ class ActionButtonComponent extends React.Component {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const ActionButton = connect(state => {
|
const ActionButton = connect((state) => {
|
||||||
return {
|
return {
|
||||||
folders: state.folders,
|
folders: state.folders,
|
||||||
locale: state.settings.locale,
|
locale: state.settings.locale,
|
||||||
|
@ -78,7 +78,7 @@ class AppNavComponent extends Component {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const AppNav = connect(state => {
|
const AppNav = connect((state) => {
|
||||||
return {
|
return {
|
||||||
route: state.route,
|
route: state.route,
|
||||||
theme: state.settings.theme,
|
theme: state.settings.theme,
|
||||||
|
@ -240,7 +240,7 @@ class NoteBodyViewer extends Component {
|
|||||||
allowFileAccess={true}
|
allowFileAccess={true}
|
||||||
onLoadEnd={() => this.onLoadEnd()}
|
onLoadEnd={() => this.onLoadEnd()}
|
||||||
onError={() => reg.logger().error('WebView error')}
|
onError={() => reg.logger().error('WebView error')}
|
||||||
onMessage={event => {
|
onMessage={(event) => {
|
||||||
// Since RN 58 (or 59) messages are now escaped twice???
|
// Since RN 58 (or 59) messages are now escaped twice???
|
||||||
let msg = unescape(unescape(event.nativeEvent.data));
|
let msg = unescape(unescape(event.nativeEvent.data));
|
||||||
|
|
||||||
|
@ -133,7 +133,7 @@ class NoteItemComponent extends Component {
|
|||||||
<View style={selectionWrapperStyle}>
|
<View style={selectionWrapperStyle}>
|
||||||
<View style={opacityStyle}>
|
<View style={opacityStyle}>
|
||||||
<View style={listItemStyle}>
|
<View style={listItemStyle}>
|
||||||
<Checkbox style={checkboxStyle} checked={checkboxChecked} onChange={checked => this.todoCheckbox_change(checked)} />
|
<Checkbox style={checkboxStyle} checked={checkboxChecked} onChange={(checked) => this.todoCheckbox_change(checked)} />
|
||||||
<Text style={listItemTextStyle}>{Note.displayTitle(note)}</Text>
|
<Text style={listItemTextStyle}>{Note.displayTitle(note)}</Text>
|
||||||
</View>
|
</View>
|
||||||
</View>
|
</View>
|
||||||
@ -143,7 +143,7 @@ class NoteItemComponent extends Component {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const NoteItem = connect(state => {
|
const NoteItem = connect((state) => {
|
||||||
return {
|
return {
|
||||||
theme: state.settings.theme,
|
theme: state.settings.theme,
|
||||||
noteSelectionEnabled: state.noteSelectionEnabled,
|
noteSelectionEnabled: state.noteSelectionEnabled,
|
||||||
|
@ -87,10 +87,10 @@ class NoteListComponent extends Component {
|
|||||||
|
|
||||||
if (this.props.items.length) {
|
if (this.props.items.length) {
|
||||||
return <FlatList
|
return <FlatList
|
||||||
ref={ref => (this.rootRef_ = ref)}
|
ref={(ref) => (this.rootRef_ = ref)}
|
||||||
data={this.props.items}
|
data={this.props.items}
|
||||||
renderItem={({ item }) => <NoteItem note={item} />}
|
renderItem={({ item }) => <NoteItem note={item} />}
|
||||||
keyExtractor={item => item.id}
|
keyExtractor={(item) => item.id}
|
||||||
/>;
|
/>;
|
||||||
} else {
|
} else {
|
||||||
if (!this.props.folders.length) {
|
if (!this.props.folders.length) {
|
||||||
@ -109,7 +109,7 @@ class NoteListComponent extends Component {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const NoteList = connect(state => {
|
const NoteList = connect((state) => {
|
||||||
return {
|
return {
|
||||||
items: state.notes,
|
items: state.notes,
|
||||||
folders: state.folders,
|
folders: state.folders,
|
||||||
|
@ -356,8 +356,8 @@ class ScreenHeaderComponent extends React.PureComponent {
|
|||||||
return pickerItems;
|
return pickerItems;
|
||||||
};
|
};
|
||||||
|
|
||||||
const titlePickerItems = mustSelect => {
|
const titlePickerItems = (mustSelect) => {
|
||||||
const folders = this.props.folders.filter(f => f.id !== Folder.conflictFolderId());
|
const folders = this.props.folders.filter((f) => f.id !== Folder.conflictFolderId());
|
||||||
let output = [];
|
let output = [];
|
||||||
if (mustSelect) output.push({ label: _('Move to notebook...'), value: null });
|
if (mustSelect) output.push({ label: _('Move to notebook...'), value: null });
|
||||||
const folderTree = Folder.buildTree(folders);
|
const folderTree = Folder.buildTree(folders);
|
||||||
@ -448,7 +448,7 @@ class ScreenHeaderComponent extends React.PureComponent {
|
|||||||
|
|
||||||
const menuComp =
|
const menuComp =
|
||||||
!menuOptionComponents.length || !showContextMenuButton ? null : (
|
!menuOptionComponents.length || !showContextMenuButton ? null : (
|
||||||
<Menu onSelect={value => this.menu_select(value)} style={this.styles().contextMenu}>
|
<Menu onSelect={(value) => this.menu_select(value)} style={this.styles().contextMenu}>
|
||||||
<MenuTrigger style={contextMenuStyle}>
|
<MenuTrigger style={contextMenuStyle}>
|
||||||
<Icon name="md-more" style={this.styles().contextMenuTrigger} />
|
<Icon name="md-more" style={this.styles().contextMenuTrigger} />
|
||||||
</MenuTrigger>
|
</MenuTrigger>
|
||||||
@ -481,7 +481,7 @@ class ScreenHeaderComponent extends React.PureComponent {
|
|||||||
</View>
|
</View>
|
||||||
{warningComps}
|
{warningComps}
|
||||||
<DialogBox
|
<DialogBox
|
||||||
ref={dialogbox => {
|
ref={(dialogbox) => {
|
||||||
this.dialogbox = dialogbox;
|
this.dialogbox = dialogbox;
|
||||||
}}
|
}}
|
||||||
/>
|
/>
|
||||||
@ -494,7 +494,7 @@ ScreenHeaderComponent.defaultProps = {
|
|||||||
menuOptions: [],
|
menuOptions: [],
|
||||||
};
|
};
|
||||||
|
|
||||||
const ScreenHeader = connect(state => {
|
const ScreenHeader = connect((state) => {
|
||||||
return {
|
return {
|
||||||
historyCanGoBack: state.historyCanGoBack,
|
historyCanGoBack: state.historyCanGoBack,
|
||||||
locale: state.settings.locale,
|
locale: state.settings.locale,
|
||||||
|
@ -23,7 +23,7 @@ class NoteTagsDialogComponent extends React.Component {
|
|||||||
savingTags: false,
|
savingTags: false,
|
||||||
};
|
};
|
||||||
|
|
||||||
const noteHasTag = tagId => {
|
const noteHasTag = (tagId) => {
|
||||||
for (let i = 0; i < this.state.tagListData.length; i++) {
|
for (let i = 0; i < this.state.tagListData.length; i++) {
|
||||||
if (this.state.tagListData[i].id === tagId) return this.state.tagListData[i].selected;
|
if (this.state.tagListData[i].id === tagId) return this.state.tagListData[i].selected;
|
||||||
}
|
}
|
||||||
@ -33,11 +33,11 @@ class NoteTagsDialogComponent extends React.Component {
|
|||||||
const newTagTitles = () => {
|
const newTagTitles = () => {
|
||||||
return this.state.newTags
|
return this.state.newTags
|
||||||
.split(',')
|
.split(',')
|
||||||
.map(t => t.trim().toLowerCase())
|
.map((t) => t.trim().toLowerCase())
|
||||||
.filter(t => !!t);
|
.filter((t) => !!t);
|
||||||
};
|
};
|
||||||
|
|
||||||
this.tag_press = tagId => {
|
this.tag_press = (tagId) => {
|
||||||
const newData = this.state.tagListData.slice();
|
const newData = this.state.tagListData.slice();
|
||||||
for (let i = 0; i < newData.length; i++) {
|
for (let i = 0; i < newData.length; i++) {
|
||||||
const t = newData[i];
|
const t = newData[i];
|
||||||
@ -52,7 +52,7 @@ class NoteTagsDialogComponent extends React.Component {
|
|||||||
this.setState({ tagListData: newData });
|
this.setState({ tagListData: newData });
|
||||||
};
|
};
|
||||||
|
|
||||||
this.renderTag = data => {
|
this.renderTag = (data) => {
|
||||||
const tag = data.item;
|
const tag = data.item;
|
||||||
const iconName = noteHasTag(tag.id) ? 'md-checkbox-outline' : 'md-square-outline';
|
const iconName = noteHasTag(tag.id) ? 'md-checkbox-outline' : 'md-square-outline';
|
||||||
return (
|
return (
|
||||||
@ -71,7 +71,7 @@ class NoteTagsDialogComponent extends React.Component {
|
|||||||
this.setState({ savingTags: true });
|
this.setState({ savingTags: true });
|
||||||
|
|
||||||
try {
|
try {
|
||||||
const tagIds = this.state.tagListData.filter(t => t.selected).map(t => t.id);
|
const tagIds = this.state.tagListData.filter((t) => t.selected).map((t) => t.id);
|
||||||
await Tag.setNoteTagsByIds(this.state.noteId, tagIds);
|
await Tag.setNoteTagsByIds(this.state.noteId, tagIds);
|
||||||
|
|
||||||
const extraTitles = newTagTitles();
|
const extraTitles = newTagTitles();
|
||||||
@ -98,9 +98,9 @@ class NoteTagsDialogComponent extends React.Component {
|
|||||||
|
|
||||||
async loadNoteTags(noteId) {
|
async loadNoteTags(noteId) {
|
||||||
const tags = await Tag.tagsByNoteId(noteId);
|
const tags = await Tag.tagsByNoteId(noteId);
|
||||||
const tagIds = tags.map(t => t.id);
|
const tagIds = tags.map((t) => t.id);
|
||||||
|
|
||||||
const tagListData = this.props.tags.map(tag => {
|
const tagListData = this.props.tags.map((tag) => {
|
||||||
return {
|
return {
|
||||||
id: tag.id,
|
id: tag.id,
|
||||||
title: tag.title,
|
title: tag.title,
|
||||||
@ -165,7 +165,7 @@ class NoteTagsDialogComponent extends React.Component {
|
|||||||
selectionColor={theme.textSelectionColor}
|
selectionColor={theme.textSelectionColor}
|
||||||
keyboardAppearance={theme.keyboardAppearance}
|
keyboardAppearance={theme.keyboardAppearance}
|
||||||
value={this.state.newTags}
|
value={this.state.newTags}
|
||||||
onChangeText={value => {
|
onChangeText={(value) => {
|
||||||
this.setState({ newTags: value });
|
this.setState({ newTags: value });
|
||||||
}}
|
}}
|
||||||
style={this.styles().newTagBoxInput}
|
style={this.styles().newTagBoxInput}
|
||||||
@ -179,7 +179,7 @@ class NoteTagsDialogComponent extends React.Component {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const NoteTagsDialog = connect(state => {
|
const NoteTagsDialog = connect((state) => {
|
||||||
return {
|
return {
|
||||||
theme: state.settings.theme,
|
theme: state.settings.theme,
|
||||||
tags: state.tags,
|
tags: state.tags,
|
||||||
|
@ -392,7 +392,7 @@ class ConfigScreenComponent extends BaseScreenComponent {
|
|||||||
<Text key="label" style={this.styles().switchSettingText}>
|
<Text key="label" style={this.styles().switchSettingText}>
|
||||||
{md.label()}
|
{md.label()}
|
||||||
</Text>
|
</Text>
|
||||||
<Switch key="control" style={this.styles().switchSettingControl} trackColor={{ false: theme.strongDividerColor }} value={value} onValueChange={value => updateSettingValue(key, value)} />
|
<Switch key="control" style={this.styles().switchSettingControl} trackColor={{ false: theme.strongDividerColor }} value={value} onValueChange={(value) => updateSettingValue(key, value)} />
|
||||||
</View>
|
</View>
|
||||||
{descriptionComp}
|
{descriptionComp}
|
||||||
</View>
|
</View>
|
||||||
@ -410,7 +410,7 @@ class ConfigScreenComponent extends BaseScreenComponent {
|
|||||||
</Text>
|
</Text>
|
||||||
<View style={{ display: 'flex', flexDirection: 'row', alignItems: 'center', flex: 1 }}>
|
<View style={{ display: 'flex', flexDirection: 'row', alignItems: 'center', flex: 1 }}>
|
||||||
<Text style={this.styles().sliderUnits}>{unitLabel}</Text>
|
<Text style={this.styles().sliderUnits}>{unitLabel}</Text>
|
||||||
<Slider key="control" style={{ flex: 1 }} step={md.step} minimumValue={md.minimum} maximumValue={md.maximum} value={value} onValueChange={value => updateSettingValue(key, value)} />
|
<Slider key="control" style={{ flex: 1 }} step={md.step} minimumValue={md.minimum} maximumValue={md.maximum} value={value} onValueChange={(value) => updateSettingValue(key, value)} />
|
||||||
</View>
|
</View>
|
||||||
</View>
|
</View>
|
||||||
);
|
);
|
||||||
@ -420,7 +420,7 @@ class ConfigScreenComponent extends BaseScreenComponent {
|
|||||||
<Text key="label" style={this.styles().settingText}>
|
<Text key="label" style={this.styles().settingText}>
|
||||||
{md.label()}
|
{md.label()}
|
||||||
</Text>
|
</Text>
|
||||||
<TextInput autoCorrect={false} autoCompleteType="off" selectionColor={theme.textSelectionColor} keyboardAppearance={theme.keyboardAppearance} autoCapitalize="none" key="control" style={this.styles().settingControl} value={value} onChangeText={value => updateSettingValue(key, value)} secureTextEntry={!!md.secure} />
|
<TextInput autoCorrect={false} autoCompleteType="off" selectionColor={theme.textSelectionColor} keyboardAppearance={theme.keyboardAppearance} autoCapitalize="none" key="control" style={this.styles().settingControl} value={value} onChangeText={(value) => updateSettingValue(key, value)} secureTextEntry={!!md.secure} />
|
||||||
</View>
|
</View>
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
@ -557,7 +557,7 @@ class ConfigScreenComponent extends BaseScreenComponent {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const ConfigScreen = connect(state => {
|
const ConfigScreen = connect((state) => {
|
||||||
return {
|
return {
|
||||||
settings: state.settings,
|
settings: state.settings,
|
||||||
theme: state.settings.theme,
|
theme: state.settings.theme,
|
||||||
|
@ -16,7 +16,7 @@ class DropboxLoginScreenComponent extends BaseScreenComponent {
|
|||||||
|
|
||||||
this.styles_ = {};
|
this.styles_ = {};
|
||||||
|
|
||||||
this.shared_ = new Shared(this, msg => dialogs.info(this, msg), msg => dialogs.error(this, msg));
|
this.shared_ = new Shared(this, (msg) => dialogs.info(this, msg), (msg) => dialogs.error(this, msg));
|
||||||
}
|
}
|
||||||
|
|
||||||
UNSAFE_componentWillMount() {
|
UNSAFE_componentWillMount() {
|
||||||
@ -68,7 +68,7 @@ class DropboxLoginScreenComponent extends BaseScreenComponent {
|
|||||||
</ScrollView>
|
</ScrollView>
|
||||||
|
|
||||||
<DialogBox
|
<DialogBox
|
||||||
ref={dialogbox => {
|
ref={(dialogbox) => {
|
||||||
this.dialogbox = dialogbox;
|
this.dialogbox = dialogbox;
|
||||||
}}
|
}}
|
||||||
/>
|
/>
|
||||||
@ -77,7 +77,7 @@ class DropboxLoginScreenComponent extends BaseScreenComponent {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const DropboxLoginScreen = connect(state => {
|
const DropboxLoginScreen = connect((state) => {
|
||||||
return {
|
return {
|
||||||
theme: state.settings.theme,
|
theme: state.settings.theme,
|
||||||
};
|
};
|
||||||
|
@ -103,7 +103,7 @@ class EncryptionConfigScreenComponent extends BaseScreenComponent {
|
|||||||
return shared.onSavePasswordClick(this, mk);
|
return shared.onSavePasswordClick(this, mk);
|
||||||
};
|
};
|
||||||
|
|
||||||
const onPasswordChange = text => {
|
const onPasswordChange = (text) => {
|
||||||
return shared.onPasswordChange(this, mk, text);
|
return shared.onPasswordChange(this, mk, text);
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -120,7 +120,7 @@ class EncryptionConfigScreenComponent extends BaseScreenComponent {
|
|||||||
<Text style={this.styles().normalText}>{_('Created: %s', time.formatMsToLocal(mk.created_time))}</Text>
|
<Text style={this.styles().normalText}>{_('Created: %s', time.formatMsToLocal(mk.created_time))}</Text>
|
||||||
<View style={{ flexDirection: 'row', alignItems: 'center' }}>
|
<View style={{ flexDirection: 'row', alignItems: 'center' }}>
|
||||||
<Text style={{ flex: 0, fontSize: theme.fontSize, marginRight: 10, color: theme.color }}>{_('Password:')}</Text>
|
<Text style={{ flex: 0, fontSize: theme.fontSize, marginRight: 10, color: theme.color }}>{_('Password:')}</Text>
|
||||||
<TextInput selectionColor={theme.textSelectionColor} keyboardAppearance={theme.keyboardAppearance} secureTextEntry={true} value={password} onChangeText={text => onPasswordChange(text)} style={inputStyle}></TextInput>
|
<TextInput selectionColor={theme.textSelectionColor} keyboardAppearance={theme.keyboardAppearance} secureTextEntry={true} value={password} onChangeText={(text) => onPasswordChange(text)} style={inputStyle}></TextInput>
|
||||||
<Text style={{ fontSize: theme.fontSize, marginRight: 10, color: theme.color }}>{passwordOk}</Text>
|
<Text style={{ fontSize: theme.fontSize, marginRight: 10, color: theme.color }}>{passwordOk}</Text>
|
||||||
<Button title={_('Save')} onPress={() => onSaveClick()}></Button>
|
<Button title={_('Save')} onPress={() => onSaveClick()}></Button>
|
||||||
</View>
|
</View>
|
||||||
@ -155,7 +155,7 @@ class EncryptionConfigScreenComponent extends BaseScreenComponent {
|
|||||||
style={this.styles().normalTextInput}
|
style={this.styles().normalTextInput}
|
||||||
secureTextEntry={true}
|
secureTextEntry={true}
|
||||||
value={this.state.passwordPromptAnswer}
|
value={this.state.passwordPromptAnswer}
|
||||||
onChangeText={text => {
|
onChangeText={(text) => {
|
||||||
this.setState({ passwordPromptAnswer: text });
|
this.setState({ passwordPromptAnswer: text });
|
||||||
}}
|
}}
|
||||||
></TextInput>
|
></TextInput>
|
||||||
@ -167,7 +167,7 @@ class EncryptionConfigScreenComponent extends BaseScreenComponent {
|
|||||||
style={this.styles().normalTextInput}
|
style={this.styles().normalTextInput}
|
||||||
secureTextEntry={true}
|
secureTextEntry={true}
|
||||||
value={this.state.passwordPromptConfirmAnswer}
|
value={this.state.passwordPromptConfirmAnswer}
|
||||||
onChangeText={text => {
|
onChangeText={(text) => {
|
||||||
this.setState({ passwordPromptConfirmAnswer: text });
|
this.setState({ passwordPromptConfirmAnswer: text });
|
||||||
}}
|
}}
|
||||||
></TextInput>
|
></TextInput>
|
||||||
@ -286,7 +286,7 @@ class EncryptionConfigScreenComponent extends BaseScreenComponent {
|
|||||||
<View style={{ flex: 1, height: 20 }}></View>
|
<View style={{ flex: 1, height: 20 }}></View>
|
||||||
</ScrollView>
|
</ScrollView>
|
||||||
<DialogBox
|
<DialogBox
|
||||||
ref={dialogbox => {
|
ref={(dialogbox) => {
|
||||||
this.dialogbox = dialogbox;
|
this.dialogbox = dialogbox;
|
||||||
}}
|
}}
|
||||||
/>
|
/>
|
||||||
@ -295,7 +295,7 @@ class EncryptionConfigScreenComponent extends BaseScreenComponent {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const EncryptionConfigScreen = connect(state => {
|
const EncryptionConfigScreen = connect((state) => {
|
||||||
return {
|
return {
|
||||||
theme: state.settings.theme,
|
theme: state.settings.theme,
|
||||||
masterKeys: state.masterKeys,
|
masterKeys: state.masterKeys,
|
||||||
|
@ -50,7 +50,7 @@ class FolderScreenComponent extends BaseScreenComponent {
|
|||||||
lastSavedFolder: Object.assign({}, folder),
|
lastSavedFolder: Object.assign({}, folder),
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
Folder.load(this.props.folderId).then(folder => {
|
Folder.load(this.props.folderId).then((folder) => {
|
||||||
this.setState({
|
this.setState({
|
||||||
folder: folder,
|
folder: folder,
|
||||||
lastSavedFolder: Object.assign({}, folder),
|
lastSavedFolder: Object.assign({}, folder),
|
||||||
@ -107,9 +107,9 @@ class FolderScreenComponent extends BaseScreenComponent {
|
|||||||
return (
|
return (
|
||||||
<View style={this.rootStyle(this.props.theme).root}>
|
<View style={this.rootStyle(this.props.theme).root}>
|
||||||
<ScreenHeader title={_('Edit notebook')} showSaveButton={true} saveButtonDisabled={saveButtonDisabled} onSaveButtonPress={() => this.saveFolderButton_press()} showSideMenuButton={false} showSearchButton={false} />
|
<ScreenHeader title={_('Edit notebook')} showSaveButton={true} saveButtonDisabled={saveButtonDisabled} onSaveButtonPress={() => this.saveFolderButton_press()} showSideMenuButton={false} showSearchButton={false} />
|
||||||
<TextInput placeholder={_('Enter notebook title')} placeholderTextColor={theme.colorFaded} underlineColorAndroid={theme.strongDividerColor} selectionColor={theme.textSelectionColor} keyboardAppearance={theme.keyboardAppearance} style={this.styles().textInput} autoFocus={true} value={this.state.folder.title} onChangeText={text => this.title_changeText(text)} />
|
<TextInput placeholder={_('Enter notebook title')} placeholderTextColor={theme.colorFaded} underlineColorAndroid={theme.strongDividerColor} selectionColor={theme.textSelectionColor} keyboardAppearance={theme.keyboardAppearance} style={this.styles().textInput} autoFocus={true} value={this.state.folder.title} onChangeText={(text) => this.title_changeText(text)} />
|
||||||
<dialogs.DialogBox
|
<dialogs.DialogBox
|
||||||
ref={dialogbox => {
|
ref={(dialogbox) => {
|
||||||
this.dialogbox = dialogbox;
|
this.dialogbox = dialogbox;
|
||||||
}}
|
}}
|
||||||
/>
|
/>
|
||||||
@ -118,7 +118,7 @@ class FolderScreenComponent extends BaseScreenComponent {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const FolderScreen = connect(state => {
|
const FolderScreen = connect((state) => {
|
||||||
return {
|
return {
|
||||||
folderId: state.selectedFolderId,
|
folderId: state.selectedFolderId,
|
||||||
theme: state.settings.theme,
|
theme: state.settings.theme,
|
||||||
|
@ -101,7 +101,7 @@ class LogScreenComponent extends BaseScreenComponent {
|
|||||||
<FlatList
|
<FlatList
|
||||||
data={this.state.logEntries}
|
data={this.state.logEntries}
|
||||||
renderItem={renderRow}
|
renderItem={renderRow}
|
||||||
keyExtractor={item => { return `${item.id}`; }}
|
keyExtractor={(item) => { return `${item.id}`; }}
|
||||||
/>
|
/>
|
||||||
<View style={{ flexDirection: 'row' }}>
|
<View style={{ flexDirection: 'row' }}>
|
||||||
<View style={{ flex: 1, marginRight: 5 }}>
|
<View style={{ flex: 1, marginRight: 5 }}>
|
||||||
@ -126,7 +126,7 @@ class LogScreenComponent extends BaseScreenComponent {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const LogScreen = connect(state => {
|
const LogScreen = connect((state) => {
|
||||||
return {
|
return {
|
||||||
theme: state.settings.theme,
|
theme: state.settings.theme,
|
||||||
};
|
};
|
||||||
|
@ -128,7 +128,7 @@ class NoteScreenComponent extends BaseScreenComponent {
|
|||||||
this.setState({ noteTagDialogShown: false });
|
this.setState({ noteTagDialogShown: false });
|
||||||
};
|
};
|
||||||
|
|
||||||
this.onJoplinLinkClick_ = async msg => {
|
this.onJoplinLinkClick_ = async (msg) => {
|
||||||
try {
|
try {
|
||||||
if (msg.indexOf('joplin://') === 0) {
|
if (msg.indexOf('joplin://') === 0) {
|
||||||
const resourceUrlInfo = urlUtils.parseResourceUrl(msg);
|
const resourceUrlInfo = urlUtils.parseResourceUrl(msg);
|
||||||
@ -407,7 +407,7 @@ class NoteScreenComponent extends BaseScreenComponent {
|
|||||||
(width, height) => {
|
(width, height) => {
|
||||||
resolve({ width: width, height: height });
|
resolve({ width: width, height: height });
|
||||||
},
|
},
|
||||||
error => {
|
(error) => {
|
||||||
reject(error);
|
reject(error);
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
@ -416,7 +416,7 @@ class NoteScreenComponent extends BaseScreenComponent {
|
|||||||
|
|
||||||
showImagePicker(options) {
|
showImagePicker(options) {
|
||||||
return new Promise((resolve) => {
|
return new Promise((resolve) => {
|
||||||
ImagePicker.launchImageLibrary(options, response => {
|
ImagePicker.launchImageLibrary(options, (response) => {
|
||||||
resolve(response);
|
resolve(response);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
@ -871,7 +871,7 @@ class NoteScreenComponent extends BaseScreenComponent {
|
|||||||
|
|
||||||
let bodyComponent = null;
|
let bodyComponent = null;
|
||||||
if (this.state.mode == 'view' && !Setting.value('editor.beta')) {
|
if (this.state.mode == 'view' && !Setting.value('editor.beta')) {
|
||||||
const onCheckboxChange = newBody => {
|
const onCheckboxChange = (newBody) => {
|
||||||
this.saveOneProperty('body', newBody);
|
this.saveOneProperty('body', newBody);
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -899,7 +899,7 @@ class NoteScreenComponent extends BaseScreenComponent {
|
|||||||
highlightedKeywords={keywords}
|
highlightedKeywords={keywords}
|
||||||
theme={this.props.theme}
|
theme={this.props.theme}
|
||||||
noteHash={this.props.noteHash}
|
noteHash={this.props.noteHash}
|
||||||
onCheckboxChange={newBody => {
|
onCheckboxChange={(newBody) => {
|
||||||
onCheckboxChange(newBody);
|
onCheckboxChange(newBody);
|
||||||
}}
|
}}
|
||||||
onMarkForDownload={this.onMarkForDownload}
|
onMarkForDownload={this.onMarkForDownload}
|
||||||
@ -923,7 +923,7 @@ class NoteScreenComponent extends BaseScreenComponent {
|
|||||||
keywords = SearchEngine.instance().allParsedQueryTerms(parsedQuery);
|
keywords = SearchEngine.instance().allParsedQueryTerms(parsedQuery);
|
||||||
}
|
}
|
||||||
|
|
||||||
const onCheckboxChange = newBody => {
|
const onCheckboxChange = (newBody) => {
|
||||||
this.saveOneProperty('body', newBody);
|
this.saveOneProperty('body', newBody);
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -938,7 +938,7 @@ class NoteScreenComponent extends BaseScreenComponent {
|
|||||||
value={note.body}
|
value={note.body}
|
||||||
borderColor={this.styles().markdownButtons.borderColor}
|
borderColor={this.styles().markdownButtons.borderColor}
|
||||||
markdownButtonsColor={this.styles().markdownButtons.color}
|
markdownButtonsColor={this.styles().markdownButtons.color}
|
||||||
saveText={text => this.body_changeText(text)}
|
saveText={(text) => this.body_changeText(text)}
|
||||||
blurOnSubmit={false}
|
blurOnSubmit={false}
|
||||||
selectionColor={theme.textSelectionColor}
|
selectionColor={theme.textSelectionColor}
|
||||||
keyboardAppearance={theme.keyboardAppearance}
|
keyboardAppearance={theme.keyboardAppearance}
|
||||||
@ -957,7 +957,7 @@ class NoteScreenComponent extends BaseScreenComponent {
|
|||||||
highlightedKeywords: keywords,
|
highlightedKeywords: keywords,
|
||||||
theme: this.props.theme,
|
theme: this.props.theme,
|
||||||
noteHash: this.props.noteHash,
|
noteHash: this.props.noteHash,
|
||||||
onCheckboxChange: newBody => {
|
onCheckboxChange: (newBody) => {
|
||||||
onCheckboxChange(newBody);
|
onCheckboxChange(newBody);
|
||||||
},
|
},
|
||||||
onMarkForDownload: this.onMarkForDownload,
|
onMarkForDownload: this.onMarkForDownload,
|
||||||
@ -979,7 +979,7 @@ class NoteScreenComponent extends BaseScreenComponent {
|
|||||||
// a plain TextInput for now.
|
// a plain TextInput for now.
|
||||||
// See https://github.com/laurent22/joplin/issues/3041
|
// See https://github.com/laurent22/joplin/issues/3041
|
||||||
(
|
(
|
||||||
<TextInput autoCapitalize="sentences" style={this.styles().bodyTextInput} ref="noteBodyTextField" multiline={true} value={note.body} onChangeText={text => this.body_changeText(text)} blurOnSubmit={false} selectionColor={theme.textSelectionColor} keyboardAppearance={theme.keyboardAppearance} placeholder={_('Add body')} placeholderTextColor={theme.colorFaded} />
|
<TextInput autoCapitalize="sentences" style={this.styles().bodyTextInput} ref="noteBodyTextField" multiline={true} value={note.body} onChangeText={(text) => this.body_changeText(text)} blurOnSubmit={false} selectionColor={theme.textSelectionColor} keyboardAppearance={theme.keyboardAppearance} placeholder={_('Add body')} placeholderTextColor={theme.colorFaded} />
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1031,7 +1031,7 @@ class NoteScreenComponent extends BaseScreenComponent {
|
|||||||
<SelectDateTimeDialog shown={this.state.alarmDialogShown} date={dueDate} onAccept={this.onAlarmDialogAccept} onReject={this.onAlarmDialogReject} />
|
<SelectDateTimeDialog shown={this.state.alarmDialogShown} date={dueDate} onAccept={this.onAlarmDialogAccept} onReject={this.onAlarmDialogReject} />
|
||||||
|
|
||||||
<DialogBox
|
<DialogBox
|
||||||
ref={dialogbox => {
|
ref={(dialogbox) => {
|
||||||
this.dialogbox = dialogbox;
|
this.dialogbox = dialogbox;
|
||||||
}}
|
}}
|
||||||
/>
|
/>
|
||||||
@ -1041,7 +1041,7 @@ class NoteScreenComponent extends BaseScreenComponent {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const NoteScreen = connect(state => {
|
const NoteScreen = connect((state) => {
|
||||||
return {
|
return {
|
||||||
noteId: state.selectedNoteIds.length ? state.selectedNoteIds[0] : null,
|
noteId: state.selectedNoteIds.length ? state.selectedNoteIds[0] : null,
|
||||||
noteHash: state.selectedNoteHash,
|
noteHash: state.selectedNoteHash,
|
||||||
|
@ -151,7 +151,7 @@ class NotesScreenComponent extends BaseScreenComponent {
|
|||||||
}
|
}
|
||||||
|
|
||||||
deleteFolder_onPress(folderId) {
|
deleteFolder_onPress(folderId) {
|
||||||
dialogs.confirm(this, _('Delete notebook? All notes and sub-notebooks within this notebook will also be deleted.')).then(ok => {
|
dialogs.confirm(this, _('Delete notebook? All notes and sub-notebooks within this notebook will also be deleted.')).then((ok) => {
|
||||||
if (!ok) return;
|
if (!ok) return;
|
||||||
|
|
||||||
Folder.delete(folderId)
|
Folder.delete(folderId)
|
||||||
@ -162,7 +162,7 @@ class NotesScreenComponent extends BaseScreenComponent {
|
|||||||
smartFilterId: 'c3176726992c11e9ac940492261af972',
|
smartFilterId: 'c3176726992c11e9ac940492261af972',
|
||||||
});
|
});
|
||||||
})
|
})
|
||||||
.catch(error => {
|
.catch((error) => {
|
||||||
alert(error.message);
|
alert(error.message);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
@ -237,7 +237,7 @@ class NotesScreenComponent extends BaseScreenComponent {
|
|||||||
<NoteList style={this.styles().noteList} />
|
<NoteList style={this.styles().noteList} />
|
||||||
{actionButtonComp}
|
{actionButtonComp}
|
||||||
<DialogBox
|
<DialogBox
|
||||||
ref={dialogbox => {
|
ref={(dialogbox) => {
|
||||||
this.dialogbox = dialogbox;
|
this.dialogbox = dialogbox;
|
||||||
}}
|
}}
|
||||||
/>
|
/>
|
||||||
@ -246,7 +246,7 @@ class NotesScreenComponent extends BaseScreenComponent {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const NotesScreen = connect(state => {
|
const NotesScreen = connect((state) => {
|
||||||
return {
|
return {
|
||||||
folders: state.folders,
|
folders: state.folders,
|
||||||
tags: state.tags,
|
tags: state.tags,
|
||||||
|
@ -98,7 +98,7 @@ class OneDriveLoginScreenComponent extends BaseScreenComponent {
|
|||||||
<ScreenHeader title={_('Login with OneDrive')} />
|
<ScreenHeader title={_('Login with OneDrive')} />
|
||||||
<WebView
|
<WebView
|
||||||
source={source}
|
source={source}
|
||||||
onNavigationStateChange={o => {
|
onNavigationStateChange={(o) => {
|
||||||
this.webview_load(o);
|
this.webview_load(o);
|
||||||
}}
|
}}
|
||||||
onError={() => {
|
onError={() => {
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user