CCM NG: PageModel AdminUI should now work
git-svn-id: https://svn.libreccm.org/ccm/ccm_ng@5130 8810af33-2d31-482b-a856-94f89814c4df
parent
6a90af6a90
commit
c0352bbb43
|
|
@ -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());
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
|||
|
|
@ -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[]{};
|
||||
|
|
|
|||
|
|
@ -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);
|
||||
|
|
|
|||
|
|
@ -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",
|
||||
|
|
|
|||
|
|
@ -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);
|
||||
|
|
|
|||
|
|
@ -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)
|
||||
|
|
@ -156,12 +180,26 @@ class PageModelsController implements Serializable {
|
|||
pageModelId)));
|
||||
|
||||
final List<ComponentModel> components = new ArrayList<>();
|
||||
for(final ComponentModel component : model.getComponents()) {
|
||||
for (final ComponentModel component : model.getComponents()) {
|
||||
components.add(component);
|
||||
}
|
||||
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) {
|
||||
|
|
|
|||
|
|
@ -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() {
|
||||
|
|
@ -53,8 +60,10 @@ public class ComponentModels {
|
|||
final PageModelComponentModel[] componentModels = moduleData
|
||||
.pageModelComponentModels();
|
||||
|
||||
for(final PageModelComponentModel componentModel : 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();
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
|||
Loading…
Reference in New Issue