openhab2_tizen/js/app.js

290 lines
7.9 KiB
JavaScript
Raw Normal View History

2019-04-15 02:55:23 +02:00
(function() {
window.addEventListener("tizenhwkey", function(ev) {
2019-04-07 14:49:51 +02:00
var activePopup = null, page = null, pageId = "";
if (ev.keyName === "back") {
activePopup = document.querySelector(".ui-popup-active");
page = document.getElementsByClassName("ui-page-active")[0];
pageId = page ? page.id : "";
2019-04-09 00:09:24 +02:00
if ((pageId === "page_main") && !activePopup) {
2019-04-07 14:49:51 +02:00
try {
tizen.application.getCurrentApplication().exit();
} catch (ignore) {
}
} else {
window.history.back();
}
}
});
}());
2019-04-08 01:36:25 +02:00
__page_count = 0;
function parseSitemap(sitemap, status) {
2019-04-15 02:55:23 +02:00
var list_main = $('<ul/>').addClass('ui-listview');
2019-04-11 02:19:22 +02:00
parseWidgets(sitemap.homepage.widgets, list_main);
2019-04-15 02:55:23 +02:00
$('#frame_main').append(list_main);
var stored_sitemap = {
'list_main' : list_main,
'pages' : $('.ui-page')
}
tizen.preference.setValue('oh_stored_sitemap', JSON.stringify(stored_sitemap));
2019-04-07 14:49:51 +02:00
}
2019-04-09 00:09:24 +02:00
function createSubFrame(wdg, parent) {
2019-04-15 02:55:23 +02:00
var page_name = 'dpage_' + __page_count.toString();
var newlist = $('<ul/>').addClass('ui-listview');
var newframe = $('<div/>').addClass('ui-content').prop('id',
'frame_' + __page_count.toString()).append(newlist);
if (parent.parent('.ui-page') && parent.parent('.ui-page').length > 0) {
2019-04-11 02:19:22 +02:00
var parent_name = parent.parent('.ui-page').prop('id');
} else {
var parent_name = 'page_main';
}
2019-04-15 02:55:23 +02:00
var sub_name = ('label' in wdg) ? wdg.label : wdg.title;
var newpage = $('<div/>').addClass('ui-page').prop('id', page_name).append(
$('<header/>').append(
$('<h2/>').append(
$('<a/>').addClass('ui-title').text(sub_name).attr(
'href', '#' + parent_name)))).append(
newframe);
parent.append($('<li/>').append(
$('<div/>').append(
$('<a/>').text(sub_name).attr('href', '#' + page_name))));
2019-04-09 01:43:33 +02:00
2019-04-08 01:36:25 +02:00
$("body").append(newpage);
2019-04-09 00:09:24 +02:00
__page_count += 1;
2019-04-10 23:47:50 +02:00
return newlist;
2019-04-08 01:36:25 +02:00
}
2019-04-09 00:09:24 +02:00
function createSwitch(wdg, page) {
2019-04-15 02:55:23 +02:00
if (wdg.mappings.length === 0) {
page.append($('<li/>').addClass('li-has-toggle').append(
$('<label/>').text(wdg.label)).append(
$('<div/>').addClass('ui-toggleswitch').append(
$('<input/>').prop('type', 'checkbox').prop(
'data-link', wdg.item.link).prop('data-item',
wdg.item.name).addClass('ui-switch-input')
.change(
function() {
updateItem($(this)
.prop('data-link'), $(this)
.is(':checked') ? "ON"
: "OFF");
})).append(
$('<div/>').addClass('ui-switch-button'))));
} else if (wdg.mappings.length > 0) {
var btnframe = $('<div/>').append($('<span/>').text(wdg.label));
wdg.mappings.forEach(function(map_item){
btnframe.append($('<button/>')
.addClass('ui-btn ui-inline')
.prop('data-link', wdg.item.link)
.prop('data-item',wdg.item.name)
.prop('type', 'button')
.prop('value', map_item.command)
.text(map_item.label)
.click(function() {updateItem($(this).prop('data-link'), $(this).val());}));
})
page.append($('<li/>').append(btnframe));
}
2019-04-07 14:49:51 +02:00
}
2019-04-09 00:09:24 +02:00
2019-04-08 01:36:25 +02:00
function createSelection(wdg, page) {
2019-04-15 02:55:23 +02:00
var name = btoa(wdg.label).replace(/[\/+=]/g, '');
var ul = $('<div/>').prop('data-link', wdg.item.link).change(function() {
var checked = $("input[name='" + name + "']:checked");
if (checked !== undefined) {
updateItem($(this).prop('data-link'), checked.val());
}
});
2019-04-09 00:09:24 +02:00
wdg.mappings.forEach(function(entry) {
2019-04-15 02:55:23 +02:00
var item = $('<input/>').attr('type', 'radio').attr('name', name).attr(
'value', entry.command);
if (wdg.item.state === entry.command) {
item.attr('checked', 'checked');
2019-04-09 01:43:33 +02:00
}
2019-04-15 02:55:23 +02:00
ul.append($('<label/>').text(entry.label).append(item)).append(
$('<br/>'));
2019-04-09 00:09:24 +02:00
});
2019-04-15 02:55:23 +02:00
page.append($('<div/>').prop('id', 'pop_' + name).addClass('ui-popup')
2019-04-09 01:43:33 +02:00
.append($('<div/>').addClass('ui-popup-header').text(wdg.label))
2019-04-15 02:55:23 +02:00
.append($('<div/>').addClass('ui-popup-content').append(ul)));
page.append($('<li/>').append(
$('<a/>').attr('href', '#pop_' + name).addClass('ui-btn').attr(
'data-rel', 'popup').text(wdg.label)));
2019-04-08 01:36:25 +02:00
}
2019-04-09 00:09:24 +02:00
2019-04-08 01:36:25 +02:00
function createSlider(wdg, page) {
var value = 0;
if (wdg.item.state !== null) {
value = wdg.item.state;
2019-04-07 22:12:07 +02:00
}
2019-04-15 02:55:23 +02:00
page.append($('<li/>').append(
$('<div/>').append($('<span/>').text(wdg.label)).append($('<br/>'))
.append(
$('<input/>').prop('data-link', wdg.item.link)
.prop('data-item', wdg.item.name).prop(
'type', 'range').prop('data-freq',
'200').prop('data-state', value)
.prop('min', '0').prop('max', '100').prop(
'value', value).change(
function() {
updateItem($(this).prop(
'data-link'), $(this)
.val());
}))));
2019-04-08 01:36:25 +02:00
}
2019-04-09 00:09:24 +02:00
2019-04-08 01:36:25 +02:00
function createText(wdg, page) {
2019-04-09 00:09:24 +02:00
if ('linkedPage' in wdg) {
var newframe = createSubFrame(wdg.linkedPage, page);
if (("widgets" in wdg.linkedPage) && wdg.linkedPage.widgets.length > 0) {
parseWidgets(wdg.linkedPage.widgets, newframe);
}
} else {
2019-04-10 23:47:50 +02:00
page.append($('<li/>').append($('<div/>').text(wdg.label)));
2019-04-09 00:09:24 +02:00
}
2019-04-08 01:36:25 +02:00
}
2019-04-15 02:55:23 +02:00
function createSetpoint(wdg, page){
page.append($('<li/>').append(
$('<div/>')
.append($('<span/>').text(wdg.label))
.append($('<br/>'))
.append($('<button/>')
.addClass('ui-inline-btn ui-inline')
.prop('data-link', wdg.item.link)
.prop('data-item',wdg.item.name)
.prop('type', 'button')
.text('-')
.click(function() {
var new_val=Math.max(Number($(this).val()) - Number(wdg.step),Number(wdg.minValue));
updateItem($(this).prop('data-link'), new_val);}))
//.append($('<span/>').text(wdg.item.state))
.append($('<button/>')
.addClass('ui-inline-btn ui-inline')
.prop('data-link', wdg.item.link)
.prop('data-item',wdg.item.name)
.prop('type', 'button')
.text('+')
.click(function() {
var new_val=Math.min(Number($(this).val()) + Number(wdg.step),Number(wdg.maxValue));
updateItem($(this).prop('data-link'), new_val);}))
));
}
2019-04-08 01:36:25 +02:00
function parseWidgets(widgets, parent) {
2019-04-15 02:55:23 +02:00
widgets.forEach(function(wdg) {
2019-04-08 01:36:25 +02:00
switch (wdg.type) {
2019-04-15 02:55:23 +02:00
case "Frame":
var newframe = createSubFrame(wdg, parent);
if (("widgets" in wdg) && wdg.widgets.length > 0) {
parseWidgets(wdg.widgets, newframe);
}
break;
case "Switch":
createSwitch(wdg, parent);
break;
2019-04-08 01:36:25 +02:00
2019-04-15 02:55:23 +02:00
case "Slider":
createSlider(wdg, parent);
break;
2019-04-08 01:36:25 +02:00
2019-04-15 02:55:23 +02:00
case "Selection":
createSelection(wdg, parent);
break;
2019-04-08 01:36:25 +02:00
2019-04-15 02:55:23 +02:00
case "Text":
createText(wdg, parent);
break;
2019-04-08 01:36:25 +02:00
2019-04-15 02:55:23 +02:00
case "Setpoint":
createSetpoint(wdg, parent);
break;
2019-04-08 01:36:25 +02:00
2019-04-15 02:55:23 +02:00
default:
parent.append($('<li/>').append(
$('<div/>').text("other[" + wdg.type + "]")));
break;
2019-04-08 01:36:25 +02:00
}
});
2019-04-07 22:12:07 +02:00
}
2019-04-15 02:55:23 +02:00
function changePage(to, transition, back, change) {
2019-04-09 01:43:33 +02:00
console.log(document.location.href);
console.log(to);
console.log(transition);
console.log(back);
console.log(change);
2019-04-15 02:55:23 +02:00
tau.changePage(to, transition, back, change);
2019-04-09 01:43:33 +02:00
console.log(document.location.href);
}
2019-04-15 02:55:23 +02:00
function updateItem(item, value) {
$.post({
url : item,
data : value.toString(),
contentType : 'text/plain'
});
}
function storeSettings() {
var local_url=$('#oh_url').val();
var remote_url=$('#oh_remote_url').val();
tizen.preference.setValue('oh_url', local_url);
tizen.preference.setValue('oh_remote_url', remote_url);
}
function resetSitemap() {
tizen.preference.remove('oh_stored_sitemap');
}
function reloadSitemap() {
$('#frame_main ul').empty();
$('div[id^=dpage]').remove();
__page_count=0;
$.get(tizen.preference.getValue('oh_url') + "/rest/sitemaps/default",
parseSitemap).fail(
function() {
$.get(tizen.preference.getValue('oh_remote_url') + "/rest/sitemaps/default",
parseSitemap).fail(function() {
});
});
2019-04-07 22:12:07 +02:00
}
function loadgui() {
2019-04-15 02:55:23 +02:00
if (tizen.preference.exists('oh_stored_sitemap')) {
var stored_sitemap = JSON.parse(tizen.preference.getValue('oh_stored_sitemap'));
var body = $('body');
stored_sitemap.pages.forEach(function(page){
if (page.prop('id').startsWith('dpage_')){
body.append(page);
}
});
$('#frame_main').append(stored_sitemap.list_main);
} else {
if(tizen.preference.exists('oh_url')){
reloadSitemap();
}
}
2019-04-07 22:12:07 +02:00
}
2019-04-08 01:36:25 +02:00
$(document).ready(loadgui);