mirror of
https://github.com/alchemy-fr/Phraseanet.git
synced 2025-10-23 18:03:17 +00:00
174 lines
9.9 KiB
Twig
174 lines
9.9 KiB
Twig
<table cellspacing="0">
|
|
<tr class="personalise-logo-row-container">
|
|
<td>
|
|
{{ form_widget(form.logoChoice[0]) }}
|
|
{{ form_label(form.logoChoice[0]) }}
|
|
<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.logoChoice[1]) }}
|
|
{{ form_label(form.logoChoice[1]) }}
|
|
<br>
|
|
<span id="help-text">{{ 'prod::setup: help text' | trans }}</span>
|
|
<span id="error-text"></span>
|
|
<div class="image-container" id="personalize-image-container">
|
|
{% if app['conf'].get(['registry', 'general', 'personalize-logo-choice', 'personalizeFile']) == 'true' %}
|
|
{% set extension = app['conf'].get(['registry', 'general', 'personalize-logo-choice', 'fileType']) %}
|
|
{% set personalise_path = '/custom/minilogos/personalize_logo.' ~ extension %}
|
|
|
|
<img id="personalise-image-placeholder" src="{{ personalise_path }}"/>
|
|
{% endif %}
|
|
</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>
|
|
{{ form_widget(form.personalizeFile) }}
|
|
{{ form_widget(form.fileType) }}
|
|
</tr>
|
|
</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 }}';
|
|
|
|
$('#help-text').show();
|
|
|
|
// show personalize logo if exist
|
|
{% if app['conf'].get(['registry', 'general', 'personalize-logo-choice', 'personalizeFile']) == 'true' %}
|
|
$('#personalize-image-container').show();
|
|
{% else %}
|
|
$('#personalize-image-container').hide();
|
|
{% endif %}
|
|
|
|
$('#error-text').hide();
|
|
|
|
$("#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;
|
|
};
|
|
|
|
$("#setupForm").fileupload({
|
|
dataType: 'html',
|
|
add: function (e, data) {
|
|
$.each(data.files, function (i, file) {
|
|
var reader = new FileReader();
|
|
|
|
reader.readAsDataURL(data.files[0]);
|
|
reader.data = data;
|
|
reader.file = data.files[0];
|
|
|
|
reader.onload = function (_file) {
|
|
var image = new Image();
|
|
|
|
fileToUpload = _file.target.result;
|
|
image.src = _file.target.result;
|
|
image.file = this.file;
|
|
image.data = this.data;
|
|
image.onload = function () {
|
|
var w = this.width,
|
|
h = this.height;
|
|
|
|
var ext = this.file.type.split('/').pop().toLowerCase();
|
|
if (ext != 'png' && ext != 'svg+xml') {
|
|
$('#general_personalize-logo-choice_personalizeLogoInput').val("");
|
|
$('#error-text').text(errorFileType);
|
|
$('#error-text').show();
|
|
$('#help-text').hide();
|
|
$('#personalize-image-container').hide();
|
|
return false;
|
|
}
|
|
|
|
if (h > 41 || w > 120 ) {
|
|
$('#error-text').text(errorDimension);
|
|
$('#error-text').show();
|
|
$('#help-text').hide();
|
|
$('#personalize-image-container').hide();
|
|
$('#general_personalize-logo-choice_personalizeLogoInput').val("");
|
|
return false;
|
|
}
|
|
|
|
require([
|
|
"blueimp.loadimage"
|
|
], function (loadImage) {
|
|
loadImage(file, function (img) {
|
|
$('#personalize-image-container').show();
|
|
$('#error-text').hide();
|
|
$('#help-text').hide();
|
|
$('#personalize-image-container').empty().append(img);
|
|
}, {
|
|
maxSize: 5242880, // 5MB
|
|
maxWidth: 120,
|
|
maxHeight: 41,
|
|
});
|
|
});
|
|
|
|
var fd = new FormData();
|
|
fd.append("fileToUpload", fileToUpload);
|
|
$.ajax({
|
|
type: 'POST',
|
|
url: '{{ path('setup_send_personalize_logo') }}',
|
|
data: fd,
|
|
processData: false,
|
|
contentType: false,
|
|
async: false,
|
|
success: function (data) {
|
|
if(data === 'success'){
|
|
$('#general_personalize-logo-choice_personalizeFile').val(true);
|
|
if(ext==='svg+xml'){
|
|
ext = 'svg';
|
|
}
|
|
$('#general_personalize-logo-choice_fileType').val(ext);
|
|
}else{
|
|
$('#general_personalize-logo-choice_personalizeFile').val(false);
|
|
}
|
|
|
|
console.log(data);
|
|
}
|
|
|
|
});
|
|
}
|
|
}
|
|
|
|
});
|
|
|
|
return false;
|
|
},
|
|
submit: function (e, data) {
|
|
},
|
|
done: function (e, data) {
|
|
}
|
|
});
|
|
|
|
});
|
|
|
|
</script>
|
|
|
|
|
|
|