2016-10-07 17:41:59 +03:00
|
|
|
/*
|
2021-05-15 22:00:15 +03:00
|
|
|
Copyright (C) 2015-2021 Jolla Ltd.
|
|
|
|
Copyright (C) 2015-2021 Slava Monich <slava.monich@jolla.com>
|
2016-10-07 17:41:59 +03:00
|
|
|
|
|
|
|
You may use this file under the terms of BSD license as follows:
|
|
|
|
|
|
|
|
Redistribution and use in source and binary forms, with or without
|
|
|
|
modification, are permitted provided that the following conditions
|
|
|
|
are met:
|
2016-10-08 14:53:05 +03:00
|
|
|
|
2020-10-10 19:02:42 +03:00
|
|
|
1. Redistributions of source code must retain the above copyright
|
|
|
|
notice, this list of conditions and the following disclaimer.
|
|
|
|
2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
notice, this list of conditions and the following disclaimer
|
|
|
|
in the documentation and/or other materials provided with the
|
|
|
|
distribution.
|
|
|
|
3. Neither the names of the copyright holders nor the names of its
|
|
|
|
contributors may be used to endorse or promote products derived
|
|
|
|
from this software without specific prior written permission.
|
2016-10-07 17:41:59 +03:00
|
|
|
|
|
|
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
|
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS
|
|
|
|
BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
|
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
|
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
|
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
|
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
|
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
|
|
|
|
THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
import QtQuick 2.0
|
|
|
|
import Sailfish.Silica 1.0
|
|
|
|
import org.nemomobile.configuration 1.0
|
|
|
|
|
2020-10-23 01:21:24 +03:00
|
|
|
import "../qml/Books.js" as Books
|
|
|
|
import "../qml/harbour"
|
|
|
|
|
2016-10-07 17:41:59 +03:00
|
|
|
Page {
|
|
|
|
id: page
|
2016-10-07 19:40:18 +03:00
|
|
|
property bool followOrientationChanges
|
2016-10-07 17:41:59 +03:00
|
|
|
property alias title: pageHeader.title
|
|
|
|
readonly property string rootPath: "/apps/" + appName() + "/"
|
2020-10-23 01:21:24 +03:00
|
|
|
readonly property bool darkOnLight: ('colorScheme' in Theme) && Theme.colorScheme === 1
|
2020-10-26 04:52:20 +03:00
|
|
|
readonly property bool landscapeLayout: (width > height && Screen.sizeCategory > Screen.Small) || Screen.sizeCategory > Screen.Medium
|
2016-10-07 17:41:59 +03:00
|
|
|
|
|
|
|
// Deduce package name from the path
|
|
|
|
function appName() {
|
|
|
|
var parts = Qt.resolvedUrl("dummy").split('/')
|
|
|
|
if (parts.length > 2) {
|
|
|
|
var name = parts[parts.length-3]
|
2016-10-07 19:40:18 +03:00
|
|
|
if (name.indexOf("-books") >= 0) {
|
2016-10-07 17:41:59 +03:00
|
|
|
return name
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return "harbour-books"
|
|
|
|
}
|
|
|
|
|
2016-10-07 19:40:18 +03:00
|
|
|
Loader {
|
|
|
|
active: followOrientationChanges
|
|
|
|
Connections {
|
|
|
|
target: orientation
|
|
|
|
onValueChanged: allowedOrientations =
|
|
|
|
(orientation.value === 1) ? Orientation.Portrait :
|
|
|
|
(orientation.value === 2) ? Orientation.Landscape :
|
2016-10-08 14:53:05 +03:00
|
|
|
Orientation.All
|
2016-10-07 19:40:18 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-10-07 17:41:59 +03:00
|
|
|
SilicaFlickable {
|
|
|
|
anchors.fill: parent
|
|
|
|
contentHeight: content.height
|
|
|
|
|
2020-10-23 01:21:24 +03:00
|
|
|
// Night mode example (positioned right above the slider)
|
|
|
|
Rectangle {
|
|
|
|
opacity: nightModeBrightnessSlider.pressed ? 1.0 : 0
|
|
|
|
visible: opacity > 0
|
|
|
|
radius: Theme.paddingSmall
|
|
|
|
width: nightModeExampleLabel.width + 2 * Theme.paddingLarge
|
|
|
|
height: nightModeExampleLabel.height + 2 * Theme.paddingMedium
|
|
|
|
readonly property int xMin: nightModeBrightnessSlider.leftMargin
|
|
|
|
readonly property int xMax: content.width - nightModeBrightnessSlider.rightMargin - width
|
2020-10-26 04:52:20 +03:00
|
|
|
readonly property int yOffset: landscapeLayout ? (Theme.itemSizeExtraLarge - Theme.itemSizeMedium) : 0
|
|
|
|
x: content.x + displayGrid.x + Math.max(Math.min(nightModeBrightnessSlider.sliderLeft + Math.round(nightModeBrightnessSlider.sliderThumbX - width/2.0), xMax), xMin)
|
|
|
|
y: content.y + displayGrid.y + nightModeBrightnessSlider.y + yOffset - height
|
2020-10-23 01:21:24 +03:00
|
|
|
z: nightModeBrightnessSlider.z + 1
|
|
|
|
color: "black"
|
|
|
|
border {
|
|
|
|
color: Theme.highlightColor
|
|
|
|
width: Math.ceil(radius/5)
|
|
|
|
}
|
|
|
|
|
|
|
|
Label {
|
|
|
|
id: nightModeExampleLabel
|
|
|
|
|
|
|
|
anchors.centerIn: parent
|
|
|
|
color: "white"
|
|
|
|
opacity: Books.contentOpacity(nightModeBrightness.value)
|
|
|
|
//: Night mode example label
|
|
|
|
//% "Night mode"
|
|
|
|
text: qsTrId("harbour-books-settings-page-night_mode_example")
|
|
|
|
font {
|
|
|
|
bold: true
|
|
|
|
pixelSize: Theme.fontSizeLarge
|
|
|
|
family: "Times"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Behavior on x { SmoothedAnimation { duration: 125 } }
|
|
|
|
Behavior on opacity { FadeAnimation { duration: 500 } }
|
|
|
|
}
|
|
|
|
|
2016-10-07 17:41:59 +03:00
|
|
|
Column {
|
|
|
|
id: content
|
|
|
|
width: parent.width
|
|
|
|
|
|
|
|
PageHeader {
|
|
|
|
id: pageHeader
|
|
|
|
//: Settings page header
|
|
|
|
//% "Books"
|
2016-10-07 18:47:27 +03:00
|
|
|
title: qsTrId("harbour-books-settings-page-header")
|
2016-10-07 17:41:59 +03:00
|
|
|
}
|
|
|
|
|
2018-07-24 00:29:52 +03:00
|
|
|
// =============== Display ===============
|
|
|
|
|
2017-08-08 16:09:01 +03:00
|
|
|
SectionHeader {
|
|
|
|
//: Section header for display settings
|
|
|
|
//% "Display"
|
|
|
|
text: qsTrId("harbour-books-settings-page-display-section_header")
|
|
|
|
}
|
|
|
|
|
2020-10-26 04:52:20 +03:00
|
|
|
Grid {
|
|
|
|
id: displayGrid
|
2016-10-07 19:40:18 +03:00
|
|
|
|
2020-10-23 01:21:24 +03:00
|
|
|
width: parent.width
|
2020-10-26 04:52:20 +03:00
|
|
|
columns: landscapeLayout ? 2 : 1
|
|
|
|
|
|
|
|
readonly property real columnWidth: width/columns
|
|
|
|
|
|
|
|
Slider {
|
|
|
|
id: fontSizeSlider
|
|
|
|
|
|
|
|
minimumValue: -5
|
|
|
|
maximumValue: 15
|
|
|
|
stepSize: 1
|
|
|
|
width: parent.columnWidth
|
|
|
|
leftMargin: landscapeLayout ? Theme.horizontalPageMargin : nightModeBrightnessSlider.leftMargin
|
|
|
|
rightMargin: leftMargin
|
|
|
|
//: Slider value label for the standard font size
|
|
|
|
//% "Default"
|
|
|
|
readonly property string normal: qsTrId("harbour-books-settings-page-font_size_label-default")
|
|
|
|
//: Slider label
|
|
|
|
//% "Font size"
|
|
|
|
label: qsTrId("harbour-books-settings-page-font_size_label")
|
|
|
|
valueText: (value === 0) ? normal : ((value > 0) ? ("+" + value) : value)
|
|
|
|
onSliderValueChanged: fontSize.value = value
|
|
|
|
Component.onCompleted: value = fontSize.value
|
|
|
|
|
|
|
|
ConfigurationValue {
|
|
|
|
id: fontSize
|
|
|
|
key: rootPath + "fontSize"
|
|
|
|
defaultValue: 0
|
|
|
|
onValueChanged: fontSizeSlider.value = value
|
2020-10-23 01:21:24 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-10-26 04:52:20 +03:00
|
|
|
Slider {
|
|
|
|
id: nightModeBrightnessSlider
|
|
|
|
|
|
|
|
width: parent.columnWidth
|
|
|
|
leftMargin: keepDisplayOnSwitch.leftMargin - Theme.paddingLarge + Theme.itemSizeExtraSmall
|
|
|
|
rightMargin: leftMargin
|
|
|
|
//: Slider label
|
|
|
|
//% "Brightness in night mode"
|
|
|
|
label: qsTrId("harbour-books-settings-page-night_mode_brightness_label")
|
|
|
|
stepSize: (maximumValue - minimumValue) / 100.0
|
|
|
|
onSliderValueChanged: nightModeBrightness.value = value
|
|
|
|
value: nightModeBrightness.value
|
|
|
|
valueText: landscapeLayout ? " " : ""
|
|
|
|
|
|
|
|
readonly property real sliderLeft: x + leftMargin
|
|
|
|
readonly property real sliderRight: x + width - rightMargin
|
|
|
|
readonly property real sliderWidth: width - leftMargin - rightMargin
|
|
|
|
readonly property real sliderThumbX: sliderLeft + (maximumValue > minimumValue) ? (sliderWidth * sliderValue / (maximumValue - minimumValue)) : 0
|
|
|
|
readonly property real sliderBarVerticalCenter: Math.round(height - Theme.fontSizeSmall - Theme.paddingSmall - Theme.itemSizeExtraSmall*3/8)
|
|
|
|
readonly property color highlightColor: highlighted ? Theme.secondaryHighlightColor : Theme.secondaryColor
|
|
|
|
|
|
|
|
ConfigurationValue {
|
|
|
|
id: nightModeBrightness
|
|
|
|
key: rootPath + "nightModeBrightness"
|
|
|
|
defaultValue: 1
|
2020-10-23 01:21:24 +03:00
|
|
|
}
|
|
|
|
|
2020-10-26 04:52:20 +03:00
|
|
|
HarbourHighlightIcon {
|
|
|
|
source: "images/brightness.svg"
|
|
|
|
y: nightModeBrightnessSlider.sliderBarVerticalCenter - Math.round(height/2)
|
|
|
|
anchors {
|
|
|
|
left: parent.left
|
|
|
|
leftMargin: nightModeBrightnessSlider.leftMargin - Theme.paddingSmall - width
|
|
|
|
}
|
|
|
|
sourceSize.height: Math.round(Theme.iconSizeSmall * 0.8)
|
|
|
|
highlightColor: nightModeBrightnessSlider.highlightColor
|
|
|
|
opacity: (darkOnLight && !nightModeBrightnessSlider.highlighted) ? 0.6 : 1.0
|
2016-10-07 19:40:18 +03:00
|
|
|
}
|
2020-10-26 04:52:20 +03:00
|
|
|
|
|
|
|
HarbourHighlightIcon {
|
|
|
|
source: "images/brightness.svg"
|
|
|
|
y: nightModeBrightnessSlider.sliderBarVerticalCenter - Math.round(height/2)
|
|
|
|
anchors {
|
|
|
|
right: parent.right
|
|
|
|
rightMargin: nightModeBrightnessSlider.rightMargin - Theme.paddingSmall - width
|
2016-10-07 19:40:18 +03:00
|
|
|
}
|
2020-10-26 04:52:20 +03:00
|
|
|
sourceSize.height: Math.round(Theme.iconSizeSmall * 1.2)
|
|
|
|
highlightColor: nightModeBrightnessSlider.highlightColor
|
|
|
|
opacity: (darkOnLight && !nightModeBrightnessSlider.highlighted) ? 0.6 : 1.0
|
2016-10-07 19:40:18 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2016-10-23 19:09:59 +03:00
|
|
|
|
2020-10-26 04:52:20 +03:00
|
|
|
Grid {
|
|
|
|
width: parent.width
|
|
|
|
columns: landscapeLayout ? 2 : 1
|
|
|
|
flow: Grid.TopToBottom
|
|
|
|
|
|
|
|
readonly property real columnWidth: width/columns
|
|
|
|
|
|
|
|
Column {
|
|
|
|
width: parent.columnWidth
|
|
|
|
|
|
|
|
ComboBox {
|
|
|
|
id: orientationComboBox
|
|
|
|
|
|
|
|
//: Combo box label
|
|
|
|
//% "Orientation"
|
|
|
|
label: qsTrId("harbour-books-settings-page-orientation_label")
|
|
|
|
value: currentItem ? currentItem.text : ""
|
|
|
|
menu: ContextMenu {
|
|
|
|
id: orientationMenu
|
|
|
|
|
2020-11-17 21:17:33 +03:00
|
|
|
x: 0
|
|
|
|
width: orientationComboBox.width
|
2020-10-26 04:52:20 +03:00
|
|
|
readonly property int defaultIndex: 0
|
|
|
|
MenuItem {
|
|
|
|
readonly property int value: 0
|
|
|
|
//: Combo box value for dynamic orientation
|
|
|
|
//% "Dynamic"
|
|
|
|
text: qsTrId("harbour-books-settings-page-orientation-dynamic")
|
|
|
|
onClicked: orientation.value = value
|
|
|
|
}
|
|
|
|
MenuItem {
|
|
|
|
readonly property int value: 1
|
|
|
|
//: Combo box value for portrait orientation
|
|
|
|
//% "Portrait"
|
|
|
|
text: qsTrId("harbour-books-settings-page-orientation-portrait")
|
|
|
|
onClicked: orientation.value = value
|
|
|
|
}
|
|
|
|
MenuItem {
|
|
|
|
readonly property int value: 2
|
|
|
|
//: Combo box value for landscape orientation
|
|
|
|
//% "Landscape"
|
|
|
|
text: qsTrId("harbour-books-settings-page-orientation-landscape")
|
|
|
|
onClicked: orientation.value = value
|
|
|
|
}
|
2018-07-23 15:17:22 +03:00
|
|
|
}
|
2020-10-26 04:52:20 +03:00
|
|
|
Component.onCompleted: orientation.updateControls()
|
|
|
|
ConfigurationValue {
|
|
|
|
id: orientation
|
|
|
|
key: rootPath + "orientation"
|
|
|
|
defaultValue: 0
|
|
|
|
onValueChanged: updateControls()
|
|
|
|
function updateControls() {
|
|
|
|
var n = orientationMenu.children.length
|
|
|
|
var index = orientationMenu.defaultIndex
|
|
|
|
for (var i=0; i<n; i++) {
|
|
|
|
if (orientationMenu.children[i].value === value) {
|
|
|
|
index = i
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
orientationComboBox.currentIndex = index
|
|
|
|
}
|
2018-07-23 15:17:22 +03:00
|
|
|
}
|
|
|
|
}
|
2020-10-26 04:52:20 +03:00
|
|
|
|
|
|
|
ComboBox {
|
|
|
|
id: layoutComboBox
|
|
|
|
|
|
|
|
//: Combo box label
|
|
|
|
//% "Page layout"
|
|
|
|
label: qsTrId("harbour-books-settings-page-page_layout")
|
|
|
|
value: currentItem ? currentItem.valueText : ""
|
|
|
|
readonly property int yBottom: y + Theme.itemSizeSmall
|
|
|
|
menu: ContextMenu {
|
2020-11-17 21:17:33 +03:00
|
|
|
x: 0
|
|
|
|
width: layoutComboBox.width
|
2020-10-26 04:52:20 +03:00
|
|
|
readonly property int defaultIndex: 0
|
|
|
|
BooksDetailMenuItem {
|
|
|
|
//: Combo box value for dynamic page layout
|
|
|
|
//% "Dynamic"
|
|
|
|
valueText: qsTrId("harbour-books-settings-page-layout-dynamic")
|
|
|
|
//: Combo box detail for dynamic page layout
|
|
|
|
//% "(toggle on tap)"
|
|
|
|
detailText: qsTrId("harbour-books-settings-page-layout-dynamic-detail")
|
|
|
|
onClicked: pageDetailsFixed.value = false
|
|
|
|
}
|
|
|
|
BooksDetailMenuItem {
|
|
|
|
//: Combo box value for clean page layout (just the content)
|
|
|
|
//% "Clean"
|
|
|
|
valueText: qsTrId("harbour-books-settings-page-layout-clean")
|
|
|
|
//: Combo box detail for clean page layout (just the content)
|
|
|
|
//% "(just the content)"
|
|
|
|
detailText: qsTrId("harbour-books-settings-page-layout-clean-detail")
|
|
|
|
onClicked: {
|
|
|
|
pageDetailsFixed.value = true
|
|
|
|
pageDetails.value = 0
|
|
|
|
}
|
|
|
|
}
|
|
|
|
BooksDetailMenuItem {
|
|
|
|
//: Combo box value for minimal page layout (title + page)
|
|
|
|
//% "Minimal"
|
|
|
|
valueText: qsTrId("harbour-books-settings-page-layout-minimal")
|
|
|
|
//: Combo box detail for minimal page layout (title + page)
|
|
|
|
//% "(title, page)"
|
|
|
|
detailText: qsTrId("harbour-books-settings-page-layout-minimal-detail")
|
|
|
|
onClicked: {
|
|
|
|
pageDetailsFixed.value = true
|
|
|
|
pageDetails.value = 1
|
|
|
|
}
|
|
|
|
}
|
|
|
|
BooksDetailMenuItem {
|
|
|
|
//: Combo box value for normal page layout (title + page + slider)
|
|
|
|
//% "Regular"
|
|
|
|
valueText: qsTrId("harbour-books-settings-page-layout-normal")
|
|
|
|
//: Combo box detail for normal page layout (title + page + slider)
|
|
|
|
//% "(title, page, slider)"
|
|
|
|
detailText: qsTrId("harbour-books-settings-page-layout-normal-detail")
|
|
|
|
onClicked: {
|
|
|
|
pageDetailsFixed.value = true
|
|
|
|
pageDetails.value = 2
|
|
|
|
}
|
|
|
|
}
|
|
|
|
BooksDetailMenuItem {
|
|
|
|
//: Combo box value for full page layout (title + page + slider)
|
|
|
|
//% "Full"
|
|
|
|
valueText: qsTrId("harbour-books-settings-page-layout-full")
|
|
|
|
//: Combo box detail for full page layout (title + page + slider)
|
|
|
|
//% "(everything)"
|
|
|
|
detailText: qsTrId("harbour-books-settings-page-layout-full-detail")
|
|
|
|
onClicked: {
|
|
|
|
pageDetailsFixed.value = true
|
|
|
|
pageDetails.value = 3
|
|
|
|
}
|
|
|
|
}
|
2018-07-23 15:17:22 +03:00
|
|
|
}
|
2020-10-26 04:52:20 +03:00
|
|
|
Component.onCompleted: updateSelectedItem()
|
|
|
|
function updateSelectedItem() {
|
|
|
|
currentIndex = pageDetailsFixed.value ? (pageDetails.value + 1) : 0
|
|
|
|
}
|
|
|
|
ConfigurationValue {
|
|
|
|
id: pageDetails
|
|
|
|
key: rootPath + "pageDetails"
|
|
|
|
defaultValue: 0
|
|
|
|
onValueChanged: layoutComboBox.updateSelectedItem()
|
|
|
|
}
|
|
|
|
ConfigurationValue {
|
|
|
|
id: pageDetailsFixed
|
|
|
|
key: rootPath + "pageDetailsFixed"
|
|
|
|
defaultValue: false
|
|
|
|
onValueChanged: layoutComboBox.updateSelectedItem()
|
2018-07-23 15:17:22 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-10-26 04:52:20 +03:00
|
|
|
TextSwitch {
|
|
|
|
id: keepDisplayOnSwitch
|
|
|
|
|
|
|
|
width: parent.columnWidth
|
|
|
|
automaticCheck: false
|
|
|
|
checked: keepDisplayOn.value
|
|
|
|
//: Text switch label
|
|
|
|
//% "Keep display on while reading"
|
|
|
|
text: qsTrId("harbour-books-settings-page-keep_display_on")
|
|
|
|
//: Text switch description
|
|
|
|
//% "Prevent the display from blanking while reading the book."
|
|
|
|
description: qsTrId("harbour-books-settings-page-keep_display_on_description")
|
|
|
|
onClicked: keepDisplayOn.value = !keepDisplayOn.value
|
|
|
|
ConfigurationValue {
|
|
|
|
id: keepDisplayOn
|
|
|
|
key: rootPath + "keepDisplayOn"
|
|
|
|
defaultValue: false
|
|
|
|
}
|
2018-05-17 11:52:04 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-07-24 00:29:52 +03:00
|
|
|
// =============== Navigation ===============
|
|
|
|
|
2017-08-08 16:09:01 +03:00
|
|
|
SectionHeader {
|
|
|
|
//: Section header for media keys
|
2018-07-24 00:29:52 +03:00
|
|
|
//% "Navigation"
|
|
|
|
text: qsTrId("harbour-books-settings-page-navigation-section_header")
|
2017-08-08 16:09:01 +03:00
|
|
|
}
|
|
|
|
|
2020-10-26 04:52:20 +03:00
|
|
|
Grid {
|
|
|
|
width: parent.width
|
|
|
|
columns: landscapeLayout ? 2 : 1
|
|
|
|
flow: Grid.TopToBottom
|
2017-08-08 16:09:01 +03:00
|
|
|
|
2020-10-26 04:52:20 +03:00
|
|
|
readonly property real columnWidth: width/columns
|
|
|
|
|
|
|
|
Column {
|
|
|
|
width: parent.columnWidth
|
|
|
|
|
|
|
|
BooksActionSelector {
|
|
|
|
//: Combo box label
|
|
|
|
//% "Volume up"
|
|
|
|
label: qsTrId("harbour-books-settings-page-volume_up-label")
|
|
|
|
key: rootPath + "volumeUpAction"
|
|
|
|
defaultValue: 2 // BooksSettings.ActionNextPage
|
|
|
|
}
|
2017-08-08 16:09:01 +03:00
|
|
|
|
2020-10-26 04:52:20 +03:00
|
|
|
BooksActionSelector {
|
|
|
|
//: Combo box label
|
|
|
|
//% "Volume down"
|
|
|
|
label: qsTrId("harbour-books-settings-page-volume_down-label")
|
|
|
|
key: rootPath + "volumeDownAction"
|
|
|
|
defaultValue: 1 // BooksSettings.ActionPreviousPage
|
|
|
|
readonly property int yBottom: y + Theme.itemSizeSmall
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
TextSwitch {
|
|
|
|
width: parent.columnWidth
|
|
|
|
automaticCheck: false
|
|
|
|
checked: turnPageByTap.value
|
|
|
|
//: Text switch label
|
|
|
|
//% "Turn pages by tapping the screen"
|
|
|
|
text: qsTrId("harbour-books-settings-page-turn_pages_by_tap")
|
|
|
|
//: Text switch description
|
|
|
|
//% "Tapping near the left edge of the screen returns to the previous page, tapping near the right edge gets you to the next page."
|
|
|
|
description: qsTrId("harbour-books-settings-page-turn_pages_by_tap-description")
|
|
|
|
onClicked: turnPageByTap.value = !turnPageByTap.value
|
|
|
|
ConfigurationValue {
|
|
|
|
id: turnPageByTap
|
|
|
|
key: rootPath + "turnPageByTap"
|
|
|
|
defaultValue: false
|
|
|
|
}
|
2018-07-24 00:29:52 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// =============== Memory card ===============
|
|
|
|
|
2016-10-23 19:09:59 +03:00
|
|
|
SectionHeader {
|
|
|
|
//: Section header for memory card settings
|
|
|
|
//% "Memory card"
|
|
|
|
text: qsTrId("harbour-books-settings-page-removable-section_header")
|
|
|
|
}
|
|
|
|
|
|
|
|
TextField {
|
|
|
|
id: removableRootField
|
|
|
|
width: parent.width
|
|
|
|
labelVisible: false
|
|
|
|
|
|
|
|
Component.onCompleted: text = removableRoot.value
|
|
|
|
onActiveFocusChanged: removableRoot.value = text
|
|
|
|
EnterKey.onClicked: page.focus = true
|
|
|
|
EnterKey.iconSource: "image://theme/icon-m-enter-close"
|
|
|
|
|
|
|
|
ConfigurationValue {
|
|
|
|
id: removableRoot
|
|
|
|
key: rootPath + "removableRoot"
|
|
|
|
defaultValue: "Books"
|
|
|
|
onValueChanged: removableRootField.text = value
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Label {
|
|
|
|
id: removableRootLabel
|
|
|
|
//: Settings field label
|
|
|
|
//% "Books folder"
|
|
|
|
text: qsTrId("harbour-books-settings-page-removable_root-label")
|
|
|
|
x: removableRootField.textLeftMargin
|
|
|
|
width: removableRootField.width - removableRootField.textLeftMargin - removableRootField.textRightMargin
|
|
|
|
height: text.length ? (implicitHeight + Theme.paddingMedium) : 0
|
|
|
|
anchors {
|
|
|
|
topMargin: -Theme.paddingSmall
|
|
|
|
bottomMargin: Theme.paddingMedium
|
|
|
|
}
|
|
|
|
color: removableRootField.activeFocus ? Theme.highlightColor : Theme.primaryColor
|
|
|
|
opacity: removableRootField.activeFocus ? 1.0 : 0.6
|
|
|
|
elide: Text.ElideRight
|
|
|
|
font.pixelSize: Theme.fontSizeSmall
|
|
|
|
}
|
|
|
|
|
|
|
|
Label {
|
|
|
|
//: Settings field description
|
|
|
|
//% "Leave the folder name empty to scan the entire memory card for books."
|
|
|
|
text: qsTrId("harbour-books-settings-page-removable_root-description")
|
|
|
|
height: text.length ? (implicitHeight + Theme.paddingMedium) : 0
|
|
|
|
width: removableRootLabel.width
|
|
|
|
x: removableRootLabel.x
|
|
|
|
font.pixelSize: Theme.fontSizeExtraSmall
|
|
|
|
color: Theme.secondaryColor
|
|
|
|
wrapMode: Text.Wrap
|
|
|
|
}
|
2016-10-07 17:41:59 +03:00
|
|
|
}
|
2021-05-15 22:00:15 +03:00
|
|
|
|
|
|
|
VerticalScrollDecorator { }
|
2016-10-07 17:41:59 +03:00
|
|
|
}
|
|
|
|
}
|