mirror of
https://github.com/LaCasemate/fab-manager.git
synced 2024-12-04 15:24:23 +01:00
315 lines
19 KiB
HTML
315 lines
19 KiB
HTML
<div class="modal-header">
|
|
<img ng-src="{{logoBlack.custom_asset_file_attributes.attachment_url}}" alt="{{logo.custom_asset_file_attributes.attachment}}" class="modal-logo"/>
|
|
<i class="fa fa-times close-modal-button" ng-click="dismiss()"></i>
|
|
<h1 translate>{{ 'app.public.common.create_your_account' }}</h1>
|
|
</div>
|
|
<div class="">
|
|
<uib-alert ng-repeat="alert in alerts" type="{{alert.type}}" close="closeAlert($index)">{{alert.msg}}</uib-alert>
|
|
|
|
<div class="well m-b-n">
|
|
<form role="form" name="signupForm" class="form-horizontal signup-form" novalidate autocomplete="off" ng-keydown="signupForm.$valid && $event.which == 13 && ok()">
|
|
<div class="form-group" ng-class="{'has-error': signupForm.gender.$dirty && signupForm.gender.$invalid}">
|
|
<div class="col-sm-12">
|
|
<label class="checkbox-inline">
|
|
<input type="radio"
|
|
name="gender"
|
|
ng-model="user.statistic_profile_attributes.gender"
|
|
value="true"
|
|
required/> {{ 'app.public.common.man' | translate }}
|
|
</label>
|
|
<label class="checkbox-inline">
|
|
<input type="radio"
|
|
name="gender"
|
|
ng-model="user.statistic_profile_attributes.gender"
|
|
value="false"/> {{ 'app.public.common.woman' | translate }}
|
|
</label>
|
|
<span class="exponent m-l-xs help-cursor" title="{{ 'app.public.common.used_for_statistics' | translate }}"><i class="fa fa-asterisk" aria-hidden="true"></i></span>
|
|
<span class="help-block" ng-show="signupForm.gender.$dirty && signupForm.gender.$error.required" translate>{{ 'app.public.common.gender_is_required'}}</span>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="form-group names-row">
|
|
|
|
<div class="col-sm-6" ng-class="{'has-error': signupForm.first_name.$dirty && signupForm.first_name.$invalid}">
|
|
<input type="text"
|
|
name="first_name"
|
|
ng-model="user.profile_attributes.first_name"
|
|
class="form-control"
|
|
placeholder="{{ 'app.public.common.your_first_name' | translate }}"
|
|
required>
|
|
<span class="exponent m-l-xs help-cursor" title="{{ 'app.public.common.used_for_invoicing' | translate }}"><i class="fa fa-asterisk" aria-hidden="true"></i></span>
|
|
<span class="help-block" ng-show="signupForm.first_name.$dirty && signupForm.first_name.$error.required" translate>{{ 'app.public.common.first_name_is_required' }}</span>
|
|
</div>
|
|
<div class="m-b visible-xs"></div>
|
|
<div class="col-sm-6" ng-class="{'has-error': signupForm.last_name.$dirty && signupForm.last_name.$invalid}">
|
|
<input type="text"
|
|
name="last_name"
|
|
ng-model="user.profile_attributes.last_name"
|
|
class="form-control"
|
|
placeholder="{{ 'app.public.common.your_surname' | translate }}"
|
|
required>
|
|
<span class="exponent m-l-xs help-cursor" title="{{ 'app.public.common.used_for_invoicing' | translate }}"><i class="fa fa-asterisk" aria-hidden="true"></i></span>
|
|
<span class="help-block" ng-show="signupForm.last_name.$dirty && signupForm.last_name.$error.required" translate>{{ 'app.public.common.surname_is_required' }}</span>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="form-group required-row" ng-class="{'has-error': signupForm.username.$dirty && signupForm.username.$invalid}">
|
|
<div class="col-sm-12">
|
|
<div class="input-group">
|
|
<span class="input-group-addon"><i class="fa fa-user"></i></span>
|
|
<input type="text"
|
|
name="username"
|
|
ng-model="user.username"
|
|
class="form-control"
|
|
placeholder="{{ 'app.public.common.your_pseudonym' | translate }}"
|
|
required>
|
|
</div>
|
|
<span class="exponent help-cursor" title="{{ 'app.public.common.used_for_profile' | translate }}"><i class="fa fa-asterisk" aria-hidden="true"></i></span>
|
|
<span class="help-block" ng-show="signupForm.username.$dirty && signupForm.username.$error.required" translate>{{ 'app.public.common.pseudonym_is_required' }}</span>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="form-group required-row" ng-class="{'has-error': signupForm.email.$dirty && signupForm.email.$invalid}">
|
|
<div class="col-sm-12">
|
|
<div class="input-group">
|
|
<span class="input-group-addon"><i class="fa fa-envelope"></i></span>
|
|
<input type="email"
|
|
name="email"
|
|
ng-pattern="/^[^@]+@[^\.]+\..{2,}$/"
|
|
ng-model="user.email"
|
|
class="form-control"
|
|
placeholder="{{ 'app.public.common.your_email_address' | translate }}"
|
|
required>
|
|
</div>
|
|
<span class="exponent help-cursor" title="{{ 'app.public.common.used_for_invoicing' | translate }}"><i class="fa fa-asterisk" aria-hidden="true"></i></span>
|
|
<span class="help-block" ng-show="signupForm.email.$dirty && signupForm.email.$error.required" translate>{{ 'app.public.common.email_is_required' }}</span>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="form-group required-row" ng-class="{'has-error': signupForm.password.$dirty && signupForm.password.$invalid}">
|
|
<div class="col-sm-12">
|
|
<div class="input-group">
|
|
<span class="input-group-addon"><i class="fa fa-key"></i></span>
|
|
<input type="password"
|
|
name="password"
|
|
ng-model="user.password"
|
|
class="form-control"
|
|
placeholder="{{ 'app.public.common.your_password' | translate }}"
|
|
required
|
|
ng-minlength="8">
|
|
</div>
|
|
<span class="exponent"><i class="fa fa-asterisk" aria-hidden="true"></i></span>
|
|
<span class="help-block" ng-show="signupForm.password.$dirty && signupForm.password.$error.required" translate>{{ 'app.public.common.password_is_required' }}</span>
|
|
<span class="help-block" ng-show="signupForm.password.$dirty && signupForm.password.$error.minlength" translate>{{ 'app.public.common.password_is_too_short' }}</span>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="form-group required-row" ng-class="{'has-error': signupForm.password_confirmation.$dirty && signupForm.password_confirmation.$invalid}">
|
|
<div class="col-sm-12">
|
|
<div class="input-group">
|
|
<span class="input-group-addon"><i class="fa fa-key"></i></span>
|
|
<input type="password"
|
|
name="password_confirmation"
|
|
ng-model="user.password_confirmation"
|
|
class="form-control"
|
|
placeholder="{{ 'app.public.common.type_your_password_again' | translate }}"
|
|
required ng-minlength="8"
|
|
match="user.password">
|
|
</div>
|
|
<span class="exponent"><i class="fa fa-asterisk" aria-hidden="true"></i></span>
|
|
<span class="help-block" ng-show="signupForm.password_confirmation.$dirty && signupForm.password_confirmation.$error.required" translate>{{ 'app.public.common.password_confirmation_is_required' }}</span>
|
|
<span class="help-block" ng-show="signupForm.password_confirmation.$error.match" translate>{{ 'app.public.common.password_does_not_match_with_confirmation' }}</span>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<div class="col-sm-12 checkbox-group">
|
|
<input type="checkbox"
|
|
name="organization"
|
|
id="organization"
|
|
ng-model="user.organization"
|
|
value="false"/>
|
|
<label for="organization" translate>{{ 'app.public.common.i_am_an_organization' }}</label>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="form-group required-row" ng-show="user.organization" ng-class="{'has-error': signupForm.organization_name.$dirty && signupForm.organization_name.$invalid}">
|
|
<div class="col-sm-12">
|
|
<div class="input-group">
|
|
<span class="input-group-addon"><i class="fa fa-building-o"></i></span>
|
|
<input type="text"
|
|
name="organization_name"
|
|
ng-model="user.invoicing_profile_attributes.organization_attributes.name"
|
|
class="form-control"
|
|
placeholder="{{ 'app.public.common.name_of_your_organization' | translate }}"
|
|
ng-required="user.organization">
|
|
</div>
|
|
<span class="exponent help-cursor" title="{{ 'app.public.common.used_for_invoicing' | translate }}"><i class="fa fa-asterisk" aria-hidden="true"></i></span>
|
|
<span class="help-block" ng-show="signupForm.organization_name.$dirty && signupForm.organization_name.$error.required" translate>{{ 'app.public.common.organization_name_is_required' }}</span>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="form-group required-row" ng-show="user.organization" ng-class="{'has-error': signupForm.organization_address.$dirty && signupForm.organization_address.$invalid}">
|
|
<div class="col-sm-12">
|
|
<div class="input-group">
|
|
<span class="input-group-addon"><i class="fa fa-map-marker"></i></span>
|
|
<input type="text"
|
|
name="organization_address"
|
|
ng-model="user.invoicing_profile_attributes.organization_attributes.address_attributes.address"
|
|
class="form-control"
|
|
placeholder="{{ 'app.public.common.address_of_your_organization' | translate }}"
|
|
ng-required="user.organization">
|
|
</div>
|
|
<span class="exponent help-cursor" title="{{ 'app.public.common.used_for_invoicing' | translate }}"><i class="fa fa-asterisk" aria-hidden="true"></i></span>
|
|
<span class="help-block" ng-show="signupForm.organization_address.$dirty && signupForm.organization_address.$error.required" translate>{{ 'app.public.common.organization_address_is_required' }}</span>
|
|
</div>
|
|
</div>
|
|
|
|
<div ng-if="user.organization" ng-repeat="(i, profileCustomField) in profileCustomFields">
|
|
<div class="form-group required-row" ng-class="{'has-error': signupForm.user_profile_custom_fields{{i}}.$dirty && signupForm.user_profile_custom_fields{{i}}.$invalid}">
|
|
<div class="col-sm-12">
|
|
<div class="input-group">
|
|
<span class="input-group-addon"><i class="fa fa-building-o"></i></span>
|
|
<input type="text"
|
|
name="user_profile_custom_fields{{i}}"
|
|
ng-model="user.invoicing_profile_attributes.user_profile_custom_fields_attributes[i].value"
|
|
class="form-control"
|
|
placeholder="{{profileCustomField.label}}"
|
|
ng-required="profileCustomField.required">
|
|
</div>
|
|
<span ng-show="profileCustomField.required" class="exponent help-cursor" title="{{ 'app.public.common.used_for_invoicing' | translate }}"><i class="fa fa-asterisk" aria-hidden="true"></i></span>
|
|
<span class="help-block" ng-show="signupForm.user_profile_custom_fields{{i}}.$dirty && signupForm.user_profile_custom_fields{{i}}.$error.required" translate translate-values="{FEILD: profileCustomField.label}">{{ 'app.public.common.profile_custom_field_is_required' }}</span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="form-group required-row" ng-class="{'has-error': signupForm.group_id.$dirty && signupForm.group_id.$invalid}">
|
|
<div class="col-sm-12">
|
|
<div>
|
|
<select ng-model="user.group_id" class="form-control" name="group_id" ng-options="g.id as g.name for g in enabledGroups" required>
|
|
<option value="" translate>{{ 'app.public.common.your_user_s_profile' }}</option>
|
|
</select>
|
|
<span class="exponent exponent-select help-cursor" title="{{ 'app.public.common.used_for_invoicing' | translate }}"><i class="fa fa-asterisk" aria-hidden="true"></i></span>
|
|
</div>
|
|
<span class="help-block" ng-show="signupForm.group_id.$dirty && signupForm.group_id.$error.required" translate>{{ 'app.public.common.user_s_profile_is_required' }}</span>
|
|
</div>
|
|
</div>
|
|
<div class="alert alert-warning" ng-show="hasProofOfIdentityTypes(user.group_id)">
|
|
<p class="text-sm">
|
|
<i class="fa fa-warning"></i>
|
|
<span translate translate-values="{GROUP: groupName(user.group_id)}">{{ 'app.public.common.user_supporting_documents_required' }}</span>
|
|
</p>
|
|
</div>
|
|
|
|
<div class="form-group required-row" ng-class="{'has-error': signupForm.birthday.$dirty && signupForm.birthday.$invalid}">
|
|
<div class="col-sm-12">
|
|
<div class="input-group">
|
|
<span class="input-group-addon"><i class="fa fa-calendar-o"></i> </span>
|
|
<input type="text"
|
|
class="form-control"
|
|
name="birthday"
|
|
ng-model="user.statistic_profile_attributes.birthday"
|
|
uib-datepicker-popup="{{datePicker.format}}"
|
|
datepicker-options="datePicker.options"
|
|
is-open="datePicker.opened"
|
|
placeholder="{{ 'app.public.common.birth_date' | translate }}"
|
|
ng-click="openDatePicker($event)"
|
|
required/>
|
|
</div>
|
|
<span class="exponent help-cursor" title="{{ 'app.public.common.used_for_statistics' | translate }}"><i class="fa fa-asterisk" aria-hidden="true"></i></span>
|
|
<span class="help-block" ng-show="signupForm.birthday.$dirty && signupForm.birthday.$error.required" translate>{{ 'app.public.common.birth_date_is_required' }}</span>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="form-group required-row" ng-class="{'has-error': signupForm.phone.$dirty && signupForm.phone.$invalid}">
|
|
<div class="col-sm-12">
|
|
<div class="input-group">
|
|
<span class="input-group-addon"><i class="fa fa-phone"></i> </span>
|
|
<input ng-model="user.profile_attributes.phone"
|
|
type="text"
|
|
name="phone"
|
|
class="form-control"
|
|
placeholder="{{ 'app.public.common.phone_number' | translate }}"
|
|
ng-required="phoneRequired">
|
|
</div>
|
|
<span ng-show="phoneRequired" class="exponent help-cursor" title="{{ 'app.public.common.used_for_reservation' | translate }}">
|
|
<i class="fa fa-asterisk" aria-hidden="true"></i>
|
|
</span>
|
|
<span class="help-block" ng-show="signupForm.phone.$dirty && signupForm.phone.$error.required" translate>{{ 'app.public.common.phone_number_is_required' }}</span>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="form-group required-row">
|
|
<div class="col-sm-12">
|
|
<div class="input-group">
|
|
<span class="input-group-addon"><i class="fa fa-map-marker"></i> </span>
|
|
<input type="text"
|
|
name="address"
|
|
ng-model="user.invoicing_profile_attributes.address_attributes.address"
|
|
class="form-control"
|
|
placeholder="{{ 'app.public.common.address' | translate }}"
|
|
ng-required="addressRequired"/>
|
|
</div>
|
|
<span ng-show="addressRequired" class="exponent help-cursor" title="{{ 'app.public.common.used_for_invoicing' | translate }}">
|
|
<i class="fa fa-asterisk" aria-hidden="true"></i>
|
|
</span>
|
|
<span class="help-block" ng-show="signupForm.address.$dirty && signupForm.address.$error.required" translate>{{ 'app.public.common.address_is_required' }}</span>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="form-group" ng-class="{'has-error': signupForm.is_allow_contact.$dirty && signupForm.is_allow_contact.$invalid}">
|
|
<div class="col-sm-12 checkbox-group">
|
|
<input type="checkbox"
|
|
name="is_allow_contact"
|
|
id="is_allow_contact"
|
|
ng-model="user.is_allow_contact"
|
|
value="true"/>
|
|
<label for="is_allow_contact" class="help-cursor" title="{{ 'app.public.common.public_profile' | translate }}" translate>{{ 'app.public.common.i_authorize_Fablab_users_registered_on_the_site_to_contact_me' }}</label>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="form-group" ng-class="{'has-error': signupForm.is_allow_newsletter.$dirty && signupForm.is_allow_newsletter.$invalid}">
|
|
<div class="col-sm-12 checkbox-group">
|
|
<input type="checkbox"
|
|
name="is_allow_newsletter"
|
|
id="is_allow_newsletter"
|
|
ng-model="user.is_allow_newsletter"
|
|
value="true"/>
|
|
<label for="is_allow_newsletter" translate>{{ 'app.public.common.i_accept_to_receive_information_from_the_fablab' }}</label>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="form-group" ng-class="{'has-error': signupForm.cgu.$dirty && signupForm.cgu.$invalid}" ng-show="cgu">
|
|
<div class="col-sm-12 checkbox-group">
|
|
<input type="checkbox"
|
|
name="cgu"
|
|
id="cgu"
|
|
ng-model="user.cgu"
|
|
value="true"
|
|
ng-required="cgu != null"/>
|
|
<label for="cgu">
|
|
<span translate>{{ 'app.public.common.i_ve_read_and_i_accept_' }}</span>
|
|
<a href="{{cgu.custom_asset_file_attributes.attachment_url}}" target="_blank" translate>{{ 'app.public.common._the_fablab_policy' }}</a>
|
|
<span class="exponent"><i class="fa fa-asterisk" aria-hidden="true"></i></span></label>
|
|
</div>
|
|
</div>
|
|
<div vc-recaptcha
|
|
key="recaptchaSiteKey"
|
|
class="flex-center"
|
|
ng-model="user.recaptcha"
|
|
ng-if="recaptchaSiteKey">
|
|
</div>
|
|
<span class="info-required">
|
|
<span class="exponent"><i class="fa fa-asterisk" aria-hidden="true"></i></span>
|
|
<span translate>{{ 'app.public.common.field_required' }}</span>
|
|
</span>
|
|
<div ng-if="!cgu">
|
|
<input type="hidden" name="cgu" ng-model="user.cgu" value="true">
|
|
</div>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
<div class="modal-footer no-padder">
|
|
<button class="btn btn-valid btn-warning btn-block p-l btn-lg text-u-c r-b" ng-click="ok()" ng-disabled="signupForm.$invalid" translate>{{ 'app.shared.buttons.confirm' }}</button>
|
|
</div>
|