view web/views/set.tpl @ 482:9950ffa9a79b

set nearly working
author Matt Johnston <matt@ucc.asn.au>
date Tue, 04 Feb 2014 22:49:16 +0800
parents
children 177f616893e6
line wrap: on
line source

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
<script src="jquery-2.1.0.js"></script>
<script>
%include riot.min.js
</script>

<style type="text/css">
span.no_selection {
    -webkit-user-select: none; // webkit (safari, chrome) browsers
    -moz-user-select: none; // mozilla browsers
    -khtml-user-select: none; // webkit (konqueror) browsers
}

body {
    font-family: "sans-serif";
}

input {
    border: 2px solid transparent;
    border-radius: 4px;
    background-color: white;
    border-color: black;
    padding: 0;
    font-size: 80%;
}

input[type="button"] {
    width: 4em;
    height: 4em;
    margin-left: 0.5em;
}

input[type="submit"] {
    width: 10em;
    height: 4em;
    margin-top: 1em;
    align: center;
}

input[type="text"] {
    height: 4em;
    text-align: center;
}

.onbutton {
    background-color: #cdf;
}

.existing {
    margin-top: 1em;
    font-size: 70%;
}

</style>
<title>Set templog</title>
</head>

<body>

<section id="paramlist">
</div>

</body>

<script type="html/num_input">
<div id="{id}">
<span class="existing">{title} <span id="existing_{name}">{oldvalue}</span>{unit}</span>
<br/>
<input type="text" id="input" name="input_{name}" />
<!--
<input type="button" class="button_down" id="down" name="down_{name}" value="-" "/>
<input type="button" class="button_up" id="up" name="up_{name}" value="+" "/>
-->
</div>
</script>

<script type="html/yesno_button">
<div id="{id}">
<span class="existing">{title} <span id="existing_{name}">{oldvalue}</span></span>
<br/>
<input type="button" class="button_no" id="no_{name}" name="no_{name}" value="No"/>
<input type="button" class="button_yes" id="yes_{name}" name="yes_{name}" value="Yes"/>
</div>
</script>

<script>

function Setter(params) {
    var self = $.observable(this);

    self.params = params;

    $.each(self.params, function(idx, param) {
        param.id = "param_id_" + idx;
    });

    self.edit = function(param) {
        params[param.name] = param;
        self.trigger("edit", param);
    }

    self.adjust = function(param, updown) {
        // XXX increment
        self.trigger("edit", param);
    }

}

(function() { 'use strict';

var params = {{!inline_data}};
window.setter = new Setter(params);

var root = $("#paramlist");

var number_template = $("[type='html/num_input']").html();
var button_template = $("[type='html/yesno_button']").html();

setter.on("add", add);
setter.on("edit", function(param)
{
    var el = $("#" + param.id);
    if (param.kind === "number")
    {
        $(".input", el).text(param.value).value(param.value);
    }
    else if (param.kind === "yesno")
    {
        set_state(el, param.value);
    }
})

$.route(function(hash) {

// clear list and add new ones
root.empty() && $.each(setter.params, function (idx, p) {
    add(p);
})
})

function set_state(el, value)
{
    var button_yes = $(".button_yes", el);
    var button_no = $(".button_no", el);
    if (value)
    {
        button_yes.addClass("onbutton");
        button_no.removeClass("onbutton");
    }
    else
    {
        button_no.addClass("onbutton");
        button_yes.removeClass("onbutton");
    }
}

function add(param)
{
    if (param.kind === "number")
    {
        var el = $($.render(number_template, param)).appendTo(root);
        var input = $(".input", el);
    }
    else if (param.kind === "yesno")
    {
        var el = $($.render(button_template, param)).appendTo(root);
        var button_yes = $(".button_yes", el);
        var button_no = $(".button_no", el);

        button_yes.click(function() {
            param.value = true;
            setter.edit(param);
        })

        button_no.click(function() {
            param.value = false;
            setter.edit(param);
        })

        set_state(el, param.value);
    }
}

})()

</script>

</html>