2021-01-20 21:45:30 +01:00
|
|
|
import SpacedUpdate from "../../services/spaced_update.js";
|
2021-01-25 21:24:02 +01:00
|
|
|
import AbstractSearchAction from "./abstract_search_action.js";
|
2021-01-20 21:45:30 +01:00
|
|
|
|
|
|
|
const TPL = `
|
|
|
|
<tr>
|
|
|
|
<td>
|
|
|
|
Execute script:
|
|
|
|
</td>
|
|
|
|
<td>
|
2021-01-26 14:10:34 +01:00
|
|
|
<input type="text"
|
|
|
|
class="form-control script"
|
|
|
|
placeholder="note.title = note.title + '- suffix';"/>
|
2021-01-20 21:45:30 +01:00
|
|
|
</td>
|
2021-01-26 14:10:34 +01:00
|
|
|
<td class="button-column">
|
2021-01-26 10:48:28 +01:00
|
|
|
<span class="bx bx-x icon-action action-conf-del"></span>
|
2021-01-20 21:45:30 +01:00
|
|
|
</td>
|
|
|
|
</tr>`;
|
|
|
|
|
2021-01-25 21:24:02 +01:00
|
|
|
export default class ExecuteScriptSearchAction extends AbstractSearchAction {
|
2021-01-20 21:45:30 +01:00
|
|
|
static get actionName() { return "executeScript"; }
|
|
|
|
|
|
|
|
doRender() {
|
|
|
|
const $action = $(TPL);
|
|
|
|
const $script = $action.find('.script');
|
|
|
|
$script.val(this.actionDef.script || "");
|
|
|
|
|
|
|
|
const spacedUpdate = new SpacedUpdate(async () => {
|
|
|
|
await this.saveAction({ script: $script.val() });
|
|
|
|
}, 1000)
|
|
|
|
|
|
|
|
$script.on('input', () => spacedUpdate.scheduleUpdate());
|
|
|
|
|
|
|
|
return $action;
|
|
|
|
}
|
|
|
|
}
|