openhab2_tizen/js/app.js

238 lines
5.9 KiB
JavaScript
Raw Normal View History

2019-04-08 01:36:25 +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-09 00:09:24 +02:00
parseWidgets(sitemap.homepage.widgets, $('#frame_main'));
$('#page_main').addClass('ui-page-active');
$("body").append($('#page_main'));
2019-04-07 14:49:51 +02:00
}
2019-04-09 00:09:24 +02:00
function createSubFrame(wdg, parent) {
var page_name = 'page_' + __page_count.toString();
2019-04-08 01:36:25 +02:00
var newframe = $('<div/>')
.addClass('ui-content')
.prop('id', 'frame_' + __page_count.toString());
2019-04-09 00:09:24 +02:00
var parent_name = parent.parent().prop('id');
var sub_name = ('label' in wdg)?wdg.label:wdg.title;
2019-04-08 01:36:25 +02:00
var newpage = $('<div/>')
.addClass('ui-page')
2019-04-09 00:09:24 +02:00
.prop('id', page_name)
.append($('<header/>')
.append($('<h2/>')
2019-04-09 01:43:33 +02:00
.append($('<a/>')
.text(sub_name)
.attr('href','#'+parent_name)
)
//.click(function(){changePage('#'+parent_name,null,true,true);})
2019-04-09 00:09:24 +02:00
)
)
2019-04-08 01:36:25 +02:00
.append(newframe);
2019-04-09 01:43:33 +02:00
parent.append($('<div/>').append($('<a/>')
.text(sub_name)
.attr('href','#'+page_name)));
// parent.append($('<div/>')
// .text(sub_name)
// .click(function(){changePage('#'+page_name,null,false,true);}));
2019-04-09 00:09:24 +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-08 01:36:25 +02:00
return newframe;
}
2019-04-09 00:09:24 +02:00
function createSwitch(wdg, page) {
if (wdg.mappings.length === 0) {
page.append($('<div/>').addClass('ui-switch')
.append($('<div/>').addClass('ui-switch-text').text(wdg.label))
.append($('<label/>').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-activation')
.append($('<div/>').addClass('ui-switch-inneroffset')
.append($('<div/>').addClass('ui-switch-handler'))))
)
);
} else if (wdg.mappings.length === 1) {
page.append($('<div/>')
.append($('<span/>').text(wdg.label))
.append($('<button/>')
.prop('data-link', wdg.item.link)
.prop('data-item', wdg.item.name)
.prop('type','button')
.prop('value',wdg.mappings[0].command)
.text(wdg.mappings[0].label)
.change(function(){
updateItem($(this).prop('data-link'),$(this).val());
}))
);
}
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-09 01:43:33 +02:00
var name=btoa(wdg.label).replace(/[\/+=]/g,'');
var selector=$('<div/>').addClass('ui-selector').attr('id','sel_'+name);
2019-04-09 00:09:24 +02:00
wdg.mappings.forEach(function(entry) {
2019-04-09 01:43:33 +02:00
var item=$('<div/>')
.addClass('ui-item')
.attr('data-title', entry.label)
.attr('data-value', entry.command);
if (wdg.item.state == entry.command){
item.addClass('ui-item-active');
}
selector.append(item);
2019-04-09 00:09:24 +02:00
});
2019-04-09 01:43:33 +02:00
//page.append(selector);
console.log(selector);
2019-04-09 00:09:24 +02:00
2019-04-09 01:43:33 +02:00
page.append($('<div/>')
.prop('id','pop_'+name)
.addClass('ui-popup')
.append($('<div/>').addClass('ui-popup-header').text(wdg.label))
.append($('<div/>').addClass('ui-popup-content').append(selector))
)
2019-04-07 14:49:51 +02:00
2019-04-09 01:43:33 +02:00
console.log(selector);
console.log($('#sel_'+name));
tau.widget.Selector(selector[0]);
// selector.click(function(){
// var activeItem = selector.querySelector(".ui-item-active");
page.append($('<a/>').attr('href','#pop_'+name).addClass('ui-btn').attr('data-rel','popup').text(wdg.label))
// page.append($('<div/>').text(wdg.label).click(function(){
// tau.widget.Selector(selector);
// selector.click(function(){
// var activeItem = selector.querySelector(".ui-item-active");
// console.log(activeItem.getAttribute("data-title"));
// selector.hide();
// });
// selector.show();
// }));
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-08 01:36:25 +02:00
page.append($('<div/>')
.append($('<span/>').text(wdg.label))
.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-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 {
page.append($('<div/>').text(wdg.label));
}
2019-04-08 01:36:25 +02:00
}
function parseWidgets(widgets, parent) {
widgets.forEach(function (wdg) {
switch (wdg.type) {
case "Frame":
2019-04-09 00:09:24 +02:00
var newframe = createSubFrame(wdg, parent);
2019-04-08 01:36:25 +02:00
if (("widgets" in wdg) && wdg.widgets.length > 0) {
parseWidgets(wdg.widgets, newframe);
}
break;
case "Switch":
2019-04-09 00:09:24 +02:00
createSwitch(wdg, parent);
2019-04-08 01:36:25 +02:00
break;
case "Slider":
createSlider(wdg, parent);
break;
case "Selection":
2019-04-09 00:09:24 +02:00
createSelection(wdg, parent);
2019-04-08 01:36:25 +02:00
break;
case "Text":
createText(wdg, parent);
break;
default:
2019-04-09 01:43:33 +02:00
parent.append($('<div/>').text("other["+wdg.type+"]"));
2019-04-08 01:36:25 +02:00
break;
}
});
2019-04-07 22:12:07 +02:00
}
2019-04-09 01:43:33 +02:00
function changePage(to,transition,back,change){
console.log(document.location.href);
console.log(to);
console.log(transition);
console.log(back);
console.log(change);
tau.changePage(to,transition,back,change);
console.log(document.location.href);
}
2019-04-08 01:36:25 +02:00
function updateItem(item, value) {
$.post({url:item,
data: value.toString(),
contentType: 'text/plain'});
2019-04-07 22:12:07 +02:00
}
function loadgui() {
2019-04-08 01:36:25 +02:00
$.get("http://habctrl:8080/rest/sitemaps/default", parseSitemap);
2019-04-07 22:12:07 +02:00
}
2019-04-08 01:36:25 +02:00
$(document).ready(loadgui);