Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F108051492
ConpherenceTransactionRenderer.php
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Subscribers
None
File Metadata
Details
File Info
Storage
Attached
Created
Sun, Apr 13, 16:07
Size
5 KB
Mime Type
text/x-php
Expires
Tue, Apr 15, 16:07 (1 d, 23 h)
Engine
blob
Format
Raw Data
Handle
25516945
Attached To
rPH Phabricator
ConpherenceTransactionRenderer.php
View Options
<?php
final
class
ConpherenceTransactionRenderer
{
public
static
function
renderTransactions
(
PhabricatorUser
$user
,
ConpherenceThread
$conpherence
,
$full_display
=
true
,
$marker_type
=
'older'
)
{
$transactions
=
$conpherence
->
getTransactions
();
$oldest_transaction_id
=
0
;
$newest_transaction_id
=
0
;
$too_many
=
ConpherenceThreadQuery
::
TRANSACTION_LIMIT
+
1
;
if
(
count
(
$transactions
)
==
$too_many
)
{
if
(
$marker_type
==
'olderandnewer'
)
{
$last_transaction
=
end
(
$transactions
);
$first_transaction
=
reset
(
$transactions
);
unset
(
$transactions
[
$last_transaction
->
getID
()]);
unset
(
$transactions
[
$first_transaction
->
getID
()]);
$oldest_transaction_id
=
$last_transaction
->
getID
();
$newest_transaction_id
=
$first_transaction
->
getID
();
}
else
if
(
$marker_type
==
'newer'
)
{
$first_transaction
=
reset
(
$transactions
);
unset
(
$transactions
[
$first_transaction
->
getID
()]);
$newest_transaction_id
=
$first_transaction
->
getID
();
}
else
if
(
$marker_type
==
'older'
)
{
$last_transaction
=
end
(
$transactions
);
unset
(
$transactions
[
$last_transaction
->
getID
()]);
$oldest_transaction
=
end
(
$transactions
);
$oldest_transaction_id
=
$oldest_transaction
->
getID
();
}
// we need **at least** the newer marker in this mode even if
// we didn't get a full set of transactions
}
else
if
(
$marker_type
==
'olderandnewer'
)
{
$first_transaction
=
reset
(
$transactions
);
unset
(
$transactions
[
$first_transaction
->
getID
()]);
$newest_transaction_id
=
$first_transaction
->
getID
();
}
$transactions
=
array_reverse
(
$transactions
);
$handles
=
$conpherence
->
getHandles
();
$rendered_transactions
=
array
();
$engine
=
id
(
new
PhabricatorMarkupEngine
())
->
setViewer
(
$user
)
->
setContextObject
(
$conpherence
);
foreach
(
$transactions
as
$key
=>
$transaction
)
{
if
(
$transaction
->
shouldHide
())
{
unset
(
$transactions
[
$key
]);
continue
;
}
if
(
$transaction
->
getComment
())
{
$engine
->
addObject
(
$transaction
->
getComment
(),
PhabricatorApplicationTransactionComment
::
MARKUP_FIELD_COMMENT
);
}
}
$engine
->
process
();
// we're going to insert a dummy date marker transaction for breaks
// between days. some setup required!
$previous_transaction
=
null
;
$date_marker_transaction
=
id
(
new
ConpherenceTransaction
())
->
setTransactionType
(
ConpherenceTransaction
::
TYPE_DATE_MARKER
)
->
makeEphemeral
();
$date_marker_transaction_view
=
id
(
new
ConpherenceTransactionView
())
->
setUser
(
$user
)
->
setConpherenceTransaction
(
$date_marker_transaction
)
->
setConpherenceThread
(
$conpherence
)
->
setHandles
(
$handles
)
->
setMarkupEngine
(
$engine
);
$transaction_view_template
=
id
(
new
ConpherenceTransactionView
())
->
setUser
(
$user
)
->
setConpherenceThread
(
$conpherence
)
->
setHandles
(
$handles
)
->
setMarkupEngine
(
$engine
)
->
setFullDisplay
(
$full_display
);
foreach
(
$transactions
as
$transaction
)
{
if
(
$previous_transaction
)
{
$previous_day
=
phabricator_format_local_time
(
$previous_transaction
->
getDateCreated
(),
$user
,
'Ymd'
);
$current_day
=
phabricator_format_local_time
(
$transaction
->
getDateCreated
(),
$user
,
'Ymd'
);
// date marker transaction time!
if
(
$previous_day
!=
$current_day
)
{
$date_marker_transaction
->
setDateCreated
(
$transaction
->
getDateCreated
());
$date_marker_transaction
->
setID
(
$previous_transaction
->
getID
());
$rendered_transactions
[]
=
$date_marker_transaction_view
->
render
();
}
}
$transaction_view
=
id
(
clone
$transaction_view_template
)
->
setConpherenceTransaction
(
$transaction
);
$rendered_transactions
[]
=
$transaction_view
->
render
();
$previous_transaction
=
$transaction
;
}
$latest_transaction_id
=
$transaction
->
getID
();
return
array
(
'transactions'
=>
$rendered_transactions
,
'latest_transaction'
=>
$transaction
,
'latest_transaction_id'
=>
$latest_transaction_id
,
'oldest_transaction_id'
=>
$oldest_transaction_id
,
'newest_transaction_id'
=>
$newest_transaction_id
,
);
}
public
static
function
renderMessagePaneContent
(
array
$transactions
,
$oldest_transaction_id
,
$newest_transaction_id
)
{
$oldscrollbutton
=
''
;
if
(
$oldest_transaction_id
)
{
$oldscrollbutton
=
javelin_tag
(
'a'
,
array
(
'href'
=>
'#'
,
'mustcapture'
=>
true
,
'sigil'
=>
'show-older-messages'
,
'class'
=>
'conpherence-show-more-messages'
,
'meta'
=>
array
(
'oldest_transaction_id'
=>
$oldest_transaction_id
,
),
),
pht
(
'Show Older Messages'
));
$oldscrollbutton
=
javelin_tag
(
'div'
,
array
(
'sigil'
=>
'conpherence-transaction-view'
,
'meta'
=>
array
(
'id'
=>
$oldest_transaction_id
-
0.5
,
),
),
$oldscrollbutton
);
}
$newscrollbutton
=
''
;
if
(
$newest_transaction_id
)
{
$newscrollbutton
=
javelin_tag
(
'a'
,
array
(
'href'
=>
'#'
,
'mustcapture'
=>
true
,
'sigil'
=>
'show-newer-messages'
,
'class'
=>
'conpherence-show-more-messages'
,
'meta'
=>
array
(
'newest_transaction_id'
=>
$newest_transaction_id
,
),
),
pht
(
'Show Newer Messages'
));
$newscrollbutton
=
javelin_tag
(
'div'
,
array
(
'sigil'
=>
'conpherence-transaction-view'
,
'meta'
=>
array
(
'id'
=>
$newest_transaction_id
+
0.5
,
),
),
$newscrollbutton
);
}
return
hsprintf
(
'%s%s%s'
,
$oldscrollbutton
,
$transactions
,
$newscrollbutton
);
}
}
Event Timeline
Log In to Comment