Add named_style_type support to update_paragraph_style operation
Allows setting TITLE and SUBTITLE paragraph styles directly, in addition to the existing heading_level (0-6) parameter. The new named_style_type parameter accepts all Google Docs named styles: NORMAL_TEXT, TITLE, SUBTITLE, HEADING_1 through HEADING_6. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -113,6 +113,7 @@ def build_paragraph_style(
|
|||||||
indent_end: float = None,
|
indent_end: float = None,
|
||||||
space_above: float = None,
|
space_above: float = None,
|
||||||
space_below: float = None,
|
space_below: float = None,
|
||||||
|
named_style_type: str = None,
|
||||||
) -> tuple[Dict[str, Any], list[str]]:
|
) -> tuple[Dict[str, Any], list[str]]:
|
||||||
"""
|
"""
|
||||||
Build paragraph style object for Google Docs API requests.
|
Build paragraph style object for Google Docs API requests.
|
||||||
@@ -126,6 +127,8 @@ def build_paragraph_style(
|
|||||||
indent_end: Right/end indent in points
|
indent_end: Right/end indent in points
|
||||||
space_above: Space above paragraph in points
|
space_above: Space above paragraph in points
|
||||||
space_below: Space below paragraph in points
|
space_below: Space below paragraph in points
|
||||||
|
named_style_type: Direct named style (TITLE, SUBTITLE, HEADING_1..6, NORMAL_TEXT).
|
||||||
|
Takes precedence over heading_level when both are provided.
|
||||||
|
|
||||||
Returns:
|
Returns:
|
||||||
Tuple of (paragraph_style_dict, list_of_field_names)
|
Tuple of (paragraph_style_dict, list_of_field_names)
|
||||||
@@ -133,7 +136,20 @@ def build_paragraph_style(
|
|||||||
paragraph_style = {}
|
paragraph_style = {}
|
||||||
fields = []
|
fields = []
|
||||||
|
|
||||||
if heading_level is not None:
|
if named_style_type is not None:
|
||||||
|
valid_styles = [
|
||||||
|
"NORMAL_TEXT", "TITLE", "SUBTITLE",
|
||||||
|
"HEADING_1", "HEADING_2", "HEADING_3",
|
||||||
|
"HEADING_4", "HEADING_5", "HEADING_6",
|
||||||
|
]
|
||||||
|
if named_style_type not in valid_styles:
|
||||||
|
raise ValueError(
|
||||||
|
f"Invalid named_style_type '{named_style_type}'. "
|
||||||
|
f"Must be one of: {', '.join(valid_styles)}"
|
||||||
|
)
|
||||||
|
paragraph_style["namedStyleType"] = named_style_type
|
||||||
|
fields.append("namedStyleType")
|
||||||
|
elif heading_level is not None:
|
||||||
if heading_level < 0 or heading_level > 6:
|
if heading_level < 0 or heading_level > 6:
|
||||||
raise ValueError("heading_level must be between 0 (normal text) and 6")
|
raise ValueError("heading_level must be between 0 (normal text) and 6")
|
||||||
if heading_level == 0:
|
if heading_level == 0:
|
||||||
@@ -321,6 +337,7 @@ def create_update_paragraph_style_request(
|
|||||||
space_above: float = None,
|
space_above: float = None,
|
||||||
space_below: float = None,
|
space_below: float = None,
|
||||||
tab_id: Optional[str] = None,
|
tab_id: Optional[str] = None,
|
||||||
|
named_style_type: str = None,
|
||||||
) -> Optional[Dict[str, Any]]:
|
) -> Optional[Dict[str, Any]]:
|
||||||
"""
|
"""
|
||||||
Create an updateParagraphStyle request for Google Docs API.
|
Create an updateParagraphStyle request for Google Docs API.
|
||||||
@@ -337,6 +354,7 @@ def create_update_paragraph_style_request(
|
|||||||
space_above: Space above paragraph in points
|
space_above: Space above paragraph in points
|
||||||
space_below: Space below paragraph in points
|
space_below: Space below paragraph in points
|
||||||
tab_id: Optional ID of the tab to target
|
tab_id: Optional ID of the tab to target
|
||||||
|
named_style_type: Direct named style (TITLE, SUBTITLE, HEADING_1..6, NORMAL_TEXT)
|
||||||
|
|
||||||
Returns:
|
Returns:
|
||||||
Dictionary representing the updateParagraphStyle request, or None if no styles provided
|
Dictionary representing the updateParagraphStyle request, or None if no styles provided
|
||||||
@@ -350,6 +368,7 @@ def create_update_paragraph_style_request(
|
|||||||
indent_end,
|
indent_end,
|
||||||
space_above,
|
space_above,
|
||||||
space_below,
|
space_below,
|
||||||
|
named_style_type,
|
||||||
)
|
)
|
||||||
|
|
||||||
if not paragraph_style:
|
if not paragraph_style:
|
||||||
|
|||||||
@@ -244,6 +244,7 @@ class BatchOperationManager:
|
|||||||
op.get("space_above"),
|
op.get("space_above"),
|
||||||
op.get("space_below"),
|
op.get("space_below"),
|
||||||
tab_id,
|
tab_id,
|
||||||
|
op.get("named_style_type"),
|
||||||
)
|
)
|
||||||
|
|
||||||
if not request:
|
if not request:
|
||||||
|
|||||||
@@ -280,6 +280,7 @@ class ValidationManager:
|
|||||||
indent_end: Optional[float] = None,
|
indent_end: Optional[float] = None,
|
||||||
space_above: Optional[float] = None,
|
space_above: Optional[float] = None,
|
||||||
space_below: Optional[float] = None,
|
space_below: Optional[float] = None,
|
||||||
|
named_style_type: Optional[str] = None,
|
||||||
) -> Tuple[bool, str]:
|
) -> Tuple[bool, str]:
|
||||||
"""
|
"""
|
||||||
Validate paragraph style parameters.
|
Validate paragraph style parameters.
|
||||||
@@ -293,6 +294,7 @@ class ValidationManager:
|
|||||||
indent_end: Right/end indent in points
|
indent_end: Right/end indent in points
|
||||||
space_above: Space above paragraph in points
|
space_above: Space above paragraph in points
|
||||||
space_below: Space below paragraph in points
|
space_below: Space below paragraph in points
|
||||||
|
named_style_type: Direct named style (TITLE, SUBTITLE, HEADING_1..6, NORMAL_TEXT)
|
||||||
|
|
||||||
Returns:
|
Returns:
|
||||||
Tuple of (is_valid, error_message)
|
Tuple of (is_valid, error_message)
|
||||||
@@ -306,13 +308,26 @@ class ValidationManager:
|
|||||||
indent_end,
|
indent_end,
|
||||||
space_above,
|
space_above,
|
||||||
space_below,
|
space_below,
|
||||||
|
named_style_type,
|
||||||
]
|
]
|
||||||
if all(param is None for param in style_params):
|
if all(param is None for param in style_params):
|
||||||
return (
|
return (
|
||||||
False,
|
False,
|
||||||
"At least one paragraph style parameter must be provided (heading_level, alignment, line_spacing, indent_first_line, indent_start, indent_end, space_above, or space_below)",
|
"At least one paragraph style parameter must be provided (heading_level, alignment, line_spacing, indent_first_line, indent_start, indent_end, space_above, space_below, or named_style_type)",
|
||||||
)
|
)
|
||||||
|
|
||||||
|
if named_style_type is not None:
|
||||||
|
valid_styles = [
|
||||||
|
"NORMAL_TEXT", "TITLE", "SUBTITLE",
|
||||||
|
"HEADING_1", "HEADING_2", "HEADING_3",
|
||||||
|
"HEADING_4", "HEADING_5", "HEADING_6",
|
||||||
|
]
|
||||||
|
if named_style_type not in valid_styles:
|
||||||
|
return (
|
||||||
|
False,
|
||||||
|
f"Invalid named_style_type '{named_style_type}'. Must be one of: {', '.join(valid_styles)}",
|
||||||
|
)
|
||||||
|
|
||||||
if heading_level is not None:
|
if heading_level is not None:
|
||||||
if not isinstance(heading_level, int):
|
if not isinstance(heading_level, int):
|
||||||
return (
|
return (
|
||||||
@@ -627,6 +642,7 @@ class ValidationManager:
|
|||||||
op.get("indent_end"),
|
op.get("indent_end"),
|
||||||
op.get("space_above"),
|
op.get("space_above"),
|
||||||
op.get("space_below"),
|
op.get("space_below"),
|
||||||
|
op.get("named_style_type"),
|
||||||
)
|
)
|
||||||
if not is_valid:
|
if not is_valid:
|
||||||
return (
|
return (
|
||||||
|
|||||||
Reference in New Issue
Block a user