var s_img;
var s_title;
var s_url;
+ var href = this.attr('href');
for (site in goodies[type].sites) {
entry = goodies[type].sites[site];
s_alt = entry.alt || "";
s_img = entry.img;
s_title = entry.title || "";
- s_url = entry.url_prefix.length > 0 ? entry.url_prefix + escape(this.href) : this.href;
+ s_url = entry.url_prefix.length > 0 ? entry.url_prefix + escape(href) : href;
text += '<a href="' + s_url + '"><img src="' + s_img + '" title="' + s_title + '" alt="' + s_alt + '"></a><br />';
- }
+ }
text += '<a href="https://www.polytechnique.org/Xorg/Goodies">Plus de bonus</a> ...</div>';
return this.overlib({
'<div class="identity">' +
'<div class="photo"><img src="photo/${hrpid}" alt="${directory_name}" /></div>' +
'<div class="nom">' +
- '{{if is_female}}•{{/if}}<a href="profile/${hrpid}">${directory_name}</a>' +
+ '{{if is_female}}•{{/if}}<a>${directory_name}</a>' +
'</div>' +
'<div class="edu">${promo}</div>' +
'</div>' +
'</div>');
- function buildPopup(input, linkBindFunction)
+ function buildPopup(input, destination, linkBindFunction)
{
- var pos = findPos(input.get(0));
- var $popup = $('<div>').hide()
- .addClass('contact-list')
- .css({
- position: 'absolute',
- width: '300px',
- top: input.css('bottom'),
- left: pos.x - 300 + input.width(),
- clear: 'both',
- 'text-align': 'left'
- });
+ var $popup = destination;
var selected = null;
+ var hovered = 0;
function updateSelection()
{
function formatProfile(i, profile) {
var data = $.tmpl('quickMinifiche', profile)
+ .css('cursor', 'pointer')
.hover(function() {
selected = i;
updateSelection();
+ hovered++;
}, function() {
if (selected === i) {
selected = null;
updateSelection();
}
+ hovered--;
}).mouseup(function() {
- if (!($(this).find('a').is(':hover'))) {
- $(this).find('a').click();
+ var sel = $(this).find('a');
+ if (!sel.attr('hovered')) {
+ sel.click();
}
});
+ data.find('a').hover(function() { $(this).attr('hovered', true) },
+ function() { $(this).attr('hovered', false) });
return data;
}
- input.after($popup);
+ if (!$popup) {
+ $popup = $('<div>').hide()
+ .addClass('contact-list')
+ .css({
+ position: 'absolute',
+ width: '300px',
+ top: input.css('bottom'),
+ clear: 'both',
+ 'text-align': 'left'
+ });
+ input.after($popup);
+ }
return {
hide: function(ignoreIfHover) {
- if (ignoreIfHover && $popup.is(':hover')) {
+ if (ignoreIfHover && hovered !== 0) {
return true;
}
selected = null;
},
show: function() {
- $popup.show();
+ var pos = findPos(input.get(0));
+ $popup.css('left', pos.x - 300 + input.width()).show();
return true;
},
return true;
},
- updateContent: function(profiles) {
+ updateContent: function(profiles, extra) {
var profile;
+ var $this;
$popup.empty();
for (var i = 0, len = profiles.length; i < len; i++) {
- profile = formatProfile(i, profiles[i]);
- profile.find('a').each(linkBindFunction);
- profile.appendTo($popup);
+ (function(elt) {
+ var profile = formatProfile(i, elt);
+ profile.find('a').each(function() {
+ linkBindFunction.call(this, elt, $this, extra);
+ });
+ profile.appendTo($popup);
+ }(profiles[i]));
}
if (len === 1) {
selected = 0;
}
$.fn.extend({
- quickSearch: function(args) {
- var query = null;
- var previous = null;
- var $this = this;
+ quickSearch: function(options) {
+ return this.each(function() {
+ var $this = $(this);
+ var $input = this;
var $popup;
- var token = (args && args.token) || $.xsrf_token;
- var url = 'search';
- var pending = false;
+ var previous = null;
+ var pending = false;
var disabled = false;
var updatePopup;
- if (token) {
- url += '?token=' + token;
- }
- $popup = buildPopup(this, function() {
- $(this).popWin(840, 600)
- .click(function() {
- $popup.hide();
- });
- });
+ options = options || { };
+ options = $.extend({
+ destination: null,
+ minChars: 3,
+ shortChars: 5,
+ shortTimeout: 300,
+ longTimeout: 100,
+ queryParams: {
+ offset: 0,
+ count: 10,
+ allow_special: true,
+ },
+ loadingClassLeft: 'ac_loading',
+ loadingClassRight: 'ac_loading_left',
+ selectAction: function(profile, popup, extra) {
+ var type = extra.link_type || 'profile';
+ switch (type) {
+ case 'profile':
+ $(this).attr('href', 'profile/' + profile.hrpid)
+ .popWin(840, 600)
+ .click(function() { $popup.hide(); return false; });
+ break;
+ case 'admin':
+ $(this).attr('href', 'admin/user/' + profile.hrpid)
+ .click(function() { window.open($(this).attr('href')); return false });
+ break;
+ }
+ }
+ }, options);
+ options.loadingClass = $this.css('text-align') === 'right' ? options.loadingClassRight
+ : options.loadingClassLeft;
+ $this.attr('autocomplete', 'off');
+ $popup = buildPopup($this, options.destination, options.selectAction);
function markPending() {
pending = true;
}
- function doUpdatePopup()
+ function performUpdate(quick)
{
- var quick = $(this).val();
- if (query !== null) {
- query.abort();
- }
- if (disabled || quick.length < 3) {
- previous = quick;
- $popup.hide();
+ if (updatePopup === markPending) {
return true;
}
- if (previous === quick) {
- $popup.show();
- return true;
- }
- query = $.xapi(url, $.extend({ 'quick': quick }, args), function(data) {
- query = null;
- if (data.profile_count > 10 || data.profile_count < 0) {
- $popup.hide();
- return;
+ updatePopup = markPending;
+ $this.addClass(options.loadingClass);
+ $.xapi('search', $.extend({ 'quick': quick }, options.queryParams), function(data) {
+ if (data.profile_count > options.queryParams.count || data.profile_count < 0) {
+ return $popup.hide();
}
- $popup.updateContent(data.profiles);
+ $popup.updateContent(data.profiles, data);
previous = quick;
- }, function() { disabled = true; });
- updatePopup = markPending;
- setTimeout(function() {
+ }, function(data, text) {
+ if (text !== 'abort') {
+ disabled = true;
+ }
+ }).complete(function() {
+ $this.removeClass(options.loadingClass);
updatePopup = doUpdatePopup;
if (pending) {
- updatePopup.call($this.get(0));
+ updatePopup();
}
- pending = false;
- }, 500);
+ });
return true;
}
+ function doUpdatePopup(dontDelay)
+ {
+ var quick = $this.val();
+ if ($.isFunction(quick.trim)) {
+ quick = quick.trim();
+ }
+ pending = false;
+ if (disabled || quick.length < options.minChars) {
+ previous = quick;
+ return $popup.hide();
+ } else if (!dontDelay) {
+ var timeout = quick.length < options.shortChars ? options.shortTimeout : options.longTimeout;
+ setTimeout(function() {
+ updatePopup(true);
+ }, timeout);
+ return true;
+ } else if (previous === quick) {
+ return $popup.show();
+ }
+ return performUpdate(quick);
+ }
+
updatePopup = doUpdatePopup;
- return this.keyup(function(e) {
+ return $this.keyup(function(e) {
if (e.keyCode !== 27 /* escape */ && e.keyCode !== 13 /* enter */
&& e.keyCode !== 9 /* tab */ && e.keyCode !== 38 /* up */
&& e.keyCode !== 40 /* down */) {
- return updatePopup.call(this);
+ return updatePopup();
}
return true;
})
.blur(function() {
return $popup.hide(true);
})
- .focus(updatePopup);
+ .focus(updatePopup);});
}
});
}(jQuery));
if (typeof text === 'string') {
args.push(text);
if (width) {
- args.push(width);
+ args.push(WIDTH, width);
}
if (height) {
- args.push(height);
+ args.push(HEIGHT, height);
}
} else {
for (key in text) {