2018-01-02 00:00:45 +00:00
|
|
|
<!--
|
|
|
|
Floorplan for Home Assistant
|
2018-06-09 16:49:50 +00:00
|
|
|
Version: 1.0.8.3
|
2018-01-02 00:00:45 +00:00
|
|
|
By Petar Kozul
|
|
|
|
https://github.com/pkozul/ha-floorplan
|
|
|
|
-->
|
|
|
|
|
2018-06-09 16:49:50 +00:00
|
|
|
<script src="lib/jquery-3.3.1.min.js"></script>
|
2018-01-02 00:00:45 +00:00
|
|
|
<script src="lib/moment.min.js"></script>
|
|
|
|
<script src="lib/yaml.min.js"></script>
|
|
|
|
|
|
|
|
<!-- As documented here for Google Chrome, removes the need for touchstart -->
|
|
|
|
<meta name="viewport" content="width=device-width">
|
|
|
|
|
|
|
|
<dom-module id="ha-floorplan">
|
|
|
|
|
|
|
|
<template>
|
|
|
|
<style>
|
|
|
|
#floorplan {
|
|
|
|
width: 100%;
|
|
|
|
height: 100%;
|
|
|
|
}
|
|
|
|
|
|
|
|
.loading-container {
|
|
|
|
text-align: center;
|
|
|
|
padding: 8px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.loading {
|
|
|
|
height: 0px;
|
|
|
|
overflow: hidden;
|
|
|
|
}
|
|
|
|
|
|
|
|
#log {
|
|
|
|
max-height: 150px;
|
|
|
|
overflow: auto;
|
|
|
|
background-color: #eee;
|
|
|
|
display: none;
|
|
|
|
padding: 10px;
|
|
|
|
}
|
|
|
|
|
|
|
|
#log ul {
|
|
|
|
list-style-type: none;
|
|
|
|
padding-left: 0px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.error {
|
|
|
|
color: #FF0000;
|
|
|
|
}
|
|
|
|
|
|
|
|
.warning {
|
|
|
|
color: #FF851B;
|
|
|
|
}
|
|
|
|
|
|
|
|
.info {
|
|
|
|
color: #0000FF;
|
|
|
|
}
|
|
|
|
|
|
|
|
.debug {
|
|
|
|
color: #000000;
|
|
|
|
}
|
|
|
|
</style>
|
|
|
|
|
|
|
|
<template is='dom-if' if='[[isLoading]]'>
|
|
|
|
<div class='loading-container'>
|
|
|
|
<paper-spinner active alt='Loading'></paper-spinner>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<div id="log">
|
|
|
|
<a href="#" onclick="$(this).siblings('ul').html('').parent().css('display', 'none');">Clear log</a>
|
|
|
|
<ul></ul>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div id="floorplan" on-tap="stopPropagation"></div>
|
|
|
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
</dom-module>
|
|
|
|
|
|
|
|
<script>
|
2018-06-09 16:49:50 +00:00
|
|
|
class HaFloorplan extends Polymer.Element {
|
2018-01-02 00:00:45 +00:00
|
|
|
static get is() { return 'ha-floorplan'; }
|
|
|
|
|
|
|
|
static get properties() {
|
|
|
|
return {
|
|
|
|
hass: {
|
|
|
|
type: Object,
|
|
|
|
observer: 'hassChanged'
|
|
|
|
},
|
|
|
|
inDialog: {
|
|
|
|
type: Boolean,
|
|
|
|
value: false,
|
|
|
|
},
|
|
|
|
isPanel: {
|
|
|
|
type: Boolean,
|
|
|
|
value: false,
|
|
|
|
},
|
|
|
|
config: {
|
|
|
|
type: Object,
|
|
|
|
},
|
|
|
|
isLoading: {
|
|
|
|
type: Boolean,
|
|
|
|
value: true,
|
|
|
|
},
|
|
|
|
flooplan: {
|
|
|
|
type: Object,
|
|
|
|
value: undefined,
|
|
|
|
},
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
connectedCallback() {
|
|
|
|
super.connectedCallback();
|
|
|
|
|
2018-06-09 16:49:50 +00:00
|
|
|
if (!this.floorplan) {
|
|
|
|
this.initFloorplan();
|
|
|
|
}
|
2018-01-02 00:00:45 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
stopPropagation(e) {
|
|
|
|
e.stopPropagation();
|
|
|
|
}
|
|
|
|
|
|
|
|
initFloorplan() {
|
|
|
|
this.loadScript('/local/custom_ui/floorplan/lib/floorplan.js')
|
|
|
|
.then(() => {
|
|
|
|
this.floorplan = new Floorplan();
|
|
|
|
|
|
|
|
let options = {
|
2018-06-09 16:49:50 +00:00
|
|
|
doc: this.root,
|
2018-01-02 00:00:45 +00:00
|
|
|
hass: this.hass,
|
|
|
|
openMoreInfo: this.openMoreInfo.bind(this),
|
|
|
|
setIsLoading: this.setIsLoading.bind(this),
|
|
|
|
config: (this.config && this.config.config) || this.config,
|
|
|
|
};
|
|
|
|
|
|
|
|
this.floorplan.init(options)
|
|
|
|
.then(() => {
|
|
|
|
this.setIsLoading(false);
|
|
|
|
});
|
|
|
|
})
|
|
|
|
.catch((error) => {
|
|
|
|
this.setIsLoading(false);
|
|
|
|
this.logError(error);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
hassChanged(newHass, oldHass) {
|
|
|
|
if (this.floorplan) {
|
|
|
|
this.floorplan.hassChanged(newHass, oldHass);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
loadScript(scriptUrl) {
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
let script = document.createElement('script');
|
|
|
|
script.src = this.cacheBuster(scriptUrl);
|
|
|
|
script.onload = () => {
|
|
|
|
return resolve();
|
|
|
|
};
|
|
|
|
script.onerror = (err) => {
|
|
|
|
reject(new URIError(`${err.target.src}`));
|
|
|
|
};
|
|
|
|
|
2018-06-09 16:49:50 +00:00
|
|
|
this.root.appendChild(script);
|
2018-01-02 00:00:45 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
openMoreInfo(entityId) {
|
|
|
|
this.fire('hass-more-info', { entityId: entityId });
|
|
|
|
}
|
|
|
|
|
|
|
|
setIsLoading(isLoading) {
|
|
|
|
this.isLoading = isLoading;
|
|
|
|
}
|
|
|
|
|
|
|
|
cacheBuster(url) {
|
|
|
|
return `${url}${(url.indexOf('?') >= 0) ? '&' : '?'}_=${new Date().getTime()}`;
|
|
|
|
}
|
|
|
|
|
|
|
|
logError(message) {
|
|
|
|
console.error(message);
|
|
|
|
|
2018-06-09 16:49:50 +00:00
|
|
|
let log = this.root.log;
|
2018-01-02 00:00:45 +00:00
|
|
|
$(log).find('ul').prepend(`<li class="error">${message}</li>`)
|
|
|
|
$(log).css('display', 'block');
|
|
|
|
}
|
2018-06-09 16:49:50 +00:00
|
|
|
|
|
|
|
fire(type, detail, options) {
|
|
|
|
options = options || {};
|
|
|
|
detail = (detail === null || detail === undefined) ? {} : detail;
|
|
|
|
const event = new Event(type, {
|
|
|
|
bubbles: options.bubbles === undefined ? true : options.bubbles,
|
|
|
|
cancelable: Boolean(options.cancelable),
|
|
|
|
composed: options.composed === undefined ? true : options.composed
|
|
|
|
});
|
|
|
|
event.detail = detail;
|
|
|
|
const node = options.node || this;
|
|
|
|
node.dispatchEvent(event);
|
|
|
|
return event;
|
|
|
|
}
|
2018-01-02 00:00:45 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
customElements.define(HaFloorplan.is, HaFloorplan);
|
|
|
|
|
|
|
|
</script>
|