ó t®¸Qc@sÚdZddlTdefd„ƒYZdefd„ƒYZdefd„ƒYZd efd „ƒYZed krÖe ƒZ ee d d dgddde ƒZ e j dededeƒee jd jddddƒj ƒee jd jddddƒj ƒee jdjddƒj ƒee ƒZee dddd„ƒZee dddd„ƒZee ddƒZej d d!dd!ƒej d d!dd!ƒej d d!ƒej d d!ƒe jƒnd"S(#sAn implementation of tabbed pages using only standard Tkinter. Originally developed for use in IDLE. Based on tabpage.py. Classes exported: TabbedPageSet -- A Tkinter implementation of a tabbed-page widget. TabSet -- A widget containing tabs (buttons) in one or more rows. iÿÿÿÿ(t*tInvalidNameErrorcBseZRS((t__name__t __module__(((s)/sys/lib/python2.7/idlelib/tabbedpages.pyR stAlreadyExistsErrorcBseZRS((RR(((s)/sys/lib/python2.7/idlelib/tabbedpages.pyR stTabSetcBsoeZdZd dded„Zd„Zd„Zd„Zd„Z d„Z d „Z d e fd „ƒYZ RS( sjA widget containing tabs (buttons) in one or more rows. Only one tab may be selected at a time. iic Ksâtj|||||_||_||_||_||_i|_i|_|rjt |ƒ|_ n g|_ d |_ g|_ t|dddddtd|jdƒƒ|_|jjdtdtd tƒ|jƒd S( sConstructor arguments: select_command -- A callable which will be called when a tab is selected. It is called with the name of the selected tab as an argument. tabs -- A list of strings, the names of the tabs. Should be specified in the desired tab order. The first tab will be the default and first active tab. If tabs is None or empty, the TabSet will be initialized empty. n_rows -- Number of rows of tabs to be shown. If n_rows <= 0 or is None, then the number of rows will be decided by TabSet. See _arrange_tabs() for details. max_tabs_per_row -- Used for deciding how many rows of tabs are needed, when the number of rows is not constant. See _arrange_tabs() for details. theightit borderwidthitrelieft backgroundtsidetfilltexpandN(tFramet__init__tselect_commandtn_rowstmax_tabs_per_rowt expand_tabstpage_sett_tabst_tab2rowtlistt _tab_namestNonet _selected_tabt _tab_rowstFLATtcgett padding_frametpacktTOPtXtFalset _arrange_tabs(tselfRRttabsRRRtkw((s)/sys/lib/python2.7/idlelib/tabbedpages.pyRs$           cCsY|std|ƒ‚n||jkr;td|ƒ‚n|jj|ƒ|jƒdS(s.Add a new tab with the name given in tab_name.sInvalid Tab name: '%s'sTab named '%s' already existsN(RRRtappendR"(R#ttab_name((s)/sys/lib/python2.7/idlelib/tabbedpages.pytadd_tabDs cCs@||jkr"tdtƒ‚n|jj|ƒ|jƒdS(sRemove the tab named sNo such Tab: '%sN(RtKeyErrort page_nametremoveR"(R#R'((s)/sys/lib/python2.7/idlelib/tabbedpages.pyt remove_tabNscCsÖ||jkrdS|dk rA||jkrAtdtƒ‚n|jdk rg|j|jjƒnd|_|dk rÒ||_|j|}|jƒ|j|}|jƒ|j dt dt ddƒndS(s1Show the tab named as the selected oneNsNo such Tab: '%sR R R i( RRRR)R*t set_normalt set_selectedRt pack_forgetRRR (R#R'ttabttab_row((s)/sys/lib/python2.7/idlelib/tabbedpages.pytset_selected_tabVs       cCsÊ|s dSt|ƒ}|jdtdtddƒ|jj|ƒxx|D]p}tj||j||ƒ}|r|jdt dtdt ƒn|jdt ƒ||j |<||j |= 1, this will be the number of rows used. Otherwise the number of rows will be calculated according to the number of tabs and max_tabs_per_row. In this case, the number of rows may change when adding/removing tabs. Nii(RtkeysR9R:R;RRRtlenRRtxrangeR8RR2( R#R'RRtit row_indextn_tabsR7tselected((s)/sys/lib/python2.7/idlelib/tabbedpages.pyR"‡s&    #   R3cBsMeZdZdZd„Zd„Zd„Zd„Zd„Ze d„Z RS(sA simple tab-like widget.icCsÂtj||d|jdtƒ||_||_||_t|_t |d|d|j ddddd t d t d d d ddd ƒ |_ |j j dtdtdtƒ|jƒ|jƒdS(súConstructor arguments: name -- The tab's name, which will appear in its button. select_command -- The command to be called upon selection of the tab. It is called with the tab's name as an argument. RRttexttcommandtpadxitpadyit takefocust indicatoronthighlightthicknessit selectcolortR R R N(R RtbwtRAISEDtnameRttab_setR!R6t Radiobuttont _select_eventtFALSEtbuttonRR4R R5t _init_masksR-(R#RNRR1RO((s)/sys/lib/python2.7/idlelib/tabbedpages.pyR´s      cGs|j|jƒdS(ssEvent handler for tab selection. With TabbedPageSet, this calls TabbedPageSet.change_page, so that selecting a tab changes the page. Note that this does -not- call set_selected -- it will be called by TabSet.set_selected_tab, which should be called when whatever the tabs are related to changes. N(RRN(R#targs((s)/sys/lib/python2.7/idlelib/tabbedpages.pyRQÍs cCs|jdtƒdS(sAssume selected lookRBN(t _place_masksR5(R#((s)/sys/lib/python2.7/idlelib/tabbedpages.pyR.ÛscCs|jdtƒdS(sAssume normal lookRBN(RVR!(R#((s)/sys/lib/python2.7/idlelib/tabbedpages.pyR-ßsc Cs|jj}|jjdƒ}t|dddtd|ƒ|_t|dddtd|ƒ|_t|jd|jdt ƒ|j_ |jj j ddd|j dd|jd |jd ƒt|dddtd|ƒ|_ t|j d|jdt ƒ|j _ dS( NR RiRtxtytwidthiRi(RORt pages_frameRR RtmasktmsklRLRMtmltplacetmskrtmr(R#RR ((s)/sys/lib/python2.7/idlelib/tabbedpages.pyRTãs    cCs|j}|r||j7}n|jjd|ddddddddd dd dd dd |ƒ |jjd|ddd|j ddddd dd |jd dd |ƒ |jj}|r|j sô|jƒ|jƒ|jƒ|jƒkr||j8}n|j jd|ddddddddd dd |jd dd |ƒ |j j jd|j d|j d d |jd ||jd ƒ|jj ƒdS(Ntin_trelxgRWitrelygð?RXtrelwidthRYt relheightRi( RLR[R^R\RORR6t winfo_rootxt winfo_widthR_R`tlower(R#RBRR((s)/sys/lib/python2.7/idlelib/tabbedpages.pyRVøs4           #( RRt__doc__RLRRQR.R-RTR!RV(((s)/sys/lib/python2.7/idlelib/tabbedpages.pyR3¯s     N(RRRiRR!RR(R,R2R8R;R"R R3(((s)/sys/lib/python2.7/idlelib/tabbedpages.pyRs  ,     (t TabbedPageSetcBs™eZdZdefd„ƒYZdefd„ƒYZdefd„ƒYZdefd„ƒYZded d e d „Z d „Z d „Z d„Z RS(sjA Tkinter tabbed-pane widget. Constains set of 'pages' (or 'panes') with tabs above for selecting which page is displayed. Only one page will be displayed at a time. Pages may be accessed through the 'pages' attribute, which is a dictionary of pages, using the name given as the key. A page is an instance of a subclass of Tk's Frame widget. The page widgets will be created (and destroyed when required) by the TabbedPageSet. Do not call the page's pack/place/grid/destroy methods. Pages may be added or removed at any time using the add_page() and remove_page() methods. tPagecBs/eZdZeZd„Zd„Zd„ZRS(s{Abstract base class for TabbedPageSet's pages. Subclasses must override the _show() and _hide() methods. cCst|dddtƒ|_dS(NRiR(R RMtframe(R#R((s)/sys/lib/python2.7/idlelib/tabbedpages.pyR9scCs t‚dS(N(tNotImplementedError(R#((s)/sys/lib/python2.7/idlelib/tabbedpages.pyt_show<scCs t‚dS(N(Rm(R#((s)/sys/lib/python2.7/idlelib/tabbedpages.pyt_hide?s(RRRiR!t uses_gridRRnRo(((s)/sys/lib/python2.7/idlelib/tabbedpages.pyRk1s   t PageRemovecBs&eZdZeZd„Zd„ZRS(sAPage class using the grid placement manager's "remove" mechanism.cCs#|jjdddddtƒdS(Ntrowitcolumntsticky(RltgridtNSEW(R#((s)/sys/lib/python2.7/idlelib/tabbedpages.pyRnFscCs|jjƒdS(N(Rlt grid_remove(R#((s)/sys/lib/python2.7/idlelib/tabbedpages.pyRoIs(RRRiR5RpRnRo(((s)/sys/lib/python2.7/idlelib/tabbedpages.pyRqBs tPageLiftcBs/eZdZeZd„Zd„Zd„ZRS(s?Page class using the grid placement manager's "lift" mechanism.cCsIttj|ƒj|ƒ|jjdddddtƒ|jjƒdS(NRriRsRt(tsuperRjRxRRlRuRvRh(R#R((s)/sys/lib/python2.7/idlelib/tabbedpages.pyRPscCs|jjƒdS(N(Rltlift(R#((s)/sys/lib/python2.7/idlelib/tabbedpages.pyRnUscCs|jjƒdS(N(RlRh(R#((s)/sys/lib/python2.7/idlelib/tabbedpages.pyRoXs(RRRiR5RpRRnRo(((s)/sys/lib/python2.7/idlelib/tabbedpages.pyRxLs   tPagePackForgetcBs eZdZd„Zd„ZRS(sAPage class using the pack placement manager's "forget" mechanism.cCs|jjdtdtƒdS(NR R (RlRtBOTHR5(R#((s)/sys/lib/python2.7/idlelib/tabbedpages.pyRn]scCs|jjƒdS(N(RlR/(R#((s)/sys/lib/python2.7/idlelib/tabbedpages.pyRo`s(RRRiRnRo(((s)/sys/lib/python2.7/idlelib/tabbedpages.pyR{[s iic KsPtj|||||_i|_g|_d |_d |_|jdddƒ|j dddƒt|ƒ|_ |j j dddddt ƒ|jj rÏ|j jdddƒ|j j dddƒnt||jd|d|d |ƒ|_|rx|D]}|j|ƒqWn|jj dddddt ƒ|j|jƒd S( sŒConstructor arguments: page_names -- A list of strings, each will be the dictionary key to a page's widget, and the name displayed on the page's tab. Should be specified in the desired page order. The first page will be the default and first active page. If page_names is None or empty, the TabbedPageSet will be initialized empty. n_rows, max_tabs_per_row -- Parameters for the TabSet which will manage the tabs. See TabSet's docs for details. page_class -- Pages can be shown/hidden using three mechanisms: * PageLift - All pages will be rendered one on top of the other. When a page is selected, it will be brought to the top, thus hiding all other pages. Using this method, the TabbedPageSet will not be resized when pages are switched. (It may still be resized when pages are added/removed.) * PageRemove - When a page is selected, the currently showing page is hidden, and the new page shown in its place. Using this method, the TabbedPageSet may resize when pages are changed. * PagePackForget - This mechanism uses the pack placement manager. When a page is shown it is packed, and when it is hidden it is unpacked (i.e. pack_forget). This mechanism may also cause the TabbedPageSet to resize when the page is changed. itweightiRrRsRtRRRN(R Rt page_classtpagest _pages_orderRt _current_paget _default_pagetcolumnconfiguret rowconfigureRZRuRvRpRt change_paget_tab_settadd_page( R#tparentt page_namesR~RRRR%RN((s)/sys/lib/python2.7/idlelib/tabbedpages.pyRcs*         cCs¦|std|ƒ‚n||jkr;td|ƒ‚n|j|jƒ|j|<|jj|ƒ|jj|ƒt |jƒdkr¢||_ |j |ƒndS(s0Add a new page with the name given in page_name.sInvalid TabPage name: '%s's!TabPage named '%s' already existsiN( RRRR~RZR€R&R†R(R=R‚R…(R#R*((s)/sys/lib/python2.7/idlelib/tabbedpages.pyR‡Ÿs cCsÊ||jkr"td|ƒ‚n|jj|ƒt|jƒdkrl||jkru|jd|_qun d|_||jkr—|j|jƒn|j j |ƒ|jj |ƒ}|j j ƒdS(s2Destroy the page whose name is given in page_name.sNo such TabPage: '%siN(RR)R€R+R=R‚RRR…R†R,R9RlR:(R#R*tpage((s)/sys/lib/python2.7/idlelib/tabbedpages.pyt remove_page¯s cCs­|j|krdS|dk rA||jkrAtd|ƒ‚n|jdk rg|j|jjƒnd|_|dk r™||_|j|jƒn|jj|ƒdS(s/Show the page whose name is given in page_name.NsNo such TabPage: '%s'(RRRR)RoRnR†R2(R#R*((s)/sys/lib/python2.7/idlelib/tabbedpages.pyR…Ås   N(RRRitobjectRkRqRxR{RR!RR‡R‹R…(((s)/sys/lib/python2.7/idlelib/tabbedpages.pyRj s ;  t__main__R‰tFoobartBazRiRR R R RCtFooRFitBarsAdd PageRDcCstjtjƒƒS(N(ttabPageR‡t entryPgNametget(((s)/sys/lib/python2.7/idlelib/tabbedpages.pytâss Remove PagecCstjtjƒƒS(N(R’R‹R“R”(((s)/sys/lib/python2.7/idlelib/tabbedpages.pyR•ässname of page to add/remove:REiN(RitTkintert ExceptionRRR RRjRtTktrootR!R’RRtTRUER|tLabelRRltEntryR“tButtont buttonAddt buttonRemovet labelPgNametmainloop(((s)/sys/lib/python2.7/idlelib/tabbedpages.pyt s2 ÿ¶   &&