what a mess
This commit is contained in:
parent
388ec90132
commit
17ed928935
93
app.js
93
app.js
@ -1,12 +1,11 @@
|
|||||||
import FSHandle from "./store.js";
|
import FSHandle from "./store.js";
|
||||||
|
|
||||||
|
|
||||||
const Rooms = {};
|
const Rooms = {};
|
||||||
|
|
||||||
async function getFolderHandle() {
|
async function getFolderHandle() {
|
||||||
try {
|
try {
|
||||||
const dirHandle = await globalThis.showDirectoryPicker();
|
const dirHandle = await globalThis.showDirectoryPicker();
|
||||||
console.log("Folder selected:", dirHandle);
|
|
||||||
|
|
||||||
|
|
||||||
const roomsFolder = await dirHandle.getDirectoryHandle("room");
|
const roomsFolder = await dirHandle.getDirectoryHandle("room");
|
||||||
if(roomsFolder)
|
if(roomsFolder)
|
||||||
@ -31,53 +30,76 @@ async function getFolderHandle() {
|
|||||||
const roomObj =
|
const roomObj =
|
||||||
{
|
{
|
||||||
meta: metaData,
|
meta: metaData,
|
||||||
pass: {}
|
pass: {},
|
||||||
};
|
live: false,
|
||||||
Rooms[roomFolder.name] = roomObj;
|
async load()
|
||||||
|
|
||||||
for await (const [_, passFolder] of roomFolder.entries())
|
|
||||||
{
|
|
||||||
if(passFolder.kind == "directory")
|
|
||||||
{
|
{
|
||||||
const passMeta = await passFolder.getFileHandle("_pass_meta.json");
|
if(this.live) return;
|
||||||
if(passMeta)
|
for await (const [_, passFolder] of roomFolder.entries())
|
||||||
{
|
{
|
||||||
|
if(passFolder.kind == "directory")
|
||||||
let metaData = {};
|
|
||||||
try
|
|
||||||
{
|
{
|
||||||
metaData = await passMeta.getFile().then(d=>d.text()).then(t=>JSON.parse(t));
|
const passMeta = await passFolder.getFileHandle("_pass_meta.json");
|
||||||
}
|
if(passMeta)
|
||||||
catch (e)
|
|
||||||
{
|
|
||||||
console.warn(`Couldn't parse pass meta: ${roomFolder.name} / ${passFolder.name} / ${passMeta.name}`, e);
|
|
||||||
}
|
|
||||||
|
|
||||||
const passObj = {
|
|
||||||
meta: metaData,
|
|
||||||
user: {}
|
|
||||||
}
|
|
||||||
roomObj.pass[passFolder.name] = passObj;
|
|
||||||
|
|
||||||
for await (const [_, userFile] of passFolder.entries())
|
|
||||||
{
|
|
||||||
if(userFile.name.endsWith(".json") && userFile.name != "_pass_meta.json")
|
|
||||||
{
|
{
|
||||||
const userID = userFile.name.substring(0, userFile.name.length-5)
|
|
||||||
|
let metaData = {};
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
passObj.user[userID] = await userFile.getFile().then(d=>d.text()).then(t=>JSON.parse(t));
|
metaData = await passMeta.getFile().then(d=>d.text()).then(t=>JSON.parse(t));
|
||||||
}
|
}
|
||||||
catch (e)
|
catch (e)
|
||||||
{
|
{
|
||||||
console.warn(`Couldn't parse user data: ${roomFolder.name} / ${passFolder.name} / ${userFile.name}`, e);
|
console.warn(`Couldn't parse pass meta: ${roomFolder.name} / ${passFolder.name} / ${passMeta.name}`, e);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const passObj = [
|
||||||
|
metaData,
|
||||||
|
{}
|
||||||
|
]
|
||||||
|
roomObj.pass[passFolder.name] = passObj;
|
||||||
|
|
||||||
|
for await (const [_, userFile] of passFolder.entries())
|
||||||
|
{
|
||||||
|
if(userFile.name.endsWith(".json") && userFile.name != "_pass_meta.json")
|
||||||
|
{
|
||||||
|
const userID = userFile.name.substring(0, userFile.name.length-5)
|
||||||
|
try
|
||||||
|
{
|
||||||
|
passObj[1][userID] = await userFile.getFile().then(d=>d.text()).then(t=>JSON.parse(t));
|
||||||
|
}
|
||||||
|
catch (e)
|
||||||
|
{
|
||||||
|
console.warn(`Couldn't parse user data: ${roomFolder.name} / ${passFolder.name} / ${userFile.name}`, e);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
this.live = true;
|
||||||
|
|
||||||
|
globalThis.Pass = this.pass;
|
||||||
|
|
||||||
|
if (navigator.serviceWorker.controller)
|
||||||
|
{
|
||||||
|
navigator.serviceWorker.controller.postMessage(this.pass);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//await import(`./room/${roomFolder.name}/room.js`);
|
||||||
|
|
||||||
|
},
|
||||||
|
async dump()
|
||||||
|
{
|
||||||
|
this.live = false;
|
||||||
|
this.pass = {};
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
|
||||||
|
Rooms[roomFolder.name] = roomObj;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -87,11 +109,14 @@ async function getFolderHandle() {
|
|||||||
|
|
||||||
console.log("Rooms:", Rooms);
|
console.log("Rooms:", Rooms);
|
||||||
|
|
||||||
|
globalThis.Rooms = Rooms;
|
||||||
|
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
console.error("Folder selection cancelled or failed:", err);
|
console.error("Folder selection cancelled or failed:", err);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
function Init()
|
function Init()
|
||||||
{
|
{
|
||||||
const d =(...args)=> document.createElement(...args);
|
const d =(...args)=> document.createElement(...args);
|
||||||
|
|||||||
59
graph.js
59
graph.js
@ -1,51 +1,51 @@
|
|||||||
/** @import * as TYPES from "./types.ts" */
|
/** @import * as TYPES from "./types.ts" */
|
||||||
|
|
||||||
/** @type {TYPES.GraphBuilder} */
|
/** @type {TYPES.GraphBuilder} */
|
||||||
export default function({users, roles, parts, desks, passes})
|
export default function Builder({user, role, part, desk, pass})
|
||||||
{
|
{
|
||||||
|
|
||||||
// mutate users
|
// mutate users
|
||||||
/** @type {Record<string, TYPES.User>} */
|
/** @type {Record<string, TYPES.User>} */
|
||||||
//@ts-ignore
|
//@ts-ignore
|
||||||
const UserList = users;
|
const UserList = user;
|
||||||
for(let userId in users)
|
for(let userId in user)
|
||||||
{
|
{
|
||||||
const name = users[userId];
|
const name = user[userId];
|
||||||
UserList[userId] = {name, desk:new Set()};
|
UserList[userId] = {name, desk:new Set()};
|
||||||
}
|
}
|
||||||
|
|
||||||
// mutate roles
|
// mutate roles
|
||||||
/** @type {Record<string, TYPES.Role>} */
|
/** @type {Record<string, TYPES.Role>} */
|
||||||
//@ts-ignore
|
//@ts-ignore
|
||||||
const RoleList = roles;
|
const RoleList = role;
|
||||||
for(let roleId in roles)
|
for(let roleId in role)
|
||||||
{
|
{
|
||||||
const [name, ...userIds] = roles[roleId];
|
const [name, ...userIds] = role[roleId];
|
||||||
RoleList[roleId] = {name, user:userIds.map(uId=>UserList[/**@type{string}*/(uId)])};
|
RoleList[roleId] = {name, user:userIds.map(uId=>UserList[/**@type{string}*/(uId)])};
|
||||||
}
|
}
|
||||||
|
|
||||||
// mutate parts
|
// mutate parts
|
||||||
/** @type {Record<string, TYPES.Part>} */
|
/** @type {Record<string, TYPES.Part>} */
|
||||||
//@ts-ignore
|
//@ts-ignore
|
||||||
const PartList = parts;
|
const PartList = part;
|
||||||
for(let partId in parts)
|
for(let partId in part)
|
||||||
{
|
{
|
||||||
const name = parts[partId];
|
const name = part[partId];
|
||||||
PartList[partId] = /** @type {TYPES.Part} */({name, need:[], make:[], pass:new Map()});
|
PartList[partId] = /** @type {TYPES.Part} */({name, need:[], make:[], pass:new Map()});
|
||||||
}
|
}
|
||||||
|
|
||||||
// mutate desks
|
// mutate desks
|
||||||
/** @type {Record<string, TYPES.Desk>} */
|
/** @type {Record<string, TYPES.Desk>} */
|
||||||
//@ts-ignore
|
//@ts-ignore
|
||||||
const DeskList = desks;
|
const DeskList = desk;
|
||||||
for(let deskId in desks)
|
for(let deskId in desk)
|
||||||
{
|
{
|
||||||
const [name, roleIDs, mode, needObj, ...makePartIDs] = desks[deskId];
|
const [name, roleIDs, mode, needObj, ...makePartIDs] = desk[deskId];
|
||||||
/** @type {TYPES.Part[]}*/ const need =[];
|
/** @type {TYPES.Part[]}*/ const need =[];
|
||||||
/** @type {number[]}*/ const time =[];
|
/** @type {number[]}*/ const time =[];
|
||||||
|
|
||||||
/** @type {TYPES.Desk} */
|
/** @type {TYPES.Desk} */
|
||||||
const desk = {
|
const deskObj = {
|
||||||
name,
|
name,
|
||||||
mode,
|
mode,
|
||||||
need,
|
need,
|
||||||
@ -58,33 +58,33 @@ export default function({users, roles, parts, desks, passes})
|
|||||||
{
|
{
|
||||||
const part = PartList[partId];
|
const part = PartList[partId];
|
||||||
need.push(part);
|
need.push(part);
|
||||||
part.need.push(desk);
|
part.need.push(deskObj);
|
||||||
time.push(needObj[partId]);
|
time.push(needObj[partId]);
|
||||||
}
|
}
|
||||||
|
|
||||||
desk.role = roleIDs.map(roleId=>
|
deskObj.role = roleIDs.map(roleId=>
|
||||||
{
|
{
|
||||||
const role = RoleList[/**@type{string}*/(roleId)];
|
const role = RoleList[/**@type{string}*/(roleId)];
|
||||||
role.user.forEach(u =>u.desk.add(desk));
|
role.user.forEach(u =>u.desk.add(deskObj));
|
||||||
return role;
|
return role;
|
||||||
});
|
});
|
||||||
|
|
||||||
desk.make = makePartIDs.map( partId=>
|
deskObj.make = makePartIDs.map( partId=>
|
||||||
{
|
{
|
||||||
const part = PartList[/**@type{string}*/(partId)];
|
const part = PartList[/**@type{string}*/(partId)];
|
||||||
part.make.push(desk);
|
part.make.push(deskObj);
|
||||||
return part;
|
return part;
|
||||||
} )
|
} )
|
||||||
|
|
||||||
DeskList[deskId] = desk;
|
DeskList[deskId] = deskObj;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Apply passes
|
// Apply passes
|
||||||
for(let passID in passes)
|
for(let passID in pass)
|
||||||
{
|
{
|
||||||
const [name, users] = passes[passID];
|
const [name, users] = pass[passID];
|
||||||
/** @type {TYPES.Pass} */
|
/** @type {TYPES.Pass} */
|
||||||
const pass = {name, path:passID};
|
const passObj = {name, path:passID};
|
||||||
|
|
||||||
for(let userID in users)
|
for(let userID in users)
|
||||||
{
|
{
|
||||||
@ -98,11 +98,11 @@ export default function({users, roles, parts, desks, passes})
|
|||||||
/** @type {TYPES.Work} */
|
/** @type {TYPES.Work} */
|
||||||
const work = [user, time, data];
|
const work = [user, time, data];
|
||||||
|
|
||||||
let partPass = part.pass.get(pass);
|
let partPass = part.pass.get(passObj);
|
||||||
if(!partPass)
|
if(!partPass)
|
||||||
{
|
{
|
||||||
partPass = {time:0, work:[]}
|
partPass = {time:0, work:[]}
|
||||||
part.pass.set(pass, partPass);
|
part.pass.set(passObj, partPass);
|
||||||
}
|
}
|
||||||
partPass.work.push(work);
|
partPass.work.push(work);
|
||||||
if(partPass.time < time)
|
if(partPass.time < time)
|
||||||
@ -114,7 +114,14 @@ export default function({users, roles, parts, desks, passes})
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
console.log(users, parts, desks);
|
console.log(user, part, desk);
|
||||||
|
}
|
||||||
|
|
||||||
|
/** @type {TYPES.GraphLoader} */
|
||||||
|
export function Loader(params)
|
||||||
|
{
|
||||||
|
params.pass = globalThis.Pass;
|
||||||
|
Builder(params);
|
||||||
}
|
}
|
||||||
|
|
||||||
const Scan =(desk)=>
|
const Scan =(desk)=>
|
||||||
|
|||||||
@ -5,6 +5,15 @@
|
|||||||
<title>Document</title>
|
<title>Document</title>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
|
<script>
|
||||||
|
|
||||||
|
if ('serviceWorker' in navigator) {
|
||||||
|
navigator.serviceWorker.register('/service-worker.js')
|
||||||
|
.then(reg => console.log('Service Worker registered:', reg))
|
||||||
|
.catch(err => console.error('Service Worker registration failed:', err));
|
||||||
|
}
|
||||||
|
|
||||||
|
</script>
|
||||||
<script src="app.js" type="module">
|
<script src="app.js" type="module">
|
||||||
</script>
|
</script>
|
||||||
</body>
|
</body>
|
||||||
|
|||||||
10
index.js
10
index.js
@ -2,21 +2,21 @@ import Graph from "./graph.js";
|
|||||||
import User from "./data/users.js"
|
import User from "./data/users.js"
|
||||||
|
|
||||||
Graph({
|
Graph({
|
||||||
users:User,
|
user:User,
|
||||||
roles:
|
role:
|
||||||
{
|
{
|
||||||
dev:["Development", "u1"]
|
dev:["Development", "u1"]
|
||||||
},
|
},
|
||||||
parts:
|
part:
|
||||||
{
|
{
|
||||||
p1:"hey",
|
p1:"hey",
|
||||||
p2:"sup"
|
p2:"sup"
|
||||||
},
|
},
|
||||||
desks:
|
desk:
|
||||||
{
|
{
|
||||||
d1:["Desk 01", ["dev"], "all", {p2:3}, "p1"]
|
d1:["Desk 01", ["dev"], "all", {p2:3}, "p1"]
|
||||||
},
|
},
|
||||||
passes:
|
pass:
|
||||||
{
|
{
|
||||||
pass1:
|
pass1:
|
||||||
[
|
[
|
||||||
|
|||||||
@ -0,0 +1 @@
|
|||||||
|
{"name":"a room!"}
|
||||||
23
room/room_01/room.js
Normal file
23
room/room_01/room.js
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
console.log("CUSTOM ROOM IMPORTED", import.meta.resolve("./"))
|
||||||
|
|
||||||
|
import {Loader} from "../../graph.js";
|
||||||
|
import User from "../../data/users.js";
|
||||||
|
|
||||||
|
Loader({
|
||||||
|
user:User,
|
||||||
|
role:
|
||||||
|
{
|
||||||
|
dev:["Development", "u1"]
|
||||||
|
},
|
||||||
|
part:
|
||||||
|
{
|
||||||
|
p1:"hey",
|
||||||
|
p2:"sup"
|
||||||
|
},
|
||||||
|
desk:
|
||||||
|
{
|
||||||
|
d1:["Desk 01", ["dev"], "all", {p2:3}, "p1"]
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
console.log("Graph loaded !!");
|
||||||
31
service-worker.js
Normal file
31
service-worker.js
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
self.addEventListener('install', (event) => {
|
||||||
|
console.log('[Service Worker] Installed');
|
||||||
|
self.skipWaiting(); // Activate worker immediately
|
||||||
|
});
|
||||||
|
|
||||||
|
self.addEventListener('activate', (event) => {
|
||||||
|
console.log('[Service Worker] Activated');
|
||||||
|
return self.clients.claim(); // Become available to all pages
|
||||||
|
});
|
||||||
|
|
||||||
|
self.addEventListener('fetch', (event) => {
|
||||||
|
const url = new URL(event.request.url);
|
||||||
|
|
||||||
|
// Intercept only JavaScript files
|
||||||
|
if (url.pathname.endsWith('/room.js')) {
|
||||||
|
console.log('[Service Worker] Intercepted JS request:', url.href);
|
||||||
|
|
||||||
|
console.log(globalThis.Rooms);
|
||||||
|
|
||||||
|
// You can modify this to return a custom response if needed
|
||||||
|
event.respondWith(fetch(event.request));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
self.addEventListener('message', (event) => {
|
||||||
|
console.log('Received message in Service Worker:', event.data);
|
||||||
|
|
||||||
|
// You can respond or act based on the message
|
||||||
|
});
|
||||||
|
|
||||||
42
types.ts
42
types.ts
@ -20,11 +20,43 @@ export type GraphBuilder=
|
|||||||
>
|
>
|
||||||
(
|
(
|
||||||
params:{
|
params:{
|
||||||
users:Users,
|
user:Users,
|
||||||
roles:Roles,
|
role:Roles,
|
||||||
parts:Parts,
|
part:Parts,
|
||||||
desks:Desks,
|
desk:Desks,
|
||||||
passes:Pass,
|
pass:Pass,
|
||||||
|
}
|
||||||
|
)
|
||||||
|
=>void
|
||||||
|
|
||||||
|
|
||||||
|
export type GraphLoader=
|
||||||
|
<
|
||||||
|
Users extends Record<string, string>,
|
||||||
|
Roles extends Record<string, [ name:string, ...users:Array<keyof Users>]>,
|
||||||
|
Parts extends Record<string, string>,
|
||||||
|
Desks extends Record<string, [ name:string, roles:Array<keyof Roles>, mode:"all"|"one", need:Partial<Record<keyof Parts, number>>, ...make:Array<keyof Parts>]>,
|
||||||
|
Passes extends Record<
|
||||||
|
string,
|
||||||
|
[
|
||||||
|
name:string,
|
||||||
|
user:Partial<Record<
|
||||||
|
keyof Users,
|
||||||
|
Partial<Record<
|
||||||
|
keyof Parts,
|
||||||
|
Array<[time:number, data:string]>
|
||||||
|
>>
|
||||||
|
>>
|
||||||
|
]
|
||||||
|
>
|
||||||
|
>
|
||||||
|
(
|
||||||
|
params:{
|
||||||
|
user:Users,
|
||||||
|
role:Roles,
|
||||||
|
part:Parts,
|
||||||
|
desk:Desks,
|
||||||
|
pass?:Passes,
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
=>void
|
=>void
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user