mirror of
https://github.com/alchemy-fr/Phraseanet.git
synced 2025-10-23 18:03:17 +00:00
add personalisation logo
This commit is contained in:
@@ -14,6 +14,7 @@ use Alchemy\Phrasea\Application;
|
|||||||
use Alchemy\Phrasea\Controller\Controller;
|
use Alchemy\Phrasea\Controller\Controller;
|
||||||
use Alchemy\Phrasea\Core\Configuration\PropertyAccess;
|
use Alchemy\Phrasea\Core\Configuration\PropertyAccess;
|
||||||
use Alchemy\Phrasea\Core\Configuration\RegistryFormManipulator;
|
use Alchemy\Phrasea\Core\Configuration\RegistryFormManipulator;
|
||||||
|
use Symfony\Component\HttpFoundation\JsonResponse;
|
||||||
use Symfony\Component\HttpFoundation\Request;
|
use Symfony\Component\HttpFoundation\Request;
|
||||||
|
|
||||||
class SetupController extends Controller
|
class SetupController extends Controller
|
||||||
@@ -61,4 +62,15 @@ class SetupController extends Controller
|
|||||||
'form' => $form->createView(),
|
'form' => $form->createView(),
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function sendPersonaliseLogo(Request $request)
|
||||||
|
{
|
||||||
|
if(null !== $blob = $request->request->get('fileToUpload')){
|
||||||
|
$result = $this->app->getApplicationBox()->write_application_logo($this->app['filesystem'], $blob);
|
||||||
|
|
||||||
|
return new JsonResponse($result);
|
||||||
|
}
|
||||||
|
|
||||||
|
return new JsonResponse('No file send');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -47,6 +47,9 @@ class Setup implements ControllerProviderInterface, ServiceProviderInterface
|
|||||||
->bind('setup_display_globals')
|
->bind('setup_display_globals')
|
||||||
->method('GET|POST');
|
->method('GET|POST');
|
||||||
|
|
||||||
|
$controllers->post('/send-logo', 'controller.admin.setup:sendPersonaliseLogo')
|
||||||
|
->bind('setup_send_personalize_logo');
|
||||||
|
|
||||||
return $controllers;
|
return $controllers;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -56,7 +56,7 @@ class GeneralFormType extends AbstractType
|
|||||||
'attr' => ['min' => -1],
|
'attr' => ['min' => -1],
|
||||||
'constraints' => new GreaterThanOrEqual(['value' => -1]),
|
'constraints' => new GreaterThanOrEqual(['value' => -1]),
|
||||||
]);
|
]);
|
||||||
$builder->add('personalize-logo-choice', new PersonalisationLogoForm(), [
|
$builder->add('personalize-logo-choice', new PersonalisationLogoFormType(), [
|
||||||
'label' => 'Design of personalization logo section',
|
'label' => 'Design of personalization logo section',
|
||||||
'attr' => [
|
'attr' => [
|
||||||
'id' => 'personalize-logo-container'
|
'id' => 'personalize-logo-container'
|
||||||
|
@@ -13,28 +13,29 @@ namespace Alchemy\Phrasea\Form\Configuration;
|
|||||||
use Symfony\Component\Form\AbstractType;
|
use Symfony\Component\Form\AbstractType;
|
||||||
use Symfony\Component\Form\FormBuilderInterface;
|
use Symfony\Component\Form\FormBuilderInterface;
|
||||||
|
|
||||||
class PersonalisationLogoForm extends AbstractType
|
class PersonalisationLogoFormType extends AbstractType
|
||||||
{
|
{
|
||||||
public function buildForm(FormBuilderInterface $builder, array $options)
|
public function buildForm(FormBuilderInterface $builder, array $options)
|
||||||
{
|
{
|
||||||
$builder->add('originalChoiceInput', 'choice', [
|
$builder->add('logoChoice', 'choice', [
|
||||||
'label' => false,
|
'label' => false,
|
||||||
'choices' => ['original' => 'original-choice-label'],
|
'choices' => [
|
||||||
|
'original' => 'original logo',
|
||||||
|
'personalize' => 'personalize logo'
|
||||||
|
],
|
||||||
'expanded' => true,
|
'expanded' => true,
|
||||||
|
'multiple' => false,
|
||||||
|
|
||||||
]);
|
]);
|
||||||
$builder->add('personaliseChoiceInput', 'choice', [
|
|
||||||
'label' => false,
|
|
||||||
'choices' => ['personalise' => 'personalise-choice-label'],
|
|
||||||
'expanded' => true,
|
|
||||||
|
|
||||||
]);
|
|
||||||
$builder->add('personalizeLogoInput', 'file', [
|
$builder->add('personalizeLogoInput', 'file', [
|
||||||
'label' => false,
|
'label' => false,
|
||||||
]);
|
]);
|
||||||
$builder->add('logoChoice', 'hidden', [
|
|
||||||
|
$builder->add('personalizeFile', 'hidden', [
|
||||||
'label' => false,
|
'label' => false,
|
||||||
]);
|
]);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getName()
|
public function getName()
|
@@ -95,6 +95,23 @@ class appbox extends base
|
|||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function write_application_logo(Filesystem $filesystem, $blob)
|
||||||
|
{
|
||||||
|
$logo_path = $this->app['root.path'] . '/www/custom/minilogos/personalize_logo.png';
|
||||||
|
|
||||||
|
$data = str_replace('data:image/png;base64,', '', $blob);
|
||||||
|
$data = str_replace(' ', '+', $data);
|
||||||
|
$data = base64_decode($data);
|
||||||
|
|
||||||
|
try{
|
||||||
|
$filesystem->dumpFile($logo_path, $data);
|
||||||
|
}catch(\Exception $e){
|
||||||
|
return $e->getMessage();
|
||||||
|
}
|
||||||
|
|
||||||
|
return 'success';
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @param collection $collection
|
* @param collection $collection
|
||||||
|
@@ -1,7 +1,8 @@
|
|||||||
<table cellspacing="0">
|
<table cellspacing="0">
|
||||||
<tr class="personalise-logo-row-container">
|
<tr class="personalise-logo-row-container">
|
||||||
<td>
|
<td>
|
||||||
{{ form_widget(form.originalChoiceInput, { 'attr': {'class': 'choice-radio'} }) }}
|
{{ form_widget(form.logoChoice[0]) }}
|
||||||
|
{{ form_label(form.logoChoice[0]) }}
|
||||||
<div class="image-container">
|
<div class="image-container">
|
||||||
<img id="original-image-placeholder" alt="gabari"
|
<img id="original-image-placeholder" alt="gabari"
|
||||||
src=""/>
|
src=""/>
|
||||||
@@ -9,11 +10,15 @@
|
|||||||
<a id="download-image-template" href="#">{{ 'prod::setup: download gabari' | trans }}</a>
|
<a id="download-image-template" href="#">{{ 'prod::setup: download gabari' | trans }}</a>
|
||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
{{ form_widget(form.personaliseChoiceInput) }}
|
{{ form_widget(form.logoChoice[1]) }}
|
||||||
|
{{ form_label(form.logoChoice[1]) }}
|
||||||
|
<br>
|
||||||
<span id="help-text">{{ 'prod::setup: help text' | trans }}</span>
|
<span id="help-text">{{ 'prod::setup: help text' | trans }}</span>
|
||||||
<span id="error-text"></span>
|
<span id="error-text"></span>
|
||||||
<div class="image-container" id="personalize-image-container">
|
<div class="image-container" id="personalize-image-container">
|
||||||
<img id="personalise-image-placeholder"/>
|
{% if app['conf'].get(['registry', 'general', 'personalize-logo-choice', 'personalizeFile']) == 'true' %}
|
||||||
|
<img id="personalise-image-placeholder" src="/custom/minilogos/personalize_logo.png"/>
|
||||||
|
{% endif %}
|
||||||
</div>
|
</div>
|
||||||
<div>
|
<div>
|
||||||
{{ form_widget(form.personalizeLogoInput) }}
|
{{ form_widget(form.personalizeLogoInput) }}
|
||||||
@@ -21,8 +26,8 @@
|
|||||||
id="select-logo-btn">{{ 'prod::setup: select file' | trans }}</label>
|
id="select-logo-btn">{{ 'prod::setup: select file' | trans }}</label>
|
||||||
</div>
|
</div>
|
||||||
</td>
|
</td>
|
||||||
|
{{ form_widget(form.personalizeFile) }}
|
||||||
</tr>
|
</tr>
|
||||||
{{ form_widget(form.logoChoice) }}
|
|
||||||
</table>
|
</table>
|
||||||
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
@@ -31,18 +36,17 @@
|
|||||||
|
|
||||||
var errorDimension = '{{ 'prod::setup: error text dimension' | trans }}';
|
var errorDimension = '{{ 'prod::setup: error text dimension' | trans }}';
|
||||||
var errorFileType = '{{ 'prod::setup: error text file type' | 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();
|
$('#help-text').show();
|
||||||
$('#personalize-image-container').hide();
|
|
||||||
$('#error-text').hide();
|
|
||||||
|
|
||||||
$('input[type=radio]').on('change', function () {
|
// show personalize logo if exist
|
||||||
$('#general_personalize-logo-choice_logoChoice').val($(this).val());
|
{% if app['conf'].get(['registry', 'general', 'personalize-logo-choice', 'personalizeFile']) == 'true' %}
|
||||||
$(this).closest('td').siblings().find('input').prop('checked', false);
|
$('#personalize-image-container').show();
|
||||||
});
|
{% else %}
|
||||||
|
$('#personalize-image-container').hide();
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
$('#error-text').hide();
|
||||||
|
|
||||||
$("#download-image-template").on('click', function (event) {
|
$("#download-image-template").on('click', function (event) {
|
||||||
event.preventDefault();
|
event.preventDefault();
|
||||||
@@ -78,6 +82,7 @@
|
|||||||
reader.onload = function (_file) {
|
reader.onload = function (_file) {
|
||||||
var image = new Image();
|
var image = new Image();
|
||||||
|
|
||||||
|
fileToUpload = _file.target.result;
|
||||||
image.src = _file.target.result;
|
image.src = _file.target.result;
|
||||||
image.file = this.file;
|
image.file = this.file;
|
||||||
image.data = this.data;
|
image.data = this.data;
|
||||||
@@ -120,7 +125,26 @@
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
fileToUpload = this.data;
|
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);
|
||||||
|
}else{
|
||||||
|
$('#general_personalize-logo-choice_personalizeFile').val(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log(data);
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -134,14 +158,6 @@
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
$("#submitSetupForm").bind('click', function () {
|
|
||||||
if (fileToUpload != null) {
|
|
||||||
fileToUpload.submit();
|
|
||||||
} else {
|
|
||||||
$("#setupForm").submit();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
|
|
||||||
</script>
|
</script>
|
||||||
|
@@ -4,7 +4,16 @@
|
|||||||
<ol>
|
<ol>
|
||||||
<li>
|
<li>
|
||||||
<span class="title">
|
<span class="title">
|
||||||
|
{% if app['conf'].get(['registry', 'general', 'personalize-logo-choice', 'logoChoice']) == 'personalize' and
|
||||||
|
app['conf'].get(['registry', 'general', 'personalize-logo-choice', 'personalizeFile']) == 'true' %}
|
||||||
|
|
||||||
|
<img src="/custom/minilogos/personalize_logo.png" alt="" id="mainLogo">
|
||||||
|
|
||||||
|
{% else %}
|
||||||
|
|
||||||
<img src="/assets/common/images/logo.png" alt="" id="mainLogo">
|
<img src="/assets/common/images/logo.png" alt="" id="mainLogo">
|
||||||
|
|
||||||
|
{% endif %}
|
||||||
</span>
|
</span>
|
||||||
</li>
|
</li>
|
||||||
<li class="show-menu" id="toggle-menu-main">
|
<li class="show-menu" id="toggle-menu-main">
|
||||||
|
Reference in New Issue
Block a user