]> git.agnieray.net Git - galette.git/blob - galette/templates/default/pages/member_form.html.twig
Better member form without javascript
[galette.git] / galette / templates / default / pages / member_form.html.twig
1 {% extends parent_tpl %}
2
3 {% block content %}
4 {% if member.id %}
5 <div class="ui stackable grid">
6 <div class="row">
7 <div class="sixteen wide tablet six wide computer five wide widescreen column">
8 <div class="position-sticky">
9 <div class="ui basic fitted segment">
10 {% include "elements/navigate.html.twig" with {"mpath": "editMember"} %}
11 </div>
12 {% include "elements/member_card.html.twig" %}
13 </div>
14 </div>
15
16 <div class="sixteen wide tablet ten wide computer eleven wide widescreen column">
17 {% endif %}
18
19 <form action="{% if self_adh %}{{ path_for("storeselfmembers") }}{% elseif not member.id %}{{ path_for("doAddMember") }}{% else %}{{ path_for("doEditMember", {"id": member.id}) }}{% endif %}" method="post" enctype="multipart/form-data" id="form" class="ui form">
20 {% if not self_adh %}
21 <div class="ui compact segment">
22 {% if member.hasParent() and not member.isDuplicate() %}
23 <div class="inline field">
24 <span class="ui primary ribbon label">{{ _T("Attached to:") }}</span>
25 <a href="{{ path_for("member", {"id": member.parent.id}) }}" class="ui label">{{ member.parent.sfullname }}</a>
26 {% if not member.id %}
27 <input type="hidden" name="parent_id" value="{{ member.parent.id }}"/>
28 {% endif %}
29 </div>
30 {% if login.isAdmin() or login.isStaff() and (addchild is not defined or not addchild) %}
31 <div class="inline field">
32 <div class="ui toggle checkbox">
33 <input type="checkbox" name="detach_parent" id="detach_parent" value="1"/>
34 <label for="detach_parent">{{ _T("Detach?") }}</label>
35 </div>
36 </div>
37 {% endif %}
38 {% elseif (login.isAdmin() or login.isStaff()) and not member.hasChildren() and members.list is defined %}
39 <div id="attach-checkbox" class="ui jsonly read-only{% if member.isDuplicate() %} checked{% endif %} toggle checkbox">
40 <input type="checkbox" name="attach" id="attach" value="1"{% if member.isDuplicate() %} checked="checked"{% endif %}/>
41 <label for="attach"><i class="linkify icon"></i> {{ _T("Attach member") }}</label>
42 </div>
43 <span id="parent_id_elt" class="">
44 <div id="parent_id" class="ui search selection dropdown nochosen">
45 <input type="hidden" name="parent_id" value="{{ member.isDuplicate() and member.parent is defined and member.parent is not null ? member.parent.id }}">
46 <i class="dropdown icon"></i>
47 <div class="default text">{{ _T("-- select a name --") }}</div>
48 <div class="menu">
49 {% for k, v in members.list %}
50 <div class="item" data-value="{{ k }}">{{ v }}</div>
51 {% endfor %}
52 </div>
53 </div>
54 <div class="ui tiny icon button" id="reset-contributor"><i class="redo icon"></i><span class="hidden">{{ _T("Reset") }}</span></div>
55 </span>
56 {% if member.isDuplicate() %}
57 <input type="hidden" name="duplicate" value="1" />
58 {% endif %}
59 <noscript><div class="ui message">{{ _T("This function requires javascript.") }}</div></noscript>
60 {% elseif member.hasChildren() %}
61 <div class="inline field">
62 <span class="ui primary ribbon label">{{ _T("Parent of:") }}</span>
63 {% for child in member.children %}
64 <a href="{{ path_for("member", {"id": child.id}) }}" class="ui label">{{ child.sfullname }}</a>{% if not loop.last %}, {% endif %}
65 {% endfor %}
66 </div>
67 {% endif %}
68 </div>
69 {% endif %}
70 {# Main form entries #}
71 {% include "components/form.html.twig" %}
72 {# Dynamic entries #}
73 {% include "components/dynamic_fields.html.twig" with {object: member} %}
74 {% include "elements/edit_socials.html.twig" with {socials: member.socials} %}
75
76 {% if not member.id and not self_adh %}
77 {% if login.isAdmin() or login.isStaff() %}
78 <div class="ui center aligned yellow segment">
79 <div class="inline field">
80 <label for="redirect_on_create">{{ _T("After member creation:") }}</label>
81 <select name="redirect_on_create" id="redirect_on_create"i class="ui search dropdown nochosen">
82 <option value="{{ constant('Galette\\Entity\\Adherent::AFTER_ADD_DEFAULT') }}"{% if preferences.pref_redirect_on_create == constant('Galette\\Entity\\Adherent::AFTER_ADD_DEFAULT') %} selected="selected"{% endif %}>{{ _T("create a new contribution (default action)") }}</option>
83 <option value="{{ constant('Galette\\Entity\\Adherent::AFTER_ADD_TRANS') }}"{% if preferences.pref_redirect_on_create == constant('Galette\\Entity\\Adherent::AFTER_ADD_TRANS') %} selected="selected"{% endif %}>{{ _T("create a new transaction") }}</option>
84 <option value="{{ constant('Galette\\Entity\\Adherent::AFTER_ADD_NEW') }}"{% if preferences.pref_redirect_on_create == constant('Galette\\Entity\\Adherent::AFTER_ADD_NEW') %} selected="selected"{% endif %}>{{ _T("create another new member") }}</option>
85 <option value="{{ constant('Galette\\Entity\\Adherent::AFTER_ADD_SHOW') }}"{% if preferences.pref_redirect_on_create == constant('Galette\\Entity\\Adherent::AFTER_ADD_SHOW') %} selected="selected"{% endif %}>{{ _T("show member") }}</option>
86 <option value="{{ constant('Galette\\Entity\\Adherent::AFTER_ADD_LIST') }}"{% if preferences.pref_redirect_on_create == constant('Galette\\Entity\\Adherent::AFTER_ADD_LIST') %} selected="selected"{% endif %}>{{ _T("go to members list") }}</option>
87 <option value="{{ constant('Galette\\Entity\\Adherent::AFTER_ADD_HOME') }}"{% if preferences.pref_redirect_on_create == constant('Galette\\Entity\\Adherent::AFTER_ADD_HOME') %} selected="selected"{% endif %}>{{ _T("go to main page") }}</option>
88 </select>
89 </div>
90 </div>
91 {% else %}
92 <input type="hidden" name="redirect_on_create" value="{{ constant('Galette\\Entity\\Adherent::AFTER_ADD_SHOW') }}"/>
93 {% endif %}
94 {% if addchild is defined and addchild %}
95 <input type="hidden" name="addchild" value="true"/>
96 {% endif %}
97 {% endif %}
98 {% if preferences.pref_mail_method != constant('Galette\\Core\\GaletteMail::METHOD_DISABLED') and (not self_adh and (login.isAdmin() or login.isStaff())) %}
99 <div class="ui center aligned yellow segment">
100 <div class="inline field">
101 <div class="ui toggle checkbox">
102 <input type="checkbox" name="mail_confirm" id="mail_confirm" value="1"{% if member.sendEMail() %} checked="checked"{% endif %}/>
103 <label for="mail_confirm">
104 {% if member.id %}
105 {{ _T("Notify member his account has been modified") }}
106 {% else %}
107 {{ _T("Notify member his account has been created") }}
108 {% endif %}
109 </label>
110 <br/>
111 <span class="exemple">
112 {% if member.id %}
113 {{ _T("Member will be notified by email his account has been modified.") }}
114 {% else %}
115 {{ _T("Member will receive his username and password by email, if he has an address.") }}
116 {% endif %}
117 </span>
118 </div>
119 </div>
120 </div>
121 {% endif %}
122 <div class="ui basic center aligned fitted segment">
123 <button type="submit" name="valid" class="action ui labeled icon primary button">
124 <i class="save icon"></i> {{ _T("Save") }}
125 </button>
126 {% for entry in hidden_elements %}
127 {% if entry.field_id != 'mdp_adh' %}
128 {% set title = null %}
129 {% set tip = null %}
130 {% set size = null %}
131 {% set propname = entry.propname %}
132 {% if entry.field_id == 'activite_adh' %}
133 {% set value = member.isActive() %}
134 {% else %}
135 {% set value = attribute(member, propname) %}
136 {% endif %}
137 {% set checked = null %}
138 {% set example = null %}
139
140 {% if value != '' and entry.field_id != 'parent_id' %}
141 {% include "components/forms/hidden.html.twig" with {
142 name: entry.field_id,
143 id: entry.field_id,
144 value: value
145 } %}
146 {% endif %}
147 {% endif %}
148 {% endfor %}
149 {% include "components/forms/csrf.html.twig" %}
150 </div>
151 </form>
152
153 {% if member.id %}
154 </div>
155 </div>
156 </div>
157 {% endif %}
158 {% endblock %}
159
160 {% block javascripts %}
161 <script type="text/javascript">
162 {% include "elements/js/choose_adh.js.twig" with {"js_chosen_id": "#parent_id"} %}
163 $(function() {
164 $('#company_field.nocompany').addClass('hidden');
165 $('#is_company').change(function(){
166 $('#company_field').toggleClass('hidden');
167 $('#company_field').backgroundFade(
168 {
169 sColor:'#ffffff',
170 eColor:'#DDDDFF',
171 steps:10
172 },
173 function() {
174 $(this).backgroundFade(
175 {
176 sColor:'#DDDDFF',
177 eColor:'#ffffff'
178 }
179 );
180 });
181 });
182
183 {% if not self_adh %}
184 {# Groups popup #}
185 $('#btngroups, #btnmanagedgroups').click(function(){
186 var _managed = false;
187 if ( $(this).attr('id') == 'btnmanagedgroups' ) {
188 _managed = true;
189 }
190 var _groups = [];
191 var _form = (_managed) ? 'managed' : 'user';
192 $('#' + _form + 'groups_form input').each(function(){
193 _group = $(this).val().split('|');
194 _groups[_groups.length] = {
195 id: _group[0],
196 name: _group[1]
197 };
198 });
199 $.ajax({
200 url: '{{ path_for("ajax_groups") }}',
201 type: "POST",
202 data: {
203 ajax: true,
204 groups: _groups,
205 managed: _managed
206 },
207 {% include "elements/js/loader.js.twig" with {
208 selector: '#groups_field'
209 } %},
210 success: function(res){
211 _groups_dialog(res, _groups, _managed);
212 },
213 error: function() {
214 alert("{{ _T("An error occurred displaying groups interface :(")|e('js') }}");
215 }
216 });
217 return false;
218 });
219
220 var _groups_dialog = function(res, _groups, _managed){
221 var _title = '{{ _T("Groups selection")|e('js') }}';
222 if ( _managed ) {
223 _title = '{{ _T("Managed groups selection")|e('js') }}';
224 }
225 $('body').modal({
226 title: _title,
227 class: 'fullscreen scrolling',
228 content: res,
229 actions: [{
230 text : '{{ _T("Close")|e('js') }}',
231 class : 'cancel'
232 }]
233 }).modal('show');
234 _groups_ajax_mapper(res, _groups, _managed);
235 }
236
237 var _groups_ajax_mapper = function(res, _groups, _managed){
238 $('#btnvalid').click(function(){
239 //remove actual groups
240 var _form = (_managed) ? 'managed' : 'user';
241 $('#' + _form + 'groups_form').empty();
242 var _groups = new Array();
243 var _groups_str = '<br/><strong>';
244 if ( _managed ) {
245 _groups_str += '{{ _T("Manager for:")|e('js') }}';
246 } else {
247 _groups_str += '{{ _T("Member of:")|e('js') }}';
248 }
249 _groups_str += '</strong> ';
250
251 $('li[id^="group_"]').each(function(){
252 //get group values
253 _gid = this.id.substring(6, this.id.length);
254 _gname = $(this).text();
255 _groups[_groups.length] = this.id.substring(6, this.id.length);
256 var _iname = (_managed) ? 'groups_managed_adh' : 'groups_adh';
257 $('#' + _form + 'groups_form').append(
258 '<input type="hidden" value="' +
259 _gid + '|' + _gname + '|' +
260 '" name="' + _iname + '[]">'
261 );
262 if ( _groups.length > 1 ) {
263 _groups_str += ', ';
264 }
265 _groups_str += _gname;
266 });
267 $('#' + _form + 'groups').html(_groups_str);
268 $('#ajax_groups_list').modal('hide');
269 });
270 //Remap links
271 var _none = $('#none_selected').clone();
272 $('li input[type=checkbox]').click(function(e){
273 e.stopPropagation();
274 });
275 $('li[id^="group_"]').click(function(){
276 $(this).remove();
277 if ( $('#selected_groups ul li').length == 0 ) {
278 $('#selected_groups ul').append(_none);
279 }
280 });
281 $('#listing a').click(function(e){
282 e.preventDefault();
283 var _gid = this.href.match(/.*\/(\d+)$/)[1];
284 var _gname = $(this).text();
285 $('#none_selected').remove()
286 if ( $('#group_' + _gid).length == 0 ) {
287 var _li = '<li id="group_' + _gid + '" class="item"><i class="user minus icon"></i><span class="ui content">' + _gname + '</span></li>';
288 $('#selected_groups ul').append(_li);
289 $('#group_' + _gid).click(function(){
290 $(this).remove();
291 if ( $('#selected_groups ul li').length == 0 ) {
292 $('#selected_groups ul').append(_none);
293 }
294 });
295 }
296 return false;
297 });
298
299 }
300
301 {% if not self_adh and not member.hasChildren() %}
302 {# Parent selection #}
303 {% if not member.isDuplicate() %}
304 $('#parent_id_elt').addClass('hidden');
305 {% endif %}
306 $('#attach-checkbox').checkbox({
307 onChecked: function() {
308 $('#parent_id_elt').removeClass('hidden');
309 },
310 onUnchecked: function() {
311 $('#parent_id_elt').addClass('hidden');
312 }
313 });
314 {% endif %}
315
316 {% if not self_adh %}
317 {% if parent_fields|length > 0 %}
318 $('#detach_parent').on('change', function(){
319 var _checked = $(this).is(':checked');
320 var _changes = '';
321 {% for req in parent_fields %}
322 _changes += '#{{ req }}';
323 {% if not loop.last %}
324 _changes += ',';
325 {% endif %}
326 {% endfor %}
327 if (_checked) {
328 $(_changes).attr('required', 'required');
329 } else {
330 $(_changes).removeAttr('required');
331 }
332 });
333
334 $('#parent_id').on('change', function(){
335 var _hasParent = $(this).attr('value') != '';
336 var _changes = '';
337 {% for req in parent_fields %}
338 _changes += '#{{ req }}';
339 {% if not loop.last %}
340 _changes += ',';
341 {% endif %}
342 {% endfor %}
343 if (_hasParent) {
344 $(_changes).removeAttr('required');
345 } else {
346 $(_changes).attr('required', 'required');
347 }
348 });
349 {% endif %}
350 {% endif %}
351 {% include "elements/js/photo_dnd.js.twig" %}
352
353 $('#ddn_adh').on('blur', function() {
354 var _bdate = $(this).val();
355 if ('{{ _T("Y-m-d") }}' === 'Y-m-d') {
356 _bdate = new Date(_bdate);
357 } else {
358 //try for dd/mm/yyyy
359 var _dparts = _bdate.split("/");
360 _bdate = new Date(_dparts[2], _dparts[1] - 1, _dparts[0]);
361 }
362
363 if (! isNaN(_bdate.getTime())) {
364 var _today = new Date();
365 var _age = Math.floor((_today-_bdate) / (365.25 * 24 * 60 * 60 * 1000));
366 $('#member_age').html('{{ _T(" (%age years old)") }}'.replace(/%age/, _age))
367 } else {
368 $('#member_age').html('');
369 }
370 });
371 {% endif %}
372 });
373 </script>
374 {% endblock %}