Files
Terminal-DAW/src/ui/widgets/timeline.py

84 lines
2.2 KiB
Python
Raw Normal View History

from textual.containers import Vertical, VerticalScroll, Horizontal, VerticalGroup, HorizontalGroup
from textual.widgets import Rule
2026-01-13 16:06:57 +11:00
from textual.app import ComposeResult
from ui.widgets.chunk_types.audio import AudioChunk, Chunk
from ui.widgets.play_head import PlayHead
from project import ChunkType
2026-01-13 20:06:28 +11:00
2026-01-13 16:06:57 +11:00
class TimelineRow(Horizontal):
DEFAULT_CSS = """
TimelineRow {
background: $surface-lighten-1;
max-height: 8;
2026-01-13 16:06:57 +11:00
margin-bottom: 1;
}
"""
class Timeline(Vertical):
2026-01-13 16:06:57 +11:00
DEFAULT_CSS = """
Timeline {
#rows {
hatch: "-" $surface-lighten-1;
padding: 1 0;
.beat-line {
color: $surface-lighten-1;
}
.bar-line {
color: $surface-lighten-2;
}
.beat-line, .bar-line {
dock: left;
margin: 0;
}
}
PlayHead {
layer: top;
}
2026-01-13 16:06:57 +11:00
}
"""
def __init__(self):
super().__init__()
self.bar_offset = self.app.project.bpm / 8 * (0.0333 / self.app.zoom_level)
2026-01-13 16:06:57 +11:00
def compose(self) -> ComposeResult:
with VerticalScroll(id="rows"):
for i in range(1, 17):
bar = None
if (i) % 4 == 0:
bar = Rule.vertical(classes="bar-line", line_style="double")
else:
bar = Rule.vertical(classes="beat-line")
bar.offset = (self.bar_offset * i, 0)
yield bar
for channel in self.app.project.channels:
with TimelineRow():
for chunk in channel.chunks:
if chunk.chunk_type == ChunkType.CHUNK:
yield Chunk(chunk_name=chunk.name)
elif chunk.chunk_type == ChunkType.AUDIO:
yield AudioChunk(chunk.audio_data, chunk.sample_rate, chunk.name)
#yield PlayHead()