Can't continue without selecting disk
This commit is contained in:
@@ -68,8 +68,7 @@ class StoragePage(Adw.Bin):
|
|||||||
if not self.first_radio:
|
if not self.first_radio:
|
||||||
radio = Gtk.CheckButton()
|
radio = Gtk.CheckButton()
|
||||||
self.first_radio = radio
|
self.first_radio = radio
|
||||||
# Default selection
|
# No default selection to force user interaction, for safety reasons
|
||||||
self.selected_disk = dev
|
|
||||||
else:
|
else:
|
||||||
radio = Gtk.CheckButton()
|
radio = Gtk.CheckButton()
|
||||||
radio.set_group(self.first_radio)
|
radio.set_group(self.first_radio)
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ gi.require_version("Gtk", "4.0")
|
|||||||
gi.require_version("Adw", "1")
|
gi.require_version("Adw", "1")
|
||||||
from gi.repository import Adw, Gtk
|
from gi.repository import Adw, Gtk
|
||||||
|
|
||||||
|
from .pages.additional_modules import ModulesPage
|
||||||
from .pages.install_mode import InstallModePage
|
from .pages.install_mode import InstallModePage
|
||||||
from .pages.partitioning import PartitioningPage, calculate_auto_partitions
|
from .pages.partitioning import PartitioningPage, calculate_auto_partitions
|
||||||
from .pages.storage import StoragePage
|
from .pages.storage import StoragePage
|
||||||
@@ -66,6 +67,7 @@ class InstallerWindow(Adw.ApplicationWindow):
|
|||||||
self.storage_page = StoragePage()
|
self.storage_page = StoragePage()
|
||||||
self.install_mode_page = InstallModePage()
|
self.install_mode_page = InstallModePage()
|
||||||
self.partitioning_page = PartitioningPage()
|
self.partitioning_page = PartitioningPage()
|
||||||
|
self.modules_page = ModulesPage()
|
||||||
self.user_page = UserPage()
|
self.user_page = UserPage()
|
||||||
|
|
||||||
# Add Pages
|
# Add Pages
|
||||||
@@ -73,6 +75,7 @@ class InstallerWindow(Adw.ApplicationWindow):
|
|||||||
self.add_page(self.storage_page, "storage")
|
self.add_page(self.storage_page, "storage")
|
||||||
self.add_page(self.install_mode_page, "install_mode")
|
self.add_page(self.install_mode_page, "install_mode")
|
||||||
self.add_page(self.partitioning_page, "partitioning")
|
self.add_page(self.partitioning_page, "partitioning")
|
||||||
|
self.add_page(self.modules_page, "modules")
|
||||||
self.add_page(self.user_page, "user")
|
self.add_page(self.user_page, "user")
|
||||||
|
|
||||||
# Initialize view
|
# Initialize view
|
||||||
@@ -99,19 +102,18 @@ class InstallerWindow(Adw.ApplicationWindow):
|
|||||||
|
|
||||||
def on_back_clicked(self, button):
|
def on_back_clicked(self, button):
|
||||||
current_page = self.page_ids[self.current_page_index]
|
current_page = self.page_ids[self.current_page_index]
|
||||||
prev_page = self.page_ids[self.current_page_index - 1]
|
|
||||||
|
|
||||||
if current_page == "user":
|
# Default: go back one page
|
||||||
|
next_prev_index = self.current_page_index - 1
|
||||||
|
|
||||||
|
if current_page == "modules":
|
||||||
mode = self.install_mode_page.get_mode()
|
mode = self.install_mode_page.get_mode()
|
||||||
if mode == "automatic":
|
if mode == "automatic":
|
||||||
# Skip partitioning
|
# Skip partitioning (which is immediately before modules)
|
||||||
self.current_page_index = self.page_ids.index("install_mode")
|
next_prev_index = self.page_ids.index("install_mode")
|
||||||
else:
|
|
||||||
self.current_page_index -= 1
|
|
||||||
else:
|
|
||||||
if self.current_page_index > 0:
|
|
||||||
self.current_page_index -= 1
|
|
||||||
|
|
||||||
|
if next_prev_index >= 0:
|
||||||
|
self.current_page_index = next_prev_index
|
||||||
self.stack.set_visible_child_name(self.page_ids[self.current_page_index])
|
self.stack.set_visible_child_name(self.page_ids[self.current_page_index])
|
||||||
self.update_buttons()
|
self.update_buttons()
|
||||||
|
|
||||||
@@ -121,7 +123,16 @@ class InstallerWindow(Adw.ApplicationWindow):
|
|||||||
|
|
||||||
if current_page_name == "storage":
|
if current_page_name == "storage":
|
||||||
selected_disk = self.storage_page.get_selected_disk()
|
selected_disk = self.storage_page.get_selected_disk()
|
||||||
if selected_disk:
|
if not selected_disk:
|
||||||
|
dialog = Adw.MessageDialog(
|
||||||
|
transient_for=self,
|
||||||
|
heading="No Disk Selected",
|
||||||
|
body="Please select a storage device to proceed."
|
||||||
|
)
|
||||||
|
dialog.add_response("ok", "OK")
|
||||||
|
dialog.present()
|
||||||
|
return
|
||||||
|
|
||||||
self.partitioning_page.load_partitions(selected_disk)
|
self.partitioning_page.load_partitions(selected_disk)
|
||||||
|
|
||||||
next_index = self.current_page_index + 1
|
next_index = self.current_page_index + 1
|
||||||
@@ -130,7 +141,7 @@ class InstallerWindow(Adw.ApplicationWindow):
|
|||||||
mode = self.install_mode_page.get_mode()
|
mode = self.install_mode_page.get_mode()
|
||||||
if mode == "automatic":
|
if mode == "automatic":
|
||||||
# Skip partitioning page
|
# Skip partitioning page
|
||||||
next_index = self.page_ids.index("user")
|
next_index = self.page_ids.index("modules")
|
||||||
else:
|
else:
|
||||||
# Go to partitioning page
|
# Go to partitioning page
|
||||||
next_index = self.page_ids.index("partitioning")
|
next_index = self.page_ids.index("partitioning")
|
||||||
@@ -141,6 +152,8 @@ class InstallerWindow(Adw.ApplicationWindow):
|
|||||||
print(f"Disk: {disk}")
|
print(f"Disk: {disk}")
|
||||||
mode = self.install_mode_page.get_mode()
|
mode = self.install_mode_page.get_mode()
|
||||||
print(f"Mode: {mode}")
|
print(f"Mode: {mode}")
|
||||||
|
modules = self.modules_page.get_modules()
|
||||||
|
print(f"Modules: {modules}")
|
||||||
|
|
||||||
partitions_config = {}
|
partitions_config = {}
|
||||||
if mode == "manual":
|
if mode == "manual":
|
||||||
|
|||||||
Reference in New Issue
Block a user