- Added DeesDashboardgrid class for managing a grid of dashboard widgets. - Implemented widget dragging and resizing capabilities. - Introduced layout management with collision detection and margin resolution. - Created styles for grid layout, widget appearance, and animations. - Added support for customizable margins, cell height, and grid lines. - Included methods for adding, removing, and updating widgets dynamically. - Implemented context menu for widget actions and keyboard navigation support. - Established a responsive design with breakpoint handling for different layouts.
48 lines
2.5 KiB
Markdown
48 lines
2.5 KiB
Markdown
# dees-dashboardgrid
|
|
|
|
`<dees-dashboardgrid>` renders a configurable dashboard layout with draggable and resizable tiles. The component is now grouped in its own folder alongside supporting utilities and styles.
|
|
|
|
## Key Features
|
|
|
|
- Pointer-driven drag and resize interactions with keyboard fallbacks (arrow keys to move, `Shift` + arrows to resize).
|
|
- Collision-aware placement that swaps compatible tiles or displaces blocking tiles into the next free slot.
|
|
- Context menu (right-click on a tile header) that exposes destructive actions such as tile removal via `dees-contextmenu`.
|
|
- Layout persistence helpers via `getLayout()`, `setLayout(...)`, and the `layout-change` event.
|
|
- Responsive presets through the `layouts` map and `applyBreakpointLayout(...)` helper to hydrate per-breakpoint arrangements.
|
|
|
|
## Public API Highlights
|
|
|
|
| Property | Description |
|
|
| --- | --- |
|
|
| `widgets` | Array of tile descriptors (`DashboardWidget`). |
|
|
| `columns` | Number of grid columns. |
|
|
| `layouts` | Optional record of named layout definitions. |
|
|
| `activeBreakpoint` | Name of the currently applied breakpoint layout. |
|
|
| `editable` | Toggles drag/resize affordances. |
|
|
|
|
| Method | Description |
|
|
| --- | --- |
|
|
| `addWidget(widget, autoPosition?)` | Adds a tile, optionally auto-placing it into the next free slot. |
|
|
| `removeWidget(id)` | Removes a tile and emits `widget-remove`. |
|
|
| `applyBreakpointLayout(name)` | Applies a layout from the `layouts` map. |
|
|
| `getLayout()` / `setLayout(layout)` | Retrieve or apply persisted layouts. |
|
|
| `compact(direction?)` | Densifies the grid vertically (default) or horizontally. |
|
|
|
|
| Event | Detail payload |
|
|
| --- | --- |
|
|
| `widget-move` | `{ widget, displaced, swappedWith }` |
|
|
| `widget-resize` | `{ widget, displaced, swappedWith }` |
|
|
| `widget-remove` | `{ widget }` |
|
|
| `layout-change` | `{ layout }` |
|
|
|
|
## Usage Notes
|
|
|
|
- **Right-click** a tile header to open the contextual menu and delete the tile.
|
|
- When resizing, blocking tiles will automatically reflow into free space once the interaction completes.
|
|
- Listen to `layout-change` to persist layouts to storage; rehydrate using `setLayout` or the `layouts` map.
|
|
- For responsive dashboards, populate `grid.layouts = { base: [...], mobile: [...] }` and call `applyBreakpointLayout` based on your own breakpoint logic (see the co-located demo for an example).
|
|
|
|
## Demo
|
|
|
|
The updated `dees-dashboardgrid.demo.ts` showcases live breakpoint switching, layout persistence, and the context menu. Run the demo gallery to explore the interactions end-to-end.
|