1 <:# see preload.pod for documentation -:>
2 <:.set dist_image_uri = cfg.entryIfVar("uri", "dist_images", "/images") -:>
3 <:# utility definitions :>
4 <:-.define make_select; groups: 0, grouplabel: "label", groupid: "id",
5 itemgroupid: "groupid" -:>
6 <:-.if !default.defined -:>
7 <:-.set default = "" -:>
9 <select name="<:= name | html :>">
12 <:.if i.$itemgroupid eq "" -:>
13 <option value="<:= i.$id | html :>"
14 <:- .if i.$id eq default :> selected="selected"<:.end if -:>
16 <:-= i.$desc | html -:>
19 <:-.for g in groups -:>
20 <optgroup label="<:= g.$grouplabel | html -:>">
22 <:.if i.$itemgroupid == g.$groupid -:>
23 <option value="<:= i.$id | html :>"
24 <:- .if i.$id eq default :> selected="selected"<:.end if -:>
26 <:-= i.$desc | html -:>
33 <option value="<:= i.$id | html :>"
34 <:- .if i.$id eq default :> selected="selected"<:.end if -:>
36 <:-= i.$desc | html -:>
42 make_multicheck expects:
43 values - list of hashes
44 default - a list of ids of checks to be checked
45 id - the name of the id field
46 desc - the name of the description field.
47 name - the name of the input elements
48 readonly - true to make it readonly
50 <:-.define make_multicheck; readonly: 0-:>
52 <input type="hidden" name="_save_<:= name -:>" value="1">
54 <:-.if !default.defined -:>
55 <:-.set default = [] -:>
57 <:.set checked = {} -:>
58 <:.for v in default -:>
59 <:% checked.set(v, 1) -:>
62 <:-.for i in values -:>
64 <:.set element_id = name _ "-" _ i.$id -:>
65 <input type="checkbox" name="<:= name :>" <:= checked[i.$id] ? 'checked ' : '' -:>
66 id="<:= element_id -:>" value="<:= i.$id :>"
67 <:-# readonly attribute isn't valid for checkboxes -:>
68 <:-= readonly ? " disabled" : "" -:>
70 <label for="<:= element_id :>"><:= i.$desc -:></label>
77 base - base url for links
78 pages - the result of the bse.pages call
80 <:-.define page_list-:>
81 <:.set sep = base =~ /\?/ ? "&" : "?" -:>
82 <:.set base = base _ sep :>
83 <div class="pagelist">
84 Page <:= pages.page :> of <:= pages.pagecount :>
85 <:.if pages.previous_page -:>
86 <a href="<:= base |html:><:= pages.pname | uri :>=1&<:= pages.ppname | uri :>=<:= pages.pp | uri :>"><<</a>
87 <a href="<:= base |html:><:= pages.pname | uri :>=<:= pages.previous_page |uri:>&<:= pages.ppname | uri :>=<:= pages.pp | uri :>"><</a>
92 <:.for p in pages.pages :>
94 <a href="<:= base |html :><:= pages.pname | uri:>=<:= p.page | uri :>&<:=pages.ppname | uri :>=<:= pages.pp | uri :>"><:= p.page |html :></a>
96 <span><:= p.page |html:></span>
99 <:.if pages.next_page -:>
100 <a href="<:= base |html:><:= pages.pname | uri :>=<:= pages.next_page |uri:>&<:= pages.ppname | uri :>=<:= pages.pp | uri :>">></a>
101 <a href="<:= base |html:><:= pages.pname | uri :>=<:= pages.pagecount |uri:>&<:= pages.ppname | uri :>=<:= pages.pp | uri :>">>></a>
110 <:# parameters: field, default -:>
111 <: .if cgi.param(field).defined -:>
112 <:= cgi.param(field) -:>
114 <:= default | html -:>
118 <:.define error_img_n -:>
120 field - name of field
121 index - index of field
122 errors - hash of error messages (should be set by code)
124 <:.if errors.$field -:>
125 <:.set msg = errors.$field -:>
126 <:.set msg = msg.is_list ? msg[index] : msg -:>
127 <:.if msg.defined -:>
128 <:.set image = cfg.entry("error_img", "image", dist_image_uri _ "/admin/error.gif") -:>
129 <:.set width = cfg.entry("error_img", "width", 16) -:>
130 <:.set height = cfg.entry("error_img", "height", 16) -:>
131 <img src="<:= image -:>" alt="<:= msg :>" title="<:= msg :>" width="<:= width :>" height="<:= height :>" class="error_img">
136 <:.define error_img -:>
137 <:.call "error_img_n", index:0 -:>
140 <:.define input; options: {} -:>
143 field - entry from fields
144 object - source for defaults in edit mode
146 <: .set default = options.default -:>
147 <: .if !default.defined -:>
149 <: .set default = object.$name -:>
150 <: .elsif field.default -:>
151 <: .set default = field.default -:>
153 <: .set default = "" -:>
156 <: .if field.type and field.type eq "date" and default ne "" -:>
157 <: .set default = default.replace(/(\d+)\D+(\d+)\D+(\d+)/, "$3/$2/$1") -:>
158 <: .elsif field.type and field.type eq "time" and default ne "" -:>
159 <: .set default = bse.date(default =~ /:00$/ ? "%I:%M%p" : "%I:%M:%S%p", default).replace(/^0/, "").lower() -:>
161 <: .if cgi.param(name).defined -:>
162 <: .set default = cgi.param(name) -:>
164 <: .if field.htmltype eq "textarea" -:>
165 <textarea id="<:= name | html :>" name="<:= name | html :>" rows="<:= field.height ? field.height : cfg.entry("forms", "textarea_rows", 10) :>" cols=<:= field.width ? field.width : cfg.entry("forms", "textarea_cols", 60) | html :>>
166 <:-= default | html -:>
168 <: .elsif field.htmltype eq "checkbox" -:>
169 <:.set is_checked = cgi.param("_save_" _ name) ? cgi.param(name).defined : default -:>
170 <input type="hidden" name="_save_<:= name -:>" value="1">
171 <input id="<:= name | html :>" type="checkbox" name="<:= name | html :>"<:= is_checked ? ' checked="checked"' : '' :> value="<:= field.value ? field.value : 1 | html :>" />
172 <: .elsif field.htmltype eq "multicheck" -:>
173 <:# we expect default to be a list of selected checks -:>
174 <:.set values = field.select["values"] -:>
175 <:.set values = values.is_code ? values() : values -:>
176 <:.set default = cgi.param("_save_" _ name) ? [ cgi.param(name) ] : default -:>
177 <:.call "make_multicheck",
179 desc:field.select.label -:>
180 <: .elsif field.htmltype eq "select" -:>
181 <:.set values = field.select["values"] -:>
182 <:.set values = values.is_code ? values() : values -:>
183 <:.call "make_select",
188 desc: field.select.label,
189 groupid : (field.select.groupid or "id"),
190 itemgroupid: (field.select.itemgroupid or "groupid"),
191 groups: field.select.groups ? (field.select.groups.is_code ? (field.select.groups)() : field.select.groups ) : 0,
192 grouplabel: (field.select.grouplabel or "label")
194 <: .elsif field.htmltype eq 'file' -:>
195 <: .if default.length -:>
196 <span class="filename"><:= default :></span>
198 <input id="<:= name :>" type="file" name="<:= name :>" />
200 <input id="<:= name | html :>" type="text" name="<:= name | html :>" value="<:= default | html :>"
201 <:-= field.maxlength ? ' maxlength="' _ field.maxlength _ '"' : '' |raw:>
202 <:-= field.width ? ' size="' _ field.width _ '"' : '' | raw :> />
206 <:.define field; options: {} -:>
209 fields - hash of fields (may be set by page instead)
210 object - object containing defaults (can be set globally instead)
211 default - a default value not dependent on object (overrides object)
213 <:.if fields.is_hash -:>
214 <:.set f = fields[name] -:>
216 <:.call "inlinefield", field:f, name:name, options: options -:>
218 <p>Unknown field id '<b><:= name :></b>', available fields are '<:= fields.keys.join("', '") :>'</p>
221 <p>fields isn't a hash, something is wrong.</p>
225 <:.define inlinefield; options: {} -:>
227 name - the field name
228 field - a field, as an entry in fields
229 options - various options, including:
230 note - display this text as a note below the field
231 delete - add a delete checkbox
232 default - a custom default value, overrides object
234 <:.if field.is_hash -:>
236 <label for="<:= name :>"><:= field.nolabel ? "" : field.description | html :>:</label>
238 <:-.if field.readonly -:>
239 <:-.call "display", name:name, options: options -:>
241 <:-.call "input", name:name, options: options -:><:.call "error_img", field:name :>
243 <:-.if field.units -:>
244 <:-= field.units | html -:>
246 <:-.if options.note -:>
247 <br /><:= options.note | raw :>
249 <:-.if options["delete"] -:>
250 <br /><input type="checkbox" name="delete_<:= name :>" value="1" id="delete_<:= name :>"><label for="delete_<:= name :>">Delete</label>
257 <:.define fieldset -:>
258 <:# like field, but wrap in a per-field field set.
261 fields - hash of fields (may be set by page instead)
263 <:.set f = fields[name] -:>
267 <legend><:= f.description :></legend>
269 <:.call "input", name: name, field: f -:>
271 <:.elsif fields.is_hash -:>
272 <p>Unknown field id '<b><:= name :></b>', available fields are '<:= fields.keys.join("', '") :>'</p>
274 <p>fields isn't a hash, something is wrong.</p>
278 <:.define display -:>
281 field - entry from fields
282 object - source for defaults in edit mode
285 <: .set default = object.$name -:>
287 <: .if field.type and field.type eq "date" and default ne "" -:>
288 <: .set default = default.replace(/(\d+)\D+(\d+)\D+(\d+)/, "$3/$2/$1") -:>
289 <: .elsif field.type and field.type eq "time" and default ne "" -:>
290 <: .set default = bse.date(default =~ /:00$/ ? "%I:%M%p" : "%I:%M:%S%p", default).replace(/^0/, "").lower() -:>
292 <: .if field.htmltype eq "textarea" -:>
293 <textarea id="<:= name | html :>" name="<:= name | html :>" rows="<:= field.height ? field.height : cfg.entry("forms", "textarea_rows", 10) :>" cols=<:= field.width ? field.width : cfg.entry("textarea_cols", 60) | html :> readonly>
294 <:-= default | html -:>
296 <: .elsif field.htmltype eq "checkbox" -:>
297 <input id="<:= name | html :>" type="checkbox" name="<:= name | html :>"<:= is_checked ? ' checked="checked"' : '' :> value="<:= field.value ? field.value : 1 | html :>" readonly>
298 <: .elsif field.htmltype eq "multicheck" -:>
299 <:# we expect default to be a list of selected checks -:>
300 <:.set values = field.select["values"] -:>
301 <:.set values = values.is_code ? values() : values -:>
302 <:.call "make_multicheck",
304 desc: field.select.label,
306 <: .elsif field.htmltype eq "select" -:>
307 <:.set values = field.select["values"] -:>
308 <:.set values = values.is_code ? values() : values -:>
309 <:# find the selected value and display it's label -:>
310 <:.set sid = field.select.id -:>
311 <:.set sdesc = field.select.label -:>
312 <:.for value in values -:>
313 <:.if value.$id eq default -:>
318 <input id="<:= name :>" type="text" name="<:= name :>" value="<:= default :>"
319 <:-= field.width ? ' size="' _ field.width _ '"' : '' | raw :> readonly>
323 <:.define inlinefieldro -:>
325 name - the field name
326 field - a field, as an entry in fields
328 <:.if field.is_hash -:>
330 <label for="<:= name :>"><:= field.nolabel ? "" : field.description :>:</label>
331 <span><:.call "display", name:name -:>
332 <:-.if field.units -:>
340 <:.define fieldro -:>
341 <:# like field, but for display, not editing -:>
342 <:.if fields.is_hash -:>
343 <:.set f = fields[name] -:>
345 <:.call "inlinefieldro", field:f, name:name -:>
347 <p>Unknown field id '<b><:= name :></b>', available fields are '<:= fields.keys.join("', '") :>'</p>
350 <p>fields isn't a hash, something is wrong.</p>
354 <:.define fieldsetro -:>
355 <:# like fieldro, but wrap in a per-field field set.
358 fields - hash of fields (may be set by page instead)
360 <:.set f = fields[name] -:>
364 <legend><:= f.description :></legend>
366 <:.call "display", "name":name, "field":f -:>
368 <:.elsif fields.is_hash -:>
369 <p>Unknown field id '<b><:= name :></b>', available fields are '<:= fields.keys.join("', '") :>'</p>
371 <p>fields isn't a hash, something is wrong.</p>
375 <:.define messages -:>
376 <: .if request.messages.size -:>
377 <div class="messages">
378 <: .for m in request.messages -:>
379 <div class="<:= m.class :>"><:= m.html |raw :></div>
386 <:# expects loop, request, parent
387 which in most cases means you can just supply parent
389 <:.if request.user_can("bse_edit_reorder_children", parent) -:>
390 <:.set down_url = loop.next ? cfg.admin_url("move", { "stepparent":parent.id, "d":"swap", "id":loop.current.id, "other":loop.next.id, "r":top.admin }) : 0 -:>
391 <:.set up_url = loop.prev ? cfg.admin_url("move", { "stepparent":parent.id, "d":"swap", "id":loop.current.id, "other":loop.prev.id, "r":top.admin }) : 0 -:>
392 <:.set class = cfg.entry("arrows", "class", "bse_arrows") -:>
393 <span class="<:= m.class :>">
394 <:-.call "make_arrows", "down_url":down_url, "up_url":up_url -:>
399 <:.define make_arrows -:>
400 <:# expects down_url, up_url
402 <:.set width = cfg.entry("arrows", "image_width", 17) -:>
403 <:.set height = cfg.entry("arrows", "image_height", 13) -:>
404 <:.set extras = 'width="' _ width _ '" height="' _ height _ '"' -:>
405 <:.set blank_img = '<img src="' _ (dist_image_uri _ "/trans_pixel.gif").escape("html") _ '" alt="" ' _ extras _ ' />' -:>
406 <:.set down_img = '<img src="' _ cfg.entry("arrows", "downimg", dist_image_uri _ "/admin/move_down.gif").escape("html") _ '" alt="Down" ' _ extras _ ' />' -:>
407 <:.set up_img = '<img src="' _ cfg.entry("arrows", "upimg", dist_image_uri _ "/admin/move_up.gif").escape("html") _ '" alt="Up" ' _ extras _ ' />' -:>
409 <a href="<:= down_url :>"><:= down_img |raw:></a>
414 <a href="<:= up_url :>"><:= up_img |raw:></a>
421 <:.define word_wrap; text: @undef, prefix:"", noncontin: "", contin:"", escape1: "", escape2: "", width: 70 -:>
422 <:# Word wrap "text" at width columns, following settings:
423 width - word wrap width (default 70)
424 prefix - prefix to add to all lines
425 noncontin - prefix to additionally add to first line of each paragraph
426 contin - prefix to additionally add to lines that have been wrapped
427 escape1 - suffix to add to lines wrapped on a non-word
428 escape2 - suffix to add to lines wrapped on a word boundary
430 <:.set re = "^.{1," _ width _ "}\\s+" -:>
431 <:.set paras = text.split(/\n/) -:>
432 <:.for para in paras -:>
433 <: .set work = para -:>
434 <: .set first = 1 -:>
435 <: .while work.length -:>
437 <: .set work = work.replace(/^\s+/, "") -:>
439 <: .if work.length < 70 -:>
440 <: .set line = work -:>
441 <: .set work = "" -:>
443 <: .set m = work.match(re) -:>
445 <: .set line = work.substring(0, m.length).replace(/\s+$/, "") _ escape2 -:>
446 <: .set work = work.substring(m.length) -:>
448 <: .set line = work.substring(0, width) _ escape1 -:>
449 <: .set work = work.substring(width) -:>
452 <:= prefix _ (first ? noncontin : contin) _ line.replace(/\s+$/, "") |raw:>
453 <: .set first = 0 -:>
458 <:- include includes/custom/preload.tmpl optional -:>