-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathflux-riot.js
134 lines (98 loc) · 2.66 KB
/
flux-riot.js
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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
;(function() {
var riot = this.riot
var flux_riot = { version: '0.2.0' }
'use strict'
flux_riot.BaseStore = (function() {
var CHANGE_EVENT = 'STORE_CHANGE_EVENT'
function BaseStore() {
riot.observable(this)
}
BaseStore.prototype = {
addChangeListener: function(callback) {
this.on(CHANGE_EVENT, callback)
},
removeChangeListener: function(callback) {
this.off(CHANGE_EVENT, callback)
},
emitChange: function() {
this.trigger(CHANGE_EVENT)
}
}
return BaseStore
})()
flux_riot.storeMixin = function(tag, store, callback) {
tag.store = store
tag.on('mount', function() {
return store.addChangeListener(callback)
})
tag.on('unmount', function() {
return store.removeChangeListener(callback)
})
}
flux_riot.BaseRouter = (function() {
var regexFuncs = []
function regexTransfer(path) {
var parts = path.split('/')
var regexParts = []
for (var i = 0; i < parts.length; i++) {
var part = parts[i]
if (!(part && part.length > 0)) continue
if (part[0] === ':') {
regexParts.push('((?:(?!\\/).)+?)')
} else {
regexParts.push(part)
}
}
return RegExp("^" + (regexParts.join('\\/')) + "\\/?$", "i")
}
function route(path) {
if (regexFuncs.length === 0) return
if (path === '') return regexFuncs[0][1].apply(null, [])
for (var i = 1; i < regexFuncs.length; i++) {
var regexFunc = regexFuncs[i]
var m = path.match(regexFunc[0])
if (m != null) return regexFunc[1].apply(null, m.slice(1))
}
}
function routes() {
if (!(arguments.length > 0)) return
regexFuncs.push([ '', arguments[0] ])
for (var i = 1; i < arguments.length; i += 2) {
regex = regexTransfer(arguments[i])
regexFuncs.push([ regex, arguments[i + 1] ])
}
}
function start(r) {
return riot.route.exec(r || route)
}
riot.route.parser(function(path) { return [path] })
riot.route(route)
return {
routes: routes,
start: start
}
})()
flux_riot.Constants = {
ActionSources: {
SERVER_ACTION: 'SERVER_ACTION',
VIEW_ACTION: 'VIEW_ACTION'
}
}
var Dispatcher = require('flux').Dispatcher
var assign = require('object-assign')
flux_riot.Dispatcher = assign(new Dispatcher(), {
handleServerAction: function(action) {
return this.handleAction(action, flux_riot.Constants.ActionSources.SERVER_ACTION)
},
handleViewAction: function(action) {
return this.handleAction(action, flux_riot.Constants.ActionSources.VIEW_ACTION)
},
handleAction: function(action, source) {
return this.dispatch({
source: source,
action: action
})
}
})
this.flux_riot = flux_riot
})()