Mercurial > pub > Impl
annotate Lib/IMPL/Web/View/TTDocument.pm @ 300:bf3af33b9003
sync
| author | cin |
|---|---|
| date | Fri, 22 Mar 2013 01:05:11 +0400 |
| parents | 78f767765706 |
| children | aeeb57a12046 |
| rev | line source |
|---|---|
| 181 | 1 package IMPL::Web::View::TTDocument; |
| 2 use strict; | |
| 3 | |
| 236 | 4 use Scalar::Util qw(weaken); |
| 5 use IMPL::Const qw(:prop); | |
|
288
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
6 use IMPL::lang qw(:hash is); |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
7 use Carp qw(carp); |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
8 use mro; |
| 181 | 9 |
| 236 | 10 use IMPL::declare { |
| 11 require => { | |
| 12 TTFactory => 'IMPL::Web::View::TTFactory', | |
| 13 TTControl => 'IMPL::Web::View::TTControl', | |
| 14 Loader => 'IMPL::Code::Loader' | |
| 15 }, | |
| 16 base => [ | |
| 17 'IMPL::Web::View::TTControl' => sub { | |
| 287 | 18 my ($template,$ctx) = @_; |
|
288
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
19 $ctx ||= Template::Context->new(); |
| 300 | 20 return $template, $ctx; # context |
| 236 | 21 } |
| 22 ], | |
| 23 props => [ | |
| 24 layout => PROP_RW, | |
| 25 loader => PROP_RW, | |
| 26 ] | |
| 27 }; | |
| 181 | 28 |
| 29 sub CTOR { | |
| 287 | 30 my ($this,$template,$ctx,$loader,$vars) = @_; |
| 194 | 31 |
| 32 $this->loader($loader) if $loader; | |
| 33 $this->layout( $template->layout ) unless $this->layout; | |
| 34 | |
|
288
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
35 $this->context->stash->update($vars) |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
36 if ref $vars eq 'HASH'; |
| 181 | 37 } |
| 38 | |
| 39 sub Render { | |
| 194 | 40 my ($this,$args) = @_; |
|
288
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
41 |
|
241
f48a1a9f4fa2
+Added ViewResult to allow implementation of the view environment.
sergey
parents:
238
diff
changeset
|
42 $args ||= {}; |
|
288
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
43 |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
44 my %controls; |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
45 my $require; |
| 289 | 46 my $documentContext; |
| 290 | 47 |
| 48 my $self = $this; | |
| 49 | |
|
288
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
50 $require = sub { |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
51 my $control = shift; |
| 290 | 52 |
| 291 | 53 unless($self) { |
| 54 carp("Cant load control $control outside the rendering procedure"); | |
| 55 return; | |
| 56 } | |
| 290 | 57 |
|
288
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
58 if (my $factory = $controls{$control}) { |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
59 return $factory; |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
60 } else { |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
61 my $path = $control; |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
62 |
| 290 | 63 if ( my $template = $self->loader->template($path) ) { |
|
288
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
64 |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
65 $factory = new IMPL::Web::View::TTFactory( |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
66 $template, |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
67 $documentContext, |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
68 join( '/', splice( @{[split(/\//,$path)]}, 0, -1 ) ), |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
69 $require |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
70 ); |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
71 |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
72 $controls{$control} = $factory; |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
73 |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
74 return $factory; |
| 194 | 75 |
|
288
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
76 } else { |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
77 die new IMPL::KeyNotFoundException($control); |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
78 } |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
79 } |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
80 }; |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
81 |
| 289 | 82 $this->context->localise(); |
| 83 $documentContext = _clone_context( $this->context ); | |
| 290 | 84 |
|
288
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
85 $this->context->stash->set(require => $require); |
| 291 | 86 $this->context->stash->set(document => sub { $self }); |
|
288
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
87 |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
88 my $text = eval { |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
89 |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
90 if ($this->layout) { |
| 287 | 91 my $tlayout = $this->loader->layout($this->layout); |
| 92 if(my $init = $tlayout->blocks->{INIT}) { | |
| 93 $this->context->process( | |
| 94 $init, | |
| 95 hashMerge( | |
|
288
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
96 $args, |
| 287 | 97 { |
|
288
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
98 template => $this->template |
| 287 | 99 } |
| 100 ) | |
| 101 ); | |
| 102 } | |
|
288
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
103 my $content = $this->next::method($args); |
| 287 | 104 return $this->context->include( |
| 105 $tlayout, | |
| 106 { | |
|
288
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
107 %{$args}, |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
108 content => $content, |
| 287 | 109 this => $this, |
| 110 template => $this->template | |
| 111 } | |
| 286 | 112 ); |
|
288
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
113 } else { |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
114 return $this->next::method($args); |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
115 } |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
116 }; |
| 289 | 117 |
| 118 undef $require; | |
| 119 undef $documentContext; | |
| 120 undef %controls; | |
| 290 | 121 undef $self; |
| 289 | 122 $this->context->delocalise(); |
|
288
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
123 |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
124 |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
125 my $e = $@; |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
126 if ($e) { |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
127 die $e; |
| 194 | 128 } else { |
|
288
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
129 return $text; |
| 194 | 130 } |
|
288
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
131 |
|
3a9cfea098dd
*TTView refactoring: removed RequireControl method, etc.
sergey
parents:
287
diff
changeset
|
132 |
|
190
cd1ff7029a63
IMLP::Web::View refactored, added new method 'require' which is available inside templates. Changed document rendering.
cin
parents:
189
diff
changeset
|
133 } |
|
cd1ff7029a63
IMLP::Web::View refactored, added new method 'require' which is available inside templates. Changed document rendering.
cin
parents:
189
diff
changeset
|
134 |
| 289 | 135 sub _clone_context { |
| 136 my $args = { %{shift || {}} }; | |
| 137 delete $args->{CONFIG}; | |
| 138 | |
| 139 return Template::Context->new($args); | |
| 140 } | |
| 141 | |
| 181 | 142 1; |
| 143 | |
| 144 __END__ | |
| 145 | |
| 146 =pod | |
| 147 | |
| 148 =head1 NAME | |
| 149 | |
| 150 C<IMPL::Web::View::TTDocument> - документ для построения HTML страницы на основе шаблонов TT. | |
| 151 | |
| 152 =head1 SYNOPSIS | |
| 153 | |
| 154 =begin code | |
| 155 | |
| 156 use IMPL::Web::View::TTDocument(); | |
| 157 | |
| 158 my $doc = new IMPL::Wbe::View::TTDocument($template,$ttOptions); | |
| 159 | |
| 160 return $doc->Render(); | |
| 161 | |
| 162 =end code | |
| 163 | |
| 164 Однако, более предпочтительный способ использовать C<IMPL::Web::View::TTLoader>. | |
| 165 | |
| 166 =head1 DESCRIPTION | |
| 167 | |
| 168 Документ для представления данных. Документы представляют собой иерархически организованные данные, | |
| 169 элементами данного документа являются данные для отображения, такие как | |
| 170 | |
| 171 =over | |
| 172 | |
| 173 =item * Объекты из БД | |
| 174 | |
| 175 =item * Навигационные цепочки | |
| 176 | |
| 177 =item * Меню и т.п. | |
| 178 | |
| 179 =back | |
| 180 | |
| 181 Скприт шаблона формирует структуру документа, затем сформированная структура форматируется в готовый документ. | |
| 192 | 182 Процесс форматирования объектной модели в готовый документ может быть выполнена как вручную, так и при помощи |
| 189 | 183 вспомогательного шаблона - обертки. Если у шаблона документа указан C<layout> в метаданных, то он будет |
| 181 | 184 использован как шаблон для форматирования объектной модели, вывод самого шаблона будет проигнорирован. Если |
| 185 обертка не задана, то результатом будет вывод самого скрипта шаблона. | |
| 186 | |
|
195
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
187 Использование объектной модели документа позволяет решить задачи по созданию контейнеров, |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
188 у которых может быть сложное содежимое. Примером таких элементов могут быть формы, |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
189 внутри форм элементы управления также могут группироваться. |
| 192 | 190 |
| 193 | 191 =head2 Элементы управления (компоненты) |
| 192 | |
| 193 Документ состоит из узлов, часть которых наследуется от C<IMPL::Web::View::TTControl>, такие узлы называются | |
| 194 элементами управления. Каждый элемент управления имеет собственный контекст, который наследуется от контекста | |
| 195 документа. | |
| 196 | |
| 197 =head2 Фабрика элементов управления | |
| 198 | |
| 199 Для создания элементов управления используются фабрики. Каждый элемен управления имеет свой шаблон для | |
| 200 форматиорвания содержимого, фабрика связывает шаблон и класс элемента управления, для чего при загрузке | |
| 201 шаблона используется свойство C<type> из метаданных. Фабрика загружается в документ при том только один | |
| 202 раз, повторные загрузки фабрики возвращают уже загруженную. Для загрузки фабрики используется метод | |
|
195
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
203 C<require()> с указанием элемента управления. |
|
190
cd1ff7029a63
IMLP::Web::View refactored, added new method 'require' which is available inside templates. Changed document rendering.
cin
parents:
189
diff
changeset
|
204 |
| 185 | 205 =head2 Порядок обработки документа |
| 206 | |
|
195
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
207 Построение представления данных состоит из двух этапов |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
208 |
| 185 | 209 =over |
| 210 | |
|
195
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
211 =item 1 Создание объектной модели документа. На данном этапе создаются все элементы управления. |
| 185 | 212 |
|
195
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
213 =item 1 Преобразование объектной модели в конечнное представление. На данном этапе происходит |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
214 форматирование документа. |
| 185 | 215 |
| 216 =back | |
| 181 | 217 |
|
195
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
218 |
| 181 | 219 =head2 Загрузка элемента управления |
| 220 | |
| 221 =over | |
| 222 | |
| 194 | 223 =item 1 C<TInput = require('my/org/input')> |
| 181 | 224 |
|
195
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
225 =item 1 Загружается шаблон C<my/org/input.tt> |
| 181 | 226 |
|
195
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
227 =item 1 Создается фабрика элементов управления с собственным контекстом, унаследованным от контекст документа. |
| 181 | 228 |
|
195
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
229 =item 1 При первом создании элемента управления фабрика инициализируется выполнением блока C<INIT>. |
| 181 | 230 |
| 231 =back | |
| 232 | |
| 233 =head2 Создание элемента управления | |
| 234 | |
| 235 =over | |
| 236 | |
| 194 | 237 =item 1 C<< TInput.new('login') >> |
| 181 | 238 |
| 239 =item 1 Создается новый дочерний контекст к контексту фабрики | |
| 240 | |
| 241 =item 1 Создается экземпляр элемента управления | |
| 242 | |
|
195
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
243 =item 1 Выполняется блок конструктора C<CTOR> в контексте элемента управления, параметр C<this> имеет значение |
| 181 | 244 нового экземпляра элемента управления |
| 245 | |
| 246 =back | |
| 247 | |
| 248 =head1 MEMBERS | |
| 249 | |
| 250 =over | |
| 251 | |
|
195
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
252 =item C<CTOR($template, $contextOpts, $loader[, $vars])> |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
253 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
254 Создает экземпляр документа с указанным шаблоном и параметрами. |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
255 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
256 =over |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
257 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
258 =item C<$template> |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
259 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
260 C<Template::Document> шаблон документа. |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
261 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
262 =item C<$contextOpts> |
| 181 | 263 |
|
195
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
264 C<HASH> Параметры контекста C<Template::Context> для документа. Эти параметры будут сохранены |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
265 в свойстве C<opts>, а также на их основе будет создан контекст текщего документа. Как правило |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
266 эти параметы задаются загрузчиком документа C<IMPL::Web::View::TTLoader>, таким образом, что |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
267 C<Template::Stash> создаваемого контекста наследует переменные из контекста загрузчика. |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
268 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
269 =item C<$loader> |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
270 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
271 C<IMPL::Web::View::TTLoader> загрузчик, который будет использоваться для загрузки элементов управления, |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
272 а также для получения обертки, заданной в свойстве документа C<layout>. |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
273 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
274 =item C<$vars> |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
275 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
276 C<HASH> Необязательный параметр. переменные которые будут переданы в блок конструктора C<INIT>. |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
277 Как правило они используются для передачи данных для построения документа |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
278 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
279 =back |
| 181 | 280 |
| 281 =back | |
| 282 | |
|
195
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
283 =over |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
284 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
285 =item C<templateVars($name[,$newValue])> |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
286 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
287 Получает или задает переменную для шаблона документа. Имя переменнной может быть составным, |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
288 например C<'my.var.name'>, см. C<Template::Stash::set()>. |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
289 |
| 236 | 290 =item C<RequireControl($controlName)> |
|
195
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
291 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
292 Загружает фабрику элемента управления, если она уже была загружена, возвращает на нее ссылку. |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
293 При загрузки фабрики для нее создается собственный контекст на основе параметров из свойства |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
294 C<opts> и ее пространство имен наследуется от пространства имен документа из свойства C<stash>. |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
295 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
296 =item C<Render($vars)> |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
297 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
298 Выполняет блок C<renderBlock> документа для получения конечного представления, C<$vars> |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
299 содержит переменные для блока. |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
300 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
301 =item C<RenderContent($vars)> |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
302 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
303 Выполняет шаблон документа для получения представления содержимого, в отличии от |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
304 метода C<Render> не использует обертку указанную в свойстве C<layout>, если обертка |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
305 не указана, то эти методы идентичны. |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
306 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
307 =item C<[get,set]layout> |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
308 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
309 Обертка, которая будет использована для построения представления документа. В обертке |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
310 будет доступна специальная переменная C<content>, при обращении к которой будет B<выполнен> |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
311 метод C<RenderContent()> и возвращен результат его работы. Для получения шаблона обертки |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
312 используется загрузчик из свойства C<loader>. |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
313 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
314 =item C<[get]opts> |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
315 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
316 Параметры контекста, используются для создания контекстов фабрик элементов управления. |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
317 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
318 =item C<[get]loader> |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
319 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
320 Загрузчик, используется для загрузки шаблонов фабрик элементов управления и обертки. |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
321 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
322 =item C<[get]controls> |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
323 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
324 C<HASH> Коллекция загруженных фабрик элементов управления, ключем является |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
325 квалифицированное имя элемента управления. |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
326 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
327 =item C<[get]stash> |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
328 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
329 C<Template::Stash> Пространство имен документа, оно используется как родительское |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
330 для пространств имен загружаемых фабрик элементов управления. |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
331 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
332 =back |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
333 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
334 =head1 TEMPLATES |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
335 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
336 =begin text |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
337 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
338 [%META layout='default'%] |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
339 [% BLOCK CTOR; |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
340 section('top','TOP'); |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
341 section('bottom','BOTTOM'); |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
342 section('client','CLIENT'); |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
343 END %] |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
344 [% BLOCK TOP; |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
345 TMenu = require('my/org/Menu'); |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
346 append(TMenu.new()); |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
347 END %] |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
348 |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
349 =end |
|
7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
cin
parents:
194
diff
changeset
|
350 |
| 181 | 351 =cut |
