Commit f7a641e7 authored by Sven Franck's avatar Sven Franck

app: add configurable action button (default search)

parent 2ad4cc98
...@@ -483,21 +483,25 @@ ...@@ -483,21 +483,25 @@
} }
// add action button // add action button
// TODO: should this be a submit via option?
if (spec.logic.action) { if (spec.logic.action) {
container.appendChild(factory.element({ container.appendChild(factory.element({
"type": "a", "type": "a",
"direct": { "direct": {
"title": "Search", "title": spec.logic.action.text || "Search",
"className": "action ui-input-action ui-btn ui-icon-search " + "className": "ui-input-action ui-btn ui-icon-" +
"ui-btn-icon-notext ui-corner-all translate ", (spec.logic.action.icon || "search") +
" ui-btn-icon-notext ui-corner-all translate ",
"href": "#" "href": "#"
}, },
"attributes": { "attributes": {
"data-i18n": "global_dict.search", "data-i18n": ("[title]" + spec.logic.action.text_i18n + ";" +
spec.logic.action.text_i18n) ||
"[title]global_dict.search;global_dict.search",
"tabindex": "-1", "tabindex": "-1",
"data-action": "search" "data-action": spec.logic.action.action || "search"
}, },
"logic": {"text": "Search"} "logic": {"text": spec.logic.action.text || "Search"}
})); }));
} }
...@@ -837,7 +841,12 @@ ...@@ -837,7 +841,12 @@
* "id": null, * "id": null,
* "title": "", * "title": "",
* "title_i18n":"", * "title_i18n":"",
* "fixed": true * "fixed": true,
* "image": {
* "src": null,
* "alt": null,
* "alt_i18n": null
* }
* }, * },
* "children": [], * "children": [],
* } * }
...@@ -846,25 +855,13 @@ ...@@ -846,25 +855,13 @@
* @return {object} object including fragment, child-selector, placeholder * @return {object} object including fragment, child-selector, placeholder
*/ */
factory.widget.header = function (spec) { factory.widget.header = function (spec) {
var container, id, title, target, fragment; var container, id, target, fragment;
container = document.createDocumentFragment(); container = document.createDocumentFragment();
id = spec.id || ((spec.data_url || "global") + "-header"); id = spec.id || ((spec.data_url || "global") + "-header");
// generate title (needed for JQM), default to empty string
title = factory.element({
"type": "h1",
"direct": {"className": "translate ui-title"},
"attributes": {
"data-i18n": spec.title_i18n || "",
"role": "heading",
"aria-level": "1"
},
"logic": {"text": spec.title || "\u00A0"}
});
// button group wrappers and title (inserted before last wrapper!) // button group wrappers and title (inserted before last wrapper!)
target = function (j, len) { target = function (j, len, conf) {
switch (true) { switch (true) {
case (j === 0): case (j === 0):
return factory.element({ return factory.element({
...@@ -873,7 +870,28 @@ ...@@ -873,7 +870,28 @@
}); });
case (j === len - 1): case (j === len - 1):
fragment = document.createDocumentFragment(); fragment = document.createDocumentFragment();
fragment.appendChild(title); if (conf.img) {
fragment.appendChild(factory.element({
"type": "img",
"direct": {"src": conf.src},
"attributes": {"alt": conf.title},
"logic": {
"data-i18n": config.title_i18n ?
("[alt]" + config.title_i18n) : null
}
}));
} else {
fragment.appendChild(factory.element({
"type": "h1",
"direct": {"className": "translate ui-title"},
"attributes": {
"data-i18n": conf.title_i18n || "",
"role": "heading",
"aria-level": "1"
},
"logic": {"text": conf.title || "\u00A0"}
}));
}
fragment.appendChild( fragment.appendChild(
factory.element({ factory.element({
"type": "div", "type": "div",
...@@ -909,7 +927,13 @@ ...@@ -909,7 +927,13 @@
"fragment": container, "fragment": container,
"child_selector": container.querySelector("#" + id), "child_selector": container.querySelector("#" + id),
"target": target, "target": target,
"target_selector": "last" "target_selector": "last",
"spec": {
"img": spec.image,
"src": spec.src,
"title": spec.title || spec.alt,
"title_i18n": spec.title_i18n || spec.alt_i18n
}
}; };
}; };
...@@ -1344,7 +1368,7 @@ ...@@ -1344,7 +1368,7 @@
"attributes": { "attributes": {
"data-role": "panel", "data-role": "panel",
"data-theme": spec.theme, "data-theme": spec.theme,
"data-position": "left", "data-position": spec.position || "left",
"data-display": "push", "data-display": "push",
"data-position-fixed": true "data-position-fixed": true
}, },
...@@ -6187,10 +6211,12 @@ ...@@ -6187,10 +6211,12 @@
target = undefined; target = undefined;
if (response) { if (response) {
// generate target for and append response // generate target for and append response
// NOTE: wrapper.spec is used for header only
if (wrapper.target) { if (wrapper.target) {
wrapper_selector = wrapper.target( wrapper_selector = wrapper.target(
wrapper.child_selector.children.length, wrapper.child_selector.children.length,
kids.length kids.length,
wrapper.spec
); );
// NOTE: wrapper_selector will return a fragment (set to // NOTE: wrapper_selector will return a fragment (set to
// first/last-ElementChild or a DOM node // first/last-ElementChild or a DOM node
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment