fixes
This commit is contained in:
@ -16,56 +16,64 @@
|
||||
display: flex;
|
||||
}
|
||||
#img_prev{
|
||||
object-fit: fill;
|
||||
height: 200px;
|
||||
width: 200px;
|
||||
}
|
||||
</style>
|
||||
|
||||
<div style="display: flex;justify-content: space-between;">
|
||||
<h1>object</h1>
|
||||
<h1 id="object_edit_type">creation</h1>
|
||||
</div>
|
||||
<div class="nobj">
|
||||
<form action="#" class="nobj">
|
||||
<div>
|
||||
<div class="img_preview">
|
||||
<label for="img_file"><%= lang("img max size") %></label><br>
|
||||
<label for="img_file">макс. размер 2мб</label><br>
|
||||
<input type="file" id="img_file" onchange="previewFile()" accept="image/*" value="" maxlength="1"><br>
|
||||
|
||||
</div>
|
||||
<div style="width: 200px; height: 200px;">
|
||||
<img src="" id="img_prev" height="100" alt="<%= lang('Image preview') %>">
|
||||
<img src="" id="img_prev" height="100" alt="предпросмотр картинки">
|
||||
</div>
|
||||
</div>
|
||||
<textarea id="nobj_description" cols="30" rows="5" placeholder="<%= lang("object description") %>"></textarea>
|
||||
<textarea id="nobj_description" cols="30" rows="5" placeholder="описание товара"></textarea>
|
||||
<div>
|
||||
<div id="object_edit_type" style="text-align: right;">creation</div>
|
||||
<div class="nobj_options">
|
||||
<input type="text" id="nobj_name" placeholder="<%= lang("object name") %>">
|
||||
<button onclick="create_obj()" id="obj_apply_btn"><%= lang("create object")%></button>
|
||||
<input type="text" id="nobj_name" placeholder="название товара">
|
||||
<input type="submit" onclick="create_obj()" id="obj_apply_btn" value="создать товар">
|
||||
<div id="obj_resp"></div>
|
||||
</div>
|
||||
<div id="obj_input">
|
||||
<div>
|
||||
<div style="display: flex;width: 100%;justify-content: space-between;">
|
||||
<label for="obj_height"><%= lang("height") %> </label>
|
||||
<label for="obj_height">высота</label>
|
||||
<div id="obj_height_value">100см</div>
|
||||
</div>
|
||||
<input style="width: 100%;" type="range" step="1" min="1" max="100" id="obj_height" value="100" oninput="obj_size_change('height')">
|
||||
</div>
|
||||
<div>
|
||||
<div style="display: flex;width: 100%;justify-content: space-between;">
|
||||
<label for="obj_width"><%= lang("width") %></label>
|
||||
<label for="obj_width">ширина</label>
|
||||
<div id="obj_width_value">100см</div>
|
||||
</div>
|
||||
<input style="width: 100%;" type="range" step="1" min="1" max="100" id="obj_width" value="100" oninput="obj_size_change('width')">
|
||||
</div>
|
||||
</div>
|
||||
<div>
|
||||
<button onclick="set_obj_edit_params()">clear parameters</button>
|
||||
<div style="display: flex;width: 100%;justify-content: space-between;">
|
||||
<label for="obj_width">цена</label>
|
||||
<div style="display: flex;">
|
||||
<input style="text-align: right;" id="obj_cost" type="text">
|
||||
<div>руб.</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div>
|
||||
<button onclick="set_obj_edit_params()" style="width: 100%;margin-block:10px;">очистить параметры</button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</form>
|
||||
|
||||
<script>
|
||||
set_obj_edit_params();
|
||||
function obj_size_change(type){
|
||||
if(type == "height"){
|
||||
let img = document.getElementById('img_prev');
|
||||
@ -83,15 +91,17 @@
|
||||
}
|
||||
}
|
||||
|
||||
function set_obj_edit_params(img = "",name = "",description="",height = 100,width = 100){
|
||||
function set_obj_edit_params(img = "",name = "",description="",height = 100,width = 100,cost = 0,gid = 0){
|
||||
if(img ==""&&name ==""&&description == ""){
|
||||
document.getElementById("object_edit_type").innerText = "creation";
|
||||
document.getElementById("obj_apply_btn").innerText = "create object";
|
||||
document.getElementById("object_edit_type").innerText = "добавление";
|
||||
document.getElementById("obj_apply_btn").value = "добавить товар";
|
||||
document.getElementById("obj_apply_btn").setAttribute("onclick","create_obj()");
|
||||
}else {
|
||||
document.getElementById("object_edit_type").innerText = "edit";
|
||||
document.getElementById("obj_apply_btn").innerText = "save edited object";
|
||||
document.getElementById("object_edit_type").innerText = "редактирование";
|
||||
document.getElementById("obj_apply_btn").value = "сохранить";
|
||||
document.getElementById("obj_apply_btn").setAttribute("onclick","save_edited_obj()");
|
||||
document.getElementById("group_select").selectedIndex = document.getElementById("group_select").options[`obj_group_${gid}`].index;
|
||||
console.log(gid);
|
||||
}
|
||||
|
||||
let img_file = document.getElementById("img_file");
|
||||
@ -103,6 +113,7 @@
|
||||
let height_text = document.getElementById("obj_height_value");
|
||||
let width_slider = document.getElementById("obj_width");
|
||||
let width_text = document.getElementById("obj_width_value");
|
||||
let cost_text = document.getElementById("obj_cost");
|
||||
|
||||
name_div.value = name;
|
||||
img_file.value = null;
|
||||
@ -110,6 +121,7 @@
|
||||
img_prev.style.height = `${height*2}px`;
|
||||
img_prev.style.width = `${width*2}px`;
|
||||
description_div.value = description;
|
||||
cost_text.value = cost;
|
||||
|
||||
height_slider.value = height;
|
||||
width_slider.value = width;
|
||||
@ -133,15 +145,17 @@
|
||||
}
|
||||
}
|
||||
|
||||
function new_obj(name,img,height,width,description,callback){
|
||||
function new_obj(cost,name,img,height,width,description,callback){
|
||||
let select = document.getElementById("group_select");
|
||||
$.post( "/admin/obj/new", { name:name,img:img,desc:description,height:height,width:width,gid:select.options[select.selectedIndex].getAttribute("gid")})
|
||||
.done(function( res ) {
|
||||
// if(res["out"] == "good"){
|
||||
// console.log(res["body"]);
|
||||
// }
|
||||
callback(res);
|
||||
});
|
||||
if(name!=""){
|
||||
$.post( "/admin/objects/new", { cost:cost,name,img:img,desc:description,height:height,width:width,gid:select.options[select.selectedIndex].getAttribute("gid")})
|
||||
.done(function( res ) {
|
||||
// if(res["out"] == "good"){
|
||||
// console.log(res["body"]);
|
||||
// }
|
||||
callback(res);
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
function create_obj(){
|
||||
@ -150,26 +164,29 @@
|
||||
let height = document.getElementById("obj_height").value;
|
||||
let width = document.getElementById("obj_width").value;
|
||||
var img = document.querySelector('#img_prev').src;
|
||||
var cost = document.getElementById("obj_cost").value;
|
||||
name = name.replace(" ","$");
|
||||
if (img != "http://n0rsrv2:3002/admin"){
|
||||
document.getElementById("obj_resp").innerHTML = "creating object";
|
||||
new_obj(name,img,height,width,description,(res)=>{
|
||||
if(res["out"] == "bad" && res["err"] == "name"){
|
||||
document.getElementById("obj_resp").innerHTML = "object already exist";
|
||||
}
|
||||
else if(res["out"] == "good"){
|
||||
document.getElementById("obj_resp").innerHTML = "object created";
|
||||
setTimeout(()=>{
|
||||
edit_get_objs();
|
||||
},1000)
|
||||
setTimeout(()=>{
|
||||
document.getElementById("obj_resp").innerHTML = "";
|
||||
},3000)
|
||||
}
|
||||
});
|
||||
}
|
||||
else{
|
||||
document.getElementById("obj_resp").innerHTML = "image not selected";
|
||||
if(name != ""){
|
||||
if (img != "http://n0rsrv2:3002/admin"){
|
||||
document.getElementById("obj_resp").innerHTML = "добавление товара";
|
||||
new_obj(cost,name,img,height,width,description,(res)=>{
|
||||
if(res["out"] == "bad" && res["err"] == "name"){
|
||||
document.getElementById("obj_resp").innerHTML = "товар уже существует";
|
||||
}
|
||||
else if(res["out"] == "good"){
|
||||
document.getElementById("obj_resp").innerHTML = "товар добавлен";
|
||||
setTimeout(()=>{
|
||||
edit_get_objs();
|
||||
},1000)
|
||||
setTimeout(()=>{
|
||||
document.getElementById("obj_resp").innerHTML = "";
|
||||
},3000)
|
||||
}
|
||||
});
|
||||
}
|
||||
else{
|
||||
document.getElementById("obj_resp").innerHTML = "картинка не выбрана";
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
@ -3,29 +3,44 @@
|
||||
background-color: #bfe4ff;
|
||||
border: dashed 4px transparent;
|
||||
border-radius: 4px;
|
||||
height: 50px;
|
||||
width: 50px;
|
||||
height: 55px;
|
||||
width: 55px;
|
||||
margin: 5px;
|
||||
margin-top: 0px;
|
||||
margin-bottom: 20px;
|
||||
}
|
||||
img{
|
||||
width: 100%;
|
||||
height: 100%;
|
||||
object-fit: contain;
|
||||
pointer-events: none;
|
||||
}
|
||||
#objs_in_group{
|
||||
#objs_in_group,#founded_objs_list{
|
||||
display: flex;
|
||||
flex-wrap: wrap;
|
||||
padding: 0px;
|
||||
}
|
||||
#find_obj_btns{
|
||||
/* display: flex; */
|
||||
margin: auto 0px;
|
||||
/* height: 25px; */
|
||||
}
|
||||
</style>
|
||||
|
||||
<h1>object edit</h1>
|
||||
<div style="display: flex;justify-content: space-between;">
|
||||
<h1>изменение объектов</h1>
|
||||
<div id="find_obj_btns">
|
||||
<button onclick="load_groups(()=>{edit_get_objs(true);});">найти по имени</button>
|
||||
<button onclick="load_groups(()=>{edit_get_objs();});">очистить</button>
|
||||
</div>
|
||||
</div>
|
||||
<div>
|
||||
<div id="objs_in_group"></div>
|
||||
</div>
|
||||
|
||||
<div class="cmenu" id="object_edit_menu">
|
||||
<button onclick="obj_del()">del object</button>
|
||||
<button onclick="set_edit()">edit object</button>
|
||||
<button onclick="obj_del()">удалить объект</button>
|
||||
<button onclick="set_edit()">редактирование объекта</button>
|
||||
</div>
|
||||
|
||||
<script>
|
||||
@ -35,42 +50,28 @@
|
||||
|
||||
function set_edit(){
|
||||
let menu = document.getElementById("object_edit_menu");
|
||||
set_obj_edit_params(menu.getAttribute("obj_img"),menu.getAttribute("obj_name").split("/")[0],menu.getAttribute("obj_description"),menu.getAttribute("obj_height"),menu.getAttribute("obj_width"));
|
||||
set_obj_edit_params(menu.getAttribute("obj_img"),menu.getAttribute("obj_name").split("/")[0],menu.getAttribute("obj_description"),menu.getAttribute("obj_height"),menu.getAttribute("obj_width"),menu.getAttribute("obj_cost"),menu.getAttribute("obj_gid"));
|
||||
}
|
||||
|
||||
function edit_get_objs(){
|
||||
function edit_get_objs(by_name){
|
||||
document.getElementById("objs_in_group").innerHTML = "";
|
||||
set_obj_edit_params();
|
||||
edit_load_objs((data)=>{
|
||||
data.forEach(value => {
|
||||
// console.log(value);
|
||||
// // console.log($.cookie("cache"));
|
||||
edit_load_obj(value["name"],"`img`",(odata)=>{
|
||||
make(odata["img"]);
|
||||
})
|
||||
function make(img){
|
||||
let obj_list = document.getElementById("objs_in_group");
|
||||
let obj = document.createElement('div');
|
||||
obj.id = "object_menu";
|
||||
obj.classList.add(value["name"]);
|
||||
obj.classList.add("object");
|
||||
obj.setAttribute("name",value["name"])
|
||||
obj.setAttribute("description",value["description"])
|
||||
obj.setAttribute("src",img)
|
||||
obj.setAttribute("height",value["height"])
|
||||
obj.setAttribute("width",value["width"])
|
||||
obj.setAttribute("obj_id",value["id"])
|
||||
obj.innerHTML = `<img src="${img}">`
|
||||
obj_list.append(obj)
|
||||
}
|
||||
make_obj(odata["img"],value,"objs_in_group");
|
||||
})
|
||||
});
|
||||
})
|
||||
},by_name)
|
||||
}
|
||||
|
||||
function obj_del(){
|
||||
let select = document.getElementById("group_select");
|
||||
let menu = document.getElementById("object_edit_menu");
|
||||
if (confirm(`are you sure you want to delete object ${menu.getAttribute("obj_name").split("/")[0]}`)){
|
||||
$.post( "/admin/obj/del", { id:menu.getAttribute(`obj_id`),gid:select.options[select.selectedIndex].getAttribute("gid"),name:menu.getAttribute("obj_name")})
|
||||
if (confirm(`вы точно хотите удалить ${menu.getAttribute("obj_name").split("/")[0]}?`)){
|
||||
$.post( "/admin/objects/delete", { id:menu.getAttribute(`obj_id`),gid:select.options[select.selectedIndex].getAttribute("gid"),name:menu.getAttribute("obj_name")})
|
||||
.done(function( res ) {
|
||||
if(res["out"] == "good"){
|
||||
edit_get_objs();
|
||||
@ -82,13 +83,14 @@
|
||||
function save_edited_obj(){
|
||||
let select = document.getElementById("group_select");
|
||||
let menu = document.getElementById("object_edit_menu");
|
||||
let attributes = ["name","description","img","height","width"];
|
||||
let attributes = ["name","description","img","height","width","cost"];
|
||||
let cur_atts = {
|
||||
name : document.getElementById("nobj_name").value,
|
||||
description : document.getElementById("nobj_description").value,
|
||||
height : document.getElementById("obj_height").value,
|
||||
width : document.getElementById("obj_width").value,
|
||||
img : document.querySelector('#img_prev').src
|
||||
img : document.querySelector('#img_prev').src,
|
||||
cost : document.getElementById("obj_cost").value
|
||||
}
|
||||
let changes = {}
|
||||
attributes.forEach(element => {
|
||||
@ -102,6 +104,7 @@
|
||||
// console.log(changes);
|
||||
if(Object.keys(changes).length > 0){
|
||||
make_obj_save(changes);
|
||||
// console.log(changes);
|
||||
}
|
||||
}
|
||||
});
|
||||
@ -115,17 +118,17 @@
|
||||
}
|
||||
function make_obj_save(){
|
||||
if(changes["name"]) changes["name"] = (changes["name"]+"/g/"+select.options[select.selectedIndex].value).replace(" ","$");
|
||||
document.getElementById("obj_resp").innerHTML = "saving object";
|
||||
$.post( "/admin/obj/edit", { id:menu.getAttribute(`obj_id`),changes:JSON.stringify(changes),gid:select.options[select.selectedIndex].getAttribute("gid")})
|
||||
document.getElementById("obj_resp").innerHTML = "сохранение товара";
|
||||
$.post( "/admin/objects/edit", { id:menu.getAttribute(`obj_id`),changes:JSON.stringify(changes),gid:select.options[select.selectedIndex].getAttribute("gid")})
|
||||
.done(function( res ) {
|
||||
// console.log(res);
|
||||
if(res["out"] == "good"){
|
||||
document.getElementById("obj_resp").innerHTML = "object saved";
|
||||
document.getElementById("obj_resp").innerHTML = "товар сохранён";
|
||||
setTimeout(()=>{
|
||||
edit_get_objs();
|
||||
set_obj_edit_params();
|
||||
if(res["name_err"]){
|
||||
document.getElementById("obj_resp").innerHTML = ("name was not changed because its taken");
|
||||
document.getElementById("obj_resp").innerHTML = ("название товара не было изменино поскольку оно занято");
|
||||
}
|
||||
},1000)
|
||||
setTimeout(()=>{
|
||||
@ -146,18 +149,56 @@
|
||||
});
|
||||
}
|
||||
|
||||
function edit_load_objs(callback){
|
||||
function edit_load_objs(callback,by_name = false){
|
||||
let select = document.getElementById("group_select");
|
||||
$.post( "/get_objs",{gid:select.options[select.selectedIndex].getAttribute("gid")})
|
||||
.done(function( res ) {
|
||||
if(res["out"] == "good"){
|
||||
// console.log(res["body"]);
|
||||
// res["body"].forEach(object => {
|
||||
// // objs_store[`${element["name"]}`] = {description:element["description"],height:element["height"],width:element["width"],id:element["id"],name:element["name"]}
|
||||
// let obj_main = document.createElement("div");
|
||||
// });
|
||||
callback(res["body"]);
|
||||
}
|
||||
});
|
||||
if(!by_name){
|
||||
$.post( "/get_objs",{gid:select.options[select.selectedIndex].getAttribute("gid")})
|
||||
.done(function( res ) {
|
||||
if(res["out"] == "good"){
|
||||
// console.log(res["body"]);
|
||||
// res["body"].forEach(object => {
|
||||
// // objs_store[`${element["name"]}`] = {description:element["description"],height:element["height"],width:element["width"],id:element["id"],name:element["name"]}
|
||||
// let obj_main = document.createElement("div");
|
||||
// });
|
||||
callback(res["body"]);
|
||||
}
|
||||
});
|
||||
}
|
||||
else{
|
||||
let name = ask("название");
|
||||
if(name != "")[
|
||||
$.post( "/admin/objects/find", { name:name.replace(" ","$")})
|
||||
.done(function( res ) {
|
||||
if(res["out"] == "good"){
|
||||
// console.log(res["body"]);
|
||||
callback(res["body"])
|
||||
}
|
||||
})
|
||||
]
|
||||
}
|
||||
}
|
||||
|
||||
function make_obj(img,value,list_id){
|
||||
let obj_list = document.getElementById(list_id);
|
||||
let obj = document.createElement('div');
|
||||
let name_text = document.createElement('div');
|
||||
let img_elm = document.createElement('img');
|
||||
obj.title = `название:${value["name"].split("/")[0].replace("$"," ")}\nцена:${value["cost"]}\nширена:${value["width"]}\nвысота${value["height"]}\nописание:${value["description"]}`;
|
||||
obj.id = "object_menu";
|
||||
obj.classList.add(value["name"]);
|
||||
obj.classList.add("object");
|
||||
obj.setAttribute("name",value["name"].split("/")[0].replace("$"," "))
|
||||
obj.setAttribute("description",value["description"])
|
||||
obj.setAttribute("src",img)
|
||||
obj.setAttribute("height",value["height"])
|
||||
obj.setAttribute("width",value["width"])
|
||||
obj.setAttribute("obj_id",value["id"])
|
||||
obj.setAttribute("cost",value["cost"])
|
||||
obj.setAttribute("gid",value["gid"])
|
||||
name_text.innerText = value["name"].split("/")[0].replace("$"," ");
|
||||
img_elm.src = img;
|
||||
obj.append(img_elm)
|
||||
obj.append(name_text)
|
||||
obj_list.append(obj)
|
||||
}
|
||||
</script>
|
@ -1,11 +1,17 @@
|
||||
|
||||
<h1>objects group</h1>
|
||||
<style>
|
||||
#obj_group button,#obj_group select{
|
||||
height: 25px;
|
||||
margin: auto 0px;
|
||||
}
|
||||
</style>
|
||||
<div id="obj_group">
|
||||
<div style="display: flex;justify-content: space-between;">
|
||||
<h1>группы товаров</h1>
|
||||
<select name="" id="group_select" onchange="edit_get_objs();"></select>
|
||||
<div style="display: flex;justify-content: space-between;width: 200px;">
|
||||
<button onclick="create_new_group()">create new group</button>
|
||||
<button onclick="delete_group()">delete group</button>
|
||||
<div style="display: flex;justify-content: space-between;width: 220px;">
|
||||
<button onclick="create_new_group()">создать группу</button>
|
||||
<button onclick="delete_group()">удалить группу</button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
@ -15,8 +21,8 @@
|
||||
function delete_group() {
|
||||
let select = document.getElementById("group_select");
|
||||
let group_id = select.options[select.selectedIndex].getAttribute("gid");
|
||||
if(confirm(`are you sure you want to delete group ${select.options[select.selectedIndex].text}`) == true){
|
||||
$.post( "/admin/delete/group", { gid:group_id})
|
||||
if(confirm(`вы уверены вы хотите удалить группу ${select.options[select.selectedIndex].text}`) == true){
|
||||
$.post( "/admin/groups/delete", { gid:group_id})
|
||||
.done(function( res ) {
|
||||
if(res["out"] == "good"){
|
||||
// console.log(res["body"]);
|
||||
@ -27,9 +33,9 @@
|
||||
}
|
||||
}
|
||||
function create_new_group() {
|
||||
let group_name = ask("enter group name");
|
||||
let group_name = ask("название группы");
|
||||
if(group_name != ""){
|
||||
$.post( "/admin/new/group", { name:group_name.replace(" ","$")})
|
||||
$.post( "/admin/groups/new", { name:group_name.replace(" ","$")})
|
||||
.done(function( res ) {
|
||||
if(res["out"] == "good"){
|
||||
// console.log(res["body"]);
|
||||
|
@ -7,7 +7,7 @@
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
text-align: center;
|
||||
margin: 20px auto;
|
||||
margin: 0px auto;
|
||||
padding: 10px;
|
||||
background-color:cornsilk;
|
||||
}
|
||||
@ -27,20 +27,30 @@
|
||||
list-style: none;
|
||||
height: 320px;
|
||||
}
|
||||
#find_user_btns{
|
||||
/* display: flex; */
|
||||
margin: auto 0px;
|
||||
/* height: 25px; */
|
||||
}
|
||||
</style>
|
||||
|
||||
<h1><%=lang("users")%></h1>
|
||||
<div style="display: flex;justify-content: space-between;">
|
||||
<h1>пользователи</h1>
|
||||
<div id="find_user_btns">
|
||||
<button onclick="load_users_data(users_from,true);">найти по имени</button>
|
||||
<button onclick="load_users_data(users_from)">очистить</button>
|
||||
</div>
|
||||
</div>
|
||||
<section id="users_section">
|
||||
<div style="display: flex;justify-content: space-between;margin: auto;">
|
||||
<div style="display: flex;"><h1><%= lang("total") %>: </h1> <h1 id="users_count">0</h1></div>
|
||||
<div style="display: flex;margin: auto 0px;"><%=lang("from")%> <div id="users_from">0</div> <%=lang("to")%> <div id="users_to">10</div></div>
|
||||
<div style="margin: auto 0px;"><button onclick="if(users_from-load_interval>=0){users_from-=load_interval;load_users_data(users_from);}">< 10 <%= lang("back") %></button></div>
|
||||
<div style="margin: auto 0px;"><button onclick="users_from+=load_interval;load_users_data(users_from);"><%= lang("next") %> 10 ></button></div>
|
||||
<div style="display: flex;"><h1>всего: </h1> <h1 id="users_count">0</h1></div>
|
||||
<div style="display: flex;margin: auto 0px;">с <div id="users_from">0</div> по <div id="users_to">10</div></div>
|
||||
<div style="margin: auto 0px;"><button onclick="if(users_from-load_interval>=0){users_from-=load_interval;load_users_data(users_from);}">< 10 назад</button></div>
|
||||
<div style="margin: auto 0px;"><button onclick="users_from+=load_interval;load_users_data(users_from);">даллее ></button></div>
|
||||
</div>
|
||||
<div>
|
||||
<li id="first_user"><div><%= lang("login") %></div><div><%= lang("privileges") %></div><div><%= lang("edit") %></div></li>
|
||||
<ul id="user_list">
|
||||
</ul>
|
||||
<li id="first_user"><div>логин</div><div>превилегии</div><div>функции</div></li>
|
||||
<ul id="user_list"></ul>
|
||||
</div>
|
||||
</section>
|
||||
|
||||
@ -49,54 +59,53 @@
|
||||
let users_from = 0;
|
||||
let load_interval = 5;
|
||||
load_users_data(users_from);
|
||||
function load_users_data(from,to){
|
||||
function load_users_data(from,by_name=false){
|
||||
// if(to == "forward") {users_from+=load_interval;}
|
||||
// else if(to == "back") {users_from-=load_interval;}
|
||||
document.getElementById("user_list").innerHTML = "";
|
||||
document.getElementById("users_from").innerText = from;
|
||||
document.getElementById("users_to").innerText = from+load_interval;
|
||||
$.post( "/admin/users/get",{from:from,load_interval:load_interval})
|
||||
.done(function( res ) {
|
||||
// console.log("serv reg");
|
||||
if(res["out"] == "good"){
|
||||
// console.log(res["body"]);
|
||||
document.getElementById("users_count").innerText = res["count"];
|
||||
res["body"].forEach(user => {
|
||||
let user_sec = document.createElement("li");
|
||||
user_sec.id = `user_${user["id"]}`;
|
||||
|
||||
let user_name = document.createElement("div");
|
||||
user_name.id = `login_${user["id"]}`;
|
||||
user_name.innerText = user["login"];
|
||||
|
||||
let user_pass = document.createElement("div");
|
||||
user_pass.id = `pass_${user["id"]}`;
|
||||
user_pass.innerText = user["pass"];
|
||||
user_pass.style.display = "none";
|
||||
|
||||
let user_prevs = document.createElement("div");
|
||||
user_prevs.id = `admin_${user["id"]}`;
|
||||
user_prevs.innerText = Boolean(user["admin"]);
|
||||
|
||||
let user_buttons = document.createElement("button");
|
||||
user_buttons.id = "user_buttons";
|
||||
user_buttons.innerText = "<%=lang('edit')%>";
|
||||
user_buttons.classList.add(user["id"]);
|
||||
user_buttons.classList.add("menu_btn");
|
||||
|
||||
user_sec.append(user_pass);
|
||||
user_sec.append(user_name);
|
||||
user_sec.append(user_prevs);
|
||||
user_sec.append(user_buttons);
|
||||
|
||||
document.getElementById("user_list").append(user_sec);
|
||||
if(!by_name){
|
||||
$.post( "/admin/users/get",{from:from,load_interval:load_interval})
|
||||
.done(function( res ) {
|
||||
if(res["out"] == "good"){
|
||||
document.getElementById("users_count").innerText = res["count"];
|
||||
res["body"].forEach(user => {
|
||||
let user_sec = document.createElement("li");user_sec.id = `user_${user["id"]}`;
|
||||
let user_name = document.createElement("div");user_name.id = `login_${user["id"]}`;user_name.innerText = user["login"];
|
||||
let user_pass = document.createElement("div");user_pass.id = `pass_${user["id"]}`;user_pass.innerText = user["pass"];user_pass.style.display = "none";
|
||||
let user_prevs = document.createElement("div");user_prevs.id = `admin_${user["id"]}`;user_prevs.innerText = Boolean(user["admin"]);
|
||||
let user_buttons = document.createElement("button");user_buttons.id = "user_buttons"; user_buttons.innerText = "изменить"; user_buttons.classList.add(user["id"]); user_buttons.classList.add("menu_btn");
|
||||
|
||||
user_sec.append(user_pass);user_sec.append(user_name);user_sec.append(user_prevs);user_sec.append(user_buttons);
|
||||
document.getElementById("user_list").append(user_sec);
|
||||
});
|
||||
}
|
||||
else if (res["out"] == "bad"){
|
||||
|
||||
}
|
||||
});
|
||||
}
|
||||
else{
|
||||
let login = ask("имя");
|
||||
if (login != ""){
|
||||
$.post( "/admin/users/find",{login:login,from:from,load_interval:load_interval})
|
||||
.done(function( res ) {
|
||||
if(res["out"] == "good"){
|
||||
res["body"].forEach(user => {
|
||||
let user_sec = document.createElement("li");user_sec.id = `user_${user["id"]}`;
|
||||
let user_name = document.createElement("div");user_name.id = `login_${user["id"]}`;user_name.innerText = user["login"];
|
||||
let user_pass = document.createElement("div");user_pass.id = `pass_${user["id"]}`;user_pass.innerText = user["pass"];user_pass.style.display = "none";
|
||||
let user_prevs = document.createElement("div");user_prevs.id = `admin_${user["id"]}`;user_prevs.innerText = Boolean(user["admin"]);
|
||||
let user_buttons = document.createElement("button");user_buttons.id = "user_buttons"; user_buttons.innerText = "изменить"; user_buttons.classList.add(user["id"]); user_buttons.classList.add("menu_btn");
|
||||
|
||||
user_sec.append(user_pass);user_sec.append(user_name);user_sec.append(user_prevs);user_sec.append(user_buttons);
|
||||
document.getElementById("user_list").append(user_sec);
|
||||
});
|
||||
}
|
||||
});
|
||||
// document.getElementById("reg_response").innerHTML = `user ${login} successfully registered `;
|
||||
}
|
||||
else if (res["out"] == "bad"){
|
||||
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
function user_edit(key){
|
||||
let user = document.getElementById("user_edit_menu");
|
||||
@ -107,7 +116,7 @@
|
||||
let value = null;
|
||||
|
||||
if(key!="admin") {value = ask(key,document.getElementById(`${key}_${id}`).innerText)}
|
||||
else if (confirm(`<%=lang('are you sure you want to change')%> <%=lang('admin privileges')%> <%=lang('for')%> ${login} <%=lang("to the")%> ${!admin}?`) == true){value = (!admin)};
|
||||
else if (confirm(`вы точно хотите изменить привелегии пользователя ${login} на ${!admin}?`) == true){value = (!admin)};
|
||||
if(value != null){
|
||||
$.post( "/admin/users/edit",{key:key,value:value,id:id,login:login})
|
||||
.done(function( res ) {
|
||||
@ -125,8 +134,8 @@
|
||||
let user = document.getElementById("user_edit_menu");
|
||||
let id = user.getAttribute("login_id");
|
||||
let login = user.getAttribute("login_name");
|
||||
if(confirm(`<%= lang("are you sure you want to delete user") %> ${login}?`) == true){
|
||||
$.post( "/admin/users/del/user",{login:login,id:id})
|
||||
if(confirm(`вы точно хотите удалить пользователя ${login}?`) == true){
|
||||
$.post( "/admin/users/delete",{login:login,id:id})
|
||||
.done(function( res ) {
|
||||
if(res["out"] == "good"){
|
||||
load_users_data(users_from);
|
||||
@ -135,29 +144,10 @@
|
||||
}
|
||||
}
|
||||
|
||||
let user_edit_menu = document.createElement("div");
|
||||
user_edit_menu.id = "user_edit_menu";
|
||||
user_edit_menu.classList.add("cmenu");
|
||||
|
||||
let user_chenge_name = document.createElement("button");
|
||||
user_chenge_name.innerHTML = "<%= lang('change login') %>";
|
||||
user_chenge_name.setAttribute("onclick","user_edit('login')");
|
||||
|
||||
let user_chenge_pass = document.createElement("button");
|
||||
user_chenge_pass.innerHTML = "<%= lang('change password') %>";
|
||||
user_chenge_pass.setAttribute("onclick","user_edit('pass')");
|
||||
|
||||
let user_chenge_prevs = document.createElement("button");
|
||||
user_chenge_prevs.innerHTML = "<%= lang('change privileges') %>";
|
||||
user_chenge_prevs.setAttribute("onclick","user_edit('admin')");
|
||||
|
||||
let user_delete = document.createElement("button");
|
||||
user_delete.innerHTML = "<%= lang('delete user') %>";
|
||||
user_delete.setAttribute("onclick","user_del()");
|
||||
|
||||
user_edit_menu.append(user_chenge_name);
|
||||
user_edit_menu.append(user_chenge_pass);
|
||||
user_edit_menu.append(user_chenge_prevs);
|
||||
user_edit_menu.append(user_delete);
|
||||
document.body.append(user_edit_menu);
|
||||
let user_edit_menu = document.createElement("div");user_edit_menu.id = "user_edit_menu"; user_edit_menu.classList.add("cmenu");
|
||||
let user_chenge_name = document.createElement("button");user_chenge_name.innerHTML = "именить логин"; user_chenge_name.setAttribute("onclick","user_edit('login')");
|
||||
let user_chenge_pass = document.createElement("button");user_chenge_pass.innerHTML = "изменить пароль"; user_chenge_pass.setAttribute("onclick","user_edit('pass')");
|
||||
let user_chenge_prevs = document.createElement("button");user_chenge_prevs.innerHTML = "сменить привелегии";user_chenge_prevs.setAttribute("onclick","user_edit('admin')");
|
||||
let user_delete = document.createElement("button");user_delete.innerHTML = "удалить пользователя";user_delete.setAttribute("onclick","user_del()");
|
||||
user_edit_menu.append(user_chenge_name);user_edit_menu.append(user_chenge_pass);user_edit_menu.append(user_chenge_prevs);user_edit_menu.append(user_delete);document.body.append(user_edit_menu);
|
||||
</script>
|
||||
|
@ -1,23 +1,23 @@
|
||||
<style>
|
||||
.main_sec{
|
||||
.user_reg_form{
|
||||
margin: auto;
|
||||
/* display: flex; */
|
||||
text-align: center;
|
||||
}
|
||||
</style>
|
||||
<h1><%= lang("user registration") %></h1>
|
||||
<div class="main_sec">
|
||||
<h1>регистрация пользователя</h1>
|
||||
<form action="#" class="user_reg_form">
|
||||
<div>
|
||||
<input type="text" id="login" name="login" value="" placeholder="<%= lang("login") %>">
|
||||
<input type="password" id="pass" name="pass" value="" placeholder="<%= lang("password") %>">
|
||||
<button onclick='reg();'><%= lang("register") %></button>
|
||||
<input type="text" id="login" name="login" value="" placeholder="логин">
|
||||
<input type="password" id="pass" name="pass" value="" placeholder="пароль">
|
||||
<input type="submit" onclick='reg();' value="зарегистрировать">
|
||||
</div>
|
||||
<div>
|
||||
<label for="admin_check"><%= lang("admin") %></label>
|
||||
<label for="admin_check">админ. привелегии</label>
|
||||
<input type="checkbox" name="admin" value='false' id="admin_check">
|
||||
</div>
|
||||
<div id="reg_response"></div>
|
||||
</div>
|
||||
</form>
|
||||
|
||||
<script>
|
||||
function reg(){
|
||||
@ -27,18 +27,20 @@
|
||||
let admin = document.getElementById("admin_check").checked;
|
||||
// console.log(login,pass,admin);
|
||||
// console.log("cl reg");
|
||||
$.post( "/admin/users/reg", { login:login,pass:pass,admin:admin })
|
||||
.done(function( res ) {
|
||||
// console.log("serv reg");
|
||||
if(res["out"] == "good"){
|
||||
// console.log(res["body"]);
|
||||
document.getElementById("reg_response").innerHTML = `user ${login} successfully registered `;
|
||||
load_users_data(users_from);
|
||||
if(login != ""&&pass!=""){
|
||||
$.post( "/admin/users/new", { login:login,pass:pass,admin:admin })
|
||||
.done(function( res ) {
|
||||
// console.log("serv reg");
|
||||
if(res["out"] == "good"){
|
||||
// console.log(res["body"]);
|
||||
document.getElementById("reg_response").innerHTML = `user ${login} successfully registered `;
|
||||
load_users_data(users_from);
|
||||
|
||||
}
|
||||
else if (res["out"] == "bad"){
|
||||
document.getElementById("reg_response").innerHTML = "cannot register user "+login+" already in use";
|
||||
}
|
||||
});
|
||||
}
|
||||
else if (res["out"] == "bad"){
|
||||
document.getElementById("reg_response").innerHTML = "cannot register user "+login+" already in use";
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
</script>
|
Reference in New Issue
Block a user