Skip to content
Snippets Groups Projects
Commit 1088af99 authored by uhensler's avatar uhensler
Browse files

OO-5301: Standard user display name in large files list

parent beb222a5
No related branches found
No related tags found
No related merge requests found
......@@ -79,6 +79,7 @@ import org.olat.core.util.StringHelper;
import org.olat.core.util.mail.ContactList;
import org.olat.core.util.mail.ContactMessage;
import org.olat.modules.co.ContactFormController;
import org.olat.user.ui.UserDisplayNameCellRenderer;
import org.springframework.beans.factory.annotation.Autowired;
......@@ -215,9 +216,7 @@ public class LargeFilesController extends FormBasicController implements Extende
}
}
Collections.sort(rows, (row1,row2) -> {
return row2.getSize().intValue() - row1.getSize().intValue();
});
Collections.sort(rows, (row1, row2) -> (row2.getSize().intValue() - row1.getSize().intValue()));
if(maxResults != 0 && maxResults < rows.size()) {
rows = rows.subList(0, maxResults);
......@@ -332,7 +331,9 @@ public class LargeFilesController extends FormBasicController implements Extende
columnsModel.addFlexiColumnModel(new DefaultFlexiColumnModel(false, LargeFilesTableColumns.fileType));
columnsModel.addFlexiColumnModel(new DefaultFlexiColumnModel(false, LargeFilesTableColumns.downloadCount));
columnsModel.addFlexiColumnModel(new DefaultFlexiColumnModel(false, LargeFilesTableColumns.author, "selectAuthor"));
DefaultFlexiColumnModel authorModel = new DefaultFlexiColumnModel(false, LargeFilesTableColumns.author, "selectAuthor");
authorModel.setCellRenderer(UserDisplayNameCellRenderer.get());
columnsModel.addFlexiColumnModel(authorModel);
columnsModel.addFlexiColumnModel(new DefaultFlexiColumnModel(false, LargeFilesTableColumns.license));
columnsModel.addFlexiColumnModel(new DefaultFlexiColumnModel(false, LargeFilesTableColumns.language));
columnsModel.addFlexiColumnModel(new DefaultFlexiColumnModel(false, LargeFilesTableColumns.source));
......@@ -342,7 +343,9 @@ public class LargeFilesController extends FormBasicController implements Extende
columnsModel.addFlexiColumnModel(column);
columnsModel.addFlexiColumnModel(new DefaultFlexiColumnModel(false, LargeFilesTableColumns.lockedAt));
columnsModel.addFlexiColumnModel(new DefaultFlexiColumnModel(false, LargeFilesTableColumns.lockedBy, "selectLockedBy"));
DefaultFlexiColumnModel lockedByModel = new DefaultFlexiColumnModel(false, LargeFilesTableColumns.lockedBy, "selectLockedBy");
lockedByModel.setCellRenderer(UserDisplayNameCellRenderer.get());
columnsModel.addFlexiColumnModel(lockedByModel);
columnsModel.addFlexiColumnModel(new DefaultFlexiColumnModel(false, LargeFilesTableColumns.creator));
columnsModel.addFlexiColumnModel(new DefaultFlexiColumnModel(false, LargeFilesTableColumns.publisher));
columnsModel.addFlexiColumnModel(new DefaultFlexiColumnModel(false, LargeFilesTableColumns.pubDate));
......
......@@ -42,7 +42,7 @@ public class LargeFilesTableModel extends DefaultFlexiTableDataModel<LargeFilesT
implements SortableFlexiTableDataModel<LargeFilesTableContentRow> {
private final Locale locale;
public LargeFilesTableModel(FlexiTableColumnModel columnModel, Locale locale) {
super(columnModel);
this.locale = locale;
......@@ -72,7 +72,7 @@ implements SortableFlexiTableDataModel<LargeFilesTableContentRow> {
case contextInfo: return row.getContextInfo();
case path: return row.getPath();
case showPath: return row.getShowPath();
case author: return row.getAuthor() != null ? row.getAuthor().getUser().getFirstName() + " " + row.getAuthor().getUser().getLastName() : null;
case author: return row.getAuthor();
case revision: return row.isRevision();
case fileCategory: return row.getFileCategory();
case fileType: return row.getFileType();
......@@ -91,7 +91,7 @@ implements SortableFlexiTableDataModel<LargeFilesTableContentRow> {
case pubDate: return returnNullSafeDate(row.getPubDate());
case language: return row.getLanguage();
case locked: return row.isLocked();
case lockedBy: return row.getLockedBy() != null ? row.getLockedBy().getUser().getFirstName() + " " + row.getLockedBy().getUser().getLastName() : null;
case lockedBy: return row.getLockedBy();
case lockedAt: return returnNullSafeDate(row.getLockedAt());
case revisionComment: return row.getRevisionComment();
case revisionNr: return row.getRevisionNr();
......
/**
* <a href="http://www.openolat.org">
* OpenOLAT - Online Learning and Training</a><br>
* <p>
* Licensed under the Apache License, Version 2.0 (the "License"); <br>
* you may not use this file except in compliance with the License.<br>
* You may obtain a copy of the License at the
* <a href="http://www.apache.org/licenses/LICENSE-2.0">Apache homepage</a>
* <p>
* Unless required by applicable law or agreed to in writing,<br>
* software distributed under the License is distributed on an "AS IS" BASIS, <br>
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. <br>
* See the License for the specific language governing permissions and <br>
* limitations under the License.
* <p>
* Initial code contributed and copyrighted by<br>
* frentix GmbH, http://www.frentix.com
* <p>
*/
package org.olat.user.ui;
import org.olat.core.CoreSpringFactory;
import org.olat.core.gui.components.form.flexible.impl.elements.table.FlexiCellRenderer;
import org.olat.core.gui.components.form.flexible.impl.elements.table.FlexiTableComponent;
import org.olat.core.gui.render.Renderer;
import org.olat.core.gui.render.StringOutput;
import org.olat.core.gui.render.URLBuilder;
import org.olat.core.gui.translator.Translator;
import org.olat.core.id.Identity;
import org.olat.core.id.User;
import org.olat.user.UserManager;
/**
*
* Initial date: 19 Feb 2021<br>
* @author uhensler, urs.hensler@frentix.com, http://www.frentix.com
*
*/
public class UserDisplayNameCellRenderer implements FlexiCellRenderer {
private static final UserDisplayNameCellRenderer INSTANCE = new UserDisplayNameCellRenderer();
private final UserManager userManager;
public static UserDisplayNameCellRenderer get() {
return INSTANCE;
}
private UserDisplayNameCellRenderer() {
this.userManager = CoreSpringFactory.getImpl(UserManager.class);
}
@Override
public void render(Renderer renderer, StringOutput target, Object cellValue, int row, FlexiTableComponent source,
URLBuilder ubu, Translator translator) {
if (cellValue instanceof Identity) {
String userDisplayName = userManager.getUserDisplayName(((Identity)cellValue).getKey());
target.append(userDisplayName);
} else if (cellValue instanceof User) {
String userDisplayName = userManager.getUserDisplayName(((User)cellValue));
target.append(userDisplayName);
}
}
}
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment