В этой статье:
В репозитории платформы реализованы различные классы объектов, имеющие определенное назначение и выполняющие определенные для них функции. Также в репозитории имеется такой класс объектов как - Ярлык. Ярлык - это ссылка на существующий объект какого-либо класса. Ярлык инкапсулирует в себе свойства объекта, на который он ссылается. При просмотре/редактировании ярлыка будет открыт соответствующий инструмент платформы или мастер, предназначенный для редактирования свойств соответствующего объекта.
При работе из языка Fore для проверки объекта на соответствие ярлыку можно использовать следующие свойства:
IMetabaseObjectDescriptor.IsShortcut. Свойство возвращает значение True, если объект является ярлыком на объект в текущем репозитории;
IMetabaseObjectDescriptor.IsLink. Свойство возвращает значение True, если объект является ярлыком на объект из другого репозитория.
Класс ярлыка будет соответствовать классу объекта, на который он ссылается.
Создание ярлыка осуществляется таким же образом как и создание других объектов репозитория. Для создания ярлыка необходимо в параметрах создаваемого объекта свойству IMetabaseObjectCreateInfo.IsShortcut установить значение True, а в свойстве IMetabaseObjectCreateInfo.Shortcut указать описание объекта, на который будет ссылаться ярлык:
Var
MB: IMetabase;
CrInfo: IMetabaseObjectCreateInfo;
ShortcutDesc: IMetabaseObjectDescriptor;
Begin
MB := MetabaseClass.Active;
CrInfo := MB.CreateCreateInfo;
CrInfo.Id := "Shortcut_OBJTEST";
CrInfo.Name := "Ярлык для OBJTEST";
CrInfo.Parent := MB.Root;
CrInfo.Permanent := True;
CrInfo.Shortcut := MB.ItemById("OBJTEST");
CrInfo.IsShortcut := True;
ShortcutDesc := MB.CreateObject(CrInfo);
При выполнении примера в корневом каталоге репозитория будет создан ярлык для объекта «OBJTEST».
Для создания ярлыка на объект из другого репозитория предварительно в текущем репозитории необходимо создать объект - Связь с репозиторием. После этого в коде в свойстве IMetabaseObjectCreateInfo.Link указывается связь с репозиторием, а в свойстве IMetabaseObjectCreateInfo.Shortcut описание объекта из другого репозитория. Также в свойстве IMetabaseObjectCreateInfo.ClassId необходимо указать класс объекта, для которого создается ярлык:
Var
MB: IMetabase;
CrInfo: IMetabaseObjectCreateInfo;
Link: IMetabaseObject;
LinkInst: IMetabaseLinkInstance;
ObjDesc, ShortcutDesc: IMetabaseObjectDescriptor;
Begin
MB := MetabaseClass.Active;
CrInfo := MB.CreateCreateInfo;
CrInfo.Id := "Shortcut_Report_1";
CrInfo.Name := "Ярлык для Report_1";
CrInfo.Parent := MB.Root;
CrInfo.Permanent := True;
Link := MB.ItemById("Link_Test").Bind;
LinkInst := Link.Open(Null) As IMetabaseLinkInstance;
ObjDesc := LinkInst.Metabase.ItemById("OBJTEST");
CrInfo.Link := Link As IMetabaseLink;
CrInfo.ClassId := ObjDesc.ClassId;
CrInfo.Shortcut := ObjDesc;
ShortcutDesc := MB.CreateObject(CrInfo);
При выполнения примера в корневом каталоге репозитория будет создан ярлык на объект из репозитория, на который настроена связь с репозиторием «Link_Test».
Для редактирования объекта (описания объекта), на который ссылается ярлык, получите описание ярлыка и вызовите метод IMetabaseObjectDescriptor.Edit (IMetabaseObjectDescriptor.EditDescriptor). Результат метода приведите к необходимому интерфейсу и измените параметры/структуру объекта. Например, если исходный объект является справочником НСИ, то, используя ярлык на него, можно следующим образом изменить наименование атрибута:
Var
MB: IMetabase;
SHDesc: IMetabaseObjectDescriptor;
Dict: IRdsDictionary;
Begin
MB := MetabaseClass.Active;
SHDesc := MB.ItemById("SHORTCUT_TO_DICTIONARY");
Dict := SHDesc.Edit As IRdsDictionary;
Dict.Attributes.FindById("COUNTRY").Name := Dict.Attributes.FindById("Страны мира").Name;
(Dict As IMetabaseObject).Save;
Если ярлык ссылается на объект из другого репозитория, то редактирование ярлыка не позволит изменить структуру (описание) объекта в виду имеющихся особенностей реализации. Для изменения объекта необходимо получить его описание, открыть на редактирование, внести необходимые изменения и сохранить. Для этого можно воспользоваться следующим кодом:
Sub Edit;
Var
MB: IMetabase;
SHDesc, ObjDesc: IMetabaseObjectDescriptor;
Dict: IRdsDictionary;
Begin
MB := MetabaseClass.Active;
SHDesc := MB.ItemById("SHORTCUT_TO_DICTIONARY");
ObjDesc := CheckShorcut(SHDesc);
Dict := ObjDesc.Edit As IRdsDictionary;
Dict.Attributes.FindById("COUNTRY").Name := Dict.Attributes.FindById("Страны мира").Name + "1";
(Dict As IMetabaseObject).Save;
End Sub Edit;
Function CheckShorcut(Desc: IMetabaseObjectDescriptor): IMetabaseObjectDescriptor;
Var
Result: IMetabaseObjectDescriptor;
Begin
//Если ярлык на объект из другого репозитория
If Desc.IsLink Then
Desc := Desc.Open(Null).Object;
End If;
//Если ярлык на
объект текущего репозитория, то рекурсивная проверка для
получения описания исходного объекта
If Desc.IsShortcut Then
Result := CheckShorcut(Desc.Shortcut);
Else
Result := Desc;
End If;
Return Result;
End Function CheckShorcut;
Функция CheckShorcut осуществляет проверку является ли объект ярлыком и рекурсивно доходит до исходного объекта. После этого она возвращает его описание. Данная функция также подходит для использования, если возникают случаи, когда ярлык ссылается на другой ярлык (из текущего или другого репозитория).
См. также:
Примеры | IMetabaseObjectDescriptor.IsShortcut | IMetabaseObjectDescriptor.IsLink