import QtQuick import QtQuick.Controls import QtQuick.Layouts import qs.Commons import qs.Services import qs.Widgets ColumnLayout { id: root spacing: 0 ScrollView { id: scrollView Layout.fillWidth: true Layout.fillHeight: true padding: Style.marginM * scaling clip: true ScrollBar.horizontal.policy: ScrollBar.AlwaysOff ScrollBar.vertical.policy: ScrollBar.AsNeeded ColumnLayout { width: scrollView.availableWidth spacing: 0 Item { Layout.fillWidth: true Layout.preferredHeight: 0 } ColumnLayout { spacing: Style.marginXS * scaling Layout.fillWidth: true NText { text: "Location" font.pointSize: Style.fontSizeXXL * scaling font.weight: Style.fontWeightBold color: Color.mOnSurface Layout.bottomMargin: Style.marginS * scaling } // Location section ColumnLayout { spacing: Style.marginM * scaling Layout.fillWidth: true Layout.topMargin: Style.marginS * scaling NTextInput { label: "Location name" description: "Choose a known location near you." text: Settings.data.location.name placeholderText: "Enter the location name" Layout.fillWidth: true onEditingFinished: { Settings.data.location.name = text LocationService.resetWeather() } } } NDivider { Layout.fillWidth: true Layout.topMargin: Style.marginL * 2 * scaling Layout.bottomMargin: Style.marginL * scaling } // Time section ColumnLayout { spacing: Style.marginL * scaling Layout.fillWidth: true NText { text: "Time Format" font.pointSize: Style.fontSizeXXL * scaling font.weight: Style.fontWeightBold color: Color.mOnSurface Layout.bottomMargin: Style.marginS * scaling } NToggle { label: "Use 12-Hour Clock" description: "Display time in 12-hour format (AM/PM) instead of 24-hour." checked: Settings.data.location.use12HourClock onToggled: checked => { Settings.data.location.use12HourClock = checked } } NToggle { label: "Reverse Day/Month" description: "Display date as DD/MM instead of MM/DD." checked: Settings.data.location.reverseDayMonth onToggled: checked => { Settings.data.location.reverseDayMonth = checked } } NToggle { label: "Show Date with Clock" description: "Display date alongside time (e.g., 18:12 - Sat, 23 Aug)." checked: Settings.data.location.showDateWithClock onToggled: checked => { Settings.data.location.showDateWithClock = checked } } } NDivider { Layout.fillWidth: true Layout.topMargin: Style.marginL * 2 * scaling Layout.bottomMargin: Style.marginL * scaling } // Weather section ColumnLayout { spacing: Style.marginM * scaling Layout.fillWidth: true NText { text: "Weather" font.pointSize: Style.fontSizeXXL * scaling font.weight: Style.fontWeightBold color: Color.mOnSurface Layout.bottomMargin: Style.marginS * scaling } NToggle { label: "Use Fahrenheit" description: "Display temperature in Fahrenheit instead of Celsius." checked: Settings.data.location.useFahrenheit onToggled: checked => { Settings.data.location.useFahrenheit = checked } } } } } } }