ti-powerbar/app/templates/index.html

309 lines
16 KiB
HTML
Raw Normal View History

2023-11-19 01:30:54 +00:00
<!DOCTYPE html>
2023-11-19 16:06:40 +00:00
<html lang="en">
2023-11-19 01:30:54 +00:00
<head>
2023-11-19 16:06:40 +00:00
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>powerbar.ti</title>
<!-- Bootstrap CSS -->
<!-- Font Awesome -->
<link
href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0/css/all.min.css"
rel="stylesheet"
/>
<!-- Google Fonts -->
<link
href="https://fonts.googleapis.com/css?family=Roboto:300,400,500,700&display=swap"
rel="stylesheet"
/>
<!-- MDB -->
<link
href="https://cdnjs.cloudflare.com/ajax/libs/mdb-ui-kit/6.4.2/mdb.min.css"
rel="stylesheet"
/>
2023-11-19 01:30:54 +00:00
2023-11-19 16:06:40 +00:00
</head>
<style>
/* The switch - the box around the slider */
.switch {
position: relative;
display: inline-block;
width: 60px;
height: 34px;
}
/* Hide default HTML checkbox */
.switch input {display:none;}
/* The slider */
.slider {
position: absolute;
cursor: pointer;
top: 0;
left: 0;
right: 0;
bottom: 0;
background-color: #ccc;
-webkit-transition: .4s;
transition: .4s;
}
.slider:before {
position: absolute;
content: "";
height: 26px;
width: 26px;
left: 4px;
bottom: 4px;
background-color: white;
-webkit-transition: .4s;
transition: .4s;
}
input.default:checked + .slider {
background-color: #444;
}
input.primary:checked + .slider {
background-color: #2196F3;
}
input.success:checked + .slider {
background-color: #8bc34a;
}
input.info:checked + .slider {
background-color: #3de0f5;
}
input.warning:checked + .slider {
background-color: #FFC107;
}
input.danger:checked + .slider {
background-color: #f44336;
}
input:focus + .slider {
box-shadow: 0 0 1px #2196F3;
}
input:checked + .slider:before {
-webkit-transform: translateX(26px);
-ms-transform: translateX(26px);
transform: translateX(26px);
}
/* Rounded sliders */
.slider.round {
border-radius: 34px;
}
.slider.round:before {
border-radius: 50%;
}
</style>
2023-11-19 01:30:54 +00:00
2023-11-19 01:42:51 +00:00
2023-11-19 16:06:40 +00:00
<body>
<div class="container">
2024-02-28 19:10:53 +00:00
<h1 class="mt-3"> <img style="height: 50px; width: 50px;" src="
2023-11-19 16:06:40 +00:00
<hr>
2023-11-19 16:53:35 +00:00
<div class="alert alert-primary" role="alert">
2023-11-22 09:09:11 +00:00
For the API vist '/powerbars' and '/groups' | A project brought to you by Piele & Mattronix for the code vist <a href="https://code.techinc.nl/techinc/ti-powerbar">code.techinc.nl</a>
2023-11-19 16:53:35 +00:00
</div>
2024-02-08 00:35:37 +00:00
<div class="alert alert-danger" role="alert">
Power Outlets take up to 6 Seconds to Toggle due to consistency over speed (double clicking issue is resolved by this delay)
</div>
2023-11-19 16:06:40 +00:00
</div>
2023-11-19 01:42:51 +00:00
2023-11-19 16:06:40 +00:00
<div class="mt-4 container">
<div class="card">
<div class="input-group">
<div class="form-outline">
<input type="search" id="searchInput" class="form-control" ,placehholder="Search Outlet"/>
<label class="form-label" for="form1">Search</label>
</div>
<button type="button" class="btn btn-primary">
<i class="fas fa-search"></i>
</button>
</div>
</div>
</div>
2023-11-19 01:42:51 +00:00
2023-11-19 16:06:40 +00:00
<div class="container">
<div class="row">
{% for powerbar in powerbars.items() %}
<div class="col-md-4">
<div class="col-md-12">
<div class="card" style="margin:10px 0">
<!-- Default panel contents -->
<div class="card-header"><h2>{{powerbar[1].name}}</h2></div>
<!-- List group -->
<ul class="list-group list-group-flush">
{% for outlet in powerbar[1].outlets.items() %}
2024-01-27 15:01:13 +00:00
{% if not outlet[1].password %}
2023-11-19 16:06:40 +00:00
<li class="list-group-item">
<div class="row">
2023-11-20 12:35:33 +00:00
<div class="col-md-8">{{outlet[1].name}}<br><span class="badge badge-secondary">Outlet: {{outlet[0]}}</span>
{% if outlet[1].state == "on" %}
2023-12-02 18:00:33 +00:00
<span id="{{powerbar[0]}}-{{outlet[0]}}-badge" class="badge badge-success">On</span>
2023-11-20 12:35:33 +00:00
{% else %}
2023-12-02 18:00:33 +00:00
<span id="{{powerbar[0]}}-{{outlet[0]}}-badge" class="badge badge-danger">Off</span>
2023-11-20 12:35:33 +00:00
{% endif %}</div>
2023-11-19 20:33:17 +00:00
<div class="col-md-2">
2023-11-19 16:06:40 +00:00
<label class="switch">
{% if outlet[1].state == "on" %}
2024-02-02 12:59:17 +00:00
<input type="checkbox" class="default" id="{{powerbar[0]}}-{{outlet[0]}}" onchange="toggleOutlet('{{powerbar[0]}}-{{outlet[0]}}', '/{{powerbar[0]}}/{{outlet[0]}}/on', '/{{powerbar[0]}}/{{outlet[0]}}/off', this.checked)" checked>
2023-11-19 16:06:40 +00:00
{% else %}
2024-02-02 12:59:17 +00:00
<input type="checkbox" class="default" id="{{powerbar[0]}}-{{outlet[0]}}" onchange="toggleOutlet('{{powerbar[0]}}-{{outlet[0]}}', '/{{powerbar[0]}}/{{outlet[0]}}/on', '/{{powerbar[0]}}/{{outlet[0]}}/off', this.checked)">
2023-11-19 16:06:40 +00:00
{% endif %}
2024-02-02 12:59:17 +00:00
<span id="{{powerbar[0]}}-{{outlet[0]}}-slider" class="slider"></span>
2023-11-19 16:06:40 +00:00
</label>
</div>
2023-11-19 17:00:11 +00:00
<div class="col-md-2">
</div>
2023-11-19 16:06:40 +00:00
</div>
</li>
2024-01-27 15:01:13 +00:00
{% endif %}
2023-11-19 16:06:40 +00:00
{% endfor %}
</ul>
</ul>
</div>
</div>
</div>
{% endfor %}
2023-11-19 16:49:38 +00:00
{% if all_groups %}
<div class="col-md-4">
<div class="col-md-12">
<div class="card" style="margin:10px 0">
<div class="card-header"><h2>Groups</h2></div>
2023-11-19 16:51:36 +00:00
<ul class="list-group list-group-flush">
2023-11-19 16:49:38 +00:00
{% for group in all_groups %}
<li class="list-group-item">
<div class="row">
2023-11-19 16:51:36 +00:00
<div class="col-md-6">{{group.name}}</div>
<div class="col-md-6">
2023-11-19 16:49:38 +00:00
<div class="btn-group" role="group" aria-label="Powerbar Controls">
2023-11-22 09:09:11 +00:00
<button class="btn btn-success" onclick="getUrl('/groups/{{group.name}}/off')">Off</button>
<button class="btn btn-primary" onclick="getUrl('/groups/{{group.name}}/on')">On</button>
2023-11-19 16:49:38 +00:00
</div>
</div>
</div>
</li>
{% endfor %}
2023-11-19 16:51:36 +00:00
</ul>
2023-11-19 16:49:38 +00:00
</div>
</div>
{% endif %}
2023-11-19 01:42:51 +00:00
</div>
</div>
2023-11-19 01:30:54 +00:00
2023-11-19 16:06:40 +00:00
<!-- Bootstrap JS -->
2023-12-02 17:17:42 +00:00
<script src="https://cdnjs.cloudflare.com/ajax/libs/socket.io/4.7.2/socket.io.js"></script>
<script>
document.addEventListener('DOMContentLoaded', function () {
// Connect to the /powerupdates namespace
var socket = io.connect('http://' + document.domain + ':' + location.port + '/powerupdates');
// Listen for messages from the server in the /powerupdates namespace
2023-12-02 18:00:33 +00:00
socket.on('power-event', function (message) {
2023-12-02 17:17:42 +00:00
console.log('Received message from server in /powerupdates namespace:', message);
2023-12-02 18:00:33 +00:00
checkboxid = message.powerbar + "-" + message.outlet;
badgeid = message.powerbar + "-" + message.outlet + "-badge";
2024-02-02 12:59:17 +00:00
sliderid = message.powerbar + "-" + message.outlet + "-slider";
2023-12-02 18:00:33 +00:00
var checkbox = document.getElementById(checkboxid);
var badge = document.getElementById(badgeid);
2024-02-02 12:59:17 +00:00
var slider = document.getElementById(sliderid);
2023-12-02 18:00:33 +00:00
if (message.action == "on") {
2023-12-02 18:13:06 +00:00
checkbox.setAttribute('checked','');
2023-12-02 18:00:33 +00:00
badge.textContent = "On";
badge.classList.replace("badge-danger","badge-success");
} else {
2024-02-02 12:59:17 +00:00
console.log(checkbox)
2023-12-02 18:00:33 +00:00
checkbox.removeAttribute('checked');
badge.textContent = "Off";
badge.classList.replace("badge-success","badge-danger");
}
2023-12-02 17:17:42 +00:00
});
});
</script>
2023-11-19 01:30:54 +00:00
<script>
2023-11-19 16:49:38 +00:00
function getUrl(url) {
return fetch(url)
2023-11-19 16:06:40 +00:00
.then(response => {
if (response.ok) {
2023-11-19 16:49:38 +00:00
console.log('GET request successful');
return response.json(); // Return the response as JSON
2023-11-19 16:06:40 +00:00
} else {
2023-11-19 16:49:38 +00:00
console.error('Failed to make GET request');
2023-11-19 16:06:40 +00:00
}
2023-11-19 01:46:47 +00:00
})
.catch(error => {
2023-11-19 16:49:38 +00:00
console.error('An error occurred while making GET request:', error);
});
}
2024-02-02 12:59:17 +00:00
function toggleOutlet(id, on_url, off_url, checked) {
2023-11-19 16:49:38 +00:00
const url = checked ? on_url : off_url;
2024-02-02 12:59:17 +00:00
checkboxid = id;
var checkbox = document.getElementById(checkboxid);
if (checked) {
checkbox.setAttribute('checked','');
} else {
checkbox.removeAttribute('checked');
}
2023-11-19 16:49:38 +00:00
getUrl(url)
.then(data => {
// Handle the response data
console.log('Response data:', data);
2023-11-19 01:46:47 +00:00
});
}
2023-11-19 16:06:40 +00:00
</script>
2023-11-19 01:30:54 +00:00
2023-11-19 16:06:40 +00:00
</body>
</html>
<!-- Add an input field for search -->
2023-11-19 01:42:51 +00:00
2023-11-19 16:06:40 +00:00
<script>
function search() {
// Get the input value
const searchValue = document.getElementById('searchInput').value.toLowerCase();
2023-11-19 01:50:13 +00:00
2023-11-19 16:06:40 +00:00
// Get all the list items
const listItems = document.querySelectorAll('li');
2023-11-19 01:42:51 +00:00
2023-11-19 16:06:40 +00:00
// Loop through each list item
listItems.forEach(item => {
const itemText = item.textContent.toLowerCase();
2023-11-19 01:42:51 +00:00
2023-11-19 16:06:40 +00:00
// Check if the item text contains the search value
if (itemText.includes(searchValue)) {
item.style.display = 'block'; // Show the item
} else {
item.style.display = 'none'; // Hide the item
2023-11-19 01:42:51 +00:00
}
});
2023-11-19 16:06:40 +00:00
}
2023-11-19 01:46:47 +00:00
2023-11-19 16:06:40 +00:00
// Add event listener to the search input
document.getElementById('searchInput').addEventListener('input', search);
</script>
2023-12-02 17:17:42 +00:00