mirror of
https://github.com/openvk/openvk
synced 2025-01-09 01:09:46 +03:00
Make messages capable of holding attachments
This commit is contained in:
parent
095b7960ca
commit
eba579046e
4 changed files with 49 additions and 7 deletions
|
@ -2,6 +2,7 @@
|
||||||
namespace openvk\Web\Models\Entities;
|
namespace openvk\Web\Models\Entities;
|
||||||
use openvk\Web\Models\Repositories\Clubs;
|
use openvk\Web\Models\Repositories\Clubs;
|
||||||
use openvk\Web\Models\Repositories\Users;
|
use openvk\Web\Models\Repositories\Users;
|
||||||
|
use openvk\Web\Models\Entities\Photo;
|
||||||
use openvk\Web\Models\RowModel;
|
use openvk\Web\Models\RowModel;
|
||||||
use openvk\Web\Util\DateTime;
|
use openvk\Web\Util\DateTime;
|
||||||
|
|
||||||
|
@ -86,6 +87,22 @@ class Message extends RowModel
|
||||||
{
|
{
|
||||||
$author = $this->getSender();
|
$author = $this->getSender();
|
||||||
|
|
||||||
|
$attachments = [];
|
||||||
|
foreach($this->getChildren() as $attachment) {
|
||||||
|
if($attachment instanceof Photo) {
|
||||||
|
$attachments[] = [
|
||||||
|
"type" => "photo",
|
||||||
|
"link" => "/photo" . $attachment->getPrettyId(),
|
||||||
|
"photo" => [
|
||||||
|
"url" => $attachment->getURL(),
|
||||||
|
"caption" => $attachment->getDescription(),
|
||||||
|
],
|
||||||
|
];
|
||||||
|
} else {
|
||||||
|
throw new \Exception("Unknown attachment type: " . get_class($attachment));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return [
|
return [
|
||||||
"uuid" => $this->getId(),
|
"uuid" => $this->getId(),
|
||||||
"sender" => [
|
"sender" => [
|
||||||
|
@ -98,9 +115,11 @@ class Message extends RowModel
|
||||||
"sent" => (string) $this->getSendTime()->format("%e %B %G" . tr("time_at_sp") . "%X"),
|
"sent" => (string) $this->getSendTime()->format("%e %B %G" . tr("time_at_sp") . "%X"),
|
||||||
"edited" => is_null($this->getEditTime()) ? null : (string) $this->getEditTime(),
|
"edited" => is_null($this->getEditTime()) ? null : (string) $this->getEditTime(),
|
||||||
],
|
],
|
||||||
"text" => $this->getText(),
|
"text" => $this->getText(),
|
||||||
|
"attachments" => $attachments,
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
use Traits\TRichText;
|
use Traits\TRichText;
|
||||||
|
use Traits\TAttachmentHost;
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,9 +17,10 @@ trait TAttachmentHost
|
||||||
|
|
||||||
function getChildren(): \Traversable
|
function getChildren(): \Traversable
|
||||||
{
|
{
|
||||||
$sel = $this->getRecord()
|
$sel = DatabaseConnection::i()->getContext()
|
||||||
->related("attachments.target_id")
|
->table("attachments")
|
||||||
->where("attachments.target_type", get_class($this));
|
->where("target_id", $this->getId())
|
||||||
|
->where("attachments.target_type", get_class($this));
|
||||||
foreach($sel as $rel) {
|
foreach($sel as $rel) {
|
||||||
$repoName = $rel->attachable_type . "s";
|
$repoName = $rel->attachable_type . "s";
|
||||||
$repoName = str_replace("Entities", "Repositories", $repoName);
|
$repoName = str_replace("Entities", "Repositories", $repoName);
|
||||||
|
|
|
@ -23,12 +23,21 @@
|
||||||
<img class="ava" data-bind="attr: { src: sender.avatar, alt: sender.name }" />
|
<img class="ava" data-bind="attr: { src: sender.avatar, alt: sender.name }" />
|
||||||
<div class="_content">
|
<div class="_content">
|
||||||
<a href="#" data-bind="attr: { href: sender.link }">
|
<a href="#" data-bind="attr: { href: sender.link }">
|
||||||
<strong data-bind="text: sender.name">Целестина Неонова {* lulz *}</strong>
|
<strong data-bind="text: sender.name"></strong>
|
||||||
</a>
|
</a>
|
||||||
<span class="text" data-bind="html: text">...</span>
|
<span class="text" data-bind="html: text"></span>
|
||||||
|
<div data-bind="foreach: attachments" class="attachments">
|
||||||
|
<div class="msg-attach-j">
|
||||||
|
<div data-bind="if: type === 'photo'" class="msg-attach-j-photo">
|
||||||
|
<a data-bind="attr: { href: link }">
|
||||||
|
<img data-bind="attr: { src: photo.url, alt: photo.caption }" />
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="time" align="right">
|
<div class="time" align="right">
|
||||||
<span data-bind="text: timing.sent">Monday, the 1st of January 1970 00:00:00</span>
|
<span data-bind="text: timing.sent"></span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -171,6 +180,7 @@
|
||||||
"edited": null
|
"edited": null
|
||||||
},
|
},
|
||||||
"text": content,
|
"text": content,
|
||||||
|
"attachments": [],
|
||||||
"_tuid": Math.ceil(performance.now())
|
"_tuid": Math.ceil(performance.now())
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -845,6 +845,18 @@ table.User {
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.messenger-app--messages---message ._content .attachments {
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.messenger-app--messages---message ._content .attachments > .msg-attach-j * {
|
||||||
|
max-width: 86%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.messenger-app--messages---message ._content .attachments:not(:empty) {
|
||||||
|
margin-top: 15px;
|
||||||
|
}
|
||||||
|
|
||||||
.messenger-app--messages---message .time {
|
.messenger-app--messages---message .time {
|
||||||
width: 100px;
|
width: 100px;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue