J'essaie de sauvegarder une pièce jointe. La pièce jointe est enregistrée mais chaque fois que j'ouvre la page VF, une erreur se produit:REQUIRED_FIELD_MISSING, Les champs obligatoires sont manquants: [Parent]: [Parent]
L'insertion a échoué. Première exception sur la ligne 0; première erreur: REQUIRED_FIELD_MISSING, les champs obligatoires sont manquants: [Parent]: [parent]
J'ai 2 VFPages en faisant ceci. L'un est le VFPage rendu en PDF et l'autre est juste une référence pour sauvegarder la pièce jointe et pour charger VFPage en format PDF. Est-ce que quelqu'un ici a une idée sur la façon de corriger cette erreur?
C'est VFPage pour référence
Voici les classes Apex:..
public class attachPDFDocument{
public String parentId{get;set;}
public String curPage = ApexPages.currentPage().getParameters().get('id');
public String vrsn = 'AttachmentV';
public Integer vrsion;
public String attName {get;set;}
public String attNames {get;set;}
public String attNameSubString;
public String attNameSubStrings;
public Integer attCount;
public Integer attachCount;
public attachPDFDocument(ApexPages.StandardController controller) {
}
public PageReference pdfLoad(){
List<Attachment> pdfAttach = new List <Attachment>();
PageReference pdf = Page.PDFAttachment;
List<Attachment> att = [SELECT Id, Name FROM Attachment where ParentId = :curPage Order by Name DESC]; //getting all attachments
//String attachName = att.Name;
if(att.size() <= 0){
vrsion = 1;
}else if(att.size() <= 9){
Attachment attachmentPDF = att[0];
attName = attachmentPDF.Name; // yung latest Version
attNameSubString = attName.subString(35,36);
vrsion = Integer.valueOf(attNameSubString) + 1;
}else if(att.size() > 9){
List<Attachment> attachPDFDoc = [SELECT Id, Name FROM Attachment where ParentId = :curPage AND Name LIKE '___________' ORDER BY Name DESC LIMIT 1]; //getting all attachments with length is 41
Attachment docpdf= attachPDFDoc[0];
String pdfdoc = docpdf.Name;
attNameSubString = pdfdoc.subString(35,37);
vrsion = Integer.valueOf(attNameSubString) + 1;
}else if(att.size() > 99){
List<Attachment> attachPDFDoc = [SELECT Id, Name FROM Attachment where ParentId = :curPage AND Name LIKE '___________' ORDER BY Name DESC LIMIT 1]; //getting all attachments with length is 41
Attachment docpdf= attachPDFDoc[0];
String pdfdoc = docpdf.Name;
attNameSubString = pdfdoc.subString(35,38);
vrsion = Integer.valueOf(attNameSubString) + 1;
}
Attachment attach = new Attachment();
Blob body;
try {
body= pdf.getContent();
} catch (VisualforceException e) {
body= Blob.valueOf(e.getMessage());
}
attach.Body = body ;
attach.IsPrivate = false;
attach.ContentType = '/application/pdf';
attach.ParentId = ApexPages.currentPage().getParameters().get('id');
attach.Name = vrsn + vrsion + '.pdf';
insert attach;
return pdf;
}
}