<div tal:define=" name name|field.name; style field.widget.style; oid oid|field.oid; css_class css_class|field.widget.css_class; optgroup_class optgroup_class|field.widget.optgroup_class; multiple multiple|field.widget.multiple;" tal:omit-tag=""> <input type="hidden" name="__start__" value="${name}:sequence" tal:condition="multiple" /> <select tal:attributes=" name name; id oid; class string: form-control ${css_class or ''}; data-placeholder field.widget.placeholder|None; multiple multiple; style style;"> <tal:loop tal:repeat="item values"> <optgroup tal:condition="isinstance(item, optgroup_class)" tal:attributes="label item.label"> <option tal:repeat="(value, description) item.options" tal:attributes=" selected python:field.widget.get_select_value(cstruct, value); class css_class; label field.widget.long_label_generator and description; value value" tal:content="field.widget.long_label_generator and field.widget.long_label_generator(item.label, description) or description"/> </optgroup> <option tal:condition="not isinstance(item, optgroup_class)" tal:attributes=" selected python:field.widget.get_select_value(cstruct, item[0]); class css_class; value item[0]">${item[1]}</option> </tal:loop> </select> <script type="text/javascript"> deform.addCallback( '${oid}', function(oid) { $('#' + oid).select2({ containerCssClass: 'form-control drop-menu', dropdownCssClass: 'drop-menu-dropdown', dropdownAutoWidth: true, placeholder: "${str(field.widget.placeholder).replace('"','\\"')|""}", allowClear: true }); } ); </script> <input type="hidden" name="__end__" value="${name}:sequence" tal:condition="multiple" /> </div>