MoneyWiseSheetSecurity.java
/*
* MoneyWise: Finance Application
* Copyright 2012-2026. Tony Washer
*
* 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 io.github.tonywasher.joceanus.moneywise.sheets;
import io.github.tonywasher.joceanus.oceanus.base.OceanusException;
import io.github.tonywasher.joceanus.moneywise.data.basic.MoneyWiseBasicResource;
import io.github.tonywasher.joceanus.moneywise.data.basic.MoneyWiseDataSet;
import io.github.tonywasher.joceanus.moneywise.data.basic.MoneyWiseSecurity;
import io.github.tonywasher.joceanus.moneywise.data.statics.MoneyWiseStaticDataType;
import io.github.tonywasher.joceanus.prometheus.data.PrometheusDataResource;
import io.github.tonywasher.joceanus.prometheus.data.PrometheusDataValues;
import io.github.tonywasher.joceanus.prometheus.sheets.PrometheusSheetEncrypted;
/**
* SheetDataItem extension for Security.
*
* @author Tony Washer
*/
public final class MoneyWiseSheetSecurity
extends PrometheusSheetEncrypted<MoneyWiseSecurity> {
/**
* NamedArea for Securities.
*/
private static final String AREA_SECURITIES = MoneyWiseSecurity.LIST_NAME;
/**
* Name column.
*/
private static final int COL_NAME = COL_KEYSETID + 1;
/**
* Type column.
*/
private static final int COL_TYPE = COL_NAME + 1;
/**
* Parent column.
*/
private static final int COL_PARENT = COL_TYPE + 1;
/**
* Description column.
*/
private static final int COL_DESC = COL_PARENT + 1;
/**
* Currency column.
*/
private static final int COL_CURRENCY = COL_DESC + 1;
/**
* Closed column.
*/
private static final int COL_CLOSED = COL_CURRENCY + 1;
/**
* Constructor for loading a spreadsheet.
*
* @param pReader the spreadsheet reader
*/
MoneyWiseSheetSecurity(final MoneyWiseReader pReader) {
/* Call super constructor */
super(pReader, AREA_SECURITIES);
/* Access the Securities list */
final MoneyWiseDataSet myData = (MoneyWiseDataSet) pReader.getData();
setDataList(myData.getSecurities());
}
/**
* Constructor for creating a spreadsheet.
*
* @param pWriter the spreadsheet writer
*/
MoneyWiseSheetSecurity(final MoneyWiseWriter pWriter) {
/* Call super constructor */
super(pWriter, AREA_SECURITIES);
/* Access the Securities list */
final MoneyWiseDataSet myData = (MoneyWiseDataSet) pWriter.getData();
setDataList(myData.getSecurities());
}
@Override
protected PrometheusDataValues loadSecureValues() throws OceanusException {
/* Build data values */
final PrometheusDataValues myValues = getRowValues(MoneyWiseSecurity.OBJECT_NAME);
myValues.addValue(MoneyWiseBasicResource.CATEGORY_NAME, loadInteger(COL_TYPE));
myValues.addValue(MoneyWiseBasicResource.ASSET_PARENT, loadInteger(COL_PARENT));
myValues.addValue(MoneyWiseStaticDataType.CURRENCY, loadInteger(COL_CURRENCY));
myValues.addValue(PrometheusDataResource.DATAITEM_FIELD_NAME, loadBytes(COL_NAME));
myValues.addValue(PrometheusDataResource.DATAITEM_FIELD_DESC, loadBytes(COL_DESC));
myValues.addValue(MoneyWiseBasicResource.ASSET_CLOSED, loadBoolean(COL_CLOSED));
/* Return the values */
return myValues;
}
@Override
protected void insertSecureItem(final MoneyWiseSecurity pItem) throws OceanusException {
/* Set the fields */
super.insertSecureItem(pItem);
writeInteger(COL_TYPE, pItem.getCategoryId());
writeInteger(COL_PARENT, pItem.getParentId());
writeInteger(COL_CURRENCY, pItem.getAssetCurrencyId());
writeBytes(COL_NAME, pItem.getNameBytes());
writeBytes(COL_DESC, pItem.getDescBytes());
writeBoolean(COL_CLOSED, pItem.isClosed());
}
@Override
protected int getLastColumn() {
/* Return the last column */
return COL_CLOSED;
}
}