mirror of
https://github.com/wbbaddons/Tims-Chat.git
synced 2025-01-21 01:50:40 +00:00
Fix rendering of attachment message types
This commit is contained in:
parent
8856cfcd8e
commit
885cfe6f31
@ -337,19 +337,34 @@ class MessageAction extends \wcf\data\AbstractDatabaseObjectAction {
|
||||
foreach ($attachments as $attachment) {
|
||||
$attachmentIDs[] = $attachment->attachmentID;
|
||||
}
|
||||
|
||||
$processor = new \wcf\system\html\input\HtmlInputProcessor();
|
||||
$processor->process(implode(' ', array_map(function ($attachmentID) {
|
||||
return '[attach='.$attachmentID.',none,true][/attach]';
|
||||
}, $attachmentIDs)), 'be.bastelstu.chat.message', 0);
|
||||
|
||||
WCF::getDB()->beginTransaction();
|
||||
/** @var Message $message */
|
||||
$message = (new MessageAction([ ], 'create', [ 'data' => [ 'roomID' => $room->roomID
|
||||
, 'userID' => WCF::getUser()->userID
|
||||
, 'username' => WCF::getUser()->username
|
||||
, 'time' => TIME_NOW
|
||||
, 'objectTypeID' => $objectTypeID
|
||||
, 'payload' => serialize([ 'attachmentIDs' => $attachmentIDs ])
|
||||
, 'payload' => serialize([ 'attachmentIDs' => $attachmentIDs
|
||||
, 'message' => $processor->getHtml()
|
||||
])
|
||||
]
|
||||
]
|
||||
)
|
||||
)->executeAction()['returnValues'];
|
||||
|
||||
$attachmentHandler->updateObjectID($message->messageID);
|
||||
$processor->setObjectID($message->messageID);
|
||||
if (\wcf\system\message\embedded\object\MessageEmbeddedObjectManager::getInstance()->registerObjects($processor)) {
|
||||
(new MessageEditor($message))->update([
|
||||
'hasEmbeddedObjects' => 1
|
||||
]);
|
||||
}
|
||||
WCF::getDB()->commitTransaction();
|
||||
}
|
||||
}
|
||||
|
@ -53,6 +53,8 @@ class AttachmentMessageType implements IMessageType, IDeletableMessageType {
|
||||
if ($user === null) $user = new \wcf\data\user\UserProfile(\wcf\system\WCF::getUser());
|
||||
|
||||
$payload = $message->payload;
|
||||
$payload['formattedMessage'] = null;
|
||||
$payload['plaintextMessage'] = null;
|
||||
|
||||
$parameters = [ 'message' => $message
|
||||
, 'user' => $user
|
||||
@ -60,7 +62,16 @@ class AttachmentMessageType implements IMessageType, IDeletableMessageType {
|
||||
];
|
||||
\wcf\system\event\EventHandler::getInstance()->fireAction($this, 'getPayload', $parameters);
|
||||
|
||||
// TODO
|
||||
if ($parameters['payload']['formattedMessage'] === null) {
|
||||
$this->processor->setOutputType('text/html');
|
||||
$this->processor->process($parameters['payload']['message'], 'be.bastelstu.chat.message', $message->messageID);
|
||||
$parameters['payload']['formattedMessage'] = $this->processor->getHtml();
|
||||
}
|
||||
if ($parameters['payload']['plaintextMessage'] === null) {
|
||||
$this->processor->setOutputType('text/plain');
|
||||
$this->processor->process($parameters['payload']['message'], 'be.bastelstu.chat.message', $message->messageID);
|
||||
$parameters['payload']['plaintextMessage'] = $this->processor->getHtml();
|
||||
}
|
||||
|
||||
return $parameters['payload'];
|
||||
}
|
||||
|
@ -433,6 +433,37 @@
|
||||
</div>
|
||||
</script>
|
||||
|
||||
<script type="x-text/template" data-application="be.bastelstu.chat" data-template-name="be-bastelstu-chat-messageType-attachment" data-template-includes="DeleteButton">
|
||||
<div class="chatMessageContainer">
|
||||
<div class="chatMessageSide">
|
||||
<div class="chatUserAvatar jsUserActionDropdown" data-user-id="{$author.userID}">
|
||||
<a href="{$author.link}">{@$author.image32}</a>
|
||||
</div>
|
||||
<time><a href="{$message.link}">{$message.formattedTime}</a></time>
|
||||
</div>
|
||||
<div class="chatMessageContent">
|
||||
<div class="chatMessageHeader">
|
||||
<span class="username">
|
||||
<a href="{$author.link}" class="jsUserActionDropdown" data-user-id="{$author.userID}">
|
||||
{@$author.coloredUsername}
|
||||
</a>
|
||||
</span>
|
||||
<small class="separatorLeft">
|
||||
<time><a href="{$message.link}">{$message.formattedTime}</a></time>
|
||||
</small>
|
||||
</div>
|
||||
<div class="chatMessage htmlContent">{@$message.payload.formattedMessage}</div>
|
||||
</div>
|
||||
<ul class="buttonGroup buttonList smallButtons">
|
||||
{/literal}
|
||||
{if $__wcf->session->getPermission('mod.chat.canDelete')}
|
||||
{ldelim}include file=$t.DeleteButton}
|
||||
{/if}
|
||||
{literal}
|
||||
</ul>
|
||||
</div>
|
||||
</script>
|
||||
|
||||
<script type="x-text/template" data-application="be.bastelstu.chat" data-template-name="be-bastelstu-chat-messageType-color">
|
||||
<div class="chatMessageContainer inline">
|
||||
<div class="chatMessageSide">
|
||||
|
Loading…
x
Reference in New Issue
Block a user