Vyuh Framework
Build Modular, Scalable, CMS-driven Flutter Apps
Vyuh Feature System 🔧
The system feature package for Vyuh framework, providing essential content types, actions, conditions, and services for building CMS-driven Flutter applications.
Features ✨
Content Types 📝
Routes 🧭
-
Page Routes: Full-screen pages with various layouts
- Default page layout with app bar and body
- Tabs layout for sectioned content
- Single item layout for focused content
- Conditional layout for dynamic routing
-
Dialog Routes: Modal dialogs with customizable content
- Default dialog layout
- Custom dialog layouts
Cards 🎴
- Default Card: Standard card layout with title, content, and actions
- List Item Card: Compact layout for list views
- Button Card: Interactive card with action triggers
- Conditional Card: Dynamic layout based on conditions
Groups 📦
-
Carousel: Horizontal scrolling group of items
- Auto-play support
- Navigation controls
- Custom transitions
-
Grid: Responsive grid layout
- Configurable columns
- Responsive breakpoints
- Custom item spacing
-
List: Vertical list of items
- Configurable spacing
- Dividers support
- Custom item layouts
Other Items 🔧
- Portable Text: Rich text content with custom marks
- Action invocation marks
- Link marks with custom styling
- Custom block styles
- Empty: Empty content placeholder
- Unknown: Fallback for unknown content types
- Conditional: Content based on conditions
Each content type can be extended with custom layouts by implementing
LayoutConfiguration<T>
and registering the layout in your feature descriptor.
Actions 🎯
The system feature provides several built-in actions for navigation, UI control, and system operations:
Navigation Actions 🧭
- NavigateAction: Navigate to a new route with optional query parameters
- NavigateBackAction: Return to the previous route in history
- NavigateReplaceAction: Replace current route with a new one
- OpenUrlAction: Open external URLs in browser or app
UI Actions 🎨
- AlertAction: Display snackbar messages with different types (success, error, info)
- DrawerAction: Show or hide the navigation drawer
- OpenInDialogAction: Display content in a modal dialog
- ToggleThemeAction: Switch between light and dark themes
System Actions ⚙️
- DelayAction: Add a timed delay between action executions
- RouteRefreshAction: Refresh the current route's content
- RestartAction: Restart the entire application
Conditions 🔄
- Boolean: Simple boolean conditions
- Feature Flag: Toggle features based on conditions
- Screen Size: Responsive layouts based on screen size
- Current Platform: Platform-specific content
- Theme Mode: Theme-based content
- User Authentication: Content based on auth state
Content Modifiers
Content modifiers allow you to transform content before rendering:
import 'package:vyuh_feature_system/vyuh_feature_system.dart' as system;
// Apply theme-based modifications
ThemeModifier(
light: LightContent(),
dark: DarkContent(),
);
API Handlers
Configure API content handling:
import 'package:vyuh_feature_system/vyuh_feature_system.dart' as system;
final apiConfig = JsonPathApiConfiguration(
baseUrl: 'https://api.example.com',
paths: {
'products': '$.items[*]',
'categories': '$.categories[*]',
},
);
Services 🛠️
Breakpoint Service
Handle responsive layouts:
import 'package:vyuh_feature_system/vyuh_feature_system.dart' as system;
final breakpointService = vyuh.di.get<system.BreakpointService>();
Observer(
builder: (_) {
if (breakpointService.isMobile) {
return MobileLayout();
}
if (breakpointService.isTablet) {
return TabletLayout();
}
return DesktopLayout();
},
);
// Custom breakpoints
breakpointService.setBreakpoints(
mobile: 480,
tablet: 768,
desktop: 1024,
);
Theme Service
Manage app theme and mode:
import 'package:vyuh_feature_system/vyuh_feature_system.dart' as system;
// Get theme service
final themeService = vyuh.di.get<system.ThemeService>();
// Toggle theme
system.ToggleThemeAction().execute();
// Observe current theme mode
Observer(
builder: (_) {
final mode = themeService.currentMode.value;
return Text('Current theme: $mode');
},
);
Content Extensions
Register content types and builders:
import 'package:vyuh_feature_system/vyuh_feature_system.dart' as system;
final feature = FeatureDescriptor(
name: 'my_feature',
extensions: [
ContentExtensionDescriptor(
contents: [
// Your content descriptors
],
contentBuilders: [
Route.contentBuilder,
Card.contentBuilder,
Group.contentBuilder,
],
contentModifiers: [
ThemeModifier.modifier,
],
),
],
);
System Routes
The system feature provides built-in routes:
Error Route
- Path:
/__system_error__
- Purpose: Displays system errors with stack trace
- Usage: Automatically used by the framework for error handling
Navigation Route
- Path:
/__system_navigate__
- Purpose: Handles external navigation (URLs, deep links)
- Usage: Automatically used by navigation actions
These routes are registered automatically when using the system feature and provide consistent error handling and navigation behavior across your app.
Installation 📦
Add this to your package's pubspec.yaml
file:
dependencies:
vyuh_feature_system: any
Learn More 📚
- Visit docs.vyuh.tech for detailed documentation
- Check out the GitHub repository for source code
- Report issues on the issue tracker
Made with ❤️ by Vyuh
Libraries
- action/alert
- action/conditional_action
- action/delay
- action/drawer
- action/open_in_dialog
- action/open_url
- action/restart
- action/route_refresh
- action/snack_bar
- action/toggle_theme
- api_handler/json_path_api_configuration
- condition/boolean
- condition/current_platform
- condition/current_theme_mode
- condition/feature_flag
- condition/screen_size
- condition/user_authenticated
- content/accordion
- content/api_content
- content/card/card
- content/card/default_layout
- content/card/list_item_layout
- content/conditional
- content/conditional_route/conditional_route
- content/conditional_route/default_layout
- content/divider
- content/document_view/document_list
- content/document_view/document_list_layout
- content/document_view/document_section
- content/document_view/document_section_layout
- content/document_view/document_view
- content/document_view/ui/document_builder
- content/document_view/ui/document_listview_builder
- content/empty
- content/group/carousel_layout
- content/group/default_layout
- content/group/grid_layout
- content/group/group
- content/group/list_layout
- content/index
- content/portable_text/invoke_action
- content/portable_text/portable_text
- content/route/default_layout
- content/route/route
- content/route/route_type
- content/route/single_item_layout
- content/route/tabs
- content/video_player
- content_modifiers/theme_modifier
- feature
- service/breakpoint_service
- service/theme_service
- ui/carousel
- ui/conditional_layout
- ui/content_image
- ui/content_items_scrollview
- ui/default_page_route_layout
- ui/dialog_page
- ui/press_effect
- ui/route_scaffold
- ui/single_item_route_scaffold
- ui/text
- ui/web_view
- vyuh_feature_system
- The system feature package for Vyuh framework, providing essential content types, actions, conditions, and services for building CMS-driven Flutter applications.