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

Popular posts from this blog

step 20 Update script for service model: AOSService on machine: CR-VM-Test-1

create movement journal through code in d365 FO x++