Skip to main content
aboutsummaryrefslogtreecommitdiffstats
blob: 2279ce26dc43aed3e6705131acc509512ce14cdf (plain) (blame)
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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
/*****************************************************************************
 * Copyright (c) 2010 CEA LIST.
 * 
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v1.0
 * which accompanies this distribution, and is available at
 * http://www.eclipse.org/legal/epl-v10.html
 *
 * Contributors:
 *  Remi Schnekenburger (CEA LIST) remi.schnekenburger@cea.fr - Initial API and implementation
 *****************************************************************************/
package org.eclipse.papyrus.customization.palette.dialog;

import java.beans.PropertyChangeListener;
import java.beans.PropertyChangeSupport;
import java.util.List;

import org.eclipse.gef.palette.PaletteDrawer;
import org.eclipse.gef.palette.PaletteEntry;
import org.eclipse.gef.palette.PaletteSeparator;
import org.eclipse.gef.palette.PaletteStack;
import org.eclipse.gef.palette.ToolEntry;
import org.eclipse.papyrus.customization.palette.dialog.LocalPaletteContentPage.EntryType;
import org.eclipse.papyrus.uml.diagram.common.Activator;
import org.eclipse.papyrus.uml.diagram.common.service.AspectCreationEntry;
import org.eclipse.papyrus.uml.diagram.common.service.palette.IPaletteEntryProxy;
import org.eclipse.swt.graphics.Image;

/**
 * Proxy class for palette entries
 */
public class PaletteEntryProxy implements IPaletteEntryProxy {

	/** key for the property : the icon path has changed */
	public static final String PROPERTY_ICON_PATH = "ICON_PATH";

	/** key for the property : a child has been added */
	public static final String PROPERTY_ADD_CHILDREN = "PROPERTY_ADD_CHILDREN";

	/** key for the property : a child has been removed */
	public static final String PROPERTY_REMOVE_CHILDREN = "PROPERTY_REMOVE_CHILDREN";

	/** proxy palette entry */
	private final PaletteEntry entry;

	/** parent of this proxy */
	private PaletteContainerProxy parent;

	/** PropertyChangeSupport */
	protected PropertyChangeSupport listeners = new PropertyChangeSupport(this);

	/** proxy type */
	private EntryType type;

	public PaletteEntryProxy(PaletteEntry entry) {
		this.entry = entry;
		setType(initType());
	}

	/**
	 * A listener can only be added once. Adding it more than once will do nothing.
	 * 
	 * @param listener
	 *        the PropertyChangeListener that is to be notified of changes
	 * @see java.beans.PropertyChangeSupport#addPropertyChangeListener(java.beans.PropertyChangeListener)
	 */
	public void addPropertyChangeListener(PropertyChangeListener listener) {
		listeners.removePropertyChangeListener(listener);
		listeners.addPropertyChangeListener(listener);
	}

	/**
	 * @param listener
	 *        the PropertyChangeListener that is not to be notified anymore
	 * @see java.beans.PropertyChangeSupport#removePropertyChangeListener(java.beans.PropertyChangeListener)
	 */
	public void removePropertyChangeListener(PropertyChangeListener listener) {
		listeners.removePropertyChangeListener(listener);
	}

	/**
	 * Returns the entry cached by this class
	 * 
	 * @return the palette entry
	 */
	public PaletteEntry getEntry() {
		return entry;
	}

	/**
	 * Inits the entry type for this proxy
	 * 
	 * @return the entry type for this proxy
	 */
	protected EntryType initType() {
		if(entry instanceof PaletteDrawer) {
			return EntryType.DRAWER;
		} else if(entry instanceof PaletteSeparator) {
			return EntryType.SEPARATOR;
		} else if(entry instanceof PaletteStack) {
			return EntryType.STACK;
		} else if(entry instanceof AspectCreationEntry) {
			return EntryType.ASPECT_TOOL;
		} else if(entry instanceof ToolEntry) {
			return EntryType.TOOL;
		}
		return EntryType.TOOL;
	}

	/**
	 * returns the label of the cached entry
	 * 
	 * @return the label of the cached entry
	 */
	public String getLabel() {
		return entry.getLabel();
	}

	/**
	 * returns the id of the cached entry
	 * 
	 * @return the id of the cached entry
	 */
	public String getId() {
		return entry.getId();
	}

	/**
	 * returns the small icon of the cached entry
	 * 
	 * @return the small icon of the cached entry
	 */
	public Image getImage() {
		return Activator.getPluginIconImage(Activator.ID, entry.getSmallIcon());
	}

	/**
	 * returns the description of this entry proxy
	 * 
	 * @return the description of this entry proxy
	 */
	public String getDescription() {
		return (entry != null) ? entry.getDescription() : "";
	}

	/**
	 * returns the image path of this entry proxy
	 * 
	 * @return the image path of this entry proxy
	 */
	public String getImagePath() {
		return "";
	}

	/**
	 * Sets the parent for this proxy
	 * 
	 * @param newParent
	 *        the parent proxy
	 */
	public void setParent(PaletteContainerProxy newParent) {
		parent = newParent;
	}

	/**
	 * Returns the parent of this proxy
	 * 
	 * @return the parent of this proxy
	 */
	public PaletteContainerProxy getParent() {
		return parent;
	}

	/**
	 * Returns the list of children for this entry. By default, entries do not have children.
	 * 
	 * @return the list of children for this entry
	 */
	public List<PaletteEntryProxy> getChildren() {
		return null;
	}

	/**
	 * Sets the king of tool it is.
	 * 
	 * @param type
	 *        the type to set
	 */
	public void setType(EntryType type) {
		this.type = type;
	}

	/**
	 * Returns the kind of entry
	 * 
	 * @return the kind of entry
	 */
	public EntryType getType() {
		return type;
	}

	/**
	 * Sets the description of the palette entry proxied by this element
	 * 
	 * @param desc
	 *        the new description
	 */
	public void setDescription(String desc) {
		if(getEntry() == null) {
			return;
		}
		String oldDesc = getEntry().getDescription();

		if(oldDesc == null && desc == null) {
			return;
		}

		if(desc == null || !desc.equals(oldDesc)) {
			getEntry().setDescription(desc);
			listeners.firePropertyChange(PaletteEntry.PROPERTY_DESCRIPTION, oldDesc, desc);
		}
	}

	/**
	 * Sets the label of the palette entry proxied by this element
	 * 
	 * @param label
	 *        the new label
	 */
	public void setLabel(String label) {
		if(getEntry() == null) {
			return;
		}
		String oldLabel = getEntry().getLabel();

		if(oldLabel == null && label == null) {
			return;
		}

		if(label == null || !label.equals(oldLabel)) {
			getEntry().setLabel(label);
			listeners.firePropertyChange(PaletteEntry.PROPERTY_LABEL, oldLabel, label);
		}
	}

	/**
	 * Sets the label of the palette entry proxied by this element
	 * 
	 * @param label
	 *        the new label
	 */
	public void setIcon(String path) {
		if(!(getEntry() instanceof AspectCreationEntry)) {
			return;
		}
		String oldPath = ((AspectCreationEntry)getEntry()).getIconPath();

		if(oldPath == null && path == null) {
			return;
		}

		if(path == null || !path.equals(oldPath)) {
			((AspectCreationEntry)getEntry()).setIconPath(path);
			listeners.firePropertyChange(PROPERTY_ICON_PATH, oldPath, path);
		}
	}

	/**
	 * Method to add a child proxy to this proxy
	 * 
	 * @param entry
	 *        the entry to add
	 */
	protected void addChild(PaletteEntryProxy entry) {
		listeners.firePropertyChange(PROPERTY_ADD_CHILDREN, null, entry);
	}

	/**
	 * Method to add a child proxy to this proxy, before the given element
	 * 
	 * @param entry
	 *        the entry to add
	 * @param nextElement
	 *        the element that should be just after the entry
	 */
	protected void addChild(PaletteEntryProxy entry, PaletteEntryProxy nextElement) {
		listeners.firePropertyChange(PROPERTY_ADD_CHILDREN, null, entry);
	}

	/**
	 * Remove the specified children from its parent
	 * 
	 * @param proxy
	 *        the proxy to remove
	 */
	public void removeChild(PaletteEntryProxy proxy) {
		listeners.firePropertyChange(PROPERTY_REMOVE_CHILDREN, proxy, null);
	}
}

Back to the top