Are you a GenerateCustomer?

Do you have an active GP Premium or GenerateBlocks Pro license key?

Create a GenerateSupport account for GeneratePress and GenerateBlocks support in one dedicated place.

Create an account
Already have a GenerateSupport account? Login

Just browsing?

Feel free to browse the forums. Support for our free versions is provided on WordPress.org (GeneratePress, GenerateBlocks).

Want to become a premium user? Learn more below.

Integrate Pinterest Hover Save Button on Images

  • Topfgartenwelt

    Hi, I have already tried some plugins to add a pinterest hover save button to my images, but it doesn’t work on mobile. So I thought to give the script from Pinterest intself a try, but it isn’t possible to add it with CodeSnippets.

    Now I have found that code – I think it will work with Code Snippets – but it uses a shortcode:

    function get_pin($atts) {
        global $post;
        if ($post) {
            $pinterestimage = wp_get_attachment_image_src(get_post_thumbnail_id($post->ID), 'full');
            if ($pinterestimage) {
                return '<a href="http://pinterest.com/pin/create/button/?url=' . urlencode(get_permalink($post->ID)) . '&media=' . $pinterestimage[0] . '&description=' . get_the_title() . '" class="pin-it-button" count-layout="vertical">Pin It</a>';
            } else {
                return 'No Pinterest image available.';
            }
        } else {
            return 'No post found.';
        }
    }
    add_shortcode('pin', 'get_pin');

    What should I do, do activate that short code globally on all posts?

    Greetings Kathrin

  • Hi there,

    this kind of thing is out of our scope
    But we had one user who we assisted.
    See my reply here:

    https://generate.support/topic/save-share-url-not-generating-optimally/#post-122285

    You just need to add the <script> to the wp_footer on all posts using a GP Hook Element.

  • Topfgartenwelt

    Thank you very much for your reply. Is the provided code for a hover pin it button? I need a Pinterest Hover Button for the images.

    So at first I create a hook element –> wp_footer, Location set to Post > All posts and use that code:

    <script>
    document.addEventListener("DOMContentLoaded", function() {
        var images = document.querySelectorAll(".single-post .wp-block-image img, .single-post .gb-block-image img, .single-post p[data-slot-rendered-content='true'] img, .single-post p img");
        var postTitle = document.querySelector(".single-post .entry-title").innerText || document.title; // Adjust the selector if needed to match your theme
    
        images.forEach(function(img) {
            var a = document.createElement('a');
            a.className = 'pin-it-button';
            var url = encodeURIComponent(window.location.href);
            var media = encodeURIComponent(img.src);
            var description = encodeURIComponent(postTitle);
            a.href = 'https://pinterest.com/pin/create/bookmarklet/?url=' + url + '&media=' + media + '&is_video=false&description=' + description;
            a.rel = 'noopener';
            a.target = '_blank';
            a.setAttribute('data-pin-do', 'buttonPin');
            img.parentNode.insertBefore(a, img);
        });
    });
    </script>

    In the customizer I add that CSS:

    .pin-it-button {
      position: absolute;
      z-index: 3;
      margin: 12px;
      font: 18px/35px "Arial";
      text-align: center;
      text-decoration: none;
      color: #fff !important;
      background: #e60023 url() 3px 50% no-repeat;
      -webkit-font-smoothing: antialiased;
      border-radius: 30px;
      width: auto;
      background-position-x: 9px;
      background-size: 20px 20px;
      text-indent: 34px;
      font-weight: 700;
      padding: 4px 15px 4px 4px;
      cursor: pointer;
      display: inline-block;
      box-sizing: border-box;
      box-shadow: inset 0 0 1px #888;
      vertical-align: baseline;
      opacity: 1;
      transition: none;
    }
    
    .pin-it-button:after {
      content: 'Save';
      color: #fff;
    }

    I have tried it, but it doesn’t work I don’t see a Pinterest Button.

    I was trying around with that code, but the hover doesn’t work. I need a Pinterest Hover Button on my images. 🙁

    js.file:

    document.addEventListener("DOMContentLoaded", function() {
        var images = document.querySelectorAll('img:not(.no-pin)'); // Exclude images with the class 'no-pin'
    
        images.forEach(function(image) {
            // Wrapper für das Bild und den Button erstellen
            var wrapper = document.createElement('div');
            wrapper.className = 'pinterest-pin';
            image.parentNode.insertBefore(wrapper, image);
            wrapper.appendChild(image);
    
            // Pinterest-Button erstellen
            var button = document.createElement('a');
            button.className = 'pin-it-button';
            button.setAttribute('href', 'https://www.pinterest.com/pin/create/button/?url=' + encodeURIComponent(window.location.href) + '&media=' + encodeURIComponent(image.src) + '&description=' + encodeURIComponent(image.alt));
            button.setAttribute('data-pin-do', 'buttonPin');
            button.setAttribute('data-pin-config', 'above');
    
            // PNG-Icon für den Button
            var buttonImage = document.createElement('img');
            buttonImage.src = 'https://assets.pinterest.com/images/pidgets/pinit_fg_en_rect_gray_20.png'; // Dein PNG-Icon
            buttonImage.alt = 'Pin it';
            button.appendChild(buttonImage);
    
            wrapper.appendChild(button);
        });
    });

    and CSS:

    /* Grundlegende Stile für den Pinterest-Button */
    .pinterest-pin {
        position: relative;
        display: inline-block;
        overflow: hidden; /* Verhindert, dass der Button außerhalb des Bildes angezeigt wird */
    }
    
    /* Stile für das Bild im Wrapper */
    .pinterest-pin img {
        display: block;
    }
    
    /* Stile für den Pinterest-Button */
    .pinterest-pin .pin-it-button {
        position: absolute;
        top: 10px; /* Abstand vom oberen Rand */
        left: 10px; /* Abstand vom linken Rand */
        display: none; /* Standardmäßig ausgeblendet */
        z-index: 10;
        background: #E60023; /* Pinterest-Rot als Hintergrundfarbe */
        border-radius: 5px; /* Abgerundete Ecken */
        padding: 10px; /* Innerer Abstand vergrößern */
        box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2); /* Schatten hinzufügen */
        display: flex; /* Flexbox verwenden */
        align-items: center; /* Vertikale Zentrierung */
        justify-content: center; /* Horizontale Zentrierung */
        width: 60px; /* Breite des Buttons */
        height: 60px; /* Höhe des Buttons */
    }
    
    /* Stile für das PNG-Icon */
    .pinterest-pin .pin-it-button img {
        width: 24px; /* Größe des Pinterest-Icons */
        height: 24px; /* Höhe des Icons */
        object-fit: contain; /* Sicherstellen, dass das Icon proportional skaliert wird */
    }
    
    /* Hover-Effekt für Desktop */
    @media (hover: hover) and (pointer: fine) {
        .pinterest-pin:hover .pin-it-button {
            display: flex; /* Button bei Hover anzeigen */
        }
    }
    
    /* Sicherstellen, dass der Button nicht über das Bild hinausgeht */
    .pinterest-pin {
        overflow: hidden; /* Verhindert, dass der Button außerhalb des Bildes angezeigt wird */
    }
    
    /* Spezifische Anpassungen für kleinere Bildschirme */
    @media (max-width: 768px) {
        .pinterest-pin .pin-it-button {
            top: 10px; /* Etwas größeren Abstand für mobile Geräte */
            left: 10px;
            max-width: 50px; /* Kleinere maximale Breite für mobile Geräte */
            max-height: 50px; /* Kleinere maximale Höhe für mobile Geräte */
        }
    }

    Greetings Kathrin

  • Hi there,

    it does show when hovering the image:
    https://app.screencast.com/OR6NQ132Nmd1q

  • Topfgartenwelt

    Yes, it shows, but on my end the button looks different every time.

    But from the start. The Pinterest Button should have a hover effect on Desktop but should be permanent on Mobiles.

    I have used that javascript:

    document.addEventListener("DOMContentLoaded", function() {
        var images = document.querySelectorAll('img:not(.no-pin)'); // Alle Bilder auf der Seite, die nicht die Klasse 'no-pin' haben
    
        images.forEach(function(image) {
            // Überprüfen, ob der Wrapper bereits existiert
            if (image.parentNode.classList.contains('pinterest-pin-wrapper')) return;
    
            // Wrapper für das Bild und den Button erstellen
            var wrapper = document.createElement('div');
            wrapper.className = 'pinterest-pin-wrapper'; // Eindeutige Klasse für den Wrapper
            wrapper.style.position = 'relative'; // Sicherstellen, dass der Wrapper relativ positioniert ist
            image.parentNode.insertBefore(wrapper, image);
            wrapper.appendChild(image);
    
            // Pinterest-Button erstellen
            var button = document.createElement('a');
            button.className = 'custom-pin-it-button'; // Eindeutige Klasse für den Button
            button.setAttribute('href', 'https://www.pinterest.com/pin/create/button/?url=' + encodeURIComponent(window.location.href) + '&media=' + encodeURIComponent(image.src) + '&description=' + encodeURIComponent(image.alt));
            button.setAttribute('data-pin-do', 'buttonPin');
            button.setAttribute('data-pin-hover', 'true');
    
            // PNG-Icon für den Button
            var buttonImage = document.createElement('img');
            buttonImage.src = 'https://assets.pinterest.com/images/pidgets/pinit_fg_en_rect_gray_20.png'; // PNG-Icon
            buttonImage.alt = 'Pin it';
            buttonImage.style.width = 'auto';
            buttonImage.style.height = 'auto';
            buttonImage.style.maxWidth = '60px';
            buttonImage.style.maxHeight = '60px';
            button.appendChild(buttonImage);
    
            wrapper.appendChild(button);
        });
    });

    And that CSS:

    .pinterest-pin-wrapper {
        position: relative; /* Wrapper relativ positionieren */
        display: inline-block; /* Inline-Block-Element */
    }
    
    .custom-pin-it-button {
        position: absolute;
        top: 10px; /* Abstand vom oberen Rand */
        left: 10px; /* Abstand vom linken Rand */
        opacity: 0; /* Button standardmäßig unsichtbar */
        z-index: 10; /* Sicherstellen, dass der Button oben liegt */
        width: 60px; /* Feste Breite */
        height: auto; /* Höhe automatisch anpassen */
        transition: opacity 0.3s ease-in-out; /* Weicher Übergang für die Sichtbarkeit */
    }
    
    .pinterest-pin-wrapper:hover .custom-pin-it-button {
        opacity: 1; /* Button anzeigen beim Hover */
    }
    
    /* CSS für mobile Geräte: Button immer sichtbar */
    @media (max-width: 767px) {
        .custom-pin-it-button {
            opacity: 1 !important; /* Button immer sichtbar auf mobilen Geräten */
        }
    }

    Now it looks like that after reloading the site:

    The Button has lost the hover-effect and it doesn’t appear as an overlay but is situated beside the image:

    https://imgur.com/a/mDvDVcH

    And sometimes it is beside the image and at the bottom:

    https://imgur.com/a/yVepWF7

    On Mobile the Button is always after the image and causes CLS because it is loaded at last.

    It is not possible to exclude my website-logo and my avatar from the button. The no-pin class is ignored.

    Do you have a better solution? There is no plugin for doing that.

    Greetings Kathrin

  • Yes, it shows, but on my end the button looks different every time.

    How it looks is not something we can control, unfortruanly.

    For function adjustments like excluding your logo and avatar, you need to modify the JS from 3rd party which is out of scope.

    I think there should be some plugins that can do it automatically, so it’s worth doing some research.

  • Topfgartenwelt

    Dear Ying, I have tried several plugins today. They are all not working. I have tried the code from David provided from Genereate Press it doesn’t show anything. Why it is impossible to add such a button?

    Images with no-pin are excluded from the JS but I can’t add it to the logo and some pictures in a GeneratePress Box. Can you help me here? And maybe can you help with the Code that David provided that was created by your team?

    Greetings Kathrin

  • Try change this:
    var images = document.querySelectorAll('img:not(.no-pin)');
    to:
    var images = document.querySelectorAll(".single-post .wp-block-image img, .single-post .gb-block-image img, .single-post p[data-slot-rendered-content='true'] img, .single-post p img");

  • Topfgartenwelt

    Thank you very much, but can you also help me with the code provided by David here: https://generate.support/topic/save-share-url-not-generating-optimally/#post-122285 and here: https://generate.support/topic/tyring-to-figure-out-if-this-is-custom-code-or-a-plugin/

    I have tried the code already but it isn’t showing. I don’t know why.

    Greetings Kathrin

  • I’ll forward this topic to David, he should be more familiar with his own codes 🙂

  • Topfgartenwelt

    Thank you very much, I have added the code again and activated everything but I don’t see a pin it button.

    Greetings Kathrin

  • Topfgartenwelt

    Hmm, did you forget about me? 🙁

  • Hi there,

    try this Javascript :

    
    <script>
    document.addEventListener("DOMContentLoaded", function() {
        try {
            var images = document.querySelectorAll(".single-post #page img:not(.no-pin)");
            var h1Tag = document.querySelector(".single-post h1");
            var postTitle = h1Tag ? h1Tag.innerText.trim() : document.title;
    
            images.forEach(function(img) {
                var a = document.createElement('a');
                a.className = 'pin-it-button';
                var url = encodeURIComponent(window.location.href);
                var media = encodeURIComponent(img.src);
                var description = encodeURIComponent(postTitle);
                a.href = 'https://pinterest.com/pin/create/bookmarklet/?url=' + url + '&media=' + media + '&is_video=false&description=' + description;
                a.rel = 'noopener';
                a.target = '_blank';
                a.setAttribute('data-pin-do', 'buttonPin');
                img.parentNode.insertBefore(a, img);
            });
        } catch (error) {
            console.error("Error adding Pinterest buttons:", error);
        }
    });
    </script>
    
    

    And this CSS:

    
    .pin-it-button {
      position: absolute;
      z-index: 3;
      margin: 12px;
      font: 18px/35px "Arial";
      text-align: center;
      text-decoration: none;
      color: #fff !important;
      background: #e60023 url() 3px 50% no-repeat;
      -webkit-font-smoothing: antialiased;
      border-radius: 30px;
      width: auto;
      background-position-x: 9px;
      background-size: 20px 20px;
      text-indent: 34px;
      font-weight: 700;
      padding: 4px 15px 4px 4px;
      cursor: pointer;
      display: inline-block;
      box-sizing: border-box;
      box-shadow: inset 0 0 1px #888;
      vertical-align: baseline;
      opacity: 1;
      transition: opacity 0.3s;
    }
    
    .pin-it-button:after {
      content: 'Save';
      color: #fff;
    }
    
    @media(min-width: 1024px) {
        figure:not(:hover) .pin-it-button {
            opacity: 0;
        }
    }
    
  • Topfgartenwelt

    Great, David you’re the best!!

    The Pinterest Button is showing now. The Button appears beside the image (Desktop) and above the image (Mobile). It would be great to have a hover overlay button on desktop and a permanent overlay button on mobile. I don’t know if this is possible and easy to achieve.

    When working on that topic I have added this part to the code: if (!img.classList.contains('no-pin')), it should proof if an image has the class no-pin. It works good in combination with the code that Ying has provided above.

    var images = document.querySelectorAll(".single-post .wp-block-image img, .single-post .gb-block-image img, .single-post p[data-slot-rendered-content='true'] img, .single-post p img");

    Only the picture in the author-box at the end of the post is ignored. Why?

    I don’t want a pin-it-button after the content, so I have deleted this code in the CSS, but it still shows:

    .pin-it-button:after {
      content: 'Save';
      color: #fff;
    }

    Thank you very much!

    Greetings Kathrin

  • You first need to make sure that the no-pin class is added to the img HTML.
    eg. make sure you select a GenerateBlocks Image Block and add the Class directly to it. And NOT on a container that it sits inside of.

  • Topfgartenwelt

    Hi,

    David thank you for your reply. I have already added to no-pin class to the img html too. As you can see here:

    https://imgur.com/a/LPLXCNf

    It is part of a Generate Press Container Block and hooked to the post.

    Greetings Kathrin

Viewing 16 posts - 1 through 16 (of 38 total)
  • You must be logged in to reply to this topic.