br.com.objectos.way.io.xls.PoiWorksheetRowWriterBoolean Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of way-io Show documentation
Show all versions of way-io Show documentation
CSV, XLS and fixed parsers
The newest version!
/*
* Copyright 2014 Objectos, Fábrica de Software LTDA.
*
* 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.
*/
package br.com.objectos.way.io.xls;
import org.apache.poi.ss.usermodel.Cell;
import com.google.common.base.Preconditions;
/**
* @author [email protected] (Marcio Endo)
*/
class PoiWorksheetRowWriterBoolean extends PoiWorksheetRowWriter implements WorksheetRowWriterBoolean {
private final boolean trueOrFalse;
private String trueText = "x";
private String falseText = null;
public PoiWorksheetRowWriterBoolean(PoiWorksheetRow row, boolean trueOrFalse) {
super(row);
this.trueOrFalse = trueOrFalse;
}
@Override
public WorksheetRowWriterStyle asText(String trueValue, String falseValue) {
this.trueText = Preconditions.checkNotNull(trueValue);
this.falseText = Preconditions.checkNotNull(falseValue);
return this;
}
@Override
public WorksheetRowWriterStyle falseAsText(String falseText) {
this.trueText = null;
this.falseText = falseText;
return this;
}
@Override
public WorksheetRowWriterStyle trueAsText(String trueText) {
this.trueText = trueText;
this.falseText = null;
return this;
}
@Override
void write(Cell cell) {
cell.setCellType(Cell.CELL_TYPE_BLANK);
String cellValue = trueOrFalse ? trueText : falseText;
if (cellValue != null) {
cell.setCellType(Cell.CELL_TYPE_STRING);
cell.setCellValue(cellValue);
}
}
}