CCM NG/ccm-cms: Fixed some queries for getting avaiable images.
git-svn-id: https://svn.libreccm.org/ccm/ccm_ng@4899 8810af33-2d31-482b-a856-94f89814c4dfccm-docs
parent
51419eb055
commit
b1ca4f3db6
|
|
@ -31,6 +31,7 @@ class AssignedImageTableRow {
|
|||
private long width;
|
||||
private long height;
|
||||
private String type;
|
||||
private String title;
|
||||
private String caption;
|
||||
|
||||
public long getAttachmentId() {
|
||||
|
|
@ -81,6 +82,14 @@ class AssignedImageTableRow {
|
|||
this.type = type;
|
||||
}
|
||||
|
||||
public String getTitle() {
|
||||
return title;
|
||||
}
|
||||
|
||||
public void setTitle(final String title) {
|
||||
this.title = title;
|
||||
}
|
||||
|
||||
public String getCaption() {
|
||||
return caption;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -48,10 +48,11 @@ import org.librecms.contentsection.ItemAttachment;
|
|||
class AssignedImagesTable extends Table {
|
||||
|
||||
protected static final int COL_PREVIEW = 0;
|
||||
protected static final int COL_IMAGE_DATA = 1;
|
||||
protected static final int COL_CAPTION = 2;
|
||||
protected static final int COL_MOVE = 3;
|
||||
protected static final int COL_REMOVE = 4;
|
||||
protected static final int COL_TITLE = 1;
|
||||
protected static final int COL_IMAGE_DATA = 2;
|
||||
protected static final int COL_CAPTION = 3;
|
||||
protected static final int COL_MOVE = 4;
|
||||
protected static final int COL_REMOVE = 5;
|
||||
|
||||
private final ItemSelectionModel itemSelectionModel;
|
||||
private final ItemAttachmentSelectionModel moveAttachmentModel;
|
||||
|
|
@ -73,6 +74,11 @@ class AssignedImagesTable extends Table {
|
|||
new Label(new GlobalizedMessage(
|
||||
"cms.ui.authoring.assets.imagestep.assigned_images.preview_header",
|
||||
CmsConstants.CMS_BUNDLE))));
|
||||
columnModel.add(new TableColumn(
|
||||
COL_TITLE,
|
||||
new Label(new GlobalizedMessage(
|
||||
"cms.ui.authoring.assets.imagestep.assigned_images.title_header",
|
||||
CmsConstants.CMS_BUNDLE))));
|
||||
columnModel.add(new TableColumn(
|
||||
COL_IMAGE_DATA,
|
||||
new Label(new GlobalizedMessage(
|
||||
|
|
|
|||
|
|
@ -87,6 +87,8 @@ class AssignedImagesTableModel implements TableModel {
|
|||
|
||||
return imageProperties;
|
||||
}
|
||||
case AssignedImagesTable.COL_TITLE:
|
||||
return currentRow.getTitle();
|
||||
case AssignedImagesTable.COL_CAPTION:
|
||||
return currentRow.getCaption();
|
||||
case AssignedImagesTable.COL_MOVE:
|
||||
|
|
|
|||
|
|
@ -18,6 +18,9 @@
|
|||
*/
|
||||
package com.arsdigita.cms.ui.authoring.assets.images;
|
||||
|
||||
import com.arsdigita.kernel.KernelConfig;
|
||||
|
||||
import org.libreccm.configuration.ConfigurationManager;
|
||||
import org.libreccm.l10n.LocalizedString;
|
||||
import org.librecms.assets.Image;
|
||||
import org.librecms.contentsection.AssetRepository;
|
||||
|
|
@ -35,6 +38,7 @@ import java.util.Locale;
|
|||
import java.util.Objects;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
import javax.annotation.PostConstruct;
|
||||
import javax.enterprise.context.RequestScoped;
|
||||
import javax.inject.Inject;
|
||||
import javax.persistence.EntityManager;
|
||||
|
|
@ -54,21 +58,34 @@ import javax.transaction.Transactional;
|
|||
@RequestScoped
|
||||
class ImageStepController {
|
||||
|
||||
@Inject
|
||||
private EntityManager entityManager;
|
||||
|
||||
@Inject
|
||||
private ContentItemRepository itemRepo;
|
||||
|
||||
@Inject
|
||||
private AssetRepository assetRepo;
|
||||
|
||||
@Inject
|
||||
private AttachmentListManager attachmentListManager;
|
||||
|
||||
@Inject
|
||||
private ConfigurationManager confManager;
|
||||
|
||||
@Inject
|
||||
private ContentItemRepository itemRepo;
|
||||
|
||||
@Inject
|
||||
private EntityManager entityManager;
|
||||
|
||||
@Inject
|
||||
private ItemAttachmentManager attachmentManager;
|
||||
|
||||
private Locale defaultLocale;
|
||||
|
||||
@PostConstruct
|
||||
private void init() {
|
||||
|
||||
final KernelConfig kernelConfig = confManager
|
||||
.findConfiguration(KernelConfig.class);
|
||||
defaultLocale = kernelConfig.getDefaultLocale();
|
||||
}
|
||||
|
||||
@Transactional(Transactional.TxType.REQUIRED)
|
||||
protected List<ItemAttachment<Image>> retrieveAssignedImages(
|
||||
final ContentItem fromContentItem) {
|
||||
|
|
@ -284,14 +301,15 @@ class ImageStepController {
|
|||
|
||||
query
|
||||
.select(criteriaBuilder.count(from));
|
||||
|
||||
if (filter == null || filter.trim().isEmpty()) {
|
||||
if (excluededImages != null && !excluededImages.isEmpty()) {
|
||||
query.where(criteriaBuilder.not(from.in(excluededImages)));
|
||||
}
|
||||
} else {
|
||||
if (excluededImages == null || excluededImages.isEmpty()) {
|
||||
criteriaBuilder.like(titleValuesJoin,
|
||||
String.format("%s%%", filter));
|
||||
query.where(criteriaBuilder.like(titleValuesJoin,
|
||||
String.format("%s%%", filter)));
|
||||
} else {
|
||||
query.where(criteriaBuilder.and(
|
||||
criteriaBuilder.not(from.in(excluededImages)),
|
||||
|
|
@ -327,8 +345,9 @@ class ImageStepController {
|
|||
}
|
||||
} else {
|
||||
if (excludedImages == null || excludedImages.isEmpty()) {
|
||||
criteriaBuilder.like(titleValuesJoin,
|
||||
String.format("%s%%", filter));
|
||||
criteriaQuery
|
||||
.where(criteriaBuilder.like(titleValuesJoin,
|
||||
String.format("%s%%", filter)));
|
||||
} else {
|
||||
criteriaQuery.where(criteriaBuilder.and(
|
||||
criteriaBuilder.not(from.in(excludedImages)),
|
||||
|
|
@ -369,7 +388,13 @@ class ImageStepController {
|
|||
final AvailableImageTableRow row = new AvailableImageTableRow();
|
||||
row.setImageId(image.getObjectId());
|
||||
row.setImageUuid(image.getUuid());
|
||||
row.setTitle(image.getTitle().getValue(selectedLocale));
|
||||
if (image.getTitle().hasValue(selectedLocale)) {
|
||||
row.setTitle(image.getTitle().getValue(selectedLocale));
|
||||
} else if(image.getTitle().hasValue(defaultLocale)){
|
||||
row.setTitle(image.getTitle().getValue(defaultLocale));
|
||||
} else {
|
||||
row.setTitle(image.getTitle().getValue());
|
||||
}
|
||||
row.setFilename(image.getFileName());
|
||||
row.setWidth(image.getWidth());
|
||||
row.setHeight(image.getHeight());
|
||||
|
|
@ -422,6 +447,13 @@ class ImageStepController {
|
|||
row.setWidth(image.getWidth());
|
||||
row.setHeight(image.getHeight());
|
||||
row.setType(image.getMimeType().toString());
|
||||
if (image.getTitle().hasValue(selectedLocale)) {
|
||||
row.setTitle(image.getTitle().getValue(selectedLocale));
|
||||
} else if(image.getTitle().hasValue(defaultLocale)){
|
||||
row.setTitle(image.getTitle().getValue(defaultLocale));
|
||||
} else {
|
||||
row.setTitle(image.getTitle().getValue());
|
||||
}
|
||||
row.setCaption(image.getDescription().getValue(selectedLocale));
|
||||
|
||||
return row;
|
||||
|
|
|
|||
|
|
@ -412,3 +412,4 @@ cms.ui.authoring.assets.imagestep.assigned_images.cancel_add_image=Cancel
|
|||
cms.ui.authoring.assets.imagestep.available_images.none=No images available
|
||||
cms.ui.authoring.assets.imagestep.available_images.title_header=Title
|
||||
cms.ui.authoring.assets.imagestep.available_images.add=Add
|
||||
cms.ui.authoring.assets.imagestep.assigned_images.title_header=Title
|
||||
|
|
|
|||
|
|
@ -409,3 +409,4 @@ cms.ui.authoring.assets.imagestep.assigned_images.cancel_add_image=Abbrechen
|
|||
cms.ui.authoring.assets.imagestep.available_images.none=Keine Bilder verf\u00fcgbar
|
||||
cms.ui.authoring.assets.imagestep.available_images.title_header=Titel
|
||||
cms.ui.authoring.assets.imagestep.available_images.add=Hinzuf\u00fcgen
|
||||
cms.ui.authoring.assets.imagestep.assigned_images.title_header=Titel
|
||||
|
|
|
|||
|
|
@ -368,3 +368,4 @@ cms.ui.authoring.assets.imagestep.assigned_images.cancel_add_image=Cancel
|
|||
cms.ui.authoring.assets.imagestep.available_images.none=No images available
|
||||
cms.ui.authoring.assets.imagestep.available_images.title_header=Title
|
||||
cms.ui.authoring.assets.imagestep.available_images.add=Add
|
||||
cms.ui.authoring.assets.imagestep.assigned_images.title_header=Title
|
||||
|
|
|
|||
Loading…
Reference in New Issue