mirror of
https://github.com/alchemy-fr/Phraseanet.git
synced 2025-10-23 09:53:15 +00:00
Merge pull request #2626 from mike-esokia/PHRAS-2079_design_personalisation_logo
PHRAS-2079 design personalisation logo
This commit is contained in:
124
templates/web/admin/personalisation_logo.html.twig
Normal file
124
templates/web/admin/personalisation_logo.html.twig
Normal file
@@ -0,0 +1,124 @@
|
||||
<table cellspacing="0">
|
||||
<tr class="personalise-logo-row-container">
|
||||
<td>
|
||||
{{ form_widget(form.originalChoiceInput, { 'attr': {'class': 'choice-radio'} }) }}
|
||||
<div class="image-container">
|
||||
<img id="original-image-placeholder" alt="gabari"
|
||||
src=""/>
|
||||
</div>
|
||||
<a id="download-image-template" href="#">{{ 'prod::setup: download gabari' | trans }}</a>
|
||||
</td>
|
||||
<td>
|
||||
{{ form_widget(form.personaliseChoiceInput) }}
|
||||
<span id="help-text">{{ 'prod::setup: help text' | trans }}</span>
|
||||
<span id="error-text"></span>
|
||||
<div class="image-container" id="personalize-image-container">
|
||||
<img id="personalise-image-placeholder"/>
|
||||
</div>
|
||||
<div>
|
||||
{{ form_widget(form.personalizeLogoInput) }}
|
||||
<label for="general_personalize-logo-choice_personalizeLogoInput"
|
||||
id="select-logo-btn">{{ 'prod::setup: select file' | trans }}</label>
|
||||
</div>
|
||||
</td>
|
||||
</tr>
|
||||
{{ form_widget(form.logoChoice) }}
|
||||
</table>
|
||||
|
||||
<script type="text/javascript">
|
||||
$(document).ready(function () {
|
||||
var fileToUpload = null;
|
||||
|
||||
var errorDimension = '{{ 'prod::setup: error text dimension' | trans }}';
|
||||
var errorFileType = '{{ 'prod::setup: error text file type' | trans }}';
|
||||
//by default select original logo
|
||||
$('#general_personalize-logo-choice_originalChoiceInput_0').attr('checked', true);
|
||||
$('#general_personalize-logo-choice_logoChoice').val('original');
|
||||
|
||||
$('#help-text').show();
|
||||
$('#personalize-image-container').hide();
|
||||
$('#error-text').hide();
|
||||
|
||||
$('input[type=radio]').on('change', function () {
|
||||
$('#general_personalize-logo-choice_logoChoice').val($(this).val());
|
||||
$(this).closest('td').siblings().find('input').prop('checked', false);
|
||||
});
|
||||
|
||||
$("#general_personalize-logo-choice_personalizeLogoInput").change(function () {
|
||||
readURL(this);
|
||||
});
|
||||
|
||||
$("#download-image-template").on('click', function (event) {
|
||||
event.preventDefault();
|
||||
var imageInBase64 = $('#original-image-placeholder').attr('src');
|
||||
var mimeInfo = base64MimeType(imageInBase64);
|
||||
var ext = mimeInfo.split('/').pop();
|
||||
var filename = $('#original-image-placeholder').attr('alt') + "." + ext;
|
||||
download(imageInBase64, filename, mimeInfo);
|
||||
});
|
||||
|
||||
var base64MimeType = function base64MimeType(encoded) {
|
||||
var result = null;
|
||||
if (typeof encoded !== 'string') {
|
||||
return result;
|
||||
}
|
||||
var mime = encoded.match(/data:([a-zA-Z0-9]+\/[a-zA-Z0-9-.+]+).*,.*/);
|
||||
if (mime && mime.length) {
|
||||
result = mime[1];
|
||||
}
|
||||
return result;
|
||||
};
|
||||
|
||||
function readURL(input) {
|
||||
if (input.files && input.files[0]) {
|
||||
var reader = new FileReader();
|
||||
|
||||
reader.onload = function (e) {
|
||||
var image = new Image();
|
||||
image.src = e.target.result;
|
||||
|
||||
//Validate the File Height and Width.
|
||||
image.onload = function () {
|
||||
var height = this.height;
|
||||
var width = this.width;
|
||||
|
||||
//check file extension
|
||||
var ext = $('#general_personalize-logo-choice_personalizeLogoInput').val().split('.').pop().toLowerCase();
|
||||
if (ext != 'png') {
|
||||
$('#general_personalize-logo-choice_personalizeLogoInput').val("");
|
||||
$('#error-text').text(errorFileType);
|
||||
$('#error-text').show();
|
||||
$('#help-text').hide();
|
||||
$('#personalize-image-container').hide();
|
||||
return false;
|
||||
}
|
||||
|
||||
//check dimensions
|
||||
if (height > 42 || width > 52) {
|
||||
$('#error-text').text(errorDimension);
|
||||
$('#error-text').show();
|
||||
$('#help-text').hide();
|
||||
$('#personalize-image-container').hide();
|
||||
$('#general_personalize-logo-choice_personalizeLogoInput').val("");
|
||||
return false;
|
||||
}
|
||||
|
||||
fileToUpload = input.files[0];
|
||||
$('#personalize-image-container').show();
|
||||
$('#error-text').hide();
|
||||
$('#help-text').hide();
|
||||
$('#personalise-image-placeholder').attr('src', e.target.result);
|
||||
return true;
|
||||
};
|
||||
}
|
||||
|
||||
reader.readAsDataURL(input.files[0]);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
});
|
||||
|
||||
</script>
|
||||
|
||||
|
@@ -30,24 +30,37 @@
|
||||
</form>
|
||||
|
||||
|
||||
|
||||
{{ form_start(form, {'method': 'POST', 'action' : path('setup_display_globals'), 'attr': {'class' : 'form-horizontal'}}) }}
|
||||
{{ form_start(form, {'method': 'POST', 'action' : path('setup_display_globals'), 'attr': {'class' : 'form-horizontal', 'id': 'setupForm'}}) }}
|
||||
{{ form_errors(form) }}
|
||||
{% for daform in form %}
|
||||
{% if daform.vars['label'] != null %}
|
||||
<fieldset>
|
||||
<legend>{{ daform.vars['label'] }}</legend>
|
||||
{% for formdata in daform %}
|
||||
<div class="control-group">
|
||||
{{ form_errors(formdata) }}
|
||||
{{ form_label(formdata, null, { 'label_attr': {'class' : 'control-label'} } ) }}
|
||||
<div class="controls">
|
||||
{{ form_widget(formdata, {'attr': {'class': 'input-xxlarge'}}) }}
|
||||
</div>
|
||||
{% if formdata.vars['attr'] is defined and formdata.vars['attr']['id'] is defined
|
||||
and formdata.vars['attr']['id'] == 'personalize-logo-container' %}
|
||||
<div class="control-group">
|
||||
{{ form_errors(formdata) }}
|
||||
{{ form_label(formdata, null, { 'label_attr': {'class' : 'control-label'} } ) }}
|
||||
<div class="controls">
|
||||
{% include 'admin/personalisation_logo.html.twig' with {'form': formdata} %}
|
||||
</div>
|
||||
|
||||
<div>{{ formdata.vars['help_message'] }}</div>
|
||||
{{ form_rest(formdata) }}
|
||||
</div>
|
||||
<div>{{ formdata.vars['help_message'] }}</div>
|
||||
{{ form_rest(formdata) }}
|
||||
</div>
|
||||
{% else %}
|
||||
<div class="control-group">
|
||||
{{ form_errors(formdata) }}
|
||||
{{ form_label(formdata, null, { 'label_attr': {'class' : 'control-label'} } ) }}
|
||||
<div class="controls">
|
||||
{{ form_widget(formdata, {'attr': {'class': 'input-xxlarge'}}) }}
|
||||
</div>
|
||||
|
||||
<div>{{ formdata.vars['help_message'] }}</div>
|
||||
{{ form_rest(formdata) }}
|
||||
</div>
|
||||
{% endif %}
|
||||
{% endfor %}
|
||||
{{ form_rest(daform) }}
|
||||
</fieldset>
|
||||
@@ -66,7 +79,8 @@
|
||||
<div style="clear: both;"></div>
|
||||
<div class="well well-large">
|
||||
<div style="max-width: 400px;margin: 0 auto 10px;">
|
||||
<input type="submit" class="btn btn-primary btn-block btn-large" value="{{ 'boutton::valider' | trans }}"/>
|
||||
<input type="submit" id="submitSetupForm" class="btn btn-primary btn-block btn-large"
|
||||
value="{{ 'boutton::valider' | trans }}"/>
|
||||
</div>
|
||||
</div>
|
||||
{{ form_end(form) }}
|
||||
|
Reference in New Issue
Block a user