Compare commits
2 Commits
feat/issue
...
main
| Author | SHA1 | Date | |
|---|---|---|---|
| fe66e5a72a | |||
| 6bf98ebcb8 |
@@ -1,15 +0,0 @@
|
|||||||
#import "/src/core/utils.typ": get-ctx, set-ctx
|
|
||||||
|
|
||||||
#let render(sync) = get-ctx(ctx => {
|
|
||||||
set-ctx(c => {
|
|
||||||
c.hidden = true
|
|
||||||
return c
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
#let render-end(sync) = get-ctx(ctx => {
|
|
||||||
set-ctx(c => {
|
|
||||||
c.hidden = false
|
|
||||||
return c
|
|
||||||
})
|
|
||||||
})
|
|
||||||
@@ -319,8 +319,7 @@
|
|||||||
level: 0,
|
level: 0,
|
||||||
lines: ()
|
lines: ()
|
||||||
)),
|
)),
|
||||||
in-sync: false,
|
in-sync: false
|
||||||
hidden: false,
|
|
||||||
)
|
)
|
||||||
chronos-ctx.insert(
|
chronos-ctx.insert(
|
||||||
"widths",
|
"widths",
|
||||||
@@ -380,15 +379,11 @@
|
|||||||
(elmt,)
|
(elmt,)
|
||||||
} else if "draw" in elmt and elmt.type != "par" {
|
} else if "draw" in elmt and elmt.type != "par" {
|
||||||
get-ctx(ctx => {
|
get-ctx(ctx => {
|
||||||
let drawn = if ctx.in-sync and elmt.type != "sync-end" {
|
if ctx.in-sync and elmt.type != "sync-end" {
|
||||||
in-sync-render(elmt)
|
in-sync-render(elmt)
|
||||||
} else {
|
} else {
|
||||||
(elmt.draw)(elmt)
|
(elmt.draw)(elmt)
|
||||||
}
|
}
|
||||||
if ctx.hidden and elmt.type != "hide-end" {
|
|
||||||
drawn = draw.hide(drawn)
|
|
||||||
}
|
|
||||||
drawn
|
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,5 +1,4 @@
|
|||||||
#import "draw/group.typ": render-end as grp-render-end
|
#import "draw/group.typ": render-end as grp-render-end
|
||||||
#import "draw/hide.typ": render-end as hide-render-end
|
|
||||||
#import "draw/sync.typ": render-end as sync-render-end
|
#import "draw/sync.typ": render-end as sync-render-end
|
||||||
#import "utils.typ": get-group-span, is-elmt
|
#import "utils.typ": get-group-span, is-elmt
|
||||||
#import "/src/participant.typ": _exists as par-exists, _par
|
#import "/src/participant.typ": _exists as par-exists, _par
|
||||||
@@ -38,21 +37,6 @@
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
#let flatten-hide(elmts, i) = {
|
|
||||||
let hide = elmts.at(i)
|
|
||||||
elmts.at(i) = hide
|
|
||||||
return (
|
|
||||||
elmts.slice(0, i + 1) +
|
|
||||||
hide.elmts +
|
|
||||||
((
|
|
||||||
type: "hide-end",
|
|
||||||
draw: hide-render-end,
|
|
||||||
start-i: i
|
|
||||||
),) +
|
|
||||||
elmts.slice(i+1)
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
#let update-group-children(elmts, i) = {
|
#let update-group-children(elmts, i) = {
|
||||||
let elmts = elmts
|
let elmts = elmts
|
||||||
let group-end = elmts.at(i)
|
let group-end = elmts.at(i)
|
||||||
@@ -97,9 +81,6 @@
|
|||||||
} else if elmt.type == "sync" {
|
} else if elmt.type == "sync" {
|
||||||
elmts = flatten-sync(elmts, i)
|
elmts = flatten-sync(elmts, i)
|
||||||
|
|
||||||
} else if elmt.type == "hide" {
|
|
||||||
elmts = flatten-hide(elmts, i)
|
|
||||||
|
|
||||||
} else if elmt.type == "seq" {
|
} else if elmt.type == "seq" {
|
||||||
if elmt.enable-dst {
|
if elmt.enable-dst {
|
||||||
activation-history.push(elmt)
|
activation-history.push(elmt)
|
||||||
|
|||||||
@@ -4,5 +4,5 @@
|
|||||||
#import "sequence.typ": _seq, _ret
|
#import "sequence.typ": _seq, _ret
|
||||||
#import "group.typ": _grp, _loop, _alt, _opt, _break
|
#import "group.typ": _grp, _loop, _alt, _opt, _break
|
||||||
#import "participant.typ": _par
|
#import "participant.typ": _par
|
||||||
#import "misc.typ": _sep, _delay, _sync, _gap, _evt, _col, _hide
|
#import "misc.typ": _sep, _delay, _sync, _gap, _evt, _col
|
||||||
#import "note.typ": _note
|
#import "note.typ": _note
|
||||||
@@ -1,6 +1,5 @@
|
|||||||
#import "core/draw/delay.typ"
|
#import "core/draw/delay.typ"
|
||||||
#import "core/draw/event.typ": render as evt-render
|
#import "core/draw/event.typ": render as evt-render
|
||||||
#import "core/draw/hide.typ"
|
|
||||||
#import "core/draw/separator.typ"
|
#import "core/draw/separator.typ"
|
||||||
#import "core/draw/sync.typ"
|
#import "core/draw/sync.typ"
|
||||||
#import "core/utils.typ": set-ctx
|
#import "core/utils.typ": set-ctx
|
||||||
@@ -64,11 +63,3 @@
|
|||||||
max-width: max-width
|
max-width: max-width
|
||||||
),)
|
),)
|
||||||
}
|
}
|
||||||
|
|
||||||
#let _hide(elmts) = {
|
|
||||||
return ((
|
|
||||||
type: "hide",
|
|
||||||
draw: hide.render,
|
|
||||||
elmts: elmts
|
|
||||||
),)
|
|
||||||
}
|
|
||||||
Reference in New Issue
Block a user