- Add TypeHint node type in parser for //- @TypeOf(field): type syntax
- Support scalar types (f32, i32, bool, etc.) and array/struct types
- Use helpers.appendValue() for non-string typed fields
- Filter out loop variable references from Data struct fields
- Preserve @TypeOf comments during comment stripping
Example usage:
//- @TypeOf(subtotal): f32
span $#{subtotal}
//- @TypeOf(items): []{name: []const u8, price: f32}
each item in items
h3 #{item.name}
52 lines
1.5 KiB
Plaintext
52 lines
1.5 KiB
Plaintext
extends layouts/base.pug
|
|
|
|
block title
|
|
title #{title} | Pugz Store
|
|
|
|
block content
|
|
section.page-header
|
|
.container
|
|
h1 Shopping Cart
|
|
p Review your items before checkout
|
|
|
|
section.section
|
|
.container
|
|
.cart-layout
|
|
.cart-main
|
|
.cart-items
|
|
//- @TypeOf(cartItems): []{name: []const u8, variant: []const u8, price: f32, quantity: u16, total: f32}
|
|
each item in cartItems
|
|
.cart-item
|
|
.cart-item-info
|
|
h3 #{item.name}
|
|
p.text-muted #{item.variant}
|
|
span.cart-item-price $#{item.price}
|
|
.cart-item-qty
|
|
button.qty-btn -
|
|
input.qty-input(type="text" value=item.quantity)
|
|
button.qty-btn +
|
|
.cart-item-total $#{item.total}
|
|
button.cart-item-remove x
|
|
|
|
.cart-actions
|
|
a.btn.btn-outline(href="/products") Continue Shopping
|
|
|
|
.cart-summary
|
|
h3 Order Summary
|
|
.summary-row
|
|
span Subtotal
|
|
//- @TypeOf(subtotal): f32
|
|
span $#{subtotal}
|
|
.summary-row
|
|
span Shipping
|
|
span.text-success Free
|
|
.summary-row
|
|
span Tax
|
|
//- @TypeOf(tax): f32
|
|
span $#{tax}
|
|
.summary-row.summary-total
|
|
span Total
|
|
//- @TypeOf(total): f32
|
|
span $#{total}
|
|
a.btn.btn-primary.btn-block(href="/checkout") Proceed to Checkout
|