44 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| {% from "components/icon.html" import Icon %}
 | |
| {% from "components/tooltip.html" import Tooltip %}
 | |
| 
 | |
| {% macro OptionsInput(field, tooltip, inline=False, label=True, disabled=False) -%}
 | |
|   <optionsinput
 | |
|     name='{{ field.name }}'
 | |
|     inline-template
 | |
|     {% if field.errors %}v-bind:initial-errors='{{ field.errors | list }}'{% endif %}
 | |
|     {% if field.data and field.data != "None" %}v-bind:initial-value="'{{ field.data }}'"{% endif %}
 | |
|     key='{{ field.name }}'
 | |
|     >
 | |
|     <div
 | |
|       v-bind:class="['usa-input', { 'usa-input--error': showError, 'usa-input--success': showValid }]">
 | |
| 
 | |
|       <fieldset data-ally-disabled="true" v-on:change="onInput" class="usa-input__choices {% if inline %}usa-input__choices--inline{% endif %}">
 | |
|         {% if label %}
 | |
|           <legend>
 | |
|             <div class="usa-input__title{% if not field.description %}-inline{% endif %}">
 | |
|               {{ field.label | striptags}}
 | |
|               {% if tooltip %}{{ Tooltip(tooltip) }}{% endif %}
 | |
|             </div>
 | |
| 
 | |
|             {% if field.description %}
 | |
|               <span class='usa-input__help'>{{ field.description | safe }}</span>
 | |
|             {% endif %}
 | |
| 
 | |
|             <span v-show='showError'>{{ Icon('alert',classes="icon-validation") }}</span>
 | |
|             <span v-show='showValid'>{{ Icon('ok',classes="icon-validation") }}</span>
 | |
|           </legend>
 | |
|         {% endif %}
 | |
| 
 | |
|         {{ field(disabled=disabled) }}
 | |
| 
 | |
|         <template v-if='showError'>
 | |
|           <span class='usa-input__message' v-html='validationError'></span>
 | |
|         </template>
 | |
| 
 | |
|       </fieldset>
 | |
|     </div>
 | |
| 
 | |
|   </optionsinput>
 | |
| 
 | |
| {%- endmacro %}
 |