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((LanternaGriffonControllerAction) action, controller, normalizeNamed, keyPrefix);
57 }
58 });
59 configureAction((LanternaGriffonControllerAction) action, 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 }
|