1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
|
package org.openslx.dozmod.gui.window;
import java.awt.Window;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.util.Map;
import org.apache.log4j.Logger;
import org.openslx.bwlp.thrift.iface.ImagePermissions;
import org.openslx.dozmod.gui.helper.UiFeedback;
import org.openslx.dozmod.gui.window.layout.ImageCustomPermissionWindowLayout;
import org.openslx.dozmod.permissions.PermissionDefaultToCustomLink;
/**
* Window for modifying the custom permissions of an image.
*/
@SuppressWarnings("serial")
public class ImageCustomPermissionWindow extends ImageCustomPermissionWindowLayout implements UiFeedback {
private static final Logger LOGGER = Logger.getLogger(ImageCustomPermissionWindow.class);
private boolean okUsed = false;
protected ImageCustomPermissionWindow(final Window modalParent, final Map<String, ImagePermissions> permissionMap, final ImagePermissions defaultPermissions, String ownerId) {
super(modalParent);
imagePermissionManager.initPanel(permissionMap, defaultPermissions, ownerId);
btnOk.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
okUsed = true;
dispose();
}
});
btnClose.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent arg0) {
dispose();
}
});
chkCustomPermAdmin.setSelected(defaultPermissions.admin);
chkCustomPermEdit.setSelected(defaultPermissions.edit);
chkCustomPermDownload.setSelected(defaultPermissions.download);
chkCustomPermLink.setSelected(defaultPermissions.link);
}
/**
* Set a created ImageCustomPermissionWindow visible and return resulting permissions
* @return PermissionDefaultToCustomLink with default- and customPermissions when using OK button, null otherwise
*/
private PermissionDefaultToCustomLink<ImagePermissions> runAndReturn(){
setVisible(true);
if (okUsed){
return new PermissionDefaultToCustomLink<ImagePermissions>(imagePermissionManager.getMap(), new ImagePermissions(chkCustomPermLink.isSelected(), chkCustomPermDownload.isSelected(), chkCustomPermEdit.isSelected(), chkCustomPermAdmin.isSelected()));
} else {
return null;
}
}
/**
* Creates a new ImageCustomPermissionWindow dialog and returns the resulting Permissions
* @param modalParent parentwindow of this dialog
* @param permissionMap The current user permissions with which the permission manager to initialise, null creates empty list.
* @param defaultPermissions The current default permissions, should not be null!
* @param ownerId The id of the user to exclude when adding users. Can be null.
* @return PermissionDefaultToCustomLink with resulting permissions or null, if abort has been used to exit the dialog
*/
public static PermissionDefaultToCustomLink<ImagePermissions> open(Window modalParent, Map<String, ImagePermissions> permissionMap, ImagePermissions defaultPermissions, String ownerId) {
return new ImageCustomPermissionWindow(modalParent, permissionMap, defaultPermissions, ownerId).runAndReturn();
}
@Override
public boolean wantConfirmQuit() {
return false;
}
@Override
public void escapePressed() {
dispose();
}
}
|