2018-09-24 16:03:29 +00:00
|
|
|
|
/**
|
2018-09-25 16:04:11 +00:00
|
|
|
|
* Интерфейс доступа к содержимому глобальной ноды
|
|
|
|
|
*
|
|
|
|
|
* Здесь создаются менеджер по работе с вложенными нодами и менеджер типов ноды
|
|
|
|
|
*
|
|
|
|
|
* <br>
|
|
|
|
|
* Связанные объекты:
|
|
|
|
|
*
|
|
|
|
|
* - {@link Trees.GlobalTree} - Здесь можно найти примеры, как работать с глобальным деревом
|
|
|
|
|
* - {@link Trees.GlobalTree.Node.Children} - Здесь можно найти примеры, как работать с вложенными нодами
|
|
|
|
|
* - {@link Trees.GlobalTree.Node.NodeTypes} - Здесь можно найти примеры, как работать с типами ноды
|
|
|
|
|
*
|
|
|
|
|
*
|
|
|
|
|
* @example
|
|
|
|
|
* // Пример: Как получить ноду дерева?
|
|
|
|
|
*
|
|
|
|
|
* // Пример взят для дерева тополгии
|
|
|
|
|
* var tree = null;
|
|
|
|
|
* var node = null;
|
|
|
|
|
*
|
|
|
|
|
* // Осуществляем запрос к менеджеру деревьев, на получение провайдера дерева
|
|
|
|
|
* ps.pl.tm.get(new v2.string("st")).then(function(ref){
|
|
|
|
|
* // ref - это ссылка на объект
|
|
|
|
|
* // метод value возвращает целевой объект. В данном случае дерево Trees.SchemeTree
|
|
|
|
|
* tree = ref.value();
|
|
|
|
|
*
|
|
|
|
|
* // Доступ к ноде осуществляется похожим образом, но теперь вместо строки нужно указать v2.integer
|
|
|
|
|
* // Так как возвратится нативный проимс, мы можем вернуть его и обработать в следующем then
|
|
|
|
|
* return tree.get(v2.integer.from_number(0))
|
|
|
|
|
* }, function(err){
|
|
|
|
|
* // в случае неудачи придет ошибка.
|
|
|
|
|
* // обычно в ошибке содержится три переменные err - код ошибки, message - краткое описание, sub - если к этому
|
|
|
|
|
* // привела другая ошибка внутри системы.
|
|
|
|
|
* }).then(function(ref){
|
|
|
|
|
* // Вот мы и получили ноду.
|
|
|
|
|
* node = ref.value();
|
|
|
|
|
* }, function(err){
|
|
|
|
|
* // Отобразим ошибку
|
|
|
|
|
* console.warn(err);
|
|
|
|
|
* })
|
|
|
|
|
*
|
2018-09-24 16:03:29 +00:00
|
|
|
|
*
|
|
|
|
|
* @class Node
|
|
|
|
|
* @memberof Trees.GlobalTree
|
|
|
|
|
*/
|
|
|
|
|
function Node() {
|
|
|
|
|
/**
|
2018-09-24 21:09:33 +00:00
|
|
|
|
* Возвращает ссылку на атрибут ноды.
|
|
|
|
|
* Работает через промис.
|
2018-09-24 16:03:29 +00:00
|
|
|
|
*
|
|
|
|
|
* @public
|
|
|
|
|
* @function get
|
|
|
|
|
* @param {v2.string} attributeName Имя атрибута
|
|
|
|
|
* @returns {tools.promise}
|
|
|
|
|
* @memberof Trees.GlobalTree.Node
|
|
|
|
|
*/
|
|
|
|
|
this.get = function(attributeName) {
|
|
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/**
|
2018-09-24 21:09:33 +00:00
|
|
|
|
* Добавляет новый динамический атрибут в ноду.
|
2018-09-24 16:03:29 +00:00
|
|
|
|
* Ничего не возвращает.
|
|
|
|
|
*
|
|
|
|
|
* @public
|
|
|
|
|
* @function add_node
|
|
|
|
|
* @param {v2.vc} _attrs
|
|
|
|
|
* @memberof Trees.GlobalTree.Node
|
|
|
|
|
*/
|
|
|
|
|
this.add_node = function(_attrs) {
|
|
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Возвращает уникальный идентификатор ноды.
|
|
|
|
|
*
|
|
|
|
|
* @public
|
|
|
|
|
* @function id
|
|
|
|
|
* @returns {v2.integer}
|
|
|
|
|
* @memberof Trees.GlobalTree.Node
|
|
|
|
|
*/
|
|
|
|
|
this.id = function() {
|
|
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/**
|
2018-09-24 21:09:33 +00:00
|
|
|
|
* Возвращает список потомков ноды.
|
|
|
|
|
* Работает через промис.
|
2018-09-24 16:03:29 +00:00
|
|
|
|
*
|
|
|
|
|
* @public
|
|
|
|
|
* @function children
|
|
|
|
|
* @returns {tools.promise}
|
|
|
|
|
* @memberof Trees.GlobalTree.Node
|
|
|
|
|
*/
|
|
|
|
|
this.children = function() {
|
|
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Доступ к менеджеру детей
|
|
|
|
|
* @public
|
|
|
|
|
* @function cm
|
2018-09-25 12:14:18 +00:00
|
|
|
|
* @returns {NodeChildren}
|
2018-09-24 16:03:29 +00:00
|
|
|
|
* @memberof Trees.GlobalTree.Node
|
|
|
|
|
*/
|
|
|
|
|
this.cm = function() {
|
|
|
|
|
|
|
|
|
|
};
|
|
|
|
|
}
|