Preloader
Auf dieser Website werden Daten wie z.B. Cookies gespeichert, um wichtige Funktionen der Website, einschließlich Analysen, Marketingfunktionen und Personalisierung zu ermöglichen. Sie können Ihre Einstellungen jederzeit ändern oder die Standardeinstellungen akzeptieren.
Cookie Hinweise
Datenschutzregelung
19.12.2024

WhatsApp-Widget

Anleitung, wie du das WhatsApp-Widget in das Vision CMS integrieren kannst.


1. Dateien einfügen

CSS: whatsapp-widget.css

Speichere die Datei im Ordner /template/css/_system/.

/* CSS Whatsapp Chat */
  .whatsapp-name {
    font-size: 16px;
    font-weight: 600;
    padding-bottom: 0;
    margin-bottom: 0;
    line-height: 0.5;
    color: white;
  }
  .head-home p small {
    color: white;
}

  #whatsapp-chat {
    box-sizing: border-box !important;
    outline: none !important;
    position: fixed;
    width: 350px;
    border-radius: 10px;
    box-shadow: 0 1px 15px rgba(32, 33, 36, 0.28);
    bottom: 90px;
    right: 30px;
    overflow: hidden;
    z-index: 99;
    animation-name: showchat;
    animation-duration: 1s;
    transform: scale(1);
    background-color: white;
  }
  
  a.blantershow-chat {
    /*   background: #009688; */
    background: #fff;
    color: #404040;
    position: fixed;
    display: flex;
    font-weight: 400;
    justify-content: space-between;
    z-index: 98;
    bottom: 25px;
    right: 35px;
    font-size: 15px;
    padding: 10px 20px;
    border-radius: 30px;
    box-shadow: 0 1px 15px rgba(32, 33, 36, 0.28);
  }
  
  a.blantershow-chat svg {
    transform: scale(1.2);
    margin: 0 10px 0 0;
  }
  
  .header-chat {
    /*   background: linear-gradient(to right top, #6f96f3, #164ed2); */
    background: #009688;
    background: #095e54;
    color: #fff;
    padding: 20px;
  }
  
  .header-chat h3 {
    margin: 0 0 10px;
  }
  
  .header-chat p {
    font-size: 14px;
    line-height: 1.7;
    margin: 0;
  }
  
  .info-avatar {
    position: relative;
  }
  
  .info-avatar img {
    border-radius: 100%;
    width: 50px;
    float: left;
    margin: 0 10px 0 0;
  }
  
  a.informasi {
    padding: 20px;
    display: block;
    overflow: hidden;
    animation-name: showhide;
    animation-duration: 0.5s;
  }
  
  a.informasi:hover {
    background: #f1f1f1;
  }
  
  .info-chat span {
    display: block;
  }
  
  #get-label,
  span.chat-label {
    font-size: 12px;
    color: #888;
  }
  
  #get-nama,
  span.chat-nama {
    margin: 5px 0 0;
    font-size: 15px;
    font-weight: 700;
    color: #222;
  }
  
  #get-label,
  #get-nama {
    color: #fff;
  }
  
  span.my-number {
    display: none;
  }
  
  /* .blanter-msg {
    color: #444;
    padding: 20px;
    font-size: 12.5px;
    text-align: center;
    border-top: 1px solid #ddd;
  } */
  textarea#chat-input {
    border: none;
    font-family: "Arial", sans-serif;
    width: 100%;
    height: 45px;
    outline: none;
    resize: none;
    padding: 10px;
    font-size: 14px;
  }
  
  a#send-it {
    width: 40px;
    height: 45px;
    font-weight: 700;
    padding: 10px 10px 0;
    background: #eee;
    border-radius: 0px;
  }
  a#send-it svg {
    fill: #a6a6a6;
    height: 24px;
    width: 24px;
  }
  
  .first-msg {
    background: transparent;
    padding: 30px;
    text-align: center;
  }
  .first-msg span {
    background: #e2e2e2;
    color: #333;
    font-size: 14.2px;
    line-height: 1.7;
    border-radius: 10px;
    padding: 15px 20px;
    display: inline-block;
  }
  
  .start-chat .blanter-msg {
    display: flex;
  }
  
  #get-number {
    display: none;
  }
  
  a.close-chat {
    position: absolute;
    top: 5px;
    right: 15px;
    color: #fff;
    font-size: 30px;
  }
  
  @keyframes ZpjSY {
    0% {
      background-color: #b6b5ba;
    }
    15% {
      background-color: #111111;
    }
    25% {
      background-color: #b6b5ba;
    }
  }
  @keyframes hPhMsj {
    15% {
      background-color: #b6b5ba;
    }
    25% {
      background-color: #111111;
    }
    35% {
      background-color: #b6b5ba;
    }
  }
  @keyframes iUMejp {
    25% {
      background-color: #b6b5ba;
    }
    35% {
      background-color: #111111;
    }
    45% {
      background-color: #b6b5ba;
    }
  }
  @keyframes showhide {
    from {
      transform: scale(0.5);
      opacity: 0;
    }
  }
  @keyframes showchat {
    from {
      transform: scale(0);
      opacity: 0;
    }
  }
  @media screen and (max-width: 480px) {
    #whatsapp-chat {
      width: auto;
      left: 5%;
      right: 5%;
      font-size: 80%;
    }
  }
  #whatsapp-chat.hide {
    display: none;
    animation-name: showhide;
    animation-duration: 0.5s;
    transform: scale(1);
    opacity: 1;
  }
  
  #whatsapp-chat.show {
    display: block;
    animation-name: showhide;
    animation-duration: 0.5s;
    transform: scale(1);
    opacity: 1;
  }
  
  .whatsapp-message-container {
    display: flex;
    z-index: 1;
  }
  
  .whatsapp-message {
    padding: 7px 14px 6px;
    background-color: white;
    border-radius: 0px 8px 8px;
    position: relative;
    transition: all 0.3s ease 0s;
    opacity: 0;
    transform-origin: center top 0px;
    z-index: 2;
    box-shadow: rgba(0, 0, 0, 0.13) 0px 1px 0.5px;
    margin-top: 4px;
    margin-left: -54px;
    max-width: calc(100% - 66px);
  }
  
  .whatsapp-chat-body {
    padding: 20px 20px 20px 10px;
    background-color: #e6ddd4;
    position: relative;
  }
  .whatsapp-chat-body::before {
    display: block;
    position: absolute;
    content: "";
    left: 0px;
    top: 0px;
    height: 100%;
    width: 100%;
    z-index: 0;
    opacity: 0.08;
    background-image: url("/template/images/backgrounds/whatsapp-background.png");
  }
  
  .dAbFpq {
    display: flex;
    z-index: 1;
  }
  
  .eJJEeC {
    background-color: white;
    width: 52.5px;
    height: 32px;
    border-radius: 16px;
    display: flex;
    -moz-box-pack: center;
    justify-content: center;
    -moz-box-align: center;
    align-items: center;
    margin-left: 10px;
    opacity: 0;
    transition: all 0.1s ease 0s;
    z-index: 1;
    box-shadow: rgba(0, 0, 0, 0.13) 0px 1px 0.5px;
  }
  
  .hFENyl {
    position: relative;
    display: flex;
  }
  
  .ixsrax {
    height: 5px;
    width: 5px;
    margin: 0px 2px;
    border-radius: 50%;
    display: inline-block;
    position: relative;
    animation-duration: 1.2s;
    animation-iteration-count: infinite;
    animation-timing-function: linear;
    top: 0px;
    background-color: #9e9da2;
    animation-name: ZpjSY;
  }
  
  .dRvxoz {
    height: 5px;
    width: 5px;
    margin: 0px 2px;
    background-color: #b6b5ba;
    border-radius: 50%;
    display: inline-block;
    position: relative;
    animation-duration: 1.2s;
    animation-iteration-count: infinite;
    animation-timing-function: linear;
    top: 0px;
    animation-name: hPhMsj;
  }
  
  .kAZgZq {
    padding: 7px 14px 6px;
    background-color: white;
    border-radius: 0px 8px 8px;
    position: relative;
    transition: all 0.3s ease 0s;
    opacity: 0;
    transform-origin: center top 0px;
    z-index: 2;
    box-shadow: rgba(0, 0, 0, 0.13) 0px 1px 0.5px;
    margin-top: 4px;
    margin-left: -54px;
    max-width: calc(100% - 66px);
  }
  .kAZgZq::before {
    position: absolute;
    background-image: url("");
    background-position: 50% 50%;
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    top: 0px;
    left: -12px;
    width: 12px;
    height: 19px;
  }
  
  .bMIBDo {
    font-size: 13px;
    font-weight: 700;
    line-height: 18px;
    color: rgba(0, 0, 0, 0.4);
  }
  
  .iSpIQi {
    font-size: 14px;
    line-height: 19px;
    margin-top: 4px;
    color: #111111;
  }
  
  .iSpIQi {
    font-size: 14px;
    line-height: 19px;
    margin-top: 4px;
    color: #111111;
  }
  
  .cqCDVm {
    text-align: right;
    margin-top: 4px;
    font-size: 12px;
    line-height: 16px;
    color: rgba(17, 17, 17, 0.5);
    margin-right: -8px;
    margin-bottom: -4px;
  }

  a.blantershow-chat-mobile {
    display: none;
    background: #009688;
    background: #fff;
    color: #404040;
    position: fixed;
    font-weight: 400;
    justify-content: space-between;
    z-index: 98;
    bottom: 25px;
    right: 35px;
    font-size: 15px;
    padding: 10px 20px;
    border-radius: 30px;
    box-shadow: 0 1px 15px rgba(32, 33, 36, 0.28);
  }

JS: whatsapp-widget.js

Speichere die Datei im Ordner /template/js/_system/.

Füge den Inhalt der hochgeladenen Datei ein. Code:

document.addEventListener('DOMContentLoaded', function() {
    var chatButtonDesktop = document.querySelector('.blantershow-chat');
    var chatButtonMobile = document.querySelector('.blantershow-chat-mobile');
    var userAgent = navigator.userAgent || navigator.vendor || window.opera;
    var isAndroid = /android/i.test(userAgent);
    var isiOS = /iPad|iPhone|iPod/.test(userAgent) && !window.MSStream;

    if (isAndroid || isiOS) {
        // Zeige den mobilen Button, verstecke den Desktop-Button
        if (chatButtonDesktop) chatButtonDesktop.style.display = 'none';
        if (chatButtonMobile) chatButtonMobile.style.display = 'flex';
    } else {
        // Zeige den Desktop-Button, verstecke den mobilen Button
        if (chatButtonMobile) chatButtonMobile.style.display = 'none';
        if (chatButtonDesktop) chatButtonDesktop.style.display = 'flex';
    }
});

$(document).on("click", "#send-it", function () {
    var chatInput = document.getElementById("chat-input");
    if (chatInput.value !== "") {
        var phoneNumber = $("#whatsapp-chat").data("phone-number") || "49017657983251",
            encodedMessage = encodeURIComponent(chatInput.value),
            apiUrl = "https://api.whatsapp.com/send",
            fullUrl = apiUrl + "?phone=" + phoneNumber + "&text=" + encodedMessage;
        window.open(fullUrl, "_blank");
    }
});

$(document).on("click", ".informasi", function () {
    document.getElementById("get-number").innerHTML = $(this).children(".my-number").text().trim();
    $(".start-chat, .get-new").addClass("show").removeClass("hide");
    $(".home-chat, .head-home").addClass("hide").removeClass("show");
    document.getElementById("get-nama").innerHTML = $(this).children(".info-chat").children(".chat-nama").text();
    document.getElementById("get-label").innerHTML = $(this).children(".info-chat").children(".chat-label").text();
});

$(document).on("click", ".close-chat", function () {
    $("#whatsapp-chat").addClass("hide").removeClass("show");
});

$(document).on("click", ".blantershow-chat", function () {
    $("#whatsapp-chat").addClass("show").removeClass("hide");
});


PHP: whatsapp-widget.php

Speichere die Datei im Ordner /template/plugins/.

Code:

<?php
$i = 0;
$result = cube_query('SELECT * FROM texte_elemente WHERE id_text="4" and typ="14" and showing="1" and lan="' . $this->pageOptions['language']['lan'] . '" ORDER BY reihenfolge');
if ($result->num_rows > 0) {
    while ($row = $result->fetch_assoc()) {
        $i++;
        $image = unserialize($row['image']);
        $imageSrc = "template/elemente/" . $row['id'] . "/200/" . $image[0];
        $WhatsappNummer = $row['value1'];
        $ButtonText = $row['value2'];
        $ChatFensterName = $row['value3'];
        $ChatFensterText = $row['value4'];
        $ChatName = $row['value5'];
        $ChatNachricht = $row['value6'];
        $ChatPlacholder = $row['value7'];
       
        if ($i == 1) {
        echo "
        <div id='whatsapp-chat' class='hide' data-phone-number='$WhatsappNummer'>
        <div class='header-chat'>
          <div class='head-home'>
            <div class='info-avatar'><img src='$imageSrc' /></div>
            <p><span class='whatsapp-name'>$ChatFensterName</span><br><small>$ChatFensterText</small></p>
      
          </div>
          <div class='get-new hide'>
            <div id='get-label'></div>
            <div id='get-nama'></div>
          </div>
        </div>
        <div class='home-chat'>
      
        </div>
        <div class='start-chat'>
          <div pattern='/template/images/backgrounds/whatsapp-background.png' class='WhatsappChat__Component-sc-1wqac52-0 whatsapp-chat-body'>
            <div class='WhatsappChat__MessageContainer-sc-1wqac52-1 dAbFpq'>
              <div style='opacity: 0;' class='WhatsappDots__Component-pks5bf-0 eJJEeC'>
                <div class='WhatsappDots__ComponentInner-pks5bf-1 hFENyl'>
                  <div class='WhatsappDots__Dot-pks5bf-2 WhatsappDots__DotOne-pks5bf-3 ixsrax'></div>
                  <div class='WhatsappDots__Dot-pks5bf-2 WhatsappDots__DotTwo-pks5bf-4 dRvxoz'></div>
                  <div class='WhatsappDots__Dot-pks5bf-2 WhatsappDots__DotThree-pks5bf-5 kXBtNt'></div>
                </div>
              </div>
              <div style='opacity: 1;' class='WhatsappChat__Message-sc-1wqac52-4 kAZgZq'>
                <div class='WhatsappChat__Author-sc-1wqac52-3 bMIBDo'>$ChatName</div>
                <div class='WhatsappChat__Text-sc-1wqac52-2 iSpIQi'>$ChatNachricht</div>
              </div>
            </div>
          </div>
      
          <div class='blanter-msg'>
            <textarea id='chat-input' placeholder='$ChatPlacholder' maxlength='120' row='1'></textarea>
            <a href='javascript:void;' id='send-it'><svg viewBox='0 0 448 448'>
                <path d='M.213 32L0 181.333 320 224 0 266.667.213 416 448 224z' />
              </svg></a>
      
          </div>
        </div>
        <div id='get-number'></div><a class='close-chat' href='javascript:void'>×</a>
      </div>
      <a class='blantershow-chat' href='javascript:void' title='Whatsapp Chat'><svg width='20' viewBox='0 0 24 24'>
          <defs />
          <path fill='#eceff1' d='M20.5 3.4A12.1 12.1 0 0012 0 12 12 0 001.7 17.8L0 24l6.3-1.7c2.8 1.5 5 1.4 5.8 1.5a12 12 0 008.4-20.3z' />
          <path fill='#4caf50' d='M12 21.8c-3.1 0-5.2-1.6-5.4-1.6l-3.7 1 1-3.7-.3-.4A9.9 9.9 0 012.1 12a10 10 0 0117-7 9.9 9.9 0 01-7 16.9z' />
          <path fill='#fafafa' d='M17.5 14.3c-.3 0-1.8-.8-2-.9-.7-.2-.5 0-1.7 1.3-.1.2-.3.2-.6.1s-1.3-.5-2.4-1.5a9 9 0 01-1.7-2c-.3-.6.4-.6 1-1.7l-.1-.5-1-2.2c-.2-.6-.4-.5-.6-.5-.6 0-1 0-1.4.3-1.6 1.8-1.2 3.6.2 5.6 2.7 3.5 4.2 4.2 6.8 5 .7.3 1.4.3 1.9.2.6 0 1.7-.7 2-1.4.3-.7.3-1.3.2-1.4-.1-.2-.3-.3-.6-.4z' />
        </svg> $ButtonText</a>
        <a class='blantershow-chat-mobile' target='_blank' href='https://api.whatsapp.com/send?phone=$WhatsappNummer' title='Whatsapp'><svg width='20' viewBox='0 0 24 24'>
        <defs />
        <path fill='#eceff1' d='M20.5 3.4A12.1 12.1 0 0012 0 12 12 0 001.7 17.8L0 24l6.3-1.7c2.8 1.5 5 1.4 5.8 1.5a12 12 0 008.4-20.3z' />
        <path fill='#4caf50' d='M12 21.8c-3.1 0-5.2-1.6-5.4-1.6l-3.7 1 1-3.7-.3-.4A9.9 9.9 0 012.1 12a10 10 0 0117-7 9.9 9.9 0 01-7 16.9z' />
        <path fill='#fafafa' d='M17.5 14.3c-.3 0-1.8-.8-2-.9-.7-.2-.5 0-1.7 1.3-.1.2-.3.2-.6.1s-1.3-.5-2.4-1.5a9 9 0 01-1.7-2c-.3-.6.4-.6 1-1.7l-.1-.5-1-2.2c-.2-.6-.4-.5-.6-.5-.6 0-1 0-1.4.3-1.6 1.8-1.2 3.6.2 5.6 2.7 3.5 4.2 4.2 6.8 5 .7.3 1.4.3 1.9.2.6 0 1.7-.7 2-1.4.3-.7.3-1.3.2-1.4-.1-.2-.3-.3-.6-.4z' />
      </svg> $ButtonText</a>
            ";};
    }
}
?>





Hintergrundbild

Speichere das Bild whatsapp-background.png im Ordner /template/images/backgrounds/.


2. Elementvorlage erstellen

  1. Gehe im Vision CMS zu Einstellungen → Konfiguration → Element Vorlagen.
  2. Erstelle eine neue Elementvorlage mit dem Namen Whatsapp_Konfiguration und füge die folgenden Felder hinzu:
FeldNameTyp
ImageAktivierenBild
Value1WhatsApp NummerText
Value2Button TextText
Value3Chat Fenster NameText
Value4Chat Fenster TextText
Value5Chat NameText
Value6Chat NachrichtCKEditor
Value7Chat Eingabe PlaceholderText

3. Widget im Template einfügen

Füge das WhatsApp-Widget in das gewünschte Template ein, wenn du es auf allen Seiten haben möchtest, füge es beim Footer hinzu.


4. Test und Anpassung

  1. CSS und JS prüfen: Stelle sicher, dass die Dateien korrekt eingebunden sind und das Widget wie erwartet angezeigt wird.
  2. Responsive Design: Passe die CSS-Definitionen bei Bedarf für mobile Geräte an.
  3. Funktionalität: Teste die Verbindung mit der angegebenen WhatsApp-Nummer.