/hg/icedtea-web: PolicyEditor fix checkbox UI updating on open
aazores at icedtea.classpath.org
aazores at icedtea.classpath.org
Fri Mar 14 13:40:06 UTC 2014
changeset fdff61a60cc1 in /hg/icedtea-web
details: http://icedtea.classpath.org/hg/icedtea-web?cmd=changeset;node=fdff61a60cc1
author: Andrew Azores <aazores at redhat.com>
date: Fri Mar 14 09:39:56 2014 -0400
PolicyEditor fix checkbox UI updating on open
* netx/net/sourceforge/jnlp/security/policyeditor/PolicyEditor.java:
(addNewCodebase) ensure that checkboxes update. (removeCodebase,
updateCheckboxes) ensure UI updates are done on EDT.
diffstat:
ChangeLog | 6 +
netx/net/sourceforge/jnlp/security/policyeditor/PolicyEditor.java | 83 ++++++---
2 files changed, 59 insertions(+), 30 deletions(-)
diffs (123 lines):
diff -r aba4c18c4c64 -r fdff61a60cc1 ChangeLog
--- a/ChangeLog Fri Mar 14 13:06:03 2014 +0100
+++ b/ChangeLog Fri Mar 14 09:39:56 2014 -0400
@@ -1,3 +1,9 @@
+2014-03-14 Andrew Azores <aazores at redhat.com>
+
+ * netx/net/sourceforge/jnlp/security/policyeditor/PolicyEditor.java:
+ (addNewCodebase) ensure that checkboxes update. (removeCodebase,
+ updateCheckboxes) ensure UI updates are done on EDT.
+
2014-03-14 Jiri Vanek <jvanek at redhat.com>
Base implementation of Application-Library-Allowable-Codebase. Remember
diff -r aba4c18c4c64 -r fdff61a60cc1 netx/net/sourceforge/jnlp/security/policyeditor/PolicyEditor.java
--- a/netx/net/sourceforge/jnlp/security/policyeditor/PolicyEditor.java Fri Mar 14 13:06:03 2014 +0100
+++ b/netx/net/sourceforge/jnlp/security/policyeditor/PolicyEditor.java Fri Mar 14 09:39:56 2014 -0400
@@ -478,10 +478,21 @@
model = codebase;
}
if (!existingCodebase) {
- listModel.addElement(model);
+ SwingUtilities.invokeLater(new Runnable() {
+ @Override
+ public void run() {
+ listModel.addElement(model);
+ }
+ });
changesMade = true;
}
- list.setSelectedValue(model, true);
+ SwingUtilities.invokeLater(new Runnable() {
+ @Override
+ public void run() {
+ list.setSelectedValue(model, true);
+ updateCheckboxes(codebase);
+ }
+ });
}
/**
@@ -545,8 +556,14 @@
previousIndex = 0;
}
codebasePermissionsMap.remove(codebase);
- listModel.removeElement(codebase);
- list.setSelectedIndex(previousIndex);
+ final int fIndex = previousIndex;
+ SwingUtilities.invokeLater(new Runnable() {
+ @Override
+ public void run() {
+ listModel.removeElement(codebase);
+ list.setSelectedIndex(fIndex);
+ }
+ });
changesMade = true;
}
@@ -592,33 +609,39 @@
* @param codebase whose permissions to display
*/
private void updateCheckboxes(final String codebase) {
- for (final PolicyEditorPermissions perm : PolicyEditorPermissions.values()) {
- final JCheckBox box = checkboxMap.get(perm);
- for (final ActionListener l : box.getActionListeners()) {
- box.removeActionListener(l);
+ SwingUtilities.invokeLater(new Runnable() {
+ @Override
+ public void run() {
+ for (final PolicyEditorPermissions perm : PolicyEditorPermissions.values()) {
+ final JCheckBox box = checkboxMap.get(perm);
+ for (final ActionListener l : box.getActionListeners()) {
+ box.removeActionListener(l);
+ }
+ initializeMapForCodebase(codebase);
+ final Map<PolicyEditorPermissions, Boolean> map = codebasePermissionsMap.get(codebase);
+ final boolean state;
+ if (map != null) {
+ final Boolean s = map.get(perm);
+ if (s != null) {
+ state = s;
+ } else {
+ state = false;
+ }
+ } else {
+ state = false;
+ }
+ box.setSelected(state);
+ box.addActionListener(new ActionListener() {
+ @Override
+ public void actionPerformed(final ActionEvent e) {
+ changesMade = true;
+ map.put(perm, box.isSelected());
+ }
+ });
+ }
}
- initializeMapForCodebase(codebase);
- final Map<PolicyEditorPermissions, Boolean> map = codebasePermissionsMap.get(codebase);
- final boolean state;
- if (map != null) {
- final Boolean s = map.get(perm);
- if (s != null) {
- state = s;
- } else {
- state = false;
- }
- } else {
- state = false;
- }
- box.setSelected(state);
- box.addActionListener(new ActionListener() {
- @Override
- public void actionPerformed(final ActionEvent e) {
- changesMade = true;
- map.put(perm, box.isSelected());
- }
- });
- }
+ });
+
}
/**
More information about the distro-pkg-dev
mailing list