home-assistant.github.io/blog/2017/10/28/demo/index.html
2017-12-03 14:35:15 +00:00

280 lines
18 KiB
HTML
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<!doctype html>
<!--[if lt IE 7]> <html class="no-js lt-ie9 lt-ie8 lt-ie7"> <![endif]-->
<!--[if IE 7]> <html class="no-js lt-ie9 lt-ie8"> <![endif]-->
<!--[if IE 8]> <html class="no-js lt-ie9"> <![endif]-->
<!--[if gt IE 8]><!--> <html> <!--<![endif]-->
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<title>Home Assistant Demo - Home Assistant</title>
<meta name="author" content="Fabian Affolter">
<meta name="description" content="Showing a demo of Home Assistant to an audience.">
<meta name="viewport" content="width=device-width">
<link rel="canonical" href="https://home-assistant.io/blog/2017/10/28/demo/">
<meta property="fb:app_id" content="338291289691179">
<meta property="og:title" content="Home Assistant Demo">
<meta property="og:site_name" content="Home Assistant">
<meta property="og:url" content="https://home-assistant.io/blog/2017/10/28/demo/">
<meta property="og:type" content="article">
<meta property="og:description" content="Showing a demo of Home Assistant to an audience.">
<meta property="og:image" content="https://home-assistant.io/images/blog/2017-10-interactive-demo/demo-random.png">
<meta name="twitter:card" content="summary_large_image">
<meta name="twitter:site" content="@home_assistant">
<meta name="twitter:creator" content="@fabaff">
<meta name="twitter:title" content="Home Assistant Demo">
<meta name="twitter:description" content="Showing a demo of Home Assistant to an audience.">
<meta name="twitter:image" content="https://home-assistant.io/images/blog/2017-10-interactive-demo/demo-random.png">
<link href="/stylesheets/screen.css" media="screen, projection, print" rel="stylesheet">
<link href="/atom.xml" rel="alternate" title="Home Assistant" type="application/atom+xml">
<link rel='shortcut icon' href='/images/favicon.ico' />
<link rel='icon' type='image/png' href='/images/favicon-192x192.png' sizes='192x192' />
</head>
<body >
<header class='site-header'>
<div class="grid-wrapper">
<div class="grid">
<div class="grid__item three-tenths lap-two-sixths palm-one-whole ha-title">
<a href="/" class="site-title">
<img width='40' src='/demo/favicon-192x192.png'>
<span>Home Assistant</span>
</a>
</div>
<div class="grid__item seven-tenths lap-four-sixths palm-one-whole">
<nav>
<input type="checkbox" id="toggle">
<label for="toggle" class="toggle" data-open="Main Menu" data-close="Close Menu"></label>
<ul class="menu pull-right">
<li><a href="/getting-started/">Getting started</a></li>
<li><a href="/components/">Components</a></li>
<li><a href="/docs/">Docs</a></li>
<li><a href="/cookbook/">Examples</a></li>
<li><a href="/developers/">Developers</a></li>
<li><a href="/blog/">Blog</a></li>
<li><a href="/help/">Need help?</a></li>
<li><a href='#' class='show-search'><i class="icon-search"></i></a></li>
</ul>
</nav>
<div class='search-container' style='display: none'>
<div class='search'>
<i class="icon-search"></i>
<input id='search' placeholder='Search the docs…'>
<a href='#' class='close'><i class="icon-remove-sign"></i></a>
</div>
</div>
</div>
</div>
</div>
</header>
<div class="grid-wrapper">
<div class="grid grid-center">
<div class="grid__item two-thirds lap-one-whole palm-one-whole">
<article class="post">
<header>
<h1 class="title indent">Home Assistant Demo</h1>
<div class="meta clearfix">
<time datetime="2017-10-28T10:00:00+00:00" pubdate data-updated="true"><i class="icon-calendar"></i> October 28, 2017</time>
<span class="byline author vcard"><i class='icon-user'></i> Fabian Affolter</span>
<span><i class='icon-time'></i> four minutes reading time</span>
<span>
<i class="icon-tags"></i>
<ul class="tags unstyled">
<li>How-To</li>
</ul>
</span>
<a class='comments'
href="#disqus_thread"
>Comments</a>
</div>
</header>
<p>If you are planning to host a Home Assistant meetup or doing a talk, then you probably want to show Home Assistant to an audience. You could use a Wireless router, bulbs, switches, and a single board computer to do a realistic demo. For a workshop, this is what I usually do because I think that working with physical hardware is more fun for the participants. The issue is that you need time to set up, power and space. For a talk or in a location, where you only have a beamer and a table or a lectern, the physical hardware approach is not very convenient.</p>
<p>The simplest way to show Home Assistant to others is the online demo at <a href="https://home-assistant.io/demo/">https://home-assistant.io/demo/</a></p>
<p class="img">
<img src="/images/blog/2017-10-interactive-demo/online-demo.png" />
Home Assistants online demo
</p>
<a name="read-more"></a>
<h2><a class="title-link" name="--demo-mode-and-demo-platform" href="#--demo-mode-and-demo-platform"></a> <code class="highlighter-rouge">--demo-mode</code> and Demo platform</h2>
<p>To be safe for your talk, you dont want to depend on an internet connection. The demo mode <a href="/docs/tools/hass/"><code class="highlighter-rouge">--demo-mode</code></a> allows you to run a demo locally including the latest features. Make sure that you have a backup of your configuration.</p>
<div class="language-bash highlighter-rouge"><pre class="highlight"><code><span class="gp">$ </span>hass --demo-mode
</code></pre>
</div>
<p>If you already have a <code class="highlighter-rouge">configuration.yaml</code> file in place then you will get a combination of your setup with all available <a href="/components/demo/"><code class="highlighter-rouge">demo</code></a> platforms. This can be overwhelming for the audience. The suggestion is that you tailor the demo to your needs by only showing a few selected platforms. For example:</p>
<div class="language-yaml highlighter-rouge"><pre class="highlight"><code><span class="s">sensor</span><span class="pi">:</span>
<span class="pi">-</span> <span class="s">platform</span><span class="pi">:</span> <span class="s">demo</span>
<span class="s">binary_sensor</span><span class="pi">:</span>
<span class="pi">-</span> <span class="s">platform</span><span class="pi">:</span> <span class="s">demo</span>
<span class="s">switch</span><span class="pi">:</span>
<span class="pi">-</span> <span class="s">platform</span><span class="pi">:</span> <span class="s">demo</span>
</code></pre>
</div>
<p class="img">
<img src="/images/blog/2017-10-interactive-demo/demo-platforms.png" />
Home Assistants demo platforms
</p>
<h2><a class="title-link" name="random-platforms" href="#random-platforms"></a> <code class="highlighter-rouge">random</code> platforms</h2>
<p>Till now the frontend is static. Nothing is changing over time. Starting with 0.57 we ship a <a href="https://github.com/home-assistant/home-assistant.github.io/blob/next/source/_components/binary_sensor.random.markdown"><code class="highlighter-rouge">random</code> binary sensor</a> platform in addition to the already available <a href="/components/sensor.random/"><code class="highlighter-rouge">random</code> sensor</a>.</p>
<p>By adding those platform to your <code class="highlighter-rouge">configuration.yaml</code> file, your demo will become more interactive.</p>
<div class="language-yaml highlighter-rouge"><pre class="highlight"><code><span class="s">sensor</span><span class="pi">:</span>
<span class="pi">-</span> <span class="s">platform</span><span class="pi">:</span> <span class="s">demo</span>
<span class="s">name</span><span class="pi">:</span> <span class="s">Temperature</span>
<span class="s">unit_of_measurement</span><span class="pi">:</span> <span class="s2">"</span><span class="s">°C"</span>
<span class="s">binary_sensor</span><span class="pi">:</span>
<span class="pi">-</span> <span class="s">platform</span><span class="pi">:</span> <span class="s">random</span>
<span class="s">name</span><span class="pi">:</span> <span class="s">Front Door</span>
<span class="pi">-</span> <span class="s">platform</span><span class="pi">:</span> <span class="s">random</span>
<span class="s">name</span><span class="pi">:</span> <span class="s">Back Door</span>
<span class="s">scan_interval</span><span class="pi">:</span> <span class="s">5</span>
</code></pre>
</div>
<p class="img">
<img src="/images/blog/2017-10-interactive-demo/demo-random.png" />
Demo with <code class="highlighter-rouge">random</code> platforms
</p>
<p>The <code class="highlighter-rouge">random</code> and the <code class="highlighter-rouge">demo</code> platforms can, of course, be used together. With a little work and some of the <a href="/components/#search/template"><code class="highlighter-rouge">template</code></a> platforms or the <a href="/components/#search/input"><code class="highlighter-rouge">input_*</code></a> components it would even be possible to simulate a complete apartment or a house. For a hint check the sample below:</p>
<div class="language-yaml highlighter-rouge"><pre class="highlight"><code><span class="s">input_boolean</span><span class="pi">:</span>
<span class="s">on_off</span><span class="pi">:</span>
<span class="s">name</span><span class="pi">:</span> <span class="s">On or off</span>
<span class="s">binary_sensor</span><span class="pi">:</span>
<span class="pi">-</span> <span class="s">platform</span><span class="pi">:</span> <span class="s">template</span>
<span class="s">sensors</span><span class="pi">:</span>
<span class="s">on_tester</span><span class="pi">:</span>
<span class="s">value_template</span><span class="pi">:</span> <span class="s2">"</span><span class="s">{{</span><span class="nv"> </span><span class="s">states.input_boolean.on_off.state</span><span class="nv"> </span><span class="s">==</span><span class="nv"> </span><span class="s">'on'</span><span class="nv"> </span><span class="s">}}"</span>
<span class="s">friendly_name</span><span class="pi">:</span> <span class="s1">'</span><span class="s">Movement'</span>
<span class="s">device_class</span><span class="pi">:</span> <span class="s">motion</span>
</code></pre>
</div>
<h2><a class="title-link" name="mqtt-discovery" href="#mqtt-discovery"></a> MQTT Discovery</h2>
<p>This is a section for advanced users as it will require to run a separate script. Instead of adding <code class="highlighter-rouge">demo</code> platforms to the configuration this setup make use of <a href="/docs/mqtt/discovery/">MQTT discovery</a> and the <a href="/docs/mqtt/broker/#embedded-broker">embedded MQTT broker</a>. Simply add MQTT to your <code class="highlighter-rouge">configuration.yaml</code> file with <code class="highlighter-rouge">discovery:</code></p>
<div class="language-yaml highlighter-rouge"><pre class="highlight"><code><span class="s">mqtt</span><span class="pi">:</span>
<span class="s">discovery</span><span class="pi">:</span> <span class="s">true</span>
</code></pre>
</div>
<p>Download the <a href="https://github.com/home-assistant/home-assistant-dev-helper/blob/master/ha-mqtt-demo.py">sample script</a>. It depends on <a href="https://pypi.python.org/pypi/paho-mqtt">paho-mqtt</a>. If you run the script inside your <a href="/docs/installation/virtualenv/">Home Assistants virtual environment</a> then you are good to go as the dependency should be present if you have used MQTT before. Otherwise, install it with <code class="highlighter-rouge">$ pip3 install paho-mqtt</code>. The same applies to the embedded broker.</p>
<div class="language-bash highlighter-rouge"><pre class="highlight"><code><span class="gp">(ha)[ha-demo]$ </span>python3 ha-mqtt-demo.py
Demo is running... -&gt; CTRL + C to shutdown
</code></pre>
</div>
<p>It will create sensors, a light, and a switch and update the states as long the script is running. It possible to stop and restart script without losing the entities.</p>
<p>Some users share their slides and other documents in <a href="https://github.com/home-assistant/home-assistant-assets">our assets repository</a>. Also, take a look at that repository if you need a logo for your slides.</p>
</article>
<section id="disqus">
<h3 class="indent title">Comments</h3>
<div id="disqus_thread" aria-live="polite"><noscript>Please enable JavaScript to view the <a href="http://disqus.com/?ref_noscript">comments powered by Disqus.</a></noscript></div>
</section>
</div>
<aside id="sidebar" class="grid__item one-third lap-one-whole palm-one-whole">
<div class="grid">
<section class="aside-module grid__item one-whole lap-one-half">
<h1 class="title delta">About Home Assistant</h1>
<ul class="divided">
<li>
Home Assistant is an open-source home automation platform running on Python 3. Track and control all devices at home and automate control.
</li>
<li><a href='/getting-started/'>Get started with Home Assistant</a></li>
<li><a href='/demo/'>Try the online demo</a></li>
<li><a class="twitter-follow-button" href="https://twitter.com/Home_Assistant">Follow Home Assistant on Twitter</a></li>
<li><div class="fb-like" data-href="https://www.facebook.com/homeassistantio/" data-layout="standard" data-action="like" data-size="small" data-show-faces="true" data-share="false"></div></li>
</ul>
</section>
<div id="fb-root"></div>
<script>!function(d,s,id){var js,fjs=d.getElementsByTagName(s)[0];if(!d.getElementById(id)){js=d.createElement(s);js.id=id;js.async=true;js.src='//platform.twitter.com/widgets.js';fjs.parentNode.insertBefore(js,fjs);}}(document, 'script', 'twitter-wjs');</script>
<script>(function(d,s,id){var js,fjs=d.getElementsByTagName(s)[0];if(d.getElementById(id)){return;}js=d.createElement(s);js.id=id;js.async=true;js.src="//connect.facebook.net/en_US/all.js#appId=338291289691179&xfbml=1";fjs.parentNode.insertBefore(js,fjs);}(document,'script','facebook-jssdk'));</script>
<section class="sharing aside-module grid__item one-whole lap-one-half">
<h1 class="title delta">Share this post</h1>
<a href="//twitter.com/share"
class="twitter-share-button"
data-via="home_assistant"
data-related="home_assistant"
data-url="https://home-assistant.io/blog/2017/10/28/demo/"
data-counturl="https://home-assistant.io/blog/2017/10/28/demo/" >Tweet</a>
<div class="fb-share-button" style='top: -6px;'
data-href="https://home-assistant.io/blog/2017/10/28/demo/"
data-layout="button_count">
</div>
<div class="g-plusone" data-size="standard"></div>
</section>
<script src="https://apis.google.com/js/platform.js" async defer></script>
<section id="recent-posts" class="aside-module grid__item one-whole lap-one-half">
<h1 class="title delta">Recent Posts</h1>
<ul class="divided">
<li class="post">
<a href="/blog/2017/12/03/release-59/">0.59: Order pizza, Entity Picker, Color Wheel</a>
</li>
<li class="post">
<a href="/blog/2017/11/29/hassio-virtual-machine/">Set up Hass.io on top of a virtual machine</a>
</li>
<li class="post">
<a href="/blog/2017/11/18/release-58/">0.58: More translations, faster frontend, system log</a>
</li>
<li class="post">
<a href="/blog/2017/11/12/tor/">Secure remote access to Home Assistant using Tor</a>
</li>
<li class="post">
<a href="/blog/2017/11/10/ttn-with-mqtt/">Home Assistant and The Things Network (TTN)</a>
</li>
</ul>
</section>
</div>
</aside>
</div>
</div>
<footer>
<div class="grid-wrapper">
<div class="grid">
<div class="grid__item">
<div class="copyright">
<a rel="me" href='https://twitter.com/home_assistant'><i class="icon-twitter"></i></a>
<a rel="me" href='https://facebook.com/homeassistantio'><i class="icon-facebook"></i></a>
<a rel="me" href='https://plus.google.com/110560654828510104551'><i class="icon-google-plus"></i></a>
<a rel="me" href='https://github.com/home-assistant/home-assistant'><i class="icon-github"></i></a>
<div class="credit">
Contact us at <a href='mailto:hello@home-assistant.io'>hello@home-assistant.io</a> (no support!).<br>
Website powered by <a href='http://jekyllrb.com/'>Jekyll</a> and the <a href='https://github.com/coogie/oscailte'>Oscalite theme</a>.<br />
Hosted by <a href='https://pages.github.com/'>GitHub</a> and served by <a href='https://cloudflare.com'>CloudFlare</a>.
</div>
<a rel="license" href="http://creativecommons.org/licenses/by-nc-sa/4.0/"><img alt="Creative Commons License" style="border-width:0" src="https://i.creativecommons.org/l/by-nc-sa/4.0/88x31.png" /></a><br /><span xmlns:dct="http://purl.org/dc/terms/" property="dct:title">home-assistant.io</span> is licensed under a <a rel="license" href="http://creativecommons.org/licenses/by-nc-sa/4.0/">Creative Commons Attribution-NonCommercial-ShareAlike 4.0 International License</a>.
</div>
</div>
</div>
</div>
</footer>
<script>
var _gaq=[['_setAccount','UA-57927901-1'],['_trackPageview']];
(function(d,t){var g=d.createElement(t),s=d.getElementsByTagName(t)[0];
g.src=('https:'==location.protocol?'//ssl':'//www')+'.google-analytics.com/ga.js';
s.parentNode.insertBefore(g,s)}(document,'script'));
</script>
<script>
var disqus_shortname = 'home-assistant';
// var disqus_developer = 1;
var disqus_identifier = 'https://home-assistant.io/blog/2017/10/28/demo/';
var disqus_url = 'https://home-assistant.io/blog/2017/10/28/demo/';
var disqus_script = 'embed.js';
(function () {
var dsq = document.createElement('script'); dsq.type = 'text/javascript'; dsq.async = true;
dsq.src = '//' + disqus_shortname + '.disqus.com/' + disqus_script;
(document.getElementsByTagName('head')[0] || document.getElementsByTagName('body')[0]).appendChild(dsq);
}());
</script>
<link rel="stylesheet" href="https://cdn.jsdelivr.net/docsearch.js/2/docsearch.min.css" />
<script type="text/javascript" src="https://cdn.jsdelivr.net/docsearch.js/2/docsearch.min.js"></script>
<script type="text/javascript">
docsearch({
apiKey: 'ae96d94b201c5444c8a443093edf3efb',
indexName: 'home-assistant',
inputSelector: '#search',
debug: false // Set debug to true if you want to inspect the dropdown
});
document.querySelector('.search .close').addEventListener('click', function(ev) {
ev.preventDefault();
document.querySelector('.search-container').style.display = 'none';
});
document.querySelector('.show-search').addEventListener('click', function(ev) {
ev.preventDefault();
document.querySelector('.search-container').style.display = 'block';
document.getElementById('toggle').checked = false;
document.querySelector('.search-container input').focus();
});
</script>
</body>
</html>