This commit is contained in:
mrilyew 2025-01-12 14:00:10 +03:00
parent d18c2bba6e
commit 49f8238670
9 changed files with 227 additions and 92 deletions

View file

@ -34,6 +34,30 @@ final class DocumentsPresenter extends OpenVKPresenter
$order = in_array($current_order, [0,1,2]) ? $current_order : 0;
$tab = in_array($current_tab, [0,1,2,3,4,5,6,7,8]) ? $current_tab : 0;
$api_request = $this->queryParam("picker") == "1";
if($api_request && $_SERVER["REQUEST_METHOD"] === "POST") {
$ctx_type = $this->postParam("context");
$docs = NULL;
switch($ctx_type) {
default:
case "list":
$docs = (new Documents)->getDocumentsByOwner($owner_id, (int)$order, (int)$tab);
break;
case "search":
$ctx_query = $this->postParam("ctx_query");
$docs = (new Documents)->find($ctx_query);
break;
}
$this->template->docs = $docs->page($page, OPENVK_DEFAULT_PER_PAGE);
$this->template->page = $page;
$this->template->count = $docs->size();
$this->template->pagesCount = ceil($this->template->count / OPENVK_DEFAULT_PER_PAGE);
$this->template->_template = "Documents/ApiGetContext.xml";
return;
}
$docs = (new Documents)->getDocumentsByOwner($owner_id, (int)$order, (int)$tab);
$this->template->tabs = (new Documents)->getTypes($owner_id);
$this->template->tags = (new Documents)->getTags($owner_id, (int)$tab);

View file

@ -0,0 +1,9 @@
<input type="hidden" name="count" value="{$count}">
<input type="hidden" name="pagesCount" value="{$pagesCount}">
<input type="hidden" name="page" value="{$page}">
{foreach $docs as $doc}
<div class='display_flex_row _content' data-attachmentdata="{$doc->getVirtualId()}_{$doc->getId()}_{$doc->getAccessKey()}" data-name='{$doc->getName()}'>
{include "components/doc.xml", doc => $doc, hideButtons => true}
</div>
{/foreach}

View file

@ -67,8 +67,8 @@
</div>
{elseif $attachment instanceof \openvk\Web\Models\Entities\Document}
<div style="width:100%;">
<div style="display:none" data-att_type='doc' data-att_id="{$attachment->getPrettyId()}">
<div class="docMainItem attachment_doc attachment_note" data-id="{$attachment->getPrettiestId()}">
<div style="display:none" data-att_type="doc" data-att_id="{$attachment->getPrettiestId()}">
<div class="docMainItem attachment_doc attachment_note">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 8 10"><polygon points="0 0 0 10 8 10 8 4 4 4 4 0 0 0"/><polygon points="5 0 5 3 8 3 5 0"/></svg>
<div class='attachment_note_content'>

View file

@ -86,14 +86,14 @@
<img src="/assets/packages/static/openvk/img/oxygen-icons/16x16/mimetypes/audio-ac3.png" />
{_audio}
</a>
<a n:if="$docs ?? true" id="__documentAttachment" {if !is_null($club ?? NULL) && $club->canBeModifiedBy($thisUser)}data-club="{$club->getRealId()}"{/if}>
<img src="/assets/packages/static/openvk/img/oxygen-icons/16x16/mimetypes/application-octet-stream.png" />
{_document}
</a>
<a n:if="$notes ?? false" id="__notesAttachment">
<img src="/assets/packages/static/openvk/img/oxygen-icons/16x16/mimetypes/application-x-srt.png" />
{_note}
</a>
<a n:if="$docs ?? false" id="__documentAttachment">
<img src="/assets/packages/static/openvk/img/oxygen-icons/16x16/mimetypes/application-octet-stream.png" />
{_document}
</a>
<a n:if="$graffiti ?? false" onclick="initGraffiti(event);">
<img src="/assets/packages/static/openvk/img/oxygen-icons/16x16/actions/draw-brush.png" />
{_graffiti}

View file

@ -2711,6 +2711,10 @@ a.poll-retract-vote {
justify-content: center;
}
.ovk-photo-view .photo_viewer_wrapper.photo_viewer_wrapper_scrollable {
height: unset;
}
.ovk-photo-view #ovk-photo-img {
max-width: 100%;
max-height: 80vh;
@ -4107,7 +4111,7 @@ hr {
border-bottom: unset !important;
}
.docListViewItem:hover {
.docListViewItem:hover, .attachButton:hover {
background: #f7f7f7;
}
@ -4219,7 +4223,18 @@ hr {
.attachments .docGalleryItem {
display: block;
min-width: 200px;
min-width: 130px;
height: 150px;
width: 50%;
margin-bottom: 4px;
}
.attachButton {
width: 12%;
height: 55px;
display: flex;
align-items: center;
justify-content: center;
cursor: pointer;
user-select: none;
}

View file

@ -304,112 +304,190 @@ u(document).on("click", ".docListViewItem a.viewerOpener, a.docGalleryItem", asy
CMessageBox.toggleLoader()
})
u(document).on('click', '#__documentAttachment', async (e) => {
// ctx > "wall" and maybe "messages" in future
// source > "user" || "club" > source_id
async function __docAttachment(form, ctx = "wall", source = "user", source_id = 0) {
const per_page = 10
const form = u(e.target).closest('form')
const msg = new CMessageBox({
title: tr('select_doc'),
body: `
<div class='attachment_selector'>
<div id='attachment_insert' style='height: 325px;'>
<div class="docsInsert"></div>
</div>
</div>
`,
buttons: [tr('close')],
callbacks: [Function.noop]
custom_template: u(`
<div class="ovk-photo-view-dimmer">
<div class="ovk-photo-view" style="z-index: 1025;">
<div class="photo_com_title">
<text id="photo_com_title_photos">
${tr("select_doc")}
</text>
${source != "user" ?
`
<a id="_doc_picker_go_to_my">
${tr("go_to_my_documents")}
</a>
`
: ""}
<div>
<a id="ovk-photo-close">${tr("close")}</a>
</div>
</div>
<div class='photo_viewer_wrapper photo_viewer_wrapper_scrollable doc_viewer_wrapper'>
<div class='attachment_selector' style="width: 100%;">
<div id='_attachment_insert'>
<div class="docsInsert"></div>
</div>
</div>
</div>
<div class="ovk-photo-details"></div>
</div>
</div>`),
})
msg.getNode().attr('style', 'width: 340px;')
msg.getNode().find(".ovk-photo-view").attr('style', 'width: 400px;')
msg.getNode().find('.ovk-diag-body').attr('style', 'height:335px;padding:0px;')
async function __recieveDocs(page) {
u('#gif_loader').remove()
u('#attachment_insert').append(`<div id='gif_loader'></div>`)
const insert_place = u('#attachment_insert .docsInsert')
let docs = null
try {
docs = await window.OVKAPI.call('docs.get', {'owner_id': window.openvk.current_id, 'count': per_page, 'offset': per_page * page})
} catch(e) {
u("#gif_loader").remove()
insert_place.html("Err")
return
docs_reciever = new class {
ctx = "my"
ctx_id = 0
stat = {
page: 0,
pagesCount: 0,
count: 0,
}
u("#gif_loader").remove()
const pages_count = Math.ceil(Number(docs.count) / per_page)
clean() {
this.stat = {
page: 0,
pagesCount: 0,
count: 0,
}
if(docs.count < 1) {
insert_place.append(tr('no_docs'))
u('#gif_loader').remove()
}
docs.items.forEach(doc => {
is_attached = (form.find(`.upload-item[data-type='doc'][data-id='${doc.owner_id}_${doc.id}']`)).length > 0
insert_place.append(`
<div class='display_flex_row _content' data-attachmentdata="${doc.owner_id}_${doc.id}_${doc.access_key}" data-name='${escapeHtml(doc.title)}'>
<div class="attachDoc" id='__attach_doc'>
<span>${is_attached ? tr("detach") : tr("attach")}</span>
async page(page = 1, perPage = 10) {
u('#_attachment_insert').append(`<div id='gif_loader'></div>`)
const fd = new FormData
fd.append("context", "list")
fd.append("hash", window.router.csrf)
const req = await fetch(`/docs${source == "club" ? source_id : ""}?picker=1&p=${page}`, {
method: "POST",
body: fd
})
const res = await req.text()
const dom = new DOMParser
const pre = dom.parseFromString(res, "text/html")
const pagesCount = Number(pre.querySelector("input[name='pagesCount']").value)
const count = Number(pre.querySelector("input[name='count']").value)
if(count < 1) {
u('#_attachment_insert .docsInsert').append(`
<div class="information">
&nbsp; ${tr("no_documents")}.
</div>
</div>
`)
})
`)
}
pre.querySelectorAll("._content").forEach(doc => {
const res = u(`${doc.outerHTML}`)
const id = res.attr("data-attachmentdata")
if(page < pages_count - 1) {
insert_place.append(`
<div id="show_more" data-pagesCount="${pages_count}" data-page="${page + 1}">
<span>${tr('show_more')}</span>
</div>`)
res.find(".docMainItem").attr("style", "width: 85%;")
res.append(`
<div class="attachButton" id='__attach_doc'>
<span>${this.isDocAttached(id) ? tr("detach") : tr("attach")}</span>
</div>
`)
u('#_attachment_insert .docsInsert').append(res)
})
this.stat.page = page
this.stat.pagesCount = pagesCount
this.stat.count = count
u('#gif_loader').remove()
this.showMore()
}
showMore() {
if(this.stat.page < this.stat.pagesCount) {
u('#_attachment_insert').append(`
<div id="show_more" data-pagesCount="${this.stat.pagesCount}">
<span>${tr('show_more')}</span>
</div>
`)
}
}
maxAttachmentsCheck() {
if(u(form).find(`.upload-item`).length > window.openvk.max_attachments) {
makeError(tr('too_many_attachments'), 'Red', 10000, 1)
return true
}
return false
}
attach(dataset, button) {
if(this.isDocAttached(dataset.attachmentdata)) {
(form.find(`.upload-item[data-type='doc'][data-id='${dataset.attachmentdata}']`)).remove()
button.html(tr('attach'))
} else {
const _url = dataset.attachmentdata.split("_")
button.html(tr('detach'))
form.find('.post-vertical').append(`
<div class="vertical-attachment upload-item" draggable="true" data-type='doc' data-id="${dataset.attachmentdata}">
<div class='vertical-attachment-content' draggable="false">
<div class="docMainItem attachment_doc attachment_note">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 8 10"><polygon points="0 0 0 10 8 10 8 4 4 4 4 0 0 0"/><polygon points="5 0 5 3 8 3 5 0"/></svg>
<div class='attachment_note_content'>
<span class="attachment_note_text">${tr("document")}</span>
<span class="attachment_note_name"><a href="/doc${_url[0]}_${_url[1]}?key=${_url[2]}">${ovk_proc_strtr(escapeHtml(dataset.name), 50)}</a></span>
</div>
</div>
</div>
<div class='vertical-attachment-remove'>
<div id='small_remove_button'></div>
</div>
</div>
`)
}
}
isDocAttached(attachmentdata) {
return (form.find(`.upload-item[data-type='doc'][data-id='${attachmentdata}']`)).length > 0
}
}
// next page
u(".ovk-diag-body .attachment_selector").on("click", "#show_more", async (ev) => {
const target = u(ev.target).closest('#show_more')
target.addClass('lagged')
await __recieveDocs(Number(target.nodes[0].dataset.page))
target.remove()
msg.getNode().find("#ovk-photo-close").on("click", function(e) {
msg.close()
})
u(".ovk-diag-body .attachment_selector").on("click", "#__attach_doc", async (ev) => {
if(u(form).find(`.upload-item`).length > window.openvk.max_attachments) {
makeError(tr('too_many_attachments'), 'Red', 10000, 1)
msg.getNode().on("click", "#__attach_doc", async (ev) => {
if(docs_reciever.maxAttachmentsCheck() == true) {
return
}
const target = u(ev.target).closest('._content')
const button = target.find('#__attach_doc')
const dataset = target.nodes[0].dataset
const is_attached = (form.find(`.upload-item[data-type='doc'][data-id='${dataset.attachmentdata}']`)).length > 0
if(is_attached) {
(form.find(`.upload-item[data-type='doc'][data-id='${dataset.attachmentdata}']`)).remove()
button.html(tr('attach'))
} else {
if(form.find(`.upload-item`).length + 1 > window.openvk.max_attachments) {
makeError(tr('too_many_attachments'), 'Red', 10000, 1)
return
}
button.html(tr('detach'))
form.find('.post-vertical').append(`
<div class="vertical-attachment upload-item" draggable="true" data-type='doc' data-id="${dataset.attachmentdata}">
<div class='vertical-attachment-content' draggable="false">
<div class="docMainItem attachment_doc attachment_note">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 8 10"><polygon points="0 0 0 10 8 10 8 4 4 4 4 0 0 0"/><polygon points="5 0 5 3 8 3 5 0"/></svg>
<div class='attachment_note_content'>
<span class="attachment_note_text">${tr("document")}</span>
<span class="attachment_note_name"><a href="/doc${dataset.attachmentdata}">${ovk_proc_strtr(escapeHtml(dataset.name), 66)}</a></span>
</div>
</div>
</div>
<div class='vertical-attachment-remove'>
<div id='small_remove_button'></div>
</div>
</div>
`)
}
docs_reciever.attach(dataset, button)
})
msg.getNode().on("click", "#show_more", async (ev) => {
const target = u(ev.target).closest('#show_more')
target.addClass('lagged')
await docs_reciever.page(docs_reciever.stat.page + 1)
target.remove()
})
msg.getNode().on("click", "#_doc_picker_go_to_my", async (e) => {
msg.close()
await __docAttachment(form, "wall")
})
__recieveDocs(0)
await docs_reciever.page(docs_reciever.stat.page + 1)
}
u(document).on('click', '#__documentAttachment', async (e) => {
const form = u(e.target).closest('form')
const targ = u(e.target).closest("#__documentAttachment")
let entity_source = "user"
let entity_id = 0
if(targ.attr('data-club') != null) {
entity_source = "club"
entity_id = Number(targ.attr('data-club'))
}
await __docAttachment(form, "wall", entity_source, entity_id)
})

View file

@ -1039,7 +1039,10 @@ u(document).on("click", "#editPost", async (e) => {
// horizontal attachments
api_post.attachments.forEach(att => {
const type = att.type
const aid = att[type].owner_id + '_' + att[type].id
let aid = att[type].owner_id + '_' + att[type].id
if(att[type] && att[type].access_key) {
aid += "_" + att[type].access_key
}
if(type == 'video' || type == 'photo') {
let preview = ''

View file

@ -2381,3 +2381,6 @@
"documents_sort_add" = "By date";
"documents_sort_alphabet" = "A-Z";
"documents_sort_size" = "By size";
"select_doc" = "Attach document";
"no_documents" = "No documents found";
"go_to_my_documents" = "Go to own documents";

View file

@ -2276,3 +2276,6 @@
"documents_sort_add" = "По дате добавления";
"documents_sort_alphabet" = "A-Z/А-Я";
"documents_sort_size" = "По размеру";
"select_doc" = "Выбор документа";
"no_documents" = "Документов нет";
"go_to_my_documents" = "Перейти к своим документам";