diff Lib/IMPL/Web/View/Metadata/FormMeta.pm @ 365:7c621bb95e53

working on the metadata model
author sergey
date Mon, 02 Dec 2013 02:13:12 +0400
parents 82b6c967bcf1
children 935629bf80df
line wrap: on
line diff
--- a/Lib/IMPL/Web/View/Metadata/FormMeta.pm	Fri Nov 29 16:33:07 2013 +0400
+++ b/Lib/IMPL/Web/View/Metadata/FormMeta.pm	Mon Dec 02 02:13:12 2013 +0400
@@ -11,9 +11,9 @@
 		'IMPL::Web::View::Metadata::BaseMeta' => '@_'
 	],
 	props => [
-		decl => PROP_RO,
+		nodes => PROP_RO,
+		decl  => PROP_RO,
 		schema => PROP_RO,
-		nodes => PROP_RO,
 		errors => PROP_RO
 	]
 };
@@ -29,11 +29,29 @@
 		foreach qw(decl schema);
 }
 
-sub GetOwnErrors {
-	
+sub isMultiple {
+	shift->decl->isMultiple;
+}
+
+sub isOptional {
+	shift->decl->isOptional;
 }
 
 
+sub GetOwnErrors {
+	my ($this) = @_;
+	
+	my $node = undef;
+	
+	$node = not($this->isMultiple) && $this->nodes ? $this->nodes->[0] : undef;
+	
+	return [
+		grep {
+			($node && $_->node && $_->node == $node) || (not($node) && $_->schema == $this->decl )
+		} @{$this->errors || []}
+	];
+}
+
 1;
 
 __END__
@@ -46,31 +64,73 @@
 
 =head1 DESCRIPTION
 
-Метаданные по модели, являющейся частью формы. Элемент формы описывается
-несколькими компонентами:
+Расширенные метаданные модели для элементов формы, помимо стандартных свойств
+сожержит в себе информацию о схеме.
+
+=head1 MEMBERS
 
-=over
+=head2 C<[get]errors>
+
+Ссылка на массив с ошибками при проверке схемы. Ошибки относятся ко всем
+узлам в текущей модели, включая вложенные и т.п.
+
+=head2 C<[get]model>
 
-=item * schema
+Ссылка на элемент документа, либо на массив с элементами для множественных
+значений (C<isMultiple = true>). В том случае, когда документ был не
+корректен и для не множественного элемента было передено несколько значений,
+данное свойство будет содержать только первое.
+
+=head2 C<[get]nodes>
 
-Схема текущего элемента, СomlexType, SimpleType, ComplexNode или SimpleNode
+Ссылка на массив с узлами документа. В теории количество узлов может быть
+произвольным, поскольку документ может быть некорректным, т.е. их может
+быть более одного в то время, как C<isMultiple = false> или, напротив, ни
+одного при C<isOptional = false>.
+
+=head2 C<[get]modelType>
 
-=item * decl
+Название типа данных из схемы документа (C<< schema->name >>), если тип не имеет название, то это
+C<ComplexNode> для сложных узлов и C<SimpleNode> для простых.
+
+Для моделей с множественными значениями это свойство означает тип элементов.
+
+=head2 C<[get]decl>
 
-Сам элемент формы, который присутствует в родительском контейнере. Объявление
-может совпадать со схемой в случае, когда это был SimpleNode или ComplexNode,
-иначе это Node ссылающийся на заранее обпределенный тип.
+Объявление элемента формы, объявление может совпадать со схемой в случае,
+когда это был C<SimpleNode> или C<ComplexNode>, иначе это C<Node> ссылающийся
+на заранее обпределенный тип.
+
+=head2 C<[get]schema>
 
-=item * nodes
+Схема текущего элемента, C<СomlexType>, C<SimpleType>, C<ComplexNode> или
+C<SimpleNode>.
+
+=head2 C<[get]isOptional>
+
+Данный элемент может не иметь ни одного значения
+
+=head2 C<[get]isMultiple>
 
-Список узлов документа, которые являются экземплярами текущего элемента, в
-случае, если этот элемен не является множественным (maxOccur=1), тогда здесь
-должен быть только один элемент.
+Данный элемент может иметь более одного значения. Модель с множественными
+значениями является сложным элементом, в котором дочерними моделями являются
+не свойства а сами элементы, в данном случае они их именами будут индексы.
+
+=begin code
 
-=item * errors
+for(my $i=0; $i< 10; $i++) {
+	display_model(
+		$meta->model->[$i],
+		schema => meta->schema, 
+	);
+}
 
-Список ошибок относящихся к данному элементу.
+=end code
+
+=head2 C<GetOwnErrors()>
 
-=back 
+Возвращает ошибки относящиеся к самому элементу C<model>, это принципиально
+для контейнеров и в случаях, когда модель не корректна и в ней присутствуют
+лишние значения.  
 
 =cut
\ No newline at end of file