2019-11-11 22:04:45 +00:00
|
|
|
from lib.snabbdom import h
|
|
|
|
import message
|
2019-11-16 13:41:29 +00:00
|
|
|
from view.modal_templates import *
|
2020-01-28 22:05:48 +00:00
|
|
|
from view.utils import show_toggle_cluster_buttons
|
2020-03-12 21:43:51 +00:00
|
|
|
import model
|
2019-11-11 22:04:45 +00:00
|
|
|
|
|
|
|
|
2020-03-12 21:43:51 +00:00
|
|
|
def edit_translation(translation, parent, cluster_idx, num_clusters, cls):
|
2020-01-26 12:35:00 +00:00
|
|
|
def split_line2(left, right):
|
|
|
|
return h("div.flex.two", {}, [
|
2019-11-11 22:04:45 +00:00
|
|
|
h("span.third.span-left-of-input", {}, left), h("span.two-third", {}, right)])
|
|
|
|
|
2020-03-12 21:43:51 +00:00
|
|
|
content = []
|
|
|
|
if type(parent) is model.Example:
|
|
|
|
content.extend([
|
|
|
|
h("span.translation-original-title", {}, "Primer: "),
|
|
|
|
h("span.translation-original", {}, parent.simple_view()),
|
|
|
|
h("hr", {}, None)])
|
|
|
|
|
2019-11-11 22:04:45 +00:00
|
|
|
# first line: transalation itself
|
2020-03-12 21:43:51 +00:00
|
|
|
content.extend([
|
|
|
|
split_line2("Prevedek:",
|
2020-03-19 20:29:19 +00:00
|
|
|
h("textarea#etv", {"props": {"value": translation.translation}}, "")),
|
2020-03-12 21:43:51 +00:00
|
|
|
split_line2("Razlaga:",
|
2020-03-20 17:34:19 +00:00
|
|
|
h("textarea#ete", {"props": {"value": translation.explanation}}, ""))])
|
2020-01-23 21:51:15 +00:00
|
|
|
|
2019-11-11 22:04:45 +00:00
|
|
|
# cluster number
|
|
|
|
options = [h("option", {"props": {"selected": idx == cluster_idx}}, str(idx + 1)) for idx in range(num_clusters + 1)]
|
2020-01-26 12:35:00 +00:00
|
|
|
content.append(split_line2("Stevilka gruce:", h("select#cluster-num", {}, options)))
|
2019-11-11 22:04:45 +00:00
|
|
|
|
|
|
|
content.append(h("h4", {}, "Tags"))
|
2020-02-16 22:17:46 +00:00
|
|
|
content.extend(label_list_editor(translation.copy().tags, [message.AddToLabelList, translation.copy().tags]))
|
2019-11-11 22:04:45 +00:00
|
|
|
|
2019-11-17 20:19:01 +00:00
|
|
|
return modal_template(content, "Translation", cls)
|
2019-11-11 22:04:45 +00:00
|
|
|
|
2019-11-11 23:34:52 +00:00
|
|
|
|
2019-11-11 22:04:45 +00:00
|
|
|
def edit_sense_label(sense):
|
2020-02-16 22:17:46 +00:00
|
|
|
content = label_list_editor(sense.copy().labels, [message.AddToLabelList, sense.copy().labels])
|
|
|
|
return modal_template(content, "Translation", (message.EditSenseLabel, sense))
|
2019-11-11 23:34:52 +00:00
|
|
|
|
2019-11-11 22:04:45 +00:00
|
|
|
|
2020-01-28 22:06:16 +00:00
|
|
|
def edit_example(example, sense):
|
2020-01-25 20:33:22 +00:00
|
|
|
example_original = example
|
|
|
|
example = example_original.copy()
|
|
|
|
|
|
|
|
def role_msg(idx, role):
|
2020-02-16 22:17:46 +00:00
|
|
|
return message.msg(message.ExampleRoleChange, example_original, idx, role)
|
2020-01-25 20:33:22 +00:00
|
|
|
|
|
|
|
divs = []
|
2020-06-11 16:47:09 +00:00
|
|
|
def list_of_right_buttons(idx, component):
|
|
|
|
result = [
|
|
|
|
h("span.example-component-button.example-component-headword",
|
|
|
|
{"on": {"click": role_msg(idx, "headword")}}, "H"),
|
|
|
|
h("span.example-component-button.example-component-collocate",
|
|
|
|
{"on": {"click": role_msg(idx, "collocate")}}, "C"),
|
|
|
|
h("span.example-component-button.example-component-other",
|
2020-06-11 17:52:57 +00:00
|
|
|
{"on": {"click": role_msg(idx, "other")}}, "O")]
|
|
|
|
|
2020-06-11 16:47:09 +00:00
|
|
|
if example.is_multiword():
|
|
|
|
additional_class = ".example-component-no-space" if component.no_space else ""
|
2020-06-11 17:52:57 +00:00
|
|
|
click_message = message.msg(message.ExampleComponentSpace, example_original, idx)
|
2020-06-11 16:47:09 +00:00
|
|
|
result.append(h("span.example-component-button" + additional_class,
|
2020-06-11 17:52:57 +00:00
|
|
|
{"on": {"click": click_message }}, "␣"))
|
|
|
|
else:
|
|
|
|
result.append(h("span.example-component-button.example-component-none",
|
|
|
|
{"on": {"click": role_msg(idx, "none")}}, "N"))
|
2020-06-11 16:47:09 +00:00
|
|
|
|
|
|
|
result.extend([
|
|
|
|
h("span.example-component-button",
|
|
|
|
{"on": {"click": message.msg(message.ExampleComponentAdd, example_original, idx)}}, "+"),
|
|
|
|
h("span.example-component-button",
|
|
|
|
{"on": {"click": message.msg(message.ExampleComponentRemove, example_original, idx)}}, "-")])
|
|
|
|
|
|
|
|
return result
|
2020-01-25 20:33:22 +00:00
|
|
|
|
|
|
|
for idx, component in enumerate(example.components):
|
|
|
|
role_txt = component.role if component.role is not None else "none"
|
|
|
|
color_class = ".example-component-" + role_txt
|
|
|
|
|
|
|
|
left = [h("span" + color_class, {}, role_txt)]
|
2020-03-19 20:33:53 +00:00
|
|
|
|
|
|
|
if component.role is None:
|
|
|
|
middle = [h("textarea.example-component-text", {"props": {"value": component.text}}, "")]
|
|
|
|
else:
|
|
|
|
middle = [h("input.example-component-text", {"props": {"type": "text", "value": component.text}}, "")]
|
2020-01-25 20:33:22 +00:00
|
|
|
|
|
|
|
divs.append(h("div.flex.five.example-component", {}, [
|
|
|
|
h("div.one-fifth", {}, left),
|
|
|
|
h("div.three-fifth", {}, middle),
|
2020-06-11 16:47:09 +00:00
|
|
|
h("div.one-fifth", {}, list_of_right_buttons(idx, component))]))
|
2020-01-25 20:33:22 +00:00
|
|
|
|
2020-06-11 20:34:04 +00:00
|
|
|
return modal_template(divs, "Edit Example",
|
|
|
|
(message.EditExampleText, example_original, sense))
|
2019-11-16 13:18:37 +00:00
|
|
|
|
|
|
|
|
2019-11-18 19:27:11 +00:00
|
|
|
def edit_variants(entry):
|
|
|
|
vget = lambda: entry.copy().variants
|
|
|
|
content = generic_list_editor("Variants", vget)
|
2020-02-16 22:17:46 +00:00
|
|
|
return modal_template(content, "Add or remove variants", (message.EditVariants,), (message.DeleteVariants,))
|
2019-11-18 19:27:11 +00:00
|
|
|
|
|
|
|
|
2020-01-21 21:18:43 +00:00
|
|
|
def edit_related_entries(entry):
|
|
|
|
reget = lambda: entry.copy().related_entries
|
|
|
|
content = generic_list_editor("Related entries", reget)
|
2020-02-16 22:17:46 +00:00
|
|
|
return modal_template(content, "Add or remove related entries", (message.EditRelatedEntries,), (message.DeleteRelatedEntries,))
|
2020-01-21 21:18:43 +00:00
|
|
|
|
|
|
|
|
2019-11-18 19:57:33 +00:00
|
|
|
def edit_entry_labels(entry):
|
2020-02-16 22:17:46 +00:00
|
|
|
content = label_list_editor(entry.copy().labels, [message.AddToLabelList, entry.copy().labels])
|
|
|
|
return modal_template(content, "Translation", (message.EditEntryLabels,), (message.DeleteEntryLabels,))
|
2019-11-18 19:57:33 +00:00
|
|
|
|
|
|
|
|
2019-11-11 22:04:45 +00:00
|
|
|
def edit_sense_definition(sense):
|
2020-02-16 22:17:46 +00:00
|
|
|
return modal_template(question("Edit sense definition", sense.definition["indicator"]), "Sense definition", (message.EditSenseDefinition, sense))
|
2019-11-11 22:04:45 +00:00
|
|
|
|
|
|
|
|
|
|
|
def edit_comment(comment):
|
2020-03-19 20:29:19 +00:00
|
|
|
return modal_template(big_question("Edit comment", comment), "Comment", (message.EditComment,), (message.DeleteComment,))
|
2019-11-15 21:24:32 +00:00
|
|
|
|
|
|
|
|
2020-01-02 13:22:35 +00:00
|
|
|
def do_chosen_examples(example_list, entry):
|
2020-01-28 22:05:48 +00:00
|
|
|
example_senses = []
|
2020-01-21 19:24:13 +00:00
|
|
|
for idx, sense in enumerate(entry.senses):
|
|
|
|
for ex in sense.examples:
|
2020-01-28 22:05:48 +00:00
|
|
|
if ex in example_list:
|
|
|
|
example_senses.append(idx)
|
2020-01-21 19:24:13 +00:00
|
|
|
break
|
|
|
|
|
2020-01-28 22:05:48 +00:00
|
|
|
sense_of_first_example = example_senses[0]
|
|
|
|
|
2020-01-14 20:57:11 +00:00
|
|
|
options = [h("p", {}, "Choose sense for examples")]
|
2020-01-14 19:59:15 +00:00
|
|
|
for idx, sense in enumerate(entry.senses):
|
2020-01-21 19:24:13 +00:00
|
|
|
text = "{}: {}".format(idx + 1, sense.definition["indicator"])
|
2020-01-14 20:57:11 +00:00
|
|
|
id_ = "choose-example-{}".format(idx)
|
2020-01-02 13:22:35 +00:00
|
|
|
|
2020-01-21 19:24:13 +00:00
|
|
|
props = {"type": "radio", "name": "choose-example"}
|
|
|
|
if idx == sense_of_first_example:
|
|
|
|
props["checked"] = True
|
|
|
|
|
|
|
|
options.append(h("input#{}.checkable-input".format(id_), {"props": props}, []))
|
2020-01-14 20:57:11 +00:00
|
|
|
options.append(h("label.checkable", {"attrs": {"for": id_}}, text))
|
|
|
|
options.append(h("br", {}, []))
|
|
|
|
|
2020-02-16 22:17:46 +00:00
|
|
|
return modal_template(options, "Examples picker", (message.DoChosenExamples, example_list))
|
2020-03-30 18:34:49 +00:00
|
|
|
|
|
|
|
|
2020-04-22 12:20:34 +00:00
|
|
|
def ske_list(search_term, data, page_num, senses, ske_kinds):
|
2020-03-30 18:34:49 +00:00
|
|
|
list_contents = []
|
|
|
|
ske_list_hidden = False
|
|
|
|
|
|
|
|
if data is None:
|
|
|
|
list_contents.append(h("div.loadingspinner", {}, ""))
|
|
|
|
elif type(data) is list:
|
|
|
|
for line in data:
|
|
|
|
list_contents.append(h("label.ske-line", {}, [
|
|
|
|
h("input.ske-line-check", {"props": { "type": "checkbox" }}, ""),
|
|
|
|
h("span.checkable", {}, line.view())]))
|
|
|
|
elif type(data) is str:
|
|
|
|
ske_list_hidden = True
|
|
|
|
else:
|
|
|
|
list_contents.append(h("span.error", {}, "Something went wrong in SKE: {}".format(data)))
|
|
|
|
|
|
|
|
contents = [
|
2020-04-22 12:20:34 +00:00
|
|
|
h("div.flex.four", {}, [
|
|
|
|
h("select#ske-select.fourth", {}, [
|
2020-03-30 18:34:49 +00:00
|
|
|
h("option", {}, "{}".format(x)) for x in ske_kinds]),
|
2020-04-22 12:20:34 +00:00
|
|
|
h("label.fourth.ske-mid-input", {}, [
|
2020-03-30 18:34:49 +00:00
|
|
|
h("input#ske-search", {"props": {"value": search_term, "type": "text"}}, "")]),
|
2020-04-22 12:20:34 +00:00
|
|
|
h("label.fourth.ske-mid-input", {}, [
|
|
|
|
h("input#ske-page-num", {"attrs": {
|
|
|
|
"value": str(page_num),
|
|
|
|
"type": "number",
|
|
|
|
"min": 1,
|
|
|
|
"step": 1}}, "")]),
|
|
|
|
h("span.fourth.button.ske-right-button",
|
2020-03-30 18:34:49 +00:00
|
|
|
{"on": {"click": message.msg(message.SearchInSkeModal)}}, "Isci")]),
|
|
|
|
h("div.ske-list",
|
|
|
|
{"style": {"visibility": "hidden" if ske_list_hidden else "visible"}},
|
|
|
|
list_contents),
|
|
|
|
h("div.flex.three", {}, [
|
|
|
|
h("span.third", {}, "Vstavi v:"),
|
|
|
|
h("select#ske-sense-select.two-third", {}, [ h("option", {}, "{} {}".format(
|
|
|
|
idx + 1, sense.definition["indicator"])) for idx, sense in enumerate(senses)])])]
|
|
|
|
|
|
|
|
return modal_template(contents, "SKE", (message.SkeInsert, data))
|