Notes/src/public/app/dialogs/options/code_notes.js

48 lines
1.4 KiB
JavaScript
Raw Normal View History

import mimeTypesService from "../../services/mime_types.js";
import options from "../../services/options.js";
const TPL = `
<h4>Available MIME types in the dropdown</h4>
<ul id="options-mime-types" style="max-height: 500px; overflow: auto; list-style-type: none;"></ul>`;
export default class CodeNotesOptions {
constructor() {
$("#options-code-notes").html(TPL);
this.$mimeTypes = $("#options-mime-types");
}
async optionsLoaded() {
this.$mimeTypes.empty();
let idCtr = 1;
for (const mimeType of await mimeTypesService.getMimeTypes()) {
const id = "code-mime-type-" + (idCtr++);
this.$mimeTypes.append($("<li>")
.append($('<input type="checkbox">')
.attr("id", id)
.attr("data-mime-type", mimeType.mime)
.prop("checked", mimeType.enabled))
2019-11-09 17:39:48 +01:00
.on('change', () => this.save())
.append(" &nbsp; ")
.append($('<label>')
.attr("for", id)
.text(mimeType.title))
);
}
}
async save() {
const enabledMimeTypes = [];
this.$mimeTypes.find("input:checked").each(
(i, el) => enabledMimeTypes.push($(el).attr("data-mime-type")));
await options.save('codeNotesMimeTypes', JSON.stringify(enabledMimeTypes));
mimeTypesService.loadMimeTypes();
}
}