From 264c386db855361a4c05d388a38c4735c883efce Mon Sep 17 00:00:00 2001
From: Phillipus
Date: Mon, 16 Dec 2024 13:46:03 +0000
Subject: [PATCH] Make the "None" border colour drop-down menu item a check
menu option
- Before this to remove the "None" border colour you had to open the color chooser and choose a different color than black for it to take effect
- This was because the color chooser would return null and so it was seen as no change
---
.../propertysections/BorderColorSection.java | 28 +++++++++----------
1 file changed, 14 insertions(+), 14 deletions(-)
diff --git a/com.archimatetool.editor/src/com/archimatetool/editor/propertysections/BorderColorSection.java b/com.archimatetool.editor/src/com/archimatetool/editor/propertysections/BorderColorSection.java
index b3bbd7d9a..b7ecbe2c3 100644
--- a/com.archimatetool.editor/src/com/archimatetool/editor/propertysections/BorderColorSection.java
+++ b/com.archimatetool.editor/src/com/archimatetool/editor/propertysections/BorderColorSection.java
@@ -56,17 +56,16 @@ public Class> getAdaptableType() {
private IPropertyChangeListener colorListener = new IPropertyChangeListener() {
@Override
public void propertyChange(PropertyChangeEvent event) {
+ RGB rgb = fColorChooser.getColorValue();
+ String newColor = ColorFactory.convertRGBToString(rgb);
+
CompoundCommand result = new CompoundCommand();
- for(EObject bo : getEObjects()) {
- if(isAlive(bo)) {
- RGB rgb = fColorChooser.getColorValue();
- String newColor = ColorFactory.convertRGBToString(rgb);
- if(!newColor.equals(((IBorderObject)bo).getBorderColor())) {
- Command cmd = new BorderColorCommand((IBorderObject)bo, newColor);
- if(cmd.canExecute()) {
- result.add(cmd);
- }
+ for(EObject eObject : getEObjects()) {
+ if(isAlive(eObject) && eObject instanceof IBorderObject bo) {
+ Command cmd = new BorderColorCommand(bo, newColor);
+ if(cmd.canExecute()) {
+ result.add(cmd);
}
}
}
@@ -95,14 +94,15 @@ private void createColorControl(Composite parent) {
fColorChooser.setDoShowPreferencesMenuItem(false);
// No border action
- fNoBorderAction = new Action(Messages.BorderColorSection_1) {
+ fNoBorderAction = new Action(Messages.BorderColorSection_1, SWT.CHECK) {
@Override
public void run() {
CompoundCommand result = new CompoundCommand();
- for(EObject bo : getEObjects()) {
- if(isAlive(bo)) {
- Command cmd = new BorderColorCommand((IBorderObject)bo, null);
+ for(EObject eObject : getEObjects()) {
+ if(isAlive(eObject) && eObject instanceof IBorderObject bo) {
+ String color = isChecked() ? null : "#000000"; //$NON-NLS-1$
+ Command cmd = new BorderColorCommand(bo, color);
if(cmd.canExecute()) {
result.add(cmd);
}
@@ -140,7 +140,7 @@ protected void update() {
fColorChooser.setEnabled(!isLocked(bo));
- fNoBorderAction.setEnabled(colorValue != null);
+ fNoBorderAction.setChecked(colorValue == null);
fColorChooser.setDoShowColorImage(colorValue != null);
}