4379abfad418e37035aca2ee700ba50183b3e7ff
[idea/community.git] / images / src / org / intellij / images / editor / actionSystem / ImageEditorActionUtil.java
1 /*
2  * Copyright 2000-2009 JetBrains s.r.o.
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 package org.intellij.images.editor.actionSystem;
17
18 import com.intellij.openapi.actionSystem.AnActionEvent;
19 import com.intellij.openapi.actionSystem.DataContext;
20 import com.intellij.openapi.actionSystem.Presentation;
21 import org.intellij.images.editor.ImageEditor;
22 import org.intellij.images.ui.ImageComponentDecorator;
23
24 /**
25  * Editor actions utility.
26  *
27  * @author <a href="mailto:aefimov.box@gmail.com">Alexey Efimov</a>
28  */
29 public final class ImageEditorActionUtil {
30     private ImageEditorActionUtil() {
31     }
32
33     /**
34      * Extract current editor from event context.
35      *
36      * @param e Action event
37      * @return Current {@link ImageEditor} or <code>null</code>
38      */
39     //public static ImageEditor getValidEditor(AnActionEvent e) {
40     //    ImageEditor editor = getEditor(e);
41     //    if (editor != null && editor.isValid()) {
42     //        return editor;
43     //    }
44     //    return null;
45     //}
46
47     public static ImageComponentDecorator getImageComponentDecorator(AnActionEvent e) {
48         DataContext dataContext = e.getDataContext();
49         return ImageComponentDecorator.DATA_KEY.getData(dataContext);
50     }
51
52     /**
53      * Enable or disable current action from event.
54      *
55      * @param e Action event
56      * @return Enabled value
57      */
58     public static boolean setEnabled(AnActionEvent e) {
59         ImageComponentDecorator decorator = getImageComponentDecorator(e);
60         Presentation presentation = e.getPresentation();
61         presentation.setEnabled(decorator != null);
62         return presentation.isEnabled();
63     }
64 }