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

* feat: hide/unhide ui * chore: implement collapsible side bar and adjust group header (#2) * refactor: hidden columns into own file * chore: adjust new group button position * fix: flowy icon buton secondary color bleed * chore: some UI adjustments * fix: some regressions * chore: proper group is_visible fetching * chore: use a bloc to manage hidden groups * fix: hiding groups not working * chore: implement hidden group popups * chore: proper ungrouped item column management * chore: remove ungrouped items button * chore: flowy hover build * fix: clean up code * test: integration tests * fix: not null promise on null value * fix: hide and unhide multiple groups * chore: i18n and code review * chore: missed review * fix: rust-lib-test * fix: dont completely remove flowyiconhovercolor * chore: apply suggest * fix: number of rows inside hidden groups not updating properly * fix: hidden groups disappearing after collapse * fix: hidden group title alignment * fix: insert newly unhidden groups into the correct position * chore: adjust padding all around * feat: reorder hidden groups * chore: adjust padding * chore: collapse hidden groups section persist * chore: no status group at beginning * fix: hiding groups when grouping with other types * chore: disable rename groups that arent supported * chore: update appflowy board ref * chore: better naming * feat: delete kanban groups * chore: forgot to save * chore: fix build and small ui adjustments * chore: add a confirm dialog when deleting a column * fix: flutter lint * test: add integration test * chore: fix some design review issues * chore: apply suggestions from Nathan * fix: write lock on group controller --------- Co-authored-by: Mathias Mogensen <mathias@appflowy.io>
188 lines
5.6 KiB
Rust
188 lines
5.6 KiB
Rust
use event_integration::EventIntegrationTest;
|
|
|
|
// The number of groups should be 0 if there is no group by field in grid
|
|
#[tokio::test]
|
|
async fn get_groups_event_with_grid_test() {
|
|
let test = EventIntegrationTest::new_with_guest_user().await;
|
|
let current_workspace = test.get_current_workspace().await;
|
|
let grid_view = test
|
|
.create_grid(¤t_workspace.id, "my board view".to_owned(), vec![])
|
|
.await;
|
|
|
|
let groups = test.get_groups(&grid_view.id).await;
|
|
assert_eq!(groups.len(), 0);
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn get_groups_event_test() {
|
|
let test = EventIntegrationTest::new_with_guest_user().await;
|
|
let current_workspace = test.get_current_workspace().await;
|
|
let board_view = test
|
|
.create_board(¤t_workspace.id, "my board view".to_owned(), vec![])
|
|
.await;
|
|
|
|
let groups = test.get_groups(&board_view.id).await;
|
|
assert_eq!(groups.len(), 4);
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn move_group_event_test() {
|
|
let test = EventIntegrationTest::new_with_guest_user().await;
|
|
let current_workspace = test.get_current_workspace().await;
|
|
let board_view = test
|
|
.create_board(¤t_workspace.id, "my board view".to_owned(), vec![])
|
|
.await;
|
|
|
|
let groups = test.get_groups(&board_view.id).await;
|
|
assert_eq!(groups.len(), 4);
|
|
let group_1 = groups[0].group_id.clone();
|
|
let group_2 = groups[1].group_id.clone();
|
|
let group_3 = groups[2].group_id.clone();
|
|
let group_4 = groups[3].group_id.clone();
|
|
|
|
let error = test.move_group(&board_view.id, &group_2, &group_3).await;
|
|
assert!(error.is_none());
|
|
|
|
let groups = test.get_groups(&board_view.id).await;
|
|
assert_eq!(groups[0].group_id, group_1);
|
|
assert_eq!(groups[1].group_id, group_3);
|
|
assert_eq!(groups[2].group_id, group_2);
|
|
assert_eq!(groups[3].group_id, group_4);
|
|
|
|
let error = test.move_group(&board_view.id, &group_1, &group_4).await;
|
|
assert!(error.is_none());
|
|
|
|
let groups = test.get_groups(&board_view.id).await;
|
|
assert_eq!(groups[0].group_id, group_3);
|
|
assert_eq!(groups[1].group_id, group_2);
|
|
assert_eq!(groups[2].group_id, group_4);
|
|
assert_eq!(groups[3].group_id, group_1);
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn move_group_event_with_invalid_id_test() {
|
|
let test = EventIntegrationTest::new_with_guest_user().await;
|
|
let current_workspace = test.get_current_workspace().await;
|
|
let board_view = test
|
|
.create_board(¤t_workspace.id, "my board view".to_owned(), vec![])
|
|
.await;
|
|
|
|
// Empty to group id
|
|
let groups = test.get_groups(&board_view.id).await;
|
|
let error = test
|
|
.move_group(&board_view.id, &groups[0].group_id, "")
|
|
.await;
|
|
assert!(error.is_some());
|
|
|
|
// empty from group id
|
|
let error = test
|
|
.move_group(&board_view.id, "", &groups[1].group_id)
|
|
.await;
|
|
assert!(error.is_some());
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn rename_group_event_test() {
|
|
let test = EventIntegrationTest::new_with_guest_user().await;
|
|
let current_workspace = test.get_current_workspace().await;
|
|
let board_view = test
|
|
.create_board(¤t_workspace.id, "my board view".to_owned(), vec![])
|
|
.await;
|
|
|
|
// Empty to group id
|
|
let groups = test.get_groups(&board_view.id).await;
|
|
let error = test
|
|
.update_group(
|
|
&board_view.id,
|
|
&groups[1].group_id,
|
|
&groups[1].field_id,
|
|
Some("new name".to_owned()),
|
|
None,
|
|
)
|
|
.await;
|
|
assert!(error.is_none());
|
|
|
|
let groups = test.get_groups(&board_view.id).await;
|
|
assert_eq!(groups[1].group_name, "new name".to_owned());
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn hide_group_event_test() {
|
|
let test = EventIntegrationTest::new_with_guest_user().await;
|
|
let current_workspace = test.get_current_workspace().await;
|
|
let board_view = test
|
|
.create_board(¤t_workspace.id, "my board view".to_owned(), vec![])
|
|
.await;
|
|
|
|
// Empty to group id
|
|
let groups = test.get_groups(&board_view.id).await;
|
|
assert_eq!(groups.len(), 4);
|
|
|
|
let error = test
|
|
.update_group(
|
|
&board_view.id,
|
|
&groups[0].group_id,
|
|
&groups[0].field_id,
|
|
None,
|
|
Some(false),
|
|
)
|
|
.await;
|
|
assert!(error.is_none());
|
|
|
|
let groups = test.get_groups(&board_view.id).await;
|
|
assert_eq!(groups.len(), 4);
|
|
assert_eq!(groups[0].is_visible, false);
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn update_group_name_test() {
|
|
let test = EventIntegrationTest::new_with_guest_user().await;
|
|
let current_workspace = test.get_current_workspace().await;
|
|
let board_view = test
|
|
.create_board(¤t_workspace.id, "my board view".to_owned(), vec![])
|
|
.await;
|
|
|
|
let groups = test.get_groups(&board_view.id).await;
|
|
assert_eq!(groups.len(), 4);
|
|
assert_eq!(groups[1].group_name, "To Do");
|
|
assert_eq!(groups[2].group_name, "Doing");
|
|
assert_eq!(groups[3].group_name, "Done");
|
|
|
|
test
|
|
.update_group(
|
|
&board_view.id,
|
|
&groups[1].group_id,
|
|
&groups[1].field_id,
|
|
Some("To Do?".to_string()),
|
|
None,
|
|
)
|
|
.await;
|
|
|
|
let groups = test.get_groups(&board_view.id).await;
|
|
assert_eq!(groups.len(), 4);
|
|
assert_eq!(groups[1].group_name, "To Do?");
|
|
assert_eq!(groups[2].group_name, "Doing");
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn delete_group_test() {
|
|
let test = EventIntegrationTest::new_with_guest_user().await;
|
|
let current_workspace = test.get_current_workspace().await;
|
|
let board_view = test
|
|
.create_board(¤t_workspace.id, "my board view".to_owned(), vec![])
|
|
.await;
|
|
|
|
let groups = test.get_groups(&board_view.id).await;
|
|
assert_eq!(groups.len(), 4);
|
|
assert_eq!(groups[1].group_name, "To Do");
|
|
assert_eq!(groups[2].group_name, "Doing");
|
|
assert_eq!(groups[3].group_name, "Done");
|
|
|
|
test.delete_group(&board_view.id, &groups[1].group_id).await;
|
|
|
|
let groups = test.get_groups(&board_view.id).await;
|
|
assert_eq!(groups.len(), 3);
|
|
assert_eq!(groups[1].group_name, "Doing");
|
|
assert_eq!(groups[2].group_name, "Done");
|
|
}
|