Compare commits
3 Commits
2879d2abb1
...
f16bafee8f
Author | SHA1 | Date | |
---|---|---|---|
f16bafee8f | |||
cfe7e49a9e | |||
a885298d00 |
24
AboutCommand.py
Normal file
24
AboutCommand.py
Normal file
@ -0,0 +1,24 @@
|
||||
from textual.command import DiscoveryHit, Provider, Hits, Hit
|
||||
|
||||
class AboutCommand(Provider):
|
||||
'''Class to represent the About command in the menu'''
|
||||
|
||||
async def discover(self) -> Hits:
|
||||
yield DiscoveryHit(
|
||||
display='About',
|
||||
command=self.app.action_toggle_sidebar,
|
||||
help='Link to repo etc.'
|
||||
)
|
||||
|
||||
async def search(self, query: str) -> Hits:
|
||||
'''Called when the search functionality is used'''
|
||||
matcher = self.matcher(query)
|
||||
command = "About"
|
||||
score = matcher.match(command)
|
||||
if score > 0:
|
||||
yield Hit(
|
||||
score,
|
||||
matcher.highlight(command),
|
||||
self.app.action_toggle_sidebar,
|
||||
'Link to repo etc.'
|
||||
)
|
54
BingoDisplay.py
Normal file
54
BingoDisplay.py
Normal file
@ -0,0 +1,54 @@
|
||||
from textual.widgets import Input, Static, Button
|
||||
from textual.containers import Horizontal
|
||||
from textual.validation import Number
|
||||
from textual.app import ComposeResult
|
||||
|
||||
from datetime import datetime
|
||||
|
||||
from BingoBoard import BingoBoard
|
||||
|
||||
class BingoDisplay(Static):
|
||||
'''
|
||||
A Widget to represent the bingo UI.
|
||||
|
||||
Contains the board, input field and re-roll button.
|
||||
|
||||
Attributes
|
||||
----------
|
||||
board : BingoBoard
|
||||
The BingoBoard object
|
||||
input_field : Input
|
||||
User input for game seed
|
||||
'''
|
||||
|
||||
def compose(self) -> ComposeResult:
|
||||
'''Create child widgets for the app.'''
|
||||
self.board = BingoBoard()
|
||||
yield self.board
|
||||
self.input_field = Input(
|
||||
str(self.board.seed),
|
||||
type='integer',
|
||||
placeholder='UNIX timestamp',
|
||||
max_length=10,
|
||||
classes='seed_input',
|
||||
validators=[
|
||||
Number(minimum=1000000000, maximum = 2000000000)
|
||||
]
|
||||
)
|
||||
self.input_field.border_title = 'Seed'
|
||||
yield Horizontal(
|
||||
self.input_field,
|
||||
Button.error(':game_die: re-roll', classes='roll_btn'),
|
||||
classes='bottom_line'
|
||||
)
|
||||
|
||||
def on_button_pressed(self, event: Button.Pressed) -> None:
|
||||
'''Re-roll the board state with current time as seed'''
|
||||
self.board.roll_board(int(datetime.now().timestamp()))
|
||||
self.input_field.value = str(self.board.seed)
|
||||
|
||||
def on_input_submitted(self, event: Input.Submitted) -> None:
|
||||
'''Re-roll the board state with the seed from the input'''
|
||||
if event.validation_result.is_valid:
|
||||
self.board.roll_board(int(event.value))
|
||||
|
31
Sidebar.py
Normal file
31
Sidebar.py
Normal file
@ -0,0 +1,31 @@
|
||||
from textual.containers import Container
|
||||
from textual.app import ComposeResult
|
||||
from textual.widgets import Static, Button
|
||||
|
||||
MESSAGE = '''
|
||||
Be excellent to each other!
|
||||
|
||||
Made with :red_heart: by Panki
|
||||
|
||||
[@click="app.open_link('https://tty0.social/@panki')"]Mastodon:[/] tty0.social/@panki
|
||||
[@click="app.open_link('https://git.theresno.cloud/panki/bingo-cli')"]Source:[/] git.theresno.cloud/panki/bingo-cli
|
||||
|
||||
Built using [@click="app.open_link('https://textual.textualize.io/')"]Textual[/]
|
||||
|
||||
'''
|
||||
|
||||
class Sidebar(Container):
|
||||
'''Class to represent the sidebar'''
|
||||
|
||||
def compose(self) -> ComposeResult:
|
||||
'''Create the widgets that make up the sidebar'''
|
||||
yield Static('CCC Bingo', classes='title')
|
||||
yield Static(MESSAGE, classes='message')
|
||||
self.button = Button('< Back', variant='primary', classes='btn_sidebar')
|
||||
self.button.disabled = True
|
||||
yield self.button
|
||||
|
||||
def on_button_pressed(self, event: Button.Pressed) -> None:
|
||||
'''Closes the sidebar'''
|
||||
self.app.action_toggle_sidebar()
|
||||
|
100
bingo.py
100
bingo.py
@ -1,59 +1,12 @@
|
||||
#!/usr/bin/env python3
|
||||
|
||||
from textual.app import App, ComposeResult
|
||||
from textual.widgets import Header, Input, Static, Button
|
||||
from textual.containers import Horizontal, Container
|
||||
from textual.validation import Number
|
||||
from textual.command import DiscoveryHit, Provider, Hits, Hit
|
||||
from textual.widgets import Header
|
||||
from textual.reactive import reactive
|
||||
|
||||
from datetime import datetime
|
||||
|
||||
from BingoBoard import BingoBoard
|
||||
|
||||
MESSAGE = '''
|
||||
Be excellent to each other!
|
||||
|
||||
Made with :red_heart: by Panki
|
||||
|
||||
[@click="app.open_link('https://tty0.social/@panki')"]Mastodon:[/] tty0.social/@panki
|
||||
[@click="app.open_link('https://git.theresno.cloud/panki/bingo-cli')"]Source:[/] git.theresno.cloud/panki/bingo-cli
|
||||
|
||||
Built using [@click="app.open_link('https://textual.textualize.io/')"]Textual[/]
|
||||
|
||||
'''
|
||||
|
||||
class AboutCommand(Provider):
|
||||
'''Class to represent the About command in the menu'''
|
||||
|
||||
async def discover(self) -> Hits:
|
||||
yield DiscoveryHit(display='About', command=self.app.action_toggle_sidebar, help='Link to repo etc.')
|
||||
|
||||
def show_about(self) -> None:
|
||||
pass
|
||||
|
||||
async def search(self, query: str) -> Hits:
|
||||
'''Called when the search functionality is used'''
|
||||
matcher = self.matcher(query)
|
||||
command = "About"
|
||||
score = matcher.match(command)
|
||||
if score > 0:
|
||||
yield Hit(score, matcher.highlight(command), self.app.action_toggle_sidebar, 'Link to repo etc.')
|
||||
|
||||
class Sidebar(Container):
|
||||
'''Class to represent the sidebar'''
|
||||
|
||||
def compose(self) -> ComposeResult:
|
||||
'''Create the widgets that make up the sidebar'''
|
||||
yield Static('CCC Bingo', classes='title')
|
||||
yield Static(MESSAGE, classes='message')
|
||||
self.button = Button('< Back', variant='primary', classes='btn_sidebar')
|
||||
self.button.disabled = True
|
||||
yield self.button
|
||||
|
||||
def on_button_pressed(self, event: Button.Pressed) -> None:
|
||||
'''Closes the sidebar'''
|
||||
self.app.action_toggle_sidebar()
|
||||
from BingoDisplay import BingoDisplay
|
||||
from AboutCommand import AboutCommand
|
||||
from Sidebar import Sidebar
|
||||
|
||||
class BingoApp(App):
|
||||
'''
|
||||
@ -92,51 +45,6 @@ class BingoApp(App):
|
||||
self.title = 'CCC Bingo'
|
||||
self.sub_title = 'GPN22 Edition'
|
||||
|
||||
class BingoDisplay(Static):
|
||||
'''
|
||||
A Widget to represent the bingo UI.
|
||||
|
||||
Contains the board, input field and re-roll button.
|
||||
|
||||
Attributes
|
||||
----------
|
||||
board : BingoBoard
|
||||
The BingoBoard object
|
||||
input_field : Input
|
||||
User input for game seed
|
||||
'''
|
||||
|
||||
def compose(self) -> ComposeResult:
|
||||
'''Create child widgets for the app.'''
|
||||
self.board = BingoBoard()
|
||||
yield self.board
|
||||
self.input_field = Input(
|
||||
str(self.board.seed),
|
||||
type='integer',
|
||||
placeholder='UNIX timestamp',
|
||||
max_length=10,
|
||||
classes='seed_input',
|
||||
validators=[
|
||||
Number(minimum=1000000000, maximum = 2000000000)
|
||||
]
|
||||
)
|
||||
self.input_field.border_title = 'Seed'
|
||||
yield Horizontal(
|
||||
self.input_field,
|
||||
Button.error(':game_die: re-roll', classes='roll_btn'),
|
||||
classes='bottom_line'
|
||||
)
|
||||
|
||||
def on_button_pressed(self, event: Button.Pressed) -> None:
|
||||
'''Re-roll the board state with current time as seed'''
|
||||
self.board.roll_board(int(datetime.now().timestamp()))
|
||||
self.input_field.value = str(self.board.seed)
|
||||
|
||||
def on_input_submitted(self, event: Input.Submitted) -> None:
|
||||
'''Re-roll the board state with the seed from the input'''
|
||||
if event.validation_result.is_valid:
|
||||
self.board.roll_board(int(event.value))
|
||||
|
||||
if __name__ == "__main__":
|
||||
app = BingoApp()
|
||||
app.run()
|
||||
|
Loading…
Reference in New Issue
Block a user