mirror of
https://github.com/XRPLF/xrpl-dev-portal.git
synced 2025-12-06 17:27:57 +00:00
6.8 KiB
6.8 KiB
PageGrid Component
A responsive grid system component for creating flexible layouts with support for multiple breakpoints.
Overview
The PageGrid component provides a flexible grid layout system with three main components:
PageGrid- The container componentPageGrid.Row- Row component for grouping columnsPageGrid.Col- Column component with responsive sizing and offset support
Breakpoints
The grid system supports the following breakpoints:
base- Default/mobile (applies to all sizes)sm- Small screensmd- Medium screenslg- Large screensxl- Extra large screens
Basic Usage
import { PageGrid } from '@/shared/components/PageGrid/page-grid';
function MyComponent() {
return (
<PageGrid>
<PageGrid.Row>
<PageGrid.Col span={6}>
Column 1
</PageGrid.Col>
<PageGrid.Col span={6}>
Column 2
</PageGrid.Col>
</PageGrid.Row>
</PageGrid>
);
}
PageGrid Props
The root PageGrid component accepts all standard HTML div attributes:
| Prop | Type | Description |
|---|---|---|
className |
string |
Additional CSS classes to apply |
...rest |
HTMLDivElement attributes |
Any other HTML div attributes |
PageGrid.Row Props
The PageGrid.Row component accepts all standard HTML div attributes:
| Prop | Type | Description |
|---|---|---|
className |
string |
Additional CSS classes to apply |
...rest |
HTMLDivElement attributes |
Any other HTML div attributes |
PageGrid.Col Props
| Prop | Type | Description |
|---|---|---|
span |
number | "auto" | "fill" | ResponsiveValue |
Column span width |
offset |
number | ResponsiveValue |
Column offset (left margin) |
className |
string |
Additional CSS classes to apply |
...rest |
HTMLDivElement attributes |
Any other HTML div attributes |
Span Values
- Number (e.g.,
1-12): Fixed column width - "auto": Column takes up only the space it needs
- "fill": Column fills remaining available space
- Responsive Object: Different spans for different breakpoints
Offset Values
- Number (e.g.,
1-12): Number of columns to offset - Responsive Object: Different offsets for different breakpoints
Examples
Fixed Column Widths
<PageGrid>
<PageGrid.Row>
<PageGrid.Col span={4}>Sidebar</PageGrid.Col>
<PageGrid.Col span={8}>Main Content</PageGrid.Col>
</PageGrid.Row>
</PageGrid>
Auto and Fill
<PageGrid>
<PageGrid.Row>
<PageGrid.Col span="auto">Minimal Width</PageGrid.Col>
<PageGrid.Col span="fill">Takes Remaining Space</PageGrid.Col>
<PageGrid.Col span="auto">Another Auto</PageGrid.Col>
</PageGrid.Row>
</PageGrid>
Responsive Layout
Create layouts that adapt to different screen sizes:
<PageGrid>
<PageGrid.Row>
<PageGrid.Col
span={{
base: 12, // Full width on mobile
sm: 12, // Full width on small screens
md: 6, // Half width on medium screens
lg: 4, // Third width on large screens
xl: 3 // Quarter width on extra large screens
}}
>
Responsive Column
</PageGrid.Col>
</PageGrid.Row>
</PageGrid>
Using Offsets
Center content or create spacing with offsets:
<PageGrid>
<PageGrid.Row>
{/* Center an 8-column element */}
<PageGrid.Col span={8} offset={2}>
Centered Content
</PageGrid.Col>
</PageGrid.Row>
</PageGrid>
Responsive Offsets
<PageGrid>
<PageGrid.Row>
<PageGrid.Col
span={6}
offset={{
base: 0, // No offset on mobile
md: 3 // Offset by 3 columns on medium+ screens
}}
>
Content
</PageGrid.Col>
</PageGrid.Row>
</PageGrid>
Complex Responsive Layout
<PageGrid>
<PageGrid.Row>
{/* Hero section */}
<PageGrid.Col span={12}>
<h1>Page Title</h1>
</PageGrid.Col>
</PageGrid.Row>
<PageGrid.Row>
{/* Sidebar - full width on mobile, 1/3 on desktop */}
<PageGrid.Col
span={{
base: 12,
lg: 4
}}
>
<aside>Sidebar</aside>
</PageGrid.Col>
{/* Main content - full width on mobile, 2/3 on desktop */}
<PageGrid.Col
span={{
base: 12,
lg: 8
}}
>
<main>Main Content</main>
</PageGrid.Col>
</PageGrid.Row>
</PageGrid>
Multiple Columns with Equal Width
<PageGrid>
<PageGrid.Row>
<PageGrid.Col span={3}>Column 1</PageGrid.Col>
<PageGrid.Col span={3}>Column 2</PageGrid.Col>
<PageGrid.Col span={3}>Column 3</PageGrid.Col>
<PageGrid.Col span={3}>Column 4</PageGrid.Col>
</PageGrid.Row>
</PageGrid>
Nested Grids
<PageGrid>
<PageGrid.Row>
<PageGrid.Col span={12}>
<PageGrid>
<PageGrid.Row>
<PageGrid.Col span={6}>Nested Column 1</PageGrid.Col>
<PageGrid.Col span={6}>Nested Column 2</PageGrid.Col>
</PageGrid.Row>
</PageGrid>
</PageGrid.Col>
</PageGrid.Row>
</PageGrid>
CSS Classes Generated
The component generates the following CSS classes:
Container
xrpl-grid__container
Row
xrpl-grid__row
Column Spans
xrpl-grid__col-{number}(e.g.,xrpl-grid__col-6)xrpl-grid__col-autoxrpl-grid__col(for fill)xrpl-grid__col-{breakpoint}-{number}(e.g.,xrpl-grid__col-md-6)xrpl-grid__col-{breakpoint}-autoxrpl-grid__col-{breakpoint}(for fill)
Column Offsets
xrpl-grid__offset-{number}(e.g.,xrpl-grid__offset-2)xrpl-grid__offset-{breakpoint}-{number}(e.g.,xrpl-grid__offset-md-2)
TypeScript Types
type PageGridBreakpoint = "base" | "sm" | "md" | "lg" | "xl";
type ResponsiveValue<T> = T | Partial<Record<PageGridBreakpoint, T>>;
type PageGridSpanValue = number | "auto" | "fill";
type PageGridOffsetValue = number;
interface PageGridColProps {
span?: ResponsiveValue<PageGridSpanValue>;
offset?: ResponsiveValue<PageGridOffsetValue>;
className?: string;
// ... plus all HTMLDivElement attributes
}
Best Practices
- Use semantic HTML: Wrap content in appropriate semantic elements within columns
- Mobile-first: Start with base/mobile layout and progressively enhance for larger screens
- Keep it simple: Avoid overly complex nested grid structures when possible
- Test responsiveness: Verify layouts work well at all breakpoint transitions
- Accessibility: Ensure grid layouts maintain logical reading order for screen readers
Notes
- The total columns in the grid system is typically 12 (though this depends on your CSS implementation)
- Responsive values cascade - if you don't specify a value for a breakpoint, it inherits from the previous breakpoint
- All components forward refs, allowing you to attach refs to the underlying DOM elements