LanternaActionManager.java
01 /*
02  * Copyright 2008-2017 the original author or authors.
03  *
04  * Licensed under the Apache License, Version 2.0 (the "License");
05  * you may not use this file except in compliance with the License.
06  * You may obtain a copy of the License at
07  *
08  *     http://www.apache.org/licenses/LICENSE-2.0
09  *
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.codehaus.griffon.runtime.lanterna.controller;
17 
18 import griffon.core.GriffonApplication;
19 import griffon.core.artifact.GriffonController;
20 import griffon.core.controller.Action;
21 import griffon.core.controller.ActionFactory;
22 import griffon.core.controller.ActionMetadataFactory;
23 import org.codehaus.griffon.runtime.core.controller.AbstractActionManager;
24 import org.slf4j.Logger;
25 import org.slf4j.LoggerFactory;
26 
27 import javax.annotation.Nonnull;
28 import javax.inject.Inject;
29 import java.beans.PropertyChangeEvent;
30 import java.beans.PropertyChangeListener;
31 
32 import static griffon.util.GriffonNameUtils.getNaturalName;
33 import static griffon.util.GriffonNameUtils.isBlank;
34 
35 /**
36  @author Andres Almiray
37  @since 2.0.0
38  */
39 public class LanternaActionManager extends AbstractActionManager {
40     private static final Logger LOG = LoggerFactory.getLogger(LanternaActionManager.class);
41 
42     private static final String DOT = ".";
43     private static final String EQUALS = " = ";
44     private static final String KEY_NAME = "name";
45 
46     @Inject
47     public LanternaActionManager(@Nonnull GriffonApplication application, @Nonnull ActionFactory actionFactory, @Nonnull ActionMetadataFactory actionMetadataFactory) {
48         super(application, actionFactory, actionMetadataFactory);
49     }
50 
51     @Override
52     protected void doConfigureAction(@Nonnull final Action action, @Nonnull final GriffonController controller, @Nonnull final String normalizeNamed, @Nonnull final String keyPrefix) {
53         controller.getApplication().addPropertyChangeListener(GriffonApplication.PROPERTY_LOCALE, new PropertyChangeListener() {
54             @Override
55             public void propertyChange(PropertyChangeEvent evt) {
56                 configureAction((LanternaGriffonControllerActionaction, controller, normalizeNamed, keyPrefix);
57             }
58         });
59         configureAction((LanternaGriffonControllerActionaction, controller, normalizeNamed, keyPrefix);
60     }
61 
62     protected void configureAction(@Nonnull LanternaGriffonControllerAction action, @Nonnull GriffonController controller, @Nonnull String normalizeNamed, @Nonnull String keyPrefix) {
63         resolveName(action, controller, normalizeNamed, keyPrefix);
64     }
65 
66     protected void resolveName(@Nonnull LanternaGriffonControllerAction action, @Nonnull GriffonController controller, @Nonnull String normalizeNamed, @Nonnull String keyPrefix) {
67         String rsActionName = msg(keyPrefix, normalizeNamed, KEY_NAME, getNaturalName(normalizeNamed));
68         if (!isBlank(rsActionName)) {
69             trace(keyPrefix + normalizeNamed, KEY_NAME, rsActionName);
70             action.setName(rsActionName);
71         }
72     }
73 
74     protected void trace(@Nonnull String actionKey, @Nonnull String key, @Nonnull String value) {
75         if (LOG.isTraceEnabled()) {
76             LOG.trace(actionKey + DOT + key + EQUALS + value);
77         }
78     }
79 }