2022-05-22 13:08:38 +08:00
|
|
|
use crate::entities::*;
|
2023-01-31 08:28:31 +08:00
|
|
|
use crate::manager::DatabaseManager;
|
2022-12-26 20:28:18 +08:00
|
|
|
use crate::services::cell::{FromCellString, ToCellChangesetString, TypeCellData};
|
2022-07-07 18:20:12 +08:00
|
|
|
use crate::services::field::{
|
2023-02-13 09:29:49 +08:00
|
|
|
default_type_option_builder_from_type, select_type_option_from_field_rev,
|
|
|
|
type_option_builder_from_json_str, DateCellChangeset, DateChangesetPB, SelectOptionCellChangeset,
|
|
|
|
SelectOptionCellChangesetPB, SelectOptionCellChangesetParams, SelectOptionCellDataPB,
|
|
|
|
SelectOptionChangeset, SelectOptionChangesetPB, SelectOptionIds, SelectOptionPB,
|
2022-07-07 18:20:12 +08:00
|
|
|
};
|
2022-12-11 11:35:42 +08:00
|
|
|
use crate::services::row::make_row_from_row_rev;
|
2023-02-21 15:47:51 +08:00
|
|
|
use database_model::FieldRevision;
|
2022-04-07 08:33:10 +08:00
|
|
|
use flowy_error::{ErrorCode, FlowyError, FlowyResult};
|
2023-02-26 16:27:17 +08:00
|
|
|
use lib_dispatch::prelude::{data_result_ok, AFPluginData, AFPluginState, DataResult};
|
2022-03-02 22:43:04 +08:00
|
|
|
use std::sync::Arc;
|
|
|
|
|
2022-05-26 17:28:44 +08:00
|
|
|
#[tracing::instrument(level = "trace", skip(data, manager), err)]
|
2023-01-31 08:28:31 +08:00
|
|
|
pub(crate) async fn get_database_data_handler(
|
2023-02-21 15:47:51 +08:00
|
|
|
data: AFPluginData<DatabaseViewIdPB>,
|
2023-02-13 09:29:49 +08:00
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2023-01-31 08:28:31 +08:00
|
|
|
) -> DataResult<DatabasePB, FlowyError> {
|
2023-02-26 16:27:17 +08:00
|
|
|
let view_id: DatabaseViewIdPB = data.into_inner();
|
|
|
|
let editor = manager.open_database_view(view_id.as_ref()).await?;
|
|
|
|
let database = editor.get_database(view_id.as_ref()).await?;
|
|
|
|
data_result_ok(database)
|
2022-03-03 22:17:07 +08:00
|
|
|
}
|
|
|
|
|
2022-06-19 21:10:07 +08:00
|
|
|
#[tracing::instrument(level = "trace", skip(data, manager), err)]
|
2023-01-31 08:28:31 +08:00
|
|
|
pub(crate) async fn get_database_setting_handler(
|
2023-02-21 15:47:51 +08:00
|
|
|
data: AFPluginData<DatabaseViewIdPB>,
|
2023-02-13 09:29:49 +08:00
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2023-01-31 08:28:31 +08:00
|
|
|
) -> DataResult<DatabaseViewSettingPB, FlowyError> {
|
2023-02-26 16:27:17 +08:00
|
|
|
let view_id: DatabaseViewIdPB = data.into_inner();
|
|
|
|
let editor = manager.open_database_view(view_id.as_ref()).await?;
|
|
|
|
let database_setting = editor.get_setting(view_id.as_ref()).await?;
|
|
|
|
data_result_ok(database_setting)
|
2022-06-19 21:10:07 +08:00
|
|
|
}
|
|
|
|
|
2022-09-04 15:33:07 +08:00
|
|
|
#[tracing::instrument(level = "trace", skip(data, manager), err)]
|
2023-01-31 08:28:31 +08:00
|
|
|
pub(crate) async fn update_database_setting_handler(
|
2023-02-13 09:29:49 +08:00
|
|
|
data: AFPluginData<DatabaseSettingChangesetPB>,
|
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2022-09-04 15:33:07 +08:00
|
|
|
) -> Result<(), FlowyError> {
|
2023-02-13 09:29:49 +08:00
|
|
|
let params: DatabaseSettingChangesetParams = data.into_inner().try_into()?;
|
2022-09-04 15:33:07 +08:00
|
|
|
|
2023-02-21 15:47:51 +08:00
|
|
|
let editor = manager.get_database_editor(¶ms.view_id).await?;
|
2023-02-13 09:29:49 +08:00
|
|
|
if let Some(insert_params) = params.insert_group {
|
|
|
|
editor.insert_group(insert_params).await?;
|
|
|
|
}
|
2022-09-04 15:33:07 +08:00
|
|
|
|
2023-02-13 09:29:49 +08:00
|
|
|
if let Some(delete_params) = params.delete_group {
|
|
|
|
editor.delete_group(delete_params).await?;
|
|
|
|
}
|
2022-09-04 15:33:07 +08:00
|
|
|
|
2023-02-13 09:29:49 +08:00
|
|
|
if let Some(alter_filter) = params.insert_filter {
|
|
|
|
editor.create_or_update_filter(alter_filter).await?;
|
|
|
|
}
|
2022-09-04 15:33:07 +08:00
|
|
|
|
2023-02-13 09:29:49 +08:00
|
|
|
if let Some(delete_filter) = params.delete_filter {
|
|
|
|
editor.delete_filter(delete_filter).await?;
|
|
|
|
}
|
2022-12-12 10:52:14 +08:00
|
|
|
|
2023-02-13 09:29:49 +08:00
|
|
|
if let Some(alter_sort) = params.alert_sort {
|
|
|
|
let _ = editor.create_or_update_sort(alter_sort).await?;
|
|
|
|
}
|
|
|
|
if let Some(delete_sort) = params.delete_sort {
|
|
|
|
editor.delete_sort(delete_sort).await?;
|
|
|
|
}
|
|
|
|
Ok(())
|
2022-09-04 15:33:07 +08:00
|
|
|
}
|
|
|
|
|
2022-11-15 23:17:01 +08:00
|
|
|
#[tracing::instrument(level = "trace", skip(data, manager), err)]
|
|
|
|
pub(crate) async fn get_all_filters_handler(
|
2023-02-21 15:47:51 +08:00
|
|
|
data: AFPluginData<DatabaseViewIdPB>,
|
2023-02-13 09:29:49 +08:00
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2022-11-15 23:17:01 +08:00
|
|
|
) -> DataResult<RepeatedFilterPB, FlowyError> {
|
2023-02-26 16:27:17 +08:00
|
|
|
let view_id: DatabaseViewIdPB = data.into_inner();
|
|
|
|
let editor = manager.open_database_view(view_id.as_ref()).await?;
|
2023-02-13 09:29:49 +08:00
|
|
|
let filters = RepeatedFilterPB {
|
2023-02-26 16:27:17 +08:00
|
|
|
items: editor.get_all_filters(view_id.as_ref()).await?,
|
2023-02-13 09:29:49 +08:00
|
|
|
};
|
2023-02-26 16:27:17 +08:00
|
|
|
data_result_ok(filters)
|
2022-11-15 23:17:01 +08:00
|
|
|
}
|
|
|
|
|
2023-01-11 17:48:53 +08:00
|
|
|
#[tracing::instrument(level = "trace", skip(data, manager), err)]
|
|
|
|
pub(crate) async fn get_all_sorts_handler(
|
2023-02-21 15:47:51 +08:00
|
|
|
data: AFPluginData<DatabaseViewIdPB>,
|
2023-02-13 09:29:49 +08:00
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2023-01-11 17:48:53 +08:00
|
|
|
) -> DataResult<RepeatedSortPB, FlowyError> {
|
2023-02-26 16:27:17 +08:00
|
|
|
let view_id: DatabaseViewIdPB = data.into_inner();
|
|
|
|
let editor = manager.open_database_view(view_id.as_ref()).await?;
|
2023-02-13 09:29:49 +08:00
|
|
|
let sorts = RepeatedSortPB {
|
2023-02-26 16:27:17 +08:00
|
|
|
items: editor.get_all_sorts(view_id.as_ref()).await?,
|
2023-02-13 09:29:49 +08:00
|
|
|
};
|
2023-02-26 16:27:17 +08:00
|
|
|
data_result_ok(sorts)
|
2023-01-11 17:48:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[tracing::instrument(level = "trace", skip(data, manager), err)]
|
|
|
|
pub(crate) async fn delete_all_sorts_handler(
|
2023-02-21 15:47:51 +08:00
|
|
|
data: AFPluginData<DatabaseViewIdPB>,
|
2023-02-13 09:29:49 +08:00
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2023-01-11 17:48:53 +08:00
|
|
|
) -> Result<(), FlowyError> {
|
2023-02-26 16:27:17 +08:00
|
|
|
let view_id: DatabaseViewIdPB = data.into_inner();
|
|
|
|
let editor = manager.open_database_view(view_id.as_ref()).await?;
|
|
|
|
editor.delete_all_sorts(view_id.as_ref()).await?;
|
2023-02-13 09:29:49 +08:00
|
|
|
Ok(())
|
2023-01-11 17:48:53 +08:00
|
|
|
}
|
|
|
|
|
2022-05-26 17:28:44 +08:00
|
|
|
#[tracing::instrument(level = "trace", skip(data, manager), err)]
|
2022-03-23 22:10:31 +08:00
|
|
|
pub(crate) async fn get_fields_handler(
|
2023-02-13 09:29:49 +08:00
|
|
|
data: AFPluginData<GetFieldPayloadPB>,
|
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2022-08-11 13:25:55 +08:00
|
|
|
) -> DataResult<RepeatedFieldPB, FlowyError> {
|
2023-02-13 09:29:49 +08:00
|
|
|
let params: GetFieldParams = data.into_inner().try_into()?;
|
2023-02-21 15:47:51 +08:00
|
|
|
let editor = manager.get_database_editor(¶ms.view_id).await?;
|
2023-02-13 09:29:49 +08:00
|
|
|
let field_revs = editor.get_field_revs(params.field_ids).await?;
|
|
|
|
let repeated_field: RepeatedFieldPB = field_revs
|
|
|
|
.into_iter()
|
|
|
|
.map(FieldPB::from)
|
|
|
|
.collect::<Vec<_>>()
|
|
|
|
.into();
|
2023-02-26 16:27:17 +08:00
|
|
|
data_result_ok(repeated_field)
|
2022-03-23 22:10:31 +08:00
|
|
|
}
|
|
|
|
|
2022-05-26 17:28:44 +08:00
|
|
|
#[tracing::instrument(level = "trace", skip(data, manager), err)]
|
2022-03-23 22:10:31 +08:00
|
|
|
pub(crate) async fn update_field_handler(
|
2023-02-13 09:29:49 +08:00
|
|
|
data: AFPluginData<FieldChangesetPB>,
|
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2022-03-23 22:10:31 +08:00
|
|
|
) -> Result<(), FlowyError> {
|
2023-02-13 09:29:49 +08:00
|
|
|
let changeset: FieldChangesetParams = data.into_inner().try_into()?;
|
2023-02-26 16:27:17 +08:00
|
|
|
let editor = manager.get_database_editor(&changeset.view_id).await?;
|
2023-02-13 09:29:49 +08:00
|
|
|
editor.update_field(changeset).await?;
|
|
|
|
Ok(())
|
2022-03-23 22:10:31 +08:00
|
|
|
}
|
|
|
|
|
2022-05-26 17:28:44 +08:00
|
|
|
#[tracing::instrument(level = "trace", skip(data, manager), err)]
|
2022-05-10 09:33:34 +08:00
|
|
|
pub(crate) async fn update_field_type_option_handler(
|
2023-02-13 09:29:49 +08:00
|
|
|
data: AFPluginData<TypeOptionChangesetPB>,
|
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2022-05-10 09:33:34 +08:00
|
|
|
) -> Result<(), FlowyError> {
|
2023-02-13 09:29:49 +08:00
|
|
|
let params: TypeOptionChangesetParams = data.into_inner().try_into()?;
|
2023-02-21 15:47:51 +08:00
|
|
|
let editor = manager.get_database_editor(¶ms.view_id).await?;
|
2023-02-13 09:29:49 +08:00
|
|
|
let old_field_rev = editor.get_field_rev(¶ms.field_id).await;
|
|
|
|
editor
|
2023-02-26 16:27:17 +08:00
|
|
|
.update_field_type_option(
|
|
|
|
¶ms.view_id,
|
|
|
|
¶ms.field_id,
|
|
|
|
params.type_option_data,
|
|
|
|
old_field_rev,
|
|
|
|
)
|
2023-02-13 09:29:49 +08:00
|
|
|
.await?;
|
|
|
|
Ok(())
|
2022-05-10 09:33:34 +08:00
|
|
|
}
|
|
|
|
|
2022-05-26 17:28:44 +08:00
|
|
|
#[tracing::instrument(level = "trace", skip(data, manager), err)]
|
2022-03-27 09:35:10 +08:00
|
|
|
pub(crate) async fn delete_field_handler(
|
2023-02-13 09:29:49 +08:00
|
|
|
data: AFPluginData<DeleteFieldPayloadPB>,
|
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2022-03-27 09:35:10 +08:00
|
|
|
) -> Result<(), FlowyError> {
|
2023-02-13 09:29:49 +08:00
|
|
|
let params: FieldIdParams = data.into_inner().try_into()?;
|
2023-02-21 15:47:51 +08:00
|
|
|
let editor = manager.get_database_editor(¶ms.view_id).await?;
|
2023-02-13 09:29:49 +08:00
|
|
|
editor.delete_field(¶ms.field_id).await?;
|
|
|
|
Ok(())
|
2022-03-27 11:14:21 +08:00
|
|
|
}
|
|
|
|
|
2023-02-27 19:00:00 +08:00
|
|
|
#[tracing::instrument(level = "debug", skip(data, manager), err)]
|
2022-04-01 09:31:10 +08:00
|
|
|
pub(crate) async fn switch_to_field_handler(
|
2023-02-13 09:29:49 +08:00
|
|
|
data: AFPluginData<UpdateFieldTypePayloadPB>,
|
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2022-10-10 20:02:52 +08:00
|
|
|
) -> Result<(), FlowyError> {
|
2023-02-13 09:29:49 +08:00
|
|
|
let params: EditFieldParams = data.into_inner().try_into()?;
|
2023-02-21 15:47:51 +08:00
|
|
|
let editor = manager.get_database_editor(¶ms.view_id).await?;
|
2023-02-13 09:29:49 +08:00
|
|
|
let old_field_rev = editor.get_field_rev(¶ms.field_id).await;
|
|
|
|
editor
|
|
|
|
.switch_to_field_type(¶ms.field_id, ¶ms.field_type)
|
|
|
|
.await?;
|
|
|
|
|
|
|
|
// Get the field_rev with field_id, if it doesn't exist, we create the default FieldRevision from the FieldType.
|
|
|
|
let new_field_rev = editor
|
|
|
|
.get_field_rev(¶ms.field_id)
|
|
|
|
.await
|
|
|
|
.unwrap_or(Arc::new(editor.next_field_rev(¶ms.field_type).await?));
|
|
|
|
|
|
|
|
// Update the type-option data after the field type has been changed
|
|
|
|
let type_option_data = get_type_option_data(&new_field_rev, ¶ms.field_type).await?;
|
|
|
|
editor
|
2023-02-26 16:27:17 +08:00
|
|
|
.update_field_type_option(
|
|
|
|
¶ms.view_id,
|
|
|
|
&new_field_rev.id,
|
|
|
|
type_option_data,
|
|
|
|
old_field_rev,
|
|
|
|
)
|
2023-02-13 09:29:49 +08:00
|
|
|
.await?;
|
|
|
|
|
|
|
|
Ok(())
|
2022-04-01 09:31:10 +08:00
|
|
|
}
|
|
|
|
|
2022-05-26 17:28:44 +08:00
|
|
|
#[tracing::instrument(level = "trace", skip(data, manager), err)]
|
2022-03-27 11:14:21 +08:00
|
|
|
pub(crate) async fn duplicate_field_handler(
|
2023-02-13 09:29:49 +08:00
|
|
|
data: AFPluginData<DuplicateFieldPayloadPB>,
|
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2022-03-27 11:14:21 +08:00
|
|
|
) -> Result<(), FlowyError> {
|
2023-02-13 09:29:49 +08:00
|
|
|
let params: FieldIdParams = data.into_inner().try_into()?;
|
2023-02-21 15:47:51 +08:00
|
|
|
let editor = manager.get_database_editor(¶ms.view_id).await?;
|
2023-02-13 09:29:49 +08:00
|
|
|
editor.duplicate_field(¶ms.field_id).await?;
|
|
|
|
Ok(())
|
2022-03-27 09:35:10 +08:00
|
|
|
}
|
|
|
|
|
2022-05-19 10:41:00 +08:00
|
|
|
/// Return the FieldTypeOptionData if the Field exists otherwise return record not found error.
|
2022-05-26 17:28:44 +08:00
|
|
|
#[tracing::instrument(level = "trace", skip(data, manager), err)]
|
2022-05-09 13:23:03 +08:00
|
|
|
pub(crate) async fn get_field_type_option_data_handler(
|
2023-02-13 09:29:49 +08:00
|
|
|
data: AFPluginData<TypeOptionPathPB>,
|
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2022-11-14 09:59:23 +08:00
|
|
|
) -> DataResult<TypeOptionPB, FlowyError> {
|
2023-02-13 09:29:49 +08:00
|
|
|
let params: TypeOptionPathParams = data.into_inner().try_into()?;
|
2023-02-21 15:47:51 +08:00
|
|
|
let editor = manager.get_database_editor(¶ms.view_id).await?;
|
2023-02-13 09:29:49 +08:00
|
|
|
match editor.get_field_rev(¶ms.field_id).await {
|
|
|
|
None => Err(FlowyError::record_not_found()),
|
|
|
|
Some(field_rev) => {
|
|
|
|
let field_type = field_rev.ty.into();
|
|
|
|
let type_option_data = get_type_option_data(&field_rev, &field_type).await?;
|
|
|
|
let data = TypeOptionPB {
|
2023-02-21 15:47:51 +08:00
|
|
|
view_id: params.view_id,
|
2023-02-13 09:29:49 +08:00
|
|
|
field: field_rev.into(),
|
|
|
|
type_option_data,
|
|
|
|
};
|
2023-02-26 16:27:17 +08:00
|
|
|
data_result_ok(data)
|
2023-02-13 09:29:49 +08:00
|
|
|
},
|
|
|
|
}
|
2022-05-19 10:41:00 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/// Create FieldMeta and save it. Return the FieldTypeOptionData.
|
2022-05-26 17:28:44 +08:00
|
|
|
#[tracing::instrument(level = "trace", skip(data, manager), err)]
|
2022-05-19 10:41:00 +08:00
|
|
|
pub(crate) async fn create_field_type_option_data_handler(
|
2023-02-13 09:29:49 +08:00
|
|
|
data: AFPluginData<CreateFieldPayloadPB>,
|
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2022-11-14 09:59:23 +08:00
|
|
|
) -> DataResult<TypeOptionPB, FlowyError> {
|
2023-02-13 09:29:49 +08:00
|
|
|
let params: CreateFieldParams = data.into_inner().try_into()?;
|
2023-02-21 15:47:51 +08:00
|
|
|
let editor = manager.get_database_editor(¶ms.view_id).await?;
|
2023-02-13 09:29:49 +08:00
|
|
|
let field_rev = editor
|
|
|
|
.create_new_field_rev_with_type_option(¶ms.field_type, params.type_option_data)
|
|
|
|
.await?;
|
|
|
|
let field_type: FieldType = field_rev.ty.into();
|
|
|
|
let type_option_data = get_type_option_data(&field_rev, &field_type).await?;
|
2022-05-09 13:23:03 +08:00
|
|
|
|
2023-02-26 16:27:17 +08:00
|
|
|
data_result_ok(TypeOptionPB {
|
2023-02-21 15:47:51 +08:00
|
|
|
view_id: params.view_id,
|
2023-02-13 09:29:49 +08:00
|
|
|
field: field_rev.into(),
|
|
|
|
type_option_data,
|
|
|
|
})
|
2022-05-09 13:23:03 +08:00
|
|
|
}
|
|
|
|
|
2022-05-26 17:28:44 +08:00
|
|
|
#[tracing::instrument(level = "trace", skip(data, manager), err)]
|
2022-08-16 15:49:54 +08:00
|
|
|
pub(crate) async fn move_field_handler(
|
2023-02-13 09:29:49 +08:00
|
|
|
data: AFPluginData<MoveFieldPayloadPB>,
|
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2022-04-13 14:24:54 +08:00
|
|
|
) -> Result<(), FlowyError> {
|
2023-02-13 09:29:49 +08:00
|
|
|
let params: MoveFieldParams = data.into_inner().try_into()?;
|
|
|
|
let editor = manager.get_database_editor(¶ms.view_id).await?;
|
|
|
|
editor.move_field(params).await?;
|
|
|
|
Ok(())
|
2022-04-13 14:24:54 +08:00
|
|
|
}
|
|
|
|
|
2022-10-10 20:02:52 +08:00
|
|
|
/// The [FieldRevision] contains multiple data, each of them belongs to a specific FieldType.
|
2023-02-13 09:29:49 +08:00
|
|
|
async fn get_type_option_data(
|
|
|
|
field_rev: &FieldRevision,
|
|
|
|
field_type: &FieldType,
|
|
|
|
) -> FlowyResult<Vec<u8>> {
|
|
|
|
let s = field_rev
|
|
|
|
.get_type_option_str(field_type)
|
|
|
|
.map(|value| value.to_owned())
|
|
|
|
.unwrap_or_else(|| {
|
|
|
|
default_type_option_builder_from_type(field_type)
|
|
|
|
.serializer()
|
|
|
|
.json_str()
|
|
|
|
});
|
|
|
|
let field_type: FieldType = field_rev.ty.into();
|
|
|
|
let builder = type_option_builder_from_json_str(&s, &field_type);
|
|
|
|
let type_option_data = builder.serializer().protobuf_bytes().to_vec();
|
|
|
|
|
|
|
|
Ok(type_option_data)
|
2022-05-09 13:23:03 +08:00
|
|
|
}
|
|
|
|
|
2022-08-18 17:40:23 +08:00
|
|
|
// #[tracing::instrument(level = "debug", skip(data, manager), err)]
|
2022-03-18 17:14:46 +08:00
|
|
|
pub(crate) async fn get_row_handler(
|
2023-02-13 09:29:49 +08:00
|
|
|
data: AFPluginData<RowIdPB>,
|
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2022-07-17 13:38:53 +08:00
|
|
|
) -> DataResult<OptionalRowPB, FlowyError> {
|
2023-02-13 09:29:49 +08:00
|
|
|
let params: RowIdParams = data.into_inner().try_into()?;
|
2023-02-21 15:47:51 +08:00
|
|
|
let editor = manager.get_database_editor(¶ms.view_id).await?;
|
2023-02-13 09:29:49 +08:00
|
|
|
let row = editor
|
|
|
|
.get_row_rev(¶ms.row_id)
|
|
|
|
.await?
|
|
|
|
.map(make_row_from_row_rev);
|
2022-07-12 15:49:14 +08:00
|
|
|
|
2023-02-26 16:27:17 +08:00
|
|
|
data_result_ok(OptionalRowPB { row })
|
2022-03-18 17:14:46 +08:00
|
|
|
}
|
|
|
|
|
2022-03-06 11:28:24 +08:00
|
|
|
#[tracing::instrument(level = "debug", skip(data, manager), err)]
|
2022-04-09 22:07:48 +08:00
|
|
|
pub(crate) async fn delete_row_handler(
|
2023-02-13 09:29:49 +08:00
|
|
|
data: AFPluginData<RowIdPB>,
|
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2022-04-09 22:42:42 +08:00
|
|
|
) -> Result<(), FlowyError> {
|
2023-02-13 09:29:49 +08:00
|
|
|
let params: RowIdParams = data.into_inner().try_into()?;
|
2023-02-21 15:47:51 +08:00
|
|
|
let editor = manager.get_database_editor(¶ms.view_id).await?;
|
2023-02-13 09:29:49 +08:00
|
|
|
editor.delete_row(¶ms.row_id).await?;
|
|
|
|
Ok(())
|
2022-04-09 22:07:48 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[tracing::instrument(level = "debug", skip(data, manager), err)]
|
|
|
|
pub(crate) async fn duplicate_row_handler(
|
2023-02-13 09:29:49 +08:00
|
|
|
data: AFPluginData<RowIdPB>,
|
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2022-04-09 22:42:42 +08:00
|
|
|
) -> Result<(), FlowyError> {
|
2023-02-13 09:29:49 +08:00
|
|
|
let params: RowIdParams = data.into_inner().try_into()?;
|
2023-02-21 15:47:51 +08:00
|
|
|
let editor = manager.get_database_editor(¶ms.view_id).await?;
|
2023-02-13 09:29:49 +08:00
|
|
|
editor.duplicate_row(¶ms.row_id).await?;
|
|
|
|
Ok(())
|
2022-04-09 22:07:48 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[tracing::instrument(level = "debug", skip(data, manager), err)]
|
2022-08-16 15:49:54 +08:00
|
|
|
pub(crate) async fn move_row_handler(
|
2023-02-13 09:29:49 +08:00
|
|
|
data: AFPluginData<MoveRowPayloadPB>,
|
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2022-08-16 15:49:54 +08:00
|
|
|
) -> Result<(), FlowyError> {
|
2023-02-13 09:29:49 +08:00
|
|
|
let params: MoveRowParams = data.into_inner().try_into()?;
|
|
|
|
let editor = manager.get_database_editor(¶ms.view_id).await?;
|
|
|
|
editor.move_row(params).await?;
|
|
|
|
Ok(())
|
2022-08-16 15:49:54 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[tracing::instrument(level = "debug", skip(data, manager), err)]
|
2023-03-08 21:19:44 +08:00
|
|
|
pub(crate) async fn create_row_handler(
|
2023-02-13 09:29:49 +08:00
|
|
|
data: AFPluginData<CreateRowPayloadPB>,
|
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2022-08-13 16:23:44 +08:00
|
|
|
) -> DataResult<RowPB, FlowyError> {
|
2023-02-13 09:29:49 +08:00
|
|
|
let params: CreateRowParams = data.into_inner().try_into()?;
|
2023-02-21 15:47:51 +08:00
|
|
|
let editor = manager.get_database_editor(params.view_id.as_ref()).await?;
|
2023-02-13 09:29:49 +08:00
|
|
|
let row = editor.create_row(params).await?;
|
2023-02-26 16:27:17 +08:00
|
|
|
data_result_ok(row)
|
2022-03-02 22:43:04 +08:00
|
|
|
}
|
2022-03-09 16:11:24 +08:00
|
|
|
|
2022-08-25 12:36:56 +08:00
|
|
|
#[tracing::instrument(level = "trace", skip_all, err)]
|
2022-04-07 20:15:00 +08:00
|
|
|
pub(crate) async fn get_cell_handler(
|
2023-02-13 09:29:49 +08:00
|
|
|
data: AFPluginData<CellIdPB>,
|
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2022-11-14 09:59:23 +08:00
|
|
|
) -> DataResult<CellPB, FlowyError> {
|
2023-02-13 09:29:49 +08:00
|
|
|
let params: CellIdParams = data.into_inner().try_into()?;
|
2023-02-26 16:27:17 +08:00
|
|
|
let editor = manager.get_database_editor(¶ms.view_id).await?;
|
2023-02-13 09:29:49 +08:00
|
|
|
match editor.get_cell(¶ms).await {
|
2023-02-26 16:27:17 +08:00
|
|
|
None => data_result_ok(CellPB::empty(¶ms.field_id, ¶ms.row_id)),
|
|
|
|
Some(cell) => data_result_ok(cell),
|
2023-02-13 09:29:49 +08:00
|
|
|
}
|
2022-04-07 20:15:00 +08:00
|
|
|
}
|
|
|
|
|
2022-05-26 17:28:44 +08:00
|
|
|
#[tracing::instrument(level = "trace", skip_all, err)]
|
2022-03-09 16:11:24 +08:00
|
|
|
pub(crate) async fn update_cell_handler(
|
2023-02-13 09:29:49 +08:00
|
|
|
data: AFPluginData<CellChangesetPB>,
|
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2022-03-09 16:11:24 +08:00
|
|
|
) -> Result<(), FlowyError> {
|
2023-02-13 09:29:49 +08:00
|
|
|
let changeset: CellChangesetPB = data.into_inner();
|
2023-02-26 16:27:17 +08:00
|
|
|
let editor = manager.get_database_editor(&changeset.view_id).await?;
|
2023-02-13 09:29:49 +08:00
|
|
|
editor
|
|
|
|
.update_cell_with_changeset(
|
|
|
|
&changeset.row_id,
|
|
|
|
&changeset.field_id,
|
|
|
|
changeset.type_cell_data,
|
|
|
|
)
|
|
|
|
.await?;
|
|
|
|
Ok(())
|
2022-03-09 16:11:24 +08:00
|
|
|
}
|
2022-04-05 14:25:07 +08:00
|
|
|
|
2022-05-26 17:28:44 +08:00
|
|
|
#[tracing::instrument(level = "trace", skip_all, err)]
|
2022-04-18 17:17:42 +08:00
|
|
|
pub(crate) async fn new_select_option_handler(
|
2023-02-13 09:29:49 +08:00
|
|
|
data: AFPluginData<CreateSelectOptionPayloadPB>,
|
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2022-07-17 13:38:53 +08:00
|
|
|
) -> DataResult<SelectOptionPB, FlowyError> {
|
2023-02-13 09:29:49 +08:00
|
|
|
let params: CreateSelectOptionParams = data.into_inner().try_into()?;
|
2023-02-26 16:27:17 +08:00
|
|
|
let editor = manager.get_database_editor(¶ms.view_id).await?;
|
2023-02-13 09:29:49 +08:00
|
|
|
match editor.get_field_rev(¶ms.field_id).await {
|
|
|
|
None => Err(ErrorCode::InvalidData.into()),
|
|
|
|
Some(field_rev) => {
|
|
|
|
let type_option = select_type_option_from_field_rev(&field_rev)?;
|
|
|
|
let select_option = type_option.create_option(¶ms.option_name);
|
2023-02-26 16:27:17 +08:00
|
|
|
data_result_ok(select_option)
|
2023-02-13 09:29:49 +08:00
|
|
|
},
|
|
|
|
}
|
2022-04-07 08:33:10 +08:00
|
|
|
}
|
|
|
|
|
2022-05-26 17:28:44 +08:00
|
|
|
#[tracing::instrument(level = "trace", skip_all, err)]
|
2022-04-12 10:06:47 +08:00
|
|
|
pub(crate) async fn update_select_option_handler(
|
2023-02-13 09:29:49 +08:00
|
|
|
data: AFPluginData<SelectOptionChangesetPB>,
|
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2022-04-05 14:25:07 +08:00
|
|
|
) -> Result<(), FlowyError> {
|
2023-02-13 09:29:49 +08:00
|
|
|
let changeset: SelectOptionChangeset = data.into_inner().try_into()?;
|
|
|
|
let editor = manager
|
2023-02-26 16:27:17 +08:00
|
|
|
.get_database_editor(&changeset.cell_path.view_id)
|
2023-02-13 09:29:49 +08:00
|
|
|
.await?;
|
|
|
|
let field_id = changeset.cell_path.field_id.clone();
|
|
|
|
let (tx, rx) = tokio::sync::oneshot::channel();
|
|
|
|
editor
|
2023-02-26 16:27:17 +08:00
|
|
|
.modify_field_rev(&changeset.cell_path.view_id, &field_id, |field_rev| {
|
2023-02-13 09:29:49 +08:00
|
|
|
let mut type_option = select_type_option_from_field_rev(field_rev)?;
|
|
|
|
let mut cell_changeset_str = None;
|
|
|
|
let mut is_changed = None;
|
|
|
|
|
|
|
|
for option in changeset.insert_options {
|
|
|
|
cell_changeset_str = Some(
|
|
|
|
SelectOptionCellChangeset::from_insert_option_id(&option.id).to_cell_changeset_str(),
|
|
|
|
);
|
|
|
|
type_option.insert_option(option);
|
|
|
|
is_changed = Some(());
|
|
|
|
}
|
|
|
|
|
|
|
|
for option in changeset.update_options {
|
|
|
|
type_option.insert_option(option);
|
|
|
|
is_changed = Some(());
|
|
|
|
}
|
|
|
|
|
|
|
|
for option in changeset.delete_options {
|
|
|
|
cell_changeset_str = Some(
|
|
|
|
SelectOptionCellChangeset::from_delete_option_id(&option.id).to_cell_changeset_str(),
|
|
|
|
);
|
|
|
|
type_option.delete_option(option);
|
|
|
|
is_changed = Some(());
|
|
|
|
}
|
|
|
|
|
|
|
|
if is_changed.is_some() {
|
|
|
|
field_rev.insert_type_option(&*type_option);
|
|
|
|
}
|
|
|
|
let _ = tx.send(cell_changeset_str);
|
|
|
|
Ok(is_changed)
|
|
|
|
})
|
|
|
|
.await?;
|
|
|
|
|
|
|
|
if let Ok(Some(cell_changeset_str)) = rx.await {
|
|
|
|
match editor
|
|
|
|
.update_cell_with_changeset(
|
|
|
|
&changeset.cell_path.row_id,
|
|
|
|
&changeset.cell_path.field_id,
|
|
|
|
cell_changeset_str,
|
|
|
|
)
|
|
|
|
.await
|
|
|
|
{
|
|
|
|
Ok(_) => {},
|
|
|
|
Err(e) => tracing::error!("{}", e),
|
2023-02-04 10:07:21 +08:00
|
|
|
}
|
2023-02-13 09:29:49 +08:00
|
|
|
}
|
|
|
|
Ok(())
|
2022-04-07 08:33:10 +08:00
|
|
|
}
|
|
|
|
|
2022-05-26 17:28:44 +08:00
|
|
|
#[tracing::instrument(level = "trace", skip(data, manager), err)]
|
2022-04-07 08:33:10 +08:00
|
|
|
pub(crate) async fn get_select_option_handler(
|
2023-02-13 09:29:49 +08:00
|
|
|
data: AFPluginData<CellIdPB>,
|
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2022-07-17 13:38:53 +08:00
|
|
|
) -> DataResult<SelectOptionCellDataPB, FlowyError> {
|
2023-02-13 09:29:49 +08:00
|
|
|
let params: CellIdParams = data.into_inner().try_into()?;
|
2023-02-26 16:27:17 +08:00
|
|
|
let editor = manager.get_database_editor(¶ms.view_id).await?;
|
2023-02-13 09:29:49 +08:00
|
|
|
match editor.get_field_rev(¶ms.field_id).await {
|
|
|
|
None => {
|
|
|
|
tracing::error!(
|
|
|
|
"Can't find the select option field with id: {}",
|
|
|
|
params.field_id
|
|
|
|
);
|
2023-02-26 16:27:17 +08:00
|
|
|
data_result_ok(SelectOptionCellDataPB::default())
|
2023-02-13 09:29:49 +08:00
|
|
|
},
|
|
|
|
Some(field_rev) => {
|
|
|
|
//
|
|
|
|
let cell_rev = editor
|
|
|
|
.get_cell_rev(¶ms.row_id, ¶ms.field_id)
|
|
|
|
.await?;
|
|
|
|
let type_option = select_type_option_from_field_rev(&field_rev)?;
|
|
|
|
let type_cell_data: TypeCellData = match cell_rev {
|
|
|
|
None => TypeCellData {
|
|
|
|
cell_str: "".to_string(),
|
|
|
|
field_type: field_rev.ty.into(),
|
|
|
|
},
|
|
|
|
Some(cell_rev) => cell_rev.try_into()?,
|
|
|
|
};
|
|
|
|
let ids = SelectOptionIds::from_cell_str(&type_cell_data.cell_str)?;
|
|
|
|
let selected_options = type_option.get_selected_options(ids);
|
2023-02-26 16:27:17 +08:00
|
|
|
data_result_ok(selected_options)
|
2023-02-13 09:29:49 +08:00
|
|
|
},
|
|
|
|
}
|
2022-04-07 08:33:10 +08:00
|
|
|
}
|
|
|
|
|
2022-05-26 17:28:44 +08:00
|
|
|
#[tracing::instrument(level = "trace", skip_all, err)]
|
2022-05-11 11:34:13 +08:00
|
|
|
pub(crate) async fn update_select_option_cell_handler(
|
2023-02-13 09:29:49 +08:00
|
|
|
data: AFPluginData<SelectOptionCellChangesetPB>,
|
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2022-04-07 08:33:10 +08:00
|
|
|
) -> Result<(), FlowyError> {
|
2023-02-13 09:29:49 +08:00
|
|
|
let params: SelectOptionCellChangesetParams = data.into_inner().try_into()?;
|
|
|
|
let editor = manager
|
2023-02-26 16:27:17 +08:00
|
|
|
.get_database_editor(¶ms.cell_identifier.view_id)
|
2023-02-13 09:29:49 +08:00
|
|
|
.await?;
|
|
|
|
let changeset = SelectOptionCellChangeset {
|
|
|
|
insert_option_ids: params.insert_option_ids,
|
|
|
|
delete_option_ids: params.delete_option_ids,
|
|
|
|
};
|
|
|
|
|
|
|
|
editor
|
|
|
|
.update_cell_with_changeset(
|
|
|
|
¶ms.cell_identifier.row_id,
|
|
|
|
¶ms.cell_identifier.field_id,
|
|
|
|
changeset,
|
|
|
|
)
|
|
|
|
.await?;
|
|
|
|
Ok(())
|
2022-05-11 11:34:13 +08:00
|
|
|
}
|
|
|
|
|
2022-05-26 17:28:44 +08:00
|
|
|
#[tracing::instrument(level = "trace", skip_all, err)]
|
2022-05-11 11:34:13 +08:00
|
|
|
pub(crate) async fn update_date_cell_handler(
|
2023-02-13 09:29:49 +08:00
|
|
|
data: AFPluginData<DateChangesetPB>,
|
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2022-05-11 11:34:13 +08:00
|
|
|
) -> Result<(), FlowyError> {
|
2023-02-13 09:29:49 +08:00
|
|
|
let data = data.into_inner();
|
|
|
|
let cell_path: CellIdParams = data.cell_path.try_into()?;
|
|
|
|
let cell_changeset = DateCellChangeset {
|
|
|
|
date: data.date,
|
|
|
|
time: data.time,
|
|
|
|
is_utc: data.is_utc,
|
|
|
|
};
|
|
|
|
|
2023-02-26 16:27:17 +08:00
|
|
|
let editor = manager.get_database_editor(&cell_path.view_id).await?;
|
2023-02-13 09:29:49 +08:00
|
|
|
editor
|
|
|
|
.update_cell(cell_path.row_id, cell_path.field_id, cell_changeset)
|
|
|
|
.await?;
|
|
|
|
Ok(())
|
2022-04-05 14:25:07 +08:00
|
|
|
}
|
2022-08-11 13:04:45 +08:00
|
|
|
|
|
|
|
#[tracing::instrument(level = "trace", skip_all, err)]
|
2022-08-11 21:18:27 +08:00
|
|
|
pub(crate) async fn get_groups_handler(
|
2023-02-21 15:47:51 +08:00
|
|
|
data: AFPluginData<DatabaseViewIdPB>,
|
2023-02-13 09:29:49 +08:00
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2022-11-26 21:28:08 +08:00
|
|
|
) -> DataResult<RepeatedGroupPB, FlowyError> {
|
2023-02-21 15:47:51 +08:00
|
|
|
let params: DatabaseViewIdPB = data.into_inner();
|
2023-02-13 09:29:49 +08:00
|
|
|
let editor = manager.get_database_editor(¶ms.value).await?;
|
2023-03-03 20:38:31 +08:00
|
|
|
let groups = editor.load_groups(¶ms.value).await?;
|
|
|
|
data_result_ok(groups)
|
2022-08-11 13:04:45 +08:00
|
|
|
}
|
2022-08-13 23:26:42 +08:00
|
|
|
|
2023-03-05 16:26:27 +08:00
|
|
|
#[tracing::instrument(level = "trace", skip_all, err)]
|
|
|
|
pub(crate) async fn get_group_handler(
|
|
|
|
data: AFPluginData<DatabaseGroupIdPB>,
|
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
|
|
|
) -> DataResult<GroupPB, FlowyError> {
|
|
|
|
let params: DatabaseGroupIdParams = data.into_inner().try_into()?;
|
|
|
|
let editor = manager.get_database_editor(¶ms.view_id).await?;
|
|
|
|
let group = editor.get_group(¶ms.view_id, ¶ms.group_id).await?;
|
|
|
|
data_result_ok(group)
|
|
|
|
}
|
|
|
|
|
2022-08-19 19:59:09 +08:00
|
|
|
#[tracing::instrument(level = "debug", skip(data, manager), err)]
|
|
|
|
pub(crate) async fn move_group_handler(
|
2023-02-13 09:29:49 +08:00
|
|
|
data: AFPluginData<MoveGroupPayloadPB>,
|
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2022-08-21 13:56:06 +08:00
|
|
|
) -> FlowyResult<()> {
|
2023-02-13 09:29:49 +08:00
|
|
|
let params: MoveGroupParams = data.into_inner().try_into()?;
|
|
|
|
let editor = manager.get_database_editor(params.view_id.as_ref()).await?;
|
|
|
|
editor.move_group(params).await?;
|
|
|
|
Ok(())
|
2022-08-19 19:59:09 +08:00
|
|
|
}
|
2022-08-22 16:16:15 +08:00
|
|
|
|
|
|
|
#[tracing::instrument(level = "debug", skip(data, manager), err)]
|
|
|
|
pub(crate) async fn move_group_row_handler(
|
2023-02-13 09:29:49 +08:00
|
|
|
data: AFPluginData<MoveGroupRowPayloadPB>,
|
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2022-08-22 16:16:15 +08:00
|
|
|
) -> FlowyResult<()> {
|
2023-02-13 09:29:49 +08:00
|
|
|
let params: MoveGroupRowParams = data.into_inner().try_into()?;
|
|
|
|
let editor = manager.get_database_editor(params.view_id.as_ref()).await?;
|
|
|
|
editor.move_group_row(params).await?;
|
|
|
|
Ok(())
|
2022-08-22 16:16:15 +08:00
|
|
|
}
|
2023-02-24 16:59:14 +08:00
|
|
|
|
2023-02-26 16:27:17 +08:00
|
|
|
#[tracing::instrument(level = "debug", skip(manager), err)]
|
|
|
|
pub(crate) async fn get_databases_handler(
|
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
|
|
|
) -> DataResult<RepeatedDatabaseDescPB, FlowyError> {
|
|
|
|
let items = manager
|
|
|
|
.get_databases()
|
|
|
|
.await?
|
|
|
|
.into_iter()
|
|
|
|
.map(|database_info| DatabaseDescPB {
|
|
|
|
name: database_info.name,
|
|
|
|
database_id: database_info.database_id,
|
|
|
|
})
|
|
|
|
.collect::<Vec<DatabaseDescPB>>();
|
|
|
|
data_result_ok(RepeatedDatabaseDescPB { items })
|
|
|
|
}
|
|
|
|
|
2023-02-24 16:59:14 +08:00
|
|
|
#[tracing::instrument(level = "debug", skip(data, manager), err)]
|
2023-03-08 21:19:44 +08:00
|
|
|
pub(crate) async fn set_layout_setting_handler(
|
|
|
|
data: AFPluginData<UpdateLayoutSettingPB>,
|
2023-02-24 16:59:14 +08:00
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
|
|
|
) -> FlowyResult<()> {
|
2023-03-08 21:19:44 +08:00
|
|
|
let params: UpdateLayoutSettingParams = data.into_inner().try_into()?;
|
|
|
|
let database_editor = manager.get_database_editor(params.view_id.as_ref()).await?;
|
|
|
|
database_editor
|
|
|
|
.set_layout_setting(¶ms.view_id, params.layout_setting)
|
|
|
|
.await?;
|
|
|
|
Ok(())
|
2023-02-24 16:59:14 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[tracing::instrument(level = "debug", skip(data, manager), err)]
|
2023-03-08 21:19:44 +08:00
|
|
|
pub(crate) async fn get_layout_setting_handler(
|
|
|
|
data: AFPluginData<DatabaseLayoutIdPB>,
|
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
|
|
|
) -> DataResult<LayoutSettingPB, FlowyError> {
|
|
|
|
let params = data.into_inner();
|
|
|
|
let database_editor = manager.get_database_editor(¶ms.view_id).await?;
|
|
|
|
let layout_setting = database_editor
|
|
|
|
.get_layout_setting(¶ms.view_id, params.layout)
|
|
|
|
.await?;
|
|
|
|
data_result_ok(layout_setting.into())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[tracing::instrument(level = "debug", skip(data, manager), err)]
|
|
|
|
pub(crate) async fn get_calendar_events_handler(
|
|
|
|
data: AFPluginData<CalendarEventRequestPB>,
|
2023-02-24 16:59:14 +08:00
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
2023-03-08 21:19:44 +08:00
|
|
|
) -> DataResult<RepeatedCalendarEventPB, FlowyError> {
|
|
|
|
let params: CalendarEventRequestParams = data.into_inner().try_into()?;
|
|
|
|
let database_editor = manager.get_database_editor(¶ms.view_id).await?;
|
|
|
|
let events = database_editor
|
|
|
|
.get_all_calendar_events(¶ms.view_id)
|
|
|
|
.await;
|
|
|
|
data_result_ok(RepeatedCalendarEventPB { items: events })
|
|
|
|
}
|
|
|
|
|
|
|
|
#[tracing::instrument(level = "debug", skip(data, manager), err)]
|
|
|
|
pub(crate) async fn get_calendar_event_handler(
|
|
|
|
data: AFPluginData<RowIdPB>,
|
|
|
|
manager: AFPluginState<Arc<DatabaseManager>>,
|
|
|
|
) -> DataResult<CalendarEventPB, FlowyError> {
|
|
|
|
let params: RowIdParams = data.into_inner().try_into()?;
|
|
|
|
let database_editor = manager.get_database_editor(¶ms.view_id).await?;
|
|
|
|
let event = database_editor
|
|
|
|
.get_calendar_event(¶ms.view_id, ¶ms.row_id)
|
|
|
|
.await;
|
|
|
|
match event {
|
|
|
|
None => Err(FlowyError::record_not_found()),
|
|
|
|
Some(event) => data_result_ok(event),
|
|
|
|
}
|
2023-02-24 16:59:14 +08:00
|
|
|
}
|