mirror of
https://github.com/overte-org/overte.git
synced 2025-04-27 22:15:52 +02:00
* canRez(Tmp)Certified() * CertifiedItem beginnings * Skeleton of verifyOwnerChallenge() * Controlled failure; updateLocation() skeletion * Controlled failure on checkout page with ctrl+f * Skeleton Purchases first-use tutorial * Initial progress on new setup * Security pic tip * Skeleton Certificate page * Updates to Certificate * General progress; setup is nearly complete * Better buttons; last step almost done * Initial progress on wallet home * Completed recent transactions * Security page * Scrollbar * Fix auth error text * PassphraseSelection * Change security pic * Minor layout changes; beginnings of emulated header * Various layout changes; wallet nav bar * Help screen * Quick onaccepted change * First pass at new purchases * Small style updates * Some error progress * Lightbox in purchases * Collapse other help answers when clicking on another * REZZED notif * Commerce Lightbox * Lots of new interactions in Purchases * Hook up 'view certificate' * Fix errors, fix close button on cert * Purchases timer; much faster filter * Add debugCheckout * Purchase updates * GlyphButton; separator; Checkout Success; Ledger fix; debug modes * Lock glyph below security pic should be white * Various fixes, round 1 * Circular mask * Passphrase change button fix; TextField error edge highlighting * Recent Activity fixes * Various changes * Standard Security Pic location * Color changes * Filter bar changes * Styling for multiple owned items * Minor language change * Header dropdown (harder than expected) * Small fixes * View backup instructions * marketplaces.js onCommerceScreen * Beginnign of new injection * Marketplace injection changes * Purchase button style changes * More button styling * MY PURCHASES button * marketplace onUsernameChanged * New help QA * Help text changes etc * Downscale security image, reducing filesize * Lots of bugfixes * Cleanup before PR * Only open cert during inspection if commerce switch is on * Help text changes * Purchase status incl. change to confirmed; Help text; Open Explorer to hifikey * Quick glyph change * New 'wallet not set up' flow for when entering Purchases or Checkout without set-up wallet
133 lines
4.7 KiB
QML
133 lines
4.7 KiB
QML
//
|
|
// TextField.qml
|
|
//
|
|
// Created by David Rowe on 17 Feb 2016
|
|
// Copyright 2016 High Fidelity, Inc.
|
|
//
|
|
// Distributed under the Apache License, Version 2.0.
|
|
// See the accompanying file LICENSE or http://www.apache.org/licenses/LICENSE-2.0.html
|
|
//
|
|
|
|
import QtQuick 2.5
|
|
import QtQuick.Controls 1.4
|
|
import QtQuick.Controls.Styles 1.4
|
|
|
|
import "../styles-uit"
|
|
import "../controls-uit" as HifiControls
|
|
|
|
TextField {
|
|
id: textField
|
|
|
|
property int colorScheme: hifi.colorSchemes.light
|
|
readonly property bool isLightColorScheme: colorScheme == hifi.colorSchemes.light
|
|
readonly property bool isFaintGrayColorScheme: colorScheme == hifi.colorSchemes.faintGray
|
|
property bool isSearchField: false
|
|
property string label: ""
|
|
property real controlHeight: height + (textFieldLabel.visible ? textFieldLabel.height + 1 : 0)
|
|
property bool hasRoundedBorder: false
|
|
property bool error: false;
|
|
property bool hasClearButton: false;
|
|
|
|
placeholderText: textField.placeholderText
|
|
|
|
FontLoader { id: firaSansSemiBold; source: "../../fonts/FiraSans-SemiBold.ttf"; }
|
|
font.family: firaSansSemiBold.name
|
|
font.pixelSize: hifi.fontSizes.textFieldInput
|
|
font.italic: textField.text == ""
|
|
height: implicitHeight + 3 // Make surrounding box higher so that highlight is vertically centered.
|
|
|
|
y: textFieldLabel.visible ? textFieldLabel.height + textFieldLabel.anchors.bottomMargin : 0
|
|
|
|
style: TextFieldStyle {
|
|
textColor: {
|
|
if (isLightColorScheme) {
|
|
if (textField.activeFocus) {
|
|
hifi.colors.black
|
|
} else {
|
|
hifi.colors.lightGray
|
|
}
|
|
} else if (isFaintGrayColorScheme) {
|
|
if (textField.activeFocus) {
|
|
hifi.colors.black
|
|
} else {
|
|
hifi.colors.lightGray
|
|
}
|
|
} else {
|
|
if (textField.activeFocus) {
|
|
hifi.colors.white
|
|
} else {
|
|
hifi.colors.lightGrayText
|
|
}
|
|
}
|
|
}
|
|
background: Rectangle {
|
|
color: {
|
|
if (isLightColorScheme) {
|
|
if (textField.activeFocus) {
|
|
hifi.colors.white
|
|
} else {
|
|
hifi.colors.textFieldLightBackground
|
|
}
|
|
} else if (isFaintGrayColorScheme) {
|
|
if (textField.activeFocus) {
|
|
hifi.colors.white
|
|
} else {
|
|
hifi.colors.faintGray50
|
|
}
|
|
} else {
|
|
if (textField.activeFocus) {
|
|
hifi.colors.black
|
|
} else {
|
|
hifi.colors.baseGrayShadow
|
|
}
|
|
}
|
|
}
|
|
border.color: textField.error ? hifi.colors.redHighlight :
|
|
(textField.activeFocus ? hifi.colors.primaryHighlight : (isFaintGrayColorScheme ? hifi.colors.lightGrayText : hifi.colors.lightGray))
|
|
border.width: textField.activeFocus || hasRoundedBorder || textField.error ? 1 : 0
|
|
radius: isSearchField ? textField.height / 2 : (hasRoundedBorder ? 4 : 0)
|
|
|
|
HiFiGlyphs {
|
|
text: hifi.glyphs.search
|
|
color: textColor
|
|
size: hifi.fontSizes.textFieldSearchIcon
|
|
anchors.left: parent.left
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
anchors.leftMargin: hifi.dimensions.textPadding - 2
|
|
visible: isSearchField
|
|
}
|
|
|
|
HiFiGlyphs {
|
|
text: hifi.glyphs.error
|
|
color: textColor
|
|
size: 40
|
|
anchors.right: parent.right
|
|
anchors.rightMargin: hifi.dimensions.textPadding - 2
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
visible: hasClearButton && textField.text !== "";
|
|
|
|
MouseArea {
|
|
anchors.fill: parent;
|
|
onClicked: {
|
|
textField.text = "";
|
|
}
|
|
}
|
|
}
|
|
}
|
|
placeholderTextColor: isFaintGrayColorScheme ? hifi.colors.lightGrayText : hifi.colors.lightGray
|
|
selectedTextColor: hifi.colors.black
|
|
selectionColor: hifi.colors.primaryHighlight
|
|
padding.left: (isSearchField ? textField.height - 2 : 0) + hifi.dimensions.textPadding
|
|
padding.right: (hasClearButton ? textField.height - 2 : 0) + hifi.dimensions.textPadding
|
|
}
|
|
|
|
HifiControls.Label {
|
|
id: textFieldLabel
|
|
text: textField.label
|
|
colorScheme: textField.colorScheme
|
|
anchors.left: parent.left
|
|
anchors.bottom: parent.top
|
|
anchors.bottomMargin: 3
|
|
visible: label != ""
|
|
}
|
|
}
|