2023-06-09 10:57:29 +00:00
|
|
|
use std::convert::TryFrom;
|
2023-05-21 03:13:22 +00:00
|
|
|
use std::env::temp_dir;
|
2023-05-23 15:55:21 +00:00
|
|
|
use std::sync::Arc;
|
2022-10-20 03:35:11 +00:00
|
|
|
|
2023-06-14 14:16:33 +00:00
|
|
|
use bytes::Bytes;
|
2023-06-06 16:05:27 +00:00
|
|
|
use nanoid::nanoid;
|
|
|
|
use parking_lot::RwLock;
|
|
|
|
|
2023-02-02 15:02:49 +00:00
|
|
|
use flowy_core::{AppFlowyCore, AppFlowyCoreConfig};
|
2023-06-07 06:52:35 +00:00
|
|
|
use flowy_database2::entities::*;
|
|
|
|
use flowy_folder2::entities::*;
|
2023-05-23 15:55:21 +00:00
|
|
|
use flowy_user::entities::{AuthTypePB, UserProfilePB};
|
2023-06-07 06:52:35 +00:00
|
|
|
use flowy_user::errors::FlowyError;
|
2023-05-17 01:49:39 +00:00
|
|
|
|
2023-06-06 16:05:27 +00:00
|
|
|
use crate::event_builder::EventBuilder;
|
2023-05-23 15:55:21 +00:00
|
|
|
use crate::user_event::{async_sign_up, init_user_setting, SignUpContext};
|
2023-06-06 16:05:27 +00:00
|
|
|
|
2023-07-04 09:17:25 +00:00
|
|
|
pub mod document;
|
2023-05-17 01:49:39 +00:00
|
|
|
pub mod event_builder;
|
2023-05-23 15:55:21 +00:00
|
|
|
pub mod folder_event;
|
|
|
|
pub mod user_event;
|
2021-07-06 06:14:47 +00:00
|
|
|
|
2021-09-04 07:12:53 +00:00
|
|
|
#[derive(Clone)]
|
2023-05-23 15:55:21 +00:00
|
|
|
pub struct FlowyCoreTest {
|
|
|
|
auth_type: Arc<RwLock<AuthTypePB>>,
|
|
|
|
inner: AppFlowyCore,
|
2022-01-07 09:37:11 +00:00
|
|
|
}
|
2021-12-08 09:33:22 +00:00
|
|
|
|
2023-05-23 15:55:21 +00:00
|
|
|
impl Default for FlowyCoreTest {
|
2023-02-13 01:29:49 +00:00
|
|
|
fn default() -> Self {
|
2023-05-23 15:55:21 +00:00
|
|
|
let temp_dir = temp_dir();
|
|
|
|
let config =
|
|
|
|
AppFlowyCoreConfig::new(temp_dir.to_str().unwrap(), nanoid!(6)).log_filter("info", vec![]);
|
|
|
|
let inner = std::thread::spawn(|| AppFlowyCore::new(config))
|
|
|
|
.join()
|
|
|
|
.unwrap();
|
|
|
|
let auth_type = Arc::new(RwLock::new(AuthTypePB::Local));
|
|
|
|
std::mem::forget(inner.dispatcher());
|
|
|
|
Self { inner, auth_type }
|
2023-02-13 01:29:49 +00:00
|
|
|
}
|
2022-01-07 09:37:11 +00:00
|
|
|
}
|
2021-12-08 09:33:22 +00:00
|
|
|
|
2023-05-23 15:55:21 +00:00
|
|
|
impl FlowyCoreTest {
|
2023-05-17 01:49:39 +00:00
|
|
|
pub fn new() -> Self {
|
2023-05-23 15:55:21 +00:00
|
|
|
Self::default()
|
2023-02-13 01:29:49 +00:00
|
|
|
}
|
|
|
|
|
2023-06-05 08:09:18 +00:00
|
|
|
pub async fn new_with_user() -> Self {
|
|
|
|
let test = Self::default();
|
|
|
|
test.sign_up().await;
|
|
|
|
test
|
|
|
|
}
|
|
|
|
|
2023-02-13 01:29:49 +00:00
|
|
|
pub async fn sign_up(&self) -> SignUpContext {
|
2023-05-23 15:55:21 +00:00
|
|
|
let auth_type = self.auth_type.read().clone();
|
|
|
|
async_sign_up(self.inner.dispatcher(), auth_type).await
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn set_auth_type(&self, auth_type: AuthTypePB) {
|
|
|
|
*self.auth_type.write() = auth_type;
|
2023-02-13 01:29:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn init_user(&self) -> UserProfilePB {
|
2023-05-23 15:55:21 +00:00
|
|
|
let auth_type = self.auth_type.read().clone();
|
|
|
|
let context = async_sign_up(self.inner.dispatcher(), auth_type).await;
|
2023-02-13 01:29:49 +00:00
|
|
|
init_user_setting(self.inner.dispatcher()).await;
|
|
|
|
context.user_profile
|
|
|
|
}
|
2023-06-05 08:09:18 +00:00
|
|
|
|
|
|
|
pub async fn get_current_workspace(&self) -> WorkspaceSettingPB {
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_folder2::event_map::FolderEvent::GetCurrentWorkspace)
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.parse::<flowy_folder2::entities::WorkspaceSettingPB>()
|
|
|
|
}
|
|
|
|
|
2023-06-06 16:05:27 +00:00
|
|
|
pub async fn get_all_workspace_views(&self) -> Vec<ViewPB> {
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_folder2::event_map::FolderEvent::ReadWorkspaceViews)
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.parse::<flowy_folder2::entities::RepeatedViewPB>()
|
|
|
|
.items
|
|
|
|
}
|
|
|
|
|
2023-06-05 08:09:18 +00:00
|
|
|
pub async fn delete_view(&self, view_id: &str) {
|
|
|
|
let payload = RepeatedViewIdPB {
|
|
|
|
items: vec![view_id.to_string()],
|
|
|
|
};
|
|
|
|
|
|
|
|
// delete the view. the view will be moved to trash
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_folder2::event_map::FolderEvent::DeleteView)
|
|
|
|
.payload(payload)
|
|
|
|
.async_send()
|
|
|
|
.await;
|
|
|
|
}
|
|
|
|
|
2023-06-14 14:16:33 +00:00
|
|
|
pub async fn update_view(&self, changeset: UpdateViewPayloadPB) -> Option<FlowyError> {
|
|
|
|
// delete the view. the view will be moved to trash
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_folder2::event_map::FolderEvent::UpdateView)
|
|
|
|
.payload(changeset)
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.error()
|
|
|
|
}
|
|
|
|
|
2023-06-05 08:09:18 +00:00
|
|
|
pub async fn create_view(&self, parent_id: &str, name: String) -> ViewPB {
|
|
|
|
let payload = CreateViewPayloadPB {
|
|
|
|
parent_view_id: parent_id.to_string(),
|
|
|
|
name,
|
|
|
|
desc: "".to_string(),
|
|
|
|
thumbnail: None,
|
|
|
|
layout: Default::default(),
|
|
|
|
initial_data: vec![],
|
|
|
|
meta: Default::default(),
|
|
|
|
set_as_current: false,
|
|
|
|
};
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_folder2::event_map::FolderEvent::CreateView)
|
|
|
|
.payload(payload)
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.parse::<flowy_folder2::entities::ViewPB>()
|
|
|
|
}
|
2023-06-06 16:05:27 +00:00
|
|
|
|
2023-06-07 06:52:35 +00:00
|
|
|
pub async fn create_grid(&self, parent_id: &str, name: String, initial_data: Vec<u8>) -> ViewPB {
|
|
|
|
let payload = CreateViewPayloadPB {
|
|
|
|
parent_view_id: parent_id.to_string(),
|
|
|
|
name,
|
|
|
|
desc: "".to_string(),
|
|
|
|
thumbnail: None,
|
|
|
|
layout: ViewLayoutPB::Grid,
|
|
|
|
initial_data,
|
|
|
|
meta: Default::default(),
|
|
|
|
set_as_current: true,
|
|
|
|
};
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_folder2::event_map::FolderEvent::CreateView)
|
|
|
|
.payload(payload)
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.parse::<flowy_folder2::entities::ViewPB>()
|
|
|
|
}
|
|
|
|
|
2023-06-09 10:57:29 +00:00
|
|
|
pub async fn create_board(&self, parent_id: &str, name: String, initial_data: Vec<u8>) -> ViewPB {
|
|
|
|
let payload = CreateViewPayloadPB {
|
|
|
|
parent_view_id: parent_id.to_string(),
|
|
|
|
name,
|
|
|
|
desc: "".to_string(),
|
|
|
|
thumbnail: None,
|
|
|
|
layout: ViewLayoutPB::Board,
|
|
|
|
initial_data,
|
|
|
|
meta: Default::default(),
|
|
|
|
set_as_current: true,
|
|
|
|
};
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_folder2::event_map::FolderEvent::CreateView)
|
|
|
|
.payload(payload)
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.parse::<flowy_folder2::entities::ViewPB>()
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn create_calendar(
|
|
|
|
&self,
|
|
|
|
parent_id: &str,
|
|
|
|
name: String,
|
|
|
|
initial_data: Vec<u8>,
|
|
|
|
) -> ViewPB {
|
|
|
|
let payload = CreateViewPayloadPB {
|
|
|
|
parent_view_id: parent_id.to_string(),
|
|
|
|
name,
|
|
|
|
desc: "".to_string(),
|
|
|
|
thumbnail: None,
|
|
|
|
layout: ViewLayoutPB::Calendar,
|
|
|
|
initial_data,
|
|
|
|
meta: Default::default(),
|
|
|
|
set_as_current: true,
|
|
|
|
};
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_folder2::event_map::FolderEvent::CreateView)
|
|
|
|
.payload(payload)
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.parse::<flowy_folder2::entities::ViewPB>()
|
|
|
|
}
|
|
|
|
|
2023-06-07 06:52:35 +00:00
|
|
|
pub async fn get_database(&self, view_id: &str) -> DatabasePB {
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_database2::event_map::DatabaseEvent::GetDatabase)
|
|
|
|
.payload(DatabaseViewIdPB {
|
|
|
|
value: view_id.to_string(),
|
|
|
|
})
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.parse::<flowy_database2::entities::DatabasePB>()
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn get_all_database_fields(&self, view_id: &str) -> RepeatedFieldPB {
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_database2::event_map::DatabaseEvent::GetFields)
|
|
|
|
.payload(GetFieldPayloadPB {
|
|
|
|
view_id: view_id.to_string(),
|
|
|
|
field_ids: None,
|
|
|
|
})
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.parse::<RepeatedFieldPB>()
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn create_field(&self, view_id: &str, field_type: FieldType) -> FieldPB {
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_database2::event_map::DatabaseEvent::CreateTypeOption)
|
|
|
|
.payload(CreateFieldPayloadPB {
|
|
|
|
view_id: view_id.to_string(),
|
|
|
|
field_type,
|
|
|
|
type_option_data: None,
|
|
|
|
})
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.parse::<TypeOptionPB>()
|
|
|
|
.field
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn update_field(&self, changeset: FieldChangesetPB) {
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_database2::event_map::DatabaseEvent::UpdateField)
|
|
|
|
.payload(changeset)
|
|
|
|
.async_send()
|
|
|
|
.await;
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn delete_field(&self, view_id: &str, field_id: &str) -> Option<FlowyError> {
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_database2::event_map::DatabaseEvent::DeleteField)
|
|
|
|
.payload(DeleteFieldPayloadPB {
|
|
|
|
view_id: view_id.to_string(),
|
|
|
|
field_id: field_id.to_string(),
|
|
|
|
})
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.error()
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn update_field_type(
|
|
|
|
&self,
|
|
|
|
view_id: &str,
|
|
|
|
field_id: &str,
|
|
|
|
field_type: FieldType,
|
|
|
|
) -> Option<FlowyError> {
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_database2::event_map::DatabaseEvent::UpdateFieldType)
|
|
|
|
.payload(UpdateFieldTypePayloadPB {
|
|
|
|
view_id: view_id.to_string(),
|
|
|
|
field_id: field_id.to_string(),
|
|
|
|
field_type,
|
|
|
|
})
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.error()
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn duplicate_field(&self, view_id: &str, field_id: &str) -> Option<FlowyError> {
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_database2::event_map::DatabaseEvent::DuplicateField)
|
|
|
|
.payload(DuplicateFieldPayloadPB {
|
|
|
|
view_id: view_id.to_string(),
|
|
|
|
field_id: field_id.to_string(),
|
|
|
|
})
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.error()
|
|
|
|
}
|
|
|
|
|
2023-06-14 14:16:33 +00:00
|
|
|
pub async fn get_primary_field(&self, database_view_id: &str) -> FieldPB {
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_database2::event_map::DatabaseEvent::GetPrimaryField)
|
|
|
|
.payload(DatabaseViewIdPB {
|
|
|
|
value: database_view_id.to_string(),
|
|
|
|
})
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.parse::<FieldPB>()
|
|
|
|
}
|
|
|
|
|
2023-06-07 06:52:35 +00:00
|
|
|
pub async fn create_row(
|
|
|
|
&self,
|
|
|
|
view_id: &str,
|
|
|
|
start_row_id: Option<String>,
|
|
|
|
data: Option<RowDataPB>,
|
2023-06-14 14:16:33 +00:00
|
|
|
) -> RowMetaPB {
|
2023-06-07 06:52:35 +00:00
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_database2::event_map::DatabaseEvent::CreateRow)
|
|
|
|
.payload(CreateRowPayloadPB {
|
|
|
|
view_id: view_id.to_string(),
|
|
|
|
start_row_id,
|
|
|
|
group_id: None,
|
|
|
|
data,
|
|
|
|
})
|
|
|
|
.async_send()
|
|
|
|
.await
|
2023-06-14 14:16:33 +00:00
|
|
|
.parse::<RowMetaPB>()
|
2023-06-07 06:52:35 +00:00
|
|
|
}
|
|
|
|
|
2023-06-09 10:57:29 +00:00
|
|
|
pub async fn delete_row(&self, view_id: &str, row_id: &str) -> Option<FlowyError> {
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_database2::event_map::DatabaseEvent::DeleteRow)
|
|
|
|
.payload(RowIdPB {
|
|
|
|
view_id: view_id.to_string(),
|
|
|
|
row_id: row_id.to_string(),
|
|
|
|
group_id: None,
|
|
|
|
})
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.error()
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn get_row(&self, view_id: &str, row_id: &str) -> OptionalRowPB {
|
2023-06-07 06:52:35 +00:00
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_database2::event_map::DatabaseEvent::GetRow)
|
|
|
|
.payload(RowIdPB {
|
|
|
|
view_id: view_id.to_string(),
|
|
|
|
row_id: row_id.to_string(),
|
|
|
|
group_id: None,
|
|
|
|
})
|
|
|
|
.async_send()
|
|
|
|
.await
|
2023-06-09 10:57:29 +00:00
|
|
|
.parse::<OptionalRowPB>()
|
2023-06-07 06:52:35 +00:00
|
|
|
}
|
|
|
|
|
2023-06-14 14:16:33 +00:00
|
|
|
pub async fn get_row_meta(&self, view_id: &str, row_id: &str) -> RowMetaPB {
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_database2::event_map::DatabaseEvent::GetRowMeta)
|
|
|
|
.payload(RowIdPB {
|
|
|
|
view_id: view_id.to_string(),
|
|
|
|
row_id: row_id.to_string(),
|
|
|
|
group_id: None,
|
|
|
|
})
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.parse::<RowMetaPB>()
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn update_row_meta(&self, changeset: UpdateRowMetaChangesetPB) -> Option<FlowyError> {
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_database2::event_map::DatabaseEvent::UpdateRowMeta)
|
|
|
|
.payload(changeset)
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.error()
|
|
|
|
}
|
|
|
|
|
2023-06-07 06:52:35 +00:00
|
|
|
pub async fn duplicate_row(&self, view_id: &str, row_id: &str) -> Option<FlowyError> {
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_database2::event_map::DatabaseEvent::DuplicateRow)
|
|
|
|
.payload(RowIdPB {
|
|
|
|
view_id: view_id.to_string(),
|
|
|
|
row_id: row_id.to_string(),
|
|
|
|
group_id: None,
|
|
|
|
})
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.error()
|
|
|
|
}
|
|
|
|
|
2023-06-09 10:57:29 +00:00
|
|
|
pub async fn move_row(&self, view_id: &str, row_id: &str, to_row_id: &str) -> Option<FlowyError> {
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_database2::event_map::DatabaseEvent::MoveRow)
|
|
|
|
.payload(MoveRowPayloadPB {
|
|
|
|
view_id: view_id.to_string(),
|
|
|
|
from_row_id: row_id.to_string(),
|
|
|
|
to_row_id: to_row_id.to_string(),
|
|
|
|
})
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.error()
|
|
|
|
}
|
|
|
|
|
2023-06-07 06:52:35 +00:00
|
|
|
pub async fn update_cell(&self, changeset: CellChangesetPB) -> Option<FlowyError> {
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_database2::event_map::DatabaseEvent::UpdateCell)
|
|
|
|
.payload(changeset)
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.error()
|
|
|
|
}
|
|
|
|
|
2023-06-09 10:57:29 +00:00
|
|
|
pub async fn update_date_cell(&self, changeset: DateChangesetPB) -> Option<FlowyError> {
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_database2::event_map::DatabaseEvent::UpdateDateCell)
|
|
|
|
.payload(changeset)
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.error()
|
|
|
|
}
|
|
|
|
|
2023-06-07 06:52:35 +00:00
|
|
|
pub async fn get_cell(&self, view_id: &str, row_id: &str, field_id: &str) -> CellPB {
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_database2::event_map::DatabaseEvent::GetCell)
|
|
|
|
.payload(CellIdPB {
|
|
|
|
view_id: view_id.to_string(),
|
|
|
|
row_id: row_id.to_string(),
|
|
|
|
field_id: field_id.to_string(),
|
|
|
|
})
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.parse::<CellPB>()
|
|
|
|
}
|
|
|
|
|
2023-06-09 10:57:29 +00:00
|
|
|
pub async fn get_date_cell(&self, view_id: &str, row_id: &str, field_id: &str) -> DateCellDataPB {
|
|
|
|
let cell = self.get_cell(view_id, row_id, field_id).await;
|
|
|
|
DateCellDataPB::try_from(Bytes::from(cell.data)).unwrap()
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn get_checklist_cell(
|
|
|
|
&self,
|
|
|
|
view_id: &str,
|
|
|
|
field_id: &str,
|
|
|
|
row_id: &str,
|
|
|
|
) -> ChecklistCellDataPB {
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_database2::event_map::DatabaseEvent::GetChecklistCellData)
|
|
|
|
.payload(CellIdPB {
|
|
|
|
view_id: view_id.to_string(),
|
|
|
|
row_id: row_id.to_string(),
|
|
|
|
field_id: field_id.to_string(),
|
|
|
|
})
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.parse::<ChecklistCellDataPB>()
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn update_checklist_cell(
|
|
|
|
&self,
|
|
|
|
changeset: ChecklistCellDataChangesetPB,
|
|
|
|
) -> Option<FlowyError> {
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_database2::event_map::DatabaseEvent::UpdateChecklistCell)
|
|
|
|
.payload(changeset)
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.error()
|
|
|
|
}
|
|
|
|
|
2023-06-07 06:52:35 +00:00
|
|
|
pub async fn insert_option(
|
|
|
|
&self,
|
|
|
|
view_id: &str,
|
|
|
|
field_id: &str,
|
|
|
|
row_id: &str,
|
|
|
|
name: &str,
|
|
|
|
) -> Option<FlowyError> {
|
|
|
|
let option = EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_database2::event_map::DatabaseEvent::CreateSelectOption)
|
|
|
|
.payload(CreateSelectOptionPayloadPB {
|
|
|
|
field_id: field_id.to_string(),
|
|
|
|
view_id: view_id.to_string(),
|
|
|
|
option_name: name.to_string(),
|
|
|
|
})
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.parse::<SelectOptionPB>();
|
|
|
|
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_database2::event_map::DatabaseEvent::InsertOrUpdateSelectOption)
|
|
|
|
.payload(RepeatedSelectOptionPayload {
|
|
|
|
view_id: view_id.to_string(),
|
|
|
|
field_id: field_id.to_string(),
|
|
|
|
row_id: row_id.to_string(),
|
|
|
|
items: vec![option],
|
|
|
|
})
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.error()
|
|
|
|
}
|
|
|
|
|
2023-06-09 10:57:29 +00:00
|
|
|
pub async fn get_groups(&self, view_id: &str) -> Vec<GroupPB> {
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_database2::event_map::DatabaseEvent::GetGroups)
|
|
|
|
.payload(DatabaseViewIdPB {
|
|
|
|
value: view_id.to_string(),
|
|
|
|
})
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.parse::<RepeatedGroupPB>()
|
|
|
|
.items
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn move_group(&self, view_id: &str, from_id: &str, to_id: &str) -> Option<FlowyError> {
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_database2::event_map::DatabaseEvent::MoveGroup)
|
|
|
|
.payload(MoveGroupPayloadPB {
|
|
|
|
view_id: view_id.to_string(),
|
|
|
|
from_group_id: from_id.to_string(),
|
|
|
|
to_group_id: to_id.to_string(),
|
|
|
|
})
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.error()
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn set_group_by_field(&self, view_id: &str, field_id: &str) -> Option<FlowyError> {
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_database2::event_map::DatabaseEvent::SetGroupByField)
|
|
|
|
.payload(GroupByFieldPayloadPB {
|
|
|
|
field_id: field_id.to_string(),
|
|
|
|
view_id: view_id.to_string(),
|
|
|
|
})
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.error()
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn update_group(
|
|
|
|
&self,
|
|
|
|
view_id: &str,
|
|
|
|
group_id: &str,
|
|
|
|
name: Option<String>,
|
|
|
|
visible: Option<bool>,
|
|
|
|
) -> Option<FlowyError> {
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_database2::event_map::DatabaseEvent::UpdateGroup)
|
|
|
|
.payload(UpdateGroupPB {
|
|
|
|
view_id: view_id.to_string(),
|
|
|
|
group_id: group_id.to_string(),
|
|
|
|
name,
|
|
|
|
visible,
|
|
|
|
})
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.error()
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn update_setting(&self, changeset: DatabaseSettingChangesetPB) -> Option<FlowyError> {
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_database2::event_map::DatabaseEvent::UpdateDatabaseSetting)
|
|
|
|
.payload(changeset)
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.error()
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn get_all_calendar_events(&self, view_id: &str) -> Vec<CalendarEventPB> {
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_database2::event_map::DatabaseEvent::GetAllCalendarEvents)
|
|
|
|
.payload(CalendarEventRequestPB {
|
|
|
|
view_id: view_id.to_string(),
|
|
|
|
})
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.parse::<RepeatedCalendarEventPB>()
|
|
|
|
.items
|
|
|
|
}
|
|
|
|
|
2023-06-06 16:05:27 +00:00
|
|
|
pub async fn get_view(&self, view_id: &str) -> ViewPB {
|
|
|
|
EventBuilder::new(self.clone())
|
|
|
|
.event(flowy_folder2::event_map::FolderEvent::ReadView)
|
|
|
|
.payload(ViewIdPB {
|
|
|
|
value: view_id.to_string(),
|
|
|
|
})
|
|
|
|
.async_send()
|
|
|
|
.await
|
|
|
|
.parse::<flowy_folder2::entities::ViewPB>()
|
|
|
|
}
|
2021-07-06 06:14:47 +00:00
|
|
|
}
|
2023-05-23 15:55:21 +00:00
|
|
|
|
|
|
|
impl std::ops::Deref for FlowyCoreTest {
|
|
|
|
type Target = AppFlowyCore;
|
|
|
|
|
|
|
|
fn deref(&self) -> &Self::Target {
|
|
|
|
&self.inner
|
|
|
|
}
|
|
|
|
}
|
2023-06-05 08:09:18 +00:00
|
|
|
|
|
|
|
// pub struct TestNotificationSender {
|
|
|
|
// pub(crate) sender: tokio::sync::mpsc::Sender<()>,
|
|
|
|
// }
|
|
|
|
//
|
|
|
|
// impl NotificationSender for TestNotificationSender {
|
|
|
|
// fn send_subject(&self, subject: SubscribeObject) -> Result<(), String> {
|
|
|
|
// todo!()
|
|
|
|
// }
|
|
|
|
// }
|