static void ImportAsset(Args _args)
{
Dialog dialog;
Dialogfield dialogfield;
SysExcelApplication application;
SysExcelWorkbooks workBooks;
SysExcelWorkbook workBook;
SysExcelWorksheets workSheets;
SysExcelWorksheet workSheet;
SysExcelCells cells;
AssetLocation assetLocation;
AssetGroup assetGroup;
AssetTable assetTable;
AssetBook assetBook;
AssetBookTable assetBookTable;
AssetLocationId location;
AssetGroupId assetGrp;
AssetBookId assetBkId;
AssetId assetId;
Name name;
AssetAcquisitionDate assetAcqDate;
AssetAcquisitionPrice assetAcqPrice;
AssetDepreciate assetDepreciate;
AssetServiceLife assetServiceLife;
AssetPostingProfile assetPostingProfile;
AssetStatus assetStatus;
Filename fileName;
COMVariantType type;
int row = 1 ;
int recordcnt;
str COMVariant2Str(COMVariant _cv, int _decimals = 0,int _characters = 0,int _separator1 = 0,int _separator2 = 0)
{
switch(_cv.variantType())
{
case (COMVariantType::VT_BSTR):
return _cv.bStr();
case (COMVariantType::VT_R4):
return num2str(_cv.float(),_characters,_decimals, _separator1,_separator2);
case (COMVariantType::VT_R8):
return num2str(_cv.double(),_characters,_decimals,_separator1,_separator2);
case (COMVariantType::VT_DECIMAL):
return num2str(_cv.decimal(),_characters,_decimals, _separator1, _separator2);
case (COMVariantType::VT_DATE):
return date2str(_cv.date(),123,2,1,2, 1,4);
case (COMVariantType::VT_EMPTY):
return "";
default:
throw error(strfmt("@SYS26908",_cv.variantType()));
}
return "";
}
application = SysExcelApplication::construct();
workBooks = application.workbooks();
dialog = new Dialog("FileOpen");
dialogfield = dialog.addField(extendedTypeStr(Filenameopen), "File Name");
dialog.run();
if (dialog.run())
{
filename = (dialogfield.value());
}
//fileName = @"C:\Users\Naresh.Tumu\Desktop\Assert.xlsx";
try
{
workBooks.open(fileName);
}
catch (Exception::Error)
{
throw error("File Cannot be opened");
}
workBook = workBooks.item(1);
workSheets = workBook.worksheets();
workSheet = workSheets.itemFromNum(1);
cells = workSheet.cells();
do
{
row++;
location = cells.item(row, 11).value().bStr();
assetGrp = cells.item(row, 1).value().bStr();
assetBkId = cells.item(row, 3).value().bStr();
assetId = cells.item(row, 2).value().bStr();
name = cells.item(row, 4).value().bStr();
assetAcqDate = cells.item(row, 6).value().date();
assetDepreciate = str2enum(assetDepreciate,cells.item(row, 10).value().bStr());
assetStatus = str2enum(assetStatus,cells.item(row, 9).value().bstr());
assetPostingProfile = cells.item(row, 7).value().bstr();
assetServiceLife = cells.item(row, 8).value().double();
assetAcqPrice = cells.item(row, 5).value().double();
assetLocation.clear();
select assetLocation where assetLocation.Location == location;
assetGroup.clear();
select assetGroup where assetGroup.GroupId == assetGrp;
assetBookTable.clear();
select assetBookTable where assetBookTable.BookId == assetBkId;
assetTable.clear();
select assetTable where assetTable.AssetId == assetId;
assetBook.clear();
select assetBook where assetBook.BookId == assetBkId;
ttsBegin;
if(!assetLocation.RecId && !assetBookTable.recid && !assetTable.RecId && !assetBook.RecId && !assetGroup.RecId )
{
assetLocation.initValue();
assetLocation.Location = location;
assetLocation.Name = location;
assetLocation.insert();
assetGroup.initValue();
assetGroup.GroupId = assetGrp;
assetGroup.Name = assetGrp;
assetGroup.insert();
assetBookTable.initValue();
assetBookTable.BookId = assetBkId;
assetBookTable.Description = assetBkId;
assetBookTable.insert();
assetTable.initValue();
assetTable.AssetId = assetId;
assetTable.Name = name;
assetTable.AssetGroup = assetGroup.GroupId;
assetTable.Location = assetLocation.Location;
assetTable.insert();
assetBook.initValue();
assetBook.BookId = assetBookTable.BookId;
assetBook.AcquisitionDate = assetAcqDate;
assetBook.AcquisitionPrice = assetAcqPrice;
assetBook.ServiceLife = assetServiceLife;
assetBook.PostingProfile = assetPostingProfile;
assetBook.Status = assetStatus;
assetBook.Depreciation = assetDepreciate;
assetBook.AssetId = assetTable.AssetId;
assetBook.insert();
}
else if(assetLocation.RecId|| assetGroup.RecId || assetBookTable.RecId)
{
if(assetLocation && assetGroup && assetBookTable)
{
assetTable.Location = assetLocation.Location;
assetTable.AssetGroup = assetGroup.GroupId;
assetBook.BookId = assetBookTable.BookId;
}
else if(assetLocation && !assetBookTable && !assetGroup)
{
assetGroup.initValue();
assetGroup.GroupId = assetGrp;
assetGroup.Name = assetGrp;
assetGroup.insert();
assetBookTable.initValue();
assetBookTable.BookId = assetBkId;
assetBookTable.Description = assetBkId;
assetBookTable.insert();
assetTable.Location = assetLocation.Location;
assetTable.AssetGroup = assetGroup.GroupId;
assetBook.BookId = assetBookTable.BookId;
}
else if(assetGroup && !assetBookTable && !assetLocation)
{
assetLocation.initValue();
assetLocation.Location = location;
assetLocation.Name = location;
assetLocation.insert();
assetBookTable.initValue();
assetBookTable.BookId = assetBkId;
assetBookTable.Description = assetBkId;
assetBookTable.insert();
assetTable.AssetGroup = assetGroup.GroupId;
assetTable.Location = assetLocation.Location;
assetBook.BookId = assetBookTable.BookId;
}
else if(!assetGroup && assetBookTable && !assetLocation)
{
assetLocation.initValue();
assetLocation.Location = location;
assetLocation.Name = location;
assetLocation.insert();
assetGroup.initValue();
assetGroup.GroupId = assetGrp;
assetGroup.Name = assetGrp;
assetGroup.insert();
assetBook.BookId = assetBookTable.BookId;
assetTable.Location = assetLocation.Location;
assetTable.AssetGroup = assetGroup.GroupId;
}
else if(assetLocation && assetBookTable && !assetGroup)
{
assetGroup.initValue();
assetGroup.GroupId = assetGrp;
assetGroup.Name = assetGrp;
assetGroup.insert();
assetBook.BookId = assetBookTable.BookId;
assetTable.Location = assetLocation.Location;
assetTable.AssetGroup = assetGroup.GroupId;
}
else if(assetGroup && !assetBookTable && assetLocation)
{
assetBookTable.initValue();
assetBookTable.BookId = assetBkId;
assetBookTable.Description = assetBkId;
assetBookTable.insert();
assetBook.BookId = assetBookTable.BookId;
assetTable.AssetGroup = assetGroup.GroupId;
assetTable.Location = assetLocation.Location;
}
else if(assetGroup && assetBookTable && !assetLocation)
{
assetLocation.initValue();
assetLocation.Location = location;
assetLocation.Name = location;
assetLocation.insert();
assetTable.Location = assetLocation.Location;
assetTable.AssetGroup = assetGroup.GroupId;
assetBook.BookId = assetBookTable.BookId;
}
assetTable.clear();
assetTable.initValue();
assetTable.clear();
assetTable.AssetId = assetId;
assetTable.Name = name;
assetTable.insert();
assetBook.clear();
assetBook.initValue();
//assetBook.BookId = assetBkId;
assetBook.AcquisitionDate = assetAcqDate;
assetBook.AcquisitionPrice = assetAcqPrice;
assetBook.ServiceLife = assetServiceLife;
assetBook.PostingProfile = assetPostingProfile;
assetBook.Status = assetStatus;
assetBook.Depreciation = assetDepreciate;
assetBook.AssetId = assetTable.AssetId;
assetBook.insert();
}
ttsCommit;
type = cells.item(row+1, 1).value().variantType();
}
while (type != COMVariantType::VT_EMPTY);
application.quit();
workbooks.close();
info("Done");
}