From c3486f9b8e88391c05d4aa0e2fd075de1ebbb520 Mon Sep 17 00:00:00 2001 From: aina-esokia Date: Fri, 31 Aug 2018 16:10:19 +0400 Subject: [PATCH] allow svg logo and change gabari --- .../PersonalisationLogoFormType.php | 4 ++++ lib/classes/appbox.php | 12 +++++++---- resources/www/_shared/styles/_main-menu.scss | 4 +--- resources/www/admin/styles/main.scss | 4 ++-- .../web/admin/personalisation_logo.html.twig | 21 ++++++++++++------- templates/web/common/menubar.html.twig | 4 +++- 6 files changed, 32 insertions(+), 17 deletions(-) diff --git a/lib/Alchemy/Phrasea/Form/Configuration/PersonalisationLogoFormType.php b/lib/Alchemy/Phrasea/Form/Configuration/PersonalisationLogoFormType.php index eea4f6e99d..f6b635461e 100644 --- a/lib/Alchemy/Phrasea/Form/Configuration/PersonalisationLogoFormType.php +++ b/lib/Alchemy/Phrasea/Form/Configuration/PersonalisationLogoFormType.php @@ -36,6 +36,10 @@ class PersonalisationLogoFormType extends AbstractType 'label' => false, ]); + $builder->add('fileType', 'hidden', [ + 'label' => false, + ]); + } public function getName() diff --git a/lib/classes/appbox.php b/lib/classes/appbox.php index e6f9307965..c75b5cb40e 100644 --- a/lib/classes/appbox.php +++ b/lib/classes/appbox.php @@ -97,14 +97,18 @@ class appbox extends base public function write_application_logo(Filesystem $filesystem, $blob) { - $logo_path = $this->app['root.path'] . '/www/custom/minilogos/personalize_logo.png'; + $logo_path = $this->app['root.path'] . '/www/custom/minilogos/personalize_logo.'; - $data = str_replace('data:image/png;base64,', '', $blob); - $data = str_replace(' ', '+', $data); + list($type, $imageData) = explode(';', $blob); + list(,$extension) = explode('/',$type); + list(,$imageData) = explode(',', $imageData); + + $data = str_replace(' ', '+', $imageData); $data = base64_decode($data); + $extension= ($extension=='svg+xml')?'svg':$extension; try{ - $filesystem->dumpFile($logo_path, $data); + $filesystem->dumpFile($logo_path.$extension, $data); }catch(\Exception $e){ return $e->getMessage(); } diff --git a/resources/www/_shared/styles/_main-menu.scss b/resources/www/_shared/styles/_main-menu.scss index 0466439f69..355d50f806 100644 --- a/resources/www/_shared/styles/_main-menu.scss +++ b/resources/www/_shared/styles/_main-menu.scss @@ -61,9 +61,7 @@ $mainMenuBottomBorder: none !default; display: inline-block; } #mainLogo { - margin:0 10px; - margin-top: 3px; - + margin:0 5px; } li { display: inline-block; diff --git a/resources/www/admin/styles/main.scss b/resources/www/admin/styles/main.scss index eb2052db1e..fd65698099 100644 --- a/resources/www/admin/styles/main.scss +++ b/resources/www/admin/styles/main.scss @@ -783,8 +783,8 @@ span.simplecolorpicker.picker { margin-left: 10px; } .image-container { - height: 42px; - width: 52px; + height: 41px; + width: 120px; border: 1px solid #979797; display: block; } diff --git a/templates/web/admin/personalisation_logo.html.twig b/templates/web/admin/personalisation_logo.html.twig index a7424d5e6c..a68853f969 100644 --- a/templates/web/admin/personalisation_logo.html.twig +++ b/templates/web/admin/personalisation_logo.html.twig @@ -5,7 +5,7 @@ {{ form_label(form.logoChoice[0]) }}
gabari + src=""/>
{{ 'prod::setup: download gabari' | trans }} @@ -17,7 +17,10 @@
{% 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 %} + + {% endif %}
@@ -27,6 +30,7 @@
{{ form_widget(form.personalizeFile) }} + {{ form_widget(form.fileType) }} @@ -91,7 +95,7 @@ h = this.height; var ext = this.file.type.split('/').pop().toLowerCase(); - if (ext != 'png') { + if (ext != 'png' && ext != 'svg+xml') { $('#general_personalize-logo-choice_personalizeLogoInput').val(""); $('#error-text').text(errorFileType); $('#error-text').show(); @@ -100,7 +104,7 @@ return false; } - if (h > 42 ) { + if (h > 41 || w > 120 ) { $('#error-text').text(errorDimension); $('#error-text').show(); $('#help-text').hide(); @@ -118,10 +122,9 @@ $('#help-text').hide(); $('#personalize-image-container').empty().append(img); }, { - fileType: /^image\/(png)$/, maxSize: 5242880, // 5MB - maxWidth: 52, - maxHeight: 42, + maxWidth: 120, + maxHeight: 41, }); }); @@ -137,6 +140,10 @@ 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); } diff --git a/templates/web/common/menubar.html.twig b/templates/web/common/menubar.html.twig index 008cfbae04..3b2d346cfa 100644 --- a/templates/web/common/menubar.html.twig +++ b/templates/web/common/menubar.html.twig @@ -6,8 +6,10 @@ {% if app['conf'].get(['registry', 'general', 'personalize-logo-choice', 'logoChoice']) == 'personalize' and 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 %} - + {% else %}