function humanFileSize(bytes, si) { var thresh = si ? 1000 : 1024; if(Math.abs(bytes) < thresh) { return bytes + ' B'; } var units = si ? ['kB','MB','GB','TB','PB','EB','ZB','YB'] : ['KiB','MiB','GiB','TiB','PiB','EiB','ZiB','YiB']; var u = -1; do { bytes /= thresh; ++u; } while(Math.abs(bytes) >= thresh && u < units.length - 1); return bytes.toFixed(1)+' '+units[u]; } function trim(string) { var newStr = string.substring(0, 10); if(newStr.length !== string.length) newStr += "…"; return newStr; } function trimNum(string, num) { var newStr = string.substring(0, num); if(newStr.length !== string.length) newStr += "…"; return newStr; } function handleUpload(id) { console.warn("блять..."); u("#post-buttons" + id + " .postFileSel").not("#" + this.id).each(input => input.value = null); var indicator = u("#post-buttons" + id + " .post-upload"); var file = this.files[0]; if(typeof file === "undefined") { indicator.attr("style", "display: none;"); } else { u("span", indicator.nodes[0]).text(trim(file.name) + " (" + humanFileSize(file.size, false) + ")"); indicator.attr("style", "display: block;"); } document.querySelector("#post-buttons" + id + " #wallAttachmentMenu").classList.add("hidden"); } function initGraffiti(id) { let canvas = null; let msgbox = MessageBox(tr("draw_graffiti"), "
", [tr("save"), tr("cancel")], [function() { canvas.getImage({includeWatermark: false}).toBlob(blob => { let fName = "Graffiti-" + Math.ceil(performance.now()).toString() + ".jpeg"; let image = new File([blob], fName, {type: "image/jpeg", lastModified: new Date().getTime()}); fastUploadImage(id, image) }, "image/jpeg", 0.92); canvas.teardown(); }, function() { canvas.teardown(); }]); let watermarkImage = new Image(); watermarkImage.src = "/assets/packages/static/openvk/img/logo_watermark.gif"; msgbox.attr("style", "width: 750px;"); canvas = LC.init(document.querySelector("#ovkDraw"), { backgroundColor: "#fff", imageURLPrefix: "/assets/packages/static/openvk/js/node_modules/literallycanvas/lib/img", watermarkImage: watermarkImage, imageSize: { width: 640, height: 480 } }); } function fastUploadImage(textareaId, file) { // uploading images if(!file.type.startsWith('image/')) { MessageBox(tr("error"), tr("only_images_accepted", escapeHtml(file.name)), [tr("ok")], [() => {Function.noop}]) return; } // 🤓🤓🤓 if(file.size > 5 * 1024 * 1024) { MessageBox(tr("error"), tr("max_filesize", 5), [tr("ok")], [() => {Function.noop}]) return; } let imagesCount = document.querySelector("#post-buttons" + textareaId + " input[name='photos']").value.split(",").length if(imagesCount > 10) { MessageBox(tr("error"), tr("too_many_photos"), [tr("ok")], [() => {Function.noop}]) return } let xhr = new XMLHttpRequest let data = new FormData data.append("photo_0", file) data.append("count", 1) data.append("hash", u("meta[name=csrf]").attr("value")) xhr.open("POST", "/photos/upload") xhr.onloadstart = () => { document.querySelector("#post-buttons"+textareaId+" .upload").insertAdjacentHTML("beforeend", ``) } xhr.onload = () => { let response = JSON.parse(xhr.responseText) appendImage(response, textareaId) } xhr.send(data) } // append image after uploading via /photos/upload function appendImage(response, textareaId) { if(!response.success) { MessageBox(tr("error"), (tr("error_uploading_photo") + response.flash.message), [tr("ok")], [() => {Function.noop}]) } else { let form = document.querySelector("#post-buttons"+textareaId) let photosInput = form.querySelector("input[name='photos']") let photosIndicator = form.querySelector(".upload") for(const phot of response.photos) { let id = phot.owner + "_" + phot.vid photosInput.value += (id + ",") u(photosIndicator).append(u(`
×
`)) u(photosIndicator.querySelector(`.upload #aP[data-id='${id}'] .upload-delete`)).on("click", () => { photosInput.value = photosInput.value.replace(id + ",", "") u(form.querySelector(`.upload #aP[data-id='${id}']`)).remove() }) } } u(`#post-buttons${textareaId} .upload #loader`).remove() } $(document).on("click", ".post-like-button", function(e) { e.preventDefault(); var thisBtn = u(this).first(); var link = u(this).attr("href"); var heart = u(".heart", thisBtn); var counter = u(".likeCnt", thisBtn); var likes = counter.text() === "" ? 0 : counter.text(); var isLiked = heart.attr("id") === 'liked'; ky(link); heart.attr("id", isLiked ? '' : 'liked'); counter.text(parseInt(likes) + (isLiked ? -1 : 1)); if (counter.text() === "0") { counter.text(""); } return false; }); function setupWallPostInputHandlers(id) { u("#wall-post-input" + id).on("paste", function(e) { // Если вы находитесь на странице с постом с id 11, то копирование произойдёт джва раза. // Оч ржачный баг, но вот как его исправить, я, если честно, не знаю. if(e.clipboardData.files.length === 1) { fastUploadImage(id, e.clipboardData.files[0]) return; } }); u("#wall-post-input" + id).on("dragover", function(e) { e.preventDefault() // todo add animation return; }); $("#wall-post-input" + id).on("drop", function(e) { e.originalEvent.dataTransfer.dropEffect = 'move'; fastUploadImage(id, e.originalEvent.dataTransfer.files[0]) return; }); } u(document).on("input", "textarea", function(e) { var boost = 5; var textArea = e.target; textArea.style.height = "5px"; var newHeight = textArea.scrollHeight; textArea.style.height = newHeight + boost + "px"; return; // revert to original size if it is larger (possibly changed by user) // textArea.style.height = (newHeight > originalHeight ? (newHeight + boost) : originalHeight) + "px"; }); function OpenMiniature(e, photo, post, photo_id, type = "post") { /* костыли но смешные однако */ e.preventDefault(); if(u(".ovk-photo-view").length > 0) u(".ovk-photo-view-dimmer").remove(); // Значения для переключения фоток let json; let imagesCount = 0; let imagesIndex = 0; let tempDetailsSection = []; let dialog = u( `
`); u("body").addClass("dimmed").append(dialog); document.querySelector("html").style.overflowY = "hidden" let button = u("#ovk-photo-close"); button.on("click", function(e) { let __closeDialog = () => { u("body").removeClass("dimmed"); u(".ovk-photo-view-dimmer").remove(); document.querySelector("html").style.overflowY = "scroll" }; __closeDialog(); }); function __reloadTitleBar() { u("#photo_com_title_photos").last().innerHTML = imagesCount > 1 ? tr("photo_x_from_y", imagesIndex, imagesCount) : tr("photo"); } function __loadDetails(photo_id, index) { if(tempDetailsSection[index] == null) { u(".ovk-photo-details").last().innerHTML = ''; ky("/photo" + photo_id, { hooks: { afterResponse: [ async (_request, _options, response) => { let parser = new DOMParser(); let body = parser.parseFromString(await response.text(), "text/html"); let element = u(body.getElementsByClassName("ovk-photo-details")).last(); tempDetailsSection[index] = element.innerHTML; if(index == imagesIndex) { u(".ovk-photo-details").last().innerHTML = element.innerHTML ?? ''; } document.querySelectorAll(".ovk-photo-details .bsdn").forEach(bsdnInitElement) document.querySelectorAll(".ovk-photo-details script").forEach(scr => { // stolen from #953 let newScr = document.createElement('script') if(scr.src) { newScr.src = scr.src } else { newScr.textContent = scr.textContent } document.querySelector(".ovk-photo-details").appendChild(newScr); }) } ] } }); } else { u(".ovk-photo-details").last().innerHTML = tempDetailsSection[index]; } } function __slidePhoto(direction) { /* direction = 1 - right direction = 0 - left */ if(json == undefined) { console.log("Да подожди ты. Куда торопишься?"); } else { if(imagesIndex >= imagesCount && direction == 1) { imagesIndex = 1; } else if(imagesIndex <= 1 && direction == 0) { imagesIndex = imagesCount; } else if(direction == 1) { imagesIndex++; } else if(direction == 0) { imagesIndex--; } let photoURL = json.body[imagesIndex - 1].url; u("#ovk-photo-img").last().src = photoURL; __reloadTitleBar(); __loadDetails(json.body[imagesIndex - 1].id, imagesIndex); } } let slideLeft = u(".ovk-photo-slide-left"); slideLeft.on("click", (e) => { __slidePhoto(0); }); let slideRight = u(".ovk-photo-slide-right"); slideRight.on("click", (e) => { __slidePhoto(1); }); let data = new FormData() data.append('parentType', type); if(type) { ky.post("/iapi/getPhotosFromPost/" + (type == "post" ? post : "1_"+post), { hooks: { afterResponse: [ async (_request, _options, response) => { json = await response.json(); imagesCount = json.body.length; imagesIndex = 0; // Это всё придётся правда на 1 прибавлять json.body.every(element => { imagesIndex++; if(element.id == photo_id) { return false; } else { return true; } }); __reloadTitleBar(); __loadDetails(json.body[imagesIndex - 1].id, imagesIndex); } ] }, body: data }); } else { imagesCount = 1 __reloadTitleBar() __loadDetails(photo_id, imagesIndex) } return u(".ovk-photo-view-dimmer"); } u("#write > form").on("keydown", function(event) { if(event.ctrlKey && event.keyCode === 13) this.submit(); }); var tooltipClientTemplate = Handlebars.compile(`
{{app_tr}}: {{name}}
${tr("learn_more")}
`); var tooltipClientNoInfoTemplate = Handlebars.compile(`
{{app_tr}}: {{name}}
`); tippy(".client_app", { theme: "light vk", content: "⌛", allowHTML: true, interactive: true, interactiveDebounce: 500, onCreate: async function(that) { that._resolvedClient = null; }, onShow: async function(that) { let client_tag = that.reference.dataset.appTag; let client_name = that.reference.dataset.appName; let client_url = that.reference.dataset.appUrl; let client_img = that.reference.dataset.appImg; if(client_name != "") { let res = { 'name': client_name, 'url': client_url, 'img': client_img, 'app_tr': tr("app") }; that.setContent(tooltipClientTemplate(res)); } else { let res = { 'name': client_tag, 'app_tr': tr("app") }; that.setContent(tooltipClientNoInfoTemplate(res)); } } }); function addNote(textareaId, nid) { if(nid > 0) { document.getElementById("note").value = nid let noteObj = document.querySelector("#nd"+nid) let nortd = document.querySelector("#post-buttons"+textareaId+" .post-has-note"); nortd.style.display = "block" nortd.innerHTML = `${tr("note")} ${escapeHtml(noteObj.dataset.name)}` } else { document.getElementById("note").value = "none" let nortd = document.querySelector("#post-buttons"+textareaId+" .post-has-note"); nortd.style.display = "none" nortd.innerHTML = "" } u("body").removeClass("dimmed"); u(".ovk-diag-cont").remove(); document.querySelector("html").style.overflowY = "scroll" } async function attachNote(id) { let notes = await API.Wall.getMyNotes() let body = `` if(notes.closed < 1) { body = `${tr("notes_closed")}` } else { if(notes.items.length < 1) { body = `${tr("no_notes")}` } else { body = ` ${tr("select_or_create_new")}
` if(document.getElementById("note").value != "none") { body += `
${tr("do_not_attach_note")}
` } for(const note of notes.items) { body += `
${escapeHtml(note.name)}
` } body += `
` } } let frame = MessageBox(tr("select_note"), body, [tr("cancel")], [Function.noop]); document.querySelector(".ovk-diag-body").style.padding = "10px" } async function showArticle(note_id) { u("body").addClass("dimmed"); let note = await API.Notes.getNote(note_id); u("#articleAuthorAva").attr("src", note.author.ava); u("#articleAuthorName").text(note.author.name); u("#articleAuthorName").attr("href", note.author.link); u("#articleTime").text(note.created); u("#articleLink").attr("href", note.link); u("#articleText").html(`

${note.title}

` + note.html); u("body").removeClass("dimmed"); u("body").addClass("article"); } // Оконный плеер $(document).on("click", "#videoOpen", async (e) => { e.preventDefault() document.getElementById("ajloader").style.display = "block" if(document.querySelector(".ovk-fullscreen-dimmer") != null) { u(".ovk-fullscreen-dimmer").remove() } let target = e.currentTarget let videoId = target.dataset.id let videoObj = null; try { videoObj = await API.Video.getVideo(Number(videoId)) } catch(e) { console.error(e) document.getElementById("ajloader").style.display = "none" MessageBox(tr("error"), tr("video_access_denied"), [tr("cancel")], [ function() { Function.noop }]); return 0; } document.querySelector("html").style.overflowY = "hidden" let player = null; if(target.dataset.dontload == null) { document.querySelectorAll("video").forEach(vid => vid.pause()) if(videoObj.type == 0) { if(videoObj.isProcessing) { player = ` ${tr("video_processing")} ` } else { player = `
` } } else { player = videoObj.embed } } else { player = `` } let dialog = u( `
${videoObj.prevVideo != null ? `
` : ""} ${videoObj.nextVideo != null ? `
` : ""}
${escapeHtml(videoObj.title)}
${tr("hide_player")} | ${tr("close_player")}
${target.dataset.dontload == null ?`
${player}
` : ""}
${tr("show_comments")} | ${tr("to_page")} ${ videoObj.type == 0 && videoObj.isProcessing == false ? `| ${tr("download_video")}` : ""}
${videoObj.description != null ? escapeHtml(videoObj.description) : "(" + tr("no_description") + ")"}
${tr("added")} ${videoObj.published} |
${tr("x_views", 0)}
${tr("video_author")}:
${videoObj.author}
${videoObj.canBeEdited ? ` ${tr("edit")} ${tr("delete")} ` : ""} ${tr("share")}
`); u("body").addClass("dimmed").append(dialog); if(target.dataset.dontload != null) { let oldPlayer = document.querySelector(".miniplayer-video .fplayer") let newPlayer = document.querySelector(".top-part-player-subdiv") newPlayer.append(oldPlayer) } if(videoObj.type == 0 && videoObj.isProcessing == false) { bsdnInitElement(document.querySelector(".fplayer .bsdn")) } document.getElementById("ajloader").style.display = "none" u(".miniplayer").remove() }) $(document).on("click", "#closeFplayer", async (e) => { u(".ovk-fullscreen-dimmer").remove(); document.querySelector("html").style.overflowY = "scroll" u("body").removeClass("dimmed") }) $(document).on("click", "#minimizePlayer", async (e) => { let targ = e.currentTarget let player = document.querySelector(".fplayer") let dialog = u(`
${escapeHtml(trimNum(targ.dataset.name, 26))}
`); u("body").append(dialog); $('.miniplayer').draggable({cursor: "grabbing", containment: "body", cancel: ".miniplayer-video"}); let newPlayer = document.querySelector(".miniplayer-video") newPlayer.append(player) document.querySelector(".miniplayer").style.top = window.scrollY; document.querySelector("#closeFplayer").click() }) $(document).on("click", "#closeMiniplayer", async (e) => { u(".miniplayer").remove() }) $(document).on("mouseup", "#gotopage", async (e) => { if(e.originalEvent.which === 1) { location.href = e.currentTarget.dataset.id } else if (e.originalEvent.which === 2) { window.open(e.currentTarget.dataset.id, '_blank') } }) $(document).keydown(function(e) { if(document.querySelector(".top-part-player-subdiv .bsdn") != null && document.activeElement.tagName == "BODY") { let video = document.querySelector(".top-part-player-subdiv video") switch(e.keyCode) { // Пробел вроде case 32: document.querySelector(".top-part-player-subdiv .bsdn_teaserButton").click() break // Стрелка вниз, уменьшение громкости case 40: oldVolume = video.volume if(oldVolume - 0.1 > 0) { video.volume = oldVolume - 0.1 } else { video.volume = 0 } break; // Стрелка вверх, повышение громкости case 38: oldVolume = video.volume if(oldVolume + 0.1 < 1) { video.volume = oldVolume + 0.1 } else { video.volume = 1 } break // стрелка влево, отступ на 2 секунды назад case 37: oldTime = video.currentTime video.currentTime = oldTime - 2 break // стрелка вправо, отступ на 2 секунды вперёд case 39: oldTime = document.querySelector(".top-part-player-subdiv video").currentTime document.querySelector(".top-part-player-subdiv video").currentTime = oldTime + 2 break } } }); $(document).keyup(function(e) { if(document.querySelector(".top-part-player-subdiv .bsdn") != null && document.activeElement.tagName == "BODY") { let video = document.querySelector(".top-part-player-subdiv video") switch(e.keyCode) { // Escape, закрытие плеера case 27: document.querySelector("#closeFplayer").click() break // Блять, я перепутал лево и право, пиздец я долбаёб конечно // Ну короче стрелка влево case 65: if(document.querySelector(".right-arrow") != null) { document.querySelector(".right-arrow").click() } else { console.info("No left arrow bro") } break // Фуллскрин case 70: document.querySelector(".top-part-player-subdiv .bsdn_fullScreenButton").click() break // стрелка вправо case 68: if(document.querySelector(".left-arrow") != null) { document.querySelector(".left-arrow").click() } else { console.info("No right arrow bro") } break; // S: Показать инфо о видео (не комментарии) case 83: document.querySelector(".top-part-player-subdiv #showComments").click() break // Мут (M) case 77: document.querySelector(".top-part-player-subdiv .bsdn_soundIcon").click() break; // Escape, выход из плеера case 192: document.querySelector(".top-part-buttons #minimizePlayer").click() break // Бля не помню сори case 75: document.querySelector(".top-part-player-subdiv .bsdn_playButton").click() break // Home, переход в начало видосика case 36: video.currentTime = 0 break // End, переход в конец видосика case 35: video.currentTime = video.duration break; } } }); $(document).on("click", "#showComments", async (e) => { if(document.querySelector(".bottom-part").style.display == "none" || document.querySelector(".bottom-part").style.display == "") { if(document.getElementById("vidComments").innerHTML == "") { let xhr = new XMLHttpRequest xhr.open("GET", "/video"+e.currentTarget.dataset.pid) xhr.onloadstart = () => { document.getElementById("vidComments").innerHTML = `` } xhr.timeout = 10000; xhr.onload = () => { let parser = new DOMParser(); let body = parser.parseFromString(xhr.responseText, "text/html"); let comms = body.getElementById("comments") let commsHTML = comms.innerHTML.replace("expand_wall_textarea(11)", "expand_wall_textarea(999)") .replace("wall-post-input11", "wall-post-input999") .replace("post-buttons11", "post-buttons999") .replace("toggleMenu(11)", "toggleMenu(999)") .replace("toggleMenu(11)", "toggleMenu(999)") .replace(/ons11/g, "ons999") document.getElementById("vidComments").innerHTML = commsHTML } xhr.onerror = () => { document.getElementById("vidComments").innerHTML = `${tr("comments_load_timeout")}` } xhr.ontimeout = () => { document.getElementById("vidComments").innerHTML = `${tr("comments_load_timeout")}` }; xhr.send() } document.querySelector(".bottom-part").style.display = "flex" e.currentTarget.innerHTML = tr("close_comments") } else { document.querySelector(".bottom-part").style.display = "none" e.currentTarget.innerHTML = tr("show_comments") } }) $(document).on("click", "#shareVideo", async (e) => { let owner_id = e.currentTarget.dataset.owner let virtual_id = e.currentTarget.dataset.vid let body = ` ${tr('auditory')}:
${tr("in_wall")}
${tr("in_group")}

${tr('your_comment')}: ` MessageBox(tr("share_video"), body, [tr("share"), tr("cancel")], [ (async function() { let type = $('input[name=type]:checked').val() let club = document.getElementById("groupId").value let asGroup = document.getElementById("asgroup").checked let signed = document.getElementById("signed").checked let repost = null; try { repost = await API.Video.shareVideo(Number(owner_id), Number(virtual_id), Number(type), uRepostMsgInput.value, Number(club), signed, asGroup) NewNotification(tr('information_-1'), tr('shared_succ_video'), null, () => {window.location.href = "/wall" + repost.pretty_id}); } catch(e) { console.log("tudu") } }), (function() { Function.noop })], false); try { clubs = await API.Groups.getWriteableClubs(); for(const el of clubs) { document.getElementById("groupId").insertAdjacentHTML("beforeend", ``) } } catch(rejection) { console.error(rejection) document.getElementById("group").setAttribute("disabled", "disabled") } }) $(document).on("click", "#videoAttachment", async (e) => { e.preventDefault() let body = `
${tr("upload_new_video")}
` let form = e.currentTarget.closest("form") MessageBox(tr("selecting_video"), body, [tr("close")], [Function.noop]); // styles for messageboxx document.querySelector(".ovk-diag-body").style.padding = "0" document.querySelector(".ovk-diag-cont").style.width = "580px" document.querySelector(".ovk-diag-body").style.height = "335px" async function insertVideos(page, query = "") { document.querySelector(".videosInsert").insertAdjacentHTML("beforeend", ``) let vidoses let noVideosText = tr("no_videos") if(query == "") { vidoses = await API.Wall.getVideos(page) } else { vidoses = await API.Wall.searchVideos(page, query) noVideosText = tr("no_videos_results") } if(vidoses.count < 1) { document.querySelector(".videosInsert").innerHTML = `${noVideosText}` } let pagesCount = Math.ceil(Number(vidoses.count) / 8) u("#loader").remove() let insert = document.querySelector(".videosInsert") for(const vid of vidoses.items) { let isAttached = (form.querySelector("input[name='videos']").value.includes(`${vid.video.owner_id}_${vid.video.id},`)) insert.insertAdjacentHTML("beforeend", `
${escapeHtml(vid.video.title)}
${ovk_proc_strtr(escapeHtml(vid.video.title), 30)}

${ovk_proc_strtr(escapeHtml(vid.video.description ?? ""), 140)}

${escapeHtml(vid.video.author_name ?? "")}
`) } if(page < pagesCount) { document.querySelector(".videosInsert").insertAdjacentHTML("beforeend", `
more...
`) } } $(".videosInsert").on("click", "#showMoreVideos", (e) => { u(e.currentTarget).remove() insertVideos(Number(e.currentTarget.dataset.page), document.querySelector(".topGrayBlock #vquery").value) }) $(".topGrayBlock #vquery").on("change", async (e) => { await new Promise(r => setTimeout(r, 1000)); if(e.currentTarget.value === document.querySelector(".topGrayBlock #vquery").value) { document.querySelector(".videosInsert").innerHTML = "" insertVideos(1, e.currentTarget.value) return; } else { console.info("skipping") } }) insertVideos(1) function insertAttachment(id) { let videos = form.querySelector("input[name='videos']") if(!videos.value.includes(id + ",")) { if(videos.value.split(",").length > 10) { NewNotification(tr("error"), tr("max_attached_videos")) return false } form.querySelector("input[name='videos']").value += (id + ",") console.info(id + " attached") return true } else { form.querySelector("input[name='videos']").value = form.querySelector("input[name='videos']").value.replace(id + ",", "") console.info(id + " detached") return false } } $(".videosInsert").on("click", "#attachvid", (ev) => { // откреплено от псто if(!insertAttachment(ev.currentTarget.dataset.attachmentdata)) { u(`.post-has-videos .post-has-video[data-id='${ev.currentTarget.dataset.attachmentdata}']`).remove() ev.currentTarget.innerHTML = tr("attach") } else { ev.currentTarget.innerHTML = tr("detach") form.querySelector(".post-has-videos").insertAdjacentHTML("beforeend", `
${tr("video")} "${ovk_proc_strtr(escapeHtml(ev.currentTarget.dataset.name), 20)}"
`) u(`#unattachVideo[data-id='${ev.currentTarget.dataset.attachmentdata}']`).on("click", (e) => { let id = ev.currentTarget.dataset.attachmentdata form.querySelector("input[name='videos']").value = form.querySelector("input[name='videos']").value.replace(id + ",", "") console.info(id + " detached") u(e.currentTarget).remove() }) } }) }) $(document).on("click", "#editPost", (e) => { let post = e.currentTarget.closest("table") let content = post.querySelector(".text") let text = content.querySelector(".really_text") if(content.querySelector("textarea") == null) { content.insertAdjacentHTML("afterbegin", `
${e.currentTarget.dataset.nsfw != null ? `
` : ``} ${e.currentTarget.dataset.fromgroup != null ? `
` : ``}
`) u(content.querySelector("#cancelEditing")).on("click", () => {post.querySelector("#editPost").click()}) u(content.querySelector("#endEditing")).on("click", () => { let nwcntnt = content.querySelector("#new_content").value let type = "post" if(post.classList.contains("comment")) { type = "comment" } let xhr = new XMLHttpRequest() xhr.open("POST", "/wall/edit") xhr.onloadstart = () => { content.querySelector(".editMenu").classList.add("loading") } xhr.onerror = () => { MessageBox(tr("error"), "unknown error occured", [tr("ok")], [() => {Function.noop}]) } xhr.ontimeout = () => { MessageBox(tr("error"), "Try to refresh page", [tr("ok")], [() => {Function.noop}]) } xhr.onload = () => { let result = JSON.parse(xhr.responseText) if(result.error == "no") { post.querySelector("#editPost").click() content.querySelector(".really_text").innerHTML = result.new_content if(post.querySelector(".editedMark") == null) { post.querySelector(".date").insertAdjacentHTML("beforeend", ` (${tr("edited_short")}) `) } if(e.currentTarget.dataset.nsfw != null) { e.currentTarget.setAttribute("data-nsfw", result.nsfw) if(result.nsfw == 0) { post.classList.remove("post-nsfw") } else { post.classList.add("post-nsfw") } } if(e.currentTarget.dataset.fromgroup != null) { e.currentTarget.setAttribute("data-fromgroup", result.from_group) } post.querySelector(".post-avatar").setAttribute("src", result.author.avatar) post.querySelector(".post-author-name").innerHTML = result.author.name.escapeHtml() post.querySelector(".really_text").setAttribute("data-text", result.new_text) } else { MessageBox(tr("error"), result.error, [tr("ok")], [Function.noop]) post.querySelector("#editPost").click() } } xhr.setRequestHeader('Content-type', 'application/x-www-form-urlencoded'); xhr.send("postid="+e.currentTarget.dataset.id+ "&newContent="+nwcntnt+ "&hash="+encodeURIComponent(u("meta[name=csrf]").attr("value"))+ "&type="+type+ "&nsfw="+(content.querySelector("#nswfw") != null ? content.querySelector("#nswfw").checked : 0)+ "&fromgroup="+(content.querySelector("#fromgroup") != null ? content.querySelector("#fromgroup").checked : 0)) }) u(".editMenu").on("keydown", (e) => { if(e.ctrlKey && e.keyCode === 13) content.querySelector("#endEditing").click() }); text.style.display = "none" setupWallPostInputHandlers(999) } else { u(content.querySelector(".editMenu")).remove() text.style.display = "block" } }) // copypaste from videos picker $(document).on("click", "#photosAttachments", async (e) => { let body = `
${tr("upload_new_photo")}:

${tr("is_x_photos", 0)}

` let form = e.currentTarget.closest("form") MessageBox(tr("select_photo"), body, [tr("close")], [Function.noop]); document.querySelector(".ovk-diag-body").style.padding = "0" document.querySelector(".ovk-diag-cont").style.width = "630px" document.querySelector(".ovk-diag-body").style.height = "335px" async function insertPhotos(page, album = 0) { u("#loader").remove() let insertPlace = document.querySelector(".photosInsert .photosList") document.querySelector(".photosInsert").insertAdjacentHTML("beforeend", ``) let photos; try { photos = await API.Photos.getPhotos(page, Number(album)) } catch(e) { document.querySelector(".photosInsert h4").innerHTML = tr("is_x_photos", -1) insertPlace.innerHTML = "Invalid album" console.error(e) u("#loader").remove() return; } document.querySelector(".photosInsert h4").innerHTML = tr("is_x_photos", photos.count) let pagesCount = Math.ceil(Number(photos.count) / 24) u("#loader").remove() for(const photo of photos.items) { let isAttached = (form.querySelector("input[name='photos']").value.includes(`${photo.owner_id}_${photo.id},`)) insertPlace.insertAdjacentHTML("beforeend", `
...
`) } if(page < pagesCount) { insertPlace.insertAdjacentHTML("beforeend", `
more...
`) } } insertPhotos(1) let albums = await API.Photos.getAlbums(Number(e.currentTarget.dataset.club ?? 0)) for(const alb of albums.items) { let sel = document.querySelector(".ovk-diag-body #albumSelect") sel.insertAdjacentHTML("beforeend", ``) } $(".photosInsert").on("click", "#showMorePhotos", (e) => { u(e.currentTarget).remove() insertPhotos(Number(e.currentTarget.dataset.page), document.querySelector(".topGrayBlock #albumSelect").value) }) $(".topGrayBlock #albumSelect").on("change", (evv) => { document.querySelector(".photosInsert .photosList").innerHTML = "" insertPhotos(1, evv.currentTarget.value) }) function insertAttachment(id) { let photos = form.querySelector("input[name='photos']") if(!photos.value.includes(id + ",")) { if(photos.value.split(",").length > 10) { NewNotification(tr("error"), tr("max_attached_photos")) return false } form.querySelector("input[name='photos']").value += (id + ",") console.info(id + " attached") return true } else { form.querySelector("input[name='photos']").value = form.querySelector("input[name='photos']").value.replace(id + ",", "") console.info(id + " detached") return false } } $(".photosList").on("click", ".album-photo", (ev) => { ev.preventDefault() if(!insertAttachment(ev.currentTarget.dataset.attachmentdata)) { u(form.querySelector(`.upload #aP[data-id='${ev.currentTarget.dataset.attachmentdata}']`)).remove() ev.currentTarget.querySelector("img").style.backgroundColor = "white" } else { ev.currentTarget.querySelector("img").style.backgroundColor = "#646464" let id = ev.currentTarget.dataset.attachmentdata u(form.querySelector(`.upload`)).append(u(`
×
`)); u(`.upload #aP[data-id='${ev.currentTarget.dataset.attachmentdata}'] .upload-delete`).on("click", () => { form.querySelector("input[name='photos']").value = form.querySelector("input[name='photos']").value.replace(id + ",", "") u(form.querySelector(`.upload #aP[data-id='${ev.currentTarget.dataset.attachmentdata}']`)).remove() }) } }) u("#fastFotosUplod").on("change", (evn) => { let xhr = new XMLHttpRequest() xhr.open("POST", "/photos/upload") let formdata = new FormData() let iterator = 0 for(const fille of evn.currentTarget.files) { if(!fille.type.startsWith('image/')) { continue; } if(fille.size > 5 * 1024 * 1024) { continue; } if(evn.currentTarget.files.length >= 10) { NewNotification(tr("error"), tr("max_attached_photos")) return; } formdata.append("photo_"+iterator, fille) iterator += 1 } xhr.onloadstart = () => { evn.currentTarget.parentNode.insertAdjacentHTML("beforeend", ``) } xhr.onload = () => { let result = JSON.parse(xhr.responseText) u("#loader").remove() if(result.success) { for(const pht of result.photos) { let id = pht.owner + "_" + pht.vid if(!insertAttachment(id)) { return } u(form.querySelector(`.upload`)).append(u(`
×
`)); u(`.upload #aP[data-id='${pht.owner + "_" + pht.vid}'] .upload-delete`).on("click", () => { form.querySelector("input[name='photos']").value = form.querySelector("input[name='photos']").value.replace(id + ",", "") u(form.querySelector(`.upload #aP[data-id='${id}']`)).remove() }) } u("body").removeClass("dimmed"); u(".ovk-diag-cont").remove(); document.querySelector("html").style.overflowY = "scroll" } else { // todo: https://vk.com/wall-32295218_78593 alert(result.flash.message) } } formdata.append("hash", u("meta[name=csrf]").attr("value")) formdata.append("count", iterator) xhr.send(formdata) }) }) $(document).on("click", "#add_image", (e) => { let isGroup = e.currentTarget.closest(".avatar_block").dataset.club != null let group = isGroup ? e.currentTarget.closest(".avatar_block").dataset.club : 0 let body = `

${isGroup == true ? tr('groups_avatar') : tr('friends_avatar')}

${tr('formats_avatar')}




${tr('troubles_avatar')}

${tr('webcam_avatar')}

` let msg = MessageBox(tr('uploading_new_image'), body, [ tr('cancel') ], [ (function() { u("#tmpPhDelF").remove(); }), ]); msg.attr("style", "width: 600px;"); document.querySelector(".ovk-diag-body").style.padding = "13px" $("#avatarUpload input").on("change", (ev) => { let image = URL.createObjectURL(ev.currentTarget.files[0]) $(".ovk-diag-body")[0].innerHTML = ` ${!isGroup ? tr("selected_area_user") : tr("selected_area_club")}

${tr("selected_area_rotate")}

` document.querySelector(".ovk-diag-action").insertAdjacentHTML("beforeend", ` `) const image_div = document.getElementById('temp_uploadPic'); const cropper = new Cropper(image_div, { aspectRatio: NaN, zoomable: true, minCropBoxWidth: 150, minCropBoxHeight: 150, dragMode: 'move', background: false, center: false, guides: false, modal: true, viewMode: 2, cropstart(event) { document.querySelector(".cropper-container").classList.add("moving") }, cropend(event) { document.querySelector(".cropper-container").classList.remove("moving") }, }); msg.attr("style", "width: 487px;"); document.querySelector("#_uploadImg").onclick = (evv) => { cropper.getCroppedCanvas({ fillColor: '#fff', imageSmoothingEnabled: false, imageSmoothingQuality: 'high', }).toBlob((blob) => { document.querySelector("#_uploadImg").classList.add("lagged") let formdata = new FormData() formdata.append("blob", blob) formdata.append("ajax", 1) formdata.append("on_wall", Number(document.querySelector("#publish_on_wall").checked)) formdata.append("hash", u("meta[name=csrf]").attr("value")) $.ajax({ type: "POST", url: isGroup ? "/club" + group + "/al_avatar" : "/al_avatars", data: formdata, processData: false, contentType: false, error: (response) => { fastError(response.flash.message) }, success: (response) => { document.querySelector("#_uploadImg").classList.remove("lagged") u("body").removeClass("dimmed"); document.querySelector("html").style.overflowY = "scroll" u(".ovk-diag-cont").remove(); if(!response.success) { fastError(response.flash.message) return } document.querySelector("#bigAvatar").src = response.url document.querySelector("#bigAvatar").parentNode.href = "/photo" + response.new_photo document.querySelector(".add_image_text").style.display = "none" document.querySelector(".avatar_controls").style.display = "block" } }) }) } $(".ovk-diag-body ._rotateLeft").on("click", (e) => { cropper.rotate(90) }) $(".ovk-diag-body ._rotateRight").on("click", (e) => { cropper.rotate(-90) }) }) $(".ovk-diag-body #_takeSelfie").on("click", (e) => { $("#avatarUpload")[0].style.display = "none" $(".ovk-diag-body")[0].insertAdjacentHTML("beforeend", `
`) let video = document.querySelector("#_takeSelfieFrame video") if(!navigator.mediaDevices) { // ех вот бы месседжбоксы были бы классами u("body").removeClass("dimmed"); document.querySelector("html").style.overflowY = "scroll" u(".ovk-diag-cont").remove(); fastError(tr("your_browser_doesnt_support_webcam")) return } navigator.mediaDevices .getUserMedia({ video: true, audio: false }) .then((stream) => { video.srcObject = stream; video.play() window._cameraStream = stream }) .catch((err) => { u("body").removeClass("dimmed"); document.querySelector("html").style.overflowY = "scroll" u(".ovk-diag-cont").remove(); fastError(err) }); function __closeConnection() { window._cameraStream.getTracks().forEach(track => track.stop()) } document.querySelector(".ovk-diag-action").insertAdjacentHTML("beforeend", ` `) document.querySelector(".ovk-diag-action button").onclick = (evv) => { __closeConnection() } document.querySelector("#_takeSnap").onclick = (evv) => { let canvas = document.getElementById('_tempCanvas') let context = canvas.getContext('2d') canvas.setAttribute("width", video.clientWidth) canvas.setAttribute("height", video.clientHeight) context.drawImage(video, 0, 0, video.clientWidth, video.clientHeight); canvas.toBlob((blob) => { $("#_takeSnap").remove() let file = new File([blob], "snapshot.jpg", {type: "image/jpeg", lastModified: new Date().getTime()}) let dt = new DataTransfer(); dt.items.add(file); $("#_avaInput")[0].files = dt.files $("#_avaInput").trigger("change") $("#_takeSelfieFrame").remove() __closeConnection() }) } }) }) $(document).on("click", ".avatarDelete", (e) => { let isGroup = e.currentTarget.closest(".avatar_block").dataset.club != null let group = isGroup ? e.currentTarget.closest(".avatar_block").dataset.club : 0 let body = ` ${tr("deleting_avatar_sure")} ` let msg = MessageBox(tr('deleting_avatar'), body, [ tr('yes'), tr('no') ], [ (function() { let formdata = new FormData() formdata.append("hash", u("meta[name=csrf]").attr("value")) $.ajax({ type: "POST", url: isGroup ? "/club" + group + "/delete_avatar" : "/delete_avatar", data: formdata, processData: false, contentType: false, beforeSend: () => { document.querySelector(".avatarDelete").classList.add("lagged") }, error: (response) => { fastError(response.flash.message) }, success: (response) => { if(!response.success) { fastError(response.flash.message) return } document.querySelector(".avatarDelete").classList.remove("lagged") u("body").removeClass("dimmed"); document.querySelector("html").style.overflowY = "scroll" u(".ovk-diag-cont").remove() document.querySelector("#bigAvatar").src = response.url document.querySelector("#bigAvatar").parentNode.href = response.new_photo ? ("/photo" + response.new_photo) : "javascript:void(0)" if(!response.has_new_photo) { document.querySelector(".avatar_controls").style.display = "none" document.querySelector(".add_image_text").style.display = "block" } } }) }), (function() { u("#tmpPhDelF").remove(); }), ]); }) async function __processPaginatorNextPage(page) { const container = u('.scroll_container') const container_node = '.scroll_node' const parser = new DOMParser const replace_url = new URL(location.href) replace_url.searchParams.set('p', page) const new_content = await fetch(replace_url.href) const new_content_response = await new_content.text() const parsed_content = parser.parseFromString(new_content_response, 'text/html') const nodes = parsed_content.querySelectorAll(container_node) nodes.forEach(node => { container.append(node) }) u(`.paginator:not(.paginator-at-top)`).html(parsed_content.querySelector('.paginator:not(.paginator-at-top)').innerHTML) // fffffuck if(u(`.paginator:not(.paginator-at-top)`).nodes[0].closest('.scroll_container')) { container.nodes[0].append(u(`.paginator:not(.paginator-at-top)`).nodes[0].parentNode) } if(window.player) { window.player.loadContextPage(page) } if(typeof __scrollHook != 'undefined') { __scrollHook(page) } } const showMoreObserver = new IntersectionObserver(entries => { entries.forEach(async x => { if(x.isIntersecting) { if(u('.scroll_container').length < 1) { return } const target = u(x.target) if(target.length < 1 || target.hasClass('paginator-at-top')) { return } const current_url = new URL(location.href) if(current_url.searchParams && !isNaN(parseInt(current_url.searchParams.get('p')))) { return } target.addClass('lagged') const active_tab = target.find('.active') const next_page = u(active_tab.nodes[0] ? active_tab.nodes[0].nextElementSibling : null) if(next_page.length < 1) { u('.paginator:not(.paginator-at-top)').removeClass('lagged') return } const page_number = Number(next_page.html()) await __processPaginatorNextPage(page_number) u('.paginator:not(.paginator-at-top)').removeClass('lagged') } }) }, { root: null, rootMargin: '0px', threshold: 0, }) if(u('.paginator:not(.paginator-at-top)').length > 0) { showMoreObserver.observe(u('.paginator:not(.paginator-at-top)').nodes[0]) } u(document).on('click', '#__sourceAttacher', (e) => { MessageBox(tr('add_source'), `
${tr('set_source_tip')}
`, [tr('cancel')], [ () => {Function.noop} ]) __removeDialog = () => { u("body").removeClass("dimmed"); document.querySelector("html").style.overflowY = "scroll" u(".ovk-diag-cont").remove() } u('.ovk-diag-action').append(` `) u('.ovk-diag-action #__setsrcbutton').on('click', async (ev) => { // Consts const _u_target = u(e.target) const nearest_textarea = _u_target.closest('#write') const source_output = nearest_textarea.find(`input[name='source']`) const source_input = u(`#source_flex_kunteynir input[type='text']`) const source_value = source_input.nodes[0].value ?? '' if(source_value.length < 1) { return } ev.target.classList.add('lagged') // Checking link const __checkCopyrightLinkRes = await fetch(`/method/wall.checkCopyrightLink?auth_mechanism=roaming&link=${encodeURIComponent(source_value)}`) const checkCopyrightLink = await __checkCopyrightLinkRes.json() // todo переписать блять мессенджбоксы чтоб они классами были if(checkCopyrightLink.error_code) { __removeDialog() switch(checkCopyrightLink.error_code) { default: case 3102: fastError(tr('error_adding_source_regex')) return case 3103: fastError(tr('error_adding_source_long')) return case 3104: fastError(tr('error_adding_source_sus')) return } } // Making indicator __removeDialog() source_output.attr('value', source_value) nearest_textarea.find('.post-source').html(` ${tr('source')}: ${ovk_proc_strtr(source_value.escapeHtml(), 50)}
`) nearest_textarea.find('.post-source #remove_source_button').on('click', () => { nearest_textarea.find('.post-source').html('') source_output.attr('value', 'none') }) }) u('.ovk-diag-body').attr('style', `padding:8px;`) u('.ovk-diag-cont').attr('style', 'width: 325px;') u('#source_flex_kunteynir input').nodes[0].focus() })