home_top_bar.dart 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  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_icon_button.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. debugPrint('share page');
  49. },
  50. );
  51. }
  52. Widget _renderMoreButton() {
  53. return StyledMore(
  54. width: 24,
  55. onPressed: () {
  56. debugPrint('show more');
  57. },
  58. );
  59. }
  60. }
  61. class HomeTitle extends StatelessWidget {
  62. final String title;
  63. final ViewType type;
  64. const HomeTitle({
  65. Key? key,
  66. required this.title,
  67. required this.type,
  68. }) : super(key: key);
  69. @override
  70. Widget build(BuildContext context) {
  71. return Flexible(
  72. child: Row(
  73. children: [
  74. Image(
  75. fit: BoxFit.scaleDown,
  76. width: 15,
  77. height: 15,
  78. image: assetImageForViewType(type)),
  79. const HSpace(6),
  80. StyledText(title, fontSize: 16),
  81. ],
  82. ),
  83. );
  84. }
  85. }