Commit 729bea2a authored by JC Brand's avatar JC Brand

Add button to clear the filter value. update #212

parent e31ded9f
...@@ -3283,7 +3283,15 @@ ...@@ -3283,7 +3283,15 @@
}, },
filter: function (q) { filter: function (q) {
var matches; /* Filter the group's contacts based on the query "q".
* The query is matched against the contact's full name.
* If all contacts are filtered out (i.e. hidden), then the
* group must be filtered out as well.
*/
var matches, rejects;
var predicate = function (item) {
return item.get('fullname').toLowerCase().indexOf(q) === -1;
};
if (q.length === 0) { if (q.length === 0) {
if (this.model.get('state') === OPENED) { if (this.model.get('state') === OPENED) {
this.model.contacts.each($.proxy(function (item) { this.model.contacts.each($.proxy(function (item) {
...@@ -3295,15 +3303,16 @@ ...@@ -3295,15 +3303,16 @@
this.showIfInvisible(); this.showIfInvisible();
} else { } else {
q = q.toLowerCase(); q = q.toLowerCase();
matches = this.model.contacts.filter(function (item) { matches = this.model.contacts.filter(predicate);
return item.get('fullname').toLowerCase().indexOf(q) === -1;
});
if (matches.length === this.model.contacts.length) { // hide the whole group if (matches.length === this.model.contacts.length) { // hide the whole group
this.$el.nextUntil('dt').addBack().hide(); this.$el.nextUntil('dt').addBack().hide();
} else { } else {
_.each(matches, $.proxy(function (item) { _.each(matches, $.proxy(function (item) {
this.get(item.get('id')).$el.hide(); this.get(item.get('id')).$el.hide();
}, this)); }, this));
_.each(this.model.contacts.reject(predicate), $.proxy(function (item) {
this.get(item.get('id')).$el.show();
}, this));
this.showIfInvisible(); this.showIfInvisible();
} }
} }
...@@ -3316,16 +3325,16 @@ ...@@ -3316,16 +3325,16 @@
}, },
toggle: function (ev) { toggle: function (ev) {
// TODO: Need to take filter query into consideration
if (ev && ev.preventDefault) { ev.preventDefault(); } if (ev && ev.preventDefault) { ev.preventDefault(); }
var $el = $(ev.target); var $el = $(ev.target);
this.$el.nextUntil('dt').slideToggle();
if ($el.hasClass("icon-opened")) { if ($el.hasClass("icon-opened")) {
this.$el.nextUntil('dt').slideUp();
this.model.save({state: CLOSED}); this.model.save({state: CLOSED});
$el.removeClass("icon-opened").addClass("icon-closed"); $el.removeClass("icon-opened").addClass("icon-closed");
} else { } else {
$el.removeClass("icon-closed").addClass("icon-opened"); $el.removeClass("icon-closed").addClass("icon-opened");
this.model.save({state: OPENED}); this.model.save({state: OPENED});
this.filter(converse.rosterview.$('.roster-filter').val());
} }
}, },
...@@ -3384,7 +3393,9 @@ ...@@ -3384,7 +3393,9 @@
tagName: 'div', tagName: 'div',
id: 'converse-roster', id: 'converse-roster',
events: { events: {
"keydown .roster-filter": "liveFilter" "keydown .roster-filter": "liveFilter",
"click .onX": "clearFilter",
"mousemove .x": "togglePointer"
}, },
initialize: function () { initialize: function () {
...@@ -3414,18 +3425,46 @@ ...@@ -3414,18 +3425,46 @@
return this; return this;
}, },
liveFilter: _.debounce(function (ev) { tog: function (v) {
return v?'addClass':'removeClass';
},
togglePointer: function (ev) {
if (ev && ev.preventDefault) { ev.preventDefault(); } if (ev && ev.preventDefault) { ev.preventDefault(); }
var q = ev.target.value; var el = ev.target;
$(el)[this.tog(el.offsetWidth-18 < ev.clientX-el.getBoundingClientRect().left)]('onX');
},
filter: function (q) {
_.each(this.getAll(), function (view) { _.each(this.getAll(), function (view) {
view.filter(q); view.filter(q);
}); });
},
liveFilter: _.debounce(function (ev) {
if (ev && ev.preventDefault) { ev.preventDefault(); }
var q = ev.target.value;
$(ev.target)[this.tog(q)]('x');
this.filter(q);
}, 500), }, 500),
clearFilter: function (ev) {
if (ev && ev.preventDefault) { ev.preventDefault(); }
$(ev.target).removeClass('x onX').val('');
this.filter('');
},
showHideFilter: function () { showHideFilter: function () {
var visible = this.$filter.is(':visible');
if (visible && this.$filter.val().length > 0) {
// Don't hide if user is currently filtering.
return;
}
var $filter = this.$('.roster-filter'); var $filter = this.$('.roster-filter');
if (this.$('.roster-contacts').hasScrollBar()) { if (this.$('.roster-contacts').hasScrollBar()) {
if (!visible) {
$filter.show(); $filter.show();
}
} else { } else {
$filter.hide(); $filter.hide();
} }
......
...@@ -888,10 +888,21 @@ dl.add-converse-contact { ...@@ -888,10 +888,21 @@ dl.add-converse-contact {
margin: 0.5em 0 0 0; margin: 0.5em 0 0 0;
height: 194px; height: 194px;
height: calc(100% - 25px); height: calc(100% - 25px);
overflow-x: hidden;
} }
#converse-roster .roster-filter { #converse-roster .roster-filter {
margin: 0 0.5em; margin: 0 0.5em 5px 0.5em;
width: 185px; width: 185px;
background: url( ) no-repeat right -20px center;
border: 1px solid #999;
}
/* (jQ addClass:) if input has value: */
#converse-roster .roster-filter.x {
background-position: right 3px center;
}
/* (jQ addClass:) if mouse is over the 'x' input area*/
#converse-roster .roster-filter.onX {
cursor: pointer;
} }
#converse-roster .roster-contacts { #converse-roster .roster-contacts {
margin: 0; margin: 0;
......
...@@ -986,11 +986,24 @@ dl.add-converse-contact { ...@@ -986,11 +986,24 @@ dl.add-converse-contact {
margin: 0.5em 0 0 0; margin: 0.5em 0 0 0;
height: 194px; height: 194px;
height: ~"calc(100% - 25px)"; height: ~"calc(100% - 25px)";
overflow-x: hidden;
} }
#converse-roster .roster-filter { #converse-roster .roster-filter {
margin: 0 0.5em; margin: 0 0.5em 5px 0.5em;
width: 185px; width: 185px;
background: url( ) no-repeat right -20px center;
border: 1px solid #999;
}
/* (jQ addClass:) if input has value: */
#converse-roster .roster-filter.x {
background-position: right 3px center;
}
/* (jQ addClass:) if mouse is over the 'x' input area*/
#converse-roster .roster-filter.onX{
cursor:pointer;
} }
#converse-roster .roster-contacts { #converse-roster .roster-contacts {
......
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