2009-09-23 22:07:20 +01:00
// add a notice encoded as JSON into the current timeline
//
// TODO: i18n
RealtimeUpdate = {
_userid : 0 ,
_replyurl : '' ,
_favorurl : '' ,
_deleteurl : '' ,
init : function ( userid , replyurl , favorurl , deleteurl )
{
RealtimeUpdate . _userid = userid ;
RealtimeUpdate . _replyurl = replyurl ;
RealtimeUpdate . _favorurl = favorurl ;
RealtimeUpdate . _deleteurl = deleteurl ;
} ,
receive : function ( data )
{
id = data . id ;
// Don't add it if it already exists
//
if ( $ ( "#notice-" + id ) . length > 0 ) {
return ;
}
var noticeItem = RealtimeUpdate . makeNoticeItem ( data ) ;
$ ( "#notices_primary .notices" ) . prepend ( noticeItem , true ) ;
$ ( "#notices_primary .notice:first" ) . css ( { display : "none" } ) ;
$ ( "#notices_primary .notice:first" ) . fadeIn ( 1000 ) ;
NoticeReply ( ) ;
} ,
makeNoticeItem : function ( data )
{
user = data [ 'user' ] ;
html = data [ 'html' ] . replace ( /&/g , '&' ) . replace ( /</g , '<' ) . replace ( />/g , '>' ) . replace ( /"/g , '"' ) ;
source = data [ 'source' ] . replace ( /&/g , '&' ) . replace ( /</g , '<' ) . replace ( />/g , '>' ) . replace ( /"/g , '"' ) ;
ni = "<li class=\"hentry notice\" id=\"notice-" + data [ 'id' ] + "\">" +
"<div class=\"entry-title\">" +
"<span class=\"vcard author\">" +
"<a href=\"" + user [ 'profile_url' ] + "\" class=\"url\">" +
"<img src=\"" + user [ 'profile_image_url' ] + "\" class=\"avatar photo\" width=\"48\" height=\"48\" alt=\"" + user [ 'screen_name' ] + "\"/>" +
"<span class=\"nickname fn\">" + user [ 'screen_name' ] + "</span>" +
"</a>" +
"</span>" +
"<p class=\"entry-content\">" + html + "</p>" +
"</div>" +
"<div class=\"entry-content\">" +
"<a class=\"timestamp\" rel=\"bookmark\" href=\"" + data [ 'url' ] + "\" >" +
"<abbr class=\"published\" title=\"" + data [ 'created_at' ] + "\">a few seconds ago</abbr>" +
"</a> " +
"<span class=\"source\">" +
"from " +
2009-09-21 20:17:37 +01:00
"<span class=\"device\">" + source + "</span>" + // may have a link
2009-09-23 22:07:20 +01:00
"</span>" ;
if ( data [ 'in_reply_to_status_id' ] ) {
ni = ni + " <a class=\"response\" href=\"" + data [ 'in_reply_to_status_url' ] + "\">in context</a>" ;
}
2009-09-21 20:17:37 +01:00
2009-09-23 22:07:20 +01:00
ni = ni + "</div>" +
2009-09-21 20:17:37 +01:00
"<div class=\"notice-options\">" ;
2009-09-23 22:07:20 +01:00
if ( RealtimeUpdate . _userid != 0 ) {
var input = $ ( "form#form_notice fieldset input#token" ) ;
var session _key = input . val ( ) ;
ni = ni + RealtimeUpdate . makeFavoriteForm ( data [ 'id' ] , session _key ) ;
ni = ni + RealtimeUpdate . makeReplyLink ( data [ 'id' ] , data [ 'user' ] [ 'screen_name' ] ) ;
if ( RealtimeUpdate . _userid == data [ 'user' ] [ 'id' ] ) {
2009-07-14 20:26:39 +01:00
ni = ni + RealtimeUpdate . makeDeleteLink ( data [ 'id' ] ) ;
2009-09-23 22:07:20 +01:00
}
}
2009-09-21 20:17:37 +01:00
2009-09-23 22:07:20 +01:00
ni = ni + "</div>" +
"</li>" ;
return ni ;
} ,
2009-09-21 20:17:37 +01:00
2009-09-23 22:07:20 +01:00
makeFavoriteForm : function ( id , session _key )
{
var ff ;
2009-09-21 20:17:37 +01:00
2009-09-23 22:07:20 +01:00
ff = "<form id=\"favor-" + id + "\" class=\"form_favor\" method=\"post\" action=\"" + RealtimeUpdate . _favorurl + "\">" +
2009-09-21 20:17:37 +01:00
"<fieldset>" +
2009-09-23 22:07:20 +01:00
"<legend>Favor this notice</legend>" +
"<input name=\"token-" + id + "\" type=\"hidden\" id=\"token-" + id + "\" value=\"" + session _key + "\"/>" +
"<input name=\"notice\" type=\"hidden\" id=\"notice-n" + id + "\" value=\"" + id + "\"/>" +
"<input type=\"submit\" id=\"favor-submit-" + id + "\" name=\"favor-submit-" + id + "\" class=\"submit\" value=\"Favor\" title=\"Favor this notice\"/>" +
2009-09-21 20:17:37 +01:00
"</fieldset>" +
2009-09-23 22:07:20 +01:00
"</form>" ;
return ff ;
} ,
makeReplyLink : function ( id , nickname )
{
var rl ;
rl = "<a class=\"notice_reply\" href=\"" + RealtimeUpdate . _replyurl + "?replyto=" + nickname + "\" title=\"Reply to this notice\">Reply <span class=\"notice_id\">" + id + "</span></a>" ;
return rl ;
2009-09-21 20:17:37 +01:00
} ,
2009-09-23 22:07:20 +01:00
makeDeleteLink : function ( id )
{
var dl , delurl ;
delurl = RealtimeUpdate . _deleteurl . replace ( "0000000000" , id ) ;
2009-09-21 20:17:37 +01:00
2009-09-23 22:07:20 +01:00
dl = "<a class=\"notice_delete\" href=\"" + delurl + "\" title=\"Delete this notice\">Delete</a>" ;
2009-09-21 20:17:37 +01:00
2009-09-23 22:07:20 +01:00
return dl ;
2009-09-23 20:24:12 +01:00
} ,
2009-09-23 22:58:35 +01:00
addPopup : function ( url , title , iconurl )
2009-09-23 20:24:12 +01:00
{
2009-09-23 22:58:35 +01:00
$ ( '#site_nav_local_views .current a' ) . append ( '<button id="realtime_timeline" title="Real-time pop window">↗</button>' ) ;
$ ( '#realtime_timeline' ) . css ( {
'margin' : '2px 0 0 11px' ,
'background' : 'transparent url(' + iconurl + ') no-repeat 45% 45%' ,
'text-indent' : '-9999px' ,
'width' : '16px' ,
'height' : '16px' ,
'padding' : '0' ,
'display' : 'block' ,
'float' : 'right' ,
'border' : 'none' ,
'cursor' : 'pointer'
} ) ;
$ ( '#realtime_timeline' ) . click ( function ( ) {
window . open ( url ,
title ,
'toolbar=no,resizable=yes,scrollbars=yes,status=yes' ) ;
return false ;
} ) ;
2009-09-23 22:07:20 +01:00
}
}
2009-09-21 20:17:37 +01:00