/*******************************************************************************
* Copyright 2012 University of Southern California
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
* This code was developed by the Information Integration Group as part
* of the Karma project at the Information Sciences Institute of the
* University of Southern California. For more information, publications,
* and related projects, please see: http://www.isi.edu/integration
******************************************************************************/
/**
*
*/
package edu.isi.karma.rep;
import java.io.PrintWriter;
import java.util.List;
import org.json.JSONException;
import org.json.JSONWriter;
import edu.isi.karma.controller.update.WorksheetDataUpdate;
import edu.isi.karma.util.JSONUtil;
/**
* @author szekely
*
*/
public class TablePager {
private final Table table;
private int startIndex;
private int desiredSize;
private int size;
public TablePager(Table table, int startIndex, int desiredSize) {
super();
this.table = table;
this.startIndex = startIndex;
this.desiredSize = desiredSize;
setSize();
}
/**
* The size is adjusted in case the table is smaller than the desired size.
*/
private void setSize() {
if (desiredSize > table.getNumRows()) {
size = table.getNumRows();
} else {
size = desiredSize;
}
if (startIndex != 0 && (startIndex + 1) % desiredSize != 0) {
startIndex = Math.max(0, startIndex - (startIndex % desiredSize));
}
// If the # rows to get is bigger than the number of max rows that can
// be retrieved
int numAfter = getNumRecordsAfter();
if (numAfter < 0) {
size = table.getNumRows() - startIndex;
}
}
public List<Row> getRows() {
return table.getRows(startIndex, size);
}
public int getNumRecordsBefore() {
return startIndex;
}
public int getNumRecordsAfter() {
return table.getNumRows() - startIndex - size;
}
public int getDesiredSize() {
return desiredSize;
}
public void setDesiredSize(int desiredSize) {
this.desiredSize = desiredSize;
setSize();
}
public int getStartIndex() {
return startIndex;
}
public boolean isAllRowsShown() {
return 0 == (getNumRecordsAfter() + getNumRecordsBefore());
}
public void moveToPreviousPage() {
size = Math.max(size, desiredSize);
startIndex = Math.max(0, startIndex - size);
}
public void moveToNextPage() {
startIndex = Math.max(size, startIndex + size);
size = Math.min(size, table.getNumRows() - startIndex);
}
public void generateJson(String prefix, PrintWriter pw) {
pw.println(prefix + "{");
String newPref = prefix + " ";
pw.println(newPref
+ JSONUtil.json(WorksheetDataUpdate.JsonKeys.numRecordsShown, size));
pw.println(newPref
+ JSONUtil.json(WorksheetDataUpdate.JsonKeys.numRecordsBefore,
getNumRecordsBefore()));
pw.println(newPref
+ JSONUtil.json(WorksheetDataUpdate.JsonKeys.numRecordsAfter,
getNumRecordsAfter()));
pw.println(newPref
+ JSONUtil.json(
WorksheetDataUpdate.JsonKeys.desiredNumRecordsShown,
desiredSize));
pw.println(newPref
+ JSONUtil.jsonLast(WorksheetDataUpdate.JsonKeys.tableId,
table.getId()));
pw.println(prefix + "}");
}
/*****************************************************************
*
* Debugging Support
*
*****************************************************************/
public void prettyPrintJson(JSONWriter jw) throws JSONException {
jw.object()//
.key("size").value(size)//
.key("desiredSize").value(desiredSize)//
.key("startIndex").value(desiredSize)//
.key("_tableId").value(table.getId())//
.endObject();
}
}