# HG changeset patch # User Robert Casties # Date 1541531149 -3600 # Node ID 34ac2e1b323aa822bcc051c5176493d3ae47756b # Parent be6bc580b13713488680bfb97ee77216de51234b new Clean UI to find non-public digitalizations of public codices and make them public. diff -r be6bc580b137 -r 34ac2e1b323a src/main/java/de/mpiwg/itgroup/ismi/browse/FullEntityRepositoryBean.java --- a/src/main/java/de/mpiwg/itgroup/ismi/browse/FullEntityRepositoryBean.java Tue Oct 30 20:09:59 2018 +0100 +++ b/src/main/java/de/mpiwg/itgroup/ismi/browse/FullEntityRepositoryBean.java Tue Nov 06 20:05:49 2018 +0100 @@ -97,19 +97,29 @@ // sort List (by attribute) Collections.sort(resultList, getEntityAttributeComparator(this.sortAttributeName, this.sortAttributeNumerically)); - this.entities = resultList; + + updateEntities(resultList); + logger.debug("Done sortByAttributes."); + } - if (resultList.size() > 0) { - this.resultSummaryMsg = resultList.size() + " items were found!"; + /** + * Update paginator and summary message with new entities list. + * + * @param resultList + */ + public void updateEntities(List resultList) { + this.entities = resultList; + if (resultList.size() > 0) { + int entitiesCount = this.entities.size(); + this.resultSummaryMsg = entitiesCount + " items were found!"; this.advancedPaginator.setCurrentPage(0); - int entitiesCount = this.entities.size(); this.advancedPaginator.resetNumberOfPages(entitiesCount); this.updateAdvancedEntities(); } else { this.resultSummaryMsg = "No items were found!"; + this.currentEntities = resultList; } - logger.debug("Done sortByAttributes."); - } + } /** * Returns Comparator for Entities that uses the Attribute attname. @@ -230,16 +240,8 @@ // sort List (by ownValue) Collections.sort(entities); - - if (entities.size() > 0) { - int entitiesCount = entities.size(); - this.resultSummaryMsg = entitiesCount + " items were found!"; - this.advancedPaginator.setCurrentPage(0); - this.advancedPaginator.resetNumberOfPages(entitiesCount); - this.updateAdvancedEntities(); - } else { - this.resultSummaryMsg = "No items were found!"; - } + + updateEntities(entities); logger.debug("Done searchByRelations."); } diff -r be6bc580b137 -r 34ac2e1b323a src/main/java/de/mpiwg/itgroup/ismi/entry/beans/SessionBean.java --- a/src/main/java/de/mpiwg/itgroup/ismi/entry/beans/SessionBean.java Tue Oct 30 20:09:59 2018 +0100 +++ b/src/main/java/de/mpiwg/itgroup/ismi/entry/beans/SessionBean.java Tue Nov 06 20:05:49 2018 +0100 @@ -28,6 +28,7 @@ import de.mpiwg.itgroup.ismi.merge.GeneralMerge; import de.mpiwg.itgroup.ismi.merge.ImportMerge; import de.mpiwg.itgroup.ismi.merge.MissingRelationsBean; +import de.mpiwg.itgroup.ismi.merge.NonpublicEntitiesBean; import de.mpiwg.itgroup.ismi.merge.PublicByAuthorBean; import de.mpiwg.itgroup.ismi.merge.ReferenceMerge; import de.mpiwg.itgroup.ismi.publicView.DynamicPageEditor; @@ -51,6 +52,7 @@ private transient AdvancedSearchBean advancedSearch = new AdvancedSearchBean(); private transient PublicByAuthorBean publicByAuthor = new PublicByAuthorBean(); private transient MissingRelationsBean missingRelations = new MissingRelationsBean(); + private transient NonpublicEntitiesBean nonpublicEntities = new NonpublicEntitiesBean(); private EntityDetailsBean entDetailsForm = new EntityDetailsBean(); @@ -1123,6 +1125,14 @@ public void setMissingRelations(MissingRelationsBean missingRelations) { this.missingRelations = missingRelations; } + + public NonpublicEntitiesBean getNonpublicEntities() { + return nonpublicEntities; + } + + public void setNonpublicEntities(NonpublicEntitiesBean nonpublicEntities) { + this.nonpublicEntities = nonpublicEntities; + } diff -r be6bc580b137 -r 34ac2e1b323a src/main/java/de/mpiwg/itgroup/ismi/merge/NonpublicEntitiesBean.java --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/main/java/de/mpiwg/itgroup/ismi/merge/NonpublicEntitiesBean.java Tue Nov 06 20:05:49 2018 +0100 @@ -0,0 +1,127 @@ +package de.mpiwg.itgroup.ismi.merge; + +import java.io.Serializable; +import java.util.ArrayList; +import java.util.List; + +import org.apache.log4j.Logger; +import org.mpi.openmind.repository.bo.Entity; +import org.mpi.openmind.repository.bo.Relation; +import org.mpi.openmind.repository.services.utils.RelationFilter; +import org.richfaces.event.ItemChangeEvent; + +import de.mpiwg.itgroup.ismi.browse.EntityRepositoryBean; +import de.mpiwg.itgroup.ismi.browse.FullEntityRepositoryBean; +import de.mpiwg.itgroup.ismi.entry.beans.AbstractISMIBean; +import de.mpiwg.itgroup.ismi.entry.utils.PrivacityUtils; + +public class NonpublicEntitiesBean extends AbstractISMIBean implements Serializable{ + + private static Logger logger = Logger.getLogger(NonpublicEntitiesBean.class); + + private static final long serialVersionUID = 1L; + + protected FullEntityRepositoryBean browseBean; + + protected String selectedTab = "aut"; + + + public NonpublicEntitiesBean(){ + //logger.info("AdvancedSearchBean"); + this.reset(); + } + + public synchronized void reset(){ + logger.info("MissingRelationsBean.reset()"); + browseBean = new FullEntityRepositoryBean(); + logger.info("MissingRelationsBean.reset() Done."); + } + + + public void actionFindNonpublicDigitalizations() { + logger.debug("Start findNonpublicDigitalizations..."); + List relFilters = new ArrayList(); + /* + * find DIGITALIZATION is_digitalization_of CODEX relation + */ + browseBean = new FullEntityRepositoryBean(); + browseBean.setObjectClass(DIGITALIZATION); + RelationFilter relFilter = new RelationFilter(); + relFilter.relObjectClass = "is_digitalization_of"; + relFilter.tarObjectClass = "CODEX"; + relFilters.add(relFilter); + try { + // search all digitalizations + browseBean.searchByRelations(relFilters); + // filter out non-public DIGITALIZATIONs of public CODEXs + List entities = browseBean.getEntities(); + List nonpublicEntities = new ArrayList(); + for (Entity ent : entities) { + if (!ent.getIsPublic()) { + List rels = ent.getSourceRelations("is_digitalization_of", CODEX); + for (Relation rel : rels) { + Entity tar = getWrapper().getEntityById(rel.getTargetId()); + if (tar.getIsPublic()) { + nonpublicEntities.add(ent); + break; + } + } + } + } + browseBean.updateEntities(nonpublicEntities); + + } catch (Exception e) { + logger.error(e); + } + logger.debug("Done findNonpublicDigitalizations."); + } + + /** + * Makes the selected digitalizations public. + * Uses PrivacityUtils.setTextAndMorePrivacity(). + * @return + */ + public String actionMakeDigitalizationsPublic() { + logger.info("MAKE DIGITALIZATIONS PUBLIC"); + List textMsg = new ArrayList(); + try { + List entities = browseBean.getEntities(); + if (entities.size() == 0) return null; + for (Entity ent : entities) { + PrivacityUtils.changeEntityPrivacity(ent, true, getWrapper()); + textMsg.add("Set public=true on "+ent.getShortString()+"\n"); + } + // save only public state + getWrapper().saveEntityListAsNodeWithoutContent(entities, null); + } catch (Exception e) { + logger.error(e); + } + for (String msg : textMsg) { + this.addGeneralMsg(msg); + logger.debug(msg); + } + addGeneralMsg(browseBean.getEntities().size() + " DIGITALIZATIONS were made public!"); + return null; + } + + + public EntityRepositoryBean getBrowseBean() { + return browseBean; + } + + public void listenerTabChange(ItemChangeEvent event) { + reset(); + String url = "?formIndex=" + selectedTab; + redirect(null, url); + } + + public String getSelectedTab() { + return selectedTab; + } + + public void setSelectedTab(String selectedMissingRelationsTab) { + selectedTab = selectedMissingRelationsTab; + } + + +} diff -r be6bc580b137 -r 34ac2e1b323a src/main/webapp/clean/components/nonpublicDigitalization.xhtml --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/main/webapp/clean/components/nonpublicDigitalization.xhtml Tue Nov 06 20:05:49 2018 +0100 @@ -0,0 +1,156 @@ + + + + + + +

non-public Digitalizations of public Codices

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Text + + + + + + + State + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ + diff -r be6bc580b137 -r 34ac2e1b323a src/main/webapp/clean/nonpublicEntities.xhtml --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/main/webapp/clean/nonpublicEntities.xhtml Tue Nov 06 20:05:49 2018 +0100 @@ -0,0 +1,39 @@ + + + + + + + + + + +
+ +
+ + + + + + + + + + + + + +
+
+ + + \ No newline at end of file diff -r be6bc580b137 -r 34ac2e1b323a src/main/webapp/templates/main_template.xhtml --- a/src/main/webapp/templates/main_template.xhtml Tue Oct 30 20:09:59 2018 +0100 +++ b/src/main/webapp/templates/main_template.xhtml Tue Nov 06 20:05:49 2018 +0100 @@ -181,6 +181,10 @@ + + +