use reqwest::Method;
use serde::{Deserialize, Serialize};
use crate::{
core::{
api_req::ApiRequest,
api_resp::{ApiResponseTrait, BaseResponse, ResponseFormat},
constants::AccessTokenType,
endpoints::cloud_docs::*,
http::Transport,
req_option::RequestOption,
standard_response::StandardResponse,
validation::{self, ValidationResult},
SDKResult,
},
impl_executable_builder_owned,
service::sheets::v3::DataOperationService,
};
impl DataOperationService {
pub async fn merge_cells(
&self,
request: MergeCellsRequest,
option: Option<RequestOption>,
) -> SDKResult<MergeCellsResponseData> {
let mut api_req = request.api_request;
api_req.http_method = Method::POST;
api_req.api_path = SHEETS_V3_SPREADSHEET_MERGE_CELLS
.replace("{}", &request.spreadsheet_token)
.replace("{}", &request.sheet_id);
api_req.supported_access_token_types = vec![AccessTokenType::Tenant, AccessTokenType::User];
let api_resp: BaseResponse<MergeCellsResponseData> =
Transport::request(api_req, &self.config, option).await?;
api_resp.into_result()
}
}
#[derive(Default, Debug, Serialize, Deserialize)]
pub struct MergeCellsRequest {
#[serde(skip)]
api_request: ApiRequest,
spreadsheet_token: String,
sheet_id: String,
range: String,
merge_type: String,
}
impl MergeCellsRequest {
pub fn builder() -> MergeCellsRequestBuilder {
MergeCellsRequestBuilder::default()
}
pub fn validate(&self) -> SDKResult<()> {
if self.spreadsheet_token.is_empty() {
return Err(crate::core::error::LarkAPIError::illegal_param(
"spreadsheet_token cannot be empty".to_string(),
));
}
if self.sheet_id.is_empty() {
return Err(crate::core::error::LarkAPIError::illegal_param(
"sheet_id cannot be empty".to_string(),
));
}
if self.range.is_empty() {
return Err(crate::core::error::LarkAPIError::illegal_param(
"range cannot be empty".to_string(),
));
}
if let ValidationResult::Invalid(msg) = validation::validate_merge_range(&self.range) {
return Err(crate::core::error::LarkAPIError::illegal_param(format!(
"Invalid merge range '{}': {}",
self.range, msg
)));
}
let valid_merge_types = ["MERGE_ALL", "MERGE_COLUMNS", "MERGE_ROWS"];
if !valid_merge_types.contains(&self.merge_type.as_str()) {
return Err(crate::core::error::LarkAPIError::illegal_param(format!(
"Invalid merge_type '{}'. Must be one of: MERGE_ALL, MERGE_COLUMNS, MERGE_ROWS",
self.merge_type
)));
}
Ok(())
}
}
#[derive(Default)]
pub struct MergeCellsRequestBuilder {
request: MergeCellsRequest,
}
impl MergeCellsRequestBuilder {
pub fn spreadsheet_token(mut self, spreadsheet_token: impl ToString) -> Self {
self.request.spreadsheet_token = spreadsheet_token.to_string();
self
}
pub fn sheet_id(mut self, sheet_id: impl ToString) -> Self {
self.request.sheet_id = sheet_id.to_string();
self
}
pub fn range(mut self, range: impl ToString) -> Self {
self.request.range = range.to_string();
self
}
pub fn merge_type(mut self, merge_type: impl ToString) -> Self {
self.request.merge_type = merge_type.to_string();
self
}
pub fn build(self) -> MergeCellsRequest {
let mut request = self.request;
request.api_request.body = serde_json::to_vec(&request).unwrap();
request
}
pub fn validate(&self) -> SDKResult<()> {
if self.request.spreadsheet_token.is_empty() {
return Err(crate::core::error::LarkAPIError::illegal_param(
"spreadsheet_token cannot be empty".to_string(),
));
}
if self.request.sheet_id.is_empty() {
return Err(crate::core::error::LarkAPIError::illegal_param(
"sheet_id cannot be empty".to_string(),
));
}
if self.request.range.is_empty() {
return Err(crate::core::error::LarkAPIError::illegal_param(
"range cannot be empty".to_string(),
));
}
if let ValidationResult::Invalid(msg) =
validation::validate_merge_range(&self.request.range)
{
return Err(crate::core::error::LarkAPIError::illegal_param(format!(
"Invalid merge range '{}': {}",
self.request.range, msg
)));
}
let valid_merge_types = ["MERGE_ALL", "MERGE_COLUMNS", "MERGE_ROWS"];
if !valid_merge_types.contains(&self.request.merge_type.as_str()) {
return Err(crate::core::error::LarkAPIError::illegal_param(format!(
"Invalid merge_type '{}'. Must be one of: MERGE_ALL, MERGE_COLUMNS, MERGE_ROWS",
self.request.merge_type
)));
}
Ok(())
}
}
impl_executable_builder_owned!(
MergeCellsRequestBuilder,
DataOperationService,
MergeCellsRequest,
MergeCellsResponseData,
merge_cells
);
#[derive(Deserialize, Debug)]
pub struct MergeCellsResponseData {
pub merged_range: String,
}
impl ApiResponseTrait for MergeCellsResponseData {
fn data_format() -> ResponseFormat {
ResponseFormat::Data
}
}
#[cfg(test)]
#[allow(unused_variables, unused_unsafe)]
mod test {
use serde_json::json;
use super::MergeCellsResponseData;
#[test]
fn test_merge_cells_response() {
let json = json!({
"merged_range": "A1:C3"
});
let response: MergeCellsResponseData = serde_json::from_value(json).unwrap();
assert_eq!(response.merged_range, "A1:C3");
}
}