Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
T
todomvc
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Sven Franck
todomvc
Commits
2909d17d
Commit
2909d17d
authored
Sep 10, 2016
by
Olivier Scherrer
Committed by
Sam Saccone
Sep 10, 2016
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix #812 Remove routing mark for Olives (#1634)
parent
4b300dc1
Changes
13
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
13 changed files
with
4719 additions
and
4590 deletions
+4719
-4590
.jscsrc
.jscsrc
+1
-0
examples/olives/.gitignore
examples/olives/.gitignore
+3
-0
examples/olives/css/app.css
examples/olives/css/app.css
+8
-0
examples/olives/index.html
examples/olives/index.html
+12
-1
examples/olives/js/lib/RouterPlugin.js
examples/olives/js/lib/RouterPlugin.js
+43
-0
examples/olives/js/lib/router.js
examples/olives/js/lib/router.js
+11
-0
examples/olives/js/lib/tools.js
examples/olives/js/lib/tools.js
+0
-0
examples/olives/js/uis/controls.js
examples/olives/js/uis/controls.js
+10
-7
examples/olives/js/uis/list.js
examples/olives/js/uis/list.js
+11
-7
examples/olives/node_modules/todomvc-app-css/index.css
examples/olives/node_modules/todomvc-app-css/index.css
+2
-2
examples/olives/node_modules/todomvc-common/base.js
examples/olives/node_modules/todomvc-common/base.js
+7
-2
examples/olives/olives-todo.js
examples/olives/olives-todo.js
+4607
-4568
examples/olives/package.json
examples/olives/package.json
+4
-3
No files found.
.jscsrc
View file @
2909d17d
...
@@ -42,6 +42,7 @@
...
@@ -42,6 +42,7 @@
"examples/elm/elm-stuff/**",
"examples/elm/elm-stuff/**",
"examples/humble/js/**",
"examples/humble/js/**",
"examples/js_of_ocaml/js/*.js",
"examples/js_of_ocaml/js/*.js",
"examples/olives/olives-todo.js",
"examples/polymer/elements/elements.build.js",
"examples/polymer/elements/elements.build.js",
"examples/spine/js/**",
"examples/spine/js/**",
"examples/thorax/js/lib/backbone-localstorage.js",
"examples/thorax/js/lib/backbone-localstorage.js",
...
...
examples/olives/.gitignore
View file @
2909d17d
node_modules/**
**/.idea/
node_modules/todomvc-app-css/*
node_modules/todomvc-app-css/*
!node_modules/todomvc-app-css/index.css
!node_modules/todomvc-app-css/index.css
...
...
examples/olives/css/app.css
View file @
2909d17d
...
@@ -5,3 +5,11 @@
...
@@ -5,3 +5,11 @@
.show
{
.show
{
display
:
block
!important
;
display
:
block
!important
;
}
}
.show-completed
li
:not
(
.completed
)
{
display
:
none
;
}
.show-active
li
.completed
{
display
:
none
;
}
examples/olives/index.html
View file @
2909d17d
...
@@ -16,7 +16,7 @@
...
@@ -16,7 +16,7 @@
<section
id=
"main"
data-stats=
"bind:toggleClass,nbItems,show"
>
<section
id=
"main"
data-stats=
"bind:toggleClass,nbItems,show"
>
<input
id=
"toggle-all"
type=
"checkbox"
data-event=
"listen:click,toggleAll"
data-stats=
"bind:toggleCheck,nbCompleted"
>
<input
id=
"toggle-all"
type=
"checkbox"
data-event=
"listen:click,toggleAll"
data-stats=
"bind:toggleCheck,nbCompleted"
>
<label
for=
"toggle-all"
>
Mark all as complete
</label>
<label
for=
"toggle-all"
>
Mark all as complete
</label>
<ul
id=
"todo-list"
data-model=
"foreach"
>
<ul
id=
"todo-list"
data-model=
"foreach"
data-router=
"toggleClassOnRouteChange"
>
<li
data-model=
"bind:toggleClass,completed,completed;"
>
<li
data-model=
"bind:toggleClass,completed,completed;"
>
<div
class=
"view"
>
<div
class=
"view"
>
<input
class=
"toggle"
type=
"checkbox"
data-model=
"bind:checked,completed"
>
<input
class=
"toggle"
type=
"checkbox"
data-model=
"bind:checked,completed"
>
...
@@ -29,6 +29,17 @@
...
@@ -29,6 +29,17 @@
</section>
</section>
<footer
id=
"footer"
data-stats=
"bind:toggleClass,nbItems,show"
>
<footer
id=
"footer"
data-stats=
"bind:toggleClass,nbItems,show"
>
<span
id=
"todo-count"
><strong
data-stats=
"bind:innerHTML,nbLeft"
>
0
</strong>
<span
data-stats=
"bind:innerHTML,plural"
></span>
left
</span>
<span
id=
"todo-count"
><strong
data-stats=
"bind:innerHTML,nbLeft"
>
0
</strong>
<span
data-stats=
"bind:innerHTML,plural"
></span>
left
</span>
<ul
id=
"filters"
>
<li>
<a
data-router=
"isLinkActive:selected"
href=
"#/"
>
All
</a>
</li>
<li>
<a
data-router=
"isLinkActive:selected"
href=
"#/active"
>
Active
</a>
</li>
<li>
<a
data-router=
"isLinkActive:selected"
href=
"#/completed"
>
Completed
</a>
</li>
</ul>
<button
id=
"clear-completed"
data-event=
"listen:click,delAll"
data-stats=
"bind:toggleClass,nbCompleted,show"
>
<button
id=
"clear-completed"
data-event=
"listen:click,delAll"
data-stats=
"bind:toggleClass,nbCompleted,show"
>
Clear completed
Clear completed
</button>
</button>
...
...
examples/olives/js/lib/RouterPlugin.js
0 → 100644
View file @
2909d17d
'
use strict
'
;
var
tools
=
require
(
'
./tools
'
);
var
routes
=
{
'
#/
'
:
'
show-all
'
,
'
#/completed
'
:
'
show-completed
'
,
'
#/active
'
:
'
show-active
'
};
/**
* A quick plugin to interface with a url-highway router.
* @param {url highway} the router's instance
* @constructor
*/
module
.
exports
=
function
RouterPlugin
(
router
)
{
var
currentRoute
=
router
.
getLastRoute
();
/**
* Set a given className to a dom element if its hash matches with the url's hash
* @param link
* @param className
*/
this
.
isLinkActive
=
function
isLinkActive
(
link
,
className
)
{
if
(
router
.
getLastRoute
()
===
link
.
hash
)
{
link
.
classList
.
add
(
className
);
}
router
.
watch
(
function
(
route
)
{
tools
.
toggleClass
.
call
(
link
,
link
.
hash
===
route
,
className
);
});
};
this
.
toggleClassOnRouteChange
=
function
toggleClassOnRouteChange
(
list
)
{
router
.
watch
(
function
(
route
)
{
list
.
classList
.
remove
(
routes
[
currentRoute
]);
list
.
classList
.
add
(
routes
[
route
]);
currentRoute
=
route
;
});
};
router
.
start
(
'
#/
'
);
};
examples/olives/js/lib/router.js
0 → 100644
View file @
2909d17d
'
use strict
'
;
var
UrlHighway
=
require
(
'
url-highway
'
);
var
urlHighway
=
new
UrlHighway
();
urlHighway
.
parse
=
function
(
hash
)
{
return
[
hash
];
};
module
.
exports
=
urlHighway
;
examples/olives/js/lib/
T
ools.js
→
examples/olives/js/lib/
t
ools.js
View file @
2909d17d
File moved
examples/olives/js/uis/controls.js
View file @
2909d17d
...
@@ -2,7 +2,9 @@
...
@@ -2,7 +2,9 @@
var
OObject
=
require
(
'
olives
'
).
OObject
;
var
OObject
=
require
(
'
olives
'
).
OObject
;
var
EventPlugin
=
require
(
'
olives
'
)[
'
Event.plugin
'
];
var
EventPlugin
=
require
(
'
olives
'
)[
'
Event.plugin
'
];
var
BindPlugin
=
require
(
'
olives
'
)[
'
Bind.plugin
'
];
var
BindPlugin
=
require
(
'
olives
'
)[
'
Bind.plugin
'
];
var
Tools
=
require
(
'
../lib/Tools
'
);
var
tools
=
require
(
'
../lib/tools
'
);
var
router
=
require
(
'
../lib/router
'
);
var
RouterPlugin
=
require
(
'
../lib/RouterPlugin
'
);
module
.
exports
=
function
controlsInit
(
view
,
model
,
stats
)
{
module
.
exports
=
function
controlsInit
(
view
,
model
,
stats
)
{
// The OObject (the controller) inits with a default model which is a simple store
// The OObject (the controller) inits with a default model which is a simple store
...
@@ -10,7 +12,7 @@ module.exports = function controlsInit(view, model, stats) {
...
@@ -10,7 +12,7 @@ module.exports = function controlsInit(view, model, stats) {
var
controls
=
new
OObject
(
model
);
var
controls
=
new
OObject
(
model
);
// A function to get the completed tasks
// A function to get the completed tasks
var
getCompleted
=
function
()
{
function
getCompleted
()
{
var
completed
=
[];
var
completed
=
[];
model
.
loop
(
function
(
value
,
id
)
{
model
.
loop
(
function
(
value
,
id
)
{
if
(
value
.
completed
)
{
if
(
value
.
completed
)
{
...
@@ -18,23 +20,24 @@ module.exports = function controlsInit(view, model, stats) {
...
@@ -18,23 +20,24 @@ module.exports = function controlsInit(view, model, stats) {
}
}
});
});
return
completed
;
return
completed
;
}
;
}
// Update all stats
// Update all stats
var
updateStats
=
function
()
{
function
updateStats
()
{
var
nbCompleted
=
getCompleted
().
length
;
var
nbCompleted
=
getCompleted
().
length
;
stats
.
set
(
'
nbItems
'
,
model
.
count
());
stats
.
set
(
'
nbItems
'
,
model
.
count
());
stats
.
set
(
'
nbLeft
'
,
stats
.
get
(
'
nbItems
'
)
-
nbCompleted
);
stats
.
set
(
'
nbLeft
'
,
stats
.
get
(
'
nbItems
'
)
-
nbCompleted
);
stats
.
set
(
'
nbCompleted
'
,
nbCompleted
);
stats
.
set
(
'
nbCompleted
'
,
nbCompleted
);
stats
.
set
(
'
plural
'
,
stats
.
get
(
'
nbLeft
'
)
===
1
?
'
item
'
:
'
items
'
);
stats
.
set
(
'
plural
'
,
stats
.
get
(
'
nbLeft
'
)
===
1
?
'
item
'
:
'
items
'
);
}
;
}
// Add plugins to the UI.
// Add plugins to the UI.
controls
.
seam
.
addAll
({
controls
.
seam
.
addAll
({
event
:
new
EventPlugin
(
controls
),
event
:
new
EventPlugin
(
controls
),
router
:
new
RouterPlugin
(
router
),
stats
:
new
BindPlugin
(
stats
,
{
stats
:
new
BindPlugin
(
stats
,
{
toggleClass
:
T
ools
.
toggleClass
toggleClass
:
t
ools
.
toggleClass
})
})
});
});
...
@@ -42,7 +45,7 @@ module.exports = function controlsInit(view, model, stats) {
...
@@ -42,7 +45,7 @@ module.exports = function controlsInit(view, model, stats) {
controls
.
alive
(
view
);
controls
.
alive
(
view
);
// Delete all tasks
// Delete all tasks
controls
.
delAll
=
function
()
{
controls
.
delAll
=
function
delAll
()
{
model
.
delAll
(
getCompleted
());
model
.
delAll
(
getCompleted
());
};
};
...
...
examples/olives/js/uis/list.js
View file @
2909d17d
...
@@ -2,14 +2,16 @@
...
@@ -2,14 +2,16 @@
var
OObject
=
require
(
'
olives
'
).
OObject
;
var
OObject
=
require
(
'
olives
'
).
OObject
;
var
EventPlugin
=
require
(
'
olives
'
)[
'
Event.plugin
'
];
var
EventPlugin
=
require
(
'
olives
'
)[
'
Event.plugin
'
];
var
BindPlugin
=
require
(
'
olives
'
)[
'
Bind.plugin
'
];
var
BindPlugin
=
require
(
'
olives
'
)[
'
Bind.plugin
'
];
var
Tools
=
require
(
'
../lib/Tools
'
);
var
tools
=
require
(
'
../lib/tools
'
);
var
router
=
require
(
'
../lib/router
'
);
var
RouterPlugin
=
require
(
'
../lib/routerPlugin
'
);
module
.
exports
=
function
listInit
(
view
,
model
,
stats
)
{
module
.
exports
=
function
listInit
(
view
,
model
,
stats
)
{
// The OObject (the controller) initializes with a default model which is a simple store
// The OObject (the controller) initializes with a default model which is a simple store
// But it can be initialized with any other store, like the LocalStore
// But it can be initialized with any other store, like the LocalStore
var
list
=
new
OObject
(
model
);
var
list
=
new
OObject
(
model
);
var
modelPlugin
=
new
BindPlugin
(
model
,
{
var
modelPlugin
=
new
BindPlugin
(
model
,
{
toggleClass
:
T
ools
.
toggleClass
toggleClass
:
t
ools
.
toggleClass
});
});
var
ENTER_KEY
=
13
;
var
ENTER_KEY
=
13
;
var
ESC_KEY
=
27
;
var
ESC_KEY
=
27
;
...
@@ -18,8 +20,9 @@ module.exports = function listInit(view, model, stats) {
...
@@ -18,8 +20,9 @@ module.exports = function listInit(view, model, stats) {
list
.
seam
.
addAll
({
list
.
seam
.
addAll
({
event
:
new
EventPlugin
(
list
),
event
:
new
EventPlugin
(
list
),
model
:
modelPlugin
,
model
:
modelPlugin
,
router
:
new
RouterPlugin
(
router
),
stats
:
new
BindPlugin
(
stats
,
{
stats
:
new
BindPlugin
(
stats
,
{
toggleClass
:
T
ools
.
toggleClass
,
toggleClass
:
t
ools
.
toggleClass
,
toggleCheck
:
function
(
value
)
{
toggleCheck
:
function
(
value
)
{
this
.
checked
=
model
.
count
()
===
value
?
'
on
'
:
''
;
this
.
checked
=
model
.
count
()
===
value
?
'
on
'
:
''
;
}
}
...
@@ -41,7 +44,7 @@ module.exports = function listInit(view, model, stats) {
...
@@ -41,7 +44,7 @@ module.exports = function listInit(view, model, stats) {
};
};
// Enter edit mode
// Enter edit mode
list
.
startEdit
=
function
(
event
,
node
)
{
list
.
startEdit
=
function
startEdit
(
event
,
node
)
{
var
taskId
=
modelPlugin
.
getItemIndex
(
node
);
var
taskId
=
modelPlugin
.
getItemIndex
(
node
);
toggleEditing
(
taskId
,
true
);
toggleEditing
(
taskId
,
true
);
...
@@ -49,7 +52,7 @@ module.exports = function listInit(view, model, stats) {
...
@@ -49,7 +52,7 @@ module.exports = function listInit(view, model, stats) {
};
};
// Leave edit mode
// Leave edit mode
list
.
stopEdit
=
function
(
event
,
node
)
{
list
.
stopEdit
=
function
stopEdit
(
event
,
node
)
{
var
taskId
=
modelPlugin
.
getItemIndex
(
node
);
var
taskId
=
modelPlugin
.
getItemIndex
(
node
);
var
value
;
var
value
;
...
@@ -62,7 +65,8 @@ module.exports = function listInit(view, model, stats) {
...
@@ -62,7 +65,8 @@ module.exports = function listInit(view, model, stats) {
model
.
del
(
taskId
);
model
.
del
(
taskId
);
}
}
// When task #n is removed, #n+1 becomes #n, the dom node is updated to the new value, so editing mode should exit anyway
// When task #n is removed, #n+1 becomes #n, the dom node is updated to the new value,
// so editing mode should exit anyway
if
(
model
.
has
(
taskId
))
{
if
(
model
.
has
(
taskId
))
{
toggleEditing
(
taskId
,
false
);
toggleEditing
(
taskId
,
false
);
}
}
...
@@ -78,7 +82,7 @@ module.exports = function listInit(view, model, stats) {
...
@@ -78,7 +82,7 @@ module.exports = function listInit(view, model, stats) {
function
toggleEditing
(
taskId
,
bool
)
{
function
toggleEditing
(
taskId
,
bool
)
{
var
li
=
getElementByModelId
(
'
li
'
,
taskId
);
var
li
=
getElementByModelId
(
'
li
'
,
taskId
);
T
ools
.
toggleClass
.
call
(
li
,
bool
,
'
editing
'
);
t
ools
.
toggleClass
.
call
(
li
,
bool
,
'
editing
'
);
}
}
function
getElementByModelId
(
selector
,
taskId
)
{
function
getElementByModelId
(
selector
,
taskId
)
{
...
...
examples/olives/node_modules/todomvc-app-css/index.css
View file @
2909d17d
...
@@ -197,8 +197,8 @@ label[for='toggle-all'] {
...
@@ -197,8 +197,8 @@ label[for='toggle-all'] {
}
}
#todo-list
li
label
{
#todo-list
li
label
{
white-space
:
pre
-line
;
white-space
:
pre
;
word-break
:
break-
all
;
word-break
:
break-
word
;
padding
:
15px
60px
15px
15px
;
padding
:
15px
60px
15px
15px
;
margin-left
:
45px
;
margin-left
:
45px
;
display
:
block
;
display
:
block
;
...
...
examples/olives/node_modules/todomvc-common/base.js
View file @
2909d17d
...
@@ -114,7 +114,12 @@
...
@@ -114,7 +114,12 @@
})({});
})({});
if
(
location
.
hostname
===
'
todomvc.com
'
)
{
if
(
location
.
hostname
===
'
todomvc.com
'
)
{
window
.
_gaq
=
[[
'
_setAccount
'
,
'
UA-31081062-1
'
],[
'
_trackPageview
'
]];(
function
(
d
,
t
){
var
g
=
d
.
createElement
(
t
),
s
=
d
.
getElementsByTagName
(
t
)[
0
];
g
.
src
=
'
//www.google-analytics.com/ga.js
'
;
s
.
parentNode
.
insertBefore
(
g
,
s
)}(
document
,
'
script
'
));
(
function
(
i
,
s
,
o
,
g
,
r
,
a
,
m
){
i
[
'
GoogleAnalyticsObject
'
]
=
r
;
i
[
r
]
=
i
[
r
]
||
function
(){
(
i
[
r
].
q
=
i
[
r
].
q
||
[]).
push
(
arguments
)},
i
[
r
].
l
=
1
*
new
Date
();
a
=
s
.
createElement
(
o
),
m
=
s
.
getElementsByTagName
(
o
)[
0
];
a
.
async
=
1
;
a
.
src
=
g
;
m
.
parentNode
.
insertBefore
(
a
,
m
)
})(
window
,
document
,
'
script
'
,
'
https://www.google-analytics.com/analytics.js
'
,
'
ga
'
);
ga
(
'
create
'
,
'
UA-31081062-1
'
,
'
auto
'
);
ga
(
'
send
'
,
'
pageview
'
);
}
}
/* jshint ignore:end */
/* jshint ignore:end */
...
@@ -228,7 +233,7 @@
...
@@ -228,7 +233,7 @@
xhr
.
onload
=
function
(
e
)
{
xhr
.
onload
=
function
(
e
)
{
var
parsedResponse
=
JSON
.
parse
(
e
.
target
.
responseText
);
var
parsedResponse
=
JSON
.
parse
(
e
.
target
.
responseText
);
if
(
parsedResponse
instanceof
Array
)
{
if
(
parsedResponse
instanceof
Array
)
{
var
count
=
parsedResponse
.
length
var
count
=
parsedResponse
.
length
;
if
(
count
!==
0
)
{
if
(
count
!==
0
)
{
issueLink
.
innerHTML
=
'
This app has
'
+
count
+
'
open issues
'
;
issueLink
.
innerHTML
=
'
This app has
'
+
count
+
'
open issues
'
;
document
.
getElementById
(
'
issue-count
'
).
style
.
display
=
'
inline
'
;
document
.
getElementById
(
'
issue-count
'
).
style
.
display
=
'
inline
'
;
...
...
examples/olives/olives-todo.js
View file @
2909d17d
This diff is collapsed.
Click to expand it.
examples/olives/package.json
View file @
2909d17d
{
{
"private"
:
true
,
"private"
:
true
,
"dependencies"
:
{
"dependencies"
:
{
"emily"
:
"^3.0.
3
"
,
"emily"
:
"^3.0.
7
"
,
"olives"
:
"^3.0.
5
"
,
"olives"
:
"^3.0.
8
"
,
"todomvc-app-css"
:
"^1.0.1"
,
"todomvc-app-css"
:
"^1.0.1"
,
"todomvc-common"
:
"^1.0.1"
"todomvc-common"
:
"^1.0.1"
,
"url-highway"
:
"1.0.0"
},
},
"scripts"
:
{
"scripts"
:
{
"build"
:
"browserify ./js/app.js -o olives-todo.js"
,
"build"
:
"browserify ./js/app.js -o olives-todo.js"
,
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment