SVG Support

Description

Téléversez en toute sécurité des fichiers SVG dans votre médiathèque et utilisez-les comme n’importe quelle autre image. Désormais, le nettoyage est facultatif !

Mais SVG Support a plus de fonctionnalités ! Lisez la suite pour en savoir plus.

Lorsque vous utilisez des images SVG sur votre site WordPress, il peut être difficile de styliser les éléments à l’intérieur du SVG à l’aide de CSS. Maintenant vous pouvez le faire, facilement !

Les SVG (Scalable Vector Graphics) sont de plus en plus courants dans la conception des sites web modernes. Ils permettent d’embarquer des images de petite taille qui peuvent être adaptées à n’importe quelle taille visuelle sans perte de qualité.

Cette extension ne fournit pas seulement un support SVG comme son nom l’indique, elle vous permet également d’embarquer facilement le code complet de votre fichier SVG à l’aide d’une simple balise IMG.

En ajoutant la classe "style-svg" à vos éléments IMG (ou conteneurs extérieurs), cette extension remplace dynamiquement tous les éléments IMG contenant un SVG dans le src qui se trouvent dans la classe cible par votre code SVG complet, avec un rendu en ligne.

L’objectif principal est de permettre le stylisme et l’animation de vos éléments SVG. Habituellement, les options de style sont limitées lorsque l’on utilise les balises embed, object ou img seule.

Fonctionnalités

  • Support SVG pour votre médiathèque
  • Nettoyage des SVG téléversés
  • Minifier les fichiers SVG
  • Intégrer votre code SVG en ligne
  • Styliser des éléments SVG directement avec du CSS
  • Animez des éléments SVG à l’aide de CSS et JS
  • Page de réglages super facile avec instructions
  • Restreindre la possibilité de téléverser des SVG aux seuls administrateurs/administratrices
  • Définir une classe cible personnalisée (utilisable sur les éléments extérieurs à partir de la version 2.4)
  • Extrêmement simple à utiliser – Simplifie l’utilisation complexe des fichiers SVG

Usage

Tout d’abord, installez et activez SVG Support (cette extension).

Une fois activée, vous pouvez simplement téléverser des images SVG dans votre médiathèque comme n’importe quel autre fichier.

En tant qu’administrateur/administratrice, vous pouvez accéder à la page des réglages administratifs « Réglages > SVG Support » et restreindre les téléversés de fichiers SVG aux seuls administrateurs/administratrices.

Si vous avez seulement besoin de téléverser des fichiers SVG à utiliser en tant qu’images, vous n’avez pas besoin d’activer le « Mode Avancé ». Le laisser désactivé garantit que le script de agissant sur la partie publique du site ne soit pas chargé et que les réglages inutiles restent cachés.

Pour les utilisateurs avancés : Activez le « Mode avancé » dans Réglages > SVG Support.

Vous pouvez maintenant activer le nettoyage et/ou la minification de vos téléversés SVG, définir une classe CSS personnalisée à cibler et modifier d’autres réglages.

Avec le mode avancé activé, vous pouvez intégrer vos images SVG comme si vous aviez une image standard en ajoutant (en mode texte) la classe style-svg (ou la classe personnalisée que vous avez définie) aux balises IMG que vous souhaitez que l’extension remplace par votre vrai code SVG.

Par exemple :

<img class="style-svg" alt="alt-text" src="image-source.svg" />

ou

<img class="your-custom-class" alt="alt-text" src="image-source.svg" />

L’ensemble de la balise IMG sera désormais remplacé dynamiquement par le code réel de votre SVG, ce qui permettra de cibler le contenu interne.
Cela vous permet de cibler des éléments à l’intérieur de votre SVG à l’aide de CSS et de JS.

Vous pouvez effacer tous les autres attributs de la balise IMG car de toute façon, elle disparaîtra.

De plus, vous pouvez maintenant ajouter la classe cible aux éléments extérieurs si vous ne pouvez pas l’ajouter directement à l’IMG lui-même. Cette extension parcourra les enfants à la recherche de votre SVG pour le remplacer par le code en ligne.

Il y a un réglage qui permet d’ajouter automatiquement votre classe à la balise IMG lorsque vous insérez des SVG dans un article ou une page, ce qui permet également de retirer les balises inutiles.

Depuis la version 2.3.11, vous pouvez forcer tous les fichiers SVG du site à être rendus en ligne à l’aide d’une simple case à cocher (à utiliser avec précaution). De plus, vous pouvez maintenant choisir d’utiliser la version minifiée ou dépliée du fichier JS.

Images mise en avant : Si un article ou une page est enregistré avec votre SVG comme image mise en avant, une case à cocher s’affichera dans la boîte méta de l’image mise en avant pour vous permettre de la rendre en ligne (seulement si le mode avancé est actif).

Remarque : si votre SVG ne s’affiche pas, il est probable qu’il soit affiché avec une hauteur et une largeur de zéro. Dans ce cas, vous devrez définir votre hauteur et votre largeur dans le CSS de votre site pour que les fichiers SVG s’affichent correctement.

Si vous avez des problèmes, veuillez utiliser l’onglet support et je ferai de mon mieux pour vous répondre rapidement.

CRÉATION D’UN SITE DE TEST

D’un simple clic, vous pouvez créer un site d’essai entièrement gratuit pour tester le SVG Support avec TasteWP ! Pas d’inscription, pas de carte, rien ! C’est génial ! Essayez-le : Cliquez ici pour créer un site de test en quelques secondes

Sécurité

Comme c’est le cas pour tous les fichiers téléversés, il existe des risques potentiels. J’ai donc ajouté quelques fonctionnalités pour vous aider !

  • Nettoyage factultatif pour aider à éliminer tout code malveillant de vos fichiers SVG lors de leur téléversement.
  • Restreindre les téléversement à l’administrateur uniquement.

Autorisez uniquement les utilisateurs/utilisatrices à téléverser des fichiers SVG que si vous leur faites confiance. Vous avez la possibilité de restreindre l’utilisation des SVG aux seuls administrateurs/administratrices à partir de la page des réglages, ainsi que d’activer le nettoyage des SVG pour qu’ils nettoient tous les fichiers SVG téléversés.

Par défaut, toute personne ayant accès à la médiathèque ou à la fonction upload_files pourra téléverser des fichiers SVG (c’est-à-dire les administrateurs/administratrices, les auteurs/auteurs et les éditeurs/éditrices). Veuillez noter que les fichiers SVG sont en fait des fichiers XML, ce qui permettrait à quelqu’un d’injecter du code malveillant si vous ne faites pas attention aux personnes qui ont les privilèges de téléverser.

Retour

Je suis ouvert à vos propositions et commentaires – Merci d’utiliser SVG Support !

Follow @SVGSupport on Twitter
Follow @benbodhi on Twitter

Note : j’espère que vous aimez cette extension ! Veuillez prendre un moment pour l’évaluer.

Traductions

Vous pouvez contribuez à la traduction ici.
Nouveau dans la traduction de WordPress ?
Lisez d’abord le Manuel du traducteur.

Captures d’écran

  • Réglages de base
  • Réglages avancés
  • Featured Image checkbox to render SVG inline
  • SVG used in WP native Image Widget (since 4.9)
  • SVG en ligne dans le balisage de l’interface publique du site.
  • Onglet aide – Vue d’ensemble
  • Onglet aide – Les réglages
  • Onglet aide – Usage courant
  • Onglet aide – Affichage de SVG inline (utilisation avancée)

FAQ

SVG not rendering inline since 2.3 update

SVG Support 2.3 includes a new settings section called « Advanced Mode ». Users that were inlining SVG files need to make sure this setting is checked. Go to your dashboard > Settings > SVG Support and check « Advanced Mode ». All of your original settings should still be there.

How do I disable the Javascript on the front end if I am not using inline SVG?

If you go to Settings > SVG Support in your admin dashboard, you can choose to enable « Advanced Mode » or not. If you leave it disabled, the advanced functionality and extraneous script is removed.

I’m trying to use SVG in the customizer but it’s not working.

To allow SVG to work in the customizer, you will need to modify/add some code in your child theme’s function file. Here is a great tutorial on how to do that. The important part is:

'flex-width'    => true
'flex-height'   => true

How do I add animation to my SVG?

You will need to edit your SVG file in a code editor so you can add CSS classes to each element you need to target within the SVG. Make sure that your IMG tag is being swapped out for your inline SVG and then you can use CSS or JS to apply animations to elements within your SVG file.

Why is SVG Support not working in multisite?

If you installed multisite prior to WordPress 3.5, then you will need to remove your ms-files. Here is a couple of resources to help you: Dumping ms-files Removing ms-files after 3.5.

Why is my SVG not working in Visual Composer?

Si vous utilisez SVG Support avec Visual Composer ou tout autre constructeur de page, vous devrez vous assurer que vous pouvez ajouter votre propre classe à l’image. Le moyen le plus simple de le faire est d’utiliser dans le constructeur de page un bloc de texte simple ou un bloc de code pour y insérer le code de votre image. De plus, il existe maintenant un réglage pour forcer tous les fichiers SVG à être affichés en ligne.

How do I get this to work with the Media Library Assistant plugin?

You need to add the mime type for svg and svgz to: « MLA Settings > Media Library Assistant > Uploads (tab) » and then it works.

Avis

28 mai 2024
Ошибка обновления. Не удалось обновить значение мета для inline_featured_image в базе данных. В некоторые посты. Основная масса без изменений. С чем связано. непонятно. На других площадках эту проблему уже год обсуждают!
Lire les 333 avis

Contributeurs/contributrices & développeurs/développeuses

« SVG Support » est un logiciel libre. Les personnes suivantes ont contribué à cette extension.

Contributeurs

“SVG Support” a été traduit dans 16 locales. Remerciez l’équipe de traduction pour ses contributions.

Traduisez « SVG Support » dans votre langue.

Le développement vous intéresse ?

Parcourir le code, consulter le SVN dépôt, ou s’inscrire au journal de développement par RSS.

Journal

2.5.5

  • More error fixes and general clean up.

2.5.4

  • Fixed errors.

2.5.3

  • Fixed fatal php error.

2.5.2

  • Added some defaults for better security by default.

2.5.1

  • Added missing quotes in uninstall.php.

2.5

  • Cleaned up spelling mistakes and general formatting.
  • Addressed security concern.
  • Added more sanitization options – frontend and admin both supported.
  • Added support for SVG minification.
  • Added ability to choose jQuery or vanilla JS.
  • Added DB cleanup on uninstall.
  • Fixed dimensions fallback.

2.4.2

  • Fixed srcset warning for some premium themes.
  • Fixed original IMG IDs not getting preserved on replacement.
  • Removed some rogue text from featured image box.

2.4.1

  • Fixed issue causing WP-CLI to break.

2.4

  • NEW FEATURE: Added optional SVG sanitization.
  • NEW FEATURE: Added optional SVG minification.
  • Added inline SVG checkbox to Gutenberg featured image.
  • Better Gutenberg support in general.
  • Modified class targeting to allow inline rendering of nested SVGs (any level deep) when you can’t set the IMG class directly.
  • Modified JS to use vanilla JS instead of jQuery.
  • Fixed accessibility issues on settings page.
  • Fixed dimensions metadata issue.
  • Fixed division by 0 issue when SVG had no width or height set.
  • Fixed featured image spacing issue in both classic and block editor.
  • Bumped required PHP version.
  • Removed obsolete admin notice.
  • Removed srcset for SVG files.
  • Removed directory name from filepath metadata.

2.3.21

  • Fixed featured image SVG overlapping container.

2.3.20

  • Fixed admin setting not being escaped when output.

2.3.19

  • Fixed PHP Warning from localize_script in functions/enqueue.php.
  • Added a check for SRC attribute in js/svgs-inline.js.

2.3.18

  • Updated author URL in main plugin file.
  • Updated donate links.
  • Cleaned up plugin action meta links and settings page.
  • Rolled back a fix in functions/attachment.php due to it removing meta from other attachments.

2.3.17

  • Added setting to choose whether to load frontend CSS or not.

2.3.16

  • Fix for files that have the XML declaration.
  • Fix for PHP warnings from image widget.
  • Some small CSS changes to the frontend when displaying SVG media attachments.

2.3.15

  • Had to roll back a recent PHP warnings fix due to it breaking some theme compatibility.

2.3.14

  • Fixed: Fatal error in some cases when removing old option from the database.

2.3.13

  • Fixed: PHP warnings and notices from the image widget when using SVG files and wp_debug was on.
  • Modified: Better front end CSS for displaying SVG attachments, both as images and inline.
  • Removed: DB entry for deprecated admin notice.

2.3.12

  • New: Native « Help » tab on the SVG Support settings page.
  • New: Wrapped the inline JS in a function so you can call it at will using bodhisvgsInlineSupport();.
  • Modified: Admin CSS to target SVG src only.
  • Modified: SVG Support settings page – cleaned it up a little.
  • Removed: Version update admin notice.

2.3.11

  • New: Feature to use expanded JS file rather than the minified/compressed version (useful for bundling and minifying using external caching plugins).
  • New: Force Inline SVG option. This feature allows you to force all of your SVG files to be rendered inline regardless of classes applied. Addresses issues where you can’t add your own class to an image for some reason. For example, some page builder image elements. Also addresses changing your target class in the settings and needing to change all of your already embedded media, allowing you to simply force render rather than update all of the classes.
  • Modified the readme file and descriptions a bit.
  • Refined some code in functions/featured-image.php line 69 to address a warning.
  • Updated « Requires at least » tag to 4.8 (though it should still work in older versions, there was issues with core during the 4.7 phase and it’s time for you to update anyway).

2.3.10

  • Correction des liens manquants dans la page réglages.

2.3.9

  • Lien méta d’action de l’extension modifiée pour la page réglages.
  • Changement de langues dans l’extension.
  • Ajout d’une recommandation pour l’optimisation d’image ShortPixel.
  • Ajout de condition pour vérifier le type de publication prenant en charge la vignette avant de définir les métadonnées.

2.3.8

  • Added some CSS to make sure featured images show on WooCommerce products, Sensei Courses and Lessons.
  • Fix: Auto insert class setting was stripping featured image HTML in some cases.

2.3.7

  • Added WP version check to wrap mime fix function needed for WP v4.7.1 – v4.7.2.
  • Moved mime fix into mime type file.
  • Modified admin notice code to make it neater.
  • Fix: attachment-modal.php issues with some servers and external SVG files (props to @abstractourist & @malthejorgensen for providing fixes, as I could not consistently reproduce the issue).
  • Compatibility: Changed a line to provide wider compatibility, specifically for WordPress Bedrock on a LEMP stack.
  • Compatibility: Added another snippet to the JS to support IE11 (apparently people still use IE).
  • Added more FAQ’s.

2.3.6

  • New: Added polyfill to make svgs-inline.js work with older browsers.
  • New: Section to leave reviews on settings page.
  • Removed: Redundant one time upgrade activate code.
  • Fix: Errors reported on activation and on the settings page – Related Support Thread.

2.3.5

  • Revision and modification of the thumbnail display code.

2.3.4

  • Fix: Fatal error for some because a function wasn’t prefixed.

2.3.3

  • Fix: Missing arguments PHP warnings from new attribute control file.
  • Update settings page text.

2.3.2

  • Modified the attribute control code that auto inserts our class to only apply to SVG files.

2.3.1

  • Fix: Fatal error in some cases due to admin notice.

2.3

  • New Feature – Advanced Mode: allows you to turn off the advanced features and simply upload SVG files like normal images. This addition also enables users to turn off the script added on front end by leaving Advanced Mode unchecked.
  • New Feature – Featured Image Support: If your featured image is SVG, once the post is saved you will see a checkbox to render the SVG inline (advanced mode only).
  • Performance – Stop inlining JS from running if image source is not SVG.
  • Added new stylesheet for settings page.
  • Moved SCSS files to their own folder.
  • Changed donate link so I can track it and properly thank you for your generous donations.
  • Added a rating link to the settings and media pages.
  • Cleaned up code formatting, added more comments.
  • Added a plugin version check.
  • Added notice so people are aware they may need to turn on the advanced mode.

2.2.5

  • FIX: Display SVG thumbnails in attachment modals.

2.2.4

  • FIX: Added function to temporarily fix an issue with uploading in WP 4.7.1

2.2.32

  • Changed text domain to match plugin slug for localization.

2.2.31

  • Attempt to fix ability to translate

2.2.3

  • Modified code in svg-support/js/svg-inline.js and svg-support/js/min/svg-inline-min.js to allow JS control of the SVG elements and detect if they have been loaded (IMG tag swapped out). Thanks to laurosello for this suggestion and code contribution.
  • Fixed SVG thumbnails not displaying correctly in list view of the media library.
  • Cleaned up the code and comments a bit.
  • Added translation for Spanish. Thanks to Apasionados del Marketing for the translation.

2.2.2

  • Changed another anonymous function in svg-support/functions/thumbnail-display.php that was causing errors for some.

2.2.1

  • Changed anonymous function in svg-support/functions/thumbnail-display.php line 15 to prevent fatal error in older PHP versions.

2.2

  • Added support to make SVG thumbnails visible in all media library screens.
  • Added SVGZ to the mime types.
  • Automatically removes the width and height attributes when inserting SVG files.
  • Added ability to choose whether the target class is automatically inserted into img tags or not, stripping the default WordPress classes.
  • Added ability to choose whether script is output in footer – true or false.
  • Blocked direct access to PHP files.
  • Added SCSS support using CodeKit – minified CSS + JS files.
  • Updated spelling for incorrect function name.
  • Changed comment formatting across all files for consistency.
  • Added link to $25 Free credit at GoWebben on the settings page.
  • Tested in WordPress 4.3.
  • Updated Readme file.

2.1.7

  • Tested in WordPress 4.0 and added plugin icons for the new interface.

2.1.6

  • Added missing jQuery dependency in /functions/enqueue.php (pointed out by walbach) – was loading SVG Support JS before jQuery.

2.1.5

  • Added Serbian translation, submitted by Ogi Djuraskovic.

2.1.4

  • Fixed plugin settings link (on plugins page)
  • Added more links – Support & Donate
  • Modified the settings page a little
  • Cleaned up settings page with CSS
  • Satisfied my OCD tendencies a little

2.1.3

  • Added plugin_action_links file for custom menus on plugin page.

2.1.2

  • Cleaned up trunk, tags and readme.txt to show correct changelog and update notice.

2.1.1

  • Fixed JS file conditional – worked in local testing but not live.

2.1

  • Updates to language files for localization.

2.0

  • Added an admin settings page with instructions plus options for restricting to admin use only and setting a custom CSS target class.
  • Whole plugin completely re-written and re-structured.
  • Added option to restrict SVG uploads to administrators only.
  • Added field for custom CSS target class.
  • Added stylesheet to admin settings page.

1.0

  • Initial Release.