mirror of
https://github.com/AppFlowy-IO/AppFlowy.git
synced 2025-07-08 17:47:11 +00:00

* chore: update calendar theming * feat: add event popup editor * chore: new event button redesign and add card shadows * chore: unscheduled events button * chore: event title text field * fix: focus node double dispose * chore: show popover when create new event * test: integrate some tests for integration testing purposes * fix: some fixes and more integration tests
239 lines
8.2 KiB
Dart
239 lines
8.2 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 event editor popup is shown
|
|
tester.assertEventEditorOpen();
|
|
|
|
tester.assertNumberOfEventsInCalendar(1);
|
|
|
|
// Dismiss the event editor popup
|
|
await tester.dismissEventEditor();
|
|
|
|
// Double click on today's calendar cell to create a new event
|
|
await tester.doubleClickCalendarCell(DateTime.now());
|
|
|
|
// Make sure that the event editor popup is shown
|
|
tester.assertEventEditorOpen();
|
|
|
|
// Make sure that the event is inserted in the cell
|
|
tester.assertNumberOfEventsInCalendar(2);
|
|
|
|
// Dismiss the event editor popup
|
|
await tester.dismissEventEditor();
|
|
|
|
// Click on the event
|
|
await tester.openCalendarEvent(index: 0);
|
|
tester.assertEventEditorOpen();
|
|
|
|
// Change the title of the event
|
|
await tester.editEventTitle('hello world');
|
|
await tester.dismissEventEditor();
|
|
|
|
// 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.assertEventEditorOpen();
|
|
|
|
// Click on the open icon
|
|
await tester.openEventToRowDetailPage();
|
|
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.deleteEventFromEventEditor();
|
|
|
|
// Check that there is 1 event
|
|
tester.assertNumberOfEventsInCalendar(1, title: 'hello world');
|
|
tester.assertNumberOfEventsOnSpecificDay(2, DateTime.now());
|
|
|
|
// Delete event from row detail page
|
|
await tester.openCalendarEvent(index: 1);
|
|
await tester.openEventToRowDetailPage();
|
|
tester.assertRowDetailPageOpened();
|
|
|
|
await tester.tapRowDetailPageRowActionButton();
|
|
await tester.tapRowDetailPageDeleteRowButton();
|
|
|
|
// Check that there is 0 event
|
|
tester.assertNumberOfEventsInCalendar(0, title: 'hello world');
|
|
tester.assertNumberOfEventsOnSpecificDay(1, 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.dismissEventEditor();
|
|
|
|
// 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.deleteEventFromEventEditor();
|
|
|
|
// Create a new event in today's calendar cell
|
|
await tester.scrollToToday();
|
|
await tester.doubleClickCalendarCell(today);
|
|
await tester.dismissEventEditor();
|
|
|
|
// 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 event editor
|
|
await tester.dismissEventEditor();
|
|
|
|
// Make sure that the event is edited
|
|
tester.assertNumberOfEventsInCalendar(1);
|
|
tester.assertNumberOfEventsOnSpecificDay(1, newDate);
|
|
|
|
// Click on the unscheduled events button
|
|
await tester.openUnscheduledEventsPopup();
|
|
|
|
// Assert that nothing shows up
|
|
tester.findUnscheduledPopup(findsNothing, 0);
|
|
|
|
// Click on the event in the calendar
|
|
await tester.openCalendarEvent(index: 0, date: newDate);
|
|
|
|
// Open the date editor of the event
|
|
await tester.tapDateCellInRowDetailPage();
|
|
await tester.findDateEditor(findsOneWidget);
|
|
|
|
// Clear the date of the event
|
|
await tester.clearDate();
|
|
|
|
// Dismiss the event editor
|
|
await tester.dismissEventEditor();
|
|
tester.assertNumberOfEventsInCalendar(0);
|
|
|
|
// Click on the unscheduled events button
|
|
await tester.openUnscheduledEventsPopup();
|
|
|
|
// Assert that a popup appears and 1 unscheduled event
|
|
tester.findUnscheduledPopup(findsOneWidget, 1);
|
|
|
|
// Click on the unscheduled event
|
|
await tester.clickUnscheduledEvent();
|
|
|
|
tester.assertRowDetailPageOpened();
|
|
});
|
|
});
|
|
}
|