function expand_wall_textarea(id) { var el = document.getElementById('post-buttons'+id); var wi = document.getElementById('wall-post-input'+id); el.style.display = "block"; wi.className = "expanded-textarea"; } function expand_comment_textarea(id) { var el = document.getElementById('commentTextArea'+id); var wi = document.getElementById('wall-post-input'+id); el.style.display = "block"; wi.focus(); } function edit_post(id, wid) { var el = document.getElementById('text'+wid+'_'+id); var ed = document.getElementById('text_edit'+wid+'_'+id); if (el.style.display == "none") { el.style.display = "block"; ed.style.display = "none"; } else { el.style.display = "none"; ed.style.display = "block"; } } function hidePanel(panel, count = 0) { $(panel).toggleClass("content_title_expanded content_title_unexpanded"); $(panel).next('div').slideToggle(300); if(count != 0){ if($(panel).hasClass("content_title_expanded")) $(panel).html($(panel).html().replaceAll(" ("+count+")", "")); else $(panel).html($(panel).html() + " ("+count+")"); } } function parseAjaxResponse(responseString) { try { const response = JSON.parse(responseString); if(response.flash) NewNotification(response.flash.title, response.flash.message || "", null); return response.success || false; } catch(error) { if(responseString === "Хакеры? Интересно...") { location.reload(); return false; } else { throw error; } } } function toggleMenu(id) { if($(`#post-buttons${id} #wallAttachmentMenu`).is('.hidden')) { $(`#post-buttons${id} #wallAttachmentMenu`).css({ opacity: 0 }); $(`#post-buttons${id} #wallAttachmentMenu`).toggleClass('hidden').fadeTo(250, 1); } else { $(`#post-buttons${id} #wallAttachmentMenu`).fadeTo(250, 0, function () { $(this).toggleClass('hidden'); }); } } document.addEventListener("DOMContentLoaded", function() { //BEGIN u("#_photoDelete").on("click", function(e) { var formHtml = "
"; formHtml += ""; formHtml += "
"; u("body").append(formHtml); MessageBox(tr('warning'), tr('question_confirm'), [ tr('yes'), tr('no') ], [ (function() { u("#tmpPhDelF").nodes[0].submit(); }), (function() { u("#tmpPhDelF").remove(); }), ]); return e.preventDefault(); }); /* @rem-pai why this func wasn't named as "#_deleteDialog"? It looks universal IMO */ u("#_noteDelete").on("click", function(e) { var formHtml = "
"; formHtml += ""; formHtml += "
"; u("body").append(formHtml); MessageBox(tr('warning'), tr('question_confirm'), [ tr('yes'), tr('no') ], [ (function() { u("#tmpPhDelF").nodes[0].submit(); }), (function() { u("#tmpPhDelF").remove(); }), ]); return e.preventDefault(); }); u("#_pinGroup").on("click", async function(e) { e.preventDefault(); let link = u(this).attr("href"); let thisButton = u(this); let groupName = u(this).attr("data-group-name"); let groupUrl = u(this).attr("data-group-url"); let list = u('#_groupListPinnedGroups'); thisButton.nodes[0].classList.add('loading'); thisButton.nodes[0].classList.add('disable'); let req = await ky(link); if(req.ok == false) { NewNotification(tr('error'), tr('error_1'), null); thisButton.nodes[0].classList.remove('loading'); thisButton.nodes[0].classList.remove('disable'); return; } if(!parseAjaxResponse(await req.text())) { thisButton.nodes[0].classList.remove('loading'); thisButton.nodes[0].classList.remove('disable'); return; } // Adding a divider if not already there if(list.nodes[0].children.length == 0) { list.nodes[0].append(u('').first()); } // Changing the button name if(thisButton.html().trim() == tr('remove_from_left_menu')) { thisButton.html(tr('add_to_left_menu')); for(let i = 0; i < list.nodes[0].children.length; i++) { let element = list.nodes[0].children[i]; if(element.pathname == groupUrl) { element.remove(); } } }else{ thisButton.html(tr('remove_from_left_menu')); list.nodes[0].append(u('' + groupName + '').first()); } // Adding the group to the left group list if(list.nodes[0].children[0].className != "menu_divider" || list.nodes[0].children.length == 1) { list.nodes[0].children[0].remove(); } thisButton.nodes[0].classList.remove('loading'); thisButton.nodes[0].classList.remove('disable'); return false; }); }); //END ONREADY DECLS async function repostPost(id, hash) { uRepostMsgTxt = ` ${tr('auditory')}:
${tr("in_wall")}
${tr("in_group")}

${tr('your_comment')}:

`; let clubs = []; repostsCount = document.getElementById("repostsCount"+id) prevVal = repostsCount != null ? Number(repostsCount.innerHTML) : 0; MessageBox(tr('share'), uRepostMsgTxt, [tr('send'), tr('cancel')], [ (function() { text = document.querySelector("#uRepostMsgInput_"+id).value; type = "user"; radios = document.querySelectorAll('input[name="type"]') for(const r of radios) { if(r.checked) { type = r.value; break; } } groupId = document.querySelector("#groupId").value; asGroup = asgroup.checked == true ? 1 : 0; signed = signed.checked == true ? 1 : 0; hash = encodeURIComponent(hash); xhr = new XMLHttpRequest(); xhr.open("POST", "/wall"+id+"/repost?hash="+hash, true); xhr.setRequestHeader('Content-type', 'application/x-www-form-urlencoded'); xhr.onload = (function() { if(xhr.responseText.indexOf("wall_owner") === -1) MessageBox(tr('error'), tr('error_repost_fail'), [tr('ok')], [Function.noop]); else { let jsonR = JSON.parse(xhr.responseText); NewNotification(tr('information_-1'), tr('shared_succ'), null, () => {window.location.href = "/wall" + jsonR.wall_owner}); repostsCount != null ? repostsCount.innerHTML = prevVal+1 : document.getElementById("reposts"+id).insertAdjacentHTML("beforeend", "(1)") //для старого вида постов } }); xhr.send('text='+encodeURI(text) + '&type='+type + '&groupId='+groupId + "&asGroup="+asGroup + "&signed="+signed); }), Function.noop ]); 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") } } function setClubAdminComment(clubId, adminId, hash) { MessageBox("Изменить комментарий к администратору", `


`, [tr('edit_action'), tr('cancel')], [ () => { if (document.querySelector(`#uClubAdminCommentTextArea_${clubId}_${adminId}`).value === "") { document.querySelector(`#uClubAdminCommentRemoveCommentInput_${clubId}_${adminId}`).value = "1"; } document.querySelector(`#uClubAdminCommentForm_${clubId}_${adminId}`).submit(); }, Function.noop ]); } function showCoinsTransferDialog(coinsCount, hash) { MessageBox(tr("transfer_poins"), `
${tr("points_transfer_dialog_header_1")} ${tr("points_transfer_dialog_header_2")} ${tr("points_amount", coinsCount)}
${tr("receiver_address")}:
${tr("coins_count")}:
${tr("message")}:
`, [tr("transfer_poins_button"), tr("cancel")], [ () => { document.querySelector("#coins_transfer_form").submit(); }, Function.noop ]); } function chunkSubstr(string, size) { const numChunks = Math.ceil(string.length / size); const chunks = new Array(numChunks); for (let i = 0, o = 0; i < numChunks; ++i, o += size) { chunks[i] = string.substr(o, size); } return chunks; } function autoTab(original, next, previous) { if(original.getAttribute && original.value.length == original.getAttribute("maxlength") && next !== undefined) next.focus(); else if(original.value.length == 0 && previous !== undefined) previous.focus(); } function showSupportFastAnswerDialog(answers) { let html = ""; for(const [index, answer] of Object.entries(answers)) { html += `
${answer.replace(/\n/g, "
")}
`; } MessageBox(tr("fast_answers"), html, [tr("close")], [ Function.noop ]); } function supportFastAnswerDialogOnClick(answer) { u("body").removeClass("dimmed"); u(".ovk-diag-cont").remove(); const answerInput = document.querySelector("#answer_text"); answerInput.value = answer; answerInput.focus(); } function ovk_proc_strtr(string, length = 0) { const newString = string.substring(0, length); return newString + (string !== newString ? "…" : ""); } function showProfileDeactivateDialog(hash) { MessageBox(tr("profile_deactivate"), `
${tr("profile_deactivate_header")}

${tr("profile_deactivate_reason_header")}



`, [tr("profile_deactivate_button"), tr("cancel")], [ () => { $("#profile_deactivate_dialog").submit(); }, Function.noop ]); $('[id^="deactivate_r_"]').on("click", function () { $('#deactivate_reason').val($(this).data("text")); }); } function showIncreaseRatingDialog(coinsCount, userUrl, hash) { MessageBox(tr("increase_rating"), `
${tr("you_have_unused_votes", coinsCount)}
${tr("apply_voucher")} »
${tr("to_whom")}:
${tr("increase_by")}:
${tr("message")}:
${tr("price")}: ${tr("points_amount", 0)} (1% = ${tr("points_amount_one", 1)})
`, [tr("increase_rating_button"), tr("cancel")], [ () => { document.querySelector("#increase_rating_form").submit(); }, Function.noop ]); document.querySelector("#value_input").oninput = function () { let value = Number(this.value); value = isNaN(value) ? "?" : ovk_proc_strtr(String(value), 7); if(!value.endsWith("…") && value != "?") value = Number(value); if(typeof value === "number") document.querySelector("#rating_price").innerHTML = tr("points_amount", value); else document.querySelector("#rating_price").innerHTML = value + " " + tr("points_amount_other").replace("$1 ", ""); }; } function escapeHtml(text) { var map = { '&': '&', '<': '<', '>': '>', '"': '"', "'": ''' }; return text.replace(/[&<>"']/g, function(m) { return map[m]; }); } function addAvatarImage(groupStrings = false, groupId = 0) { let inputname = groupStrings == true ? 'ava' : 'blob'; let body = `

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

${tr('formats_avatar')}




${tr('troubles_avatar')}

` let msg = MessageBox(tr('uploading_new_image'), body, [ tr('cancel') ], [ (function() { u("#tmpPhDelF").remove(); }), ]); msg.attr("style", "width: 600px;"); } function uploadAvatar(group = false, group_id = 0) { loader.style.display = "block"; uploadbtn.setAttribute("hidden", "hidden") let xhr = new XMLHttpRequest(); let formData = new FormData(); let bloborava = group == false ? "blob" : "ava" formData.append(bloborava, document.getElementById(bloborava).files[0]); formData.append("ava", 1) formData.append("hash", u("meta[name=csrf]").attr("value")) xhr.open("POST", group == true ? "/club"+group_id+"/al_avatar" : "/al_avatars") xhr.onload = () => { let json = JSON.parse(xhr.responseText); document.getElementById(group == false ? "thisUserAvatar" : "thisGroupAvatar").src = json["url"]; u("body").removeClass("dimmed"); u(".ovk-diag-cont").remove(); if(document.getElementsByClassName("text_add_image")[0] == undefined) { document.getElementById("upl").href = "javascript:deleteAvatar('"+json["id"]+"', '"+u("meta[name=csrf]").attr("value")+"')" } //console.log(json["id"]) NewNotification(tr("update_avatar_notification"), tr("update_avatar_description"), json["url"], () => {window.location.href = "/photo" + json["id"]}); if(document.getElementsByClassName("text_add_image")[0] != undefined) { //ожидание чтобы в уведомлении была аватарка let promise = new Promise((resolve, reject) => { setTimeout(() => { location.reload() }, 500); }); } } xhr.send(formData) } function deleteAvatar(avatar) { let body = `

${tr("deleting_avatar_sure")}

` let msg = MessageBox(tr('deleting_avatar'), body, [ tr('yes'), tr('cancel') ], [ (function() { let xhr = new XMLHttpRequest(); xhr.open("POST", "/photo"+avatar+"/delete") xhr.onload = () => { //не люблю формы NewNotification(tr("deleted_avatar_notification"), ""); location.reload() } xhr.setRequestHeader('Content-type', 'application/x-www-form-urlencoded'); xhr.send("hash="+u("meta[name=csrf]").attr("value")) }), (function() { u("#tmpPhDelF").remove(); }), ]); } function expandSearch() { // console.log("search expanded") let els = document.querySelectorAll("div.dec") for(const element of els) { element.style.display = "none" } document.querySelector(".whatFind").style.display = "block"; document.querySelector(".whatFind").style.marginRight = "-80px"; document.getElementById("searchInput").style.width = "627px"; document.getElementById("searchInput").style.background = "none"; document.getElementById("searchInput").style.backgroundColor = "#fff"; document.getElementById("searchInput").style.paddingLeft = "6px"; srch.classList.add("nodivider") } async function decreaseSearch() { // чтобы люди успели выбрать что искать и поиск не скрывался сразу await new Promise(r => setTimeout(r, 4000)); // console.log("search decreased") if(document.activeElement !== searchInput && document.activeElement !== typer) { srcht.setAttribute("hidden", "hidden") document.getElementById("searchInput").style.background = "url('/assets/packages/static/openvk/img/search_icon.png') no-repeat 3px 4px"; document.getElementById("searchInput").style.backgroundColor = "#fff"; document.getElementById("searchInput").style.paddingLeft = "18px"; document.getElementById("searchInput").style.width = "120px"; document.querySelector(".whatFind").style.display = "none"; await new Promise(r => setTimeout(r, 300)); srch.classList.remove("nodivider") let els = document.querySelectorAll("div.dec") for(const element of els) { element.style.display = "inline-block" } } } function hideParams(name) { $("#s_"+name).slideToggle(250, "swing"); if($(`#n_${name} img`).attr("src") == "/assets/packages/static/openvk/img/hide.png") { $("#n_"+name+" img").attr("src", "/assets/packages/static/openvk/img/show.png"); } else { $("#n_"+name+" img").attr("src", "/assets/packages/static/openvk/img/hide.png"); } } function resetSearch() { let inputs = document.querySelectorAll("input") let selects = document.querySelectorAll("select") for(const input of inputs) { if(input != dnt && input != gend && input != gend1 && input != gend2) { input.value = "" } } for(const select of selects) { if(select != sortyor && select != document.querySelector(".whatFind")) { select.value = 0 } } } async function checkSearchTips() { let query = searchInput.value; await new Promise(r => setTimeout(r, 1000)); let type = typer.value; let smt = type == "users" || type == "groups" || type == "videos"; if(query.length > 3 && query == searchInput.value && smt) { srcht.removeAttribute("hidden") let etype = type try { let results = await API.Search.fastSearch(escapeHtml(query), etype) srchrr.innerHTML = "" for(const el of results["items"]) { srchrr.insertAdjacentHTML("beforeend", `

${escapeHtml(el.name)}

${escapeHtml(el.description)}

`) } } catch(rejection) { srchrr.innerHTML = tr("no_results") } } } $(document).on("scroll", () => { if($(document).scrollTop() > $(".sidebar").height() + 50) { $(".floating_sidebar")[0].classList.add("show"); } else if($(".floating_sidebar")[0].classList.contains("show")) { $(".floating_sidebar")[0].classList.remove("show"); $(".floating_sidebar")[0].classList.add("hide_anim"); setTimeout(() => { $(".floating_sidebar")[0].classList.remove("hide_anim"); }, 250); } }) function showBtStatusChangeDialog(report, currentBalance, hash) { MessageBox("Изменить статус", `

Вы можете прокомментировать изменение статуса



У тестировщика сейчас ${currentBalance} голосов.
Вы можете начислить    голосов
`, ["Сохранить", "Отмена"], [ () => { $("#status_change_dialog").submit(); }, Function.noop ]); } function showBtPriorityChangeDialog(report, currentBalance, hash) { MessageBox("Изменить приоритет", `

Вы можете прокомментировать изменение приоритета



У тестировщика сейчас ${currentBalance} голосов.
Вы можете начислить    голосов
`, ["Сохранить", "Отмена"], [ () => { $("#priority_change_dialog").submit(); }, Function.noop ]); } function showBtGiveProductAccessDialog(product, hash) { MessageBox("Выдать доступ", `
Выдать пользователю ID    доступ к продукту ${product[1]} (#${product[0]}).
`, ["Продолжить", tr("cancel")], [ () => { $("#give_product_access_dialog").submit(); }, Function.noop ]); } function showBtRevokeProductAccessDialog(product, hash) { MessageBox("Забрать доступ", `
Забрать у пользователя ID    доступ к продукту ${product[1]} (#${product[0]}).
`, ["Продолжить", tr("cancel")], [ () => { $("#revoke_product_access_dialog").submit(); }, Function.noop ]); } function showBtProductAccessDialog(product, hash) { MessageBox(`Доступ к ${product[1]} (#${product[0]})`, `

ID пользователя 
`, ["Продолжить", tr("cancel")], [ () => { $("#give_product_access_dialog").submit(); }, Function.noop ]); } function showBtPrivateProductDialog(product, hash) { MessageBox(`Настройки продукта ${product[1]} (#${product[0]})`, `
`, ["Продолжить", tr("cancel")], [ () => { $("#give_product_access_dialog").submit(); }, Function.noop ]); } function showBtProductStatusDialog(product, hash) { MessageBox(`Статус продукта ${product[1]} (#${product[0]})`, `
`, ["Продолжить", tr("cancel")], [ () => { $("#give_product_access_dialog").submit(); }, Function.noop ]); } function showBtKickUserDialog(user, hash) { MessageBox("Исключить из программы", `
Вы действительно хотите исключить тестировщика ${user[1]} из программы OVK Testers?

Комментарий модератора

`, ["Продолжить", tr("cancel")], [ () => { $("#kick_from_ovk_testers_dialog").submit(); }, Function.noop ]); } function showBtUnbanUserDialog(user, hash) { MessageBox("Вернуть в программу", `
Вы действительно хотите вернуть тестировщика ${user[1]} в программу OVK Testers?

Он был исключён по причине: ${user[2]}
`, ["Вернуть", tr("cancel")], [ () => { $("#unban_ovk_testers_dialog").submit(); }, Function.noop ]); }