Compare commits
2 Commits
57269ae983
...
03b7fa1157
| Author | SHA1 | Date | |
|---|---|---|---|
|
03b7fa1157
|
|||
|
e01d180445
|
@@ -3,6 +3,9 @@
|
|||||||
#let render(sync) = get-ctx(ctx => {
|
#let render(sync) = get-ctx(ctx => {
|
||||||
set-ctx(c => {
|
set-ctx(c => {
|
||||||
c.hidden = true
|
c.hidden = true
|
||||||
|
for i in range(c.lifelines.len()) {
|
||||||
|
c.lifelines.at(i).lines.push(("hide",))
|
||||||
|
}
|
||||||
return c
|
return c
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
@@ -10,6 +13,9 @@
|
|||||||
#let render-end(sync) = get-ctx(ctx => {
|
#let render-end(sync) = get-ctx(ctx => {
|
||||||
set-ctx(c => {
|
set-ctx(c => {
|
||||||
c.hidden = false
|
c.hidden = false
|
||||||
|
for i in range(c.lifelines.len()) {
|
||||||
|
c.lifelines.at(i).lines.push(("unhide",))
|
||||||
|
}
|
||||||
return c
|
return c
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -320,9 +320,20 @@
|
|||||||
let destructions = ()
|
let destructions = ()
|
||||||
let lines = ()
|
let lines = ()
|
||||||
|
|
||||||
|
let hidden = false
|
||||||
|
|
||||||
// Compute lifeline rectangles + destruction positions
|
// Compute lifeline rectangles + destruction positions
|
||||||
for line in ctx.lifelines.at(p.i).lines {
|
for line in ctx.lifelines.at(p.i).lines {
|
||||||
let event = line.first()
|
let event = line.first()
|
||||||
|
if event == "hide" {
|
||||||
|
hidden = true
|
||||||
|
} else if event == "unhide" {
|
||||||
|
hidden = false
|
||||||
|
}
|
||||||
|
if hidden and event in ("create", "enable") {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
if event == "create" {
|
if event == "create" {
|
||||||
last-y = line.at(1)
|
last-y = line.at(1)
|
||||||
|
|
||||||
|
|||||||
@@ -1,12 +1,17 @@
|
|||||||
#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/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, is-touying-pause
|
||||||
#import "/src/participant.typ": _exists as par-exists, _par
|
#import "/src/participant.typ": _exists as par-exists, _par
|
||||||
#import "/src/sequence.typ": _seq
|
#import "/src/sequence.typ": _seq
|
||||||
|
|
||||||
#let flatten-group(elmts, i) = {
|
#let flatten-group(elmts, i) = {
|
||||||
let group = elmts.at(i)
|
let group = elmts.at(i)
|
||||||
|
for elmt in group.elmts {
|
||||||
|
if is-touying-pause(elmt) {
|
||||||
|
panic("Cannot pause inside of a group yet")
|
||||||
|
}
|
||||||
|
}
|
||||||
elmts.at(i) = group
|
elmts.at(i) = group
|
||||||
return (
|
return (
|
||||||
elmts.slice(0, i + 1) +
|
elmts.slice(0, i + 1) +
|
||||||
@@ -22,6 +27,11 @@
|
|||||||
|
|
||||||
#let flatten-sync(elmts, i) = {
|
#let flatten-sync(elmts, i) = {
|
||||||
let sync = elmts.at(i)
|
let sync = elmts.at(i)
|
||||||
|
for elmt in sync.elmts {
|
||||||
|
if is-touying-pause(elmt) {
|
||||||
|
panic("Cannot pause inside of a sync")
|
||||||
|
}
|
||||||
|
}
|
||||||
elmts.at(i) = sync
|
elmts.at(i) = sync
|
||||||
let start = sync
|
let start = sync
|
||||||
start.remove("elmts")
|
start.remove("elmts")
|
||||||
|
|||||||
@@ -10,6 +10,17 @@
|
|||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#let is-touying-pause(elmt) = {
|
||||||
|
if type(elmt) != content or elmt.func() != metadata {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
let kind = elmt.value.at("kind", default: "")
|
||||||
|
if type(kind) != str {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
return kind.starts-with("touying-jump")
|
||||||
|
}
|
||||||
|
|
||||||
#let normalize-units(value) = {
|
#let normalize-units(value) = {
|
||||||
if type(value) == int or type(value) == float {
|
if type(value) == int or type(value) == float {
|
||||||
return value
|
return value
|
||||||
@@ -33,6 +44,12 @@
|
|||||||
let pars-i = get-participants-i(participants)
|
let pars-i = get-participants-i(participants)
|
||||||
|
|
||||||
for elmt in group.elmts {
|
for elmt in group.elmts {
|
||||||
|
if not is-elmt(elmt) {
|
||||||
|
if is-touying-pause(elmt) {
|
||||||
|
panic("Cannot pause inside of a group yet")
|
||||||
|
}
|
||||||
|
continue
|
||||||
|
}
|
||||||
if elmt.type == "seq" {
|
if elmt.type == "seq" {
|
||||||
let i1 = pars-i.at(elmt.p1)
|
let i1 = pars-i.at(elmt.p1)
|
||||||
let i2 = pars-i.at(elmt.p2)
|
let i2 = pars-i.at(elmt.p2)
|
||||||
|
|||||||
Reference in New Issue
Block a user