CCM NG: PageModel AdminUI should now work

git-svn-id: https://svn.libreccm.org/ccm/ccm_ng@5130 8810af33-2d31-482b-a856-94f89814c4df
ccm-docs
jensp 2017-11-22 11:07:35 +00:00
parent 856c8553ec
commit ab058ba86b
7 changed files with 127 additions and 64 deletions

View File

@ -81,7 +81,9 @@ public abstract class AbstractContentItemComponentForm<T extends ContentItemComp
final PageState state = event.getPageState();
final ContentItemComponent component = getComponentModel();
if (getComponentModel() != null) {
modeField.setValue(state, component.getMode());
}
}
}

View File

@ -98,7 +98,7 @@ public class CategoryTreeComponentForm extends AbstractComponentModelForm<Catego
final CategoryTreeComponent component = getComponentModel();
final Object[] showFullTreeValue;
if (component.isShowFullTree()) {
if (component != null && component.isShowFullTree()) {
showFullTreeValue = new Object[]{SHOW_FULL_TREE};
} else {
showFullTreeValue = new Object[]{};

View File

@ -96,17 +96,20 @@ public abstract class AbstractComponentModelForm<T extends ComponentModel>
this.selectedModelId = selectedModelId;
this.selectedComponentId = selectedComponentId;
keyField = new TextField(COMPONENT_KEY);
keyField.setLabel(new GlobalizedMessage(
"ui.admin.pagemodels.components.key.label",
AdminUiConstants.ADMIN_BUNDLE));
super.add(keyField);
// keyField = new TextField(COMPONENT_KEY);
// keyField.setLabel(new GlobalizedMessage(
// "ui.admin.pagemodels.components.key.label",
// AdminUiConstants.ADMIN_BUNDLE));
// super.add(keyField);
createWidgets();
addBasicWidgets();
super.addInitListener(this);
super.addValidationListener(this);
super.addProcessListener(this);
}
private void addBasicWidgets() {
keyField = new TextField("componentModelKey");
private void createWidgets() {
keyField = new TextField(COMPONENT_KEY);
keyField.setLabel(new GlobalizedMessage(
"ui.admin.pagemodels.components.key.label",
AdminUiConstants.ADMIN_BUNDLE));
@ -226,10 +229,8 @@ public abstract class AbstractComponentModelForm<T extends ComponentModel>
.getSelectedKey(state);
final CdiUtil cdiUtil = CdiUtil.createCdiUtil();
final PageModelRepository pageModelRepo = cdiUtil
.findBean(PageModelRepository.class);
final PageModelManager pageModelManager = cdiUtil
.findBean(PageModelManager.class);
final PageModelsController controller = cdiUtil
.findBean(PageModelsController.class);
final FormData data = event.getFormData();
final String keyValue = data.getString(COMPONENT_KEY);
@ -241,13 +242,8 @@ public abstract class AbstractComponentModelForm<T extends ComponentModel>
componentModel.setKey(keyValue);
updateComponentModel(componentModel, state, data);
final PageModel pageModel = pageModelRepo
.findById(Long.parseLong(selectedModelIdStr))
.orElseThrow(() -> new IllegalArgumentException(String
.format("No PageModel with ID %s in the database.",
selectedModelIdStr)));
pageModelManager.addComponentModel(pageModel, componentModel);
controller.addComponentModel(Long.parseLong(selectedModelIdStr),
componentModel);
} else {
componentModel = retrieveComponentModel(selectedComponentIdStr);

View File

@ -231,8 +231,13 @@ class ComponentsTable extends Table {
switch (columnIndex) {
case ComponentsTable.COL_COMPONENT_KEY:
return currentComponent.getKey();
case ComponentsTable.COL_COMPONENT_TYPE:
return currentComponent.getClass().getName();
case ComponentsTable.COL_COMPONENT_TYPE: {
final CdiUtil cdiUtil = CdiUtil.createCdiUtil();
final PageModelsController controller = cdiUtil
.findBean(PageModelsController.class);
return controller
.getComponentModelTitle(currentComponent.getClass());
}
case ComponentsTable.COL_EDIT:
return new Label(new GlobalizedMessage(
"ui.admin.pagemodels.components.edit",

View File

@ -88,37 +88,33 @@ public class PageModelTab extends LayoutPanel {
.findBean(PageModelsController.class);
try {
final Class<? extends Form> formClass;
if (selectedComponentId.getSelectedKey(state) == null
|| selectedComponentId.getSelectedKey(state)
.isEmpty()) {
final Class<? extends Form> formClass = controller
formClass = controller
.getComponentModelForm(componentModelClass);
formClass
.getDeclaredConstructor()
.newInstance();
} else {
final Class<? extends Form> formClass = controller
formClass = controller
.getComponentModelForm(Long
.parseLong(selectedComponentId
.getSelectedKey(state)));
}
return formClass
.getDeclaredConstructor(
PageModelTab.class,
ParameterSingleSelectionModel.class,
ParameterSingleSelectionModel.class)
.newInstance(selectedComponentId);
}
.newInstance(PageModelTab.this,
selectedModelId,
selectedComponentId);
} catch (InstantiationException
| InvocationTargetException
| IllegalAccessException
| NoSuchMethodException ex) {
throw new UnexpectedErrorException(ex);
}
throw new UnsupportedOperationException("Not supported yet."); //To change body of generated methods, choose Tools | Templates.
}
};
final BoxPanel right = new BoxPanel(BoxPanel.VERTICAL);
@ -138,6 +134,7 @@ public class PageModelTab extends LayoutPanel {
super.register(page);
page.addGlobalStateParam(selectedModelId.getStateParameter());
page.addGlobalStateParam(selectedComponentId.getStateParameter());
page.setVisibleDefault(addNewModel, true);
page.setVisibleDefault(pageModelsTable, true);

View File

@ -23,6 +23,7 @@ import com.arsdigita.bebop.Form;
import org.libreccm.l10n.GlobalizationHelper;
import org.libreccm.pagemodel.ComponentModel;
import org.libreccm.pagemodel.ComponentModelRepository;
import org.libreccm.pagemodel.ComponentModels;
import org.libreccm.pagemodel.PageModel;
import org.libreccm.pagemodel.PageModelComponentModel;
import org.libreccm.pagemodel.PageModelManager;
@ -33,6 +34,9 @@ import org.libreccm.web.CcmApplication;
import java.io.Serializable;
import java.util.ArrayList;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import java.util.ResourceBundle;
import java.util.stream.Collectors;
import javax.enterprise.context.RequestScoped;
@ -54,6 +58,9 @@ class PageModelsController implements Serializable {
@Inject
private ComponentModelRepository componentModelRepo;
@Inject
private ComponentModels componentModels;
@Inject
private GlobalizationHelper globalizationHelper;
@ -117,6 +124,22 @@ class PageModelsController implements Serializable {
return row;
}
protected String getComponentModelTitle(
final Class<? extends ComponentModel> clazz) {
final Optional<PageModelComponentModel> info = componentModels
.getComponentModelInfo(clazz);
if (info.isPresent()) {
final ResourceBundle bundle = ResourceBundle
.getBundle(info.get().descBundle());
return bundle.getString(info.get().titleKey());
} else {
return clazz.getName();
}
}
protected Class<? extends Form> getComponentModelForm(
final long componentModelId) {
@ -135,15 +158,16 @@ class PageModelsController implements Serializable {
protected Class<? extends Form> getComponentModelForm(
final Class<? extends ComponentModel> clazz) {
if (clazz.isAnnotationPresent(PageModelComponentModel.class)) {
Objects.requireNonNull(clazz);
final PageModelComponentModel annotation = clazz
.getAnnotation(PageModelComponentModel.class);
final Optional<PageModelComponentModel> info = componentModels
.getComponentModelInfo(clazz);
return annotation.editor();
} else {
return null;
}
return info
.orElseThrow(() -> new IllegalArgumentException(String
.format("No data about ComponentModel class \"%s\" available.",
clazz.getName())))
.editor();
}
@Transactional(Transactional.TxType.REQUIRED)
@ -162,6 +186,20 @@ class PageModelsController implements Serializable {
return components;
}
@Transactional(Transactional.TxType.REQUIRED)
protected void addComponentModel(final long pageModelId,
final ComponentModel componentModel) {
final PageModel model = pageModelRepo
.findById(pageModelId)
.orElseThrow(() -> new IllegalArgumentException(String
.format("No PageModel with ID %d in the database.",
pageModelId)));
pageModelManager.addComponentModel(model, componentModel);
}
@Transactional(Transactional.TxType.REQUIRED)
protected void removeComponentModel(final long pageModelId,
final long componentModelId) {

View File

@ -23,7 +23,10 @@ import org.libreccm.modules.Module;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Optional;
import java.util.ServiceLoader;
import javax.annotation.PostConstruct;
@ -36,7 +39,11 @@ import javax.enterprise.context.ApplicationScoped;
@ApplicationScoped
public class ComponentModels {
private final List<PageModelComponentModel> availableComponentModels = new ArrayList<>();
private final List<PageModelComponentModel> availableComponentModels
= new ArrayList<>();
private final Map<String, PageModelComponentModel> componentInfos
= new HashMap<>();
@PostConstruct
private void init() {
@ -55,6 +62,8 @@ public class ComponentModels {
for (final PageModelComponentModel componentModel : componentModels) {
availableComponentModels.add(componentModel);
componentInfos.put(componentModel.modelClass().getName(),
componentModel);
}
}
}
@ -63,4 +72,20 @@ public class ComponentModels {
return Collections.unmodifiableList(availableComponentModels);
}
public Optional<PageModelComponentModel> getComponentModelInfo(
final Class<? extends ComponentModel> clazz) {
return getComponentModelInfo(clazz.getName());
}
public Optional<PageModelComponentModel> getComponentModelInfo(
final String className) {
if (componentInfos.containsKey(className)) {
return Optional.of(componentInfos.get(className));
} else {
return Optional.empty();
}
}
}