added groups, stated adding object edit
This commit is contained in:
parent
fc4b567c87
commit
387a0d135f
11
db.js
11
db.js
|
@ -1,6 +1,6 @@
|
||||||
const mysql = require('mysql');
|
const mysql = require('mysql');
|
||||||
const vars = require('./vars');
|
const vars = require('./vars');
|
||||||
const db_host = "db";
|
const db_host = "localhost";
|
||||||
|
|
||||||
const admin = mysql.createConnection({
|
const admin = mysql.createConnection({
|
||||||
host: db_host,
|
host: db_host,
|
||||||
|
@ -68,6 +68,7 @@ module.exports.gav = (table,limit = "0",callback,prevs = false) => {
|
||||||
module.exports.ggv = (table,ekey,key,value,callback,prevs = false) => {
|
module.exports.ggv = (table,ekey,key,value,callback,prevs = false) => {
|
||||||
// console.log('SELECT * FROM `'+table+'` WHERE `'+key+'` = '+value);
|
// console.log('SELECT * FROM `'+table+'` WHERE `'+key+'` = '+value);
|
||||||
db(prevs).query(`SELECT ${ekey} FROM ${table} WHERE ${key} = ${value}`, (err, rows, fields) => {
|
db(prevs).query(`SELECT ${ekey} FROM ${table} WHERE ${key} = ${value}`, (err, rows, fields) => {
|
||||||
|
// console.log(`SELECT ${ekey} FROM ${table} WHERE ${key} = ${value}`);
|
||||||
if (err) {
|
if (err) {
|
||||||
console.log("sql err");
|
console.log("sql err");
|
||||||
throw err;
|
throw err;
|
||||||
|
@ -78,8 +79,9 @@ module.exports.ggv = (table,ekey,key,value,callback,prevs = false) => {
|
||||||
}
|
}
|
||||||
|
|
||||||
// set value where
|
// set value where
|
||||||
module.exports.sv = (table,key,value,ekey,evalue,callback,prevs = false) => {
|
module.exports.sv = (table,key,value,ekey,evalue,callback,prevs = false,no_srt = false) => {
|
||||||
db(prevs).query(`UPDATE ${table} SET ${key} = '${value}' WHERE ${ekey} = '${evalue}'`, (err , rows) => {
|
value = (no_srt)? value:`'${value}'`;
|
||||||
|
db(prevs).query(`UPDATE ${table} SET ${key} = ${value} WHERE ${ekey} = '${evalue}'`, (err , rows) => {
|
||||||
// console.log("UPDATE `"+table+"` SET `"+key+"` = '"+value+"' WHERE `"+ekey+"` = '"+evalue+"'");
|
// console.log("UPDATE `"+table+"` SET `"+key+"` = '"+value+"' WHERE `"+ekey+"` = '"+evalue+"'");
|
||||||
if (err) {
|
if (err) {
|
||||||
console.log("sql err");
|
console.log("sql err");
|
||||||
|
@ -90,13 +92,14 @@ module.exports.sv = (table,key,value,ekey,evalue,callback,prevs = false) => {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
// new record
|
// new record
|
||||||
module.exports.nr = (table,keys,values,prevs = false) =>{
|
module.exports.nr = (table,keys,values,prevs = false,callback) =>{
|
||||||
// console.log('INSERT INTO `'+table+'`('+keys+') VALUES ('+values+')');
|
// console.log('INSERT INTO `'+table+'`('+keys+') VALUES ('+values+')');
|
||||||
db(prevs).query(`INSERT INTO ${table} (${keys}) VALUES (${values})`,(err,res) =>{
|
db(prevs).query(`INSERT INTO ${table} (${keys}) VALUES (${values})`,(err,res) =>{
|
||||||
if (err) {
|
if (err) {
|
||||||
console.log("sql err");
|
console.log("sql err");
|
||||||
throw err;
|
throw err;
|
||||||
}else{
|
}else{
|
||||||
|
if(callback)callback();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
4
func.js
4
func.js
|
@ -120,8 +120,8 @@ module.exports.logs_file = (res)=>{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
module.exports.get_uuid = (name = "") =>{
|
module.exports.get_uuid = (name = "/") =>{
|
||||||
name = (name != "")? this.encrypt(name,"name"):"";
|
if (name != "/") name = this.encrypt(name,"name");
|
||||||
let unid = uuid.v4() + '%%'+name+'#e'+(621);
|
let unid = uuid.v4() + '%%'+name+'#e'+(621);
|
||||||
return unid;
|
return unid;
|
||||||
}
|
}
|
||||||
|
|
34
index.js
34
index.js
|
@ -166,6 +166,18 @@ app.post("/get_obj", (req,res) => {
|
||||||
func.log("router single object getting error - "+error);
|
func.log("router single object getting error - "+error);
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
app.post("/get_groups", (req,res) => {
|
||||||
|
try{
|
||||||
|
let inp = req.body;
|
||||||
|
let cook = req.cookies;
|
||||||
|
// func.log(inp["name"]);
|
||||||
|
func.sid(cook,res,()=>{
|
||||||
|
obj.load_groups(inp,cook,res);
|
||||||
|
})
|
||||||
|
} catch (error) {
|
||||||
|
func.log("router single object getting error - "+error);
|
||||||
|
}
|
||||||
|
})
|
||||||
/// admin
|
/// admin
|
||||||
app.get("/admin", (req,res) =>{
|
app.get("/admin", (req,res) =>{
|
||||||
try {
|
try {
|
||||||
|
@ -211,6 +223,28 @@ app.post("/new_obj", (req,res) => {
|
||||||
func.log("router object creating error - "+error);
|
func.log("router object creating error - "+error);
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
app.post("/admin/new/group", (req,res) => {
|
||||||
|
try{
|
||||||
|
let inp = req.body;
|
||||||
|
let cook = req.cookies;
|
||||||
|
func.sid(cook,res,()=>{
|
||||||
|
obj.new_group(inp,cook,res);
|
||||||
|
},true,true)
|
||||||
|
} catch (error) {
|
||||||
|
func.log("router object creating error - "+error);
|
||||||
|
}
|
||||||
|
})
|
||||||
|
app.post("/admin/delete/group", (req,res) => {
|
||||||
|
try{
|
||||||
|
let inp = req.body;
|
||||||
|
let cook = req.cookies;
|
||||||
|
func.sid(cook,res,()=>{
|
||||||
|
obj.del_group(inp,cook,res);
|
||||||
|
},true,true)
|
||||||
|
} catch (error) {
|
||||||
|
func.log("router object creating error - "+error);
|
||||||
|
}
|
||||||
|
})
|
||||||
app.post("/admin/users/get", (req,res) => {
|
app.post("/admin/users/get", (req,res) => {
|
||||||
try{
|
try{
|
||||||
let inp = req.body;
|
let inp = req.body;
|
||||||
|
|
64
object.js
64
object.js
|
@ -1,10 +1,11 @@
|
||||||
|
const { name } = require('ejs');
|
||||||
const db = require('./db');
|
const db = require('./db');
|
||||||
const func = require('./func');
|
const func = require('./func');
|
||||||
const vars = require('./vars');
|
const vars = require('./vars');
|
||||||
|
|
||||||
module.exports.loads = (inp,cook,res)=>{
|
module.exports.loads = (inp,cook,res)=>{
|
||||||
try {
|
try {
|
||||||
db.ggv("objects","`name`,`id`,`height`,`width`,`description`","gid",0,(odata)=>{
|
db.ggv("objects","`name`,`id`,`height`,`width`,`description`,`gid`","gid",`${inp["gid"]}`,(odata)=>{
|
||||||
// func.log(odata);
|
// func.log(odata);
|
||||||
res.send({out:"good",body:odata});
|
res.send({out:"good",body:odata});
|
||||||
})
|
})
|
||||||
|
@ -27,16 +28,63 @@ module.exports.load = (inp,cook,res)=>{
|
||||||
|
|
||||||
module.exports.new = (inp,cook,res)=>{
|
module.exports.new = (inp,cook,res)=>{
|
||||||
try {
|
try {
|
||||||
db.ggv("objects","id","name",`'${inp["name"]}'`,(db_name)=>{db_name= db_name[0]
|
db.ggv("object_groups","name","id",`'${inp["gid"]}'`,(gname)=>{gname = gname[0]
|
||||||
if(db_name != null){
|
db.ggv("objects","name","gid",`'${inp["gid"]}' AND name = '${inp["name"]}/g/${gname["name"]}'`,(db_name)=>{
|
||||||
|
if(db_name[0] != null){
|
||||||
res.send({out:"bad",err:"name"});
|
res.send({out:"bad",err:"name"});
|
||||||
}
|
}
|
||||||
else if (db_name == null){
|
else if (db_name[0] == null){
|
||||||
db.nr("objects","`name`,`img`,`height`,`width`,`description`",`'${inp["name"]}','${inp["img"]}','${inp["height"]}','${inp["width"]}','${inp["desc"]}'`,true);
|
db.nr("objects","`name`,`img`,`height`,`width`,`description`,`gid`",`'${inp["name"]}/g/${gname["name"]}','${inp["img"]}','${inp["height"]}','${inp["width"]}','${inp["desc"]}','${inp["gid"]}'`,true);
|
||||||
res.send({out:"good"});
|
db.sv("object_groups","count",`(count + 1)`,"id",inp["gid"],()=>{},true,true)
|
||||||
}
|
func.log(`admin object created name:${inp["name"]} group:${gname["name"]}`);
|
||||||
},true)
|
res.send({out:"good"});
|
||||||
|
}
|
||||||
|
// console.log(db_name);
|
||||||
|
// db.ggv("objects","gid","name",`'${inp["name"]}'`,(db_name)=>{
|
||||||
|
// })
|
||||||
|
},true)
|
||||||
|
})
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
func.log("backend object creating error - "+error);
|
func.log("backend object creating error - "+error);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports.load_groups = (inp,cook,res)=>{
|
||||||
|
try {
|
||||||
|
db.gav("object_groups","0",(gdata)=>{
|
||||||
|
// func.log(odata);
|
||||||
|
res.send({out:"good",body:gdata});
|
||||||
|
})
|
||||||
|
} catch (error) {
|
||||||
|
func.log("backend object groups loading err0r - "+error);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
module.exports.new_group = (inp,cook,res)=>{
|
||||||
|
try {
|
||||||
|
db.ggv("object_groups","id","name",`'${inp["name"]}'`,(gdata)=>{gdata = gdata[0]
|
||||||
|
// func.log(odata);
|
||||||
|
if(gdata != null){
|
||||||
|
res.send({out:"bad"});
|
||||||
|
}
|
||||||
|
else if (gdata == null){
|
||||||
|
db.nr("object_groups","`name`,`count`",`'${inp["name"]}','0'`,true,()=>{
|
||||||
|
res.send({out:"good"});
|
||||||
|
})
|
||||||
|
}
|
||||||
|
})
|
||||||
|
} catch (error) {
|
||||||
|
func.log("backend single object loading err0r - "+error);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
module.exports.del_group = (inp,cook,res)=>{
|
||||||
|
try {
|
||||||
|
db.ggv("object_groups",`name`,`id`,`'${inp["gid"]}'`,(gname)=>{gname = gname[0]["name"]
|
||||||
|
db.dl("object_groups",`id`,`'${inp["gid"]}'`,()=>{
|
||||||
|
func.log(`admin group deleted ${gname}`);
|
||||||
|
res.send({out:"good"});
|
||||||
|
},true);
|
||||||
|
})
|
||||||
|
} catch (error) {
|
||||||
|
func.log("backend single object loading err0r - "+error);
|
||||||
|
}
|
||||||
}
|
}
|
BIN
public/img/img_placeholder.webp
Normal file
BIN
public/img/img_placeholder.webp
Normal file
Binary file not shown.
After Width: | Height: | Size: 802 B |
|
@ -90,6 +90,29 @@ function get_sid(){
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function load_groups(callback){
|
||||||
|
let select = document.getElementById("group_select");
|
||||||
|
// let name = select.options[select.selectedIndex].text;
|
||||||
|
$.post( "/get_groups")
|
||||||
|
.done(function( res ) {
|
||||||
|
if(res["out"] == "good"){
|
||||||
|
select.innerHTML = "";
|
||||||
|
res["body"].forEach(group => {
|
||||||
|
let group_div = document.createElement("option");
|
||||||
|
group_div.innerText = group["name"].replace("$"," ");
|
||||||
|
group_div.setAttribute("group_count",group["count"]);
|
||||||
|
group_div.setAttribute("gid",group["id"]);
|
||||||
|
group_div.id = `obj_group_${group["id"]}`;
|
||||||
|
select.append(group_div);
|
||||||
|
if(group["id"] == res["body"].at(-1)["id"]){
|
||||||
|
if(callback)callback();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
// callback(res);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
// redirect
|
// redirect
|
||||||
function goto(url) {
|
function goto(url) {
|
||||||
location.href = url;
|
location.href = url;
|
||||||
|
|
|
@ -15,44 +15,47 @@ function create(clas,x,y,body,id,size){
|
||||||
obj.classList.add(cl);
|
obj.classList.add(cl);
|
||||||
});
|
});
|
||||||
get_obj(main_clas,(db_data)=>{
|
get_obj(main_clas,(db_data)=>{
|
||||||
if ($.cookie("cache") == "true"){
|
// console.log(db_data);
|
||||||
if (localStorage.getItem(`${main_clas}`) == null){
|
// db_data.forEach(db_data => {
|
||||||
|
// });
|
||||||
|
if (db_data == null) {
|
||||||
|
delete objs[main_clas][id];
|
||||||
|
if(proj_from == "cloud"){
|
||||||
|
save(()=>{
|
||||||
|
goto("/proj/"+proj_name);
|
||||||
|
},false);
|
||||||
|
}
|
||||||
|
else if (proj_from == "local"){
|
||||||
|
save_local();
|
||||||
|
load_proj_local();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (db_data != null){
|
||||||
|
if ($.cookie("cache") == "true"){
|
||||||
|
if (localStorage.getItem(`${main_clas}`) == null){
|
||||||
|
load_obj(main_clas,"`img`",(odata)=>{
|
||||||
|
localStorage.setItem(main_clas,odata["img"]);
|
||||||
|
make(odata["img"]);
|
||||||
|
})
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
make(localStorage.getItem(main_clas))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else{
|
||||||
load_obj(main_clas,"`img`",(odata)=>{
|
load_obj(main_clas,"`img`",(odata)=>{
|
||||||
localStorage.setItem(main_clas,odata["img"]);
|
localStorage.setItem(main_clas,odata["img"]);
|
||||||
make(odata["img"]);
|
make(odata["img"]);
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
else{
|
|
||||||
make(localStorage.getItem(main_clas))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
load_obj(main_clas,"`img`",(odata)=>{
|
|
||||||
localStorage.setItem(main_clas,odata["img"]);
|
|
||||||
make(odata["img"]);
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
function make(img){
|
function make(img){
|
||||||
if (db_data == null) {
|
obj.src = img;
|
||||||
delete objs[main_clas][id];
|
obj.title = `${db_data["name"].replace("$"," ").split("/g")[0]}\n${db_data["description"]}\n${lang("width")}:${db_data["width"]}см ${lang("height")}:${db_data["height"]}см`;
|
||||||
if(proj_from == "cloud"){
|
// drag.transform = `translate(${drag.getAttribute("data-y")}px, ${drag.getAttribute("data-y")}px) scale(${db_data["width"] * 2} ${db_data["height"] * 2})`;
|
||||||
save(()=>{
|
if(size){
|
||||||
goto("/proj/"+proj_name);
|
obj.style.width = `${db_data["width"] * 2}px`;
|
||||||
},false);
|
obj.style.height = `${db_data["height"] * 2}px`;
|
||||||
}
|
|
||||||
else if (proj_from == "local"){
|
|
||||||
save_local();
|
|
||||||
load_proj_local();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (db_data != null){
|
|
||||||
obj.src = img;
|
|
||||||
obj.title = `${db_data["name"]}\n${db_data["description"]}\n${lang("width")}:${db_data["width"]}см ${lang("height")}:${db_data["height"]}см`;
|
|
||||||
// drag.transform = `translate(${drag.getAttribute("data-y")}px, ${drag.getAttribute("data-y")}px) scale(${db_data["width"] * 2} ${db_data["height"] * 2})`;
|
|
||||||
if(size){
|
|
||||||
obj.style.width = `${db_data["width"] * 2}px`;
|
|
||||||
obj.style.height = `${db_data["height"] * 2}px`;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
@ -136,7 +139,7 @@ function load_proj_cloud(){
|
||||||
console.log("bad");
|
console.log("bad");
|
||||||
save(()=>{
|
save(()=>{
|
||||||
goto("/proj/"+proj_name);
|
goto("/proj/"+proj_name);
|
||||||
});
|
},false);
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -174,9 +177,9 @@ function save(callback,with_pic = true){
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
make_save("none");
|
make_save();
|
||||||
}
|
}
|
||||||
function make_save(src = "none"){
|
function make_save(src = "img/img_placeholder.webp"){
|
||||||
$.post( "/save_proj", {proj:JSON.stringify(objs),name:proj_name,img:src})
|
$.post( "/save_proj", {proj:JSON.stringify(objs),name:proj_name,img:src})
|
||||||
.done(function( res ) {
|
.done(function( res ) {
|
||||||
if(res["out"] == "good"){
|
if(res["out"] == "good"){
|
||||||
|
@ -189,7 +192,8 @@ function save(callback,with_pic = true){
|
||||||
}
|
}
|
||||||
|
|
||||||
function load_objs(callback){
|
function load_objs(callback){
|
||||||
$.post( "/get_objs")
|
let select = document.getElementById("group_select");
|
||||||
|
$.post( "/get_objs",{gid:select.options[select.selectedIndex].getAttribute("gid")})
|
||||||
.done(function( res ) {
|
.done(function( res ) {
|
||||||
if(res["out"] == "good"){
|
if(res["out"] == "good"){
|
||||||
// console.log(res["body"]);
|
// console.log(res["body"]);
|
||||||
|
@ -333,7 +337,6 @@ function drag_start() {
|
||||||
Object.entries(zones).forEach(([key, zone]) => {
|
Object.entries(zones).forEach(([key, zone]) => {
|
||||||
let x = zone.getBoundingClientRect().left - document.getElementById("drags").getBoundingClientRect().left;
|
let x = zone.getBoundingClientRect().left - document.getElementById("drags").getBoundingClientRect().left;
|
||||||
let y = zone.getBoundingClientRect().top - document.getElementById("drags").getBoundingClientRect().top;
|
let y = zone.getBoundingClientRect().top - document.getElementById("drags").getBoundingClientRect().top;
|
||||||
// console.log(x,y);
|
|
||||||
create(`${zone.classList[0]} spawn drag`,x,y,`${zone.classList[0]}`,`none`);
|
create(`${zone.classList[0]} spawn drag`,x,y,`${zone.classList[0]}`,`none`);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,6 +10,8 @@
|
||||||
<h1 style="text-align: center;"><%= lang("hello admin") %></h1> <br>
|
<h1 style="text-align: center;"><%= lang("hello admin") %></h1> <br>
|
||||||
<section>
|
<section>
|
||||||
<%- include('./admin/objects/object_creation.ejs') %>
|
<%- include('./admin/objects/object_creation.ejs') %>
|
||||||
|
<%- include('./admin/objects/object_groups.ejs') %>
|
||||||
|
<%- include('./admin/objects/object_edit.ejs') %>
|
||||||
</section>
|
</section>
|
||||||
|
|
||||||
<section>
|
<section>
|
||||||
|
|
|
@ -60,7 +60,7 @@
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
function obj_size_change(type){
|
function obj_size_change(type){
|
||||||
if(type == "height"){
|
if(type == "height"){
|
||||||
let img = document.getElementById('img_prev');
|
let img = document.getElementById('img_prev');
|
||||||
let range = document.getElementById('obj_height');
|
let range = document.getElementById('obj_height');
|
||||||
|
@ -93,7 +93,8 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
function new_obj(name,img,height,width,description,callback){
|
function new_obj(name,img,height,width,description,callback){
|
||||||
$.post( "/new_obj", { name:name,img:img,desc:description,height:height,width:width })
|
let select = document.getElementById("group_select");
|
||||||
|
$.post( "/new_obj", { name:name,img:img,desc:description,height:height,width:width,gid:select.options[select.selectedIndex].getAttribute("gid")})
|
||||||
.done(function( res ) {
|
.done(function( res ) {
|
||||||
// if(res["out"] == "good"){
|
// if(res["out"] == "good"){
|
||||||
// console.log(res["body"]);
|
// console.log(res["body"]);
|
||||||
|
@ -108,7 +109,7 @@
|
||||||
let height = document.getElementById("obj_height").value;
|
let height = document.getElementById("obj_height").value;
|
||||||
let width = document.getElementById("obj_width").value;
|
let width = document.getElementById("obj_width").value;
|
||||||
var img = document.querySelector('img').src;
|
var img = document.querySelector('img').src;
|
||||||
name = name.replace(" ","_");
|
name = name.replace(" ","$");
|
||||||
if (img != "http://n0rsrv2:3002/admin"){
|
if (img != "http://n0rsrv2:3002/admin"){
|
||||||
document.getElementById("obj_resp").innerHTML = "creating object";
|
document.getElementById("obj_resp").innerHTML = "creating object";
|
||||||
new_obj(name,img,height,width,description,(res)=>{
|
new_obj(name,img,height,width,description,(res)=>{
|
||||||
|
@ -117,6 +118,9 @@
|
||||||
}
|
}
|
||||||
else if(res["out"] == "good"){
|
else if(res["out"] == "good"){
|
||||||
document.getElementById("obj_resp").innerHTML = "object created";
|
document.getElementById("obj_resp").innerHTML = "object created";
|
||||||
|
setTimeout(()=>{
|
||||||
|
edit_get_objs();
|
||||||
|
},1000)
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,97 @@
|
||||||
|
<style>
|
||||||
|
.object{
|
||||||
|
background-color: #bfe4ff;
|
||||||
|
border: dashed 4px transparent;
|
||||||
|
border-radius: 4px;
|
||||||
|
height: 50px;
|
||||||
|
width: 50px;
|
||||||
|
margin: 5px;
|
||||||
|
margin-top: 0px;
|
||||||
|
}
|
||||||
|
img{
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
}
|
||||||
|
#objs_in_group{
|
||||||
|
display: flex;
|
||||||
|
flex-wrap: wrap;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|
||||||
|
<h1>object edit</h1>
|
||||||
|
<div>
|
||||||
|
<div id="objs_in_group"></div>
|
||||||
|
</div>
|
||||||
|
<div class="cmenu" id="object_menu">
|
||||||
|
<button>del object</button>
|
||||||
|
<button>change name</button>
|
||||||
|
<button>change size</button>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
load_groups(()=>{
|
||||||
|
edit_get_objs();
|
||||||
|
});
|
||||||
|
|
||||||
|
function edit_get_objs(){
|
||||||
|
document.getElementById("objs_in_group").innerHTML = "";
|
||||||
|
edit_load_objs((data)=>{
|
||||||
|
data.forEach(value => {
|
||||||
|
// console.log(value);
|
||||||
|
// // console.log($.cookie("cache"));
|
||||||
|
// console.log(localStorage.getItem(`${value["name"]}`));
|
||||||
|
if ($.cookie("cache") == "true"){
|
||||||
|
if (localStorage.getItem(`${value["name"]}`) == null){
|
||||||
|
edit_load_obj(value["name"],"`img`",(odata)=>{
|
||||||
|
localStorage.setItem(value["name"],odata["img"]);
|
||||||
|
make(odata["img"]);
|
||||||
|
})
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
make(localStorage.getItem(value["name"]))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
$.cookie("cache","true",{path:"/;SameSite=Strict"})
|
||||||
|
edit_load_obj(value["name"],"`img`",(odata)=>{
|
||||||
|
localStorage.setItem(value["name"],odata["img"]);
|
||||||
|
make(odata["img"]);
|
||||||
|
})
|
||||||
|
}
|
||||||
|
function make(img){
|
||||||
|
let czones = document.getElementById("objs_in_group");
|
||||||
|
let czone = document.createElement('div');
|
||||||
|
czone.classList.add(value["name"]);
|
||||||
|
czone.classList.add("object");
|
||||||
|
czone.innerHTML = `<img src="${img}">`
|
||||||
|
czones.append(czone)
|
||||||
|
}
|
||||||
|
});
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
function edit_load_obj(name,key,callback){
|
||||||
|
$.post( "/get_obj",{name:name,key:key})
|
||||||
|
.done(function( res ) {
|
||||||
|
if(res["out"] == "good"){
|
||||||
|
// console.log(res["body"]);
|
||||||
|
callback(res["body"]);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function edit_load_objs(callback){
|
||||||
|
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"]);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
</script>
|
40
views/admin/objects/object_groups.ejs
Normal file
40
views/admin/objects/object_groups.ejs
Normal file
|
@ -0,0 +1,40 @@
|
||||||
|
|
||||||
|
<h1>objects group</h1>
|
||||||
|
<div id="obj_group">
|
||||||
|
<div style="display: flex;justify-content: space-between;">
|
||||||
|
<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>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
load_groups();
|
||||||
|
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})
|
||||||
|
.done(function( res ) {
|
||||||
|
if(res["out"] == "good"){
|
||||||
|
// console.log(res["body"]);
|
||||||
|
load_groups();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
function create_new_group() {
|
||||||
|
let group_name = ask("enter group name");
|
||||||
|
if(group_name != ""){
|
||||||
|
$.post( "/admin/new/group", { name:group_name.replace(" ","$")})
|
||||||
|
.done(function( res ) {
|
||||||
|
if(res["out"] == "good"){
|
||||||
|
// console.log(res["body"]);
|
||||||
|
load_groups();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
|
@ -42,6 +42,7 @@
|
||||||
color: black;
|
color: black;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
border: 1px black solid;
|
border: 1px black solid;
|
||||||
|
z-index: 100;
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
<script>
|
<script>
|
||||||
|
|
|
@ -23,7 +23,7 @@
|
||||||
transition: background-color 0.3s;
|
transition: background-color 0.3s;
|
||||||
position: absolute;
|
position: absolute;
|
||||||
inset: 0px;
|
inset: 0px;
|
||||||
margin: 250px auto;
|
margin: 5px auto;
|
||||||
width: 400px;
|
width: 400px;
|
||||||
height: 200px;
|
height: 200px;
|
||||||
background-color: #fff;
|
background-color: #fff;
|
||||||
|
@ -43,6 +43,7 @@
|
||||||
height: 22px;
|
height: 22px;
|
||||||
width: 22px;
|
width: 22px;
|
||||||
margin: 10px;
|
margin: 10px;
|
||||||
|
margin-top: 0px;
|
||||||
padding: 10px;
|
padding: 10px;
|
||||||
transition: background-color 0.3s;
|
transition: background-color 0.3s;
|
||||||
}
|
}
|
||||||
|
@ -51,7 +52,7 @@
|
||||||
background-color: #bfe4ff;
|
background-color: #bfe4ff;
|
||||||
border: dashed 4px transparent;
|
border: dashed 4px transparent;
|
||||||
border-radius: 4px;
|
border-radius: 4px;
|
||||||
margin: 10px auto 30px;
|
/* margin: 10px auto 30px; */
|
||||||
/* padding: 10px; */
|
/* padding: 10px; */
|
||||||
height: 50px;
|
height: 50px;
|
||||||
width: 50px;
|
width: 50px;
|
||||||
|
@ -61,11 +62,11 @@
|
||||||
}
|
}
|
||||||
.czones{
|
.czones{
|
||||||
display: flex;
|
display: flex;
|
||||||
margin: auto;
|
margin: 0px auto;
|
||||||
/* justify-content: space-around; */
|
/* justify-content: space-around; */
|
||||||
flex-wrap: wrap;
|
flex-wrap: wrap;
|
||||||
width: 80%;
|
width: 75%;
|
||||||
height: 100px;
|
/* height: 100px; */
|
||||||
/* overflow-x: auto; */
|
/* overflow-x: auto; */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -102,13 +103,24 @@
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
|
|
||||||
<div id="project_menu" class="cmenu"></div>
|
<div id="project_menu" class="cmenu">
|
||||||
|
<button id='proj_csave_btn' onclick='save_proj()'><%= lang(`save to cloud`) %></button> <br>
|
||||||
|
<button id='proj_cload_btn' onclick='load_proj_cloud()'><%=lang('load from cloud')%></button> <br>
|
||||||
|
<button id='proj_lsave_btn' onclick='save_proj_local()'><%=lang('save to local') %></button> <br>
|
||||||
|
<button id='proj_lload_btn' onclick='load_proj_local()'><%=lang('load from local')%></button> <br>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
<!-- <div class="dropzone"></div> -->
|
<!-- <div class="dropzone"></div> -->
|
||||||
|
|
||||||
<div class="inputs">
|
<div class="inputs">
|
||||||
<div id="wall_input">
|
<div id="wall_input">
|
||||||
|
<div id="obj_group">
|
||||||
|
<div style="display: flex;justify-content: space-between;">
|
||||||
|
<div style="width: 50px;">object group</div>
|
||||||
|
<select name="" id="group_select" onchange="get_objs()"></select>
|
||||||
|
</div>
|
||||||
|
</div><br>
|
||||||
<div>
|
<div>
|
||||||
<div style="display: flex;width: 150px;justify-content: space-between;">
|
<div style="display: flex;width: 150px;justify-content: space-between;">
|
||||||
<label for="wall_height"><%= lang("height") %> </label>
|
<label for="wall_height"><%= lang("height") %> </label>
|
||||||
|
@ -128,41 +140,50 @@
|
||||||
<img class="trash" style="height: 100px; width: 100px;" src="/img/shadow-energy.gif" alt="<%= lang('black hole') %>">
|
<img class="trash" style="height: 100px; width: 100px;" src="/img/shadow-energy.gif" alt="<%= lang('black hole') %>">
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div id="drags"></div>
|
<div class="zones" style="position: relative;">
|
||||||
|
<div id="drags"></div>
|
||||||
<div class="wall dropzone" id="wall"></div>
|
<div class="wall dropzone" id="wall"></div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
<script src="/lib/inter.js"></script>
|
<script src="/lib/inter.js"></script>
|
||||||
<script>
|
<script>
|
||||||
load_objs((data)=>{
|
load_groups(()=>{
|
||||||
data.forEach(value => {
|
get_objs();
|
||||||
// console.log(value);
|
|
||||||
let czones = document.getElementsByClassName("czones")[0];
|
|
||||||
let czone = document.createElement('div');
|
|
||||||
czone.classList.add(value["name"]);
|
|
||||||
czone.classList.add("createzone");
|
|
||||||
czones.append(czone)
|
|
||||||
});
|
|
||||||
load_proj_cloud();
|
load_proj_cloud();
|
||||||
})
|
});
|
||||||
|
function get_objs(){
|
||||||
|
document.getElementsByClassName("czones")[0].innerHTML = "";
|
||||||
|
load_objs((data)=>{
|
||||||
|
data.forEach(value => {
|
||||||
|
let czones = document.getElementsByClassName("czones")[0];
|
||||||
|
let czone = document.createElement('div');
|
||||||
|
czone.classList.add(value["name"]);
|
||||||
|
czone.classList.add("createzone");
|
||||||
|
czones.append(czone)
|
||||||
|
});
|
||||||
|
drag_start()
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
let proj_name = "<%= proj_name %>";
|
let proj_name = "<%= proj_name %>";
|
||||||
if($.cookie("cache") ==null)$.cookie("cache","true",{path:"/proj;SameSite=Strict"});
|
if($.cookie("cache") ==null)$.cookie("cache","true",{path:"/;SameSite=Strict"});
|
||||||
// console.log(proj_name);
|
// console.log(proj_name);
|
||||||
let menu = document.getElementById("project_menu");
|
let menu = document.getElementById("project_menu");
|
||||||
document.getElementById("top_panel_left").innerHTML = `<div id='proj_menu' class="menu_btn"><%= lang("project settings") %></div>`;
|
document.getElementById("top_panel_left").innerHTML = `<div id='proj_menu' class="menu_btn"><%= lang("project settings") %></div>`;
|
||||||
menu.innerHTML += "<button id='proj_csave_btn' onclick='save_proj()'><%= lang(`save to cloud`) %></button> <br>";
|
// menu.innerHTML += "<button id='proj_csave_btn' onclick='save_proj()'><%= lang(`save to cloud`) %></button> <br>";
|
||||||
menu.innerHTML += "<button id='proj_cload_btn' onclick='load_proj_cloud()'><%=lang('load from cloud')%></button> <br>";
|
// menu.innerHTML += "<button id='proj_cload_btn' onclick='load_proj_cloud()'><%=lang('load from cloud')%></button> <br>";
|
||||||
menu.innerHTML += "<button id='proj_lsave_btn' onclick='save_proj_local()'><%=lang('save to local') %></button> <br>";
|
// menu.innerHTML += "<button id='proj_lsave_btn' onclick='save_proj_local()'><%=lang('save to local') %></button> <br>";
|
||||||
menu.innerHTML += "<button id='proj_lload_btn' onclick='load_proj_local()'><%=lang('load from local')%></button> <br>";
|
// menu.innerHTML += "<button id='proj_lload_btn' onclick='load_proj_local()'><%=lang('load from local')%></button> <br>";
|
||||||
if ($.cookie("cache") == "false") menu.innerHTML += "<div id='cache_switch' title='<%=lang('cache_title')%>'><button onclick='cache_change(true);'><%=lang('cache_off')%></button></div>";
|
if ($.cookie("cache") == "false") menu.innerHTML += "<div id='cache_switch' title='<%=lang('cache_title')%>'><button onclick='cache_change(true);'><%=lang('cache_off')%></button></div>";
|
||||||
else if ($.cookie("cache") == "true") menu.innerHTML += "<div id='cache_switch' title='<%=lang('cache_title')%>'><button onclick='cache_change(false);'><%=lang('cache_on')%></button></div>";
|
else if ($.cookie("cache") == "true") menu.innerHTML += "<div id='cache_switch' title='<%=lang('cache_title')%>'><button onclick='cache_change(false);'><%=lang('cache_on')%></button></div>";
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
function cache_change(to){
|
function cache_change(to){
|
||||||
let cache_switch = document.getElementById("cache_switch");
|
let cache_switch = document.getElementById("cache_switch");
|
||||||
if(to) {cache_switch.innerHTML = "<button onclick='cache_change(false);' title='<%=lang('cache_title')%>'><%=lang('cache_on')%></button></div>";$.cookie("cache","true",{path:"/proj;SameSite=Strict"});}
|
if(to) {cache_switch.innerHTML = "<button onclick='cache_change(false);' title='<%=lang('cache_title')%>'><%=lang('cache_on')%></button></div>";$.cookie("cache","true",{path:"/;SameSite=Strict"});}
|
||||||
else if(!to) {cache_switch.innerHTML = "<button onclick='cache_change(true);' title='<%=lang('cache_title')%>'><%=lang('cache_off')%></button></div>";$.cookie("cache","false",{path:"/proj;SameSite=Strict"});}
|
else if(!to) {cache_switch.innerHTML = "<button onclick='cache_change(true);' title='<%=lang('cache_title')%>'><%=lang('cache_off')%></button></div>";$.cookie("cache","false",{path:"/;SameSite=Strict"});}
|
||||||
}
|
}
|
||||||
function save_proj(type){
|
function save_proj(type){
|
||||||
document.getElementById('top_panel_center').innerHTML=` <%=lang("saving")%> ${proj_name}`;
|
document.getElementById('top_panel_center').innerHTML=` <%=lang("saving")%> ${proj_name}`;
|
||||||
|
@ -191,5 +212,6 @@
|
||||||
function isZooming(){
|
function isZooming(){
|
||||||
resize_drags();
|
resize_drags();
|
||||||
}
|
}
|
||||||
|
|
||||||
</script>
|
</script>
|
||||||
<%- include('./static/end.ejs') %>
|
<%- include('./static/end.ejs') %>
|
Loading…
Reference in New Issue
Block a user