300 lines
9.1 KiB
JavaScript
300 lines
9.1 KiB
JavaScript
var pending = false;
|
|
|
|
var firebaseConfig = {
|
|
apiKey: "AIzaSyBFZjXvnCMpGurSWEuVgHkE9jD9jxGJhx8",
|
|
authDomain: "test-push-notf.firebaseapp.com",
|
|
databaseURL: "https://test-push-notf.firebaseio.com",
|
|
projectId: "test-push-notf",
|
|
storageBucket: "",
|
|
messagingSenderId: "93473765978",
|
|
appId: "1:93473765978:web:5d959a487fe5382480f663"
|
|
};
|
|
firebase.initializeApp(firebaseConfig);
|
|
|
|
const messaging = firebase.messaging();
|
|
if ('serviceWorker' in navigator) {
|
|
window.addEventListener('load', () => {
|
|
navigator.serviceWorker.register('serviceWorker.js')
|
|
.then(registration => {
|
|
console.log('Service Worker is registered', registration);
|
|
|
|
messaging.useServiceWorker(registration);
|
|
messaging.usePublicVapidKey('BDYQ7X7J7PX0aOFNqB-CivQeqLq4-SqCxQJlDfJ6yNnQeYRoK8H2KOqxHRh47fLrbUhC8O3tve67MqJAIqox7Ng');
|
|
messaging.requestPermission().then(function () {
|
|
console.log("Notification permission granted.");
|
|
return messaging.getToken()
|
|
})
|
|
.then(function (token) {
|
|
console.log("token is : " + token);
|
|
$.ajax({
|
|
url: 'ajax',
|
|
type: 'POST',
|
|
data: {
|
|
"notification": 'X',
|
|
"action": 'subscribe',
|
|
"token": token
|
|
},
|
|
success: function (data) {
|
|
console.log('saved', data);
|
|
},
|
|
error: function (request, status, error) {
|
|
console.log("ERROR ", request, error);
|
|
}
|
|
});
|
|
})
|
|
.catch(function (err) {
|
|
console.log("Unable to get permission to notify.", err);
|
|
});
|
|
})
|
|
.catch(err => {
|
|
console.error('Registration failed:', err);
|
|
});
|
|
});
|
|
}
|
|
|
|
|
|
$('select[name="atSelector"]').change(function (e) {
|
|
console.log($(this).val());
|
|
if ($(this).val() == 'time') {
|
|
|
|
$('input[name="atTime"]').prop("disabled", false);
|
|
|
|
$('select[name="atDeviceValueInt"]').prop("disabled", true);
|
|
$('input[name="atDeviceValue"]').prop("disabled", true);
|
|
} else if ($(this).val() == 'atDeviceValue') {
|
|
|
|
$('select[name="atDeviceValue"]').prop("disabled", false);
|
|
$('input[name="atDeviceValueInt"]').prop("disabled", false);
|
|
|
|
$('input[name="atTime"]').prop("disabled", true);
|
|
}
|
|
});
|
|
|
|
var pressTimer;
|
|
var touch = 0;
|
|
var touchSubId = "";
|
|
$("div.square-content").on('touchend', function (e) {
|
|
clearTimeout(pressTimer);
|
|
});
|
|
|
|
$("div.square-content").on('touchstart', function (eTarget) {
|
|
navigator.vibrate([500]);
|
|
var id = '';
|
|
|
|
var windowLoc = $(location).attr('pathname');
|
|
windowLoc = windowLoc.substring(windowLoc.lastIndexOf("/"));
|
|
console.log(windowLoc);
|
|
if (windowLoc == "/") {
|
|
id = $(this).attr('id').replace('device-', '');
|
|
} else if (windowLoc == "/scene") {
|
|
id = $(this).attr('id').replace('scene-', '');
|
|
} else if (windowLoc == "/automation") {
|
|
id = $(this).attr('id').replace('automation-', '');
|
|
}
|
|
|
|
var subId = $(this).attr('data-sub-device-id');
|
|
|
|
touch++;
|
|
if (touch == 2 && touchSubId == subId) {
|
|
console.log("Detail");
|
|
if (windowLoc == "/") {
|
|
$("#modal-detail-" + subId).removeClass('modal-container-hiden').show();
|
|
ajaxChart(subId);
|
|
} else if (windowLoc == "/scene") {
|
|
|
|
} else if (windowLoc == "/automation") {
|
|
}
|
|
touch = 0;
|
|
touchSubId = "";
|
|
return;
|
|
}
|
|
touchSubId = subId;
|
|
|
|
pressTimer = window.setTimeout(function (e) {
|
|
console.log("Setting");
|
|
$("#modal-setting-" + id).removeClass('modal-container-hiden').show();
|
|
touch = 0;
|
|
}, 500);
|
|
});
|
|
|
|
$("div.square-content").mousedown(function (e) {
|
|
if (event.which == 3) {
|
|
var windowLoc = $(location).attr('pathname');
|
|
windowLoc = windowLoc.substring(windowLoc.lastIndexOf("/"));
|
|
console.log(windowLoc);
|
|
var id = null;
|
|
if (windowLoc == "/") {
|
|
id = $(this).attr('id').replace('device-', '');
|
|
} else if (windowLoc == "/scene") {
|
|
id = $(this).attr('id').replace('scene-', '');
|
|
} else if (windowLoc == "/automation") {
|
|
id = $(this).attr('id').replace('automation-', '');
|
|
}
|
|
$("#modal-setting-" + id).removeClass('modal-container-hiden').show();
|
|
console.log("Setting");
|
|
console.log("modal" + id);
|
|
}
|
|
});
|
|
|
|
$(".close").on('click', function (e) {
|
|
var a = $(this).parent().parent();
|
|
a.hide();
|
|
});
|
|
|
|
$(this).bind("contextmenu", function (e) {
|
|
e.preventDefault();
|
|
});
|
|
|
|
$("div.square-content").on('dblclick', function (eTarget) {
|
|
windowLoc = windowLoc.substring(windowLoc.lastIndexOf("/"));
|
|
if (windowLoc == "/") {
|
|
console.log("Detail");
|
|
var subId = $(this).attr('data-sub-device-id');
|
|
ajaxChart(subId);
|
|
$("#modal-detail-" + subId).removeClass('modal-container-hiden').show();
|
|
}
|
|
});
|
|
|
|
$("input#sleepTime").change(function () {
|
|
console.log("Input text changed!");
|
|
});
|
|
|
|
var element = $('div.delete');
|
|
element.hide();
|
|
$("a#remove").on('click', function (e) {
|
|
console.log("Show/Hide Button");
|
|
var element = $('div.delete');
|
|
element.toggle();
|
|
});
|
|
|
|
function ajaxChart(id, period = 'day', group = 'hour') {
|
|
$.ajax({
|
|
url: 'ajax',
|
|
type: 'POST',
|
|
dataType: 'json',
|
|
data: {
|
|
"subDevice_id": id,
|
|
"action": 'chart',
|
|
"period": period,
|
|
"group": group
|
|
},
|
|
success: function (data) {
|
|
console.log('ID: ', id, 'DATA: ', data);
|
|
var ctx = document.getElementById('canvas-' + id).getContext('2d');
|
|
var myChart = new Chart(ctx, data);
|
|
},
|
|
error: function (request, status, error) {
|
|
console.log("ERROR ajaxChart():", request, error);
|
|
}
|
|
});
|
|
}
|
|
|
|
//select room on load
|
|
var windowLoc = $(location).attr('pathname');
|
|
windowLoc = windowLoc.substring(windowLoc.lastIndexOf("/"));
|
|
console.log();
|
|
if (windowLoc == "/") {
|
|
|
|
var selectRoomId = localStorage.getItem("selectedRoomId");
|
|
|
|
if (selectRoomId == null) {
|
|
selectRoomId = 'all';
|
|
}
|
|
|
|
|
|
console.log('Saved Selected Room ID ' + selectRoomId);
|
|
$('[name="room"]').val(selectRoomId);
|
|
$('.device-button').each(function () {
|
|
if (selectRoomId != 'all') {
|
|
if ($(this).data('room-id') != selectRoomId) {
|
|
$(this).hide();
|
|
} else {
|
|
$(this).show();
|
|
}
|
|
}
|
|
});
|
|
|
|
|
|
}
|
|
|
|
//Room selector
|
|
$('[name="room"]').change(function (e) {
|
|
console.log('Selected Room ID ' + this.value)
|
|
var roomId = this.value;
|
|
localStorage.setItem("selectedRoomId", roomId);
|
|
$('.device-button').show();
|
|
if (roomId != 'all') {
|
|
$('.device-button').each(function () {
|
|
if ($(this).data('room-id') != roomId) {
|
|
$(this).hide();
|
|
}
|
|
});
|
|
}
|
|
});
|
|
|
|
|
|
/*
|
|
var windowLoc = $(location).attr('pathname');
|
|
windowLoc = windowLoc.substring(windowLoc.lastIndexOf("/"));
|
|
console.log();
|
|
if (windowLoc == "/") {
|
|
var autoUpdate = setInterval(function(){
|
|
if (pending == false) {
|
|
pending = true;
|
|
$.ajax({
|
|
url: 'ajax',
|
|
type: 'POST',
|
|
dataType: 'json',
|
|
data: {
|
|
"action": 'getState'
|
|
},
|
|
success: function(data){
|
|
console.log(data);
|
|
for (const key in data) {
|
|
if (data.hasOwnProperty(key)) {
|
|
const device = data[key];
|
|
$('[data-sub-device-id="'+key+'"]')
|
|
.find('.device-button-value')
|
|
.text(device['value'])
|
|
.attr('title',device['time'])
|
|
}
|
|
}
|
|
},
|
|
error: function (request, status, error) {
|
|
console.log("ERROR ajaxChart():", request, error);
|
|
},
|
|
complete: function (){
|
|
pending = false;
|
|
}
|
|
});
|
|
}
|
|
},4000);
|
|
}*/
|
|
|
|
|
|
|
|
|
|
//Graphs
|
|
$('.graph-period').on('click', function (e) {
|
|
var subId = $(this).attr('data-sub-device-id');
|
|
var period = $(this).attr('data-period');
|
|
var groupBy = $(this).attr('data-group');
|
|
|
|
ajaxChart(subId, period, groupBy);
|
|
});
|
|
|
|
$("button[name=remove]").click(function (e) {
|
|
if (confirm('Are you shure ?')) {
|
|
var windowLoc = $(location).attr('pathname');
|
|
windowLoc = windowLoc.substring(windowLoc.lastIndexOf("/"));
|
|
console.log(windowLoc);
|
|
var id = null;
|
|
if (windowLoc == "/scene") {
|
|
id = $(this).data('scene-id');
|
|
$("#scene-" + id + "-content").remove();
|
|
} else if (windowLoc == "/automation") {
|
|
$(this).parent().remove();
|
|
}
|
|
}
|
|
});
|