Botão personalizado
Se você deseja integrar um botão de inscrição/cancelamento de inscrição personalizado com seu próprio design, você pode.
Esses são os recursos de pixel expostos que você pode usar no seu código JS para fazer uma integração personalizada:
await metricspush.get_subscription_status(); await metricspush.subscribe(); await metricspush.unsubscribe();
Aqui está um exemplo de integração de código que utiliza essas funções JS personalizadas:
<span id="pusher_loading">Loading status...</span> <a href="#" id="pusher_subscribe" style="display: none;">Subscribe ✅</a> <a href="#" id="pusher_unsubscribe" style="display: none;">Unsubscribe ❌</a> <script defer> let initiate_pusher_script = async () => { if(typeof pusher !== 'undefined') { clearInterval(pusher_is_loaded_interval); /* Get status of subscription */ let status = await metricspush.get_subscription_status(); /* Remove loading message */ document.querySelector('#pusher_loading').style.display = 'none'; /* Display subscribe or unsubscribe button based on the current subscription status */ if(status) { document.querySelector('#pusher_unsubscribe').style.display = 'block'; document.querySelector('#pusher_subscribe').style.display = 'none'; } else { document.querySelector('#pusher_unsubscribe').style.display = 'none'; document.querySelector('#pusher_subscribe').style.display = 'block'; } } } let pusher_is_loaded_interval = setInterval(initiate_pusher_script, 100); /* Attach simple subscribe event */ document.querySelector(`#pusher_subscribe`) && document.querySelector(`#pusher_subscribe`).addEventListener('click', async event => { event.preventDefault(); await metricspush.subscribe(event); initiate_pusher_script(); }); /* Attach simple unsubscribe event */ document.querySelector(`#pusher_unsubscribe`) && document.querySelector(`#pusher_unsubscribe`).addEventListener('click', async event => { event.preventDefault(); await metricspush.unsubscribe(event); initiate_pusher_script(); }); </script>