123456789101112131415161718192021222324252627282930313233343536373839404142434445 |
- use crate::entities::{
- DocumentSnapshotPB, EditParams, EditPayloadPB, ExportDataPB, ExportParams, ExportPayloadPB, OpenDocumentContextPB,
- };
- use crate::DocumentManager;
- use flowy_error::FlowyError;
- use lib_dispatch::prelude::{data_result, AFPluginData, AFPluginState, DataResult};
- use std::convert::TryInto;
- use std::sync::Arc;
- pub(crate) async fn get_document_handler(
- data: AFPluginData<OpenDocumentContextPB>,
- manager: AFPluginState<Arc<DocumentManager>>,
- ) -> DataResult<DocumentSnapshotPB, FlowyError> {
- let context: OpenDocumentContextPB = data.into_inner();
- let editor = manager.open_document_editor(&context.document_id).await?;
- let document_data = editor.export().await?;
- data_result(DocumentSnapshotPB {
- doc_id: context.document_id,
- snapshot: document_data,
- })
- }
- pub(crate) async fn apply_edit_handler(
- data: AFPluginData<EditPayloadPB>,
- manager: AFPluginState<Arc<DocumentManager>>,
- ) -> Result<(), FlowyError> {
- let params: EditParams = data.into_inner().try_into()?;
- let _ = manager.apply_edit(params).await?;
- Ok(())
- }
- #[tracing::instrument(level = "debug", skip(data, manager), err)]
- pub(crate) async fn export_handler(
- data: AFPluginData<ExportPayloadPB>,
- manager: AFPluginState<Arc<DocumentManager>>,
- ) -> DataResult<ExportDataPB, FlowyError> {
- let params: ExportParams = data.into_inner().try_into()?;
- let editor = manager.open_document_editor(¶ms.view_id).await?;
- let document_data = editor.export().await?;
- data_result(ExportDataPB {
- data: document_data,
- export_type: params.export_type,
- })
- }
|