ctrl+click now on different message.

Will have to change these stuff, probably composition over inheritance
This commit is contained in:
Ozbolt Menegatti 2020-01-24 02:04:12 +01:00
parent 7e3fa499f8
commit 20ffe570f4
3 changed files with 75 additions and 71 deletions

View File

@ -1,5 +1,7 @@
from model import Translation, Sense, Example from model import Translation, Sense, Example
from message.simple_messages import ClickMessage from message.simple_messages import ClickMessage
from view import modals
from browser import document
class ShowMenu(ClickMessage): class ShowMenu(ClickMessage):
@ -10,6 +12,34 @@ class ShowMenu(ClickMessage):
super().on_event(event) super().on_event(event)
# Special message to handle ctrl+click, shift+click and click
# overwrite update_model_default/ctrl/shift
class KeyPlusClickMessage(ShowMenu):
def on_event(self, event):
super().on_event(event)
self.ctrl = event.ctrlKey
self.shift = event.shiftKey
def update_model(self, model):
if self.ctrl:
self.update_model_ctrl(model)
elif self.shift:
document.getSelection().removeAllRanges()
self.update_model_shift(model)
else:
self.update_model_default(model)
def update_model_ctrl(self, model):
pass
def update_model_shift(self, model):
pass
def update_model_default(self, model):
pass
class ShowTranslationMenu(ShowMenu): class ShowTranslationMenu(ShowMenu):
def update_model(self, model): def update_model(self, model):
model.menu_location = self.menu_location model.menu_location = self.menu_location
@ -24,8 +54,46 @@ class ShowSenseMenu(ShowMenu):
model.menu_target = sense model.menu_target = sense
class ShowExampleMenu(ShowMenu): class ShowExampleMenu(KeyPlusClickMessage):
def update_model(self, model): def update_model_default(self, model):
model.menu_location = self.menu_location
example = self.get_arg(0, Example) example = self.get_arg(0, Example)
model.menu_target = 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_set(lambda: modals.do_chosen_examples(chosen_examples, model.entry))
else:
model.menu_location = self.menu_location
model.menu_target = example
def update_model_ctrl(self, model):
example = self.get_arg(0, Example)
if example in model.chosen_examples:
model.chosen_examples.remove(example)
else:
model.chosen_examples.append(example)
def update_model_shift(self, model):
first_example = self.get_arg(0, Example)
last_example = model.chosen_examples[model.chosen_examples.length - 1]
adding = False
# logic to add all senses between these two
for sense in model.entry.senses:
for example in sense.examples:
match = example in (first_example, last_example)
if adding and match:
adding = False
elif match:
adding = True
elif not adding:
continue
if example not in model.chosen_examples:
model.chosen_examples.append(example)
def reset(self):
# special case, when choosing messages dont reset
return not (self.ctrl or self.shift)

View File

@ -1,6 +1,6 @@
from message.message import Message from message.message import Message
from message.translation_edit import AddTranslation, EditTranslation from message.translation_edit import AddTranslation, EditTranslation
from message.simple_messages import ClickMessage, KeyPlusClickMessage from message.simple_messages import ClickMessage
from model import Example, Sense, Translation from model import Example, Sense, Translation
from view import modals from view import modals
@ -37,49 +37,11 @@ class ShowRelatedEntriesEdit(ClickMessage):
model.modal_set(lambda: modals.edit_related_entries(model.entry)) model.modal_set(lambda: modals.edit_related_entries(model.entry))
class ShowExampleEdit(KeyPlusClickMessage): class ShowExampleEdit(ClickMessage):
def update_model_default(self, model): def update_model_default(self, model):
example = self.get_arg(0, Example) example = self.get_arg(0, Example)
example.make_copy() example.make_copy()
model.modal_set(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_set(lambda: modals.do_chosen_examples(chosen_examples, model.entry))
else:
model.modal_set(lambda: modals.edit_example(example))
def update_model_ctrl(self, model):
example = self.get_arg(0, Example)
if example in model.chosen_examples:
model.chosen_examples.remove(example)
else:
model.chosen_examples.append(example)
def update_model_shift(self, model):
first_example = self.get_arg(0, Example)
last_example = model.chosen_examples[model.chosen_examples.length - 1]
adding = False
# logic to add all senses between these two
for sense in model.entry.senses:
for example in sense.examples:
match = example in (first_example, last_example)
if adding and match:
adding = False
elif match:
adding = True
elif not adding:
continue
if example not in model.chosen_examples:
model.chosen_examples.append(example)
def reset(self):
# special case, when choosing messages dont reset
return not (self.ctrl or self.shift)
class ShowEditTranslation(ClickMessage): class ShowEditTranslation(ClickMessage):

View File

@ -68,30 +68,4 @@ class ModalNotOkClose(Reset):
return False return False
# Special message to handle ctrl+click, shift+click and click
# overwrite update_model_default/ctrl/shift
class KeyPlusClickMessage(ClickMessage):
def on_event(self, event):
super().on_event(event)
self.ctrl = event.ctrlKey
self.shift = event.shiftKey
def update_model(self, model):
if self.ctrl:
self.update_model_ctrl(model)
elif self.shift:
document.getSelection().removeAllRanges()
self.update_model_shift(model)
else:
self.update_model_default(model)
def update_model_ctrl(self, model):
pass
def update_model_shift(self, model):
pass
def update_model_default(self, model):
pass