mirror of https://github.com/interlegis/sapl.git
				
				
			
			You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							196 lines
						
					
					
						
							6.2 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							196 lines
						
					
					
						
							6.2 KiB
						
					
					
				| {% extends "base.html" %} | |
| {% load i18n %} | |
| {% load compilacao_filters %} | |
| 
 | |
| {% block title%} | |
|   <h1><b>Edição:</b> {{ view.get_norma }} - <i>Texto Multivigente</i></h1> | |
| {% endblock %} | |
| 
 | |
| {% block base_content %}   | |
| 
 | |
| <script type="text/javascript"> | |
| 
 | |
| $(document).ready(function() { | |
| 
 | |
|     var flag_add_next = false | |
|     var flag_add_next_pk = 0 | |
|     var flag_add_next_pai = 0 | |
|      | |
|     var withTinymce = false | |
| 
 | |
|     clickEditDispositivo = function(event) {  | |
|         var _pk = event.currentTarget.getAttribute('pk'); | |
|          | |
|         if ($('#de'+_pk).hasClass("editselected")) { | |
|             clearEditSelected(); | |
|             return; | |
|         } | |
|         clearEditSelected(); | |
|         clickUpdateDispositivo(event) | |
|     } | |
| 
 | |
|     clickUpdateDispositivo = function(event, __pk, __action, addeditselected) { | |
| 
 | |
|         var _pk = __pk; | |
|         var _action = __action; | |
|         var _variacao = ''; | |
|         var _tipo_pk = ''; | |
| 
 | |
|         if (event != null) { | |
|             _pk = event.currentTarget.getAttribute('pk'); | |
|             _action = $(this).attr('action'); | |
|             _variacao = $(this).attr('variacao'); | |
|             _tipo_pk = $(this).attr('tipo_pk'); | |
|         } | |
|          | |
|         if (flag_add_next_pk == 0) | |
|             flag_add_next_pk = _pk | |
| 
 | |
|         var url = '' | |
|         if (_action == '') | |
|             return | |
|         else if ( _action == null || _action.startsWith('refresh')) { | |
|               | |
|             if (_action != null && _action.endsWith('tinymce')) | |
|                withTinymce = true; | |
|             else if (_action != null && _action.endsWith('textarea')) | |
|                withTinymce = false; | |
|              | |
|             url = _pk+'/refresh?pkadd='+flag_add_next_pk+url; | |
|              | |
|             } | |
|         else { | |
|             url = _pk+'/actions?action='+_action; | |
|             url += '&tipo_pk='+_tipo_pk; | |
|             url += '&variacao='+_variacao; | |
|             if (addeditselected == null || addeditselected) { | |
|                 $("#message_block").css("display", "block"); | |
|             } | |
|         } | |
| 
 | |
|         $.get(url).done(function( data ) { | |
| 
 | |
|             if ( _action == null || _action.startsWith('refresh')) { | |
|              | |
|                 if (addeditselected) | |
|                     clearEditSelected(); | |
| 
 | |
|                 if (flag_add_next) { | |
|                     $( '#de' + _pk ).html( data); | |
|                     flag_add_next = false | |
|                 }  | |
|                 else { | |
|                     clearEditSelected(); | |
|                     $( '#de' + _pk ).prepend( data ); | |
|                 } | |
|                 reloadFunctionClicks(); | |
| 
 | |
|                 if ( withTinymce ) | |
|                     tinymce.init({  | |
|                         mode : "textareas",  | |
|                         force_br_newlines : false, | |
|                         force_p_newlines : false, | |
|                         forced_root_block : '', | |
|                         plugins: "table", | |
|                         tools: "inserttable",  | |
|                     }); | |
| 
 | |
|                 if (addeditselected == null || addeditselected) { | |
|                     $('#de'+flag_add_next_pk).addClass('editselected'); | |
|                     $('html, body').animate({ | |
|                         scrollTop: $('#de' + flag_add_next_pk ).offset().top - window.innerHeight / 10  | |
|                         }, 300); | |
|                     flag_add_next_pk = 0; | |
|                 } | |
|             } | |
| 
 | |
|             else if (_action == 'add_next') { | |
| 
 | |
|                 clearEditSelected(); | |
| 
 | |
|                 flag_add_next_pk = data.pk; | |
|                 flag_add_next_pai = data.pai; | |
|                  | |
|                 if (flag_add_next_pk != null) | |
|                     for (var pai = 0; pai < flag_add_next_pai.length; pai++) | |
|                          if (flag_add_next_pai[pai] != -1) { | |
|                               flag_add_next = true; | |
|                               flag_add_next_pk = data.pk; | |
|                               clickUpdateDispositivo(null, flag_add_next_pai[pai], 'refresh', pai == 0); | |
|                          } | |
|                          else { | |
|                              href = location.href.split('#')[0] | |
|                              location.href = href+'#'+flag_add_next_pk | |
|                              location.reload(true) | |
|                          } | |
|                 else { | |
|                     alert('Erro na inserção!'); | |
|                     flag_add_next_pk = 0; | |
|                     flag_add_next = false; | |
|                     } | |
|             } | |
|         }).always(function() { | |
|             $("#message_block").css("display", "none"); | |
|         }); | |
|     } | |
| 
 | |
| 
 | |
| function clearEditSelected() { | |
|     tinymce.remove(); | |
|     $('.editselected').removeClass('editselected'); | |
|     $('.editdi_form').remove(); | |
|     $('.editselected .label_pai, .edit .label_pai').remove(); | |
|     $('.editselected .actions_head, .edit .actions_head').remove(); | |
|     $('.editselected .actions_footer, .edit .actions_footer').remove(); | |
| } | |
| 
 | |
| function reloadFunctionClicks() {  | |
|     $('.dispositivo .edit .di').off(); | |
|     $('.actions .btn-action').off(); | |
|     $('.actions_head .btn-action').off(); | |
|     $('.dispositivo .edit .di').on('click', clickEditDispositivo); | |
|     $('.actions .btn-action').on('click', clickEditDispositivo); | |
|     $('.actions_head .btn-action').on('click', clickUpdateDispositivo); | |
| 
 | |
|     $('.editdi_form form').submit(function(event) { | |
|         var texto = '' | |
|         var editorTiny = tinymce.get('editdi_texto') | |
| 
 | |
|         if (editorTiny != null) | |
|            texto = editorTiny.getContent(); | |
|         else | |
|            texto = $('#editdi_texto').val(); | |
| 
 | |
|         var formData = { | |
|             'csrfmiddlewaretoken' : $('input[name=csrfmiddlewaretoken]').val(), | |
|             'texto'               : texto | |
|         }; | |
|         var $form = $( this ), | |
|         url = $form.attr( "action" ); | |
|         $("#message_block").css("display", "block"); | |
|         $.post(url,formData) | |
|             .done(function(data) { | |
|                 $('.editselected').html(data); | |
|                 clearEditSelected(); | |
|                 reloadFunctionClicks(); | |
| 
 | |
|             }).always(function() { | |
|                 $("#message_block").css("display", "none"); | |
|             }); | |
|         event.preventDefault(); | |
|     }); | |
| } | |
| 
 | |
| reloadFunctionClicks(); | |
| $("#message_block").css("display", "none"); | |
| 
 | |
| }); | |
| 
 | |
| 
 | |
| </script> | |
| <div id="message_block"><div id="msg">Aguarde... Atualizando informações!!!</div></div> | |
| <div class="compilacaoedit"> | |
|     {% include 'compilacao/edit_bloco.html'%} | |
| </div> | |
| {% endblock base_content %} | |
| 
 | |
| 
 |