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