mirror of
https://github.com/AppFlowy-IO/AppFlowy.git
synced 2025-07-10 02:26:08 +00:00

* feat: revamp row detail page UI * chore: some minor details and fix tests * fix: fix tests * chore: remove unused field * chore: code cleanup * test: add reordering fields in row page tests * chore: remove duplicate and delete row events * chore: timestamp cell ui adjustment * chore: remove unused code * test: fix new integration tests
194 lines
6.9 KiB
Dart
194 lines
6.9 KiB
Dart
import 'package:appflowy_backend/protobuf/flowy-database2/setting_entities.pbenum.dart';
|
|
import 'package:appflowy_backend/protobuf/flowy-folder2/view.pbenum.dart';
|
|
import 'package:flutter_test/flutter_test.dart';
|
|
import 'package:integration_test/integration_test.dart';
|
|
|
|
import 'util/database_test_op.dart';
|
|
import 'util/util.dart';
|
|
|
|
void main() {
|
|
IntegrationTestWidgetsFlutterBinding.ensureInitialized();
|
|
|
|
group('calendar', () {
|
|
testWidgets('update calendar layout', (tester) async {
|
|
await tester.initializeAppFlowy();
|
|
await tester.tapGoButton();
|
|
|
|
await tester.createNewPageWithName(layout: ViewLayoutPB.Calendar);
|
|
|
|
// open setting
|
|
await tester.tapDatabaseSettingButton();
|
|
await tester.tapDatabaseLayoutButton();
|
|
await tester.selectDatabaseLayoutType(DatabaseLayoutPB.Board);
|
|
await tester.assertCurrentDatabaseLayoutType(DatabaseLayoutPB.Board);
|
|
|
|
await tester.tapDatabaseSettingButton();
|
|
await tester.tapDatabaseLayoutButton();
|
|
await tester.selectDatabaseLayoutType(DatabaseLayoutPB.Grid);
|
|
await tester.assertCurrentDatabaseLayoutType(DatabaseLayoutPB.Grid);
|
|
|
|
await tester.pumpAndSettle();
|
|
});
|
|
|
|
testWidgets('calendar start from day setting', (tester) async {
|
|
await tester.initializeAppFlowy();
|
|
await tester.tapGoButton();
|
|
|
|
// Create calendar view
|
|
const name = 'calendar';
|
|
await tester.createNewPageWithName(
|
|
name: name,
|
|
layout: ViewLayoutPB.Calendar,
|
|
);
|
|
|
|
// Open setting
|
|
await tester.tapDatabaseSettingButton();
|
|
await tester.tapCalendarLayoutSettingButton();
|
|
|
|
// select the first day of week is Monday
|
|
await tester.tapFirstDayOfWeek();
|
|
await tester.tapFirstDayOfWeekStartFromMonday();
|
|
|
|
// Open the other page and open the new calendar page again
|
|
await tester.openPage(gettingStarted);
|
|
await tester.pumpAndSettle(const Duration(milliseconds: 300));
|
|
await tester.openPage(name, layout: ViewLayoutPB.Calendar);
|
|
|
|
// Open setting again and check the start from Monday is selected
|
|
await tester.tapDatabaseSettingButton();
|
|
await tester.tapCalendarLayoutSettingButton();
|
|
await tester.tapFirstDayOfWeek();
|
|
tester.assertFirstDayOfWeekStartFromMonday();
|
|
|
|
await tester.pumpAndSettle();
|
|
});
|
|
|
|
testWidgets('creating and editing calendar events', (tester) async {
|
|
await tester.initializeAppFlowy();
|
|
await tester.tapGoButton();
|
|
|
|
// Create the calendar view
|
|
await tester.createNewPageWithName(layout: ViewLayoutPB.Calendar);
|
|
|
|
// Scroll until today's date cell is visible
|
|
await tester.scrollToToday();
|
|
|
|
// Hover over today's calendar cell
|
|
await tester.hoverOnTodayCalendarCell();
|
|
|
|
// Tap on create new event button
|
|
await tester.tapAddCalendarEventButton();
|
|
|
|
// Make sure that the row details page is opened
|
|
tester.assertRowDetailPageOpened();
|
|
|
|
// Dismiss the row details page
|
|
await tester.dismissRowDetailPage();
|
|
|
|
tester.assertNumberOfEventsInCalendar(1);
|
|
|
|
// Double click on today's calendar cell to create a new event
|
|
await tester.doubleClickCalendarCell(DateTime.now());
|
|
|
|
// Make sure that the row details page is opened
|
|
tester.assertRowDetailPageOpened();
|
|
|
|
// Dismiss the row details page
|
|
await tester.dismissRowDetailPage();
|
|
|
|
// Make sure that the event is inserted in the cell
|
|
tester.assertNumberOfEventsInCalendar(2);
|
|
|
|
// Click on the event
|
|
await tester.openCalendarEvent(index: 0);
|
|
tester.assertRowDetailPageOpened();
|
|
|
|
// Change the title of the event
|
|
await tester.editTitleInRowDetailPage('hello world');
|
|
await tester.dismissRowDetailPage();
|
|
|
|
// Make sure that the event is edited
|
|
tester.assertNumberOfEventsInCalendar(1, title: 'hello world');
|
|
tester.assertNumberOfEventsOnSpecificDay(2, DateTime.now());
|
|
|
|
// Click on the event
|
|
await tester.openCalendarEvent(index: 1);
|
|
tester.assertRowDetailPageOpened();
|
|
|
|
// Duplicate the event
|
|
await tester.tapRowDetailPageRowActionButton();
|
|
await tester.tapRowDetailPageDuplicateRowButton();
|
|
await tester.dismissRowDetailPage();
|
|
|
|
// Check that there are 2 events
|
|
tester.assertNumberOfEventsInCalendar(2, title: 'hello world');
|
|
tester.assertNumberOfEventsOnSpecificDay(3, DateTime.now());
|
|
|
|
// Delete an event
|
|
await tester.openCalendarEvent(index: 1);
|
|
await tester.tapRowDetailPageRowActionButton();
|
|
await tester.tapRowDetailPageDeleteRowButton();
|
|
|
|
// Check that there is 1 event
|
|
tester.assertNumberOfEventsInCalendar(1, title: 'hello world');
|
|
tester.assertNumberOfEventsOnSpecificDay(2, DateTime.now());
|
|
});
|
|
|
|
testWidgets('rescheduling events', (tester) async {
|
|
await tester.initializeAppFlowy();
|
|
await tester.tapGoButton();
|
|
|
|
// Create the calendar view
|
|
await tester.createNewPageWithName(layout: ViewLayoutPB.Calendar);
|
|
|
|
// Create a new event on the first of this month
|
|
final today = DateTime.now();
|
|
final firstOfThisMonth = DateTime(today.year, today.month, 1);
|
|
await tester.doubleClickCalendarCell(firstOfThisMonth);
|
|
await tester.dismissRowDetailPage();
|
|
|
|
// Drag and drop the event onto the next week, same day
|
|
await tester.dragDropRescheduleCalendarEvent(firstOfThisMonth);
|
|
|
|
// Make sure that the event has been rescheduled to the new date
|
|
final sameDayNextWeek = firstOfThisMonth.add(const Duration(days: 7));
|
|
tester.assertNumberOfEventsInCalendar(1);
|
|
tester.assertNumberOfEventsOnSpecificDay(1, sameDayNextWeek);
|
|
|
|
// Delete the event
|
|
await tester.openCalendarEvent(index: 0, date: sameDayNextWeek);
|
|
await tester.tapRowDetailPageRowActionButton();
|
|
await tester.tapRowDetailPageDeleteRowButton();
|
|
|
|
// Create a new event in today's calendar cell
|
|
await tester.scrollToToday();
|
|
await tester.doubleClickCalendarCell(today);
|
|
await tester.dismissRowDetailPage();
|
|
|
|
// Make sure that the event is today
|
|
tester.assertNumberOfEventsOnSpecificDay(1, today);
|
|
|
|
// Click on the event
|
|
await tester.openCalendarEvent(index: 0);
|
|
|
|
// Open the date editor of the event
|
|
await tester.tapDateCellInRowDetailPage();
|
|
await tester.findDateEditor(findsOneWidget);
|
|
|
|
// Edit the event's date. To avoid selecting a day outside of the current month, the new date will be one day closer to the middle of the month.
|
|
final newDate = today.day < 15
|
|
? today.add(const Duration(days: 1))
|
|
: today.subtract(const Duration(days: 1));
|
|
await tester.selectDay(content: newDate.day);
|
|
await tester.dismissCellEditor();
|
|
|
|
// Dismiss the row details page
|
|
await tester.dismissRowDetailPage();
|
|
|
|
// Make sure that the event is edited
|
|
tester.assertNumberOfEventsInCalendar(1);
|
|
tester.assertNumberOfEventsOnSpecificDay(1, newDate);
|
|
});
|
|
});
|
|
}
|