Changes for page Macros

Last modified by Jip-jan Alunkel on April 15, 18:09

From version 2.91
edited by Jip-jan Alunkel
on April 11, 16:46
Change comment: Renamed from xwiki:assets.formMaker.form-macros
To version 2.99
edited by Jip-jan Alunkel
on June 28, 20:27
Change comment: Update document after refactoring.

Summary

Details

Page properties
Parent
... ... @@ -1,1 +1,1 @@
1 -Main.WebHome
1 +WebHome
Content
... ... @@ -1,16 +1,16 @@
1 1  {{velocity}}
2 2  #macro(createFormStart $id $product)
3 -<form action="" id="${id}" method="post" class="formMaker" data-form-product="${product}" novalidate="novalidate">
3 +<form action="" id="${id}" method="post" class="pagemaker" data-form-product="${product}" novalidate="novalidate">
4 4  #end
5 5  #macro(createFormEnd)
6 6   <div role="alert" class="form-response-output form-validation-errors" style="display: none">
7 7   <p>
8 -$services.localization.render('formMaker.line.global_error_msg')
8 +$services.localization.render('pagemaker.line.global_error_msg')
9 9   </p>
10 10   </div>
11 11   <div role="alert" class="form-response-output form-validation-ok" style="display: none">
12 12   <p>
13 -$services.localization.render('formMaker.line.global_ok_msg')
13 +$services.localization.render('pagemaker.line.global_ok_msg')
14 14   </p>
15 15   </div>
16 16  </form>
... ... @@ -18,17 +18,21 @@
18 18  #macro(createFormElement $elementDataObj)
19 19   #set($elementType = $elementDataObj.type)
20 20   #set($elementTagName = '')
21 - #set($requiredAttributes = 'aria-required="false"')
22 22   #set($requiredCSSClass = '')
22 + #set($makeFocusable = '')
23 23   #set($addedCSSClass = '')
24 24   #set($hint = '')
25 - #if($elementDataObj.required == "true")
25 + #set($placeholder = '')
26 + #if($elementDataObj.required == 'true')
26 26   #set($requiredCSSClass = ' class="required"')
27 27   #end
29 + #if($elementDataObj.data-query-type)
30 + #set($makeFocusable = ' tabindex="-1"')
31 + #end
28 28   #if($elementType == "select")
29 29   #set($addedCSSClass = " select-wrap")
30 30   #set($elementTagName = "select")
31 - #elseif($elementType == "text" || $elementType == "number" || $elementType == "range" || $elementType == "email")
35 + #elseif($elementType == "text" || $elementType == "number" || $elementType == "range" || $elementType == "email" || $elementType == "password" || $elementType == "date" || $elementType == "tel" || $elementType == "url" || $elementType == "color")
32 32   #set($elementTagName = "input")
33 33   #elseif($elementType == "checkbox" || $elementType == "radio")
34 34   #set($addedCSSClass = " checkradio")
... ... @@ -39,22 +39,43 @@
39 39   #set($hint = "This type of element does not exist, read the manual for more information about element types.")
40 40   #end
41 41   #if($elementTagName == "select" || $elementTagName == "input" || $elementTagName == "textarea")
42 - <p${requiredCSSClass}>
46 + <p${requiredCSSClass}${makeFocusable}>
43 43   <label for="${elementDataObj.id}_${elementTagName}">
44 44   $elementDataObj.label
45 45   <span class="input-wrap${addedCSSClass}">
46 46   #if($elementTagName == "select")
47 - #createSelectElement($elementDataObj $elementTagName $requiredAttributes)
51 + #createSelectElement($elementDataObj $elementTagName)
48 48   #elseif($elementTagName == "textarea")
53 + #createTextareaElement($elementDataObj $elementTagName)
49 49   #else
50 50   #if($elementType == "text")
51 - #createTextElement($elementDataObj $elementType $requiredAttributes)
56 + #createTextElement($elementDataObj $elementType)
52 52   #elseif($elementType == "number")
53 53   #if(!$elementDataObj.data-decimals)#set($elementDataObj.data-decimals = 0)#end
54 - #if(!$elementDataObj.decimals-step)#set($elementDataObj.decimals-step = 0.5)#end
55 - #createNumberElement($elementDataObj $elementType $requiredAttributes)
59 + #if(!$elementDataObj.decimals-step)#set($elementDataObj.decimals-step = 1)#end
60 + #createNumberElement($elementDataObj $elementType)
56 56   #elseif($elementType == "email")
62 + #createEmailElement($elementDataObj $elementType)
57 57   #elseif($elementType == "range")
64 + #if($elementDataObj.range-minmax)
65 + #set($minmax = $elementDataObj.range-minmax.split('-'))
66 + #if($minmax.size() == 2)
67 + #set($elementDataObj.range-min = $minmax[0])
68 + #set($elementDataObj.range-max = $minmax[1])
69 + #end
70 + #else
71 + #set($elementDataObj.range-min = 0)
72 + #set($elementDataObj.range-max = 100)
73 + #end
74 + #createRangeElement($elementDataObj $elementType)
75 + #elseif($elementType == "date")
76 + #createDateElement($elementDataObj $elementType)
77 + #elseif($elementType == "color")
78 + #createColorElement($elementDataObj $elementType)
79 + #elseif($elementType == "tel")
80 + #createTelElement($elementDataObj $elementType)
81 + #elseif($elementType == "url")
82 + #createUrlElement($elementDataObj $elementType)
58 58   #end
59 59   #end
60 60   #if($elementDataObj.help-block && $elementDataObj.help-block != "")
... ... @@ -62,8 +62,8 @@
62 62   #end
63 63   #if($elementDataObj.required == "true")
64 64   <span class="required-input-field" title="Required input"></span>
65 - <span role="alert" class="form-not-valid-tip"></span>
66 66   #end
91 + <span role="alert" class="form-not-valid-tip"></span>
67 67   </span>
68 68   </label>
69 69   </p>
... ... @@ -74,9 +74,7 @@
74 74   <span class="fieldset no-fieldset-border">
75 75   <label for="${elementDataObj.id}" class="strong">
76 76   #if($elementType == "checkbox")
77 -
78 78  #createCheckboxElement($elementDataObj)
79 -
80 80   #elseif($elementType == "radio")
81 81   #end
82 82   </label>
... ... @@ -88,35 +88,124 @@
88 88   <p class="box errormessage">${hint}</p>
89 89   #end
90 90  #end
114 +
91 91  #macro(createSelectElement $O_elementData $O_tagName)
92 - <select class="form-select form-control"#if($O_elementData.aria-label) aria-label="${O_elementData.aria-label}"#end aria-describedby="${O_elementData.id}_helpBlock"#if($O_elementData.required == "true") aria-required="true" required="required" data-error-response-type="${O_elementData.data-error-response-type}"#else aria-required="false"#end data-set-space="${O_elementData.data-set-space}" name="${O_elementData.id}_${O_tagName}" id="${O_elementData.id}_${O_tagName}">
116 + <select class="form-select form-control"#if($O_elementData.aria-label) aria-label="${O_elementData.aria-label}"#end aria-describedby="${O_elementData.id}_helpBlock"#if($O_elementData.required == "true") aria-required="true" required="required" data-error-response-type="${O_elementData.data-error-response-type}"#else aria-required="false"#end data-set-space="${O_elementData.data-set-space}"#if($O_elementData.select-spaces-json) data-select-spaces-json="true"#end name="${O_elementData.id}_${O_tagName}" id="${O_elementData.id}_${O_tagName}">
93 93   #if($O_elementData.placeholder)
94 94   <option value="" disabled="" selected="" hidden="hidden">${O_elementData.placeholder}</option>
95 95   #end
96 - #set($query = $services.query.xwql("from doc.object(AppWithinMinutes.MetadataClass) met where doc.space like :space and doc.space <> :spaceExclude order by met.dataSpaceName asc"))
97 - #set($spaceLikeRef = $O_elementData.space-reference.replaceAll('([%_!])', '!$1').concat('.%'))
98 - #set($spaceExcludeRef = $O_elementData.space-reference.replaceAll('([%_!])', '!$1').concat('.Code'))
99 - #set($query = $query.bindValue('space', $spaceLikeRef))
100 - #set($query = $query.bindValue('spaceExclude', $spaceExcludeRef))
101 - #set($results = $query.addFilter('unique').execute())
102 - #foreach ($item in $results)
103 - #set ($document = $xwiki.getDocument($item))
104 - <option value="$document.space">$document.getTitle()</option>
120 + #set ($mydoc = $xwiki.getDocument('assets.pagemaker.pagemakerClass'))
121 + #if($mydoc.isNew() && $hasProgramming)
122 + #set ($myinternaldoc = $mydoc.getDocument())
123 + #set ($myclass = $myinternaldoc.getXClass())
124 + #set ($discard = $myclass.addTextField("pmSpaceOrder", "pageMaker space order", 10))
125 + #set ($discard = $mydoc.save())
105 105   #end
127 + #set($removedNr = 0)
128 +
129 + #if($O_elementData.select-space-reference)
130 + #set($space = $O_elementData.select-space-reference)
131 + #set($codespace = "")
132 + #if($xwiki.getSpaces().contains("${space}.${space}Code"))
133 + #set($codespace = "${space}Code")
134 + #elseif($xwiki.getSpaces().contains("${space}.Code"))
135 + #set($codespace = "Code")
136 + #elseif($xwiki.getSpaces().contains("${space}.code"))
137 + #set($codespace = "code")
138 + #end
139 +
140 + #set($nameExcludeRef = $codespace)
141 + #set($spaceAbsRef = $space.replaceAll('([%_!])', '!$1'))
142 + #set($query_add_xobj = $services.query.xwql("select space.name from XWikiSpace as space where space.parent = :space and space.name <> :nameExclude and space.name <> 'WebPreferences' order by space.name"))
143 +
144 + ## Add XObjects to current child spaces so the spaces can be queried on the XObject to generate the select options.
145 + #set($result_add_xobj = $query_add_xobj.bindValue('space', $spaceAbsRef).bindValue('nameExclude', $nameExcludeRef).addFilter('unique').execute())
146 + #foreach($item in $result_add_xobj)
147 + #set($doc = $xwiki.getDocument("${space}.${item}.WebHome"))
148 + #set($rightXObj = $doc.getObject("assets.pagemaker.pagemakerClass", true))
149 + #set($discard = $rightXObj.set('pmSpaceOrder', $foreach.count))
150 + #set($discard = $doc.save())
151 + #end
152 +
153 + #set($spaceExcludeRef = $space.replaceAll('([%_!])', '!$1').concat(".${codespace}"))
154 + #set($spaceLikeRef = $space.replaceAll('([%_!])', '!$1').concat('.%'))
155 + #set($query = $services.query.xwql("from doc.object(assets.pagemaker.pagemakerClass) met where doc.space like :space and doc.space <> :spaceExclude and doc.name <> 'WebPreferences' order by met.pmSpaceOrder asc"))
156 +
157 + ## Generate the select options from all child spaces that have the 'assets.pagemaker.pagemakerClass' XClass.
158 + ## The order is still random but the JSON can be extracted from the console with the 'select-spaces-json' attribute.
159 + #set($result = $query.bindValue('space', $spaceLikeRef).bindValue('spaceExclude', $spaceExcludeRef).addFilter('unique').execute())
160 + #foreach($item in $result)
161 + #set($doc = $xwiki.getDocument($item))
162 + <option value="$doc.space">$doc.getTitle()</option>
163 + #end
164 + #elseif($O_elementData.select-json)
165 + #set($json = $O_elementData.select-json)
166 + #foreach($key in $json.keySet())
167 + #set($spaceDocTitle = $json.get($key))
168 + #set($spaceDoc = $xwiki.getDocument("${key}.WebHome")) ## Fetch doc or create one if it does not exist by this name.
169 + #set($spaceXObj = $spaceDoc.getObject("assets.pagemaker.pagemakerClass", true)) ## Get or create the needed object.
170 + #set($order_error = ($spaceXObj.getProperty('pmSpaceOrder').value != $foreach.count))
171 + #set($title_error = ($spaceDoc.getTitle() != $spaceDocTitle))
172 + #if($spaceDoc.isNew()) ## Doc did not exist so spaceDoc needs a title and a default locale.
173 + #set($discard = $spaceDoc.setTitle($spaceDocTitle)) ## Title.
174 + #set($discard = $spaceDoc.setDefaultLocale("en")) ## Locale.
175 + #set($discard = $spaceXObj.set("pmSpaceOrder", $foreach.count)) ## Set the property with the (correct) value.
176 + #set($discard = $spaceDoc.save())
177 + #else
178 + #if($title_error) ## Doc did exist but the title did not match with the JSON value.
179 + #set($discard = $spaceDoc.setTitle($spaceDocTitle))
180 + #end
181 + #if($order_error) ## Either the property does not exist or the value is incorrect.
182 + #set($discard = $spaceXObj.set("pmSpaceOrder", $foreach.count)) ## Set the property with the (correct) value.
183 + #end
184 + #if($title_error || $order_error) ## Save only if changed
185 + #set($discard = $spaceDoc.save())
186 + #end
187 + #end
188 + <option value="$key">$json.get($key)</option>
189 + #end
190 + #end
106 106   </select>
192 + #if($removedNr > 0)
193 + $removedNr pages had the XObject ##${removeXObj}## removed.
194 + #end
107 107  #end
108 108  #macro(createTextElement $O_elementData $O_tagName)
109 - <input type="text" class="form-control full" name="${O_elementData.id}_${O_tagName}" id="${O_elementData.id}_${O_tagName}" autocomplete="off"#if($O_elementData.placeholder) placeholder="${O_elementData.placeholder}"#end aria-describedby="${O_elementData.id}_helpBlock"#if($O_elementData.required == "true") aria-required="true" required="required" data-error-response-type="${O_elementData.data-error-response-type}"#else aria-required="false"#end#if($O_elementData.aria-label) aria-label="${O_elementData.aria-label}"#end#if($O_elementData.data-query-type) data-query-type="${O_elementData.data-query-type}"#end#if($O_elementData.data-query-list-type) data-query-list-type="${O_elementData.data-query-list-type}"')#end#if($O_elementData.data-query-list-header) data-query-list-header="${O_elementData.data-query-list-header}"')#end#if($O_elementData.data-query-list-contents) data-query-list-contents="${O_elementData.data-query-list-contents}"')#end#if($O_elementData.data-create-page) data-create-page="${O_elementData.data-create-page}"')#end#if($O_elementData.data-query-scope) data-query-scope="${O_elementData.data-query-scope}"')#end#if($O_elementData.data-create-xobj) data-create-xobj="${O_elementData.data-create-xobj}"')#end#if($O_elementData.data-xobj-classname) data-xobj-classname="${O_elementData.data-xobj-classname}"')#end#if($O_elementData.data-xobj-fieldname) data-xobj-fieldname="${O_elementData.data-xobj-fieldname}"')#end#if($O_elementData.data-query-list-editable) data-query-list-editable="${O_elementData.data-query-list-editable}"')#end>
197 + <input type="text" class="form-control full" name="${O_elementData.id}_${O_tagName}" id="${O_elementData.id}_${O_tagName}" autocomplete="off"#if($O_elementData.placeholder) placeholder="${O_elementData.placeholder}"#end aria-describedby="${O_elementData.id}_helpBlock"#if($O_elementData.required == "true") aria-required="true" required="required" data-error-response-type="${O_elementData.data-error-response-type}"#else aria-required="false"#end#if($O_elementData.aria-label) aria-label="${O_elementData.aria-label}"#end#if($O_elementData.data-query-type) data-query-type="${O_elementData.data-query-type}"#end#if($O_elementData.data-query-list-type) data-query-list-type="${O_elementData.data-query-list-type}"#end#if($O_elementData.data-query-list-header) data-query-list-header="${O_elementData.data-query-list-header}"#end#if($O_elementData.data-query-list-contents) data-query-list-contents="${O_elementData.data-query-list-contents}"#end#if($O_elementData.data-query-list-editable) data-query-list-editable="${O_elementData.data-query-list-editable}"#end#if($O_elementData.data-create-page) data-create-page="${O_elementData.data-create-page}"#end#if($O_elementData.data-query-scope) data-query-scope="${O_elementData.data-query-scope}"#end#if($O_elementData.data-create-xobj) data-create-xobj="${O_elementData.data-create-xobj}"#end#if($O_elementData.data-xobj-classname) data-xobj-classname="${O_elementData.data-xobj-classname}"#end#if($O_elementData.data-xobj-fieldname) data-xobj-fieldname="${O_elementData.data-xobj-fieldname}"#end>
110 110  #end
111 111  #macro(createNumberElement $O_elementData $O_tagName)
112 - <input type="number" class="form-control full" name="${O_elementData.id}_${O_tagName}" id="${O_elementData.id}_${O_tagName}" autocomplete="off" min="0" pattern="[0-9]*[.,]?[0-9]+" data-decimals="${O_elementData.data-decimals}" step="${O_elementData.decimal-step}"#if($O_elementData.placeholder) placeholder="${O_elementData.placeholder}"#end aria-describedby="${O_elementData.id}_helpBlock"#if($O_elementData.required == "true") aria-required="true" required="required" data-error-response-type="${O_elementData.data-error-response-type}"#else aria-required="false"#end#if($O_elementData.aria-label) aria-label="${O_elementData.aria-label}"#end#if($O_elementData.data-query-type) data-query-type="${O_elementData.data-query-type}"#end#if($O_elementData.data-query-list-type) data-query-list-type="${O_elementData.data-query-list-type}"')#end#if($O_elementData.data-query-list-header) data-query-list-header="${O_elementData.data-query-list-header}"')#end#if($O_elementData.data-query-list-contents) data-query-list-contents="${O_elementData.data-query-list-contents}"')#end#if($O_elementData.data-create-page) data-create-page="${O_elementData.data-create-page}"')#end#if($O_elementData.data-query-scope) data-query-scope="${O_elementData.data-query-scope}"')#end#if($O_elementData.data-create-xobj) data-create-xobj="${O_elementData.data-create-xobj}"')#end#if($O_elementData.data-xobj-classname) data-xobj-classname="${O_elementData.data-xobj-classname}"')#end#if($O_elementData.data-xobj-fieldname) data-xobj-fieldname="${O_elementData.data-xobj-fieldname}"')#end#if($O_elementData.data-query-list-editable) data-query-list-editable="${O_elementData.data-query-list-editable}"')#end>
200 + <input type="number" class="form-control full" name="${O_elementData.id}_${O_tagName}" id="${O_elementData.id}_${O_tagName}" autocomplete="off" min="0" pattern="[0-9]*[.,]?[0-9]+" data-decimals="${O_elementData.data-decimals}" step="${O_elementData.decimal-step}"#if($O_elementData.placeholder) placeholder="${O_elementData.placeholder}"#end aria-describedby="${O_elementData.id}_helpBlock"#if($O_elementData.required == "true") aria-required="true" required="required" data-error-response-type="${O_elementData.data-error-response-type}"#else aria-required="false"#end#if($O_elementData.aria-label) aria-label="${O_elementData.aria-label}"#end#if($O_elementData.data-query-type) data-query-type="${O_elementData.data-query-type}"#end#if($O_elementData.data-query-list-type) data-query-list-type="${O_elementData.data-query-list-type}"#end#if($O_elementData.data-query-list-header) data-query-list-header="${O_elementData.data-query-list-header}"#end#if($O_elementData.data-query-list-contents) data-query-list-contents="${O_elementData.data-query-list-contents}"#end#if($O_elementData.data-query-list-editable) data-query-list-editable="${O_elementData.data-query-list-editable}"#end#if($O_elementData.data-create-page) data-create-page="${O_elementData.data-create-page}"#end#if($O_elementData.data-query-scope) data-query-scope="${O_elementData.data-query-scope}"#end#if($O_elementData.data-create-xobj) data-create-xobj="${O_elementData.data-create-xobj}"#end#if($O_elementData.data-xobj-classname) data-xobj-classname="${O_elementData.data-xobj-classname}"#end#if($O_elementData.data-xobj-fieldname) data-xobj-fieldname="${O_elementData.data-xobj-fieldname}"#end>
113 113  #end
202 +#macro(createEmailElement $O_elementData $O_tagName)
203 + <input type="email" class="form-control full" name="${O_elementData.id}_${O_tagName}" id="${O_elementData.id}_${O_tagName}" autocomplete="off" pattern="^[A-Za-z0-9._+-]+@[A-Za-z0-9.-]+\.[A-Za-z]{2,63}$"#if($O_elementData.placeholder) placeholder="${O_elementData.placeholder}"#end aria-describedby="${O_elementData.id}_helpBlock"#if($O_elementData.required == "true") aria-required="true" required="required" data-error-response-type="${O_elementData.data-error-response-type}"#else aria-required="false"#end#if($O_elementData.aria-label) aria-label="${O_elementData.aria-label}"#end#if($O_elementData.data-create-xobj) data-create-xobj="${O_elementData.data-create-xobj}"#end#if($O_elementData.data-xobj-classname) data-xobj-classname="${O_elementData.data-xobj-classname}"#end#if($O_elementData.data-xobj-fieldname) data-xobj-fieldname="${O_elementData.data-xobj-fieldname}"#end>
204 +#end
205 +#macro(createPasswordElement $O_elementData $O_tagName)
206 + <input type="password" class="form-control full" name="${O_elementData.id}_${O_tagName}" id="${O_elementData.id}_${O_tagName}" autocomplete="off"#if($O_elementData.placeholder) placeholder="${O_elementData.placeholder}"#end aria-describedby="${O_elementData.id}_helpBlock"#if($O_elementData.required == "true") aria-required="true" required="required" data-error-response-type="${O_elementData.data-error-response-type}"#else aria-required="false"#end#if($O_elementData.aria-label) aria-label="${O_elementData.aria-label}"#end>
207 +#end
208 +#macro(createDateElement $O_elementData $O_tagName)
209 + <input type="date" class="form-control full" name="${O_elementData.id}_${O_tagName}" id="${O_elementData.id}_${O_tagName}"#if($O_elementData.date-min) min="${O_elementData.date-min}"#end#if($O_elementData.date-max) max="${O_elementData.date-max}"#end autocomplete="off" aria-describedby="${O_elementData.id}_helpBlock" #if($O_elementData.required == "true") aria-required="true" required="required" data-error-response-type="${O_elementData.data-error-response-type}"#else aria-required="false"#end#if($O_elementData.aria-label) aria-label="${O_elementData.aria-label}"#end#if($O_elementData.data-create-xobj) data-create-xobj="${O_elementData.data-create-xobj}"#end#if($O_elementData.data-xobj-classname) data-xobj-classname="${O_elementData.data-xobj-classname}"#end #if($O_elementData.data-xobj-fieldname) data-xobj-fieldname="${O_elementData.data-xobj-fieldname}"#end>
210 +#end
211 +#macro(createColorElement $O_elementData $O_tagName)
212 + <input type="color" class="form-control full" name="${O_elementData.id}_${O_tagName}" id="${O_elementData.id}_${O_tagName}" value="#fffffe" autocomplete="off" aria-describedby="${O_elementData.id}_helpBlock"#if($O_elementData.required == "true") aria-required="true" required="required" data-error-response-type="${O_elementData.data-error-response-type}"#else aria-required="false"#end#if($O_elementData.aria-label) aria-label="${O_elementData.aria-label}"#end#if($O_elementData.data-create-xobj) data-create-xobj="${O_elementData.data-create-xobj}"#end#if($O_elementData.data-xobj-classname) data-xobj-classname="${O_elementData.data-xobj-classname}"#end#if($O_elementData.data-xobj-fieldname) data-xobj-fieldname="${O_elementData.data-xobj-fieldname}"#end>
213 +#end
214 +#macro(createRangeElement $O_elementData $O_tagName)
215 + <input type="range" class="form-control full" name="${O_elementData.id}_${O_tagName}" id="${O_elementData.id}_${O_tagName}" min="${O_elementData.range-min}" max="${O_elementData.range-max}"#if($O_elementData.range-step) step="${O_elementData.range-step}"#end autocomplete="off" aria-describedby="${O_elementData.id}_helpBlock"#if($O_elementData.required == "true") aria-required="true" required="required" data-error-response-type="${O_elementData.data-error-response-type}"#else aria-required="false"#end#if($O_elementData.aria-label) aria-label="${O_elementData.aria-label}"#end#if($O_elementData.data-create-xobj) data-create-xobj="${O_elementData.data-create-xobj}"#end#if($O_elementData.data-xobj-classname) data-xobj-classname="${O_elementData.data-xobj-classname}"#end#if($O_elementData.data-xobj-fieldname) data-xobj-fieldname="${O_elementData.data-xobj-fieldname}"#end>
216 +#end
217 +#macro(createTelElement $O_elementData $O_tagName)
218 + <input type="tel" class="form-control full" name="${O_elementData.id}_${O_tagName}" id="${O_elementData.id}_${O_tagName}" autocomplete="off"#if($O_elementData.placeholder) placeholder="${O_elementData.placeholder}"#end aria-describedby="${O_elementData.id}_helpBlock"#if($O_elementData.required == "true") aria-required="true" required="required" data-error-response-type="${O_elementData.data-error-response-type}"#else aria-required="false"#end#if($O_elementData.aria-label) aria-label="${O_elementData.aria-label}"#end#if($O_elementData.data-create-xobj) data-create-xobj="${O_elementData.data-create-xobj}"#end#if($O_elementData.data-xobj-classname) data-xobj-classname="${O_elementData.data-xobj-classname}"#end#if($O_elementData.data-xobj-fieldname) data-xobj-fieldname="${O_elementData.data-xobj-fieldname}"#end>
219 +#end
220 +#macro(createUrlElement $O_elementData $O_tagName)
221 + <input type="url" class="form-control full" name="${O_elementData.id}_${O_tagName}" id="${O_elementData.id}_${O_tagName}" autocomplete="off" pattern="https?://.*"#if($O_elementData.placeholder) placeholder="${O_elementData.placeholder}"#end aria-describedby="${O_elementData.id}_helpBlock"#if($O_elementData.required == "true") aria-required="true" required="required" data-error-response-type="${O_elementData.data-error-response-type}"#else aria-required="false"#end#if($O_elementData.aria-label) aria-label="${O_elementData.aria-label}"#end#if($O_elementData.data-create-xobj) data-create-xobj="${O_elementData.data-create-xobj}"#end#if($O_elementData.data-xobj-classname) data-xobj-classname="${O_elementData.data-xobj-classname}"#end#if($O_elementData.data-xobj-fieldname) data-xobj-fieldname="${O_elementData.data-xobj-fieldname}"#end>
222 +#end
114 114  #macro(createCheckboxElement $O_elementData)
115 - <input type="checkbox" name="${O_elementData.id}" id="${O_elementData.id}" data-mod-display="${O_elementData.id}_checkradio" value="${O_elementData.value}"#if($O_elementData.required == "true") aria-required="true" required="required" data-error-response-type="${O_elementData.data-error-response-type}"#else aria-required="false"#end#if($O_elementData.aria-label) aria-label="${O_elementData.aria-label}"#end>$O_elementData.label
224 + <input type="checkbox" name="${O_elementData.id}" id="${O_elementData.id}"#if($O_elementData.data-opener) data-opener="${O_elementData.data-opener}"#end value="${O_elementData.value}"#if($O_elementData.required == "true") aria-required="true" required="required" data-error-response-type="${O_elementData.data-error-response-type}"#else aria-required="false"#end#if($O_elementData.aria-label) aria-label="${O_elementData.aria-label}"#end>$O_elementData.label
116 116  #end
117 -#macro(createExpandStart $id $value)
118 - <div id="${id}_section_${value}" class="togglee">
226 +#macro(createTextareaElement $O_elementData $O_tagName)
227 + <textarea class="form-control full" name="${O_elementData.id}_${O_tagName}" id="${O_elementData.id}_${O_tagName}"#if($O_elementData.placeholder) placeholder="${O_elementData.placeholder}"#end#if($O_elementData.textarea-rows) rows="$O_elementData.textarea-rows"#end aria-describedby="${O_elementData.id}_helpBlock"#if($O_elementData.required == "true") aria-required="true" required="required" data-error-response-type="${O_elementData.data-error-response-type}"#else aria-required="false"#end#if($O_elementData.aria-label) aria-label="${O_elementData.aria-label}"#end></textarea>
119 119  #end
229 +#macro(createExpandStart $opener $value)
230 + <div id="${opener.id}_section_#if($value)${value}#else${opener.value}#end" class="togglee">
231 +#end
120 120  #macro(createExpandEnd)
121 121   </div>
122 122  #end