mirror of
				https://github.com/AppFlowy-IO/AppFlowy.git
				synced 2025-10-31 10:03:18 +00:00 
			
		
		
		
	 aec7bc847e
			
		
	
	
		aec7bc847e
		
			
		
	
	
	
	
		
			
			* chore: ai type * chore: use patch to fix version issue * chore: update * chore: update * chore: integrate client api * chore: add schema * chore: setup event * chore: add event test * chore: add test * chore: update test * chore: load chat message * chore: load chat message * chore: chat ui * chore: disable create chat * chore: update client api * chore: disable chat * chore: ui theme * chore: ui theme * chore: copy message * chore: fix test * chore: show error * chore: update bloc * chore: update test * chore: lint * chore: icon * chore: hover * chore: show unsupported page * chore: adjust mobile ui * chore: adjust view title bar * chore: return related question * chore: error page * chore: error page * chore: code format * chore: prompt * chore: fix test * chore: ui adjust * chore: disable create chat * chore: add loading page * chore: fix test * chore: disable chat action * chore: add maximum text limit
		
			
				
	
	
		
			85 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
			
		
		
	
	
			85 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
| import 'package:appflowy/generated/flowy_svgs.g.dart';
 | |
| import 'package:appflowy/generated/locale_keys.g.dart';
 | |
| import 'package:appflowy/startup/plugin/plugin.dart';
 | |
| import 'package:appflowy/workspace/presentation/home/home_stack.dart';
 | |
| import 'package:appflowy_backend/protobuf/flowy-folder/view.pbenum.dart';
 | |
| import 'package:easy_localization/easy_localization.dart';
 | |
| import 'package:flowy_infra_ui/style_widget/text.dart';
 | |
| import 'package:flutter/material.dart';
 | |
| 
 | |
| class BlankPluginBuilder extends PluginBuilder {
 | |
|   @override
 | |
|   Plugin build(dynamic data) {
 | |
|     return BlankPagePlugin();
 | |
|   }
 | |
| 
 | |
|   @override
 | |
|   String get menuName => "Blank";
 | |
| 
 | |
|   @override
 | |
|   FlowySvgData get icon => const FlowySvgData('');
 | |
| 
 | |
|   @override
 | |
|   PluginType get pluginType => PluginType.blank;
 | |
| 
 | |
|   @override
 | |
|   ViewLayoutPB get layoutType => ViewLayoutPB.Document;
 | |
| }
 | |
| 
 | |
| class BlankPluginConfig implements PluginConfig {
 | |
|   @override
 | |
|   bool get creatable => false;
 | |
| }
 | |
| 
 | |
| class BlankPagePlugin extends Plugin {
 | |
|   @override
 | |
|   PluginWidgetBuilder get widgetBuilder => BlankPagePluginWidgetBuilder();
 | |
| 
 | |
|   @override
 | |
|   PluginId get id => "BlankStack";
 | |
| 
 | |
|   @override
 | |
|   PluginType get pluginType => PluginType.blank;
 | |
| }
 | |
| 
 | |
| class BlankPagePluginWidgetBuilder extends PluginWidgetBuilder
 | |
|     with NavigationItem {
 | |
|   @override
 | |
|   Widget get leftBarItem => FlowyText.medium(LocaleKeys.blankPageTitle.tr());
 | |
| 
 | |
|   @override
 | |
|   Widget tabBarItem(String pluginId) => leftBarItem;
 | |
| 
 | |
|   @override
 | |
|   Widget buildWidget({
 | |
|     required PluginContext context,
 | |
|     required bool shrinkWrap,
 | |
|   }) =>
 | |
|       const BlankPage();
 | |
| 
 | |
|   @override
 | |
|   List<NavigationItem> get navigationItems => [this];
 | |
| }
 | |
| 
 | |
| class BlankPage extends StatefulWidget {
 | |
|   const BlankPage({super.key});
 | |
| 
 | |
|   @override
 | |
|   State<BlankPage> createState() => _BlankPageState();
 | |
| }
 | |
| 
 | |
| class _BlankPageState extends State<BlankPage> {
 | |
|   @override
 | |
|   Widget build(BuildContext context) {
 | |
|     return SizedBox.expand(
 | |
|       child: Container(
 | |
|         color: Theme.of(context).colorScheme.surface,
 | |
|         child: const Padding(
 | |
|           padding: EdgeInsets.all(10),
 | |
|           child: SizedBox.shrink(),
 | |
|         ),
 | |
|       ),
 | |
|     );
 | |
|   }
 | |
| }
 |