From d01024d1be74cea5fc3466cd61e00f92433f2b48 Mon Sep 17 00:00:00 2001 From: Sebastian Lohff Date: Thu, 20 Aug 2020 01:37:20 +0200 Subject: [PATCH] Add initial_pos to choose initially selected item --- clintermission/climenu.py | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/clintermission/climenu.py b/clintermission/climenu.py index 04a75ac..f79012d 100644 --- a/clintermission/climenu.py +++ b/clintermission/climenu.py @@ -83,12 +83,13 @@ class CliMenu: cls.default_cursor = cursor def __init__(self, options=None, header=None, cursor=None, style=None, - indent=2, dedent_selection=False): + indent=2, dedent_selection=False, initial_pos=0): self._items = [] self._item_num = 0 self._ran = False self._success = None self._pos = 0 + self._initial_pos = initial_pos self._option_indent = indent self._header_indent = indent self._dedent_selection = dedent_selection @@ -230,6 +231,10 @@ class CliMenu: pass def _run(self): + if self._initial_pos < 0 or self._initial_pos >= self._item_num: + raise ValueError("Initial position {} is out of range, needs to be in range of [0, {})" + .format(self._initial_pos, self._item_num)) + class MenuColorizer(Processor): def apply_transformation(_self, ti): return self._transform_line(ti) @@ -293,7 +298,8 @@ class CliMenu: self._searchbar]) # set initial pos - self.sync_cursor_to_line(0) + for _ in range(self._initial_pos + 1): + self.next_item(1) app = Application(layout=Layout(split), key_bindings=self._kb,