Linux lorencats.com 5.10.103-v7l+ #1529 SMP Tue Mar 8 12:24:00 GMT 2022 armv7l
Apache/2.4.59 (Raspbian)
: 10.0.0.29 | : 216.73.216.130
Cant Read [ /etc/named.conf ]
7.3.31-1~deb10u7
root
www.github.com/MadExploits
Terminal
AUTO ROOT
Adminer
Backdoor Destroyer
Linux Exploit
Lock Shell
Lock File
Create User
CREATE RDP
PHP Mailer
BACKCONNECT
UNLOCK SHELL
HASH IDENTIFIER
CPANEL RESET
CREATE WP USER
README
+ Create Folder
+ Create File
/
usr /
lib /
python3 /
dist-packages /
guizero /
[ HOME SHELL ]
Name
Size
Permission
Action
__pycache__
[ DIR ]
drwxr-xr-x
App.py
1.99
KB
-rw-r--r--
Box.py
3.11
KB
-rw-r--r--
ButtonGroup.py
10.2
KB
-rw-r--r--
CheckBox.py
4.63
KB
-rw-r--r--
Combo.py
10.54
KB
-rw-r--r--
ListBox.py
8.05
KB
-rw-r--r--
MenuBar.py
1.32
KB
-rw-r--r--
Picture.py
2.58
KB
-rw-r--r--
PushButton.py
5.2
KB
-rw-r--r--
RadioButton.py
1.7
KB
-rw-r--r--
Slider.py
2.59
KB
-rw-r--r--
Text.py
2.71
KB
-rw-r--r--
TextBox.py
3.7
KB
-rw-r--r--
Waffle.py
10.4
KB
-rw-r--r--
Window.py
1.03
KB
-rw-r--r--
__init__.py
715
B
-rw-r--r--
alerts.py
1.17
KB
-rw-r--r--
base.py
18.22
KB
-rw-r--r--
event.py
5.87
KB
-rw-r--r--
tkmixins.py
10.47
KB
-rw-r--r--
utilities.py
11.77
KB
-rw-r--r--
Delete
Unzip
Zip
${this.title}
Close
Code Editor : ListBox.py
from tkinter import Listbox, Frame, Scrollbar, END, BROWSE, EXTENDED, LEFT, RIGHT, Y from . import utilities as utils from .base import TextWidget, ContainerTextWidget from .event import EventManager # I suspect the implementation of ListBox can be simplified in the future... # At the moment it is a Container which contains a list box # The only reason it is a container is to support scrollbars which need to be placed inside a frame. # It feels like scrollbar should be built into guizero's base classes, Im just not sure how at the moment. # Martin class ListBox(ContainerTextWidget): def __init__( self, master, items=None, selected=None, command=None, grid=None, align=None, visible=True, enabled=None, multiselect=False, scrollbar=False, width=None, height=None): """ Creates a ListBox :param Container master: The Container (App, Box, etc) the ListBox will belong too. :param List items: A list of strings to populate the ListBox, defaults to `None`. :param string selected: The item in the ListBox to select, defaults to `None`. :param callback command: The callback function to call when the ListBox changes, defaults to `None`. :param List grid: Grid co-ordinates for the widget, required if the master layout is 'grid', defaults to `None`. :param string align: How to align the widget within the grid, defaults to None. :param bool visible: If the widget should be visible, defaults to `True`. :param bool enabled: If the widget should be enabled, defaults to `None`. If `None` the value is inherited from the master. :param bool multiselect: If ListBox should allow multiple items to be selected, defaults to `False`. :param bool scrollbar: If ListBox should have a vertical scrollbar, defaults to False. :param int width: The starting width of the widget. Defaults to `None` and will auto size. :param int height: The starting height of the widget. Defaults to `None` and will auto size. """ description = "[ListBox] object" tk = Frame(master.tk) super(ListBox, self).__init__(master, tk, description, "auto", grid, align, visible, enabled, width, height) self._listbox = ListBoxWidget(self, items, selected, command, None, None, visible, enabled, multiselect, width, height) if scrollbar: # create the scrollbar and link it to the listbox self._listbox.tk.pack(side=LEFT) scrollbar = Scrollbar(tk) scrollbar.pack(side=RIGHT, fill=Y) self._listbox.tk.config(yscrollcommand=scrollbar.set) scrollbar.config(command=self._listbox.tk.yview) else: self._listbox.tk.pack() # override the event manager to associate it to the list box and not the frame self._events = EventManager(self, self._listbox.tk) self.resize(width, height) def resize(self, width, height): """ Resizes the widget. :param int width: The width of the widget. :param int height: The height of the widget. """ self._set_propagation(width, height) super(ListBox, self).resize(width, height) self._listbox.resize(width, height) @property def value(self): """ Sets or returns the items selected in a ListBox `None` if 0 items are selected. If the ListBox is a not `multiselect`, `value` is the item selected. If the ListBox is a `multiselect`, `value` is a list of items selected. """ return self._listbox.value @value.setter def value(self, value): self._listbox.value = value def insert(self, index, item): """ Insert a new `item` at `index` """ self._listbox.insert(index, item) def append(self, item): """ Appends a new `item` to the end of the ListBox. """ self._listbox.append(item) def remove(self, item): """ Removes the first `item` from the ListBox. Returns `True` if an item was removed. """ return self._listbox.remove(item) def clear(self): """ Clears all the items in a ListBox """ self._listbox.clear() @property def items(self): """ Returns a list of items in the ListBox """ return self._listbox.items def update_command(self, command): """ Updates the callback command which is called when the ListBox changes. Setting to `None` stops the callback. :param callback command: The callback function to call, it can accept 0 or 1 parameters. If it accepts 1 parameter the `value` of the ListBox will be passed. """ self._listbox.update_command(command) class ListBoxWidget(TextWidget): def __init__(self, master, items=None, selected=None, command=None, grid=None, align=None, visible=True, enabled=None, multiselect=False, width=None, height=None): description = "[ListBox] object" self._multiselect = multiselect # Create a tk OptionMenu object within this object mode = EXTENDED if multiselect else BROWSE # exportselection=0 allows you to select from more than 1 Listbox tk = Listbox(master.tk, selectmode=mode, exportselection=0) # Add the items if items is not None: for item in items: tk.insert(END, item) super(ListBoxWidget, self).__init__(master, tk, description, None, None, visible, enabled, width, height) self.events.set_event("<ListBox.ListboxSelect>", "<<ListboxSelect>>", self._command_callback) # Select the selected items if selected is not None: self.value = selected # The command associated with this combo self.update_command(command) @property def value(self): if len(self.tk.curselection()) > 0: if self._multiselect: return [self.tk.get(selected) for selected in self.tk.curselection()] else: return self.tk.get(self.tk.curselection()[0]) else: return None @value.setter def value(self, value): self.tk.selection_clear(0, self.tk.size() - 1) # go through all the items and select those in `value` for index in range(self.tk.size()): if self._multiselect: for item in value: if self.tk.get(index) == item: self.tk.select_set(index) else: if self.tk.get(index) == value: self.tk.select_set(index) def insert(self, index, item): self.tk.insert(index, item) def append(self, item): self.tk.insert(END, item) def remove(self, item): for index in range(len(self.items)): if item == self.items[index]: self.tk.delete(index) return True return False def clear(self): self.tk.delete(0, END) @property def items(self): return [self.tk.get(index) for index in range(self.tk.size())] def _command_callback(self): if self._command: args_expected = utils.no_args_expected(self._command) if args_expected == 0: self._command() elif args_expected == 1: self._command(self.value) else: utils.error_format("ListBox command function must accept either 0 or 1 arguments.\nThe current command has {} arguments.".format(args_expected)) def update_command(self, command): if command is None: self._command = lambda: None else: self._command = command
Close