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->raw('<style>'.$this->stylesheet().'</style>');
|
||||
|
||||
$out->raw(sprintf(_('<p>Recent updates from %1s for %2s:</p>'),
|
||||
common_config('site', 'name'),
|
||||
$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>'),
|
||||
common_local_url('emailsettings'),
|
||||
@ -170,295 +219,4 @@ class UserEmailSummaryHandler extends QueueHandler
|
||||
|
||||
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