diff -r 000000000000 -r 7f8907368bd5 web/lib/metadataplayer/Tweet.js --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/web/lib/metadataplayer/Tweet.js Fri Oct 18 17:54:44 2013 +0200 @@ -0,0 +1,168 @@ +IriSP.Widgets.Tweet = function(player, config) { + IriSP.Widgets.Widget.call(this, player, config); + this.lastAnnotation = false; +}; + +IriSP.Widgets.Tweet.prototype = new IriSP.Widgets.Widget(); + +IriSP.Widgets.Tweet.prototype.defaults = { + hide_timeout: 10000, + polemics : [ + { + "keywords" : [ "++" ], + "color" : "#30d765" + }, + { + "keywords" : [ "--" ], + "color" : "#f51123" + }, + { + "keywords" : [ "==" ], + "color" : "#f1e24a" + }, + { + "keywords" : [ "??" ], + "color" : "#05aae6" + } + ], + annotation_type: "tweet", + pin_at_start: false +}; + +IriSP.Widgets.Tweet.prototype.messages = { + "fr": { + retweet: "Retweeter", + reply: "Répondre", + keep_visible: "Empêcher la fermeture automatique", + dont_keep_visible: "Permettre la fermeture automatique", + close_widget: "Fermer l'affichage du tweet", + original_time: "Heure d'envoi\u00a0: ", + video_time: "Temps de la vidéo\u00a0: ", + show_original: "Voir l'original" + }, + "en": { + retweet: "Retweet", + reply: "Reply", + keep_visible: "Keep visible", + dont_keep_visible: "Don't keep visible", + close_widget: "Close tweet display", + original_time: "Tweet sent at: ", + video_time: "Video time: ", + show_original: "Show original" + } +}; + +IriSP.Widgets.Tweet.prototype.template = + '
' + + '' + + '' + + '

' + + ' ()

'; + + +IriSP.Widgets.Tweet.prototype.draw = function() { + this.renderTemplate(); + this.pinned = this.pin_at_start; + var _this = this; + this.$.find(".Ldt-Tweet-Pin").click(function() { + _this.pinned = !_this.pinned; + var _el = IriSP.jQuery(this); + if (_this.pinned) { + _el.addClass("active").attr("title",_this.l10n.dont_keep_visible); + _this.cancelTimeout(); + } else { + _el.removeClass("active").attr("title",_this.l10n.keep_visible); + _this.hideTimeout(); + } + }); + this.$.find(".Ldt-Tweet-Close").click(function() { + _this.hide(); + }); + this.$.hide(); + this.getWidgetAnnotations().forEach(function(_annotation) { + _annotation.on("click", function() { + _this.show(_annotation); + }); + }); +}; + +IriSP.Widgets.Tweet.prototype.show = function(_tweet) { + if (typeof _tweet !== "undefined" && typeof _tweet.source !== "undefined") { + var extend = [ + [ + /#(\w+)/gm, + function(matches) { + return ''; + }, + '' + ] + ]; + var _urls = IriSP._(_tweet.source.entities.urls).sortBy(function(_entity) { + return _entity.indices[0]; + }); + + var _currentPos = 0, + _txt = ''; + IriSP._(_urls).each(function(_url) { + if (_url.indices[0] >= _currentPos) { + _txt += _tweet.source.text.substring(_currentPos, _url.indices[0]); + _txt += (typeof _url.expanded_url !== "undefined" && _url.expanded_url !== null ? _url.expanded_url : _url.url); + _currentPos = _url.indices[1]; + } + }); + _txt += _tweet.source.text.substring(_currentPos); + + for (var _i = 0; _i < this.polemics.length; _i++) { + var rx = IriSP.Model.regexpFromTextOrArray(this.polemics[_i].keywords); + extend.push([ + rx, + '', + '' + ]); + } + var rx = (_tweet.found ? (_this.source.getAnnotations().regexp || false) : false), + profile_url = _tweet.source.user ? _tweet.source.user.profile_image_url : _tweet.source.profile_image_url, + screen_name = _tweet.source.user ? _tweet.source.user.screen_name :_tweet.source.from_user, + user_name = _tweet.source.user ? _tweet.source.user.name :_tweet.source.from_user_name; + this.$.find(".Ldt-Tweet-Avatar").attr("src", profile_url); + this.$.find(".Ldt-Tweet-ScreenName").html('@' + screen_name); + this.$.find(".Ldt-Tweet-ProfileLink").attr("href", "https://twitter.com/" + screen_name); + this.$.find(".Ldt-Tweet-FullName").html(user_name); + this.$.find(".Ldt-Tweet-Contents").html(IriSP.textFieldHtml(_txt, rx, extend)); + this.$.find(".Ldt-Tweet-Time").html(this.l10n.original_time + new Date(_tweet.source.created_at).toLocaleTimeString() + " / " + this.l10n.video_time + _tweet.begin.toString()); + this.$.find(".Ldt-Tweet-Retweet").attr("href", "https://twitter.com/intent/retweet?tweet_id=" + _tweet.source.id_str); + this.$.find(".Ldt-Tweet-Reply").attr("href", "https://twitter.com/intent/tweet?in_reply_to=" + _tweet.source.id_str); + this.$.find(".Ldt-Tweet-Original").attr("href", "https://twitter.com/" + screen_name + "/status/" + _tweet.source.id_str); + this.player.trigger("Annotation.minimize"); + this.$.slideDown(); + this.cancelTimeout(); + if (!this.pinned) { + this.hideTimeout(); + } + } else { + this.hide(); + } +}; + +IriSP.Widgets.Tweet.prototype.hide = function() { + this.player.trigger("Annotation.maximize"); + this.$.slideUp(); + this.cancelTimeout(); +}; + +IriSP.Widgets.Tweet.prototype.cancelTimeout = function() { + if (typeof this.hide_timer !== "undefined") { + window.clearTimeout(this.hide_timer); + this.hide_timer = undefined; + } +}; + +IriSP.Widgets.Tweet.prototype.hideTimeout = function() { + this.cancelTimeout(); + this.hide_timer = window.setTimeout(this.functionWrapper("hide"), this.hide_timeout); +};