change to a table for HTML output
This commit is contained in:
parent
37407d8c77
commit
974e41aa4b
@ -124,17 +124,66 @@ class UserEmailSummaryHandler extends QueueHandler
|
|||||||
|
|
||||||
$out = new XMLStringer();
|
$out = new XMLStringer();
|
||||||
|
|
||||||
$out->raw('<style>'.$this->stylesheet().'</style>');
|
|
||||||
|
|
||||||
$out->raw(sprintf(_('<p>Recent updates from %1s for %2s:</p>'),
|
$out->raw(sprintf(_('<p>Recent updates from %1s for %2s:</p>'),
|
||||||
common_config('site', 'name'),
|
common_config('site', 'name'),
|
||||||
$profile->getBestName()));
|
$profile->getBestName()));
|
||||||
|
|
||||||
$nl = new NoticeList($notice, $out);
|
|
||||||
|
|
||||||
// Outputs to the string
|
$out->elementStart('table', array('width' => '100%', 'style' => 'border: none'));
|
||||||
|
|
||||||
$nl->show();
|
while ($notice->fetch()) {
|
||||||
|
|
||||||
|
$profile = Profile::staticGet('id', $notice->profile_id);
|
||||||
|
|
||||||
|
if (empty($profile)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
$avatar = $profile->getAvatar(AVATAR_STREAM_SIZE);
|
||||||
|
|
||||||
|
$out->elementStart('tr');
|
||||||
|
$out->elementStart('td');
|
||||||
|
$out->element('img', array('src' => ($avatar) ?
|
||||||
|
$avatar->displayUrl() :
|
||||||
|
Avatar::defaultImage($avatar_size),
|
||||||
|
'class' => 'avatar photo',
|
||||||
|
'width' => $avatar_size,
|
||||||
|
'height' => $avatar_size,
|
||||||
|
'alt' => $profile->getBestName()));
|
||||||
|
$out->elementEnd('td');
|
||||||
|
$out->elementStart('td');
|
||||||
|
$out->element('a', array('href' => $profile->profileurl),
|
||||||
|
$profile->nickname);
|
||||||
|
$out->text(' ');
|
||||||
|
$out->raw($notice->rendered);
|
||||||
|
$out->element('br'); // yeah, you know it. I just wrote a <br> in the middle of my table layout.
|
||||||
|
$noticeurl = $notice->bestUrl();
|
||||||
|
// above should always return an URL
|
||||||
|
assert(!empty($noticeurl));
|
||||||
|
$out->elementStart('a', array('rel' => 'bookmark',
|
||||||
|
'class' => 'timestamp',
|
||||||
|
'href' => $noticeurl));
|
||||||
|
$dt = common_date_iso8601($notice->created);
|
||||||
|
$out->element('abbr', array('class' => 'published',
|
||||||
|
'title' => $dt),
|
||||||
|
common_date_string($notice->created));
|
||||||
|
$out->elementEnd('a');
|
||||||
|
if ($notice->hasConversation()) {
|
||||||
|
$conv = Conversation::staticGet('id', $notice->conversation);
|
||||||
|
$convurl = $conv->uri;
|
||||||
|
if (!empty($convurl)) {
|
||||||
|
$out->text(' ');
|
||||||
|
$out->element('a',
|
||||||
|
array('href' => $convurl.'#notice-'.$notice->id,
|
||||||
|
'class' => 'response'),
|
||||||
|
_('in context'));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$out->elementEnd('td');
|
||||||
|
$out->elementEnd('tr');
|
||||||
|
}
|
||||||
|
|
||||||
|
$out->elementEnd('table');
|
||||||
|
|
||||||
$out->raw(sprintf(_('<p><a href="%1s">change your email settings for %2s</a></p>'),
|
$out->raw(sprintf(_('<p><a href="%1s">change your email settings for %2s</a></p>'),
|
||||||
common_local_url('emailsettings'),
|
common_local_url('emailsettings'),
|
||||||
@ -170,295 +219,4 @@ class UserEmailSummaryHandler extends QueueHandler
|
|||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
function stylesheet()
|
|
||||||
{
|
|
||||||
$ss = <<<END_OF_STYLESHEET
|
|
||||||
|
|
||||||
#notices_primary {
|
|
||||||
padding-top: 8px;
|
|
||||||
clear: both;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#notices_primary h2 {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notice {
|
|
||||||
list-style-type: none;
|
|
||||||
margin-bottom: 25px;
|
|
||||||
clear: left;
|
|
||||||
min-height: 54px;
|
|
||||||
padding-bottom: 2px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notice, .profile, .application {
|
|
||||||
position:relative;
|
|
||||||
clear:both;
|
|
||||||
float:left;
|
|
||||||
width:100%;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notice .author {
|
|
||||||
margin-right: 8px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.fn {
|
|
||||||
overflow: hidden;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notice .author .fn {
|
|
||||||
font-weight: bold;
|
|
||||||
}
|
|
||||||
|
|
||||||
#core .vcard .photo {
|
|
||||||
display: inline;
|
|
||||||
margin-right: 11px;
|
|
||||||
float: left;
|
|
||||||
}
|
|
||||||
|
|
||||||
#content .notice .author .photo {
|
|
||||||
position: absolute;
|
|
||||||
top: 4px;
|
|
||||||
left: 4px;
|
|
||||||
float: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
#content .notice .entry-title {
|
|
||||||
margin: 2px 7px 0px 59px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.vcard .url {
|
|
||||||
text-decoration:none;
|
|
||||||
}
|
|
||||||
.vcard .url:hover {
|
|
||||||
text-decoration:underline;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notice .entry-title {
|
|
||||||
overflow:hidden;
|
|
||||||
word-wrap:break-word;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notice .entry-title.ov {
|
|
||||||
overflow:visible;
|
|
||||||
}
|
|
||||||
|
|
||||||
#showstream h1 {
|
|
||||||
display:none;
|
|
||||||
}
|
|
||||||
|
|
||||||
#showstream .notice .entry-title, #showstream .notice div.entry-content {
|
|
||||||
margin-left: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
#showstream #content .notice .author {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
#showstream .notice {
|
|
||||||
min-height: 1em;
|
|
||||||
}
|
|
||||||
|
|
||||||
#shownotice .vcard .photo {
|
|
||||||
margin-bottom: 4px;
|
|
||||||
}
|
|
||||||
|
|
||||||
#shownotice .notice .entry-title {
|
|
||||||
margin-left:110px;
|
|
||||||
font-size:2.2em;
|
|
||||||
min-height:123px;
|
|
||||||
font-size: 1.6em;
|
|
||||||
line-height: 1.2em;
|
|
||||||
}
|
|
||||||
|
|
||||||
#shownotice .notice div.entry-content {
|
|
||||||
margin-left:0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notice p.entry-content {
|
|
||||||
display:inline;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notice div.entry-content {
|
|
||||||
clear:left;
|
|
||||||
float:left;
|
|
||||||
margin-left:59px;
|
|
||||||
margin-top: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.entry-content .repeat {
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
|
|
||||||
.entry-content .repeat .photo {
|
|
||||||
float:none;
|
|
||||||
margin-right:1px;
|
|
||||||
position:relative;
|
|
||||||
top:4px;
|
|
||||||
left:0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notice-options {
|
|
||||||
float: right;
|
|
||||||
margin-top: 12px;
|
|
||||||
margin-right: -6px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notice-options fieldset {
|
|
||||||
border: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notice-options legend {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notice-options form, .notice-options a, .notice-options .repeated {
|
|
||||||
float: left;
|
|
||||||
margin-right: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notice-options input, .notice-options a, .notice-options .repeated {
|
|
||||||
text-indent: -9999px;
|
|
||||||
outline:none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notice-options input.submit, .notice-options a, .notice-options .repeated {
|
|
||||||
display: block;
|
|
||||||
border: 0;
|
|
||||||
height: 16px;
|
|
||||||
width: 16px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notice-options input.submit, .notice-options a {
|
|
||||||
opacity: 0.6;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notice-options input.submit:hover, .notice-options a:hover {
|
|
||||||
opacity: 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notice .attachment {
|
|
||||||
position:relative;
|
|
||||||
padding-left:16px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notice .attachment.more {
|
|
||||||
text-indent:-9999px;
|
|
||||||
width:16px;
|
|
||||||
height:16px;
|
|
||||||
display:inline-block;
|
|
||||||
overflow:hidden;
|
|
||||||
vertical-align:middle;
|
|
||||||
margin-left:4px;
|
|
||||||
}
|
|
||||||
|
|
||||||
#attachments .attachment,
|
|
||||||
.notice .attachment.more {
|
|
||||||
padding-left:0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notice .attachment img {
|
|
||||||
position:absolute;
|
|
||||||
top:18px;
|
|
||||||
left:0;
|
|
||||||
z-index:99;
|
|
||||||
}
|
|
||||||
|
|
||||||
#shownotice .notice .attachment img {
|
|
||||||
position:static;
|
|
||||||
}
|
|
||||||
|
|
||||||
#attachments {
|
|
||||||
clear:both;
|
|
||||||
float:left;
|
|
||||||
width:100%;
|
|
||||||
margin-top:18px;
|
|
||||||
}
|
|
||||||
#attachments dt {
|
|
||||||
font-weight:bold;
|
|
||||||
font-size:1.3em;
|
|
||||||
margin-bottom:4px;
|
|
||||||
}
|
|
||||||
|
|
||||||
#attachments ol li {
|
|
||||||
margin-bottom:18px;
|
|
||||||
list-style-type:decimal;
|
|
||||||
float:left;
|
|
||||||
clear:both;
|
|
||||||
}
|
|
||||||
|
|
||||||
#jOverlayContent,
|
|
||||||
#jOverlayContent #content,
|
|
||||||
#jOverlayContent #content_inner {
|
|
||||||
width: auto !important;
|
|
||||||
margin-bottom:0;
|
|
||||||
}
|
|
||||||
#jOverlayContent #content {
|
|
||||||
padding:11px;
|
|
||||||
min-height:auto;
|
|
||||||
border: 1px solid #fff;
|
|
||||||
}
|
|
||||||
#jOverlayContent .entry-title {
|
|
||||||
display:block;
|
|
||||||
margin-bottom:11px;
|
|
||||||
}
|
|
||||||
#jOverlayContent button {
|
|
||||||
position:absolute;
|
|
||||||
top: 5px;
|
|
||||||
right: 20px;
|
|
||||||
}
|
|
||||||
#jOverlayContent h1 {
|
|
||||||
max-width:425px;
|
|
||||||
}
|
|
||||||
#jOverlayLoading {
|
|
||||||
top:5%;
|
|
||||||
left:40%;
|
|
||||||
}
|
|
||||||
#attachment_view img {
|
|
||||||
max-width:480px;
|
|
||||||
max-height:480px;
|
|
||||||
}
|
|
||||||
#attachment_view #oembed_info {
|
|
||||||
margin-top:11px;
|
|
||||||
}
|
|
||||||
#attachment_view #oembed_info dt,
|
|
||||||
#attachment_view #oembed_info dd {
|
|
||||||
float:left;
|
|
||||||
}
|
|
||||||
#attachment_view #oembed_info dt {
|
|
||||||
clear:left;
|
|
||||||
margin-right:11px;
|
|
||||||
font-weight:bold;
|
|
||||||
}
|
|
||||||
#attachment_view #oembed_info dt:after {
|
|
||||||
content: ":";
|
|
||||||
}
|
|
||||||
|
|
||||||
#content .notice .notice {
|
|
||||||
width: 98%;
|
|
||||||
margin-left: 2%;
|
|
||||||
margin-top: 16px;
|
|
||||||
margin-bottom: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notice .notice {
|
|
||||||
background-color:rgba(200, 200, 200, 0.050);
|
|
||||||
}
|
|
||||||
.notice .notice .notice {
|
|
||||||
background-color:rgba(200, 200, 200, 0.100);
|
|
||||||
}
|
|
||||||
.notice .notice .notice .notice {
|
|
||||||
background-color:rgba(200, 200, 200, 0.150);
|
|
||||||
}
|
|
||||||
.notice .notice .notice .notice .notice {
|
|
||||||
background-color:rgba(200, 200, 200, 0.300);
|
|
||||||
}
|
|
||||||
|
|
||||||
END_OF_STYLESHEET;
|
|
||||||
|
|
||||||
return $ss;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user