feat: add interfaces for secondary menu items with various types and functionalities
This commit is contained in:
@@ -1,6 +1,7 @@
|
||||
import { html, css, DeesElement, customElement, state } from '@design.estate/dees-element';
|
||||
import type { DeesAppui } from './dees-appui.js';
|
||||
import type { IAppConfig, IViewActivationContext } from '../../interfaces/appconfig.js';
|
||||
import type * as interfaces from '../../interfaces/index.js';
|
||||
import '@design.estate/dees-wcctools/demotools';
|
||||
|
||||
// Demo view component with lifecycle hooks
|
||||
@@ -16,7 +17,7 @@ class DemoDashboardView extends DeesElement {
|
||||
this.activated = true;
|
||||
console.log('Dashboard activated with context:', context);
|
||||
|
||||
// Set view-specific secondary menu
|
||||
// Set view-specific secondary menu with new item types
|
||||
context.appui.setSecondaryMenu({
|
||||
heading: 'Dashboard',
|
||||
groups: [
|
||||
@@ -24,17 +25,36 @@ class DemoDashboardView extends DeesElement {
|
||||
name: 'Quick Access',
|
||||
iconName: 'lucide:zap',
|
||||
items: [
|
||||
{ key: 'overview', iconName: 'layoutDashboard', action: () => console.log('Overview') },
|
||||
{ key: 'recent', iconName: 'clock', badge: 5, action: () => console.log('Recent') },
|
||||
]
|
||||
{ key: 'Overview', iconName: 'layoutDashboard', action: () => console.log('Overview') },
|
||||
{ key: 'Recent', iconName: 'clock', badge: 5, action: () => console.log('Recent') },
|
||||
{ type: 'divider' },
|
||||
{ type: 'action', key: 'Refresh Data', iconName: 'lucide:refreshCw', action: () => alert('Refreshing dashboard data...') },
|
||||
] as interfaces.ISecondaryMenuItem[]
|
||||
},
|
||||
{
|
||||
name: 'Filters',
|
||||
iconName: 'lucide:filter',
|
||||
items: [
|
||||
{ type: 'header', label: 'Time Range' },
|
||||
{ type: 'filter', key: 'Live Updates', iconName: 'lucide:radio', active: true, onToggle: (active) => console.log('Live updates:', active) },
|
||||
{ type: 'filter', key: 'Show Archived', iconName: 'lucide:archive', active: false, onToggle: (active) => console.log('Show archived:', active) },
|
||||
{ type: 'divider' },
|
||||
{ type: 'multiFilter', key: 'Data Sources', iconName: 'lucide:database', options: [
|
||||
{ key: 'api', label: 'API Server', checked: true, iconName: 'lucide:server' },
|
||||
{ key: 'web', label: 'Web Traffic', checked: true, iconName: 'lucide:globe' },
|
||||
{ key: 'mobile', label: 'Mobile App', checked: false, iconName: 'lucide:smartphone' },
|
||||
], onChange: (keys) => console.log('Data sources:', keys) },
|
||||
] as interfaces.ISecondaryMenuItem[]
|
||||
},
|
||||
{
|
||||
name: 'Analytics',
|
||||
iconName: 'lucide:barChart3',
|
||||
items: [
|
||||
{ key: 'metrics', iconName: 'activity', action: () => console.log('Metrics') },
|
||||
{ key: 'reports', iconName: 'fileText', badge: 'new', badgeVariant: 'success', action: () => console.log('Reports') },
|
||||
]
|
||||
{ key: 'Metrics', iconName: 'activity', action: () => console.log('Metrics') },
|
||||
{ key: 'Reports', iconName: 'fileText', badge: 'new', badgeVariant: 'success', action: () => console.log('Reports') },
|
||||
{ type: 'divider' },
|
||||
{ type: 'link', key: 'Analytics Docs', iconName: 'lucide:externalLink', href: 'https://docs.example.com/analytics' },
|
||||
] as interfaces.ISecondaryMenuItem[]
|
||||
}
|
||||
]
|
||||
});
|
||||
@@ -322,11 +342,22 @@ class DemoProjectsView extends DeesElement {
|
||||
groups: [
|
||||
{
|
||||
name: 'My Projects',
|
||||
iconName: 'lucide:folder',
|
||||
items: [
|
||||
{ key: 'active', iconName: 'folder', badge: 3, action: () => console.log('Active') },
|
||||
{ key: 'archived', iconName: 'archive', action: () => console.log('Archived') },
|
||||
{ key: 'shared', iconName: 'users', badge: 2, badgeVariant: 'warning', action: () => console.log('Shared') },
|
||||
]
|
||||
{ key: 'Active', iconName: 'folder', badge: 3, action: () => console.log('Active') },
|
||||
{ key: 'Archived', iconName: 'archive', action: () => console.log('Archived') },
|
||||
{ key: 'Shared', iconName: 'users', badge: 2, badgeVariant: 'warning', action: () => console.log('Shared') },
|
||||
] as interfaces.ISecondaryMenuItem[]
|
||||
},
|
||||
{
|
||||
name: 'Quick Actions',
|
||||
iconName: 'lucide:zap',
|
||||
items: [
|
||||
{ type: 'action', key: 'New Project', iconName: 'lucide:folderPlus', action: () => alert('Create new project') },
|
||||
{ type: 'action', key: 'Import', iconName: 'lucide:download', action: () => alert('Import project') },
|
||||
{ type: 'divider' },
|
||||
{ type: 'link', key: 'Templates', iconName: 'lucide:layoutTemplate', href: 'https://templates.example.com' },
|
||||
] as interfaces.ISecondaryMenuItem[]
|
||||
}
|
||||
]
|
||||
});
|
||||
@@ -407,13 +438,40 @@ class DemoTasksView extends DeesElement {
|
||||
heading: 'Tasks',
|
||||
groups: [
|
||||
{
|
||||
name: 'Filters',
|
||||
name: 'Views',
|
||||
iconName: 'lucide:eye',
|
||||
items: [
|
||||
{ key: 'all', iconName: 'list', badge: 12, action: () => console.log('All') },
|
||||
{ key: 'today', iconName: 'calendar', badge: 3, action: () => console.log('Today') },
|
||||
{ key: 'upcoming', iconName: 'clock', action: () => console.log('Upcoming') },
|
||||
{ key: 'completed', iconName: 'checkCircle', action: () => console.log('Completed') },
|
||||
]
|
||||
{ key: 'All Tasks', iconName: 'list', badge: 12, action: () => console.log('All') },
|
||||
{ key: 'Today', iconName: 'calendar', badge: 3, action: () => console.log('Today') },
|
||||
{ key: 'Upcoming', iconName: 'clock', action: () => console.log('Upcoming') },
|
||||
{ key: 'Completed', iconName: 'checkCircle', action: () => console.log('Completed') },
|
||||
] as interfaces.ISecondaryMenuItem[]
|
||||
},
|
||||
{
|
||||
name: 'Filters',
|
||||
iconName: 'lucide:filter',
|
||||
items: [
|
||||
{ type: 'header', label: 'Priority' },
|
||||
{ type: 'multiFilter', key: 'Priority', iconName: 'lucide:flag', options: [
|
||||
{ key: 'high', label: 'High', checked: true, iconName: 'lucide:alertCircle' },
|
||||
{ key: 'medium', label: 'Medium', checked: true, iconName: 'lucide:minusCircle' },
|
||||
{ key: 'low', label: 'Low', checked: false, iconName: 'lucide:circle' },
|
||||
], onChange: (keys) => console.log('Priority filter:', keys) },
|
||||
{ type: 'divider' },
|
||||
{ type: 'header', label: 'Options' },
|
||||
{ type: 'filter', key: 'Show Subtasks', iconName: 'lucide:listTree', active: true, onToggle: (active) => console.log('Show subtasks:', active) },
|
||||
{ type: 'filter', key: 'Show Completed', iconName: 'lucide:checkSquare', active: false, onToggle: (active) => console.log('Show completed:', active) },
|
||||
] as interfaces.ISecondaryMenuItem[]
|
||||
},
|
||||
{
|
||||
name: 'Actions',
|
||||
iconName: 'lucide:zap',
|
||||
items: [
|
||||
{ type: 'action', key: 'Add Task', iconName: 'lucide:plus', action: () => alert('Add new task') },
|
||||
{ type: 'action', key: 'Import Tasks', iconName: 'lucide:upload', action: () => alert('Import tasks') },
|
||||
{ type: 'divider' },
|
||||
{ type: 'action', key: 'Clear Completed', iconName: 'lucide:trash2', variant: 'danger', confirmMessage: 'Delete all completed tasks?', action: () => alert('Cleared completed tasks') },
|
||||
] as interfaces.ISecondaryMenuItem[]
|
||||
}
|
||||
]
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user