Well recently I came across an issue where user had created more than 100 items in productions with wrong type. The standard out of the functionality does not allow to convert the item type if its released. Deleting is also not possible. So we are stuck with an option of disabling the item and creating new once with correct type.
But the limitation here is than we would have to come with new sku code where its similar to original code but not exact as it is used. So I wrote the code convert the item type through X++ which resolved our issue.
Below is the code to perform this task.
I am using csv file to bulk update the items and changing item type from service to item in this example.
public static void main(Args _args)
{
AsciiStreamIo file;
Array fileLines;
FileUploadTemporaryStorageResult fileUpload;
InventTable invt;
EcoResProduct ecores;
ItemId id;
EcoResStorageDimensionGroupItem EDM;
EcoResTrackingDimensionGroupItem ETD;
InventModelGroupItem IMG;
InventTableModule ITM;
WHSInventTable WHS;
PurchLine PUL;
RefRecId STD;
RefRecId TTD;
str purchids;
fileUpload = File::GetFileFromUser() as FileUploadTemporaryStorageResult;
if(fileUpload != null)
{
file = AsciiStreamIo::constructForRead(fileUpload.openResult());
if (file)
{
if (file.status())
{
throw error("@SYS52680");
}
file.inFieldDelimiter(',');
file.inRecordDelimiter('\r\n');
}
container record;
while (!file.status())
{
record = file.read();
STD = EcoResStorageDimensionGroup::findByDimensionGroupName('STOCK').RecId;
TTD = EcoResTrackingDimensionGroup::findByDimensionGroupName('SE').RecId;
if (conLen(record))
{
id = strFmt("%1",conPeek(record,1));
invt = InventTable::find(id,false);
if(invt.RecId != 0)
{
ttsbegin;
ecores = EcoResProduct::find(invt.product,true);
ecores.ProductType = EcoResProductType::Item;
ecores.update();
EDM = EcoResStorageDimensionGroupItem::findByItem('DAT',id,true);
EDM.StorageDimensionGroup = STD;
EDM.update();
ETD = EcoResTrackingDimensionGroupItem::findByItem('DAT',id,true);
ETD.TrackingDimensionGroup = TTD;
ETD.update();
IMG = InventModelGroupItem::findByItemIdLegalEntity(id,'DAT',true);
IMG.ModelGroupId = 'STK-ACCES';
IMG.update();
ITM = InventTableModule::find(id,ModuleInventPurchSales::Purch,true);
ITM.TaxItemGroupId = 'STD-G-5%';
ITM.update();
ITM = InventTableModule::find(id,ModuleInventPurchSales::Sales,true);
ITM.TaxItemGroupId = 'STD-G-5%';
ITM.update();
ITM = InventTableModule::find(id,ModuleInventPurchSales::Invent,true);
ITM.TaxItemGroupId = 'STD-G-5%';
ITM.update();
WHS = WHSInventTable::find(id,true);
WHS.UOMSeqGroupId = 'EA';
WHS.update();
ttscommit;
info(strFmt("%1 - Update",id));
}
else
{
info(strFmt("%1 - Notfound",id));
}
}
}
info("done");
}
}
Comments
Post a Comment