update
added: db users admin user edit cleared router cleared sql new sid creation new log creation cleaned code (a bit) ( removed db check value function and replaced with get one value.
This commit is contained in:
172
views/admin.ejs
172
views/admin.ejs
@ -1,92 +1,21 @@
|
||||
<!DOCTYPE html>
|
||||
<style>
|
||||
.nobj{
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
margin: auto;
|
||||
/* margin-bottom: 50px; */
|
||||
}
|
||||
#img_file{
|
||||
text-overflow:ellipsis;
|
||||
max-width:100px;
|
||||
}
|
||||
.img_preview{
|
||||
/* width: 50px;
|
||||
height: 20px; */
|
||||
display: flex;
|
||||
}
|
||||
#img_prev{
|
||||
height: 200px;
|
||||
width: 200px;
|
||||
}
|
||||
.main_sec{
|
||||
margin: auto;
|
||||
/* display: flex; */
|
||||
text-align: center;
|
||||
}
|
||||
section{
|
||||
width: 80vw;
|
||||
margin: auto;
|
||||
}
|
||||
</style>
|
||||
|
||||
<%- include('./static/start.ejs',{name:"admin",async: true}) %>
|
||||
<%- include('./header.ejs') %>
|
||||
|
||||
<h1 style="text-align: center;"><%= lang("hello admin") %></h1> <br>
|
||||
<section>
|
||||
<h1><%= lang("create new object") %></h1>
|
||||
<div class="nobj">
|
||||
<div>
|
||||
<div class="img_preview">
|
||||
<label for="img_file"><%= lang("img max size") %></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') %>">
|
||||
</div>
|
||||
</div>
|
||||
<textarea id="nobj_description" cols="30" rows="5" placeholder="<%= lang("object description") %>"></textarea>
|
||||
<div>
|
||||
<div class="nobj_options">
|
||||
<input type="text" id="nobj_name" placeholder="<%= lang("object name") %>">
|
||||
<button onclick="create_obj()"><%= lang("create object")%></button>
|
||||
<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>
|
||||
<div id="obj_height_value">100см</div>
|
||||
</div>
|
||||
<input style="width: 100%;" type="range" step="0.5" 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>
|
||||
<div id="obj_width_value">100см</div>
|
||||
</div>
|
||||
<input style="width: 100%;" type="range" step="0.5" min="1" max="100" id="obj_width" value="100" oninput="obj_size_change('width')">
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<%- include('./admin/objects/object_creation.ejs') %>
|
||||
</section>
|
||||
|
||||
<section>
|
||||
<h1><%= lang("user registration") %></h1>
|
||||
<div class="main_sec">
|
||||
<div>
|
||||
<input type="text" id="login" name="login" placeholder="<%= lang("login") %>">
|
||||
<input type="password" id="pass" name="pass" placeholder="<%= lang("password") %>">
|
||||
<button onclick='reg();'><%= lang("register") %></button>
|
||||
</div>
|
||||
<div>
|
||||
<label for="admin_check"><%= lang("admin") %></label>
|
||||
<input type="checkbox" name="admin" value='false' id="admin_check">
|
||||
</div>
|
||||
<div id="reg_response"></div>
|
||||
</div>
|
||||
<%- include('./admin/users/user_reg.ejs') %>
|
||||
<%- include('./admin/users/user_edit.ejs') %>
|
||||
</section>
|
||||
|
||||
<section style="display: flex; justify-content: space-between;">
|
||||
@ -96,95 +25,4 @@
|
||||
</div>
|
||||
</section>
|
||||
|
||||
<%- include('./static/end.ejs') %>
|
||||
|
||||
|
||||
<script>
|
||||
function reg(){
|
||||
console.log("reg");
|
||||
let login = document.getElementById("login").value;
|
||||
let pass = document.getElementById("pass").value;
|
||||
let admin = document.getElementById("admin_check").checked;
|
||||
// console.log(login,pass,admin);
|
||||
// console.log("cl reg");
|
||||
$.post( "/reg_user", { 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 `;
|
||||
}
|
||||
else if (res["out"] == "bad"){
|
||||
document.getElementById("reg_response").innerHTML = "cannot register user "+login+" already in use";
|
||||
}
|
||||
});
|
||||
}
|
||||
</script>
|
||||
|
||||
<script>
|
||||
function obj_size_change(type){
|
||||
if(type == "height"){
|
||||
let img = document.getElementById('img_prev');
|
||||
let range = document.getElementById('obj_height');
|
||||
let text = document.getElementById('obj_height_value');
|
||||
img.style.height = `${range.value * 2}px`;
|
||||
text.innerHTML = `${range.value}см`;
|
||||
}else if (type == "width"){
|
||||
let img = document.getElementById('img_prev');
|
||||
let range = document.getElementById('obj_width');
|
||||
let text = document.getElementById('obj_width_value');
|
||||
img.style.width = `${range.value * 2}px`;
|
||||
text.innerHTML = `${range.value}см`;
|
||||
|
||||
}
|
||||
}
|
||||
function previewFile() {
|
||||
var preview = document.querySelector('img');
|
||||
var file = document.querySelector('input[type=file]').files[0];
|
||||
var reader = new FileReader();
|
||||
|
||||
reader.onloadend = function () {
|
||||
preview.src = reader.result;
|
||||
}
|
||||
|
||||
if (file) {
|
||||
reader.readAsDataURL(file);
|
||||
} else {
|
||||
preview.src = "";
|
||||
}
|
||||
}
|
||||
|
||||
function new_obj(name,img,height,width,description,callback){
|
||||
$.post( "/new_obj", { name:name,img:img,desc:description,height:height,width:width })
|
||||
.done(function( res ) {
|
||||
// if(res["out"] == "good"){
|
||||
// console.log(res["body"]);
|
||||
// }
|
||||
callback(res);
|
||||
});
|
||||
}
|
||||
|
||||
function create_obj(){
|
||||
let name = document.getElementById("nobj_name").value;
|
||||
let description = document.getElementById("nobj_description").value;
|
||||
let height = document.getElementById("obj_height").value;
|
||||
let width = document.getElementById("obj_width").value;
|
||||
var img = document.querySelector('img').src;
|
||||
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";
|
||||
}
|
||||
});
|
||||
}
|
||||
else{
|
||||
document.getElementById("obj_resp").innerHTML = "image not selected";
|
||||
}
|
||||
}
|
||||
|
||||
</script>
|
||||
<%- include('./static/end.ejs') %>
|
127
views/admin/objects/object_creation.ejs
Normal file
127
views/admin/objects/object_creation.ejs
Normal file
@ -0,0 +1,127 @@
|
||||
|
||||
<style>
|
||||
.nobj{
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
margin: auto;
|
||||
/* margin-bottom: 50px; */
|
||||
}
|
||||
#img_file{
|
||||
text-overflow:ellipsis;
|
||||
max-width:100px;
|
||||
}
|
||||
.img_preview{
|
||||
/* width: 50px;
|
||||
height: 20px; */
|
||||
display: flex;
|
||||
}
|
||||
#img_prev{
|
||||
height: 200px;
|
||||
width: 200px;
|
||||
}
|
||||
</style>
|
||||
|
||||
<h1><%= lang("create new object") %></h1>
|
||||
<div class="nobj">
|
||||
<div>
|
||||
<div class="img_preview">
|
||||
<label for="img_file"><%= lang("img max size") %></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') %>">
|
||||
</div>
|
||||
</div>
|
||||
<textarea id="nobj_description" cols="30" rows="5" placeholder="<%= lang("object description") %>"></textarea>
|
||||
<div>
|
||||
<div class="nobj_options">
|
||||
<input type="text" id="nobj_name" placeholder="<%= lang("object name") %>">
|
||||
<button onclick="create_obj()"><%= lang("create object")%></button>
|
||||
<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>
|
||||
<div id="obj_height_value">100см</div>
|
||||
</div>
|
||||
<input style="width: 100%;" type="range" step="0.5" 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>
|
||||
<div id="obj_width_value">100см</div>
|
||||
</div>
|
||||
<input style="width: 100%;" type="range" step="0.5" min="1" max="100" id="obj_width" value="100" oninput="obj_size_change('width')">
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<script>
|
||||
function obj_size_change(type){
|
||||
if(type == "height"){
|
||||
let img = document.getElementById('img_prev');
|
||||
let range = document.getElementById('obj_height');
|
||||
let text = document.getElementById('obj_height_value');
|
||||
img.style.height = `${range.value * 2}px`;
|
||||
text.innerHTML = `${range.value}см`;
|
||||
}else if (type == "width"){
|
||||
let img = document.getElementById('img_prev');
|
||||
let range = document.getElementById('obj_width');
|
||||
let text = document.getElementById('obj_width_value');
|
||||
img.style.width = `${range.value * 2}px`;
|
||||
text.innerHTML = `${range.value}см`;
|
||||
|
||||
}
|
||||
}
|
||||
function previewFile() {
|
||||
var preview = document.querySelector('img');
|
||||
var file = document.querySelector('input[type=file]').files[0];
|
||||
var reader = new FileReader();
|
||||
|
||||
reader.onloadend = function () {
|
||||
preview.src = reader.result;
|
||||
}
|
||||
|
||||
if (file) {
|
||||
reader.readAsDataURL(file);
|
||||
} else {
|
||||
preview.src = "";
|
||||
}
|
||||
}
|
||||
|
||||
function new_obj(name,img,height,width,description,callback){
|
||||
$.post( "/new_obj", { name:name,img:img,desc:description,height:height,width:width })
|
||||
.done(function( res ) {
|
||||
// if(res["out"] == "good"){
|
||||
// console.log(res["body"]);
|
||||
// }
|
||||
callback(res);
|
||||
});
|
||||
}
|
||||
|
||||
function create_obj(){
|
||||
let name = document.getElementById("nobj_name").value;
|
||||
let description = document.getElementById("nobj_description").value;
|
||||
let height = document.getElementById("obj_height").value;
|
||||
let width = document.getElementById("obj_width").value;
|
||||
var img = document.querySelector('img').src;
|
||||
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";
|
||||
}
|
||||
});
|
||||
}
|
||||
else{
|
||||
document.getElementById("obj_resp").innerHTML = "image not selected";
|
||||
}
|
||||
}
|
||||
</script>
|
0
views/admin/objects/object_edit.ejs
Normal file
0
views/admin/objects/object_edit.ejs
Normal file
163
views/admin/users/user_edit.ejs
Normal file
163
views/admin/users/user_edit.ejs
Normal file
@ -0,0 +1,163 @@
|
||||
<style>
|
||||
#users_section{
|
||||
width: 80vw;
|
||||
margin: auto;
|
||||
}
|
||||
#users_section li{
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
text-align: center;
|
||||
margin: 20px auto;
|
||||
padding: 10px;
|
||||
background-color:cornsilk;
|
||||
}
|
||||
#users_section li div:not(#first_user div){
|
||||
/* margin: auto; */
|
||||
width: 100px;
|
||||
text-align: center;
|
||||
}
|
||||
#first_user div{
|
||||
/* text-align: center; */
|
||||
width: 100px;
|
||||
text-align: center;
|
||||
}
|
||||
#users_section ul{
|
||||
padding: 0px;
|
||||
margin: 0px;
|
||||
list-style: none;
|
||||
height: 320px;
|
||||
}
|
||||
</style>
|
||||
|
||||
<h1><%=lang("users")%></h1>
|
||||
<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>
|
||||
<div>
|
||||
<li id="first_user"><div><%= lang("login") %></div><div><%= lang("privileges") %></div><div><%= lang("edit") %></div></li>
|
||||
<ul id="user_list">
|
||||
</ul>
|
||||
</div>
|
||||
</section>
|
||||
|
||||
|
||||
<script>
|
||||
let users_from = 0;
|
||||
let load_interval = 5;
|
||||
load_users_data(users_from);
|
||||
function load_users_data(from,to){
|
||||
// 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);
|
||||
});
|
||||
// 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");
|
||||
let id = user.getAttribute("login_id");
|
||||
let login = user.getAttribute("login_name");
|
||||
let admin = JSON.parse(user.getAttribute("login_admin"));
|
||||
let pass= user.getAttribute("login_pass");
|
||||
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)};
|
||||
if(value != null){
|
||||
$.post( "/admin/users/edit",{key:key,value:value,id:id,login:login})
|
||||
.done(function( res ) {
|
||||
// console.log("serv reg");
|
||||
if(res["out"] == "good"){
|
||||
document.getElementById(`${key}_${id}`).innerText = value;
|
||||
}
|
||||
if(res["out"] == "bad"){
|
||||
alert("cant change name in use")
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
function user_del(){
|
||||
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})
|
||||
.done(function( res ) {
|
||||
if(res["out"] == "good"){
|
||||
load_users_data(users_from);
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
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);
|
||||
</script>
|
44
views/admin/users/user_reg.ejs
Normal file
44
views/admin/users/user_reg.ejs
Normal file
@ -0,0 +1,44 @@
|
||||
<style>
|
||||
.main_sec{
|
||||
margin: auto;
|
||||
/* display: flex; */
|
||||
text-align: center;
|
||||
}
|
||||
</style>
|
||||
<h1><%= lang("user registration") %></h1>
|
||||
<div class="main_sec">
|
||||
<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>
|
||||
</div>
|
||||
<div>
|
||||
<label for="admin_check"><%= lang("admin") %></label>
|
||||
<input type="checkbox" name="admin" value='false' id="admin_check">
|
||||
</div>
|
||||
<div id="reg_response"></div>
|
||||
</div>
|
||||
|
||||
<script>
|
||||
function reg(){
|
||||
console.log("reg");
|
||||
let login = document.getElementById("login").value;
|
||||
let pass = document.getElementById("pass").value;
|
||||
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);
|
||||
|
||||
}
|
||||
else if (res["out"] == "bad"){
|
||||
document.getElementById("reg_response").innerHTML = "cannot register user "+login+" already in use";
|
||||
}
|
||||
});
|
||||
}
|
||||
</script>
|
106
views/header.ejs
106
views/header.ejs
@ -37,7 +37,7 @@
|
||||
}
|
||||
.cmenu{
|
||||
position: fixed;
|
||||
display: block;
|
||||
display: grid;
|
||||
background: ghostwhite;
|
||||
color: black;
|
||||
cursor: pointer;
|
||||
@ -60,54 +60,70 @@
|
||||
</header>
|
||||
<div id="user_menu" class="cmenu"></div>
|
||||
|
||||
<script>get_from_uuid((res)=>{
|
||||
let uname = document.getElementById("user_name");
|
||||
let menu = document.getElementById("user_menu");
|
||||
let header = document.getElementById("top_panel");
|
||||
let right = document.getElementById("top_panel_right");
|
||||
let left = document.getElementById("top_panel_left");
|
||||
|
||||
if(document.title != "main") menu.innerHTML += `<button onclick="goto('/');"><%= lang("main page") %></button> <br>`;
|
||||
right.innerHTML += `<div id="user_name" class="menu_btn">${res["login"]}</div>`;
|
||||
|
||||
if (res["admin"] == true){
|
||||
menu.innerHTML += `<button onclick='goto("/admin")'><%= lang("admin panel") %></button><br>`;
|
||||
}
|
||||
menu.innerHTML += "<button onclick='logout();'><%= lang('logout') %></button><br>";
|
||||
});
|
||||
|
||||
onclick = (e) => {
|
||||
// e.preventDefault()
|
||||
// console.log(e);
|
||||
// console.log(document.getElementById(e.target.id).parentElement);
|
||||
if(e.target.onclick != null){
|
||||
if(document.title == "login"){
|
||||
// console.log(document.title);
|
||||
log_by_sid();
|
||||
}else if(document.title != "login"){
|
||||
check_sid(true);
|
||||
// console.log("check");
|
||||
<script>
|
||||
get_from_uuid((res)=>{
|
||||
let uname = document.getElementById("user_name");
|
||||
let menu = document.getElementById("user_menu");
|
||||
let header = document.getElementById("top_panel");
|
||||
let right = document.getElementById("top_panel_right");
|
||||
let left = document.getElementById("top_panel_left");
|
||||
|
||||
if(document.title != "main") menu.innerHTML += `<button onclick="goto('/');"><%= lang("main page") %></button> <br>`;
|
||||
right.innerHTML += `<div id="user_name" class="menu_btn">${res["login"]}</div>`;
|
||||
|
||||
if (res["admin"] == true){
|
||||
menu.innerHTML += `<button onclick='goto("/admin")'><%= lang("admin panel") %></button><br>`;
|
||||
}
|
||||
}
|
||||
if(e.target.id == "user_name"){
|
||||
hide_menus();
|
||||
let menu = document.getElementById("user_menu");
|
||||
menu.style.display = 'block';
|
||||
menu.style = `top:${e.target.getBoundingClientRect().top+30}px;left:${e.target.getBoundingClientRect().left}px`
|
||||
// menu.onmouseleave = () => menu.style.display = 'none';
|
||||
// menu.innerHTML = "<p>Option1</p><p>Option2</p><p>Option3</p><p>Option4</p>"
|
||||
// document.body.appendChild(menu)
|
||||
}else if(e.target.id == "proj_menu"){
|
||||
hide_menus();
|
||||
let menu = document.getElementById("project_menu");
|
||||
menu.style.display = 'block';
|
||||
menu.style = `top:${e.target.getBoundingClientRect().top+30}px;left:${e.target.getBoundingClientRect().left}px`
|
||||
menu.innerHTML += "<button onclick='logout();'><%= lang('logout') %></button><br>";
|
||||
});
|
||||
|
||||
onclick = (e) => {
|
||||
// e.preventDefault()
|
||||
// console.log(e);
|
||||
// console.log(document.getElementById(e.target.id).parentElement);
|
||||
// if(e.target.onclick != null){
|
||||
// if(document.title == "login"){
|
||||
// // console.log(document.title);
|
||||
// log_by_sid();
|
||||
// }else if(document.title != "login"){
|
||||
// check_sid(true);
|
||||
// // console.log("check");
|
||||
// }
|
||||
// }
|
||||
if(e.target.id == "user_name"){
|
||||
hide_menus();
|
||||
let menu = document.getElementById("user_menu");
|
||||
menu.style.display = 'block';
|
||||
menu.style = `top:${e.target.getBoundingClientRect().top+30}px;left:${e.target.getBoundingClientRect().left}px`;
|
||||
// menu.onmouseleave = () => menu.style.display = 'none';
|
||||
// menu.innerHTML = "<p>Option1</p><p>Option2</p><p>Option3</p><p>Option4</p>"
|
||||
// document.body.appendChild(menu)
|
||||
}else if(e.target.id == "proj_menu"){
|
||||
hide_menus();
|
||||
let menu = document.getElementById("project_menu");
|
||||
menu.style.display = 'block';
|
||||
menu.style = `top:${e.target.getBoundingClientRect().top+30}px;left:${e.target.getBoundingClientRect().left}px`;
|
||||
// menu.onmouseleave = () => menu.style.display = 'none';
|
||||
// menu.innerHTML = "<p>Option1</p><p>Option2</p><p>Option3</p><p>Option4</p>"
|
||||
// document.body.appendChild(menu)
|
||||
}
|
||||
else if(e.target.id == "user_buttons"){
|
||||
hide_menus();
|
||||
let menu = document.getElementById("user_edit_menu");
|
||||
menu.setAttribute("login_id",e.target.classList[0]);
|
||||
menu.setAttribute("login_name",document.getElementById(`login_${e.target.classList[0]}`).innerText);
|
||||
menu.setAttribute("login_pass",document.getElementById(`pass_${e.target.classList[0]}`).innerText);
|
||||
menu.setAttribute("login_admin",document.getElementById(`admin_${e.target.classList[0]}`).innerText);
|
||||
menu.style.display = 'block';
|
||||
menu.style = `top:${e.target.getBoundingClientRect().top+30}px;left:${e.target.getBoundingClientRect().left-40}px`;
|
||||
// menu.onmouseleave = () => menu.style.display = 'none';
|
||||
// menu.innerHTML = "<p>Option1</p><p>Option2</p><p>Option3</p><p>Option4</p>"
|
||||
// document.body.appendChild(menu)
|
||||
|
||||
}
|
||||
else{
|
||||
hide_menus();
|
||||
}
|
||||
}
|
||||
else{
|
||||
hide_menus();
|
||||
}
|
||||
}
|
||||
</script>
|
@ -1,5 +1,4 @@
|
||||
<%- include('./static/start.ejs',{name:'login',async: true}) %>
|
||||
|
||||
<!DOCTYPE html>
|
||||
<style>
|
||||
* {
|
||||
text-align: center;
|
||||
@ -9,6 +8,8 @@
|
||||
display: none;
|
||||
}
|
||||
</style>
|
||||
<%- include('./static/start.ejs',{name:'login',async: true}) %>
|
||||
|
||||
|
||||
<div class="login-page">
|
||||
<input name="login" type="text" id="login" required>
|
||||
@ -23,8 +24,6 @@
|
||||
<!-- <input type="submit" value="" hidden> -->
|
||||
<div id="res"></div>
|
||||
|
||||
<%- include('./static/end.ejs') %>
|
||||
|
||||
<script>
|
||||
// console.log($.cookie("uuid"));
|
||||
// log_by_sid();
|
||||
@ -62,3 +61,4 @@
|
||||
}
|
||||
});
|
||||
</script>
|
||||
<%- include('./static/end.ejs') %>
|
@ -1,3 +1,4 @@
|
||||
<!DOCTYPE html>
|
||||
<style>
|
||||
.drag{
|
||||
height: 50px;
|
||||
@ -39,9 +40,10 @@
|
||||
border-style: solid;
|
||||
}
|
||||
</style>
|
||||
|
||||
<%- include('./static/start.ejs',{name:'main',async: true}) %>
|
||||
<%- include('./header.ejs') %>
|
||||
|
||||
|
||||
<!-- <script src="/lib/interact.min.js"></script> -->
|
||||
|
||||
<section class="main">
|
||||
@ -50,7 +52,6 @@
|
||||
</section>
|
||||
|
||||
<!-- <script src="/lib/inter.js"></script> -->
|
||||
<%- include('./static/end.ejs') %>
|
||||
|
||||
<script>
|
||||
function load_projs(callback){
|
||||
@ -63,7 +64,7 @@
|
||||
});
|
||||
}
|
||||
function new_proj(){
|
||||
let name = ask();
|
||||
let name = ask("please enter project name");
|
||||
if(name != null && name!= "" && name!=" " && typeof name != "undefined" && name!="undefined"){
|
||||
goto(`/proj/${name}`);
|
||||
}
|
||||
@ -75,4 +76,5 @@
|
||||
div.innerHTML += `<button id='proj_${proj["name"]}' class='proj' onclick="goto('/proj/${proj["name"]}')">${proj["name"]}<br><img height="200" width="290" src='${proj["img"]}' alt='${proj["name"]}'></img></button>`;
|
||||
});
|
||||
});
|
||||
</script>
|
||||
</script>
|
||||
<%- include('./static/end.ejs') %>
|
@ -1,3 +1,7 @@
|
||||
<%- include('./static/start.ejs',{name:proj_name,async:true}) %>
|
||||
<%- include('./header.ejs') %>
|
||||
<script src="/lib/interact.js"></script>
|
||||
<script src="/lib/html2canvas.js"></script>
|
||||
<style>
|
||||
.drag{
|
||||
height: 50px;
|
||||
@ -13,19 +17,25 @@
|
||||
margin: auto;
|
||||
}
|
||||
|
||||
.dropzone {
|
||||
background-color: #bfe4ff;
|
||||
border: dashed 4px transparent;
|
||||
.wall {
|
||||
/* border: dashed 4px transparent; */
|
||||
border-radius: 4px;
|
||||
height: 140px;
|
||||
margin: 10px auto 30px;
|
||||
/* padding: 10px; */
|
||||
width: 80%;
|
||||
transition: background-color 0.3s;
|
||||
position: absolute;
|
||||
inset: 0px;
|
||||
margin: 250px auto;
|
||||
width: 400px;
|
||||
height: 200px;
|
||||
background-color: #fff;
|
||||
background-image: url("/img/bg1red.png");
|
||||
background-size: 200px;
|
||||
background-repeat: repeat;
|
||||
background-position: bottom 0px left 0px;
|
||||
border: 2px solid black;
|
||||
/* overflow: visible; */
|
||||
z-index: 2;
|
||||
}
|
||||
|
||||
.createzone {
|
||||
background-color: #bfe4ff;
|
||||
border: dashed 4px transparent;
|
||||
@ -63,11 +73,11 @@
|
||||
border-color: #aaa;
|
||||
}
|
||||
|
||||
.drop-target {
|
||||
/* .drop-target {
|
||||
background-color: #29e;
|
||||
border-color: #fff;
|
||||
border-style: solid;
|
||||
}
|
||||
} */
|
||||
|
||||
#proj_top{
|
||||
margin: auto;
|
||||
@ -89,32 +99,8 @@
|
||||
padding-bottom: 0px;
|
||||
margin-top: 50px;
|
||||
}
|
||||
|
||||
.wall{
|
||||
/* display: flex; */
|
||||
/* position: relative; */
|
||||
/* margin: 60px auto; */
|
||||
width: 400px;
|
||||
height: 200px;
|
||||
background-color: #fff;
|
||||
background-image: url("/img/bg1red.png");
|
||||
background-size: 200px;
|
||||
background-repeat: repeat;
|
||||
background-position: bottom 0px left 0px;
|
||||
border: 2px solid black;
|
||||
/* overflow: visible; */
|
||||
z-index: 2;
|
||||
}
|
||||
</style>
|
||||
|
||||
<%- include('./static/start.ejs',{name:proj_name,async: true}) %>
|
||||
<%- include('./header.ejs',{async: true}) %>
|
||||
<script src="/lib/interact.js"></script>
|
||||
<script src="/lib/html2canvas.js"></script>
|
||||
|
||||
<div id="drags">
|
||||
<!-- <div class="cube drag spawn" id="cube_0" style="transform: translate(197.7px, 57.8667px);" data-x="197.6999969482422" data-y="57.866668701171875" >cube</div> -->
|
||||
</div>
|
||||
|
||||
<div id="project_menu" class="cmenu"></div>
|
||||
|
||||
@ -128,7 +114,7 @@
|
||||
<label for="wall_height"><%= lang("height") %> </label>
|
||||
<div id="wall_height_value">0</div>
|
||||
</div>
|
||||
<input type="range" step="0.1" min="0" max="5" id="wall_height" value="2" oninput="wall_size_change('height')">
|
||||
<input type="range" step="0.1" min="0" max="5" id="wall_height" value="2" oninput="wall_size_change('height')" onchange="resize_drags()">
|
||||
</div>
|
||||
<div>
|
||||
<div style="display: flex;width: 150px;justify-content: space-between;">
|
||||
@ -142,31 +128,12 @@
|
||||
<img class="trash" style="height: 100px; width: 100px;" src="/img/shadow-energy.gif" alt="<%= lang('black hole') %>">
|
||||
</div>
|
||||
|
||||
<div id="drags"></div>
|
||||
<div class="wall dropzone" id="wall"></div>
|
||||
|
||||
|
||||
<script src="/lib/inter.js"></script>
|
||||
<%- include('./static/end.ejs') %>
|
||||
<script>
|
||||
// function scree(){
|
||||
// // console.log(document.getElementById("wall").style.height.split("p")[0]);
|
||||
// html2canvas(document.querySelector("body"),{height: document.getElementById("wall").style.height.split("p")[0], width:document.getElementById("wall").style.width.split("p")[0], y:255}).then(canvas => {
|
||||
// console.log(canvas.toDataURL().length);
|
||||
// let scr = canvas.toDataURL();
|
||||
// let img = document.createElement("img");
|
||||
// img.src = scr;
|
||||
// document.body.append(img);
|
||||
// // return canvas;
|
||||
// // console.log(scr)
|
||||
// });
|
||||
|
||||
|
||||
|
||||
// // html2canvas(document.querySelector("#drags")).then(canvas => {
|
||||
// // document.body.appendChild(canvas)
|
||||
// // });
|
||||
|
||||
|
||||
// }
|
||||
load_objs((data)=>{
|
||||
data.forEach(value => {
|
||||
// console.log(value);
|
||||
@ -178,8 +145,7 @@
|
||||
});
|
||||
load_proj_cloud();
|
||||
})
|
||||
</script>
|
||||
<script>
|
||||
|
||||
let proj_name = "<%= proj_name %>";
|
||||
if($.cookie("cache") ==null)$.cookie("cache","true",{path:"/proj;SameSite=Strict"});
|
||||
// console.log(proj_name);
|
||||
@ -225,4 +191,5 @@
|
||||
function isZooming(){
|
||||
resize_drags();
|
||||
}
|
||||
</script>
|
||||
</script>
|
||||
<%- include('./static/end.ejs') %>
|
@ -15,16 +15,16 @@ language = {
|
||||
"width": "ширина",
|
||||
"img max size": "макс. размер 2мб",
|
||||
"user registration": "регистрация пользователя",
|
||||
"create object": "создать обьект",
|
||||
"create object": "создать объект",
|
||||
"admin": "админ",
|
||||
"register": "зарегистрировать",
|
||||
"download logs": "скачать логи",
|
||||
"create new object": "создание нового обьекта",
|
||||
"create new object": "создание нового объекта",
|
||||
"logs": "логи",
|
||||
"password": "пароль",
|
||||
"login": "логин",
|
||||
"object name": "название обьекта",
|
||||
"object description": "описание обьекта",
|
||||
"object name": "название объекта",
|
||||
"object description": "описание объекта",
|
||||
"black hole": "чёрная дыра",
|
||||
"project settings": "настройки проекта",
|
||||
"save to cloud": "сохранить в облако",
|
||||
@ -43,8 +43,29 @@ language = {
|
||||
"loading": "загружается",
|
||||
"loaded": "загружено",
|
||||
"from": "из",
|
||||
"to": "в",
|
||||
"in": "в"
|
||||
"in": "в",
|
||||
"edit current / list": "редактирование / просмотр",
|
||||
"users": "пользователи",
|
||||
"objects": "объекты",
|
||||
"back": "назад",
|
||||
"next": "далле",
|
||||
"edit": "радактирование",
|
||||
"name": "имя",
|
||||
"delete user": "удалить пользователя",
|
||||
"change privileges": "изменить привилегии",
|
||||
"change name": "изменить имя",
|
||||
"change login": "изменить логин",
|
||||
"change password": "изменить пароль",
|
||||
"privileges": "привилегии",
|
||||
"from": "от",
|
||||
"to": "до",
|
||||
"for": "для",
|
||||
"to the": "на",
|
||||
"total": "всего",
|
||||
"are you sure you want to change": "вы точно хотите именить",
|
||||
"admin privileges to": "превилегии администратора на",
|
||||
"admin privileges": "превилегии администратора",
|
||||
"are you sure you want to delete user": "вы точно хотите удалить пользователя"
|
||||
},
|
||||
"en":{
|
||||
"main page": "main page",
|
||||
@ -85,8 +106,29 @@ language = {
|
||||
"loading": "loading",
|
||||
"loaded": "loaded",
|
||||
"from": "from",
|
||||
"in": "in",
|
||||
"back": "back",
|
||||
"next": "next",
|
||||
"edit": "edit",
|
||||
"name": "name",
|
||||
"users": "users",
|
||||
"objects": "objects",
|
||||
"delete user": "delete user",
|
||||
"change privileges": "change privileges",
|
||||
"change name": "change name",
|
||||
"change login": "change login",
|
||||
"change password": "change password",
|
||||
"privileges": "privileges",
|
||||
"edit current / list": "edit current / list",
|
||||
"from": "from",
|
||||
"to": "to",
|
||||
"in": "in"
|
||||
"for": "for",
|
||||
"to the": "to the",
|
||||
"total": "total",
|
||||
"are you sure you want to change": "are you sure you want to change",
|
||||
"admin privileges to": "admin privileges to",
|
||||
"admin privileges": "admin privileges",
|
||||
"are you sure you want to delete user": "are you sure you want to delete user"
|
||||
}
|
||||
}
|
||||
%>
|
@ -10,6 +10,15 @@
|
||||
<meta charset="UTF-8">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||
<title> <%= name %> </title>
|
||||
<script>
|
||||
if(document.title == "login"){
|
||||
// console.log(document.title);
|
||||
log_by_sid();
|
||||
}else if(document.title != "login"){
|
||||
check_sid(true);
|
||||
// console.log("check");
|
||||
}
|
||||
</script>
|
||||
<style>
|
||||
.main{
|
||||
width: 80vw;
|
||||
@ -20,15 +29,6 @@
|
||||
background-color:aliceblue;
|
||||
}
|
||||
</style>
|
||||
<script>
|
||||
if(document.title == "login"){
|
||||
// console.log(document.title);
|
||||
log_by_sid();
|
||||
}else if(document.title != "login"){
|
||||
check_sid(true);
|
||||
// console.log("check");
|
||||
}
|
||||
</script>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
|
Reference in New Issue
Block a user