173 lines
4.6 KiB
Dart
Raw Normal View History

2022-08-12 20:10:56 +08:00
import 'package:app_flowy/plugins/board/application/card/card_bloc.dart';
import 'package:app_flowy/plugins/board/application/card/card_data_controller.dart';
import 'package:app_flowy/plugins/grid/application/cell/cell_service/cell_service.dart';
2022-08-16 17:36:39 +08:00
import 'package:app_flowy/plugins/grid/presentation/widgets/row/row_action_sheet.dart';
2022-08-13 11:51:26 +08:00
import 'package:flowy_infra/image.dart';
import 'package:flowy_infra/theme.dart';
2022-08-16 17:36:39 +08:00
import 'package:flowy_infra_ui/flowy_infra_ui_web.dart';
2022-08-10 17:59:28 +08:00
import 'package:flutter/material.dart';
2022-08-12 20:10:56 +08:00
import 'package:flutter_bloc/flutter_bloc.dart';
2022-08-30 20:54:11 +08:00
import 'board_cell.dart';
2022-08-12 20:10:56 +08:00
import 'card_cell_builder.dart';
2022-08-13 11:51:26 +08:00
import 'card_container.dart';
2022-08-10 17:59:28 +08:00
2022-08-12 20:10:56 +08:00
class BoardCard extends StatefulWidget {
final String gridId;
2022-08-25 16:17:19 +08:00
final String groupId;
final String fieldId;
final bool isEditing;
2022-08-12 20:10:56 +08:00
final CardDataController dataController;
final BoardCellBuilder cellBuilder;
2022-08-16 18:02:39 +08:00
final void Function(BuildContext) openCard;
2022-08-12 20:10:56 +08:00
const BoardCard({
required this.gridId,
2022-08-25 16:17:19 +08:00
required this.groupId,
required this.fieldId,
required this.isEditing,
2022-08-12 20:10:56 +08:00
required this.dataController,
required this.cellBuilder,
2022-08-16 18:02:39 +08:00
required this.openCard,
2022-08-12 20:10:56 +08:00
Key? key,
}) : super(key: key);
@override
State<BoardCard> createState() => _BoardCardState();
}
class _BoardCardState extends State<BoardCard> {
late BoardCardBloc _cardBloc;
2022-08-30 20:54:11 +08:00
late EditableRowNotifier rowNotifier;
2022-08-12 20:10:56 +08:00
@override
void initState() {
2022-08-30 20:54:11 +08:00
rowNotifier = EditableRowNotifier();
2022-08-12 20:10:56 +08:00
_cardBloc = BoardCardBloc(
gridId: widget.gridId,
fieldId: widget.fieldId,
2022-08-12 20:10:56 +08:00
dataController: widget.dataController,
2022-08-24 21:06:10 +08:00
)..add(const BoardCardEvent.initial());
2022-08-12 20:10:56 +08:00
super.initState();
}
2022-08-10 17:59:28 +08:00
@override
Widget build(BuildContext context) {
2022-08-12 20:10:56 +08:00
return BlocProvider.value(
value: _cardBloc,
child: BlocBuilder<BoardCardBloc, BoardCardState>(
buildWhen: (previous, current) {
return previous.cells.length != current.cells.length;
},
2022-08-12 20:10:56 +08:00
builder: (context, state) {
2022-08-13 11:51:26 +08:00
return BoardCardContainer(
accessoryBuilder: (context) {
2022-08-30 20:54:11 +08:00
return [
_CardEditOption(
startEditing: () => rowNotifier.becomeFirstResponder(),
),
const _CardMoreOption(),
];
2022-08-13 11:51:26 +08:00
},
2022-08-16 18:02:39 +08:00
onTap: (context) {
widget.openCard(context);
},
child: Column(
2022-08-29 15:42:08 +08:00
mainAxisSize: MainAxisSize.min,
children: _makeCells(
context,
state.cells.map((cell) => cell.identifier).toList(),
),
),
2022-08-12 20:10:56 +08:00
);
},
),
);
}
List<Widget> _makeCells(
BuildContext context,
List<GridCellIdentifier> cells,
) {
2022-08-29 15:42:08 +08:00
final List<Widget> children = [];
cells.asMap().forEach(
(int index, GridCellIdentifier cellId) {
2022-08-30 20:54:11 +08:00
final cellNotifier = EditableCellNotifier();
Widget child = widget.cellBuilder.buildCell(
widget.groupId,
cellId,
widget.isEditing,
2022-08-30 20:54:11 +08:00
cellNotifier,
);
2022-08-30 20:54:11 +08:00
rowNotifier.insertCell(cellId, cellNotifier);
2022-08-29 15:42:08 +08:00
if (index != 0) {
child = Padding(
key: cellId.key(),
2022-08-29 15:42:08 +08:00
padding: const EdgeInsets.only(left: 4, right: 4, top: 8),
child: child,
);
2022-08-29 15:42:08 +08:00
} else {
child = Padding(
key: UniqueKey(),
2022-08-29 15:42:08 +08:00
padding: const EdgeInsets.only(left: 4, right: 4),
child: child,
);
2022-08-29 15:42:08 +08:00
}
children.add(child);
2022-08-12 20:10:56 +08:00
},
2022-08-29 15:42:08 +08:00
);
return children;
2022-08-10 17:59:28 +08:00
}
2022-08-24 21:06:10 +08:00
@override
Future<void> dispose() async {
_cardBloc.close();
super.dispose();
}
2022-08-10 17:59:28 +08:00
}
2022-08-13 11:51:26 +08:00
class _CardMoreOption extends StatelessWidget with CardAccessory {
const _CardMoreOption({Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
2022-08-30 20:54:11 +08:00
return Padding(
padding: const EdgeInsets.all(3.0),
child:
svgWidget('grid/details', color: context.read<AppTheme>().iconColor),
);
2022-08-13 11:51:26 +08:00
}
@override
void onTap(BuildContext context) {
2022-08-16 17:36:39 +08:00
GridRowActionSheet(
rowData: context.read<BoardCardBloc>().rowInfo(),
).show(context, direction: AnchorDirection.bottomWithCenterAligned);
2022-08-13 11:51:26 +08:00
}
}
2022-08-30 20:54:11 +08:00
class _CardEditOption extends StatelessWidget with CardAccessory {
final VoidCallback startEditing;
const _CardEditOption({
required this.startEditing,
Key? key,
}) : super(key: key);
@override
Widget build(BuildContext context) {
return Padding(
padding: const EdgeInsets.all(3.0),
child: svgWidget(
'editor/edit',
color: context.read<AppTheme>().iconColor,
),
);
}
@override
void onTap(BuildContext context) {
startEditing();
}
}