/
Ejercicio6.html
86 lines (73 loc) · 3.1 KB
/
Ejercicio6.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
<!DOCTYPE html>
<html>
<head>
<script src="http://fb.me/react-with-addons-0.12.0.js"></script>
<script src="http://fb.me/JSXTransformer-0.12.0.js"></script>
<link rel="stylesheet" href="bootstrap.min.css">
<script src="https://code.jquery.com/jquery-2.1.3.min.js"></script>
</head>
<body>
<div class="container">
<div class="row">
<div class="col-md-3"></div>
<div id="Tareas" class="col-md-6"></div>
<div class="col-md-3"></div>
</div>
</div>
<script type="text/jsx">
var ListaTareas = React.createClass({
CrearElementosDeLista: function(itemText) {
return <li className="ui-state-default" > <div className="checkbox">
<label>
<button className="btn btn-danger" onClick={this.props.EstadoBorrar.bind(this, itemText)} >x</button> {itemText}</label>
</div></li>;
},
render: function() {
return <ul id="sortable" className="list-unstyled">{this.props.ElementosLista.map(this.CrearElementosDeLista)}</ul>;
}
});
var AplicacionTareas = React.createClass({
getInitialState: function() { return {ElementosLista: ["Elemento 1","Elemento 2"], text: ''};
},
componentWillMount:function(){
this.actualizarInformacion();
},
actualizarInformacion:function(){
$.get("Datos/index.php", function(resultado) {
this.setState({ElementosLista:resultado});
}.bind(this));
},
EstadoBorrar: function(ElementoAborrar, e) {
var LosElementosLista = this.state.ElementosLista;
var indice = LosElementosLista.indexOf(ElementoAborrar);
LosElementosLista.splice(indice, 1);
this.setState({ElementosLista: LosElementosLista});
},
EstadoCambio: function(e) {
this.setState({text: e.target.value});
},
EstadoSubmit: function(e) {
e.preventDefault();
var nextElementosLista = this.state.ElementosLista.concat([this.state.text]);
var nextText = '';
this.setState({ElementosLista: nextElementosLista, text: nextText});
},
render: function() {
return (
<div>
<h3>Lista de Tareas</h3>
<form onSubmit={this.EstadoSubmit} >
<input className="form-control" placeholder="Agregar a la lista" onChange={this.EstadoCambio} value={this.state.text} />
<br/><button className="btn btn-success btn-block " >{'Agregar a lista #' + (this.state.ElementosLista.length )}</button>
</form>
<hr/>
<ListaTareas ElementosLista={this.state.ElementosLista}
EstadoBorrar={this.EstadoBorrar} />
</div>
);
}
});
React.render(<AplicacionTareas />, document.getElementById('Tareas'));
</script>
</body>
</html>