Changes for page Macros
Last modified by Jip-jan Alunkel on April 15, 18:09
From version 2.89
edited by Jip-jan Alunkel
on April 10, 16:33
on April 10, 16:33
Change comment:
Renamed from xwiki:assets.formMaker.form-macros
To version 2.101
edited by Jip-jan Alunkel
on June 28, 20:49
on June 28, 20:49
Change comment:
Update document after refactoring.
Summary
-
Page properties (2 modified, 0 added, 0 removed)
Details
- Page properties
-
- Parent
-
... ... @@ -1,1 +1,1 @@ 1 - Main.WebHome1 +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,20 +39,45 @@ 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 - #createNumberElement($elementDataObj $elementType $requiredAttributes) 58 + #if(!$elementDataObj.data-decimals)#set($elementDataObj.data-decimals = 0)#end 59 + #if(!$elementDataObj.decimals-step)#set($elementDataObj.decimals-step = 1)#end 60 + #createNumberElement($elementDataObj $elementType) 54 54 #elseif($elementType == "email") 62 + #createEmailElement($elementDataObj $elementType) 63 + #elseif($elementType == "password") 64 + #createPasswordElement($elementDataObj $elementType) 55 55 #elseif($elementType == "range") 66 + #if($elementDataObj.range-minmax) 67 + #set($minmax = $elementDataObj.range-minmax.split('-')) 68 + #if($minmax.size() == 2) 69 + #set($elementDataObj.range-min = $minmax[0]) 70 + #set($elementDataObj.range-max = $minmax[1]) 71 + #end 72 + #else 73 + #set($elementDataObj.range-min = 0) 74 + #set($elementDataObj.range-max = 100) 75 + #end 76 + #createRangeElement($elementDataObj $elementType) 77 + #elseif($elementType == "date") 78 + #createDateElement($elementDataObj $elementType) 79 + #elseif($elementType == "color") 80 + #createColorElement($elementDataObj $elementType) 81 + #elseif($elementType == "tel") 82 + #createTelElement($elementDataObj $elementType) 83 + #elseif($elementType == "url") 84 + #createUrlElement($elementDataObj $elementType) 56 56 #end 57 57 #end 58 58 #if($elementDataObj.help-block && $elementDataObj.help-block != "") ... ... @@ -60,8 +60,8 @@ 60 60 #end 61 61 #if($elementDataObj.required == "true") 62 62 <span class="required-input-field" title="Required input"></span> 63 - <span role="alert" class="form-not-valid-tip"></span> 64 64 #end 93 + <span role="alert" class="form-not-valid-tip"></span> 65 65 </span> 66 66 </label> 67 67 </p> ... ... @@ -72,9 +72,7 @@ 72 72 <span class="fieldset no-fieldset-border"> 73 73 <label for="${elementDataObj.id}" class="strong"> 74 74 #if($elementType == "checkbox") 75 - 76 76 #createCheckboxElement($elementDataObj) 77 - 78 78 #elseif($elementType == "radio") 79 79 #end 80 80 </label> ... ... @@ -86,35 +86,124 @@ 86 86 <p class="box errormessage">${hint}</p> 87 87 #end 88 88 #end 116 + 89 89 #macro(createSelectElement $O_elementData $O_tagName) 90 - <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}"> 118 + <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}"> 91 91 #if($O_elementData.placeholder) 92 92 <option value="" disabled="" selected="" hidden="hidden">${O_elementData.placeholder}</option> 93 93 #end 94 - #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")) 95 - #set($spaceLikeRef = $O_elementData.space-reference.replaceAll('([%_!])', '!$1').concat('.%')) 96 - #set($spaceExcludeRef = $O_elementData.space-reference.replaceAll('([%_!])', '!$1').concat('.Code')) 97 - #set($query = $query.bindValue('space', $spaceLikeRef)) 98 - #set($query = $query.bindValue('spaceExclude', $spaceExcludeRef)) 99 - #set($results = $query.addFilter('unique').execute()) 100 - #foreach ($item in $results) 101 - #set ($document = $xwiki.getDocument($item)) 102 - <option value="$document.space">$document.getTitle()</option> 122 + #set ($mydoc = $xwiki.getDocument('assets.pagemaker.pagemakerClass')) 123 + #if($mydoc.isNew() && $hasProgramming) 124 + #set ($myinternaldoc = $mydoc.getDocument()) 125 + #set ($myclass = $myinternaldoc.getXClass()) 126 + #set ($discard = $myclass.addTextField("pmSpaceOrder", "pageMaker space order", 10)) 127 + #set ($discard = $mydoc.save()) 103 103 #end 129 + #set($removedNr = 0) 130 + 131 + #if($O_elementData.select-space-reference) 132 + #set($space = $O_elementData.select-space-reference) 133 + #set($codespace = "") 134 + #if($xwiki.getSpaces().contains("${space}.${space}Code")) 135 + #set($codespace = "${space}Code") 136 + #elseif($xwiki.getSpaces().contains("${space}.Code")) 137 + #set($codespace = "Code") 138 + #elseif($xwiki.getSpaces().contains("${space}.code")) 139 + #set($codespace = "code") 140 + #end 141 + 142 + #set($nameExcludeRef = $codespace) 143 + #set($spaceAbsRef = $space.replaceAll('([%_!])', '!$1')) 144 + #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")) 145 + 146 + ## Add XObjects to current child spaces so the spaces can be queried on the XObject to generate the select options. 147 + #set($result_add_xobj = $query_add_xobj.bindValue('space', $spaceAbsRef).bindValue('nameExclude', $nameExcludeRef).addFilter('unique').execute()) 148 + #foreach($item in $result_add_xobj) 149 + #set($doc = $xwiki.getDocument("${space}.${item}.WebHome")) 150 + #set($rightXObj = $doc.getObject("assets.pagemaker.pagemakerClass", true)) 151 + #set($discard = $rightXObj.set('pmSpaceOrder', $foreach.count)) 152 + #set($discard = $doc.save()) 153 + #end 154 + 155 + #set($spaceExcludeRef = $space.replaceAll('([%_!])', '!$1').concat(".${codespace}")) 156 + #set($spaceLikeRef = $space.replaceAll('([%_!])', '!$1').concat('.%')) 157 + #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")) 158 + 159 + ## Generate the select options from all child spaces that have the 'assets.pagemaker.pagemakerClass' XClass. 160 + ## The order is still random but the JSON can be extracted from the console with the 'select-spaces-json' attribute. 161 + #set($result = $query.bindValue('space', $spaceLikeRef).bindValue('spaceExclude', $spaceExcludeRef).addFilter('unique').execute()) 162 + #foreach($item in $result) 163 + #set($doc = $xwiki.getDocument($item)) 164 + <option value="$doc.space">$doc.getTitle()</option> 165 + #end 166 + #elseif($O_elementData.select-json) 167 + #set($json = $O_elementData.select-json) 168 + #foreach($key in $json.keySet()) 169 + #set($spaceDocTitle = $json.get($key)) 170 + #set($spaceDoc = $xwiki.getDocument("${key}.WebHome")) ## Fetch doc or create one if it does not exist by this name. 171 + #set($spaceXObj = $spaceDoc.getObject("assets.pagemaker.pagemakerClass", true)) ## Get or create the needed object. 172 + #set($order_error = ($spaceXObj.getProperty('pmSpaceOrder').value != $foreach.count)) 173 + #set($title_error = ($spaceDoc.getTitle() != $spaceDocTitle)) 174 + #if($spaceDoc.isNew()) ## Doc did not exist so spaceDoc needs a title and a default locale. 175 + #set($discard = $spaceDoc.setTitle($spaceDocTitle)) ## Title. 176 + #set($discard = $spaceDoc.setDefaultLocale("en")) ## Locale. 177 + #set($discard = $spaceXObj.set("pmSpaceOrder", $foreach.count)) ## Set the property with the (correct) value. 178 + #set($discard = $spaceDoc.save()) 179 + #else 180 + #if($title_error) ## Doc did exist but the title did not match with the JSON value. 181 + #set($discard = $spaceDoc.setTitle($spaceDocTitle)) 182 + #end 183 + #if($order_error) ## Either the property does not exist or the value is incorrect. 184 + #set($discard = $spaceXObj.set("pmSpaceOrder", $foreach.count)) ## Set the property with the (correct) value. 185 + #end 186 + #if($title_error || $order_error) ## Save only if changed 187 + #set($discard = $spaceDoc.save()) 188 + #end 189 + #end 190 + <option value="$key">$json.get($key)</option> 191 + #end 192 + #end 104 104 </select> 194 + #if($removedNr > 0) 195 + $removedNr pages had the XObject ##${removeXObj}## removed. 196 + #end 105 105 #end 106 106 #macro(createTextElement $O_elementData $O_tagName) 107 - <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>199 + <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> 108 108 #end 109 109 #macro(createNumberElement $O_elementData $O_tagName) 110 - <input type="number" 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>202 + <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> 111 111 #end 204 +#macro(createEmailElement $O_elementData $O_tagName) 205 + <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> 206 +#end 207 +#macro(createPasswordElement $O_elementData $O_tagName) 208 + <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> 209 +#end 210 +#macro(createDateElement $O_elementData $O_tagName) 211 + <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> 212 +#end 213 +#macro(createColorElement $O_elementData $O_tagName) 214 + <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> 215 +#end 216 +#macro(createRangeElement $O_elementData $O_tagName) 217 + <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> 218 +#end 219 +#macro(createTelElement $O_elementData $O_tagName) 220 + <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> 221 +#end 222 +#macro(createUrlElement $O_elementData $O_tagName) 223 + <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> 224 +#end 112 112 #macro(createCheckboxElement $O_elementData) 113 - <input type="checkbox" name="${O_elementData.id}" id="${O_elementData.id}" 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.label226 + <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 114 114 #end 115 -#macro(create ExpandStart $id$value)116 - < divid="${id}_section_${value}"class="togglee">228 +#macro(createTextareaElement $O_elementData $O_tagName) 229 + <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> 117 117 #end 231 +#macro(createExpandStart $opener $value) 232 + <div id="${opener.id}_section_#if($value)${value}#else${opener.value}#end" class="togglee"> 233 +#end 118 118 #macro(createExpandEnd) 119 119 </div> 120 120 #end