intermediate #1

Merged
yves-biener merged 31 commits from intermediate into main 2025-02-16 16:02:59 +01:00
2 changed files with 8 additions and 12 deletions
Showing only changes of commit 5c148e1aa5 - Show all commits

View File

@@ -24,15 +24,11 @@ pub fn main() !void {
defer renderer.deinit();
var container = try App.Container.init(allocator, .{
.border = .{
.color = .blue,
.corners = .rounded,
.sides = .all(),
.separator = .{ .enabled = true },
},
.border = .{ .separator = .{ .enabled = true } },
.layout = .{
.gap = 2,
.padding = .all(5),
.direction = .vertical,
.direction = .horizontal,
},
});
var box = try App.Container.init(allocator, .{

View File

@@ -83,7 +83,7 @@ pub const Border = packed struct {
if (this.sides.bottom) cells[last_row + col].style.fg = this.color;
}
// render left and right border
for (1..size.rows - 1) |row| {
for (1..size.rows -| 1) |row| {
const idx = (row * size.cols);
if (this.sides.left) {
cells[idx].cp = frame[3]; // left
@@ -133,7 +133,7 @@ pub const Border = packed struct {
};
switch (layout.direction) {
.horizontal => {
offset += (layout.gap + 1) / 2;
offset += layout.gap / 2;
for (0..len - 1) |_| {
var cols = element_cols;
if (overflow > 0) {
@@ -141,7 +141,7 @@ pub const Border = packed struct {
cols += 1;
}
offset += cols;
for (1..size.rows - 1) |row| {
for (1..size.rows -| 1) |row| {
// TODO: support the line options
cells[row * size.cols + offset].cp = frame[3];
cells[row * size.cols + offset].style.fg = this.separator.color;
@@ -150,7 +150,7 @@ pub const Border = packed struct {
}
},
.vertical => {
offset += (layout.gap + 1) / 2;
offset += layout.gap / 2;
for (0..len - 1) |_| {
var rows = element_rows;
if (overflow > 0) {
@@ -158,7 +158,7 @@ pub const Border = packed struct {
rows += 1;
}
offset += rows;
for (1..size.cols - 1) |col| {
for (1..size.cols -| 1) |col| {
// TODO: support the line options
cells[offset * size.cols + col].cp = frame[1];
cells[offset * size.cols + col].style.fg = this.separator.color;