Give uwap-home a proper svg

This commit is contained in:
uwap 2019-08-05 04:28:00 +02:00
parent 226bfa3602
commit edb3ae4ff9
5 changed files with 3 additions and 3 deletions

File diff suppressed because one or more lines are too long

After

Width:  |  Height:  |  Size: 26 KiB

View file

@ -0,0 +1 @@
<mxfile modified="2019-08-05T02:24:45.879Z" host="www.draw.io" agent="Mozilla/5.0 (X11; Linux x86_64; rv:65.0) Gecko/20100101 Firefox/65.0" etag="ZEvUBlrDTQidPugJw7fi" version="11.1.1" type="device"><diagram id="YpsO6_Ys41EOyISO9KxR" name="Page-1">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</diagram></mxfile>

454
config/uwap-home/index.js Normal file
View file

@ -0,0 +1,454 @@
// @flow
import type { Config } from "config/flowtypes";
import * as types from "config/types";
import { mdi, rawMdi } from "config/icon";
import { hex } from "config/colors";
const topicBulb = (bulb: string, argument: string) => ({
[`${bulb}${argument}`]: {
state: {
name: `home-rust/bulb/${bulb}/${argument}`,
type: types.string
},
command: {
name: `home-rust/bulb/${bulb}/${argument}/set`,
type: types.string
},
defaultValue: "0"
}
});
const topicHomeBoolean = (name: string, topic: string) => ({
[`${name}`]: {
state: {
name: `home-rust/${topic}`,
type: types.option({ true: "on", false: "off" })
},
command: {
name: `home-rust/${topic}/set`,
type: types.option({ on: "true", off: "false" })
},
defaultValue: "OFF"
}
});
const topicHomeNumber = (name: string, topic: string) => ({
[`${name}`]: {
state: {
name: `home-rust/${topic}`,
type: types.string
},
command: {
name: `home-rust/${topic}/set`,
type: types.string
},
defaultValue: 0
}
});
const topicTasmota = (name: string, topic: string) => ({
[`${name}State`]: {
state: {
name: `stat/${topic}/POWER`,
type: types.option({
OFF: "off",
ON: "on"
})
},
command: {
name: `cmnd/${topic}/POWER`,
type: types.string
},
defaultValue: "OFF"
}
});
const sliderRGB = (bulb: string, argument: string) => (
[{
type: "slider",
min: 0,
max: 255,
text: argument,
icon: mdi("brightness-7"),
topic: `${bulb}${argument}`
}]
);
const sliderH = (bulb: string, argument: string) => (
[{
type: "slider",
min: 0,
max: 360,
text: argument,
icon: mdi("brightness-7"),
topic: `${bulb}${argument}`
}]
);
const sliderSVXY = (bulb: string, argument: string) => (
[{
type: "slider",
min: 0,
max: 1,
step: 0.01,
text: argument,
icon: mdi("brightness-7"),
topic: `${bulb}${argument}`
}]
);
const config: Config = {
space: {
name: "Home",
color: "orange",
mqtt: "ws://192.168.0.12:1884"
},
topics: [
{
/*
*zigbee2mqtt/bulb_livingroom
*zigbee2mqtt/bulb_hallway
*zigbee2mqtt/bulb_bedroom
*/
...topicBulb("livingroom", "r"),
...topicBulb("livingroom", "g"),
...topicBulb("livingroom", "b"),
...topicBulb("livingroom", "h"),
...topicBulb("livingroom", "s"),
...topicBulb("livingroom", "v"),
...topicBulb("livingroom", "x"),
...topicBulb("livingroom", "y"),
...topicBulb("livingroom", "animation-speed"),
...topicBulb("livingroom", "mode"),
livingroomBrightness: {
state: {
name: "home-rust/bulb/livingroom/brightness",
type: types.string
},
command: {
name: "zigbee2mqtt/bulb_livingroom/set",
type: (value) => JSON.stringify({ brightness: value.toString() })
},
defaultValue: "0"
},
livingroomState: {
state: {
name: "home-rust/bulb/livingroom/state",
type: types.option({
OFF: "off",
ON: "on"
})
},
command: {
name: "zigbee2mqtt/bulb_livingroom/set",
type: (value) => JSON.stringify({ state: value.toString() })
},
defaultValue: "OFF"
},
...topicHomeBoolean("livingroomKodiControlled",
"bulb/livingroom/kodi-controlled"),
...topicHomeBoolean("bedroomWakeup", "wakeup"),
bedroomBrightness: {
state: {
name: "home-rust/bulb/bedroom/brightness",
type: types.string
},
command: {
name: "zigbee2mqtt/bulb_bedroom/set",
type: (value) => JSON.stringify({ brightness: value.toString() })
},
defaultValue: "0"
},
bedroomColorTemp: {
state: {
name: "home-rust/bulb/bedroom/color_temp",
type: types.string
},
command: {
name: "zigbee2mqtt/bulb_bedroom/set",
type: (value) => JSON.stringify({ "color_temp": value.toString() })
},
defaultValue: "0"
},
bedroomState: {
state: {
name: "home-rust/bulb/bedroom/state",
type: types.option({
OFF: "off",
ON: "on"
})
},
command: {
name: "zigbee2mqtt/bulb_bedroom/set",
type: (value) => JSON.stringify({ state: value.toString() })
},
defaultValue: "OFF"
},
...topicTasmota("fanBedroom", "sonoff-bedroom-fan"),
...topicHomeBoolean("fanBedroomAuto", "temperature-control/bedroom"),
...topicHomeNumber("fanBedroomTarget",
"temperature-control/bedroom/target"),
...topicTasmota("fanOffice", "sonoff-office-fan"),
...topicHomeBoolean("fanOfficeAuto", "temperature-control/office"),
...topicHomeNumber("fanOfficeTarget",
"temperature-control/office/target"),
hallwayBrightness: {
state: {
name: "home-rust/bulb/hallway/brightness",
type: types.string
},
command: {
name: "zigbee2mqtt/bulb_hallway/set",
type: (value) => JSON.stringify({ brightness: value.toString() })
},
defaultValue: "0"
},
hallwayState: {
state: {
name: "home-rust/bulb/hallway/state",
type: types.option({
OFF: "off",
ON: "on"
})
},
command: {
name: "zigbee2mqtt/bulb_hallway/set",
type: (value) => JSON.stringify({ state: value.toString() })
},
defaultValue: "OFF"
},
...topicTasmota("speakerOffice", "sonoff-office-speaker")
}
],
controls: {
bedroomLight: {
name: "Schlafzimmer",
position: [300, 400],
icon: mdi("ceiling-light"),
ui: [
{
type: "toggle",
topic: "bedroomState",
text: "Ein/Ausschalten",
icon: mdi("power")
},
{
type: "slider",
min: 0,
max: 255,
text: "Helligkeit",
icon: mdi("brightness-7"),
topic: "bedroomBrightness"
},
{
type: "toggle",
topic: "bedroomWakeup",
text: "Lichtwecker",
icon: mdi("weather-sunset-up")
},
{
type: "slider",
min: 250,
max: 454,
text: "Farbtemperatur",
icon: mdi("weather-sunset-down"),
topic: "bedroomColorTemp"
}
]
},
bedroomFan: {
name: "Lüftung Schlafzimmer",
position: [200, 400],
icon: mdi("fan"),
iconColor: ({fanBedroomState}) =>
(fanBedroomState === "on" ? hex("#00FF00") : hex("#000000")),
ui: [
{
type: "toggle",
topic: "fanBedroomState",
text: "Ein/Ausschalten",
icon: mdi("power")
},
{
type: "toggle",
topic: "fanBedroomAuto",
text: "Automatik",
icon: mdi("air-conditioner")
},
{
type: "text",
text: "Zieltemperatur",
icon: mdi("temperature-celsius"),
topic: "fanBedroomTarget"
},
{
type: "slider",
min: 10,
max: 21.5,
text: "Zieltemperatur",
icon: mdi("oil-temperature"),
topic: "fanBedroomTarget"
}
]
},
officeSpeaker: {
name: "Lautsprecher",
position: [550, 400],
icon: ({speakerOfficeState}) =>
(speakerOfficeState === "on" ? rawMdi("volume-high")
: rawMdi("volume-off")),
iconColor: ({speakerOfficeState}) =>
(speakerOfficeState === "on" ? hex("#00FF00") : hex("#000000")),
ui: [
{
type: "toggle",
topic: "speakerOfficeState",
text: "Ein/Ausschalten",
icon: mdi("power")
}
]
},
officeFan: {
name: "Lüftung Büro",
position: [600, 400],
icon: mdi("fan"),
iconColor: ({fanOfficeState}) =>
(fanOfficeState === "on" ? hex("#00FF00") : hex("#000000")),
ui: [
{
type: "toggle",
topic: "fanOfficeState",
text: "Ein/Ausschalten",
icon: mdi("power")
},
{
type: "toggle",
topic: "fanOfficeAuto",
text: "Automatik",
icon: mdi("air-conditioner")
},
{
type: "text",
text: "Zieltemperatur",
icon: mdi("temperature-celsius"),
topic: "fanOfficeTarget"
},
{
type: "slider",
min: 10,
max: 21.5,
text: "Zieltemperatur",
icon: mdi("oil-temperature"),
topic: "fanOfficeTarget"
}
]
},
hallwayLight: {
name: "Flur",
position: [400, 200],
icon: mdi("ceiling-light"),
ui: [
{
type: "toggle",
topic: "hallwayState",
text: "Ein/Ausschalten",
icon: mdi("power")
},
{
type: "slider",
min: 0,
max: 255,
text: "Helligkeit",
icon: mdi("brightness-7"),
topic: "hallwayBrightness"
}
]
},
livingroomLight: {
name: "Wohnzimmer",
position: [300, 200],
icon: mdi("ceiling-light"),
ui: ([
{
type: "toggle",
topic: "livingroomState",
text: "Ein/Ausschalten",
icon: mdi("power")
},
{
type: "toggle",
topic: "livingroomKodiControlled",
text: "Kodi Einbindung",
icon: mdi("brightness-auto")
},
{
type: "slider",
min: 0,
max: 255,
text: "Helligkeit",
icon: mdi("brightness-7"),
topic: "livingroomBrightness"
},
{
type: "slider",
max: 1,
min: 300,
step: -1,
text: "Speed",
icon: mdi("speedometer"),
topic: "livingroomanimation-speed"
},
{
type: "dropDown",
text: "Modus",
topic: "livingroommode",
options: {
"-1": "Cancel Animation",
"0": "Pink",
"1": "Kodi",
"2": "Sleep",
"3": "RGB Fade",
"4": "Work"
},
icon: mdi("settings")
},
{
type: "section",
text: "RGB"
}
]).concat(sliderRGB("livingroom", "r"))
.concat(sliderRGB("livingroom", "g"))
.concat(sliderRGB("livingroom", "b"))
.concat([
{
type: "section",
text: "HSV"
}
]).concat(sliderH("livingroom", "h"))
.concat(sliderSVXY("livingroom", "s"))
.concat(sliderSVXY("livingroom", "v"))
.concat([
{
type: "section",
text: "XY"
}
]).concat(sliderSVXY("livingroom", "x"))
.concat(sliderSVXY("livingroom", "y"))
}
},
layers: [
{
image: require("./assets/layers/rooms.svg"),
baseLayer: true,
name: "Entropia",
defaultVisibility: "visible",
opacity: 0.7,
bounds: {
topLeft: [0, 0],
bottomRight: [720, 680]
}
}
]
};
window.config = config;