All Downloads are FREE. Search and download functionalities are using the official Maven repository.

br.com.objectos.way.io.xls.PoiWorksheetRowWriterBoolean Maven / Gradle / Ivy

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);
    }
  }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy