| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108 | import 'package:app_flowy/startup/startup.dart';import 'package:app_flowy/workspace/domain/image.dart';import 'package:app_flowy/workspace/domain/page_stack/page_stack.dart';import 'package:app_flowy/workspace/presentation/home/home_sizes.dart';import 'package:app_flowy/workspace/presentation/home/navigation_list.dart';import 'package:flowy_infra_ui/widget/rounded_button.dart';import 'package:flowy_infra_ui/widget/spacing.dart';import 'package:flowy_sdk/protobuf/flowy-workspace/view_create.pb.dart';import 'package:flowy_sdk/protobuf/flowy-workspace/view_create.pbenum.dart';import 'package:flutter/material.dart';import 'package:flowy_infra_ui/style_widget/icon_button.dart';import 'package:flowy_infra_ui/style_widget/extension.dart';import 'package:flowy_infra_ui/style_widget/text.dart';class HomeTopBar extends StatelessWidget {  final HomeStackView view;  const HomeTopBar({Key? key, required this.view}) : super(key: key);  @override  Widget build(BuildContext context) {    return SizedBox(      height: HomeSizes.topBarHeight,      child: Row(        crossAxisAlignment: CrossAxisAlignment.center,        children: [          _renderNavigationList(view),          const Spacer(),          _renderShareButton(),          _renderMoreButton(),        ],      )          .padding(            horizontal: HomeInsets.topBarTitlePadding,          )          .bottomBorder(color: Colors.grey.shade300),    );  }  Widget _renderShareButton() {    return RoundedTextButton(      title: 'Share',      height: 30,      width: 60,      fontSize: 12,      borderRadius: BorderRadius.circular(6),      color: Colors.lightBlue,      press: () {        debugPrint('share page');      },    );  }  Widget _renderMoreButton() {    return FlowyMoreButton(      width: 24,      onPressed: () {        debugPrint('show more');      },    );  }  Widget _renderNavigationList(HomeStackView view) {    return const StyledNavigationList();  }}class HomeTitle extends StatelessWidget {  final String title;  final ViewType type;  const HomeTitle({    Key? key,    required this.title,    required this.type,  }) : super(key: key);  @override  Widget build(BuildContext context) {    return Flexible(      child: Row(        children: [          Image(              fit: BoxFit.scaleDown,              width: 15,              height: 15,              image: assetImageForViewType(type)),          const HSpace(6),          FlowyText(title, fontSize: 16),        ],      ),    );  }}class ViewNaviItemImpl extends NaviItem {  final HomeStackView view;  ViewNaviItemImpl(this.view);  @override  NaviAction get action => () => getIt<HomePageStack>().setStackView(view);  @override  String get identifier => view.identifier;  @override  String get title => view.title;}
 |