card.dart 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. import 'package:app_flowy/plugins/board/application/card/card_bloc.dart';
  2. import 'package:app_flowy/plugins/board/application/card/card_data_controller.dart';
  3. import 'package:app_flowy/plugins/grid/application/cell/cell_service/cell_service.dart';
  4. import 'package:app_flowy/plugins/grid/presentation/widgets/row/row_action_sheet.dart';
  5. import 'package:flowy_infra/image.dart';
  6. import 'package:flowy_infra/theme.dart';
  7. import 'package:flowy_infra_ui/flowy_infra_ui_web.dart';
  8. import 'package:flutter/material.dart';
  9. import 'package:flutter_bloc/flutter_bloc.dart';
  10. import 'card_cell_builder.dart';
  11. import 'card_container.dart';
  12. typedef OnEndEditing = void Function(String rowId);
  13. class BoardCard extends StatefulWidget {
  14. final String gridId;
  15. final bool isEditing;
  16. final CardDataController dataController;
  17. final BoardCellBuilder cellBuilder;
  18. final OnEndEditing onEditEditing;
  19. final void Function(BuildContext) openCard;
  20. const BoardCard({
  21. required this.gridId,
  22. required this.isEditing,
  23. required this.dataController,
  24. required this.cellBuilder,
  25. required this.onEditEditing,
  26. required this.openCard,
  27. Key? key,
  28. }) : super(key: key);
  29. @override
  30. State<BoardCard> createState() => _BoardCardState();
  31. }
  32. class _BoardCardState extends State<BoardCard> {
  33. late BoardCardBloc _cardBloc;
  34. @override
  35. void initState() {
  36. _cardBloc = BoardCardBloc(
  37. gridId: widget.gridId,
  38. dataController: widget.dataController,
  39. )..add(const BoardCardEvent.initial());
  40. super.initState();
  41. }
  42. @override
  43. Widget build(BuildContext context) {
  44. return BlocProvider.value(
  45. value: _cardBloc,
  46. child: BlocBuilder<BoardCardBloc, BoardCardState>(
  47. builder: (context, state) {
  48. return BoardCardContainer(
  49. accessoryBuilder: (context) {
  50. return [const _CardMoreOption()];
  51. },
  52. onTap: (context) {
  53. widget.openCard(context);
  54. },
  55. child: Column(
  56. children: _makeCells(context, state.gridCellMap),
  57. ),
  58. );
  59. },
  60. ),
  61. );
  62. }
  63. List<Widget> _makeCells(BuildContext context, GridCellMap cellMap) {
  64. return cellMap.values.map(
  65. (cellId) {
  66. final child = widget.cellBuilder.buildCell(cellId);
  67. return Padding(
  68. padding: const EdgeInsets.symmetric(horizontal: 6),
  69. child: child,
  70. );
  71. },
  72. ).toList();
  73. }
  74. @override
  75. Future<void> dispose() async {
  76. _cardBloc.close();
  77. super.dispose();
  78. }
  79. }
  80. class _CardMoreOption extends StatelessWidget with CardAccessory {
  81. const _CardMoreOption({Key? key}) : super(key: key);
  82. @override
  83. Widget build(BuildContext context) {
  84. return svgWidget('grid/details', color: context.read<AppTheme>().iconColor);
  85. }
  86. @override
  87. void onTap(BuildContext context) {
  88. GridRowActionSheet(
  89. rowData: context.read<BoardCardBloc>().rowInfo(),
  90. ).show(context, direction: AnchorDirection.bottomWithCenterAligned);
  91. }
  92. }