package org.activityinfo.ui.client.page.entry.column;
/*
* #%L
* ActivityInfo Server
* %%
* Copyright (C) 2009 - 2013 UNICEF
* %%
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public
* License along with this program. If not, see
* <http://www.gnu.org/licenses/gpl-3.0.html>.
* #L%
*/
import com.extjs.gxt.ui.client.data.ModelData;
import com.extjs.gxt.ui.client.store.ListStore;
import com.extjs.gxt.ui.client.widget.grid.ColumnData;
import com.extjs.gxt.ui.client.widget.grid.Grid;
import com.extjs.gxt.ui.client.widget.grid.GridCellRenderer;
import com.google.common.collect.Sets;
import com.google.gwt.safehtml.shared.SafeHtmlBuilder;
import org.activityinfo.legacy.shared.model.AdminEntityDTO;
import org.activityinfo.legacy.shared.model.AdminLevelDTO;
import org.activityinfo.legacy.shared.model.AdminLevelPredicates;
import org.activityinfo.legacy.shared.model.SiteDTO;
import java.util.List;
import java.util.Set;
/**
* Renders the site's admin membership as a single cell, with a maximum of three
* rows, with a quick tip for the rest.
*/
public class AdminColumnRenderer implements GridCellRenderer<ModelData> {
private List<AdminLevelDTO> levels;
// reused to avoid reallocing for each row
private Set<String> seen = Sets.newHashSet();
public AdminColumnRenderer(List<AdminLevelDTO> levels) {
super();
this.levels = AdminLevelPredicates.breadthFirstSort(levels);
}
@Override
public Object render(ModelData model,
String property,
ColumnData config,
int rowIndex,
int colIndex,
ListStore<ModelData> store,
Grid<ModelData> grid) {
if (model instanceof SiteDTO) {
return render((SiteDTO) model);
} else {
return "";
}
}
private Object render(SiteDTO model) {
StringBuilder qtip = new StringBuilder();
SafeHtmlBuilder summary = new SafeHtmlBuilder();
// we use this set to keep track of names that we've added
// to the summary to avoid duplication that is common between
// territories, zones de sante, provinces and districts, etc
seen.clear();
int summaryLines = 0;
for (AdminLevelDTO level : levels) {
AdminEntityDTO entity = model.getAdminEntity(level.getId());
if (entity != null) {
String name = entity.getName();
if (qtip.length() > 0) {
qtip.append("<br>");
}
qtip.append(level.getName()).append(": ").append(name);
if (summaryLines < 3 && !seen.contains(name)) {
if (summaryLines > 0) {
summary.appendHtmlConstant("<br/>");
}
summary.appendEscaped(name);
seen.add(name);
summaryLines++;
}
}
}
// return summary.toSafeHtml().asString();
return ColumnTemplates.INSTANCE.adminCell(qtip.toString(), summary.toSafeHtml()).asString();
}
}