
* Add allowed DNS list for killswitch * Windows killswitch strict mode backend part * Killswitch strict mode for Linux and MacOS * Windows fixes * feature: Add Kill Switch settings page with strict mode option * fix windows build after merge * Refresh killswitch mode when it toggled * Use HLM to store strictMode flag * Some Linux updates * feat: Enhance VerticalRadioButton with improved styling and disabled states * Refresh killSwitch state update * Fix build * refactor: Modularize header components * Change kill switch radio button styling * Fix strict kill switch mode handling * Refactor: Replace HeaderType with new Types for headers in QML pages * Remove deprecated HeaderType QML component * Refresh strict mode killswitch after global toggle change * Implement model, controller and UI for killswitch dns exceptions * Connect backend part and UI * Change label text to DNS exceptions * Remove HeaderType from PageSettingsApiDevices * Some pretty fixes * Fix problem with definition sequence of PageSettingsKillSwitchExceptions.pml elements * Add exclusion method for Windows firewall * Change ubuntu version in deploy script * Update ubuntu version in GH actions * Add confirmation popup for strict killswitch mode * Add qt standard path for build script * Add method to killswitch for expanding strickt mode exceptions list and fix allowTrafficTo() for Windows. Also Added cache in KillSwitch class for exceptions * Add insertion of gateway address to strict killswitch exceptions * Review fixes * buildfix and naming --------- Co-authored-by: aiamnezia <ai@amnezia.org>
73 lines
1.6 KiB
QML
73 lines
1.6 KiB
QML
import QtQuick
|
|
import QtQuick.Controls
|
|
import QtQuick.Layouts
|
|
|
|
import Style 1.0
|
|
import "../Controls2"
|
|
import "../Controls2/TextTypes"
|
|
|
|
Item {
|
|
id: root
|
|
|
|
property bool enabled: true
|
|
property string placeholderText: ""
|
|
property alias textField: searchField.textField
|
|
|
|
signal addClicked(string text)
|
|
signal moreClicked()
|
|
|
|
implicitWidth: 360
|
|
implicitHeight: 96
|
|
|
|
Rectangle {
|
|
id: background
|
|
anchors.fill: parent
|
|
color: "#0E0F12"
|
|
opacity: 0.85
|
|
z: -1
|
|
}
|
|
|
|
RowLayout {
|
|
id: addSiteButton
|
|
|
|
enabled: root.enabled
|
|
spacing: 2
|
|
|
|
anchors {
|
|
fill: parent
|
|
topMargin: 16
|
|
leftMargin: 16
|
|
rightMargin: 16
|
|
bottomMargin: 24
|
|
}
|
|
|
|
TextFieldWithHeaderType {
|
|
id: searchField
|
|
|
|
Layout.fillWidth: true
|
|
rightButtonClickedOnEnter: true
|
|
|
|
textField.placeholderText: root.placeholderText
|
|
buttonImageSource: "qrc:/images/controls/plus.svg"
|
|
|
|
clickedFunc: function() {
|
|
root.addClicked(textField.text)
|
|
textField.text = ""
|
|
}
|
|
}
|
|
|
|
ImageButtonType {
|
|
id: addSiteButtonImage
|
|
implicitWidth: 56
|
|
implicitHeight: 56
|
|
|
|
image: "qrc:/images/controls/more-vertical.svg"
|
|
imageColor: AmneziaStyle.color.paleGray
|
|
|
|
onClicked: root.moreClicked()
|
|
|
|
Keys.onReturnPressed: addSiteButtonImage.clicked()
|
|
Keys.onEnterPressed: addSiteButtonImage.clicked()
|
|
}
|
|
}
|
|
}
|