2023-07-29 01:46:24 +00:00
|
|
|
use std::sync::{Arc, Weak};
|
2024-03-23 23:31:41 +00:00
|
|
|
use tracing::instrument;
|
2023-06-05 01:42:11 +00:00
|
|
|
|
2023-08-17 15:46:39 +00:00
|
|
|
use flowy_error::{FlowyError, FlowyResult};
|
|
|
|
use lib_dispatch::prelude::{data_result_ok, AFPluginData, AFPluginState, DataResult};
|
|
|
|
|
2023-06-14 14:16:33 +00:00
|
|
|
use crate::entities::*;
|
2023-07-05 12:57:09 +00:00
|
|
|
use crate::manager::FolderManager;
|
2023-05-31 06:08:54 +00:00
|
|
|
use crate::share::ImportParams;
|
2023-04-04 00:41:16 +00:00
|
|
|
|
2023-07-29 01:46:24 +00:00
|
|
|
fn upgrade_folder(
|
|
|
|
folder_manager: AFPluginState<Weak<FolderManager>>,
|
|
|
|
) -> FlowyResult<Arc<FolderManager>> {
|
|
|
|
let folder = folder_manager
|
|
|
|
.upgrade()
|
2023-08-21 16:19:15 +00:00
|
|
|
.ok_or(FlowyError::internal().with_context("The folder manager is already dropped"))?;
|
2023-07-29 01:46:24 +00:00
|
|
|
Ok(folder)
|
|
|
|
}
|
|
|
|
|
2023-04-04 00:41:16 +00:00
|
|
|
#[tracing::instrument(level = "debug", skip(data, folder), err)]
|
|
|
|
pub(crate) async fn create_workspace_handler(
|
|
|
|
data: AFPluginData<CreateWorkspacePayloadPB>,
|
2023-07-29 01:46:24 +00:00
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
2023-04-04 00:41:16 +00:00
|
|
|
) -> DataResult<WorkspacePB, FlowyError> {
|
2023-07-29 01:46:24 +00:00
|
|
|
let folder = upgrade_folder(folder)?;
|
2023-04-04 00:41:16 +00:00
|
|
|
let params: CreateWorkspaceParams = data.into_inner().try_into()?;
|
|
|
|
let workspace = folder.create_workspace(params).await?;
|
2023-11-01 03:45:35 +00:00
|
|
|
let views = folder
|
|
|
|
.get_views_belong_to(&workspace.id)
|
|
|
|
.await?
|
|
|
|
.into_iter()
|
2024-03-12 02:59:52 +00:00
|
|
|
.map(|view| view_pb_without_child_views(view.as_ref().clone()))
|
2023-11-01 03:45:35 +00:00
|
|
|
.collect::<Vec<ViewPB>>();
|
|
|
|
data_result_ok(WorkspacePB {
|
|
|
|
id: workspace.id,
|
|
|
|
name: workspace.name,
|
|
|
|
views,
|
|
|
|
create_time: workspace.created_at,
|
|
|
|
})
|
2023-04-04 00:41:16 +00:00
|
|
|
}
|
|
|
|
|
2023-11-05 06:00:24 +00:00
|
|
|
#[tracing::instrument(level = "debug", skip_all, err)]
|
|
|
|
pub(crate) async fn get_all_workspace_handler(
|
|
|
|
_data: AFPluginData<CreateWorkspacePayloadPB>,
|
|
|
|
_folder: AFPluginState<Weak<FolderManager>>,
|
|
|
|
) -> DataResult<RepeatedWorkspacePB, FlowyError> {
|
|
|
|
todo!()
|
|
|
|
}
|
|
|
|
|
2023-04-04 00:41:16 +00:00
|
|
|
#[tracing::instrument(level = "debug", skip(folder), err)]
|
2023-07-14 05:37:13 +00:00
|
|
|
pub(crate) async fn get_workspace_views_handler(
|
2024-04-24 00:47:33 +00:00
|
|
|
_data: AFPluginData<GetWorkspaceViewPB>,
|
2024-03-21 04:02:03 +00:00
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
|
|
|
) -> DataResult<RepeatedViewPB, FlowyError> {
|
|
|
|
let folder = upgrade_folder(folder)?;
|
2024-04-24 00:47:33 +00:00
|
|
|
let child_views = folder.get_workspace_public_views().await?;
|
2024-03-21 04:02:03 +00:00
|
|
|
let repeated_view: RepeatedViewPB = child_views.into();
|
|
|
|
data_result_ok(repeated_view)
|
|
|
|
}
|
|
|
|
|
|
|
|
#[tracing::instrument(level = "debug", skip(folder), err)]
|
|
|
|
pub(crate) async fn get_current_workspace_views_handler(
|
2023-07-29 01:46:24 +00:00
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
2023-04-04 00:41:16 +00:00
|
|
|
) -> DataResult<RepeatedViewPB, FlowyError> {
|
2023-07-29 01:46:24 +00:00
|
|
|
let folder = upgrade_folder(folder)?;
|
2024-03-22 09:15:18 +00:00
|
|
|
let child_views = folder.get_current_workspace_public_views().await?;
|
2023-04-04 00:41:16 +00:00
|
|
|
let repeated_view: RepeatedViewPB = child_views.into();
|
|
|
|
data_result_ok(repeated_view)
|
|
|
|
}
|
|
|
|
|
2024-03-21 04:02:03 +00:00
|
|
|
#[tracing::instrument(level = "debug", skip(folder), err)]
|
|
|
|
pub(crate) async fn read_private_views_handler(
|
|
|
|
data: AFPluginData<GetWorkspaceViewPB>,
|
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
|
|
|
) -> DataResult<RepeatedViewPB, FlowyError> {
|
|
|
|
let folder = upgrade_folder(folder)?;
|
2024-04-24 00:47:33 +00:00
|
|
|
let _params: GetWorkspaceViewParams = data.into_inner().try_into()?;
|
|
|
|
let child_views = folder.get_workspace_private_views().await?;
|
2024-03-21 04:02:03 +00:00
|
|
|
let repeated_view: RepeatedViewPB = child_views.into();
|
|
|
|
data_result_ok(repeated_view)
|
|
|
|
}
|
|
|
|
|
2023-11-01 03:45:35 +00:00
|
|
|
#[tracing::instrument(level = "debug", skip(folder), err)]
|
|
|
|
pub(crate) async fn read_current_workspace_setting_handler(
|
2023-07-29 01:46:24 +00:00
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
2023-11-01 03:45:35 +00:00
|
|
|
) -> DataResult<WorkspaceSettingPB, FlowyError> {
|
2023-07-29 01:46:24 +00:00
|
|
|
let folder = upgrade_folder(folder)?;
|
2023-11-05 06:00:24 +00:00
|
|
|
let setting = folder.get_workspace_setting_pb().await?;
|
2023-11-01 03:45:35 +00:00
|
|
|
data_result_ok(setting)
|
2023-04-04 00:41:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[tracing::instrument(level = "debug", skip(folder), err)]
|
2023-11-01 03:45:35 +00:00
|
|
|
pub(crate) async fn read_current_workspace_handler(
|
2023-07-29 01:46:24 +00:00
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
2023-11-01 03:45:35 +00:00
|
|
|
) -> DataResult<WorkspacePB, FlowyError> {
|
2023-07-29 01:46:24 +00:00
|
|
|
let folder = upgrade_folder(folder)?;
|
2023-11-05 06:00:24 +00:00
|
|
|
let workspace = folder.get_workspace_pb().await?;
|
2023-11-01 03:45:35 +00:00
|
|
|
data_result_ok(workspace)
|
2023-04-04 00:41:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
pub(crate) async fn create_view_handler(
|
|
|
|
data: AFPluginData<CreateViewPayloadPB>,
|
2023-07-29 01:46:24 +00:00
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
2023-04-04 00:41:16 +00:00
|
|
|
) -> DataResult<ViewPB, FlowyError> {
|
2023-07-29 01:46:24 +00:00
|
|
|
let folder = upgrade_folder(folder)?;
|
2023-04-04 00:41:16 +00:00
|
|
|
let params: CreateViewParams = data.into_inner().try_into()?;
|
2023-06-03 05:40:12 +00:00
|
|
|
let set_as_current = params.set_as_current;
|
2024-07-02 05:02:15 +00:00
|
|
|
let (view, _) = folder.create_view_with_params(params, true).await?;
|
2023-06-03 05:40:12 +00:00
|
|
|
if set_as_current {
|
2024-08-18 03:16:42 +00:00
|
|
|
let _ = folder.set_current_view(view.id.clone()).await;
|
2023-06-03 05:40:12 +00:00
|
|
|
}
|
2024-03-12 02:59:52 +00:00
|
|
|
data_result_ok(view_pb_without_child_views(view))
|
2023-04-04 00:41:16 +00:00
|
|
|
}
|
|
|
|
|
2023-06-14 14:16:33 +00:00
|
|
|
pub(crate) async fn create_orphan_view_handler(
|
|
|
|
data: AFPluginData<CreateOrphanViewPayloadPB>,
|
2023-07-29 01:46:24 +00:00
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
2023-06-14 14:16:33 +00:00
|
|
|
) -> DataResult<ViewPB, FlowyError> {
|
2023-07-29 01:46:24 +00:00
|
|
|
let folder = upgrade_folder(folder)?;
|
2023-06-14 14:16:33 +00:00
|
|
|
let params: CreateViewParams = data.into_inner().try_into()?;
|
|
|
|
let set_as_current = params.set_as_current;
|
|
|
|
let view = folder.create_orphan_view_with_params(params).await?;
|
|
|
|
if set_as_current {
|
2024-08-18 03:16:42 +00:00
|
|
|
let _ = folder.set_current_view(view.id.clone()).await;
|
2023-06-14 14:16:33 +00:00
|
|
|
}
|
2024-03-12 02:59:52 +00:00
|
|
|
data_result_ok(view_pb_without_child_views(view))
|
2023-06-14 14:16:33 +00:00
|
|
|
}
|
|
|
|
|
2024-02-09 02:18:52 +00:00
|
|
|
#[tracing::instrument(level = "debug", skip(data, folder), err)]
|
2024-03-15 14:58:55 +00:00
|
|
|
pub(crate) async fn get_view_handler(
|
2023-04-04 00:41:16 +00:00
|
|
|
data: AFPluginData<ViewIdPB>,
|
2023-07-29 01:46:24 +00:00
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
2023-04-04 00:41:16 +00:00
|
|
|
) -> DataResult<ViewPB, FlowyError> {
|
2023-07-29 01:46:24 +00:00
|
|
|
let folder = upgrade_folder(folder)?;
|
2023-04-04 00:41:16 +00:00
|
|
|
let view_id: ViewIdPB = data.into_inner();
|
2023-11-01 03:45:35 +00:00
|
|
|
let view_pb = folder.get_view_pb(&view_id.value).await?;
|
2023-04-04 00:41:16 +00:00
|
|
|
data_result_ok(view_pb)
|
|
|
|
}
|
|
|
|
|
2024-04-23 13:46:57 +00:00
|
|
|
#[tracing::instrument(level = "debug", skip(folder), err)]
|
|
|
|
pub(crate) async fn get_all_views_handler(
|
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
|
|
|
) -> DataResult<RepeatedViewPB, FlowyError> {
|
|
|
|
let folder = upgrade_folder(folder)?;
|
|
|
|
let view_pbs = folder.get_all_views_pb().await?;
|
|
|
|
|
|
|
|
data_result_ok(RepeatedViewPB::from(view_pbs))
|
|
|
|
}
|
|
|
|
|
2024-04-09 00:58:53 +00:00
|
|
|
#[tracing::instrument(level = "debug", skip(data, folder), err)]
|
|
|
|
pub(crate) async fn get_view_ancestors_handler(
|
|
|
|
data: AFPluginData<ViewIdPB>,
|
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
|
|
|
) -> DataResult<RepeatedViewPB, FlowyError> {
|
|
|
|
let folder = upgrade_folder(folder)?;
|
|
|
|
let view_id: ViewIdPB = data.into_inner();
|
|
|
|
let view_ancestors = folder.get_view_ancestors_pb(&view_id.value).await?;
|
|
|
|
data_result_ok(RepeatedViewPB {
|
|
|
|
items: view_ancestors,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2023-04-04 00:41:16 +00:00
|
|
|
#[tracing::instrument(level = "debug", skip(data, folder), err)]
|
|
|
|
pub(crate) async fn update_view_handler(
|
|
|
|
data: AFPluginData<UpdateViewPayloadPB>,
|
2023-07-29 01:46:24 +00:00
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
2023-04-04 00:41:16 +00:00
|
|
|
) -> Result<(), FlowyError> {
|
2023-07-29 01:46:24 +00:00
|
|
|
let folder = upgrade_folder(folder)?;
|
2023-04-04 00:41:16 +00:00
|
|
|
let params: UpdateViewParams = data.into_inner().try_into()?;
|
2023-05-10 11:43:32 +00:00
|
|
|
folder.update_view_with_params(params).await?;
|
2023-04-04 00:41:16 +00:00
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
2023-08-04 11:27:14 +00:00
|
|
|
#[tracing::instrument(level = "debug", skip(data, folder), err)]
|
|
|
|
pub(crate) async fn update_view_icon_handler(
|
|
|
|
data: AFPluginData<UpdateViewIconPayloadPB>,
|
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
|
|
|
) -> Result<(), FlowyError> {
|
|
|
|
let folder = upgrade_folder(folder)?;
|
|
|
|
let params: UpdateViewIconParams = data.into_inner().try_into()?;
|
|
|
|
folder.update_view_icon_with_params(params).await?;
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
2023-04-04 00:41:16 +00:00
|
|
|
pub(crate) async fn delete_view_handler(
|
|
|
|
data: AFPluginData<RepeatedViewIdPB>,
|
2023-07-29 01:46:24 +00:00
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
2023-04-04 00:41:16 +00:00
|
|
|
) -> Result<(), FlowyError> {
|
2023-07-29 01:46:24 +00:00
|
|
|
let folder = upgrade_folder(folder)?;
|
2023-04-04 00:41:16 +00:00
|
|
|
let params: RepeatedViewIdPB = data.into_inner();
|
|
|
|
for view_id in ¶ms.items {
|
|
|
|
let _ = folder.move_view_to_trash(view_id).await;
|
|
|
|
}
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
2023-08-02 13:20:51 +00:00
|
|
|
pub(crate) async fn toggle_favorites_handler(
|
|
|
|
data: AFPluginData<RepeatedViewIdPB>,
|
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
|
|
|
) -> Result<(), FlowyError> {
|
|
|
|
let params: RepeatedViewIdPB = data.into_inner();
|
|
|
|
let folder = upgrade_folder(folder)?;
|
|
|
|
for view_id in ¶ms.items {
|
|
|
|
let _ = folder.toggle_favorites(view_id).await;
|
|
|
|
}
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
2023-12-01 01:58:36 +00:00
|
|
|
pub(crate) async fn update_recent_views_handler(
|
|
|
|
data: AFPluginData<UpdateRecentViewPayloadPB>,
|
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
|
|
|
) -> Result<(), FlowyError> {
|
|
|
|
let params: UpdateRecentViewPayloadPB = data.into_inner();
|
|
|
|
let folder = upgrade_folder(folder)?;
|
|
|
|
if params.add_in_recent {
|
|
|
|
let _ = folder.add_recent_views(params.view_ids).await;
|
|
|
|
} else {
|
|
|
|
let _ = folder.remove_recent_views(params.view_ids).await;
|
|
|
|
}
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
2023-04-04 00:41:16 +00:00
|
|
|
pub(crate) async fn set_latest_view_handler(
|
|
|
|
data: AFPluginData<ViewIdPB>,
|
2023-07-29 01:46:24 +00:00
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
2023-04-04 00:41:16 +00:00
|
|
|
) -> Result<(), FlowyError> {
|
2023-07-29 01:46:24 +00:00
|
|
|
let folder = upgrade_folder(folder)?;
|
2023-04-04 00:41:16 +00:00
|
|
|
let view_id: ViewIdPB = data.into_inner();
|
2024-08-18 03:16:42 +00:00
|
|
|
let _ = folder.set_current_view(view_id.value.clone()).await;
|
2023-04-04 00:41:16 +00:00
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
2024-03-23 23:31:41 +00:00
|
|
|
#[instrument(level = "debug", skip(data, folder), err)]
|
2023-04-04 00:41:16 +00:00
|
|
|
pub(crate) async fn close_view_handler(
|
|
|
|
data: AFPluginData<ViewIdPB>,
|
2023-07-29 01:46:24 +00:00
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
2023-04-04 00:41:16 +00:00
|
|
|
) -> Result<(), FlowyError> {
|
2023-07-29 01:46:24 +00:00
|
|
|
let folder = upgrade_folder(folder)?;
|
2023-04-04 00:41:16 +00:00
|
|
|
let view_id: ViewIdPB = data.into_inner();
|
|
|
|
let _ = folder.close_view(&view_id.value).await;
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[tracing::instrument(level = "debug", skip_all, err)]
|
|
|
|
pub(crate) async fn move_view_handler(
|
2023-06-05 08:09:18 +00:00
|
|
|
data: AFPluginData<MoveViewPayloadPB>,
|
2023-07-29 01:46:24 +00:00
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
2023-04-04 00:41:16 +00:00
|
|
|
) -> Result<(), FlowyError> {
|
2023-07-29 01:46:24 +00:00
|
|
|
let folder = upgrade_folder(folder)?;
|
2023-04-04 00:41:16 +00:00
|
|
|
let params: MoveViewParams = data.into_inner().try_into()?;
|
|
|
|
folder
|
2023-06-06 16:05:27 +00:00
|
|
|
.move_view(¶ms.view_id, params.from, params.to)
|
2023-04-04 00:41:16 +00:00
|
|
|
.await?;
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
2023-07-26 08:49:50 +00:00
|
|
|
pub(crate) async fn move_nested_view_handler(
|
|
|
|
data: AFPluginData<MoveNestedViewPayloadPB>,
|
2023-07-29 01:46:24 +00:00
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
2023-07-26 08:49:50 +00:00
|
|
|
) -> Result<(), FlowyError> {
|
2023-07-29 01:46:24 +00:00
|
|
|
let folder = upgrade_folder(folder)?;
|
2023-07-26 08:49:50 +00:00
|
|
|
let params: MoveNestedViewParams = data.into_inner().try_into()?;
|
2024-03-21 04:02:03 +00:00
|
|
|
folder.move_nested_view(params).await?;
|
2023-07-26 08:49:50 +00:00
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
2023-04-04 00:41:16 +00:00
|
|
|
#[tracing::instrument(level = "debug", skip(data, folder), err)]
|
|
|
|
pub(crate) async fn duplicate_view_handler(
|
2024-06-25 02:03:02 +00:00
|
|
|
data: AFPluginData<DuplicateViewPayloadPB>,
|
2023-07-29 01:46:24 +00:00
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
2023-04-04 00:41:16 +00:00
|
|
|
) -> Result<(), FlowyError> {
|
2023-07-29 01:46:24 +00:00
|
|
|
let folder = upgrade_folder(folder)?;
|
2024-06-25 02:03:02 +00:00
|
|
|
let params: DuplicateViewParams = data.into_inner().try_into()?;
|
|
|
|
folder.duplicate_view(params).await?;
|
2023-04-04 00:41:16 +00:00
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
2023-08-02 13:20:51 +00:00
|
|
|
#[tracing::instrument(level = "debug", skip(folder), err)]
|
|
|
|
pub(crate) async fn read_favorites_handler(
|
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
2024-05-27 00:51:49 +00:00
|
|
|
) -> DataResult<RepeatedFavoriteViewPB, FlowyError> {
|
2023-08-02 13:20:51 +00:00
|
|
|
let folder = upgrade_folder(folder)?;
|
2023-11-01 06:47:25 +00:00
|
|
|
let favorite_items = folder.get_all_favorites().await;
|
2023-08-02 13:20:51 +00:00
|
|
|
let mut views = vec![];
|
2023-11-01 06:47:25 +00:00
|
|
|
for item in favorite_items {
|
|
|
|
if let Ok(view) = folder.get_view_pb(&item.id).await {
|
2024-05-30 01:56:44 +00:00
|
|
|
views.push(SectionViewPB {
|
2024-05-27 00:51:49 +00:00
|
|
|
item: view,
|
|
|
|
timestamp: item.timestamp,
|
|
|
|
});
|
2023-08-02 13:20:51 +00:00
|
|
|
}
|
|
|
|
}
|
2024-05-27 00:51:49 +00:00
|
|
|
data_result_ok(RepeatedFavoriteViewPB { items: views })
|
2023-08-02 13:20:51 +00:00
|
|
|
}
|
2023-11-13 02:07:46 +00:00
|
|
|
|
|
|
|
#[tracing::instrument(level = "debug", skip(folder), err)]
|
|
|
|
pub(crate) async fn read_recent_views_handler(
|
2024-07-15 06:23:20 +00:00
|
|
|
data: AFPluginData<ReadRecentViewsPB>,
|
2023-11-13 02:07:46 +00:00
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
2024-05-30 01:56:44 +00:00
|
|
|
) -> DataResult<RepeatedRecentViewPB, FlowyError> {
|
2023-11-13 02:07:46 +00:00
|
|
|
let folder = upgrade_folder(folder)?;
|
2024-04-02 01:57:14 +00:00
|
|
|
let recent_items = folder.get_my_recent_sections().await;
|
2024-07-15 06:23:20 +00:00
|
|
|
let start = data.start;
|
|
|
|
let limit = data.limit;
|
|
|
|
let ids = recent_items
|
|
|
|
.iter()
|
|
|
|
.rev() // the most recent view is at the end of the list
|
|
|
|
.map(|item| item.id.clone())
|
|
|
|
.skip(start as usize)
|
|
|
|
.take(limit as usize)
|
|
|
|
.collect::<Vec<_>>();
|
|
|
|
let views = folder.get_view_pbs_without_children(ids).await?;
|
|
|
|
let items = views
|
|
|
|
.into_iter()
|
|
|
|
.zip(recent_items.into_iter().rev())
|
|
|
|
.map(|(view, item)| SectionViewPB {
|
|
|
|
item: view,
|
|
|
|
timestamp: item.timestamp,
|
|
|
|
})
|
|
|
|
.collect::<Vec<_>>();
|
|
|
|
data_result_ok(RepeatedRecentViewPB { items })
|
2023-11-13 02:07:46 +00:00
|
|
|
}
|
|
|
|
|
2023-04-04 00:41:16 +00:00
|
|
|
#[tracing::instrument(level = "debug", skip(folder), err)]
|
|
|
|
pub(crate) async fn read_trash_handler(
|
2023-07-29 01:46:24 +00:00
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
2023-04-04 00:41:16 +00:00
|
|
|
) -> DataResult<RepeatedTrashPB, FlowyError> {
|
2023-07-29 01:46:24 +00:00
|
|
|
let folder = upgrade_folder(folder)?;
|
2024-03-22 09:15:18 +00:00
|
|
|
let trash = folder.get_my_trash_info().await;
|
2023-04-04 00:41:16 +00:00
|
|
|
data_result_ok(trash.into())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[tracing::instrument(level = "debug", skip(identifier, folder), err)]
|
|
|
|
pub(crate) async fn putback_trash_handler(
|
|
|
|
identifier: AFPluginData<TrashIdPB>,
|
2023-07-29 01:46:24 +00:00
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
2023-04-04 00:41:16 +00:00
|
|
|
) -> Result<(), FlowyError> {
|
2023-07-29 01:46:24 +00:00
|
|
|
let folder = upgrade_folder(folder)?;
|
2023-04-04 00:41:16 +00:00
|
|
|
folder.restore_trash(&identifier.id).await;
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[tracing::instrument(level = "debug", skip(identifiers, folder), err)]
|
|
|
|
pub(crate) async fn delete_trash_handler(
|
|
|
|
identifiers: AFPluginData<RepeatedTrashIdPB>,
|
2023-07-29 01:46:24 +00:00
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
2023-04-04 00:41:16 +00:00
|
|
|
) -> Result<(), FlowyError> {
|
2023-07-29 01:46:24 +00:00
|
|
|
let folder = upgrade_folder(folder)?;
|
2023-04-04 00:41:16 +00:00
|
|
|
let trash_ids = identifiers.into_inner().items;
|
|
|
|
for trash_id in trash_ids {
|
2023-06-05 01:42:11 +00:00
|
|
|
let _ = folder.delete_trash(&trash_id.id).await;
|
2023-04-04 00:41:16 +00:00
|
|
|
}
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[tracing::instrument(level = "debug", skip(folder), err)]
|
|
|
|
pub(crate) async fn restore_all_trash_handler(
|
2023-07-29 01:46:24 +00:00
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
2023-04-04 00:41:16 +00:00
|
|
|
) -> Result<(), FlowyError> {
|
2023-07-29 01:46:24 +00:00
|
|
|
let folder = upgrade_folder(folder)?;
|
2023-04-04 00:41:16 +00:00
|
|
|
folder.restore_all_trash().await;
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[tracing::instrument(level = "debug", skip(folder), err)]
|
2024-03-22 09:15:18 +00:00
|
|
|
pub(crate) async fn delete_my_trash_handler(
|
2023-07-29 01:46:24 +00:00
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
2023-04-04 00:41:16 +00:00
|
|
|
) -> Result<(), FlowyError> {
|
2023-07-29 01:46:24 +00:00
|
|
|
let folder = upgrade_folder(folder)?;
|
2024-03-22 09:15:18 +00:00
|
|
|
folder.delete_my_trash().await;
|
2023-04-04 00:41:16 +00:00
|
|
|
Ok(())
|
|
|
|
}
|
2023-05-31 06:08:54 +00:00
|
|
|
|
|
|
|
#[tracing::instrument(level = "debug", skip(data, folder), err)]
|
|
|
|
pub(crate) async fn import_data_handler(
|
2024-07-01 06:44:08 +00:00
|
|
|
data: AFPluginData<ImportPayloadPB>,
|
2023-07-29 01:46:24 +00:00
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
2024-07-01 06:44:08 +00:00
|
|
|
) -> DataResult<RepeatedViewPB, FlowyError> {
|
2023-07-29 01:46:24 +00:00
|
|
|
let folder = upgrade_folder(folder)?;
|
2023-05-31 06:08:54 +00:00
|
|
|
let params: ImportParams = data.into_inner().try_into()?;
|
2024-07-01 06:44:08 +00:00
|
|
|
let views = folder.import(params).await?;
|
|
|
|
data_result_ok(views)
|
2023-05-31 06:08:54 +00:00
|
|
|
}
|
2023-07-05 12:57:09 +00:00
|
|
|
|
|
|
|
#[tracing::instrument(level = "debug", skip(folder), err)]
|
|
|
|
pub(crate) async fn get_folder_snapshots_handler(
|
|
|
|
data: AFPluginData<WorkspaceIdPB>,
|
2023-07-29 01:46:24 +00:00
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
2023-07-05 12:57:09 +00:00
|
|
|
) -> DataResult<RepeatedFolderSnapshotPB, FlowyError> {
|
2023-07-29 01:46:24 +00:00
|
|
|
let folder = upgrade_folder(folder)?;
|
2023-11-01 03:45:35 +00:00
|
|
|
let data = data.into_inner();
|
|
|
|
let snapshots = folder.get_folder_snapshots(&data.value, 10).await?;
|
|
|
|
data_result_ok(RepeatedFolderSnapshotPB { items: snapshots })
|
2023-07-05 12:57:09 +00:00
|
|
|
}
|
2024-02-08 15:53:05 +00:00
|
|
|
|
2024-04-01 06:27:29 +00:00
|
|
|
#[tracing::instrument(level = "debug", skip(data, folder), err)]
|
|
|
|
pub(crate) async fn update_view_visibility_status_handler(
|
|
|
|
data: AFPluginData<UpdateViewVisibilityStatusPayloadPB>,
|
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
|
|
|
) -> Result<(), FlowyError> {
|
|
|
|
let folder = upgrade_folder(folder)?;
|
|
|
|
let params = data.into_inner();
|
2024-08-18 03:16:42 +00:00
|
|
|
folder
|
|
|
|
.set_views_visibility(params.view_ids, params.is_public)
|
|
|
|
.await;
|
2024-04-01 06:27:29 +00:00
|
|
|
Ok(())
|
|
|
|
}
|
2024-07-08 05:45:57 +00:00
|
|
|
|
|
|
|
#[tracing::instrument(level = "debug", skip(data, folder), err)]
|
|
|
|
pub(crate) async fn publish_view_handler(
|
|
|
|
data: AFPluginData<PublishViewParamsPB>,
|
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
|
|
|
) -> Result<(), FlowyError> {
|
|
|
|
let folder = upgrade_folder(folder)?;
|
|
|
|
let params = data.into_inner();
|
2024-07-22 05:35:42 +00:00
|
|
|
let selected_view_ids = params.selected_view_ids.map(|ids| ids.items);
|
2024-07-08 05:45:57 +00:00
|
|
|
folder
|
2024-07-22 05:35:42 +00:00
|
|
|
.publish_view(
|
|
|
|
params.view_id.as_str(),
|
|
|
|
params.publish_name,
|
|
|
|
selected_view_ids,
|
|
|
|
)
|
2024-07-08 05:45:57 +00:00
|
|
|
.await?;
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[tracing::instrument(level = "debug", skip(data, folder), err)]
|
|
|
|
pub(crate) async fn unpublish_views_handler(
|
|
|
|
data: AFPluginData<UnpublishViewsPayloadPB>,
|
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
|
|
|
) -> Result<(), FlowyError> {
|
|
|
|
let folder = upgrade_folder(folder)?;
|
|
|
|
let params = data.into_inner();
|
|
|
|
folder.unpublish_views(params.view_ids).await?;
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
2024-07-22 05:35:42 +00:00
|
|
|
#[tracing::instrument(level = "debug", skip(data, folder))]
|
2024-07-08 05:45:57 +00:00
|
|
|
pub(crate) async fn get_publish_info_handler(
|
|
|
|
data: AFPluginData<ViewIdPB>,
|
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
|
|
|
) -> DataResult<PublishInfoResponsePB, FlowyError> {
|
|
|
|
let folder = upgrade_folder(folder)?;
|
|
|
|
let view_id = data.into_inner().value;
|
|
|
|
let info = folder.get_publish_info(&view_id).await?;
|
|
|
|
data_result_ok(PublishInfoResponsePB::from(info))
|
|
|
|
}
|
|
|
|
|
|
|
|
#[tracing::instrument(level = "debug", skip(data, folder), err)]
|
|
|
|
pub(crate) async fn set_publish_namespace_handler(
|
|
|
|
data: AFPluginData<SetPublishNamespacePayloadPB>,
|
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
|
|
|
) -> Result<(), FlowyError> {
|
|
|
|
let folder = upgrade_folder(folder)?;
|
|
|
|
let namespace = data.into_inner().new_namespace;
|
|
|
|
folder.set_publish_namespace(namespace).await?;
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[tracing::instrument(level = "debug", skip(folder), err)]
|
|
|
|
pub(crate) async fn get_publish_namespace_handler(
|
|
|
|
folder: AFPluginState<Weak<FolderManager>>,
|
|
|
|
) -> DataResult<PublishNamespacePB, FlowyError> {
|
|
|
|
let folder = upgrade_folder(folder)?;
|
|
|
|
let namespace = folder.get_publish_namespace().await?;
|
|
|
|
data_result_ok(PublishNamespacePB { namespace })
|
|
|
|
}
|