o
    h/                     @  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 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rLd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)CT_DecimalNumber)ST_SignedTwipsMeasureST_TwipsMeasure)BaseOxmlElement	OneOrMoreOptionalAttributeRequiredAttribute	ZeroOrOne)Length)	CT_SectPr)	CT_Stringc                   @  sZ   e Zd ZU dZedeZded< edeZded< ede	Z
ded< ed	e	Zded
< dS )CT_Indz6``<w:ind>`` element, specifying paragraph indentation.zw:leftLength | Noneleftzw:rightrightzw:firstLine	firstLinez	w:hanginghangingN)__name__
__module____qualname____doc__r   r
   r   __annotations__r   r   r   r    r   r   U/var/www/html/premium_crap/venv/lib/python3.10/site-packages/docx/oxml/text/parfmt.pyr      s   
 r   c                   @  s$   e Zd ZU dZedeZded< dS )CT_Jcz7``<w:jc>`` element, specifying paragraph justification.w:valr   valN)r   r   r   r   r   r   r#   r   r   r   r   r    r!   .   s
   
 r!   c                   @  s  e Zd ZU dZded< ded< 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d$ed%< ed&ed'd dZed(ed)d dZd*ed+< ed,ed-d dZ[ed[d0d1Zejd\d3d1Zed[d4d5Zejd\d6d5Zed[d7d8Zejd\d9d8Zed]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dGdH ZejdIdH ZedJdK ZejdLdK ZedMdN ZejdOdN ZedPdQ ZejdRdQ Zed^dTdUZ e jd_dWdUZ edXdY Z!e!jdZdY Z!dS )`CT_PPrz?``<w:pPr>`` element, containing the properties for a paragraph.zCallable[[], CT_Ind]get_or_add_indzCallable[[], CT_String]get_or_add_pStylezCallable[[], CT_SectPr]get_or_add_sectPrz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:textboxTightWrapw:outlineLvlzw:divIdz
w:cnfStylezw:rPrw:sectPrzw:pPrChanger+      N
successorszCT_String | NonepStyler,      r-      r.      r/      r0      r1      r2      r3      zCT_Ind | Noneindr4      r5      r	   
outlineLvlr6   #   returnr   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)rC   r   r   r   )selfrC   r   r   r   r   r    first_line_indentz   s   
zCT_PPr.first_line_indentvaluec                 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   )rC   r%   r   r   rI   rK   rC   r   r   r    rJ      s   
c                 C     | j }|du r	dS |jS )z6The value of `w:ind/@w:left` or |None| if not present.N)rC   r   rI   rC   r   r   r    ind_left      zCT_PPr.ind_leftc                 C  (   |d u r| j d u rd S |  }||_d S N)rC   r%   r   rL   r   r   r    rO         
c                 C  rM   )z7The value of `w:ind/@w:right` or |None| if not present.N)rC   r   rN   r   r   r    	ind_right   rP   zCT_PPr.ind_rightc                 C  rQ   rR   )rC   r%   r   rL   r   r   r    rT      rS   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#   rI   r   r   r    jc_val   s   zCT_PPr.jc_valc                 C  "   |d u r
|    d S ||  _d S rR   )
_remove_jcget_or_add_jcr#   rI   rK   r   r   r    rX      s   c                 C  rM   )z7The value of `keepLines/@val` or |None| if not present.N)	keepLinesr#   )rI   r]   r   r   r    keepLines_val   rP   zCT_PPr.keepLines_valc                 C  rY   rR   )_remove_keepLinesget_or_add_keepLinesr#   r\   r   r   r    r^         c                 C  rM   )z6The value of `keepNext/@val` or |None| if not present.N)keepNextr#   )rI   rb   r   r   r    keepNext_val   rP   zCT_PPr.keepNext_valc                 C  rY   rR   )_remove_keepNextget_or_add_keepNextr#   r\   r   r   r    rc      ra   c                 C  rM   )z=The value of `pageBreakBefore/@val` or |None| if not present.N)pageBreakBeforer#   )rI   rf   r   r   r    pageBreakBefore_val   rP   zCT_PPr.pageBreakBefore_valc                 C  rY   rR   )_remove_pageBreakBeforeget_or_add_pageBreakBeforer#   r\   r   r   r    rg      ra   c                 C  rM   )z;The value of `w:spacing/@w:after` or |None| if not present.N)spacingafterrI   rj   r   r   r    spacing_after   rP   zCT_PPr.spacing_afterc                 C  $   |d u r| j d u rd S ||  _d S rR   )rj   get_or_add_spacingrk   r\   r   r   r    rm         c                 C  rM   )z<The value of `w:spacing/@w:before` or |None| if not present.N)rj   beforerl   r   r   r    spacing_before   rP   zCT_PPr.spacing_beforec                 C  rn   rR   )rj   ro   rq   r\   r   r   r    rr     rp   c                 C  rM   )z:The value of `w:spacing/@w:line` or |None| if not present.N)rj   linerl   r   r   r    spacing_line  rP   zCT_PPr.spacing_linec                 C  rn   rR   )rj   ro   rs   r\   r   r   r    rt     rp   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)rj   lineRulers   r   MULTIPLE)rI   rj   ru   r   r   r    spacing_lineRule  s   
zCT_PPr.spacing_lineRulec                 C  rn   rR   )rj   ro   ru   r\   r   r   r    rw   ,  rp   
str | Nonec                 C  rM   )zGString contained in `./w:pStyle/@val`, or None if child is not present.N)r:   r#   )rI   r:   r   r   r    style2  rP   zCT_PPr.stylery   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#   )rI   ry   r:   r   r   r    ry   :  s
   
c                 C  rM   )z:The value of `widowControl/@val` or |None| if not present.N)widowControlr#   )rI   rz   r   r   r    widowControl_valF  rP   zCT_PPr.widowControl_valc                 C  rY   rR   )_remove_widowControlget_or_add_widowControlr#   r\   r   r   r    r{   N  ra   )rH   r   )rK   r   )rH   rU   )rH   rx   )ry   rx   )"r   r   r   r   r   _tag_seqr   r:   rb   r]   rf   rz   numPrtabsrj   rC   rV   rF   sectPrpropertyrJ   setterrO   rT   rX   r^   rc   rg   rm   rr   rt   rw   ry   r{   r   r   r   r    r$   6   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   rk   rq   r
   rs   r   ru   r   r   r   r    r   V  s    


r   c                   @  sX   e Zd ZU dZedeZded< ede	e	j
dZded< ed	eZd
ed< 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"   r   r#   zw:leader)defaultzWD_TAB_LEADER | Noneleaderzw:posr   posrH   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   rW   r   r   r    __str__q  s   zCT_TabStop.__str__N)rH   r   )r   r   r   r   r   r   r#   r   r   r   SPACESr   r
   r   r   r   r   r   r    r   `  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   r8   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)rI   r   alignr   new_tabtabr   r   r    insert_tab_in_order  s   


zCT_TabStops.insert_tab_in_orderN)r   r   r   r   r   r   r   r   r   r   r    r   z  s    r   N)!r   
__future__r   typingr   r   docx.enum.textr   r   r   r   docx.oxml.sharedr	   docx.oxml.simpletypesr
   r   docx.oxml.xmlchemyr   r   r   r   r   docx.sharedr   docx.oxml.sectionr   r   r   r!   r$   r   r   r   r   r   r   r    <module>   s&      "
