pre-commit and red pill
This commit is contained in:
parent
1720af54e9
commit
536261dce7
32
.pre-commit-config.yaml
Normal file
32
.pre-commit-config.yaml
Normal file
@ -0,0 +1,32 @@
|
||||
repos:
|
||||
- repo: https://github.com/pre-commit/pre-commit-hooks
|
||||
rev: v4.5.0
|
||||
hooks:
|
||||
- id: trailing-whitespace
|
||||
- id: end-of-file-fixer
|
||||
- id: check-docstring-first
|
||||
- id: debug-statements
|
||||
- id: double-quote-string-fixer
|
||||
- id: requirements-txt-fixer
|
||||
- id: check-added-large-files
|
||||
- id: check-ast
|
||||
- id: check-builtin-literals
|
||||
- id: check-case-conflict
|
||||
- id: destroyed-symlinks
|
||||
- id: check-merge-conflict
|
||||
- id: debug-statements
|
||||
- id: detect-private-key
|
||||
- id: fix-byte-order-marker
|
||||
- id: mixed-line-ending
|
||||
- repo: https://github.com/hhatto/autopep8
|
||||
rev: v2.1.0
|
||||
hooks:
|
||||
- id: autopep8
|
||||
- repo: https://github.com/asottile/add-trailing-comma
|
||||
rev: v3.1.0
|
||||
hooks:
|
||||
- id: add-trailing-comma
|
||||
- repo: https://github.com/asottile/pyupgrade
|
||||
rev: v3.15.2
|
||||
hooks:
|
||||
- id: pyupgrade
|
Binary file not shown.
Before Width: | Height: | Size: 4.3 KiB After Width: | Height: | Size: 4.1 KiB |
BIN
assets/icon.png
BIN
assets/icon.png
Binary file not shown.
Before Width: | Height: | Size: 4.3 KiB After Width: | Height: | Size: 4.1 KiB |
8
main.py
8
main.py
@ -3,15 +3,17 @@ from utils import views_handler
|
||||
|
||||
|
||||
def main(page: ft.Page):
|
||||
page.title = "BillPay"
|
||||
page.title = 'BillPay'
|
||||
# print("Initial route:", page.route)
|
||||
|
||||
def route_change(e):
|
||||
# print("Route change:", e.route)
|
||||
page.views.clear()
|
||||
page.views.append(
|
||||
views_handler(page)[page.route]
|
||||
views_handler(page)[page.route],
|
||||
)
|
||||
page.update()
|
||||
|
||||
def view_pop(e):
|
||||
# print("View pop:", e.view)
|
||||
page.views.pop()
|
||||
@ -23,4 +25,4 @@ def main(page: ft.Page):
|
||||
page.go(page.route)
|
||||
|
||||
|
||||
ft.app(target=main, assets_dir="assets")
|
||||
ft.app(target=main, assets_dir='assets')
|
||||
|
@ -2,4 +2,4 @@ from .home import Home
|
||||
from .settings import Settings
|
||||
|
||||
|
||||
__all__ = ["Home", "Settings"]
|
||||
__all__ = ['Home', 'Settings']
|
||||
|
@ -2,18 +2,19 @@ import flet as ft
|
||||
from utils import AppView, Title
|
||||
from modules.settings import config
|
||||
|
||||
|
||||
def Home(page: ft.Page):
|
||||
return AppView(
|
||||
"/",
|
||||
'/',
|
||||
[
|
||||
ft.AppBar(
|
||||
title=ft.Text(Title(__file__)),
|
||||
actions=[
|
||||
ft.IconButton(
|
||||
icon=ft.icons.SETTINGS,
|
||||
on_click=lambda _: page.go("/settings"),
|
||||
)
|
||||
]
|
||||
on_click=lambda _: page.go('/settings'),
|
||||
),
|
||||
],
|
||||
),
|
||||
ft.Container(
|
||||
height=100,
|
||||
@ -21,11 +22,11 @@ def Home(page: ft.Page):
|
||||
content=ft.Column(
|
||||
controls=[
|
||||
ft.Text(
|
||||
"Goodmorning,"
|
||||
'Goodmorning,',
|
||||
),
|
||||
ft.Text(
|
||||
config.get("general", "name")
|
||||
)
|
||||
config.get('general', 'name'),
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
|
@ -1,4 +1,4 @@
|
||||
from .settings import Settings
|
||||
from .functions import config
|
||||
|
||||
__all__ = ["Settings", "config"]
|
||||
__all__ = ['Settings', 'config']
|
||||
|
@ -45,15 +45,16 @@ nid =
|
||||
phone =
|
||||
"""
|
||||
|
||||
|
||||
class Config(ConfigParser):
|
||||
def __init__(self) -> None:
|
||||
super().__init__()
|
||||
if not os.path.exists("config.ini"):
|
||||
if not os.path.exists('config.ini'):
|
||||
self.initialize(content=static)
|
||||
self.read("config.ini")
|
||||
self.read('config.ini')
|
||||
|
||||
def initialize(self, content):
|
||||
with open("config.ini", 'a+') as file:
|
||||
with open('config.ini', 'a+') as file:
|
||||
file.write(content)
|
||||
|
||||
|
||||
|
@ -1,5 +1,6 @@
|
||||
import flet as ft
|
||||
|
||||
|
||||
class Theme:
|
||||
def __init__(self, page: ft.Page) -> None:
|
||||
self.page = page
|
||||
|
@ -2,11 +2,12 @@ import flet as ft
|
||||
from utils import AppView, Title
|
||||
from .functions import Theme
|
||||
|
||||
|
||||
def Settings(page: ft.Page):
|
||||
settingsContainer = ft.ListView(
|
||||
expand=True
|
||||
expand=True,
|
||||
)
|
||||
settingsContainer.controls.append(ft.Text("General"))
|
||||
settingsContainer.controls.append(ft.Text('General'))
|
||||
generalSettings = ft.Container(
|
||||
content=ft.Column(
|
||||
controls=[
|
||||
@ -17,16 +18,16 @@ def Settings(page: ft.Page):
|
||||
[
|
||||
ft.ListTile(
|
||||
leading=ft.Icon(ft.icons.PERSON),
|
||||
title=ft.Text("Username"),
|
||||
title=ft.Text('Username'),
|
||||
subtitle=ft.Text(
|
||||
"The greeting message"
|
||||
'The greeting message',
|
||||
),
|
||||
),
|
||||
]
|
||||
],
|
||||
),
|
||||
padding=10,
|
||||
on_click=lambda _: print("clicked username"),
|
||||
)
|
||||
on_click=lambda _: print('clicked username'),
|
||||
),
|
||||
),
|
||||
ft.Card(
|
||||
content=ft.Container(
|
||||
@ -35,16 +36,16 @@ def Settings(page: ft.Page):
|
||||
[
|
||||
ft.ListTile(
|
||||
leading=ft.Icon(ft.icons.PHONE),
|
||||
title=ft.Text("Phone"),
|
||||
title=ft.Text('Phone'),
|
||||
subtitle=ft.Text(
|
||||
"Personal Phone number"
|
||||
'Personal Phone number',
|
||||
),
|
||||
),
|
||||
]
|
||||
],
|
||||
),
|
||||
padding=10,
|
||||
on_click=lambda _: print("clicked phone"),
|
||||
)
|
||||
on_click=lambda _: print('clicked phone'),
|
||||
),
|
||||
),
|
||||
ft.Card(
|
||||
content=ft.Container(
|
||||
@ -53,16 +54,16 @@ def Settings(page: ft.Page):
|
||||
[
|
||||
ft.ListTile(
|
||||
leading=ft.Icon(ft.icons.EMAIL),
|
||||
title=ft.Text("Email"),
|
||||
title=ft.Text('Email'),
|
||||
subtitle=ft.Text(
|
||||
"Personal Email"
|
||||
'Personal Email',
|
||||
),
|
||||
),
|
||||
]
|
||||
],
|
||||
),
|
||||
padding=10,
|
||||
on_click=lambda _: print("clicked email"),
|
||||
)
|
||||
on_click=lambda _: print('clicked email'),
|
||||
),
|
||||
),
|
||||
ft.Card(
|
||||
content=ft.Container(
|
||||
@ -71,25 +72,25 @@ def Settings(page: ft.Page):
|
||||
[
|
||||
ft.ListTile(
|
||||
leading=ft.Icon(ft.icons.CARD_TRAVEL),
|
||||
title=ft.Text("NID"),
|
||||
title=ft.Text('NID'),
|
||||
subtitle=ft.Text(
|
||||
"National Idenity Number"
|
||||
'National Idenity Number',
|
||||
),
|
||||
),
|
||||
]
|
||||
],
|
||||
),
|
||||
padding=10,
|
||||
on_click=lambda _: print("clicked email"),
|
||||
)
|
||||
on_click=lambda _: print('clicked email'),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
]
|
||||
)
|
||||
)
|
||||
settingsContainer.controls.append(
|
||||
generalSettings
|
||||
generalSettings,
|
||||
)
|
||||
settingsContainer.controls.append(ft.Divider())
|
||||
settingsContainer.controls.append(ft.Text("Notifications"))
|
||||
settingsContainer.controls.append(ft.Text('Notifications'))
|
||||
notificationsSettings = ft.Container(
|
||||
content=ft.Column(
|
||||
controls=[
|
||||
@ -100,25 +101,25 @@ def Settings(page: ft.Page):
|
||||
[
|
||||
ft.ListTile(
|
||||
leading=ft.Icon(ft.icons.TELEGRAM),
|
||||
title=ft.Text("Telegram"),
|
||||
title=ft.Text('Telegram'),
|
||||
subtitle=ft.Text(
|
||||
"Telegram Notifications for reminders and Bill pays"
|
||||
'Telegram Notifications for reminders and Bill pays',
|
||||
),
|
||||
),
|
||||
]
|
||||
],
|
||||
),
|
||||
padding=10,
|
||||
on_click=lambda _: print("clicked username"),
|
||||
)
|
||||
on_click=lambda _: print('clicked username'),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
]
|
||||
)
|
||||
)
|
||||
settingsContainer.controls.append(
|
||||
notificationsSettings
|
||||
notificationsSettings,
|
||||
)
|
||||
settingsContainer.controls.append(ft.Divider())
|
||||
settingsContainer.controls.append(ft.Text("Apps"))
|
||||
settingsContainer.controls.append(ft.Text('Apps'))
|
||||
appsSettings = ft.Container(
|
||||
content=ft.Column(
|
||||
controls=[
|
||||
@ -131,18 +132,18 @@ def Settings(page: ft.Page):
|
||||
leading=ft.Image(
|
||||
border_radius=ft.border_radius.all(10),
|
||||
fit=ft.ImageFit.CONTAIN,
|
||||
src="https://asset.brandfetch.io/idZJsIaold/id9-VJM_HU.png"
|
||||
src='https://asset.brandfetch.io/idZJsIaold/id9-VJM_HU.png',
|
||||
),
|
||||
title=ft.Text("Dhiraagu"),
|
||||
title=ft.Text('Dhiraagu'),
|
||||
subtitle=ft.Text(
|
||||
"An ISP Service."
|
||||
'An ISP Service.',
|
||||
),
|
||||
),
|
||||
]
|
||||
],
|
||||
),
|
||||
padding=10,
|
||||
on_click=lambda _: print("clicked dhiraagu"),
|
||||
)
|
||||
on_click=lambda _: print('clicked dhiraagu'),
|
||||
),
|
||||
),
|
||||
ft.Card(
|
||||
content=ft.Container(
|
||||
@ -153,18 +154,18 @@ def Settings(page: ft.Page):
|
||||
leading=ft.Image(
|
||||
border_radius=ft.border_radius.all(10),
|
||||
fit=ft.ImageFit.CONTAIN,
|
||||
src="https://asset.brandfetch.io/idR1xFKHLD/idu6J-WQsm.jpeg"
|
||||
src='https://asset.brandfetch.io/idR1xFKHLD/idu6J-WQsm.jpeg',
|
||||
),
|
||||
title=ft.Text("Ooredoo"),
|
||||
title=ft.Text('Ooredoo'),
|
||||
subtitle=ft.Text(
|
||||
"An ISP Service."
|
||||
'An ISP Service.',
|
||||
),
|
||||
),
|
||||
]
|
||||
],
|
||||
),
|
||||
padding=10,
|
||||
on_click=lambda _: print("clicked ooredoo"),
|
||||
)
|
||||
on_click=lambda _: print('clicked ooredoo'),
|
||||
),
|
||||
),
|
||||
ft.Card(
|
||||
content=ft.Container(
|
||||
@ -175,18 +176,18 @@ def Settings(page: ft.Page):
|
||||
leading=ft.Image(
|
||||
border_radius=ft.border_radius.all(10),
|
||||
fit=ft.ImageFit.CONTAIN,
|
||||
src="https://www.stelco.com.mv/wp-content/uploads/2022/02/unnamed.png"
|
||||
src='https://www.stelco.com.mv/wp-content/uploads/2022/02/unnamed.png',
|
||||
),
|
||||
title=ft.Text("STELCO"),
|
||||
title=ft.Text('STELCO'),
|
||||
subtitle=ft.Text(
|
||||
"Electricity Bills"
|
||||
'Electricity Bills',
|
||||
),
|
||||
),
|
||||
]
|
||||
],
|
||||
),
|
||||
padding=10,
|
||||
on_click=lambda _: print("clicked stelco"),
|
||||
)
|
||||
on_click=lambda _: print('clicked stelco'),
|
||||
),
|
||||
),
|
||||
ft.Card(
|
||||
content=ft.Container(
|
||||
@ -197,18 +198,18 @@ def Settings(page: ft.Page):
|
||||
leading=ft.Image(
|
||||
border_radius=ft.border_radius.all(10),
|
||||
fit=ft.ImageFit.CONTAIN,
|
||||
src="https://asset.brandfetch.io/idOZWUOUm-/idNastd9Bg.jpeg"
|
||||
src='https://asset.brandfetch.io/idOZWUOUm-/idNastd9Bg.jpeg',
|
||||
),
|
||||
title=ft.Text("MWSC"),
|
||||
title=ft.Text('MWSC'),
|
||||
subtitle=ft.Text(
|
||||
"Water Bills"
|
||||
'Water Bills',
|
||||
),
|
||||
),
|
||||
]
|
||||
],
|
||||
),
|
||||
padding=10,
|
||||
on_click=lambda _: print("clicked mwsc"),
|
||||
)
|
||||
on_click=lambda _: print('clicked mwsc'),
|
||||
),
|
||||
),
|
||||
ft.Card(
|
||||
content=ft.Container(
|
||||
@ -219,25 +220,26 @@ def Settings(page: ft.Page):
|
||||
leading=ft.Image(
|
||||
border_radius=ft.border_radius.all(10),
|
||||
fit=ft.ImageFit.CONTAIN,
|
||||
src="https://asset.brandfetch.io/idLMZnv5SC/iduyX4keYN.jpeg"
|
||||
src='https://asset.brandfetch.io/idLMZnv5SC/iduyX4keYN.jpeg',
|
||||
),
|
||||
title=ft.Text("Medianet"),
|
||||
title=ft.Text('Medianet'),
|
||||
subtitle=ft.Text(
|
||||
"Online Television Service"
|
||||
'Online Television Service',
|
||||
),
|
||||
),
|
||||
]
|
||||
],
|
||||
),
|
||||
padding=10,
|
||||
on_click=lambda _: print("clicked medianet"),
|
||||
)
|
||||
on_click=lambda _: print('clicked medianet'),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
]
|
||||
)
|
||||
)
|
||||
settingsContainer.controls.append(appsSettings)
|
||||
settingsContainer.controls.append(ft.Divider())
|
||||
settingsContainer.controls.append(ft.Text("Theme"))
|
||||
settingsContainer.controls.append(ft.Text('Theme'))
|
||||
|
||||
def _on_theme_change(e):
|
||||
Theme(page).change()
|
||||
themeSettings = ft.Container(
|
||||
@ -248,29 +250,29 @@ def Settings(page: ft.Page):
|
||||
content=ft.Container(
|
||||
ft.Switch(
|
||||
value=True,
|
||||
label=" Switch to dark theme",
|
||||
on_change=_on_theme_change
|
||||
label=' Switch to dark theme',
|
||||
on_change=_on_theme_change,
|
||||
),
|
||||
),
|
||||
padding=10,
|
||||
on_click=None,
|
||||
)
|
||||
),
|
||||
]
|
||||
)
|
||||
),
|
||||
],
|
||||
),
|
||||
)
|
||||
settingsContainer.controls.append(themeSettings)
|
||||
return AppView(
|
||||
"/settings",
|
||||
'/settings',
|
||||
[
|
||||
ft.AppBar(
|
||||
leading=ft.IconButton(
|
||||
ft.icons.ARROW_BACK_IOS_NEW_ROUNDED,
|
||||
on_click=lambda _: page.go("/")
|
||||
on_click=lambda _: page.go('/'),
|
||||
),
|
||||
title=ft.Text(Title(str(__file__))),
|
||||
bgcolor=ft.colors.TRANSPARENT
|
||||
bgcolor=ft.colors.TRANSPARENT,
|
||||
),
|
||||
settingsContainer
|
||||
settingsContainer,
|
||||
],
|
||||
)
|
||||
|
@ -3,7 +3,7 @@ from .title import Title
|
||||
from .views import views_handler
|
||||
|
||||
__all__ = [
|
||||
"AppView",
|
||||
"Title",
|
||||
"views_handler"
|
||||
'AppView',
|
||||
'Title',
|
||||
'views_handler',
|
||||
]
|
@ -1,4 +1,5 @@
|
||||
import os
|
||||
|
||||
|
||||
def Title(title: str):
|
||||
return str(os.path.basename(title)).replace('.py', '').title()
|
@ -1,5 +1,6 @@
|
||||
import flet as ft
|
||||
|
||||
|
||||
class AppView(ft.View):
|
||||
def __init__(self, route, controls):
|
||||
super().__init__()
|
||||
|
@ -1,7 +1,8 @@
|
||||
from modules import Home, Settings
|
||||
|
||||
|
||||
def views_handler(page):
|
||||
return {
|
||||
'/': Home(page),
|
||||
'/settings': Settings(page)
|
||||
'/settings': Settings(page),
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user