get product image in D365 FO x++
public str getProductImage(ItemId _itemId)
{
str imageBase64;
InventTable inventTable = InventTable::find(_itemId);
EcoResProduct product;
Common firstRecord;
Common secondRecord;
product = EcoResProduct::find(inventTable.Product);
firstRecord = inventTable;
secondRecord = product;
TableId firstTableId = DocuRef::GetRootTableID(firstRecord.TableId);
TableId secondTableId = DocuRef::GetRootTableID(secondRecord.TableId);
DocuRef docuRef;
DocuValue docuValue;
EcoResProductImage ecoResProductImage;
DocuRef docuRefRow;
EcoResProductImage ecoResProductImageRow;
while select ecoResProductImage
where ecoResProductImage.DefaultImage == NoYes::Yes
join docuRef
where
docuRef.RecId == ecoResProductImage.RefRecId
&& ((docuRef.RefTableId == firstTableId
&& docuRef.RefRecId == firstRecord.RecId
&& docuRef.RefCompanyId == firstRecord.DataAreaId)
||
(docuRef.RefTableId == secondTableId
&& docuRef.RefRecId == secondRecord.RecId
&& docuRef.RefCompanyId == secondRecord.DataAreaId)
)
exists join docuValue
where
docuValue.RecId == docuRef.ValueRecId
{
docuRefRow.data(docuRef);
ecoResProductImageRow.data(ecoResProductImage);
if (docuRef.RefTableId == firstTableId)
{
// We loop until we hit the first table (in case the first table is selected as the second row).
// If we do not hit the first table, then second table row is used.
// This logic could also be replaced by ordering
// (depending on the order of firstTableId and secondTableId we would order our query,
// but it would result in copying the query code or building it dynamically, which is not worth it).
break;
}
}
if (docuRefRow)
{
imageBase64 = this.getDocumentBase64String(docuRefRow);
}
else
{
imageBase64 = "";
}
return imageBase64;
}
private str getDocumentBase64String(DocuRef docuRef)
{
str base64String;
System.IO.MemoryStream memoryStream;
;
if(docuRef)
{
memoryStream = new System.IO.MemoryStream();
DocumentManagement::getAttachmentStream(docuRef).CopyTo(memoryStream);
base64String = System.Convert::ToBase64String(memoryStream.ToArray());
}
return base64String;
}
Comments
Post a Comment