home_top_bar.dart 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. import 'package:app_flowy/workspace/domain/image.dart';
  2. import 'package:app_flowy/workspace/domain/page_stack/page_stack.dart';
  3. import 'package:app_flowy/workspace/presentation/home/home_sizes.dart';
  4. import 'package:flowy_infra_ui/widget/rounded_button.dart';
  5. import 'package:flowy_infra_ui/widget/spacing.dart';
  6. import 'package:flowy_sdk/protobuf/flowy-workspace/view_create.pbenum.dart';
  7. import 'package:flutter/material.dart';
  8. import 'package:flowy_infra_ui/style_widget/styled_more.dart';
  9. import 'package:flowy_infra_ui/style_widget/styled_text.dart';
  10. class HomeTopBar extends StatelessWidget {
  11. final HomeStackView view;
  12. const HomeTopBar({Key? key, required this.view}) : super(key: key);
  13. @override
  14. Widget build(BuildContext context) {
  15. return SizedBox(
  16. height: HomeSizes.topBarHeight,
  17. child: Container(
  18. decoration: BoxDecoration(
  19. border: Border(
  20. bottom: BorderSide(width: 0.5, color: Colors.grey.shade300),
  21. ),
  22. ),
  23. child: Padding(
  24. padding:
  25. EdgeInsets.symmetric(horizontal: HomeInsets.topBarTitlePadding),
  26. child: Row(
  27. crossAxisAlignment: CrossAxisAlignment.center,
  28. children: [
  29. HomeTitle(title: view.title, type: view.type),
  30. const Spacer(),
  31. _renderShareButton(),
  32. _renderMoreButton(),
  33. ],
  34. ),
  35. ),
  36. ),
  37. );
  38. }
  39. Widget _renderShareButton() {
  40. return RoundedTextButton(
  41. title: 'Share',
  42. height: 30,
  43. width: 60,
  44. fontSize: 12,
  45. borderRadius: BorderRadius.circular(6),
  46. color: Colors.lightBlue,
  47. press: () {},
  48. );
  49. }
  50. Widget _renderMoreButton() {
  51. return StyledMore(
  52. width: 24,
  53. onPressed: () {},
  54. );
  55. }
  56. }
  57. class HomeTitle extends StatelessWidget {
  58. final String title;
  59. final ViewType type;
  60. const HomeTitle({
  61. Key? key,
  62. required this.title,
  63. required this.type,
  64. }) : super(key: key);
  65. @override
  66. Widget build(BuildContext context) {
  67. return Flexible(
  68. child: Row(
  69. children: [
  70. Image(
  71. fit: BoxFit.scaleDown,
  72. width: 15,
  73. height: 15,
  74. image: assetImageForViewType(type)),
  75. const HSpace(6),
  76. StyledText(title, fontSize: 16),
  77. ],
  78. ),
  79. );
  80. }
  81. }