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
|
;(function (FMS, Backbone, _, $) {
_.extend( FMS, {
FMSView: Backbone.View.extend({
tag: 'div',
events: {
'pagehide': 'destroy',
'pageshow': 'afterDisplay',
'click .ui-btn-left': 'onClickButtonPrev',
'click .ui-btn-right': 'onClickButtonNext'
},
render: function(){
if ( !this.template ) {
console.log('no template to render');
return;
}
template = _.template( tpl.get( this.template ) );
if ( this.model ) {
this.$el.html(template(this.model.toJSON()));
} else {
this.$el.html(template());
}
this.afterRender();
return this;
},
afterRender: function() {},
afterDisplay: function() {},
navigate: function( route, direction ) {
if ( !direction ) {
direction == 'left';
}
FMS.router.navigate( route, { trigger: true } );
},
onClickButtonPrev: function() {
this.navigate( this.prev, 'right' );
},
onClickButtonNext: function() {
this.navigate( this.next, 'left' );
},
displayError: function(msg) {
alert(msg);
},
destroy: function() { console.log('destory for ' + this.id); this._destroy(); this.remove(); },
_destroy: function() {}
})
});
_.extend( FMS.FMSView, Backbone.Events );
})(FMS, Backbone, _, $);
|