unioffice/spreadsheet/cellmarker.go
Vyacheslav Zgordan dd7713e1e3 Functions2 (#348)
* MATCH, IFS, MAXA, MINA
* OFFSET fixed
* ISBLANK, ISERR, ISERROR, ISEVEN ,ISFORMULA, ISNONTEXT, ISNUMBER, ISODD, ISTEXT
* ISLEAPYEAR, ISLOGICAL, ISNA, ISREF
* FIND, FINDB
* SEARCH, SEARCHB
* CONCAT, CONCATENATE
* YEAR, YEARFRAC
* CONCAT is fixed, now TRUE and FALSE are concatenated instead of 1 and 0 in case of boolean results
* NOW, TODAY, TIME, TIMEVALUE
* DATE
* DATEDIF
2019-11-20 23:21:00 +00:00

71 lines
2.0 KiB
Go

// Copyright 2017 FoxyUtils ehf. All rights reserved.
//
// Use of this source code is governed by the terms of the Affero GNU General
// Public License version 3.0 as published by the Free Software Foundation and
// appearing in the file LICENSE included in the packaging of this file. A
// commercial license can be purchased on https://unidoc.io.
package spreadsheet
import (
"github.com/unidoc/unioffice"
"github.com/unidoc/unioffice/measurement"
sd "github.com/unidoc/unioffice/schema/soo/dml/spreadsheetDrawing"
)
// CellMarker represents a cell position
type CellMarker struct {
x *sd.CT_Marker
}
// X returns the inner wrapped XML type.
func (c CellMarker) X() *sd.CT_Marker {
return c.x
}
// Col returns the column of the cell marker.
func (c CellMarker) Col() int32 {
return c.x.Col
}
// SetCol set the column of the cell marker.
func (c CellMarker) SetCol(col int32) {
c.x.Col = col
}
// Row returns the row of the cell marker.
func (c CellMarker) Row() int32 {
return c.x.Row
}
// SetRow set the row of the cell marker.
func (c CellMarker) SetRow(row int32) {
c.x.Row = row
}
// SetColOffset sets a column offset in absolute distance.
func (c CellMarker) SetColOffset(m measurement.Distance) {
c.x.ColOff.ST_CoordinateUnqualified = unioffice.Int64(int64(m / measurement.EMU))
}
// ColOffset returns the offset from the row cell.
func (c CellMarker) ColOffset() measurement.Distance {
if c.x.RowOff.ST_CoordinateUnqualified == nil {
return 0
}
return measurement.Distance(float64(*c.x.ColOff.ST_CoordinateUnqualified) * measurement.EMU)
}
// SetRowOffset sets a column offset in absolute distance.
func (c CellMarker) SetRowOffset(m measurement.Distance) {
c.x.RowOff.ST_CoordinateUnqualified = unioffice.Int64(int64(m / measurement.EMU))
}
// RowOffset returns the offset from the row cell.
func (c CellMarker) RowOffset() measurement.Distance {
if c.x.RowOff.ST_CoordinateUnqualified == nil {
return 0
}
return measurement.Distance(float64(*c.x.RowOff.ST_CoordinateUnqualified) * measurement.EMU)
}