o
    	'f+                     @  s   d Z ddlmZ ddlmZmZ ddlmZmZm	Z	m
Z
 ddlmZmZ ddlmZmZmZmZmZ ddlmZ erFddlmZ dd	lmZ G d
d deZG dd deZG dd deZG dd deZG dd deZG dd deZdS )z@Custom element classes related to paragraph properties (CT_PPr).    )annotations)TYPE_CHECKINGCallable)WD_ALIGN_PARAGRAPHWD_LINE_SPACINGWD_TAB_ALIGNMENTWD_TAB_LEADER)ST_SignedTwipsMeasureST_TwipsMeasure)BaseOxmlElement	OneOrMoreOptionalAttributeRequiredAttribute	ZeroOrOne)Length)	CT_SectPr)	CT_Stringc                   @  s8   e Zd ZdZedeZedeZedeZ	edeZ
dS )CT_Indz6``<w:ind>`` element, specifying paragraph indentation.zw:leftzw:rightzw:firstLinez	w:hangingN)__name__
__module____qualname____doc__r   r	   leftrightr
   	firstLinehanging r   r   M/home/ubuntu/flask/venv/lib/python3.10/site-packages/docx/oxml/text/parfmt.pyr      s    


r   c                   @  s   e Zd ZdZedeZdS )CT_Jcz7``<w:jc>`` element, specifying paragraph justification.w:valN)r   r   r   r   r   r   valr   r   r   r   r   %   s    r   c                   @  st  e Zd ZU dZded< ded< ded< ded< d	Zed
edd dZded< ededd dZededd dZ	ededd dZ
ededd dZededd dZededd dZededd dZededd dZed ed!d dZed"ed#d dZ[ed$d% Zejd&d% Zed'd( Zejd)d( Zed*d+ Zejd,d+ ZedOd/d0Zejd1d0 Zed2d3 Zejd4d3 Zed5d6 Zejd7d6 Zed8d9 Zejd:d9 Zed;d< Zejd=d< Zed>d? Zejd@d? ZedAdB ZejdCdB ZedDdE ZejdFdE ZedPdHdIZejdQdKdIZedLdM Z e jdNdM Z dS )RCT_PPrz?``<w:pPr>`` element, containing the properties for a paragraph.zCallable[[], CT_String]get_or_add_pStylezCallable[[CT_SectPr], None]_insert_sectPrzCallable[[], None]_remove_pStyle_remove_sectPr)$w:pStyle
w:keepNextw:keepLinesw:pageBreakBeforez	w:framePrw:widowControlw:numPrzw:suppressLineNumberszw:pBdrzw:shdw:tabszw:suppressAutoHyphensz	w:kinsokuz
w:wordWrapzw:overflowPunctzw:topLinePunctzw:autoSpaceDEzw:autoSpaceDNzw:bidizw:adjustRightIndzw:snapToGrid	w:spacingw:indzw:contextualSpacingzw:mirrorIndentszw:suppressOverlapw:jczw:textDirectionzw:textAlignmentzw:textboxTightWrapzw:outlineLvlzw:divIdz
w:cnfStylezw:rPrw:sectPrzw:pPrChanger&      N
successorszCT_String | NonepStyler'      r(      r)      r*      r+      r,      r-      r.      r/      r0   #   c                 C  s@   | j }|du r	dS |j}|durt| S |j}|du rdS |S )zA |Length| value calculated from the values of `w:ind/@w:firstLine` and
        `w:ind/@w:hanging`.

        Returns |None| if the `w:ind` child is not present.
        N)indr   r   r   )selfr?   r   r   r   r   r   first_line_indenth   s   
zCT_PPr.first_line_indentc                 C  sT   | j d u r|d u rd S |  }d  |_|_|d u rd S |dk r%| |_d S ||_d S )Nr   )r?   get_or_add_indr   r   r@   valuer?   r   r   r   rA   z   s   
c                 C     | j }|du r	dS |jS )z6The value of `w:ind/@w:left` or |None| if not present.N)r?   r   r@   r?   r   r   r   ind_left      zCT_PPr.ind_leftc                 C  (   |d u r| j d u rd S |  }||_d S N)r?   rB   r   rC   r   r   r   rG         
c                 C  rE   )z7The value of `w:ind/@w:right` or |None| if not present.N)r?   r   rF   r   r   r   	ind_right   rH   zCT_PPr.ind_rightc                 C  rI   rJ   )r?   rB   r   rC   r   r   r   rL      rK   returnWD_ALIGN_PARAGRAPH | Nonec                 C  s   | j dur	| j jS dS )z=Value of the `<w:jc>` child element or |None| if not present.N)jcr    r@   r   r   r   jc_val   s   zCT_PPr.jc_valc                 C  "   |d u r
|    d S ||  _d S rJ   )
_remove_jcget_or_add_jcr    r@   rD   r   r   r   rQ      s   c                 C  rE   )z7The value of `keepLines/@val` or |None| if not present.N)	keepLinesr    )r@   rV   r   r   r   keepLines_val   rH   zCT_PPr.keepLines_valc                 C  rR   rJ   )_remove_keepLinesget_or_add_keepLinesr    rU   r   r   r   rW         c                 C  rE   )z6The value of `keepNext/@val` or |None| if not present.N)keepNextr    )r@   r[   r   r   r   keepNext_val   rH   zCT_PPr.keepNext_valc                 C  rR   rJ   )_remove_keepNextget_or_add_keepNextr    rU   r   r   r   r\      rZ   c                 C  rE   )z=The value of `pageBreakBefore/@val` or |None| if not present.N)pageBreakBeforer    )r@   r_   r   r   r   pageBreakBefore_val   rH   zCT_PPr.pageBreakBefore_valc                 C  rR   rJ   )_remove_pageBreakBeforeget_or_add_pageBreakBeforer    rU   r   r   r   r`      rZ   c                 C  rE   )z;The value of `w:spacing/@w:after` or |None| if not present.N)spacingafterr@   rc   r   r   r   spacing_after   rH   zCT_PPr.spacing_afterc                 C  $   |d u r| j d u rd S ||  _d S rJ   )rc   get_or_add_spacingrd   rU   r   r   r   rf         c                 C  rE   )z<The value of `w:spacing/@w:before` or |None| if not present.N)rc   beforere   r   r   r   spacing_before   rH   zCT_PPr.spacing_beforec                 C  rg   rJ   )rc   rh   rj   rU   r   r   r   rk      ri   c                 C  rE   )z:The value of `w:spacing/@w:line` or |None| if not present.N)rc   linere   r   r   r   spacing_line   rH   zCT_PPr.spacing_linec                 C  rg   rJ   )rc   rh   rl   rU   r   r   r   rm     ri   c                 C  s4   | j }|du r	dS |j}|du r|jdurtjS |S )au  The value of `w:spacing/@w:lineRule` as a member of the :ref:`WdLineSpacing`
        enumeration.

        Only the `MULTIPLE`, `EXACTLY`, and `AT_LEAST` members are used. It is the
        responsibility of the client to calculate the use of `SINGLE`, `DOUBLE`, and
        `MULTIPLE` based on the value of `w:spacing/@w:line` if that behavior is
        desired.
        N)rc   lineRulerl   r   MULTIPLE)r@   rc   rn   r   r   r   spacing_lineRule  s   
zCT_PPr.spacing_lineRulec                 C  rg   rJ   )rc   rh   rn   rU   r   r   r   rp     ri   
str | Nonec                 C  rE   )zGString contained in `./w:pStyle/@val`, or None if child is not present.N)r4   r    )r@   r4   r   r   r   style   rH   zCT_PPr.stylerr   c                 C  s&   |du r
|    dS |  }||_dS )zSet `./w:pStyle/@val` `style`, adding a new element if necessary.

        If `style` is |None|, remove `./w:pStyle` when present.
        N)r$   r"   r    )r@   rr   r4   r   r   r   rr   (  s
   
c                 C  rE   )z:The value of `widowControl/@val` or |None| if not present.N)widowControlr    )r@   rs   r   r   r   widowControl_val4  rH   zCT_PPr.widowControl_valc                 C  rR   rJ   )_remove_widowControlget_or_add_widowControlr    rU   r   r   r   rt   <  rZ   )rM   rN   )rM   rq   )rr   rq   )!r   r   r   r   __annotations___tag_seqr   r4   r[   rV   r_   rs   numPrtabsrc   r?   rO   sectPrpropertyrA   setterrG   rL   rQ   rW   r\   r`   rf   rk   rm   rp   rr   rt   r   r   r   r   r!   +   s   
 &





















r!   c                   @  s8   e Zd ZdZedeZedeZedeZ	ede
ZdS )
CT_Spacingzk``<w:spacing>`` element, specifying paragraph spacing attributes such as space
    before and line spacing.zw:afterzw:beforezw:linez
w:lineRuleN)r   r   r   r   r   r
   rd   rj   r	   rl   r   rn   r   r   r   r   r~   D  s    


r~   c                   @  s>   e Zd ZdZedeZedeej	dZ
edeZddd	Zd
S )
CT_TabStopz`<w:tab>` element, representing an individual tab stop.

    Overloaded to use for a tab-character in a run, which also uses the w:tab tag but
    only needs a __str__ method.
    r   zw:leader)defaultzw:posrM   strc                 C  s   dS )zText equivalent of a `w:tab` element appearing in a run.

        Allows text of run inner-content to be accessed consistently across all text
        inner-content.
        	r   rP   r   r   r   __str__Y  s   zCT_TabStop.__str__N)rM   r   )r   r   r   r   r   r   r    r   r   SPACESleaderr	   posr   r   r   r   r   r   N  s    

r   c                   @  s$   e Zd ZdZedddZdd ZdS )CT_TabStopszC``<w:tabs>`` element, container for a sorted sequence of tab stops.zw:tabr   r2   c                 C  sV   |   }||||_|_|_| jD ]}|j|jk r#|| |  S q| | |S )z<Insert a newly created `w:tab` child element in `pos` order.)_new_tabr   r    r   tab_lstaddpreviousappend)r@   r   alignr   new_tabtabr   r   r   insert_tab_in_orderg  s   


zCT_TabStops.insert_tab_in_orderN)r   r   r   r   r   r   r   r   r   r   r   r   b  s    r   N) r   
__future__r   typingr   r   docx.enum.textr   r   r   r   docx.oxml.simpletypesr	   r
   docx.oxml.xmlchemyr   r   r   r   r   docx.sharedr   docx.oxml.sectionr   docx.oxml.sharedr   r   r   r!   r~   r   r   r   r   r   r   <module>   s$    	  
