DiagramRootPackage
Contents
 [
        
            Hide
        ]
    DiagramRootPackage class
Represents the root package intended to work with metadata in a diagram.
public class DiagramRootPackage : DocumentRootPackage<DiagramPackage>
Properties
| Name | Description | 
|---|---|
| Count { get; } | Gets the number of metadata properties. | 
| virtual DocumentProperties { get; } | Gets the native metadata properties presented in the document. | 
| DocumentStatistics { get; } | Gets the document statistics package. | 
| FileType { get; } | Gets the file type metadata package. (2 properties) | 
| Item { get; } | Gets the MetadataProperty with the specified name. | 
| Keys { get; } | Gets a collection of the metadata property names. | 
| MetadataType { get; } | Gets the metadata type. | 
| PropertyDescriptors { get; } | Gets a collection of descriptors that contain information about properties accessible through the GroupDocs.Metadata search engine. | 
Methods
| Name | Description | 
|---|---|
| virtual AddProperties(Func<MetadataProperty, bool>, PropertyValue) | Adds known metadata properties satisfying the specified predicate. The operation is recursive so it affects all nested packages as well. | 
| Contains(string) | Determines whether the package contains a metadata property with the specified name. | 
| virtual FindProperties(Func<MetadataProperty, bool>) | Finds the metadata properties satisfying the specified predicate. The search is recursive so it affects all nested packages as well. | 
| GetEnumerator() | Returns an enumerator that iterates through the collection. | 
| virtual RemoveProperties(Func<MetadataProperty, bool>) | Removes metadata properties satisfying the specified predicate. | 
| override Sanitize() | Removes writable metadata properties from the package. The operation is recursive so it affects all nested packages as well. | 
| virtual SetProperties(Func<MetadataProperty, bool>, PropertyValue) | Sets known metadata properties satisfying the specified predicate. The operation is recursive so it affects all nested packages as well. This method is a combination of AddProperties and UpdateProperties. If an existing property satisfies the predicate its value is updated. If there is a known property missing in the package that satisfies the predicate it is added to the package. | 
| virtual UpdateProperties(Func<MetadataProperty, bool>, PropertyValue) | Updates known metadata properties satisfying the specified predicate. The operation is recursive so it affects all nested packages as well. | 
Remarks
Learn more
Examples
The following code sample demonstrates how to update built-in metadata properties in a diagram document.
using (Metadata metadata = new Metadata(Constants.InputVdx))
{
    var root = metadata.GetRootPackage<DiagramRootPackage>();
    root.DocumentProperties.Creator = "test author";
    root.DocumentProperties.TimeCreated = DateTime.Now;
    root.DocumentProperties.Company = "GroupDocs";
    root.DocumentProperties.Category = "test category";
    root.DocumentProperties.Keywords = "metadata, built-in, update";
    // ... 
    metadata.Save(Constants.OutputVdx);
}
See Also
- class DocumentRootPackage<TPackage>
 - class DiagramPackage
 - namespace GroupDocs.Metadata.Formats.Document
 - assembly GroupDocs.Metadata