add typings/parsing
This commit is contained in:
parent
697f8a2d7d
commit
ef1fb55057
@ -32,8 +32,9 @@ export function Room({user, role, part, desk, pass})
|
||||
const PartList = part;
|
||||
for(let partId in part)
|
||||
{
|
||||
const name = part[partId];
|
||||
PartList[partId] = /** @type {TYPES.Part} */({name, id:partId, need:[], make:[], pass:new Map()});
|
||||
const [name, loop] = part[partId];
|
||||
|
||||
PartList[partId] = /** @type {TYPES.Part} */({name, id:partId, need:[], make:[], pass:new Map(), loop:loop});
|
||||
}
|
||||
|
||||
// mutate desks
|
||||
@ -42,7 +43,7 @@ export function Room({user, role, part, desk, pass})
|
||||
const DeskList = desk;
|
||||
for(let deskId in desk)
|
||||
{
|
||||
const [name, roleIDs, mode, needObj, ...makePartIDs] = desk[deskId];
|
||||
const [name, roleIDs, needObj, ...makePartIDs] = desk[deskId];
|
||||
/** @type {TYPES.Part[]}*/ const need =[];
|
||||
/** @type {number[]}*/ const time =[];
|
||||
|
||||
@ -50,7 +51,6 @@ export function Room({user, role, part, desk, pass})
|
||||
const deskObj = {
|
||||
name,
|
||||
id:deskId,
|
||||
mode,
|
||||
need,
|
||||
time,
|
||||
make:[],
|
||||
|
||||
@ -1,17 +1,25 @@
|
||||
export type User = {name:string, id:string, desk:Set<Desk>};
|
||||
export type Role = {name:string, id:string, user:User[]};
|
||||
export type Desk = {name:string, id:string, need:Part[], time:number[], make:Part[], pass:Map<Pass, Scan>, mode:string, role:Role[]};
|
||||
export type Desk = {name:string, id:string, need:Part[], time:number[], make:Part[], pass:Map<Pass, Scan>, role:Role[]};
|
||||
export type Pass = {name:string, id:string, path:string, live:boolean, load:()=>Promise<void>, dump:()=>void};
|
||||
export type Part = {name:string, id:string, pass:Map<Pass, {time:number, work:Work[], make:(user:User, data:string)=>Promise<void>}>, need:Desk[], make:Desk[]};
|
||||
export type Part = {name:string, id:string, pass:Map<Pass, {time:number, work:Work[], make:(user:User, data:string)=>Promise<void>}>, need:Desk[], make:Desk[], loop?:boolean};
|
||||
export type Work = [time:number, data:string, user:User];
|
||||
export type Scan = {need_dirty:number[], make_dirty:number[], need_empty:number[], make_empty:number[]}
|
||||
|
||||
/*
|
||||
|
||||
Loops:
|
||||
- are considered clean when empty
|
||||
- can receive a no-op value that considers them clean
|
||||
|
||||
*/
|
||||
|
||||
export type GraphBuilder=
|
||||
<
|
||||
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>]>,
|
||||
Parts extends Record<string, [ name:string, loop?:"loop"] >,
|
||||
Desks extends Record<string, [ name:string, roles:Array<keyof Roles>, need:Partial<Record<keyof Parts, number>>, ...make:Array<keyof Parts>]>,
|
||||
>
|
||||
(
|
||||
params:{
|
||||
|
||||
@ -19,14 +19,16 @@ export default CreateAllRooms({
|
||||
admin:["Admin", "u4"]
|
||||
},
|
||||
part:{
|
||||
p1:"Page title",
|
||||
p2:"Page slug",
|
||||
p3:"Page preview",
|
||||
p4:"Page Project",
|
||||
p1:["Page title"],
|
||||
p2:["Page slug"],
|
||||
p3:["Page preview"],
|
||||
p4:["Page Project"],
|
||||
p5:["Page Corrections", "loop"],
|
||||
},
|
||||
desk:{
|
||||
d1:["Write page metas", ["admin", "write"], "all", {}, "p1", "p2"],
|
||||
d2:["Build Page preview", ["admin", "dev"], "all", {p1:1, p2:1}, "p3", "p4"]
|
||||
d1:["Write page metas", ["admin", "write"], { }, "p1", "p2"],
|
||||
d2:["Build Page preview", ["admin", "dev" ], {p1:1, p2:1, p5:1}, "p3", "p4"],
|
||||
d3:["Proof Page", ["admin", "write"], {p3:1, p5:1 }, "p5" ]
|
||||
},
|
||||
pass:{
|
||||
pass_01:["January"],
|
||||
|
||||
Loading…
Reference in New Issue
Block a user