LanternaActionManager.java
01 /*
02  * SPDX-License-Identifier: Apache-2.0
03  *
04  * Copyright 2008-2017 the original author or authors.
05  *
06  * Licensed under the Apache License, Version 2.0 (the "License");
07  * you may not use this file except in compliance with the License.
08  * You may obtain a copy of the License at
09  *
10  *     http://www.apache.org/licenses/LICENSE-2.0
11  *
12  * Unless required by applicable law or agreed to in writing, software
13  * distributed under the License is distributed on an "AS IS" BASIS,
14  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15  * See the License for the specific language governing permissions and
16  * limitations under the License.
17  */
18 package org.codehaus.griffon.runtime.lanterna.controller;
19 
20 import griffon.core.GriffonApplication;
21 import griffon.core.artifact.GriffonController;
22 import griffon.core.controller.Action;
23 import griffon.core.controller.ActionFactory;
24 import griffon.core.controller.ActionMetadataFactory;
25 import org.codehaus.griffon.runtime.core.controller.AbstractActionManager;
26 import org.slf4j.Logger;
27 import org.slf4j.LoggerFactory;
28 
29 import javax.annotation.Nonnull;
30 import javax.inject.Inject;
31 import java.beans.PropertyChangeEvent;
32 import java.beans.PropertyChangeListener;
33 
34 import static griffon.util.GriffonNameUtils.getNaturalName;
35 import static griffon.util.GriffonNameUtils.isNotBlank;
36 
37 /**
38  @author Andres Almiray
39  @since 2.0.0
40  */
41 public class LanternaActionManager extends AbstractActionManager {
42     private static final Logger LOG = LoggerFactory.getLogger(LanternaActionManager.class);
43 
44     private static final String DOT = ".";
45     private static final String EQUALS = " = ";
46     private static final String KEY_NAME = "name";
47 
48     @Inject
49     public LanternaActionManager(@Nonnull GriffonApplication application, @Nonnull ActionFactory actionFactory, @Nonnull ActionMetadataFactory actionMetadataFactory) {
50         super(application, actionFactory, actionMetadataFactory);
51     }
52 
53     @Override
54     protected void doConfigureAction(@Nonnull final Action action, @Nonnull final GriffonController controller, @Nonnull final String normalizeNamed, @Nonnull final String keyPrefix) {
55         controller.getApplication().addPropertyChangeListener(GriffonApplication.PROPERTY_LOCALE, new PropertyChangeListener() {
56             @Override
57             public void propertyChange(PropertyChangeEvent evt) {
58                 configureAction((LanternaGriffonControllerActionaction, controller, normalizeNamed, keyPrefix);
59             }
60         });
61         configureAction((LanternaGriffonControllerActionaction, controller, normalizeNamed, keyPrefix);
62     }
63 
64     protected void configureAction(@Nonnull LanternaGriffonControllerAction action, @Nonnull GriffonController controller, @Nonnull String normalizeNamed, @Nonnull String keyPrefix) {
65         resolveName(action, controller, normalizeNamed, keyPrefix);
66     }
67 
68     protected void resolveName(@Nonnull LanternaGriffonControllerAction action, @Nonnull GriffonController controller, @Nonnull String normalizeNamed, @Nonnull String keyPrefix) {
69         String rsActionName = msg(keyPrefix, normalizeNamed, KEY_NAME, getNaturalName(normalizeNamed));
70         if (isNotBlank(rsActionName)) {
71             trace(keyPrefix + normalizeNamed, KEY_NAME, rsActionName);
72             action.setName(rsActionName);
73         }
74     }
75 
76     protected void trace(@Nonnull String actionKey, @Nonnull String key, @Nonnull String value) {
77         if (LOG.isTraceEnabled()) {
78             LOG.trace(actionKey + DOT + key + EQUALS + value);
79         }
80     }
81 }