Mercurial > prosody-modules
view mod_invites_page/static/invite.js @ 5907:d194d1012fd3
Updating dox for mod_rest. Ideas expressed / clarified:
1) Making clear that mod_rest isn't to be installed under VirtualHosts AND as a component.
2) Understanding some of the implications of this choice:
A) Changes to user authentication
B) How it affects subdomains
3) More consistent use of domain names for clarity.
4) Using different heading sizes to show scope of section.
Essentially, I added all the tidbits I had to clarify in getting this to work in my
own example.
author | Ben Smith <bens@effortlessis.com> |
---|---|
date | Mon, 13 May 2024 13:25:13 -0700 |
parents | ef3aa6901a93 |
children |
line wrap: on
line source
(function () { // If QR lib loaded ok, show QR button on desktop devices if(window.QRCode) { new QRCode(document.getElementById("qr-invite-page"), document.location.href); document.getElementById('qr-button-container').classList.add("d-md-block"); } // Detect current platform and show/hide appropriate clients if(window.platform) { let platform_friendly = null; let platform_classname = null; switch(platform.os.family) { case "Ubuntu": case "Linux": case "Fedora": case "Red Hat": case "SuSE": platform_friendly = platform.os.family + " (Linux)"; platform_classname = "linux"; break; case "Linux aarch64": platform_friendly = "Linux mobile"; platform_classname = "linux"; break; case "Haiku R1": platform_friendly = "Haiku"; platform_classname = "haiku"; break; case "Windows Phone": platform_friendly = "Windows Phone"; platform_classname = "windows-phone"; break; default: if(platform.os.family.startsWith("Windows")) { platform_friendly = "Windows"; platform_classname = "windows"; } else { platform_friendly = platform.os.family; platform_classname = platform_friendly.toLowerCase(); } } if(platform_friendly && platform_classname) { if(document.querySelectorAll('.client-card .client-platform-badge-'+platform_classname).length == 0) { // No clients recognised for this platform, do nothing return; } // Hide clients not for this platform const client_cards = document.getElementsByClassName('client-card'); for (let card of client_cards) { if (card.classList.contains('app-platform-'+platform_classname)) card.classList.add('supported-platform'); else if (!card.classList.contains('app-platform-web')) card.hidden = true; const badges = card.querySelectorAll('.client-platform-badge'); for (let badge of badges) { if (badge.classList.contains('client-platform-badge-'+platform_classname)) { badge.classList.add("badge-success"); badge.classList.remove("badge-info"); } else { badge.classList.add("badge-secondary"); badge.classList.remove("badge-info"); } } } const show_all_clients_button_container = document.getElementById('show-all-clients-button-container'); show_all_clients_button_container.querySelector('.platform-name').innerHTML = platform_friendly; show_all_clients_button_container.classList.remove("d-none"); document.getElementById('show-all-clients-button').addEventListener('click', function (e) { for (let card of client_cards) card.hidden = false; show_all_clients_button_container.hidden = true; e.preventDefault(); }); } } })();