ShowExampleEdit becomes more complex, handles ctrl+click and selecting/moving examples

This commit is contained in:
Ozbolt Menegatti 2020-01-02 14:22:35 +01:00
parent 00827e7b0b
commit e7283c3ba1
5 changed files with 50 additions and 6 deletions

View File

@ -1,7 +1,7 @@
from message.simple_messages import NoReset, Reset, ModalNotOkClose, ClickMessage, DataChgClickMessage
from message.translation_edit import EditTranslation, MoveRight, MoveLeft, BinTranslation
from message.show_messages import ShowEntryLabelsEdit, ShowEditTranslation, ShowSenseLabelEdit, ShowSenseDefinitionEdit, ShowCommentEdit, ShowAddTranslation, ShowExampleEdit, ShowExampleTranslationEdit, ShowVariantsEdit
from message.simple_edits import EditSenseLabel, EditSenseDefinition, EditComment, AddSenseLabel, AddSense, EditExample, AddExampleTranslation, EditExampleTranslation, AddToLabelList, AddToGenericList, EditVariants, EditEntryLabels
from message.simple_edits import EditSenseLabel, EditSenseDefinition, EditComment, AddSenseLabel, AddSense, EditExample, AddExampleTranslation, EditExampleTranslation, DoChosenExamples, AddToLabelList, AddToGenericList, EditVariants, EditEntryLabels
from message.show_menu import ShowTranslationMenu, ShowSenseMenu
from message.sense_edit import SenseMoveUp, SenseMoveDown, SenseBin

View File

@ -1,6 +1,6 @@
from message.message import Message
from message.translation_edit import AddTranslation, EditTranslation
from message.simple_messages import ClickMessage
from message.simple_messages import ClickMessage, CtrlClickMessage
from model import Example, Sense, Translation
from view import modals
@ -35,12 +35,25 @@ class ShowVariantsEdit(ClickMessage):
model.modal = lambda: modals.edit_variants(model.entry)
class ShowExampleEdit(ClickMessage):
def update_model(self, model):
class ShowExampleEdit(CtrlClickMessage):
def update_model_noctrl(self, model):
model.modal_shown = True
example = self.get_arg(0, Example)
model.modal = lambda: modals.edit_example(example)
# if some are chosen, then show modal for choosing senses
if len(model.chosen_examples) > 0 and example in model.chosen_examples:
chosen_examples = model.chosen_examples
model.modal = lambda: modals.do_chosen_examples(chosen_examples, model.entry)
else:
model.modal = lambda: modals.edit_example(example)
def update_model_ctrl(self, model):
example = self.get_arg(0, Example)
model.chosen_examples.append(example)
def reset(self):
# special case, when choosing messages dont reset
return not self.ctrl
class ShowExampleTranslationEdit(ClickMessage):
def update_model(self, model):

View File

@ -69,6 +69,21 @@ class EditExample(QuestionMessage):
example.example = self.new_text
class DoChosenExamples(Message):
def update_model(self, model):
chosen_examples = self.get_arg(0, list)
selected = document.getElementById("chosen-examples-select").selectedIndex
# first, remove the selected examples from wherever they were
for sense in model.entry.senses:
for example in chosen_examples:
if example in sense.examples:
sense.examples.remove(example)
# now, append selected examples to chosen sense
model.entry.senses[selected].examples.extend(chosen_examples)
class EditVariants(Message):
def update_model(self, model):
variants = common_accessors.generic_list_getter()

View File

@ -35,3 +35,7 @@ class Sense(Editable):
self.translations = [[] for _ in range(max_num_cluster)]
for clusterNum, translation in translations:
self.translations[clusterNum - 1].append(translation)
def merge_labels(self):
return ", ".join(val for _, val in self.labels)

View File

@ -29,7 +29,6 @@ def edit_sense_label(sense):
return modal_template(content, "Translation", message.EditSenseLabel(sense))
def edit_example_translation(example):
etl_getter = lambda: example.copy().translations
content = generic_list_editor("Edit example translations", etl_getter)
@ -57,3 +56,16 @@ def edit_comment(comment):
def edit_example(example):
return modal_template(question("Edit exmample", example.example), "Example", message.EditExample(example))
def do_chosen_examples(example_list, entry):
options = []
for sense in entry.senses:
options.append(h("option", {}, sense.merge_labels()))
content = [
h("span", {}, "Choose sense for examples"),
h("label", {}, [
h("select#chosen-examples-select", {}, options)])]
return modal_template(content, "Examples picker", message.DoChosenExamples(example_list))