mirror of
https://github.com/AppFlowy-IO/AppFlowy.git
synced 2024-08-30 18:12:39 +00:00
432db0f6d5
* chore: refactor the publish code * feat: integrate publish into database page * feat: add publish database structure * feat: add database row collab * feat: publish the database row collabs * chore: update collab * chore: improve question bubble * feat: publish the database relations * fix: rust ci * feat: select grid view to publish * feat: unable to deselect the primary database * feat: optimize the read recent views speed (#5726) * feat: optimize the read recent views speed * fix: order of recent views should be from the latest to the oldest * chore: update translations * fix: replace the unable to be selected icon * feat: remove left padding of inline database * fix: code review * chore: remove publish api err log * chore: read the database collab and document collab from disk instead of memory * chore: code cleanup * chore: revert beta.appflowy.com * chore: code cleanup * test: add database encode test * test: add publish database test * chore: refresh sidebar layout * chore: update comments
86 lines
2.1 KiB
Dart
86 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,
|
|
Map<String, dynamic>? data,
|
|
}) =>
|
|
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(),
|
|
),
|
|
),
|
|
);
|
|
}
|
|
}
|