Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
E
ecommerce-ui
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
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
ecommerce-ui
Commits
5c7feef0
Commit
5c7feef0
authored
Feb 14, 2014
by
Sven Franck
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
start adding state related content on initialization
parent
a31d3ff6
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
162 additions
and
131 deletions
+162
-131
data/global.json
data/global.json
+44
-32
js/erp5_loader.js
js/erp5_loader.js
+117
-98
lang/en-EN/dict.json
lang/en-EN/dict.json
+1
-1
No files found.
data/global.json
View file @
5c7feef0
[
{
"type"
:
"hello"
,
"set_on"
:
"login_dict"
,
"modernizr"
:
[
"localStorage"
],
"property_dict"
:
{
"use_login"
:
true
},
"scheme"
:
[{
"property_dict"
:
{
"google"
:
"1028374738607-pg2qqcopjpoc09shlpul3mehu2dv76ln.apps.googleusercontent.com"
}
}],
"children"
:
[]
},
{
"type"
:
"i18n"
,
"set_on"
:
"lang_dict"
,
"initializer"
:
"init"
,
"handler"
:
"language"
,
"property_dict"
:
{
"use_browser_language"
:
false
},
"scheme"
:
[{
"property_dict"
:
{
"lng"
:
"en-EN"
,
"load"
:
"current"
,
"fallbackLng"
:
"en-EN"
,
"resGetPath"
:
"lang/__lng__/__ns__.json"
,
"ns"
:
"dict"
,
"getAsync"
:
false
}
}],
"children"
:
[]
},
{
"type"
:
"StateMachine"
,
"set_on"
:
"state_dict"
,
...
...
@@ -33,40 +67,18 @@
{
"name"
:
"found_connection"
,
"from"
:
"probing"
,
"to"
:
"online"
}
]
}
}]
},
{
"type"
:
"hello"
,
"set_on"
:
"login_dict"
,
"modernizr"
:
[
"localStorage"
],
"property_dict"
:
{
"use_login"
:
true
},
"scheme"
:
[{
"property_dict"
:
{
"google"
:
"1028374738607-pg2qqcopjpoc09shlpul3mehu2dv76ln.apps.googleusercontent.com"
}
}],
"children"
:
[]
},
"children"
:
[
{
"type"
:
"i18n"
,
"set_on"
:
"lang_dict"
,
"initializer"
:
"init"
,
"handler"
:
"language"
,
"property_dict"
:
{
"use_browser_language"
:
false
},
"scheme"
:
[{
"property_dict"
:
{
"lng"
:
"en-EN"
,
"load"
:
"current"
,
"fallbackLng"
:
"en-EN"
,
"resGetPath"
:
"lang/__lng__/__ns__.json"
,
"ns"
:
"dict"
"generate"
:
"widget"
,
"type"
:
"crumbs"
,
"children"
:
[
{
"href"
:
"#"
,
"text"
:
"Synchronization"
,
"text_i18n"
:
"global_dict.sync_status"
,
"icon"
:
"random"
,
"info"
:
"sync_status"
},
{
"href"
:
"#"
,
"text"
:
"Login"
,
"text_i18n"
:
"global_dict.login_status"
,
"icon"
:
"user"
,
"info"
:
"login_status"
},
{
"href"
:
"#"
,
"text"
:
"Connection"
,
"text_i18n"
:
"global_dict.connection_status"
,
"icon"
:
"signal"
,
"info"
:
"connection_status"
}
]
}
}],
"children"
:
[]
]
},
{
"type"
:
"status_dict"
,
...
...
js/erp5_loader.js
View file @
5c7feef0
...
...
@@ -3282,6 +3282,78 @@
return
document
.
createDocumentFragment
();
};
/* ********************************************************************** */
/* CRUMBS */
/* ********************************************************************** */
/**
* Make a breadcrumb url for easy navigation
* @method breadcrumb
* @param {object} spec Configuration object
* @return {object} HTML fragment
*/
factory
.
crumbs
=
function
(
spec
)
{
var
i
,
crumb
,
base
,
breadcrumb
,
makeLink
,
len
,
pass
,
icon
,
patch
,
space
;
len
=
(
spec
.
children
||
[]).
length
;
base
=
""
;
space
=
document
.
createTextNode
(
"
\
u00A0
"
);
patch
=
"
#
"
;
makeLink
=
function
(
config
)
{
icon
=
config
.
home
||
config
.
icon
;
return
factory
.
element
(
"
a
"
,
{
"
href
"
:
config
.
href
||
"
#
"
,
"
className
"
:
(
icon
?
"
ui-btn ui-btn-icon-notext ui-icon-
"
+
icon
+
"
ui-shadow ui-corner-all
"
:
"
ui-link
"
)
+
(
config
.
text_i18n
?
"
translate
"
:
""
)
},
{},
{
"
data-action
"
:
config
.
action
||
null
,
"
data-info
"
:
config
.
info
||
null
,
"
data-i18n
"
:
config
.
text_i18n
||
null
,
"
text
"
:
config
.
home
?
"
Home
"
:
(
config
.
text
||
"
\
u00A0
"
)
}
);
};
// base element
breadcrumb
=
factory
.
element
(
"
span
"
,
{
"
className
"
:
"
crumbs
"
},
{},
{
"
data-info
"
:
spec
.
data_url
?
"
url
"
:
null
,
"
data-reference
"
:
spec
.
data_url
||
null
}
);
// home
if
(
spec
.
home
)
{
breadcrumb
.
appendChild
(
makeLink
({
"
href
"
:
app
.
property_dict
.
home
,
"
home
"
:
"
home
"
})
);
}
// fragments
for
(
i
=
0
;
i
<
len
;
i
+=
1
)
{
crumb
=
spec
.
children
[
i
];
if
(
typeof
crumb
===
"
string
"
)
{
pass
=
{
"
href
"
:
base
+=
(
patch
+
crumb
),
"
text
"
:
crumb
};
patch
=
"
/
"
;
}
breadcrumb
.
appendChild
(
space
);
breadcrumb
.
appendChild
(
makeLink
(
pass
||
crumb
));
breadcrumb
.
appendChild
(
space
);
}
return
breadcrumb
;
};
/* ********************************************************************** */
/* JQM POPUP */
/* ********************************************************************** */
...
...
@@ -3387,6 +3459,8 @@
util
.
getPage
(
url_dict
.
data_url
).
appendChild
(
container
);
// and return the placeholder for JQM
return
placeholder
;
}
else
{
document
.
body
.
appendChild
(
container
);
}
// also add placeholder to fragment
...
...
@@ -3512,6 +3586,8 @@
if
(
url_dict
.
data_url
)
{
util
.
getPage
(
url_dict
.
data_url
).
appendChild
(
header
);
return
undefined
;
}
else
{
document
.
body
.
appendChild
(
header
);
}
return
header
;
...
...
@@ -3607,7 +3683,10 @@
if
(
url_dict
.
data_url
)
{
util
.
getPanel
(
url_dict
.
data_url
).
appendChild
(
panel
);
return
undefined
;
}
else
{
document
.
body
.
insertBefore
(
panel
,
document
.
body
.
children
[
0
]);
}
return
panel
;
}
};
...
...
@@ -4605,7 +4684,11 @@
}
);
wrapper
.
appendChild
(
app
.
breadcrumb
(
url_dict
));
wrapper
.
appendChild
(
factory
.
crumbs
({
"
children
"
:
url_dict
.
fragment_list
,
"
home
"
:
true
,
"
data-url
"
:
url_dict
.
data_url
}));
wrapper
.
appendChild
(
target
);
container
.
appendChild
(
wrapper
);
...
...
@@ -6786,73 +6869,6 @@
};
};
/**
* Make a breadcrumb url for easy navigation
* @method breadcrumb
* @param {object} url_dict Current URL object
* @return {object} HTML fragment
*/
app
.
breadcrumb
=
function
(
url_dict
)
{
var
i
,
crumb
,
indicator
,
translation
,
path_builder
=
""
,
translation_failed
=
true
,
breadcrumb
=
factory
.
element
(
"
span
"
,
{
"
className
"
:
"
crumbs
"
},
{
"
data-info
"
:
"
url
"
,
"
data-reference
"
:
url_dict
.
data_url
}
),
makeLink
=
function
(
path
,
title
,
home
)
{
// test translation dict if the page title is translateable
if
(
title
&&
i18n
)
{
translation
=
map
.
actions
.
translateLookup
(
"
page_dict.
"
+
title
.
split
(
"
?
"
)[
0
]
+
"
.title
"
);
translation_failed
=
util
.
testForString
(
title
,
translation
,
true
);
}
// return link element
return
factory
.
element
(
"
a
"
,
{
"
href
"
:
path
||
"
#
"
,
"
className
"
:
(
home
?
"
ui-btn ui-btn-icon-notext ui-icon-home
"
+
"
ui-shadow ui-corner-all
"
:
"
ui-link
"
)
+
(
translation_failed
?
""
:
"
translate
"
)
},
{
"
data-enhanced
"
:
"
true
"
},
{
"
text
"
:
home
?
"
Home
"
:
title
,
"
data-i18n
"
:
home
?
"
global_dict.home
"
:
(
translation_failed
?
null
:
"
page_dict.
"
+
title
.
split
(
"
?
"
)[
0
]
+
"
.title
"
)
}
);
};
// home
breadcrumb
.
appendChild
(
makeLink
(
app
.
property_dict
.
home
,
undefined
,
true
)
);
// fragments
for
(
i
=
0
;
i
<
url_dict
.
fragment_list
.
length
;
i
+=
1
)
{
crumb
=
url_dict
.
fragment_list
[
i
];
indicator
=
i
===
0
?
"
#
"
:
"
/
"
;
path_builder
+=
indicator
+
crumb
;
breadcrumb
.
appendChild
(
document
.
createTextNode
(
"
|
\
u00A0
"
));
breadcrumb
.
appendChild
(
makeLink
(
path_builder
,
crumb
));
breadcrumb
.
appendChild
(
document
.
createTextNode
(
"
\
u00A0
"
));
}
// translate
if
(
i18n
)
{
map
.
actions
.
translateNodeList
(
breadcrumb
);
}
return
breadcrumb
;
};
/**
* Set the page title
* @method setPageTitle
...
...
@@ -8594,36 +8610,39 @@
}
}
return
RSVP
.
all
(
promise_list
)
// TODO: remove all this, should be handled by setContent
.
then
(
function
(
response_list
)
{
var
target
,
l
,
container
,
i18n
;
// create a fragment for promises
target
=
document
.
createDocumentFragment
();
for
(
l
=
0
;
l
<
response_list
.
length
;
l
+=
1
)
{
container
=
response_list
[
l
];
// exclude undefined promises (i18n)
if
(
container
&&
container
.
nodeName
)
{
// translate
if
(
i18n
)
{
map
.
actions
.
translateNodeList
(
container
);
}
// insert panel as first child into DOM
if
(
util
.
testForString
(
"
ui-panel
"
,
container
.
className
))
{
document
.
body
.
insertBefore
(
container
,
document
.
body
.
children
[
0
]
);
}
else
{
target
.
appendChild
(
container
);
}
}
document
.
body
.
appendChild
(
target
);
}
});
// // TODO: remove all this, should be handled by setContent, but
// // then setContent needs to know where to put things. So if
// // we make a footer, set content should insert it into the page or
// // DOM. End.
// .then (function (response_list) {
// var target, l, container, i18n;
//
// // create a fragment for promises
// target = document.createDocumentFragment();
//
// for (l = 0; l < response_list.length; l += 1) {
// container = response_list[l];
// // exclude undefined promises (i18n)
// if (container && container.nodeName) {
//
// // translate
// if (i18n) {
// map.actions.translateNodeList(container);
// }
//
// // insert panel as first child into DOM
// if (util.testForString("ui-panel", container.className)) {
// document.body.insertBefore(
// container,
// document.body.children[0]
// );
// } else {
// target.appendChild(container);
// }
// }
// document.body.appendChild(target);
// }
// });
}
};
...
...
lang/en-EN/dict.json
View file @
5c7feef0
...
...
@@ -2,7 +2,7 @@
"global_dict"
:
{
"connection_status"
:
"Connection"
,
"login_status"
:
"Login"
,
"sync_status"
:
"Synchroniz
ed
"
,
"sync_status"
:
"Synchroniz
ation
"
,
"about"
:
"About"
,
"about_subtitle"
:
""
,
"first"
:
"First"
,
...
...
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