mirror of
https://github.com/lnbits/lnbits.git
synced 2025-07-01 11:02:56 +02:00
Add files via upload
This commit is contained in:
474
lnbits/extensions/events/templates/events/ticket.html
Normal file
474
lnbits/extensions/events/templates/events/ticket.html
Normal file
@ -0,0 +1,474 @@
|
|||||||
|
<!-- @format -->
|
||||||
|
|
||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8" />
|
||||||
|
<title>LNBits Wallet</title>
|
||||||
|
<meta
|
||||||
|
content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no"
|
||||||
|
name="viewport"
|
||||||
|
/>
|
||||||
|
<!-- Bootstrap 3.3.2 -->
|
||||||
|
<link
|
||||||
|
rel="stylesheet"
|
||||||
|
media="screen"
|
||||||
|
href="{{ url_for('static', filename='bootstrap/css/bootstrap.min.css') }}"
|
||||||
|
/>
|
||||||
|
<!-- FontAwesome 4.3.0 -->
|
||||||
|
<link
|
||||||
|
href="https://maxcdn.bootstrapcdn.com/font-awesome/4.3.0/css/font-awesome.min.css"
|
||||||
|
rel="stylesheet"
|
||||||
|
type="text/css"
|
||||||
|
/>
|
||||||
|
<!-- Ionicons 2.0.0 -->
|
||||||
|
<link
|
||||||
|
href="https://code.ionicframework.com/ionicons/2.0.0/css/ionicons.min.css"
|
||||||
|
rel="stylesheet"
|
||||||
|
type="text/css"
|
||||||
|
/>
|
||||||
|
|
||||||
|
<!-- Theme style -->
|
||||||
|
<link
|
||||||
|
rel="stylesheet"
|
||||||
|
media="screen"
|
||||||
|
href="{{ url_for('static', filename='dist/css/AdminLTE.min.css') }}"
|
||||||
|
/>
|
||||||
|
<!-- AdminLTE Skins. Choose a skin from the css/skins
|
||||||
|
folder instead of downloading all of them to reduce the load. -->
|
||||||
|
|
||||||
|
<link
|
||||||
|
rel="stylesheet"
|
||||||
|
media="screen"
|
||||||
|
href="{{ url_for('static', filename='dist/css/skins/_all-skins.min.css') }}"
|
||||||
|
/>
|
||||||
|
|
||||||
|
<!-- Morris chart -->
|
||||||
|
<link
|
||||||
|
rel="stylesheet"
|
||||||
|
media="screen"
|
||||||
|
href="{{ url_for('static', filename='plugins/morris/morris.css') }}"
|
||||||
|
/>
|
||||||
|
|
||||||
|
<!-- jvectormap -->
|
||||||
|
<link
|
||||||
|
rel="stylesheet"
|
||||||
|
media="screen"
|
||||||
|
href="{{ url_for('static', filename='plugins/jvectormap/jquery-jvectormap-1.2.2.css') }}"
|
||||||
|
/>
|
||||||
|
|
||||||
|
<!-- bootstrap wysihtml5 - text editor -->
|
||||||
|
<link
|
||||||
|
rel="stylesheet"
|
||||||
|
media="screen"
|
||||||
|
href="{{ url_for('static', filename='plugins/bootstrap-wysihtml5/bootstrap3-wysihtml5.min.css') }}"
|
||||||
|
/>
|
||||||
|
|
||||||
|
<!-- HTML5 Shim and Respond.js IE8 support of HTML5 elements and media queries -->
|
||||||
|
<!-- WARNING: Respond.js doesn't work if you view the page via file:// -->
|
||||||
|
<!--[if lt IE 9]>
|
||||||
|
<script src="https://oss.maxcdn.com/libs/html5shiv/3.7.0/html5shiv.js"></script>
|
||||||
|
<script src="https://oss.maxcdn.com/libs/respond.js/1.3.0/respond.min.js"></script>
|
||||||
|
<![endif]-->
|
||||||
|
|
||||||
|
<style>
|
||||||
|
.small-box > .small-box-footer {
|
||||||
|
text-align: left;
|
||||||
|
padding-left: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#loadingMessage {
|
||||||
|
text-align: center;
|
||||||
|
padding: 40px;
|
||||||
|
background-color: #eee;
|
||||||
|
}
|
||||||
|
|
||||||
|
#canvas {
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
#output {
|
||||||
|
margin-top: 20px;
|
||||||
|
background: #eee;
|
||||||
|
padding: 10px;
|
||||||
|
padding-bottom: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#output div {
|
||||||
|
padding-bottom: 10px;
|
||||||
|
word-wrap: break-word;
|
||||||
|
}
|
||||||
|
|
||||||
|
#noQRFound {
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|
||||||
|
<!-- jQuery 2.1.3 -->
|
||||||
|
<script src="{{ url_for('static', filename='plugins/jQuery/jQuery-2.1.3.min.js') }}"></script>
|
||||||
|
<!-- jQuery UI 1.11.2 -->
|
||||||
|
<script
|
||||||
|
src="https://code.jquery.com/ui/1.11.2/jquery-ui.min.js"
|
||||||
|
type="text/javascript"
|
||||||
|
></script>
|
||||||
|
<!-- Resolve conflict in jQuery UI tooltip with Bootstrap tooltip -->
|
||||||
|
<script>
|
||||||
|
$.widget.bridge('uibutton', $.ui.button)
|
||||||
|
</script>
|
||||||
|
<!-- Bootstrap 3.3.2 JS -->
|
||||||
|
<script
|
||||||
|
src="{{ url_for('static', filename='bootstrap/js/bootstrap.min.js') }}"
|
||||||
|
type="text/javascript"
|
||||||
|
></script>
|
||||||
|
<!-- Morris.js charts -->
|
||||||
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/raphael/2.1.0/raphael-min.js"></script>
|
||||||
|
<script
|
||||||
|
src="{{ url_for('static', filename='plugins/morris/morris.min.js') }}"
|
||||||
|
type="text/javascript"
|
||||||
|
></script>
|
||||||
|
<!-- Sparkline -->
|
||||||
|
<script
|
||||||
|
src="{{ url_for('static', filename='plugins/sparkline/jquery.sparkline.min.js') }}"
|
||||||
|
type="text/javascript"
|
||||||
|
></script>
|
||||||
|
<!-- jvectormap -->
|
||||||
|
<script
|
||||||
|
src="{{ url_for('static', filename='plugins/jvectormap/jquery-jvectormap-1.2.2.min.js') }}"
|
||||||
|
type="text/javascript"
|
||||||
|
></script>
|
||||||
|
<script
|
||||||
|
src="{{ url_for('static', filename='plugins/jvectormap/jquery-jvectormap-world-mill-en.js') }}"
|
||||||
|
type="text/javascript"
|
||||||
|
></script>
|
||||||
|
<!-- jQuery Knob Chart -->
|
||||||
|
<script
|
||||||
|
src="{{ url_for('static', filename='plugins/knob/jquery.knob.js') }}"
|
||||||
|
type="text/javascript"
|
||||||
|
></script>
|
||||||
|
<!-- Bootstrap WYSIHTML5 -->
|
||||||
|
<script
|
||||||
|
src="{{ url_for('static', filename='plugins/bootstrap-wysihtml5/bootstrap3-wysihtml5.all.min.js') }}"
|
||||||
|
type="text/javascript"
|
||||||
|
></script>
|
||||||
|
<!-- Slimscroll -->
|
||||||
|
<script
|
||||||
|
src="{{ url_for('static', filename='plugins/slimScroll/jquery.slimscroll.min.js') }}"
|
||||||
|
type="text/javascript"
|
||||||
|
></script>
|
||||||
|
<!-- FastClick -->
|
||||||
|
<script src="{{ url_for('static', filename='plugins/fastclick/fastclick.min.js') }}"></script>
|
||||||
|
<!-- AdminLTE App -->
|
||||||
|
<script
|
||||||
|
src="{{ url_for('static', filename='dist/js/app.min.js') }}"
|
||||||
|
type="text/javascript"
|
||||||
|
></script>
|
||||||
|
|
||||||
|
<!-- AdminLTE dashboard demo (This is only for demo purposes) -->
|
||||||
|
<script
|
||||||
|
src="{{ url_for('static', filename='dist/js/pages/dashboard.js') }}"
|
||||||
|
type="text/javascript"
|
||||||
|
></script>
|
||||||
|
|
||||||
|
<!-- AdminLTE for demo purposes -->
|
||||||
|
<script
|
||||||
|
src="{{ url_for('static', filename='dist/js/demo.js') }}"
|
||||||
|
type="text/javascript"
|
||||||
|
></script>
|
||||||
|
|
||||||
|
<script
|
||||||
|
src="{{ url_for('static', filename='plugins/datatables/jquery.dataTables.js') }}"
|
||||||
|
type="text/javascript"
|
||||||
|
></script>
|
||||||
|
<link
|
||||||
|
rel="stylesheet"
|
||||||
|
href="//cdnjs.cloudflare.com/ajax/libs/morris.js/0.5.1/morris.css"
|
||||||
|
/>
|
||||||
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/raphael/2.1.0/raphael-min.js"></script>
|
||||||
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/morris.js/0.5.1/morris.min.js"></script>
|
||||||
|
<script
|
||||||
|
src="{{ url_for('static', filename='plugins/jscam/JS.js') }}"
|
||||||
|
type="text/javascript"
|
||||||
|
></script>
|
||||||
|
<script
|
||||||
|
src="{{ url_for('static', filename='plugins/jscam/qrcode.min.js') }}"
|
||||||
|
type="text/javascript"
|
||||||
|
></script>
|
||||||
|
<script
|
||||||
|
src="{{ url_for('static', filename='plugins/bolt11/decoder.js') }}"
|
||||||
|
type="text/javascript"
|
||||||
|
></script>
|
||||||
|
<script
|
||||||
|
src="{{ url_for('static', filename='plugins/bolt11/utils.js') }}"
|
||||||
|
type="text/javascript"
|
||||||
|
></script>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<style>
|
||||||
|
|
||||||
|
//GOOFY CSS HACK TO GO DARK
|
||||||
|
|
||||||
|
.skin-blue .wrapper {
|
||||||
|
background:
|
||||||
|
#1f2234;
|
||||||
|
}
|
||||||
|
|
||||||
|
body {
|
||||||
|
color: #fff;
|
||||||
|
}
|
||||||
|
|
||||||
|
.skin-blue .sidebar-menu > li.active > a {
|
||||||
|
color: #fff;
|
||||||
|
background:#1f2234;
|
||||||
|
border-left-color:#8964a9;
|
||||||
|
}
|
||||||
|
|
||||||
|
.skin-blue .main-header .navbar {
|
||||||
|
background-color:
|
||||||
|
#2e507d;
|
||||||
|
}
|
||||||
|
|
||||||
|
.content-wrapper, .right-side {
|
||||||
|
background-color:
|
||||||
|
#1f2234;
|
||||||
|
}
|
||||||
|
.skin-blue .main-header .logo {
|
||||||
|
background-color:
|
||||||
|
#1f2234;
|
||||||
|
color:
|
||||||
|
#fff;
|
||||||
|
}
|
||||||
|
|
||||||
|
.skin-blue .sidebar-menu > li.header {
|
||||||
|
color:
|
||||||
|
#4b646f;
|
||||||
|
background:
|
||||||
|
#1f2234;
|
||||||
|
}
|
||||||
|
.skin-blue .wrapper, .skin-blue .main-sidebar, .skin-blue .left-side {
|
||||||
|
background:
|
||||||
|
#1f2234;
|
||||||
|
}
|
||||||
|
|
||||||
|
.skin-blue .sidebar-menu > li > .treeview-menu {
|
||||||
|
margin: 0 1px;
|
||||||
|
background:
|
||||||
|
#1f2234;
|
||||||
|
}
|
||||||
|
|
||||||
|
.skin-blue .sidebar-menu > li > a {
|
||||||
|
border-left: 3px solid
|
||||||
|
transparent;
|
||||||
|
margin-right: 1px;
|
||||||
|
}
|
||||||
|
.skin-blue .sidebar-menu > li > a:hover, .skin-blue .sidebar-menu > li.active > a {
|
||||||
|
|
||||||
|
color: #fff;
|
||||||
|
background:#3e355a;
|
||||||
|
border-left-color:#8964a9;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
.skin-blue .main-header .logo:hover {
|
||||||
|
background:
|
||||||
|
#3e355a;
|
||||||
|
}
|
||||||
|
|
||||||
|
.skin-blue .main-header .navbar .sidebar-toggle:hover {
|
||||||
|
background-color:
|
||||||
|
#3e355a;
|
||||||
|
}
|
||||||
|
.main-footer {
|
||||||
|
background-color: #1f2234;
|
||||||
|
padding: 15px;
|
||||||
|
color: #fff;
|
||||||
|
border-top: 0px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.skin-blue .main-header .navbar {
|
||||||
|
background-color: #1f2234;
|
||||||
|
}
|
||||||
|
|
||||||
|
.bg-red, .callout.callout-danger, .alert-danger, .alert-error, .label-danger, .modal-danger .modal-body {
|
||||||
|
background-color:
|
||||||
|
#1f2234 !important;
|
||||||
|
}
|
||||||
|
.alert-danger, .alert-error {
|
||||||
|
|
||||||
|
border-color: #fff;
|
||||||
|
border: 1px solid
|
||||||
|
|
||||||
|
#fff;
|
||||||
|
border-radius: 7px;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
.skin-blue .main-header .navbar .nav > li > a:hover, .skin-blue .main-header .navbar .nav > li > a:active, .skin-blue .main-header .navbar .nav > li > a:focus, .skin-blue .main-header .navbar .nav .open > a, .skin-blue .main-header .navbar .nav .open > a:hover, .skin-blue .main-header .navbar .nav .open > a:focus {
|
||||||
|
color:
|
||||||
|
#f6f6f6;
|
||||||
|
background-color: #3e355a;
|
||||||
|
}
|
||||||
|
.bg-aqua, .callout.callout-info, .alert-info, .label-info, .modal-info .modal-body {
|
||||||
|
background-color:
|
||||||
|
#3e355a !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.box {
|
||||||
|
position: relative;
|
||||||
|
border-radius: 3px;
|
||||||
|
background-color: #333646;
|
||||||
|
border-top: 3px solid #8964a9;
|
||||||
|
margin-bottom: 20px;
|
||||||
|
width: 100%;
|
||||||
|
|
||||||
|
}
|
||||||
|
.table-striped > tbody > tr:nth-of-type(2n+1) {
|
||||||
|
background-color:
|
||||||
|
#333646;
|
||||||
|
}
|
||||||
|
|
||||||
|
.box-header {
|
||||||
|
color: #fff;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
.box.box-danger {
|
||||||
|
border-top-color: #8964a9;
|
||||||
|
}
|
||||||
|
.box.box-primary {
|
||||||
|
border-top-color: #8964a9;
|
||||||
|
}
|
||||||
|
|
||||||
|
a {
|
||||||
|
color: #8964a9;
|
||||||
|
}
|
||||||
|
.box-header.with-border {
|
||||||
|
border-bottom: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
a:hover, a:active, a:focus {
|
||||||
|
outline: none;
|
||||||
|
text-decoration: none;
|
||||||
|
color: #fff;
|
||||||
|
}
|
||||||
|
// .modal.in .modal-dialog{
|
||||||
|
// color:#000;
|
||||||
|
// }
|
||||||
|
|
||||||
|
.form-control {
|
||||||
|
|
||||||
|
background-color:#333646;
|
||||||
|
color: #fff;
|
||||||
|
|
||||||
|
}
|
||||||
|
.box-footer {
|
||||||
|
|
||||||
|
border-top: none;
|
||||||
|
|
||||||
|
background-color:
|
||||||
|
#333646;
|
||||||
|
}
|
||||||
|
.modal-footer {
|
||||||
|
|
||||||
|
border-top: none;
|
||||||
|
|
||||||
|
}
|
||||||
|
.modal-content {
|
||||||
|
|
||||||
|
background-color:
|
||||||
|
#333646;
|
||||||
|
}
|
||||||
|
.modal.in .modal-dialog {
|
||||||
|
|
||||||
|
background-color: #333646;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
.layout-boxed {
|
||||||
|
background: none;
|
||||||
|
background-color: rgba(0, 0, 0, 0);
|
||||||
|
background-color:
|
||||||
|
#3e355a;
|
||||||
|
}
|
||||||
|
|
||||||
|
.skin-blue .sidebar-menu > li > a:hover, .skin-blue .sidebar-menu > li.active > a {
|
||||||
|
|
||||||
|
background: none;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|
||||||
|
|
||||||
|
</head>
|
||||||
|
<body class="skin-blue layout-boxed sidebar-collapse sidebar-open">
|
||||||
|
<div class="wrapper">
|
||||||
|
<header class="main-header">
|
||||||
|
<!-- Logo -->
|
||||||
|
<a href="{{ url_for('core.home') }}" class="logo"><b>LN</b>bits</a>
|
||||||
|
<!-- Header Navbar: style can be found in header.less -->
|
||||||
|
<nav class="navbar navbar-static-top" role="navigation">
|
||||||
|
<!-- Sidebar toggle button-->
|
||||||
|
<a
|
||||||
|
href="#"
|
||||||
|
class="sidebar-toggle"
|
||||||
|
data-toggle="offcanvas"
|
||||||
|
role="button"
|
||||||
|
>
|
||||||
|
<span class="sr-only">Toggle navigation</span>
|
||||||
|
</a>
|
||||||
|
<div class="navbar-custom-menu">
|
||||||
|
<ul class="nav navbar-nav">
|
||||||
|
<!-- Messages: style can be found in dropdown.less-->
|
||||||
|
<li class="dropdown messages-menu">
|
||||||
|
|
||||||
|
{% block messages %}{% endblock %}
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</nav>
|
||||||
|
</header>
|
||||||
|
|
||||||
|
<aside class="main-sidebar">
|
||||||
|
<!-- sidebar: style can be found in sidebar.less -->
|
||||||
|
<section class="sidebar" style="height: auto;">
|
||||||
|
|
||||||
|
</section>
|
||||||
|
<!-- /.sidebar -->
|
||||||
|
</aside>
|
||||||
|
|
||||||
|
<!-- Right side column. Contains the navbar and content of the page -->
|
||||||
|
<div class="content-wrapper">
|
||||||
|
<!-- Content Header (Page header) -->
|
||||||
|
<section class="content-header">
|
||||||
|
<h1>
|
||||||
|
LNBits Events
|
||||||
|
<small>Lightning powered tickets</small>
|
||||||
|
</h1>
|
||||||
|
|
||||||
|
</section>
|
||||||
|
|
||||||
|
<!-- Main content -->
|
||||||
|
<section class="content"><br/><br/>
|
||||||
|
|
||||||
|
<center><h2 style="width:70%;font-size:400%" >Bookmark/Screenshot this page. <br/>It is your ticket!</h2></center>
|
||||||
|
<center> <div style="width:340px;background-color:white;padding:20px"id="qrcode"></div></center>
|
||||||
|
|
||||||
|
|
||||||
|
</section><!-- /.content -->
|
||||||
|
</div><!-- /.content-wrapper -->
|
||||||
|
</div>
|
||||||
|
</body>
|
||||||
|
<script>
|
||||||
|
new QRCode(document.getElementById('qrcode'), {
|
||||||
|
text: "{{ticket}}",
|
||||||
|
width: 300,
|
||||||
|
height: 300,
|
||||||
|
colorDark: '#000000',
|
||||||
|
colorLight: '#ffffff',
|
||||||
|
correctLevel: QRCode.CorrectLevel.M
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
|
</script>
|
||||||
|
</html>
|
Reference in New Issue
Block a user