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

com.jameskleeh.excel.style.CellRangeBorderStyleApplier.groovy Maven / Gradle / Ivy

package com.jameskleeh.excel.style

import org.apache.poi.ss.usermodel.Cell
import org.apache.poi.ss.usermodel.Row
import org.apache.poi.ss.util.CellUtil
import org.apache.poi.xssf.usermodel.XSSFCellStyle
import org.apache.poi.xssf.usermodel.XSSFSheet
import groovy.transform.CompileStatic
import groovy.transform.TupleConstructor
import org.apache.poi.ss.usermodel.BorderStyle
import org.apache.poi.ss.usermodel.Sheet
import org.apache.poi.ss.util.CellRangeAddress
import org.apache.poi.xssf.usermodel.XSSFColor
import org.apache.poi.xssf.usermodel.extensions.XSSFCellBorder.BorderSide

/**
 * Applys styles and borders to a range of cells (merged).
 * Assumes the merged region is within a single row or column, which
 * is all that is supported in the current API
 *
 * @author James Kleeh
 */
@CompileStatic
@TupleConstructor
abstract class CellRangeBorderStyleApplier implements BorderStyleApplier {

    CellRangeAddress range
    Sheet sheet

    protected XSSFCellStyle leftTop
    protected XSSFCellStyle middle
    protected XSSFCellStyle bottomRight

    CellRangeBorderStyleApplier(CellRangeAddress range, XSSFSheet sheet) {
        this.range = range
        this.sheet = sheet
        leftTop = sheet.workbook.createCellStyle()
        if (range.numberOfCells > 2) {
            middle = sheet.workbook.createCellStyle()
        }
        bottomRight = sheet.workbook.createCellStyle()

        Row row = CellUtil.getRow(range.firstRow, sheet)
        leftTop.cloneStyleFrom(CellUtil.getCell(row, range.firstColumn).cellStyle)
        middle?.cloneStyleFrom(leftTop)
        bottomRight.cloneStyleFrom(leftTop)
    }

    @Override
    abstract void applyStyle(BorderSide side, BorderStyle style)

    @Override
    void applyStyle(BorderStyle style) {
        BorderSide.values().each { BorderSide side ->
            applyStyle(side, style)
        }
    }

    @Override
    abstract void applyColor(BorderSide side, XSSFColor color)

    @Override
    void applyColor(XSSFColor color) {
        BorderSide.values().each { BorderSide side ->
            applyColor(side, color)
        }
    }

    private void loopRows(Closure c) {
        int start = range.firstRow
        int end = range.lastRow
        for (int i = start; i <= end; i++) {
            c.call(CellUtil.getRow(i, sheet), i == start, i == end)
        }
    }

    private void loopColumns(Row row, Closure c) {
        int start = range.firstColumn
        int end = range.lastColumn
        for (int i = start; i <= end; i++) {
            c.call(CellUtil.getCell(row, i), i == start, i == end)
        }
    }

    void setStyles() {
        loopRows { Row row, boolean firstRow, boolean lastRow ->
            loopColumns(row) { Cell cell, boolean firstCol, boolean lastCol ->
                if (firstRow && firstCol) {
                    cell.setCellStyle(leftTop)
                } else if (lastRow && lastCol) {
                    cell.setCellStyle(bottomRight)
                } else {
                    cell.setCellStyle(middle)
                }
            }
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy