Search field for tasks

Fixes #2103
pull/7/head
Francis Lachapelle 2012-12-05 14:47:28 -05:00
parent 3606601c39
commit 8ca79d9a17
13 changed files with 145 additions and 116 deletions

View File

@ -211,11 +211,11 @@ static NSArray *tasksFields = nil;
user = [context activeUser];
userLogin = [user login];
title = [request formValueForKey: @"search"];
param = [request formValueForKey: @"filterpopup"];
if ([param length])
{
[self _setupDatesWithPopup: param andUserTZ: userTimeZone];
title = [request formValueForKey: @"search"];
}
else
{

View File

@ -5,17 +5,16 @@
xmlns:const="http://www.skyrix.com/od/constant"
xmlns:label="OGo:label"
>
<div class="menu" id="searchMenu">
<ul id="searchOptions" class="choiceMenu">
<li id="name_or_address"><var:string
label:value="Name or Email"/></li>
</ul>
</div>
<div id="filterPanel">
<div class="filterPanel" data-search="admin">
<div class="menu" id="searchMenu">
<ul class="choiceMenu">
<li data-option="name_or_address"><var:string
label:value="Name or Email"/></li>
</ul>
</div>
<span class="searchBox" style="float: right;">
<input id="searchCriteria" name="criteria" type="hidden" var:value="searchCriteria" />
<input id="searchValue" class="textField" autocomplete="off" name="search"
<input name="criteria" type="hidden" var:value="searchCriteria" />
<input name="search" class="textField" autocomplete="off"
menuid="searchMenu"
type="text" var:value="searchText" />
</span>

View File

@ -5,21 +5,20 @@
xmlns:const="http://www.skyrix.com/od/constant"
xmlns:label="OGo:label"
>
<div class="menu" id="searchMenu">
<ul id="searchOptions" class="choiceMenu">
<li id="name_or_address"><var:string
label:value="Name or Email"/></li>
<li id="category"><var:string label:value="Category"/></li>
<li id="organization"><var:string label:value="Organization"/></li>
</ul>
</div>
<div id="filterPanel">
<div class="filterPanel" data-search="contacts">
<div class="menu" id="searchMenu">
<ul id="searchOptions" class="choiceMenu">
<li data-option="name_or_address"><var:string
label:value="Name or Email"/></li>
<li data-option="category"><var:string label:value="Category"/></li>
<li data-option="organization"><var:string label:value="Organization"/></li>
</ul>
</div>
<span class="searchBox" style="float: right;">
<input id="searchCriteria" name="criteria" type="hidden" var:value="searchCriteria" />
<input id="searchValue" class="textField" autocomplete="off" name="search"
menuid="searchMenu"
type="text" var:value="searchText" />
<input name="criteria" type="hidden" var:value="searchCriteria" />
<input name="search" class="textField" autocomplete="off"
menuid="searchMenu"
type="text" var:value="searchText" />
</span>
</div>
</container>

View File

@ -5,25 +5,24 @@
xmlns:const="http://www.skyrix.com/od/constant"
xmlns:label="OGo:label"
>
<div class="menu" id="searchMenu">
<ul id="searchOptions" class="choiceMenu">
<li id="subject"><var:string label:value="Subject"/></li>
<li id="sender"><var:string label:value="Sender"/></li>
<li id="subject_or_sender"><var:string
label:value="Subject or Sender"/></li>
<li id="to_or_cc"><var:string label:value="To or Cc"/></li>
<li id="entire_message"><var:string
label:value="Entire Message"/></li>
</ul>
</div>
<div id="filterPanel">
<div class="filterPanel" data-search="mail">
<div class="menu" id="searchMenu">
<ul class="choiceMenu">
<li data-option="subject"><var:string label:value="Subject"/></li>
<li data-option="sender"><var:string label:value="Sender"/></li>
<li data-option="subject_or_sender"><var:string
label:value="Subject or Sender"/></li>
<li data-option="to_or_cc"><var:string label:value="To or Cc"/></li>
<li data-option="entire_message"><var:string
label:value="Entire Message"/></li>
</ul>
</div>
<var:if condition="hideFrame" const:negate="YES"
><span class="searchBox" style="float: right">
<input id="searchCriteria" name="criteria" type="hidden" var:value="searchCriteria" />
<input id="searchValue"
<input name="criteria" type="hidden" var:value="searchCriteria" />
<input name="search"
class="textField"
autocomplete="off" name="search" type="text" var:value="searchText"
autocomplete="off" type="text" var:value="searchText"
menuid="searchMenu" />
</span>
</var:if>

View File

@ -5,19 +5,18 @@
xmlns:const="http://www.skyrix.com/od/constant"
xmlns:label="OGo:label"
>
<div class="menu" id="searchMenu">
<ul id="searchOptions" class="choiceMenu">
<li><var:string label:value="Title or Description"/></li>
</ul>
</div>
<div id="filterPanel">
<div class="filterPanel" data-search="events">
<div class="menu" id="eventSearchMenu">
<ul class="choiceMenu">
<li data-option="title"><var:string label:value="Title or Description"/></li>
</ul>
</div>
<span class="searchBox" style="float: right">
<input id="searchCriteria" name="criteria" type="hidden" var:value="searchCriteria" />
<input id="searchValue"
class="textField"
autocomplete="off" name="search" type="text" var:value="searchText"
menuid="searchMenu" />
class="textField"
autocomplete="off" name="search" type="text" var:value="searchText"
menuid="eventSearchMenu" />
</span>
<var:string label:value="View:" />

View File

@ -170,9 +170,20 @@
</table>
</div>
<div id="tasksListView" class="tab">
<label>
<div class="filterPanel" data-search="tasks">
<div class="menu" id="taskSearchMenu">
<ul class="choiceMenu">
<li data-option="title"><var:string label:value="Title or Description"/></li>
</ul>
</div>
<span class="searchBox" style="float: right">
<input name="criteria" type="hidden" />
<input name="search" class="textField"
autocomplete="off" type="text"
menuid="taskSearchMenu" />
</span>
<input id="showHideCompletedTasks" type="checkbox" class="checkBox"/><var:string label:value="Show completed tasks"/>
</label>
</div>
<table id="tasksList" cellspacing="0">
<thead>
<tr>

View File

@ -6,8 +6,8 @@ var usersRightsWindowWidth = 450;
/* ACLs module */
function onSearchFormSubmit() {
var searchValue = $("searchValue");
function onSearchFormSubmit(panel) {
var searchValue = panel.down('[name="search"]');
var encodedValue = encodeURI(searchValue.value);
if (encodedValue.blank()) {
@ -61,20 +61,18 @@ function buildUsersTree(treeDiv, response) {
var isUserDialog = false;
var multiplier = ((isUserDialog) ? 1 : 2);
if (response.length > 0) {
for (var i = 0; i < response.length; i++)
addUserLineToTree(d, 1 + i * multiplier, response[i]);
treeDiv.innerHTML = "";
treeDiv.appendChild(d.domObject ());
treeDiv.clean = false;
for (var i = 0; i < response.length; i++) {
if (!isUserDialog) {
var toggle = $("tgd" + (1 + i * 2));
toggle.observe ("click", onUserNodeToggle);
}
var sd = $("sd" + (1 + i * multiplier));
sd.observe("click", onTreeItemClick);
for (var i = 0; i < response.length; i++)
addUserLineToTree(d, 1 + i * multiplier, response[i]);
treeDiv.innerHTML = "";
treeDiv.appendChild(d.domObject());
treeDiv.clean = false;
for (var i = 0; i < response.length; i++) {
if (!isUserDialog) {
var toggle = $("tgd" + (1 + i * 2));
toggle.observe ("click", onUserNodeToggle);
}
var sd = $("sd" + (1 + i * multiplier));
sd.observe("click", onTreeItemClick);
}
}
@ -220,7 +218,7 @@ function initAdministration() {
$("helpDialog").hide();
});
var searchValue = $("searchValue");
var searchValue = $$('[data-search="admin"] [name="search"]').first();
searchValue.focus();
}

View File

@ -18,9 +18,9 @@ function openContactsFolder(contactsFolder, reload, idx) {
var url = URLForFolderID(Contact.currentAddressBook, "Contacts") +
"/view?noframe=1";
var searchValue = search["value"];
var searchValue = search["contacts"]["value"];
if (searchValue && searchValue.length > 0)
url += ("&search=" + search["criteria"]
url += ("&search=" + search["contacts"]["criteria"]
+ "&value=" + escape(searchValue.utf8encode()));
var sortAttribute = sorting["attribute"];
if (sortAttribute && sortAttribute.length > 0)
@ -613,7 +613,7 @@ function onFolderSelectionChange(event) {
}
else {
search = {};
$("searchValue").value = "";
$$('[name="search"]').each(function(input) { input.value = "" });
initCriteria();
openContactsFolder(nodes[0].getAttribute("id"));
}

View File

@ -784,9 +784,9 @@ function openMailbox(mailbox, reload) {
lastClickedRow = -1; // from generic.js
}
var searchValue = search["value"];
var searchValue = search["mail"]["value"];
if (searchValue && searchValue.length > 0) {
urlParams.set("search", search["criteria"]);
urlParams.set("search", search["mail"]["criteria"]);
urlParams.set("value", escape(searchValue.utf8encode()));
}
var sortAttribute = sorting["attribute"];

View File

@ -277,11 +277,11 @@ TABLE#eventsList THEAD TD:last-child,
TABLE#tasksList THEAD TD:last-child
{ border-right: 0px; }
#filterPanel,
.filterPanel,
#schedulerTabs .tab label
{ display: block;
margin: 0;
padding: 5px;
padding: 0 0 5px 5px;
background-color: #eee;
background-color: #E6E7E6; }

View File

@ -2169,14 +2169,17 @@ function onHeaderClick(event) {
Event.stop(event);
}
function refreshCurrentFolder() {
refreshEvents();
function refreshCurrentFolder(id) {
if (id == 'tasks')
refreshTasks();
else
refreshEvents();
}
/* refreshes the "unifinder" list */
function refreshEvents() {
var titleSearch;
var value = search["value"];
var value = search["events"]["value"];
if (value && value.length)
titleSearch = "&search=" + escape(value.utf8encode());
@ -2193,7 +2196,15 @@ function refreshEvents() {
}
function refreshTasks(setUserDefault) {
var titleSearch;
var value = search["tasks"]["value"];
var setud;
if (value && value.length)
titleSearch = "&search=" + escape(value.utf8encode());
else
titleSearch = "";
/* TODO: the logic behind this should be reimplemented properly:
the "taskslist" method should save the status when the 'show-completed'
is set to true and revert to the current status when that parameter is
@ -2201,10 +2212,13 @@ function refreshTasks(setUserDefault) {
setud = "";
if (setUserDefault == 1)
setud = "&setud=1";
refreshAlarms();
return _loadTasksHref("taskslist?show-completed=" + showCompletedTasks
+ "&asc=" + sorting["task-ascending"]
+ "&sort=" + sorting["task-attribute"]);
+ "&sort=" + sorting["task-attribute"]
+ titleSearch);
}
function refreshEventsAndDisplay() {
@ -2700,11 +2714,12 @@ function getMenus() {
onCalendarNew, onCalendarRemove,
"-", onCalendarExport, onCalendarImport,
null, "-", null, "-", onMenuSharing);
menus["searchMenu"] = new Array(setSearchCriteria);
menus["eventSearchMenu"] = new Array(setSearchCriteria);
menus["tasksListMenu"] = new Array (editEvent, newTask, "-",
marksTasksAsCompleted, deleteEvent, "-",
onMenuRawTask);
menus["taskSearchMenu"] = new Array(setSearchCriteria);
var calendarsMenu = $("calendarsMenu");
if (calendarsMenu)
@ -3361,4 +3376,4 @@ function initScheduler() {
Event.observe(window, "resize", onWindowResize);
}
document.observe("dom:loaded", initScheduler);
document.observe("generic:loaded", initScheduler);

View File

@ -443,7 +443,7 @@ DIV.dragHandle:active
{ background-color: #99a; }
/* search fields */
DIV#filterPanel
DIV.filterPanel
{ height: 2em;
vertical-align: middle;
width: 100%;
@ -770,7 +770,7 @@ BUTTON.comboBoxButton:active
background-color: #d6d7d6;
}
INPUT#searchValue
INPUT[name="search"]
{ margin-right: 1em;
width: 20em;
padding-left: 24px;

View File

@ -1073,14 +1073,15 @@ function popupSearchMenu(event) {
}
function setSearchCriteria(event) {
var searchValue = $("searchValue");
var searchCriteria = $("searchCriteria");
var panel = $(this).up('.filterPanel');
var searchValue = panel.down('[name="search"]');
var searchCriteria = panel.down('[name="criteria"]');
if (searchValue.ghostPhrase == searchValue.value)
searchValue.value = "";
searchValue.ghostPhrase = this.innerHTML;
searchCriteria.value = this.getAttribute('id');
searchCriteria.value = this.readAttribute('data-option');
if (this.parentNode.chosenNode)
this.parentNode.chosenNode.removeClassName("_chosen");
@ -1092,20 +1093,18 @@ function setSearchCriteria(event) {
searchValue.lastSearch = "";
this.parentNode.chosenNode = this;
onSearchFormSubmit();
onSearchFormSubmit(panel);
}
}
function configureSearchField() {
var searchValue = $("searchValue");
if (searchValue) {
searchValue.observe("click", popupSearchMenu);
searchValue.observe("blur", onSearchBlur);
searchValue.observe("focus", onSearchFocus);
searchValue.observe("keydown", onSearchKeyDown);
searchValue.observe("mousedown", onSearchMouseDown);
}
$$('.searchBox [name="search"]').each(function(searchValue) {
searchValue.on("click", popupSearchMenu);
searchValue.on("blur", onSearchBlur);
searchValue.on("focus", onSearchFocus);
searchValue.on("keydown", onSearchKeyDown);
searchValue.on("mousedown", onSearchMouseDown);
});
}
function onSearchMouseDown(event) {
@ -1118,7 +1117,7 @@ function onSearchMouseDown(event) {
}
function onSearchFocus(event) {
ghostPhrase = this.ghostPhrase;
var ghostPhrase = this.ghostPhrase;
if (this.value == ghostPhrase) {
this.value = "";
this.setAttribute("modified", "");
@ -1130,15 +1129,16 @@ function onSearchFocus(event) {
function onSearchBlur(event) {
if (!this.value || this.value.blank()) {
var id = $(this).up('[data-search]').readAttribute('data-search');
this.setAttribute("modified", "");
this.setStyle({ color: "#909090" });
this.value = this.ghostPhrase;
if (this.timer)
clearTimeout(this.timer);
search["value"] = "";
search[id]["value"] = "";
if (this.lastSearch != "") {
this.lastSearch = "";
refreshCurrentFolder();
refreshCurrentFolder(id);
}
} else if (this.value == this.ghostPhrase) {
this.setAttribute("modified", "");
@ -1160,43 +1160,47 @@ function IsCharacterKey(keyCode) {
function onSearchKeyDown(event) {
if (event.keyCode == Event.KEY_RETURN) {
var panel = $(this).up('.filterPanel');
if (this.timer)
clearTimeout(this.timer);
onSearchFormSubmit();
onSearchFormSubmit(panel);
preventDefault(event);
}
else if (event.keyCode == Event.KEY_BACKSPACE
|| IsCharacterKey(event.keyCode)) {
var panel = $(this).up('.filterPanel');
if (this.timer)
clearTimeout(this.timer);
this.timer = setTimeout("onSearchFormSubmit()", 500);
this.timer = onSearchFormSubmit.delay(0.5, panel);
}
}
function onSearchFormSubmit(event) {
var searchValue = $("searchValue");
var searchCriteria = $("searchCriteria");
function onSearchFormSubmit(filterPanel) {
var id = filterPanel.readAttribute('data-search');
var searchValue = filterPanel.down('[name="search"]');
var searchCriteria = filterPanel.down('[name="criteria"]');
if (searchValue.value != searchValue.ghostPhrase
&& (searchValue.value != searchValue.lastSearch
&& (searchValue.value.strip().length > minimumSearchLength
|| searchValue.value.strip() == "." ))) {
search["criteria"] = searchCriteria.value;
search["value"] = searchValue.value;
search[id]["criteria"] = searchCriteria.value;
search[id]["value"] = searchValue.value;
searchValue.lastSearch = searchValue.value;
refreshCurrentFolder();
refreshCurrentFolder(id);
}
}
function initCriteria() {
var searchCriteria = $("searchCriteria");
var searchValue = $("searchValue");
var searchOptions = $("searchOptions");
if (searchValue && searchOptions) {
$$('[data-search]').each(function(element) {
var box = $(element);
var id = box.readAttribute('data-search');
var searchCriteria = box.down('[name="criteria"]');
var searchValue = box.down('[name="search"]');
var searchOptions = box.down('.choiceMenu');
var firstOption = searchOptions.down("li");
if (firstOption) {
searchCriteria.value = firstOption.getAttribute('id');
searchCriteria.value = firstOption.readAttribute('data-option');
searchValue.ghostPhrase = firstOption.innerHTML;
searchValue.lastSearch = "";
if (searchValue.value == '') {
@ -1209,9 +1213,11 @@ function initCriteria() {
searchOptions.chosenNode.removeClassName("_chosen");
firstOption.addClassName("_chosen");
searchOptions.chosenNode = firstOption;
// Initialize global array
search[id] = {};
}
searchValue.blur();
}
});
}
/* toolbar buttons */
@ -1657,6 +1663,9 @@ function onLoadHandler(event) {
progressImage.parentNode.removeChild(progressImage);
$(document.body).observe("contextmenu", onBodyClickContextMenu);
// Some module are initialized only once this method is completed
document.fire('generic:loaded');
onFinalLoadHandler();
}
@ -1862,7 +1871,7 @@ function parent$(element) {
}
/* stubs */
function refreshCurrentFolder() {
function refreshCurrentFolder(id) {
}
function configureDragHandles() {