Mercurial > prosody-modules
diff mod_invites_page/html/invite.html @ 4094:dd00a2b9927c
mod_invites_page: New module to generate landing page for invites
author | Matthew Wild <mwild1@gmail.com> |
---|---|
date | Fri, 11 Sep 2020 13:52:32 +0100 |
parents | |
children | 82b02f85ac31 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/mod_invites_page/html/invite.html Fri Sep 11 13:52:32 2020 +0100 @@ -0,0 +1,177 @@ +<!DOCTYPE html> +<html> +<head> + <meta charset="utf-8"> + <meta name="viewport" content="width=device-width, initial-scale=1.0"> + <title>Invite to {site_name}</title> + <link rel="alternate" href="{uri}"> + <link rel="stylesheet" href="/share/bootstrap4/css/bootstrap.min.css"> + <link rel="apple-touch-icon" sizes="180x180" href="/apple-touch-icon.png"> + <link rel="icon" type="image/png" sizes="32x32" href="/favicon-32x32.png"> + <link rel="icon" type="image/png" sizes="16x16" href="/favicon-16x16.png"> + <link rel="manifest" href="/site.webmanifest"> + <link rel="mask-icon" href="/safari-pinned-tab.svg" color="#5bbad5"> + <meta name="msapplication-TileColor" content="#fbd308"> + <meta name="theme-color" content="#fbd308"> +</head> +<body> + <div id="background" class="fixed-top overflow-hidden" aria-role="none presentation"></div> + <div id="form" class="container col-md-10 col-md-offset-1 col-sm-8 col-sm-offset-2 col-lg-10 col-lg-offset-1 mt-2 mt-md-5"> + <div class="card rounded-lg shadow"> + <h1 class="card-header rounded-lg rounded-lg"> + Invite to {site_name}<br/> + </h1> + <div class="card-body" > + <div id="qr-button-container" class="float-right w-25 border border-info p-3 d-none"> + <strong>Tip:</strong> You can open this invite + on your mobile device by scanning a barcode with + your camera. + <a href="#qr-modal" class="mt-2 d-block" id="qr-modal-show"> + <button class="btn btn-info" title="Send this invite to your device" + data-toggle="modal" data-target="#qr-modal"> + <img src="{static}/qr-logo.png" class="align-middle h-50 mt-1" style="display:inline" > + Scan with mobile device + </button> + </a> + </div> + + {inviter?<p>You have been invited to chat on {site_name} using XMPP, + a secure and decentralized messaging network.</p>} + + {inviter&<p>You have been invited to chat with {inviter} on {site_name}, + part of the XMPP secure and decentralized messaging network.</p>} + + <h5 class="card-title" style="clear:both">Get started</h5> + + <p>To get started, you need to install an app for your platform:</p> + + <div class="container"> + <div class="row"> + {apps# + <div class="card m-3 client-card {item.platforms#app-platform-{item|lower|classname} } flex-wrap col-sm-12 col-md-8 col-lg-5"> + <div class="row no-gutters h-100"> + <div class="col-md-4"> + <img src="{item.image|relurl}" class="p-2 img-fluid" alt="{item.imagetext?}"> + </div> + <div class="col-md-8 h-100"> + <div class="card-body d-flex flex-column h-100"> + <h5 class="card-title text-nowrap mb-1">{item.name}</h5> + <div> + {item.platforms#<span class="badge badge-info client-platform-badge client-platform-badge-{item|lower|classname} mr-1 mb-3">{item}</span> } + </div> + <p class="card-text">{item.text}</p> + <a href="{item.proceed_url?#}" class="btn btn-primary mt-md-auto">Install</a> + </div> + </div> + </div> + </div> + } + </div> + </div> + + <div id="show-all-clients-button-container" class="d-none alert alert-info"> + Showing apps for <span class="platform-name">your current platform</span> only. You may also <a href="#" id="show-all-clients-button">view all apps.</a> + </div> + + <div id="install-buttons-container" class="container mt-2 text-center"> + </div> + + <h6 class="text-center">Already have a compatible app installed?</h6> + + <div class="text-center"> + <a href="{uri}" id="uri-cta"><button class="btn btn-secondary btn-sm">Open the app</button></a><br/> + <small class="text-muted">This button works only if you have a compatible app installed already!</small> + </div> + <br/> + <h5>Other software</h5> + <p>You can connect to {site_name} using any XMPP-compatible software. If the button above does not + work with your app, you may need to <a href="register?t={token}">register an account manually</a>.</p> + </div> + </div> + </div> + + <div class="modal" tabindex="-1" role="dialog" id="qr-modal"> + <div class="modal-dialog" role="document"> + <div class="modal-content"> + <div class="modal-header"> + <h5 class="modal-title">Scan invite code</h5> + <button type="button" class="close" data-dismiss="modal" aria-label="Close"> + <span aria-hidden="true">×</span> + </button> + </div> + <div class="modal-body"> + <p>You can transfer this invite to your mobile device by scanning a code with your camera.</p> + <div id="qr-info-url" class="tab-pane show active"> + <p>Use a <em>QR code</em> scanner on your mobile device to scan the code below:</p> + <div id="qr-invite-page" class="w-50 p-1 mx-auto"></div> + </div> + <div class="modal-footer"> + <button type="button" class="btn btn-primary" data-dismiss="modal">Close</button> + </div> + </div> + </div> + </div> + + <script src="/share/jquery/jquery.min.js"></script> + <script src="/share/bootstrap4/js/bootstrap.min.js"></script> + <script src="{static}/qrcode.min.js"></script> + <script src="{static}/platform.min.js"></script> + <script type="text/javascript"> + $(function () { + // If QR lib loaded ok, show QR button on desktop devices + if(window.QRCode) { + $('#qr-modal').one('show.bs.modal', function (e) { + new QRCode(document.getElementById("qr-invite-page"), document.location.href); + }); + $('#qr-button-container').addClass("d-md-block"); + } + + // Detect current platform and show/hide appropriate clients + if(window.platform) { + var platform_friendly = null; + var 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 "Windows Phone": + platform_friendly = "Windows Phone"; + platform_classname = "windows-phone"; + break; + default: + if(platform.os.family.startsWith("Windows")) { + platform_friendly = "Windows"; + platform_classname = "windows"; + } + } + + if(platform_friendly && platform_classname) { + // Hide clients not for this platform + $('.client-card.app-platform-'+platform_classname).addClass("supported-platform"); + $('.client-card').not(".supported-platform").hide(); + $('.client-card .client-platform-badge') + .not(".client-platform-badge-"+platform_classname) + .addClass("badge-secondary") + .removeClass("badge-info"); + $('.client-card .client-platform-badge-'+platform_classname) + .addClass("badge-success") + .removeClass("badge-info"); + $('#show-all-clients-button-container .platform-name').text(platform_friendly); + $('#show-all-clients-button-container').removeClass("d-none"); + $('#show-all-clients-button').click(function () { + $('.client-card').show(); + $('#show-all-clients-button-container').hide(); + }); + } + } + }); + + </script> +</body> +</html>