<!DOCTYPE html>
<html>

<head>
  <link href="//cdn.jsdelivr.net/picnicss/4.1.1/picnic.min.css" rel="stylesheet">
  <link rel="stylesheet" href="style.css">
  <meta charset="utf-8">
  <title>Mag.JS</title>
</head>

<body>

  <nav>
    <h1>Hello Mag.JS!</h1>
    <a target="_tab" href="https://github.com/magnumjs/mag.js">GitHub</a>
  </nav>

  <article class="card">
    <header>
      <h2>Templating Comps!</h2>
      </header>
      
    <footer>
      <div id="app">
        <todos-app>Loading..</todos-app>
      </div>
    </footer>
  </article>


  <script src="//rawgit.com/magnumjs/mag.js/master/mag-latest.min.js"></script>
  <script src="//rawgit.com/magnumjs/mag.js/master/dist/mag.addons.0.22.min.js"></script>
  <script src="//rawgit.com/magnumjs/mag.js/master/src/extends/mag-template.js"></script>

  <script src="todos/todos-module.js"></script>
  <script src="todos/todos-comps.js"></script>
  <script src="todos/todos-data.js"></script>
  <script src="app.js"></script>

</body>

</html>
//Boot App:
var App = {}
var defaultProps = {
  data: TodoStore
}

App.controller = function(props) {
  //Load template container
  this['todos-app'] = mag(Todos.templateUrl, Todos, props)

}

mag.module("app", App, defaultProps)
li:empty,
.hide {
  display: none;
}

a {
  display: block;
}

a:after {
  content: " \bb";
}

.mainButton {
  font-size: 1.5em;
}

nav a {
  float: right;
  margin-top: -50px;
}

body {
  background: #fff;
  text-align: left;
  width: 90%;
  max-width: 960px;
  margin: 0 auto;
  padding: 20px 0 0;
}

nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 3em;
  padding: 0 .6em;
  background: #fff;
  box-shadow: 0 0 0.2em rgba(17, 17, 17, 0.2);
  z-index: 10000;
  transition: all .3s;
  transform-style: preserve-3d;
}

header {
  font-weight: bold;
  position: relative;
  border-bottom: 1px solid #eee;
  padding: .6em .8em;
}

footer {
  padding: .8em;
}

article {
  top: 100px;
}

.card {
  max-width: 100%;
  display: block;
  position: relative;
  box-shadow: 0;
  border-radius: .2em;
  border: 1px solid #ccc;
  overflow: hidden;
  text-align: left;
  background: #fff;
  margin-bottom: .6em;
  padding: 6px;
  transition: all .3s ease;
}
#Mag.JS

## plunk boilerplate of "Things"

Basic template loader example 
with mixing state and stateless components
and observable data store
<div>
  <h2>TODOS!</h2>
  <div class="add">
    <form>
      <input name="text">
      <input type="submit" value="Add">
    </form>
  </div>
  <div class="list">
    <ul>
      <li>
        <name></name>
      </li>
    </ul>
  </div>
</div>
var Todos = {
    templateUrl: 'todos/todos.html'
}

Todos.controller = function() {
  this.didload = () => Todos.UI.mount()
}

Todos.view = function(state, props) {

  Todos.UI.list({
    items: props.data.orderBy('id')
  })

  Todos.UI.add({
    handleAdd: function() {
      if (state.text) {
        props.data.addTodo(state.text)
        state.text = ''
      }
      return false;
    }
  })

}
//Data store:
var TodoStore = {
  todos: [{
    id: 1,
    name: 'Milk'
  }, {
    id: 2,
    name: 'Eggs'
  }],
  orderBy: function(field) {
    return TodoStore.todos.sort(function(a, b) {
      if (a[field] > b[field]) return -1;
      if (a[field] < b[field]) return 1;
      return 0;
    })
  },
  addTodo: function(item) {
    TodoStore.todos.push({id:TodoStore.todos.length+1, name: item })
  }
}
//UI Components

Todos.UI = {
  list: () => {},
  add: () => {}
}

//Define
Todos.UI.listFun = ({items}) => ({
  li: items
})
Todos.UI.addFun = ({handleAdd}) => ({
  form: {_onSubmit: handleAdd}
})


Todos.UI.mount = () => {
  //Attach
  Todos.UI.list = mag('list', Todos.UI.listFun)
  Todos.UI.add = mag('add', Todos.UI.addFun)
}