Файлы XAML для файлов, папок и пользовательских объектов предварительно сконфигурированы. Однако в этой папке можно создавать другие файлы XAML. Кроме того, разные файлы XAML могут отображаться для одного и того же объекта.
Чтобы открыть разные диалоговые окна для одного и того же объекта, создайте файл PowerShell с содержимым в следующей папке: %programdata%\Autodesk\Vault [версия]\Extensions\DataStandard\Vault\addinVault\Menus.
Пример пользовательского файла XAML
$vaultContext.ForceRefresh = $true
$currentSelected = $vaultContext.CurrentSelectionSet[0]
$folderid = $currentSelected.Id
#if selected object is of type 'FILE' then use $vaultContext.NavSelectionSet[0].Id,
#it will give you back the folder Id where this file is located
if ($currentselected.typeid.entityclassid--eq-"file")
{
$folderid = $vaultContext.NavSelectionSet[0].Id
}
$xamlFile = New-Object CreateObject.WPF.XamlFile "MyOwnXaml", "C:\ProgramData\Autodesk\Vault [edition]\Extensions\DataStandard\Vault\Configuration\myfile.xaml"
$dialog = $dsCommands.GetCreateDialog($folderid)
$dialog.XamlFile = $xamlFile
#new file can be found in $dialog.CurrentFile
$result = $dialog.Execute()
$dsDiag.Trace($result)
if ($result)
{
$folder = $vault.DocumentService.GetFolderById($folderid)
$path=$folder.FullName+"/"+$dialog.CurrentFile.Name
$selectionId = [Autodesk.Connectivity.Explorer.Extensibility.SelectionTypeId]::File
$location = New-Object Autodesk.Connectivity.Explorer.Extensibility.LocationContext $selectionId, $path
#$dsDiag.Inspect()
$vaultContext.GoToLocation = $location
}
После загрузки диалогового окна (при помощи $dialog.execute()) им можно управлять с помощью функций Data Standard. Дополнительные сведения о процедуре выполнения кода в примере выше см. в разделе «Элементы меню».