U
    bEfp                     @   s6   d dl T d dlmZ d dlmZ G dd dejZdS )    )*)cmf_list)CmfActiveEntityc                       s~  e Zd Ze fddZdd Zdd Zdd Z fd	d
Z fddZ	 fddZ
dd Zdd Zdd fdd
Z fddZeedddgddd Zeeddddd d!d" Zed#d$ Zd%d%d&d'd(Zd)d* Zeed+dd,dd-d.d/ ZdHd0d1Z fd2d3Zd4d5 Zd6d7 Zeed+dd8dd-d9d: Zd;d< Zed=d> ZdIeeed@dAdBZ dJeedEdFdGZ!  Z"S )KCmfListc                    s   t  j||}|S N)superget)clsargskwargsres	__class__ $./modules/project/models/cmf_list.pyr      s    zCmfList.getc                 C   s   | j r
d S | jj  | _ d S r   )default_task_workflowZ	scheme_wfloadselfr   r   r   _calc_default_workflow   s    zCmfList._calc_default_workflowc                 C   s   | j jsd S | jsd S | j s6d | j_| jjdd d S d| j }| jj  | jj}|r~d|_ |jdd d|j d| }| | j_| jjdd t| d S )NTZ	only_datau`   Все новые задачи проекта будут добавляться в список FuW   Сбросили галочку Список по умолчанию у спринта z. )Zis_default_list
is_changedparentZdefault_listsavenamer   	cmf_alert)r   msgZcurrent_default_listr   r   r   _calc_is_default_list   s$    zCmfList._calc_is_default_listc                 C   s^   | j js| js| jrd S | jjr*| jr*d S | jdkr<d| _n| jdkrNd| _n| j | _d S )N)list.agile_sprintZkanban
list.pfeedpfeed)Z
logic_typer   is_newZui_view_formlogic_prefixui_namelowerr   r   r   r   _calc_ui_view_form2   s    

zCmfList._calc_ui_view_formc                    s   t   dddg S )Ntree_parentr   auto_favorite)r   save_preload_fieldsr   r   r   r   r(   @   s    zCmfList.save_preload_fieldsc                    s   t   dg S )Nmembers)r   simple_perm_allow_fieldsr   r   r   r   r*   C   s    z CmfList.simple_perm_allow_fieldsc                    s  |    td| j dtjjjitjgd dd | jddD dgkrLd S | jsv| 	 | _| jrv| jj
d	d
dgd | js| jr| jj r| jj| _| js| jr| jj r| jj| _| jstjjddd| _| jrL| jdkrL| jr| jj
dgd | jr | jjs | jpd | _n,| jr8| jjdsLd| jpDd | _| jrp| jdkrptjjdd| _|   t j||}| jjrttjj | j js| j!jr| 
dg | jD ]D}d|_d|j"_| j s| j!sd |_ d |_!|j|ddi| q| jrP| jjrP| 
dg | jD ]"}| j|_|j|ddi| q,| j#jr| j#r| 
dg | jD ](}d |_$|%  |&  |j|| qt|S )Nzlist-changes-Zperson_code)Zevent_personsc                 S   s   g | ]
}|j qS r   )
class_name).0ir   r   r   
<listcomp>J   s     z CmfList.save.<locals>.<listcomp>T)r   r)   	cmf_ownerZcmf_owner_assistantsactivityfieldsZbusiness)codeZcache_inmemoryr   add_object_type1ZSprintzSprint r   zpfeed.base:default)r3   notifyF)'_process_auto_favoritecmf_emit_eventidgcurrent_personr3   valuevaluesr   get_projectload_fieldsr0   r&   r   modelsZCmfActivityr   r!   r"   r4   r   
startswithZCmfLogicTypeZdefault_task_logic_typer   r   r   r)   r   schedule_deferred_jobr   recalculate_cacheplan_start_dateplan_end_datelistsr   workflowZsave_prepareZ_calc_workflow)r   r
   r   r   taskmemberr   r   r   r   F   sd    $






zCmfList.savec                 K   s   | j dgd tjj|dddgd}|s<td| ddd	 t| jjD ]}| j| |j	| qH|
  | 
  |   | S )
Nr)   r1   rD   rE   r9   r2   u:   Целевой список для объединения u    не существуетTabort)r?   r@   r   r   r   listr)   r<   removeappendr   delete)r   target_list_idr   target_listrH   r   r   r   
move_tasks   s    zCmfList.move_tasksc                    s    fdd  | j jS )Nc                    s0   | sd S | j dkr| S | j   | jjS d S )N
CmfProject)r+   r&   r   r<   )Zchildroot_parentr   r   rV      s    

z(CmfList.get_project.<locals>.root_parent)r&   r<   r   r   rU   r   r>      s    zCmfList.get_projectF)TEXKOM_db_deletec                   s\   | j j|dgd t| j D ](}|j|  |jdd | j | qt j|d|i|S )NrF   )Zinclude_deletedr2   Fr6   rW   )r)   r   rM   rF   rN   r   r   rP   )r   rW   r
   r   mr   r   r   rP      s    zCmfList.deletec                    s"   t  j|fdd| j di|S )NZmsg_urlz/project/List/z/kanban)r   create_eventr3   )r   Zevent_personr   r   r   r   rZ      s    zCmfList.create_eventTlist_ids)	only_once
system_jobZonly_once_argsc                 C   s   | sd S t jjdd| gdddddgd}|D ]}d	}|jd
krBd}t jj|d|jggdgd}d|_d|_d|_	d|_
|D ]P}|d}|d}|dkr||_|dkr||_|dkr||_	|dkrz||_
qz|  q,d S )Nr9   INr"   count_tasks_opencount_tasks_in_progresscount_tasks_in_reviewcount_tasks_closedfilterr2   rF   list.releasefix_versionscache_status_type)rd   Zgroup_byr   countOPENIN_PROGRESSZ	IN_REVIEWCLOSED)r@   r   rM   r"   CmfTaskrh   r9   r_   r`   ra   rb   r   r   )r[   rF   lstZ
field_nameZcounterscstatus_typerh   r   r   r   recalculate_count_cache   s4    


zCmfList.recalculate_count_cache<      )r\   Zsoft_time_limitr]   priorityc               	   K   s  t j}d}d}|jdddgdD ]}|d7 }t|j}|jdkrf|t jjdd	|ggd
d|gggd7 }|j|kr|d7 }t	
d|j d| d|j  ||_|jdd |jj|jjd}td|j | td| |d dkr t  q t	
d| d| d |S )uI   Актуализация кеша кол-ва задач в списке.r   cache_members_countr)   r"   r1      re   rf   r^   rF   zNOT INrd   zUpdate cache_members_count z ->  Tr   )Znode_idZelements_countztree-node-count-changes-ztree-node-count-changes2   zRecalculate /z lists caches)r@   r   rM   lenr)   r"   rl   rh   rt   r:   debugr9   r   r<   r8   Z
cmf_commit)_kwargsr	   Ztotal_countZ
calc_countr   Z
real_countZ
event_datar   r   r   rC      s,    




 
zCmfList.recalculate_cachec                 C   s   t jjdd}g }|rpt jjdgdd|jgdddggdgd	}t jjdddgd
ddgdd|jggdgdgd}n&t jjdddgd
ddggdgdgd}||S )NT)Z
is_defaultr   Z	parent_id==Z	list_typer    cmf_created_at)r2   rd   order_byrg   !=rk   textrd   r   r2   )r@   rT   r   r   rM   r9   )r	   Zdefault_parentZdefault_pfeedr   r   r   r   
pfeed_list   s2    


  zCmfList.pfeed_listN)release_daterQ   c                O   s   |  dg | jjdd| _|| _|   |rtjj|d}tj	j
ddd| ggdd	dggdgd
}|D ]*}|j|  |j| |jddd qfd S )NrG   rk   ro   r9   ZANDrf   r^   rg   r   rc   F)r6   emit)r?   rG   get_default_statusstatusr   r   r@   r   r   rl   rM   rf   rN   rO   )r   r   rQ   r
   r   rR   Z
open_tasksrH   r   r   r   release  s     
zCmfList.releasec                 C   s  dd l }| dddg g | _| jjdd| _| j d| _|   | dd	d
ddd	g d }|d k	r~tj	j
|ddddgd}t| j}d}t }| jD ]}z~|d7 }|d dkrtd| d| d |jdkr|j|  |jdd n*|r||jkr|j| |jdd W q tk
rv }	 z<tjd| d|  dd |	 d|  ||jj< W 5 d }	~	X Y qX q|rtddd | D td  d}| jD ]}z@|d7 }|d dkrtd!| d| d |jd"| d# W n\ tk
rP }	 z<tjd$| d|  dd |	 d|  ||jj< W 5 d }	~	X Y nX q|rxtdd%d | D td& tjjjD ]r}
d'd(| gd)d(|
gd*d+d"gg}tjj
|d,gd-gd.}d}d}|r|j}|j }tj| d"||dd |
d/}|  qd'd(| gd)d(d0gd*d+d"gg}tj!j
|d,gd-gd.}d}d}d}|rV|j}|j }|j"}tj!| d"|||dd d0d1}|  |rtd2 | #  td3 |S )4Nr   r   rG   favorite_forrk   r   u    (Закрыто)members.cache_status_typezmembers.listszmember.agile_story_pointsz$members.op_gantt_task.sched_duration members.op_gantt_task.sched_workkanban_status_columnskanban_status_columns.statuskanban_status_columns.work_listrJ   ru      zprocess_sprint_complete Move  of z members complete...FrX   u)   Ошибка переноса задчи : Tforcez: 
 
c                 S   s    g | ]\}}d | d| qS )u)   Ошибка преноса задачи r   r   r,   keyvalr   r   r   r.   K  s     z3CmfList.process_sprint_complete.<locals>.<listcomp>z)process_sprint_complete Move members donez%process_sprint_complete calc_history closedtask_list_operate	task_listu6   Ошибка записи истории задачи c                 S   s    g | ]\}}d | d| qS )u:   Ошибка подсчета истории задачи r   r   r   r   r   r   r.   Z  s     z)process_sprint_complete calc_history doner   r}   counter_typer   r   -cmf_created_atr   r   )r   r   estimate_sumremaining_sum
show_charttask_operater   duration)r   r   r   r   	spent_sumr   r   r   z%process_sprint_complete archive startz$process_sprint_complete archive done)$	tracebackr?   r   rG   r   r   r   r   r@   r   r   rz   r)   dictr:   r{   rg   Zclosed_listsrO   rF   	Exception
format_excr3   r<   CmfErrorjoinitemscalc_historyCmfListHistoryOTRr   choicesr   r   CmfListHistoryRTEr   archive)r   rQ   
do_archiver   rR   Zmembers_lenr-   errorsrI   er   _filterprev_sumr   r   historyr   r   r   r   process_sprint_complete#  s    
  



.

0

  
   

zCmfList.process_sprint_complete   u#   Завершение спринта)rs   r\   descriptionZshow_bg_progressbarc              
   K   st  dd l }tjj| dgd}z||| tjjdddgdd|jggddgd	}|r|jsrtjd
d|_|j	dd |g|j_
|jj
j	dd |}n|}d|j d}	d}
W n tk
r } z&t  tjj| dgd}d}	| }
W 5 d }~X Y nj tk
rV } zJt  tjj| dgd}d}	| d|  }
tjd|  dd W 5 d }~X Y nX tjj|||	|
ddd d S )Nr   r   rJ   Zreport_type=Zagile_sprint
tmp_filterztmp_filter.ft_sprintsrc   u/   Фильтр отчета по спринтам)r   FrX      Спринт "uX   " успешно завершен. Доступен отчет для просмотраu+   Создан отчет по спринтуu,   Ошибка закрытия спринтаr   u.   Ошибка закрытия спринта: Tr   ru   objZpersonr   r   Zforce_notify_current_personrs   )r   r@   r   r   r   ZCmfTaskReportr   r   ZCmfTaskFilterr   Z
ft_sprintsr   r   rollback_purge_eventr   r   r:   r{   	CmfNotifyplace_notify)list_idrQ   r   notify_person_idr|   r   r   Ztask_report
notify_objnotify_name
notify_msgr   r   r   r   sprint_complete_job  sJ    
*zCmfList.sprint_complete_jobc                 K   s   |  ddg | jdkr(tddd d S | jdkr>tddd tjjd	d
| ggddk rd| ||S td t| j	| j
j||tjj
jdd d }|d k	rtjj|ddddgd}|S d S )Nr"   rg   r   6   Это метод только для спринтовTrK   rj   uL   Завершить можно только запущенный СпринтrF   r^   rv   rx   u   Завершение спринта займет несколько минут. После окончания процесса, вы получите уведомление с отчетом.)r   rQ   r   r   r   r   r   r   r   rJ   )r?   r"   r   rg   r@   rl   rh   r   rB   r   r9   r<   r:   r;   r   r   )r   rQ   r   r|   rR   r   r   r   sprint_complete  s*    


zCmfList.sprint_completec                    s   |  ddddg | jdkr| jdks2tddd	 td
d | jD ]@}d}|jD ]}|| krP|jsPd} qlqP|rBd|_|jdd qBt	 j
|| | S )Nr"   r   zmembers.lists.cmf_archivedrg   r   rk   uT   Можно архивировать только завершенный спринтTrK   c                 S   s
   | j dkS )Nrk   )rg   )tr   r   r   <lambda>      z!CmfList.archive.<locals>.<lambda>Fr   )r?   r"   rg   r   rd   r)   rF   Zcmf_archivedr   r   r   )r   r
   r   rH   r   rm   r   r   r   r     s    


zCmfList.archivec                 C   sD  | j js| jjsdS | jjrt }| ddg | jrV| jjrV| jjD ]}|| qF| j D ]*}|jr\|jjr\|jjD ]}|| qvq\|D ]$}| jr| j	
| q| j	| qdS | j jr@| jr@t }| j jD ]d^}}}|dkrq|dg |jr"|jjr"|jjD ]}|| q|D ]}| j	
| q&qdS dS )up   
        Всем участникам задач добавляем список в избранное
        Nzmembers.responsible.person_varzcmf_owner.person_varrO   zresponsible.person_var)r)   r   r'   setr?   r/   
person_varaddZresponsibler   rO   rN   Z_changes)r   resultvrH   r   Zchange_actionZ
change_obj_r   r   r   r7     s:    
zCmfList._process_auto_favoritec              	   C   sH  |  dddddg t| j}d}| jD ]>}|d7 }|d dkrXtd	| d
| d |jd| d q(td tjjj	D ]R}d}d}tjj
| |dgdgd}|r|j}|j}tj| d||d|d}|  q|d}d}d}	tjj
| ddgdgd}
|
r|
j}|
j}|
j}	tj| d||d|	dd}|  | jjdd| _|   d S )Nr   rG   zmembers.agile_story_pointsz1members.listsmembers.op_gantt_task.sched_durationr   r   ru   r   z"process_sprint_start calc_history r   z tasks complete ...startedr   z&process_sprint_start calc_history doner   r   )r   r   r   r2   T)r   r   r   r   r   r   r   )r   r   r   r   r   r   r   rj   r   )r?   rz   r)   r:   r{   r   r@   r   r   r   r   r   r   r   r   r   rG   r   r   )r   Znumber_tasksZ
task_countrH   r   r   r   r   r   r   Zprev_rte_historyZrte_historyr   r   r   process_sprint_start  s^    



 
  

 
  zCmfList.process_sprint_startu   Запуск спринтаc              
   C   s   t jj| d}z*|  |}d}d|j d|j d}W nD tk
r| } z&t  t jj| dgd}d}| }W 5 d }~X Y nX t jj	||||d	d
d d S )Nr   u   Спринт запущенr   z" (u   ) запущенr   rJ   u*   Ошибка запуска спринтаTru   r   )
r@   r   r   r   r   r3   r   r   r   r   )r   r   r   r   r   r   r   r   r   r   sprint_start_job-  s&    zCmfList.sprint_start_jobc                 C   s   |  dg | jdkr&tddd dS tjj| drDtddd dS tjjd	d
| ggddk rh|   n&td t| j	| j
jtjj
jdd | S )u-   
        Запуск спринта
        r"   r   r   TrK   N)r   uG   Спринт уже был запущен! Создайте новый.rF   r^   rv   rx   un   Запуск спринта займет несколько минут, ожидайте оповещения.)r   r   r   )r?   r"   r   r@   r   rh   rl   r   rB   r   r9   r<   r:   r;   r   r   r   r   do_startH  s    

zCmfList.do_startc                 C   s   d| j  d| j d| j S )Nry   )Z	ui_moduler#   r3   r   r   r   r   hrefa  s    zCmfList.hrefrte-changed)task_idtimetracker_history_idr   c                 K   s  dd }|  ddg | jdksB| jdksB| jjr>| jjdksBdS |dkrtjjd	| jj	d
gddgd}tjdd||| d	|||d	}|r|j
|_
|j|_| j
|jpd7  _
|j|_| j|jpd7  _|  n|dkr|tjjdd| jj	gdd|gddd	ggd
gdgd}tj| |||j|j
|j
|j|j|jdd	ddd}tjjddidd|gdd| jj	gddd	ggd |  n|dkrtjjd	| d
gddgd}tjdd||| d	||||d
}|r|j
|_
|j|_|j|_| j
|jpd7  _
|j|_tjjdd|gdd| gddd gddd	ggd!gdgd}|D ]}| j|j7  _|j|_q4|j|j |_| j|jprd7  _tjjddidd|gdd| gddd	ggd |  n|d"krtjjd	| d
gddgd}tjdd||| d	||||d
}|r|j
|_
|j|_|j|_tjjdd|gdd| gddd gddd	ggd!gdgd}|D ]}| j|j7  _|j|_qJ| j
|jpzd8  _
|j|_|j|j |_| j|jpd8  _tjjddidd|gdd| gddd	ggd |  n|r|d krddd	gdd| gd!d#|gg}tjj|d
gdgd}|dd|g tjj|d
gdgd}d}|rtjj|ddgd$}|stjdd||| ||d	d%}||_||_|j| |_|j|_|j
|j |_
||_|j|_||_|j| |_tjjddidd|gdd| gddd	ggd |  ntjjdd| gdd|gddd	ggddgd!gd&}|r|jrn|j|krh| j|8  _nd|_|j
r|j
|kr| j
|8  _
nd|_
| j|8  _||_| j|7  _|  |r|| n|d'krptjjd	| d
gdgd}tjdd||| |d	d(}|j
|_
|j|_|j|_||_||_||_tjjddidd|gdd| gddd	ggd |  n*|d)krtjjd	| d
gdgd}tjjd	| |d
gdgd*}tjdd||| |d	d(}||_|j|jkr|j|j |j |_|j
|j |_
|j|j |_|j|j |_n>|j|j |j |_|j
|j |_
|j|j |_|j|j |_|j|_|j|_tjjddidd|gdd| gddd	ggd |  dS )+zDhttps://bcrm.carbonsoft.ru/project/Document/DOC-011865#spec-011844-bc                 S   s   | }t jjdd|jgdd|jgdd|jgdddggdgd	dgd
D ]}|j|j |_|j|j	 |j
 |_|j|j |j |_|j| jkr| j|_| j|j	 |j
 |_| j|j |j |_|} |  |}qBd S )Nr~   >r   r}   r9   r   r   r   r   r   )r@   r   rM   r~   r   r9   r   estimate_valuer   	spent_inc	spent_decr   rem_increm_decr   spent_valueremaining_valuer   )Ztask_historyprev_historyr   r   r   r   recalc_historyi  s&    

 
z/CmfList.history_rte_add.<locals>.recalc_historyr"   rg   r   rj   Nr   r   r   r   r   )r   task_list_idr   r2   FT)	r   currentr   rH   r   r   r   r   r   r   r   r   r}   r   r   r   )r   rH   r   r   r   r   r   r   r   r   r   r   r   r   r=   rd   rO   )r   r   r   r2   )
r   r   r   rH   r   r   r   r   r   r   rH   r   zwork-loggedr~   rN   <)timetracker_historyr2   )r   r   r   rH   r   r   r   r   )rd   r2   r   zstate-change)r   r   r   rH   r   r   r   z
rte-change)r   r   rH   r   r2   )r?   r"   rg   r   oldr@   r   sgetr9   r<   r   r   r   r   r   r   r   r   bulk_updater   rM   r   r   r   rO   r~   )r   r   r   r   r   estimate_durationZremaining_durationZspent_durationestimate_workZremaining_workZ
spent_workZhistory_dater   r   r   r   Zprev_histories_taskphr   Zprev_history_taskZprev_history_sumr   r   r   history_rte_adde  s    

  
    

   
       

  

    zCmfList.history_rte_addchangedri   )r   r   c	                    s>   fdd}	 fdd}
 fdd} fdd} fd	d
} fdd} fdd}  ddg  jdks jdks jjr jjdksdS dkr܈dkr|dk	r|	d| |dk	r|	d| |dk	r|	d| |dk	r|	d| ndkrP|
d| |
d| |
d| |
d| ndkr|d| |d| |d| |d| nVdkr|d |d |d |d n*dkr:|d |d |d |d n^dkr|d| |d| |d| |d| n*dkr:|d |d |d |d dS ) u  https://bcrm.carbonsoft.ru/project/Document/DOC-011865#spec-011844-b

        Args:
            task_id (str): ид задачи
            task_operate (str): Операция по задаче
            estimate_sp (_type_, optional): _description_. Defaults to None.
            remaining_sp (_type_, optional): _description_. Defaults to None.
            spent_sp (_type_, optional): _description_. Defaults to None.
            estimate_duration (_type_, optional): _description_. Defaults to None.
            remaining_duration (_type_, optional): _description_. Defaults to None.
            spent_duration (_type_, optional): _description_. Defaults to None.
            estimate_work (_type_, optional): _description_. Defaults to None.
            remaining_work (_type_, optional): _description_. Defaults to None.
            spent_work (_type_, optional): _description_. Defaults to None.
            estimate_count (_type_, optional): _description_. Defaults to None.
            remaining_count (_type_, optional): _description_. Defaults to None.
            spent_count (_type_, optional): _description_. Defaults to None.
        c              
      sP  t jjdd gddgdd| ggdgdgd}t jjdd gdd| ggdgdgd}t j || dd	kd
}|r|j|_|j|_|j|jkr|j|j }d	kr||_| j|j7  _| j|7  _|j|jk r|j|j }d	kr||_| j|j8  _| j|8  _t jjddidd gddgdd| gdddggd |	  d S )Nr   r}   rH   r   r   r   r   Trk   r   rH   r   r   r<   r   r   r   r   Fr   )
r@   r   r   r   r   r<   r   r   r   r   )r   r<   r   cur_sum_historyr   Zdeltar   ro   r   r   r   r   r   change_historye  sZ       z/CmfList.history_otr_add.<locals>.change_historyc              	      s   t jjdd gdd| ggdgdgd}t j | ddkd	}|rL||_|r`|j|_|j|_dkrp|j|_| j|j7  _| j|j7  _t jjd
didd gddgdd| gd
ddggd |  d S )Nr   r}   r   r   r   r   Trk   )r   rH   r   r   r   r   r   r   FrH   r   	r@   r   r   r<   r   r   r   r   r   r   r<   r   r   r   r   r   append_history  s>      z/CmfList.history_otr_add.<locals>.append_historyc                    s   t jjdd jjgdd| ggdgdgd}t j | ddd	}|rJ||_|r^|j|_|j|_d
krn|j|_| j|j7  _| j|j7  _t jjddidd jjgddgdd| gdddggd |	  d S )Nr   r}   r   r   r   r   TF)r   rH   r   r   r   r   rk   r   r   r   )
r@   r   r   r9   r<   r   r   r   r   r   r   )r   ro   r   r   r   r   start_sprint  s<      z-CmfList.history_otr_add.<locals>.start_sprintc              
      s   t jjdd gddgdd| ggdgdgd}t jjdd gdd| ggdgdgd}t j || ddd	}|r|j|_|j|_|j|_| j|j8  _| j|j8  _t jjd
didd gddgdd| gd
ddggd |  d S )Nr   r}   rH   r   r   r   r   Tr   r   Fr   )	r@   r   r   r   r   r   r   r   r   )r   r<   r   r   r   r   r   r   r   r   r   remove_history  sH       z/CmfList.history_otr_add.<locals>.remove_historyc              
      s   t jjdd jjgddgdd| ggdgdgd}t j |jd | dd	d
}t jjddidd jjgddgdd| gddd	ggd |  d S )Nr   r}   r   r   r   r   r   FT)r   rH   r   r   r   r   r   r   r   r   )r@   r   r   r9   r<   r   r   )r   r   r   )r   r   r   r   r   close_sprint  s0        z-CmfList.history_otr_add.<locals>.close_sprintc              
      s   t jjdd gddgdd| ggdgdgd}t jjdd gdd| ggdgdgd}t j |j| ddd	}|r|j|_|j|_|j|_| j|j8  _t jjd
didd gddgdd| gd
ddggd |  d S Nr   r}   rH   r   r   r   r   T)r   rH   r   r   r<   r   r   r   r   Fr   )	r@   r   r   r<   r   r   r   r   r   r   r   r   r   r   r   r   close_history  sF         z.CmfList.history_otr_add.<locals>.close_historyc              
      s   t jjdd gddgdd| ggdgdgd}t jjdd gdd| ggdgdgd}t j |j| ddd	}|r|j|_|j|_|j|_| j|j7  _t jjd
didd gddgdd| gd
ddggd |  d S r   r   r   r   r   r   unclose_history  sF         z0CmfList.history_otr_add.<locals>.unclose_historyr"   rg   r   rj   Nr   Zchangezstory-pointr   Zworkrh   rO   rN   closeZuncloser   r   )r?   r"   rg   r   r   )r   r   r   r   Zestimate_spr   r   Zestimate_countro   r   r   r   r   r   r  r  r   r   r   history_otr_addQ  sp    (

























zCmfList.history_otr_add)NF)r   NNNNNNN)r   NNNNri   )#__name__
__module____qualname__classmethodr   r   r   r%   r(   r*   r   rS   r>   rP   rZ   staticmethodZcmf_deferred_jobrp   rC   r   r   r   r   r   r   r7   r   r   r   propertyr   strr   r  __classcell__r   r   r   r   r      sd   L
\-
',
              m      r   N)Zcmf.includeZmodules.project.fieldsr   Zcommon.models.cmf_active_entityr   r   r   r   r   r   <module>   s   