mirror of
https://github.com/haveno-dex/haveno.git
synced 2025-01-14 08:49:57 -05:00
#967 Text in Pop Ups selectable
This commit is contained in:
parent
0a67b9a423
commit
3cac6d7c69
@ -1200,6 +1200,19 @@ textfield */
|
|||||||
-fx-border-color: -bs-background-gray;
|
-fx-border-color: -bs-background-gray;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.text-area-no-border {
|
||||||
|
-fx-border-color: -fx-control-inner-background;
|
||||||
|
}
|
||||||
|
|
||||||
|
.text-area-no-border .content {
|
||||||
|
-fx-background-color: -fx-control-inner-background;
|
||||||
|
}
|
||||||
|
|
||||||
|
.text-area-no-border:focused {
|
||||||
|
-fx-focus-color: -fx-control-inner-background;
|
||||||
|
-fx-faint-focus-color: -fx-control-inner-background;
|
||||||
|
}
|
||||||
|
|
||||||
/*******************************************************************************
|
/*******************************************************************************
|
||||||
* *
|
* *
|
||||||
* Tab pane *
|
* Tab pane *
|
||||||
|
@ -33,6 +33,7 @@ import haveno.desktop.components.AutoTooltipCheckBox;
|
|||||||
import haveno.desktop.components.AutoTooltipLabel;
|
import haveno.desktop.components.AutoTooltipLabel;
|
||||||
import haveno.desktop.components.BusyAnimation;
|
import haveno.desktop.components.BusyAnimation;
|
||||||
import haveno.desktop.main.MainView;
|
import haveno.desktop.main.MainView;
|
||||||
|
import haveno.desktop.util.CssTheme;
|
||||||
import haveno.desktop.util.FormBuilder;
|
import haveno.desktop.util.FormBuilder;
|
||||||
import haveno.desktop.util.GUIUtil;
|
import haveno.desktop.util.GUIUtil;
|
||||||
import haveno.desktop.util.Layout;
|
import haveno.desktop.util.Layout;
|
||||||
@ -41,6 +42,8 @@ import javafx.animation.Interpolator;
|
|||||||
import javafx.animation.KeyFrame;
|
import javafx.animation.KeyFrame;
|
||||||
import javafx.animation.KeyValue;
|
import javafx.animation.KeyValue;
|
||||||
import javafx.animation.Timeline;
|
import javafx.animation.Timeline;
|
||||||
|
import javafx.application.Platform;
|
||||||
|
import javafx.beans.binding.Bindings;
|
||||||
import javafx.beans.property.BooleanProperty;
|
import javafx.beans.property.BooleanProperty;
|
||||||
import javafx.beans.property.SimpleBooleanProperty;
|
import javafx.beans.property.SimpleBooleanProperty;
|
||||||
import javafx.beans.value.ChangeListener;
|
import javafx.beans.value.ChangeListener;
|
||||||
@ -56,6 +59,7 @@ import javafx.scene.control.Button;
|
|||||||
import javafx.scene.control.CheckBox;
|
import javafx.scene.control.CheckBox;
|
||||||
import javafx.scene.control.Hyperlink;
|
import javafx.scene.control.Hyperlink;
|
||||||
import javafx.scene.control.Label;
|
import javafx.scene.control.Label;
|
||||||
|
import javafx.scene.control.TextArea;
|
||||||
import javafx.scene.control.Tooltip;
|
import javafx.scene.control.Tooltip;
|
||||||
import javafx.scene.control.ScrollPane;
|
import javafx.scene.control.ScrollPane;
|
||||||
import javafx.scene.control.ScrollPane.ScrollBarPolicy;
|
import javafx.scene.control.ScrollPane.ScrollBarPolicy;
|
||||||
@ -163,7 +167,8 @@ public abstract class Overlay<T extends Overlay<T>> {
|
|||||||
protected boolean useAnimation = true;
|
protected boolean useAnimation = true;
|
||||||
protected boolean showScrollPane = false;
|
protected boolean showScrollPane = false;
|
||||||
|
|
||||||
protected Label headlineIcon, copyIcon, headLineLabel, messageLabel;
|
protected TextArea messageTextArea;
|
||||||
|
protected Label headlineIcon, copyIcon, headLineLabel;
|
||||||
protected String headLine, message, closeButtonText, actionButtonText,
|
protected String headLine, message, closeButtonText, actionButtonText,
|
||||||
secondaryActionButtonText, dontShowAgainId, dontShowAgainText,
|
secondaryActionButtonText, dontShowAgainId, dontShowAgainText,
|
||||||
truncatedMessage;
|
truncatedMessage;
|
||||||
@ -847,20 +852,37 @@ public abstract class Overlay<T extends Overlay<T>> {
|
|||||||
|
|
||||||
protected void addMessage() {
|
protected void addMessage() {
|
||||||
if (message != null) {
|
if (message != null) {
|
||||||
messageLabel = new AutoTooltipLabel(truncatedMessage);
|
messageTextArea = new TextArea(truncatedMessage);
|
||||||
messageLabel.setMouseTransparent(true);
|
messageTextArea.setEditable(false);
|
||||||
messageLabel.setWrapText(true);
|
messageTextArea.getStyleClass().add("text-area-no-border");
|
||||||
|
messageTextArea.sceneProperty().addListener((o, oldScene, newScene) -> {
|
||||||
|
if (newScene != null) {
|
||||||
|
// avoid javafx css warning
|
||||||
|
CssTheme.loadSceneStyles(newScene, CssTheme.CSS_THEME_LIGHT, false);
|
||||||
|
messageTextArea.applyCss();
|
||||||
|
var text = messageTextArea.lookup(".text");
|
||||||
|
|
||||||
|
messageTextArea.prefHeightProperty().bind(Bindings.createDoubleBinding(() -> {
|
||||||
|
return messageTextArea.getFont().getSize() + text.getBoundsInLocal().getHeight();
|
||||||
|
}, text.boundsInLocalProperty()));
|
||||||
|
|
||||||
|
text.boundsInLocalProperty().addListener((observableBoundsAfter, boundsBefore, boundsAfter) -> {
|
||||||
|
Platform.runLater(() -> messageTextArea.requestLayout());
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
messageTextArea.setWrapText(true);
|
||||||
|
|
||||||
Region messageRegion;
|
Region messageRegion;
|
||||||
if (showScrollPane) {
|
if (showScrollPane) {
|
||||||
scrollPane = new ScrollPane(messageLabel);
|
scrollPane = new ScrollPane(messageTextArea);
|
||||||
scrollPane.setHbarPolicy(ScrollBarPolicy.NEVER);
|
scrollPane.setHbarPolicy(ScrollBarPolicy.NEVER);
|
||||||
scrollPane.setVbarPolicy(ScrollBarPolicy.AS_NEEDED);
|
scrollPane.setVbarPolicy(ScrollBarPolicy.AS_NEEDED);
|
||||||
scrollPane.setFitToWidth(true);
|
scrollPane.setFitToWidth(true);
|
||||||
|
|
||||||
messageRegion = scrollPane;
|
messageRegion = scrollPane;
|
||||||
} else
|
} else
|
||||||
messageRegion = messageLabel;
|
messageRegion = messageTextArea;
|
||||||
|
|
||||||
GridPane.setHalignment(messageRegion, HPos.LEFT);
|
GridPane.setHalignment(messageRegion, HPos.LEFT);
|
||||||
GridPane.setHgrow(messageRegion, Priority.ALWAYS);
|
GridPane.setHgrow(messageRegion, Priority.ALWAYS);
|
||||||
@ -892,7 +914,7 @@ public abstract class Overlay<T extends Overlay<T>> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void addReportErrorButtons() {
|
private void addReportErrorButtons() {
|
||||||
messageLabel.setText(Res.get("popup.reportError", truncatedMessage));
|
messageTextArea.setText(Res.get("popup.reportError", truncatedMessage));
|
||||||
|
|
||||||
Button logButton = new AutoTooltipButton(Res.get("popup.reportError.log"));
|
Button logButton = new AutoTooltipButton(Res.get("popup.reportError.log"));
|
||||||
GridPane.setMargin(logButton, new Insets(20, 0, 0, 0));
|
GridPane.setMargin(logButton, new Insets(20, 0, 0, 0));
|
||||||
|
@ -26,7 +26,6 @@ import org.slf4j.Logger;
|
|||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import static com.google.common.base.Preconditions.checkNotNull;
|
import static com.google.common.base.Preconditions.checkNotNull;
|
||||||
import static haveno.desktop.util.FormBuilder.addMultilineLabel;
|
|
||||||
|
|
||||||
public class DisplayAlertMessageWindow extends Overlay<DisplayAlertMessageWindow> {
|
public class DisplayAlertMessageWindow extends Overlay<DisplayAlertMessageWindow> {
|
||||||
private static final Logger log = LoggerFactory.getLogger(DisplayAlertMessageWindow.class);
|
private static final Logger log = LoggerFactory.getLogger(DisplayAlertMessageWindow.class);
|
||||||
@ -41,6 +40,7 @@ public class DisplayAlertMessageWindow extends Overlay<DisplayAlertMessageWindow
|
|||||||
type = Type.Attention;
|
type = Type.Attention;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public void show() {
|
public void show() {
|
||||||
width = 768;
|
width = 768;
|
||||||
// need to set headLine, otherwise the fields will not be created in addHeadLine
|
// need to set headLine, otherwise the fields will not be created in addHeadLine
|
||||||
@ -75,7 +75,8 @@ public class DisplayAlertMessageWindow extends Overlay<DisplayAlertMessageWindow
|
|||||||
|
|
||||||
private void addContent() {
|
private void addContent() {
|
||||||
checkNotNull(alert, "alertMessage must not be null");
|
checkNotNull(alert, "alertMessage must not be null");
|
||||||
addMultilineLabel(gridPane, ++rowIndex, alert.getMessage(), 10);
|
message(alert.getMessage());
|
||||||
|
addMessage();
|
||||||
if (alert.isSoftwareUpdateNotification()) {
|
if (alert.isSoftwareUpdateNotification()) {
|
||||||
String url = "https://haveno.exchange/downloads";
|
String url = "https://haveno.exchange/downloads";
|
||||||
HyperlinkWithIcon hyperlinkWithIcon = FormBuilder.addLabelHyperlinkWithIcon(gridPane, ++rowIndex,
|
HyperlinkWithIcon hyperlinkWithIcon = FormBuilder.addLabelHyperlinkWithIcon(gridPane, ++rowIndex,
|
||||||
|
@ -89,7 +89,7 @@ public class TacWindow extends Overlay<TacWindow> {
|
|||||||
protected void addMessage() {
|
protected void addMessage() {
|
||||||
super.addMessage();
|
super.addMessage();
|
||||||
String fontStyleClass = smallScreen ? "small-text" : "normal-text";
|
String fontStyleClass = smallScreen ? "small-text" : "normal-text";
|
||||||
messageLabel.getStyleClass().add(fontStyleClass);
|
messageTextArea.getStyleClass().add(fontStyleClass);
|
||||||
|
|
||||||
// TODO: link to the wiki
|
// TODO: link to the wiki
|
||||||
// HyperlinkWithIcon hyperlinkWithIcon = addHyperlinkWithIcon(gridPane, ++rowIndex, Res.get("tacWindow.arbitrationSystem"),
|
// HyperlinkWithIcon hyperlinkWithIcon = addHyperlinkWithIcon(gridPane, ++rowIndex, Res.get("tacWindow.arbitrationSystem"),
|
||||||
|
Loading…
Reference in New Issue
Block a user