Browse Source

Add alternancia de editores com frontEnd bootstrap

pull/590/head
LeandroRoberto 8 years ago
parent
commit
b1c0ce945c
  1. 6
      sapl/compilacao/views.py
  2. 38
      sapl/static/js/compilacao_edit.js
  3. 5
      sapl/static/styles/app.scss
  4. 54
      sapl/static/styles/compilacao.scss
  5. 27
      sapl/templates/compilacao/ajax_actions_dinamic_edit.html
  6. 4
      sapl/templates/compilacao/text_edit_bloco.html

6
sapl/compilacao/views.py

@ -2894,13 +2894,15 @@ class TextNotificacoesView(CompMixin, ListView, FormView):
_('Dispositivo está substituindo um Dispositivo de outro ' _('Dispositivo está substituindo um Dispositivo de outro '
'Texto Articulado.')) 'Texto Articulado.'))
padd(r, type_notificacao, 'compilacao:dispositivo_edit_alteracao', padd(r, type_notificacao,
'sapl.compilacao:dispositivo_edit_alteracao',
r.dispositivo_substituido and r.dispositivo_substituido and
r.dispositivo_substituido.dispositivo_subsequente != r, r.dispositivo_substituido.dispositivo_subsequente != r,
_('Dispositivo está substituindo um Dispositivo que não ' _('Dispositivo está substituindo um Dispositivo que não '
'possui este como seu Dispositivo Subsequente.')) 'possui este como seu Dispositivo Subsequente.'))
padd(r, type_notificacao, 'compilacao:dispositivo_edit_alteracao', padd(r, type_notificacao,
'sapl.compilacao:dispositivo_edit_alteracao',
r.dispositivo_subsequente and r.dispositivo_subsequente and
r.dispositivo_subsequente.dispositivo_substituido != r, r.dispositivo_subsequente.dispositivo_substituido != r,
_('Dispositivo foi substituído por outro que não ' _('Dispositivo foi substituído por outro que não '

38
sapl/static/js/compilacao_edit.js

@ -15,7 +15,17 @@ function DispositivoEdit() {
return instance; return instance;
}; };
instance.bindActionClick = function(event) { instance.bindActionsEditorType = function(event) {
editortype = this.getAttribute('editortype');
SetCookie("editortype", editortype, 30);
var dpt = $(this).closest('.dpt');
var pk = dpt.attr('pk');
instance.clearEditSelected();
instance.triggerBtnDptEdit(pk);
}
instance.bindActionsClick = function(event) {
var pk = this.getAttribute('pk'); var pk = this.getAttribute('pk');
var form_data = { var form_data = {
@ -68,7 +78,6 @@ function DispositivoEdit() {
instance.clearEditSelected(); instance.clearEditSelected();
instance.loadActionsEdit(dpt); instance.loadActionsEdit(dpt);
dpt.on('get_form_base', function () { dpt.on('get_form_base', function () {
var _this = $(this); var _this = $(this);
_this.addClass('dpt-selected'); _this.addClass('dpt-selected');
@ -83,7 +92,7 @@ function DispositivoEdit() {
var btns_excluir = _this.find('.btns-excluir'); var btns_excluir = _this.find('.btns-excluir');
_this.find('.dpt-actions-bottom').last().append(btns_excluir); _this.find('.dpt-actions-bottom').last().append(btns_excluir);
btns_excluir.find('.btn-excluir').on('click', instance.bindActionClick); btns_excluir.find('.btn-excluir').on('click', instance.bindActionsClick);
}); });
instance.loadForm(dpt, 'get_form_base'); instance.loadForm(dpt, 'get_form_base');
} }
@ -93,23 +102,27 @@ function DispositivoEdit() {
var url = pk+'/refresh?action=get_actions'; var url = pk+'/refresh?action=get_actions';
$.get(url).done(function(data) { $.get(url).done(function(data) {
dpt.find('.dpt-actions').first().html(data); dpt.find('.dpt-actions').first().html(data);
dpt.find('.btn-inserts').on('click', instance.bindActionClick); dpt.find('.btn-inserts').on('click', instance.bindActionsClick);
dpt.find('.btn-editor-type').on('click', instance.bindActionsEditorType);
if (editortype == 'construct')
dpt.find('.btn-group-inserts').first().addClass('open');
}); });
} }
instance.loadForm = function(dpt, trigger) { instance.loadForm = function(dpt, trigger) {
var pk = dpt.attr('pk'); var pk = dpt.attr('pk');
if (editortype == "construct")
return;
var dpt_form = dpt.children().filter('.dpt-form'); var dpt_form = dpt.children().filter('.dpt-form');
if (dpt_form.length == 1) { if (dpt_form.length == 1) {
var url = pk+'/refresh?action='+trigger; var url = pk+'/refresh?action='+trigger;
$.get(url).done(function(data) { $.get(url).done(function(data) {
dpt_form.html(data); if (editortype != "construct") {
dpt_form.find('form').submit(instance.onSubmitEditFormBase); dpt_form.html(data);
if (editortype == 'tinymce' ) { dpt_form.find('form').submit(instance.onSubmitEditFormBase);
initTinymce(); if (editortype == 'tinymce' ) {
initTinymce();
}
} }
dpt.trigger(trigger); dpt.trigger(trigger);
}).always(function() { }).always(function() {
@ -230,6 +243,7 @@ function DispositivoEdit() {
var dpt = $('#id'+pk).closest('.dpt'); var dpt = $('#id'+pk).closest('.dpt');
dpt = $('#'+dpt.replaceWith(data).attr('id')); dpt = $('#'+dpt.replaceWith(data).attr('id'));
instance.onClicks(dpt); instance.onClicks(dpt);
instance.reloadFunctionsDraggables();
if (trigger_edit_pk > 0) if (trigger_edit_pk > 0)
instance.triggerBtnDptEdit(trigger_edit_pk) instance.triggerBtnDptEdit(trigger_edit_pk)
@ -320,7 +334,7 @@ function DispositivoEdit() {
editortype = "textarea" editortype = "textarea"
SetCookie("editortype", editortype, 30) SetCookie("editortype", editortype, 30)
} }
editortype = "textarea"; //editortype = "textarea";
instance.offClicks(); instance.offClicks();
instance.onClicks(); instance.onClicks();
instance.reloadFunctionsDraggables(); instance.reloadFunctionsDraggables();

5
sapl/static/styles/app.scss

@ -145,11 +145,6 @@ fieldset {
} }
} }
} }
.btn-primary, .btn-danger{
font-size: 16px;
height: 40px !important;
display: inline-block;
}
/* INDEX */ /* INDEX */
#conteudo { #conteudo {

54
sapl/static/styles/compilacao.scss

@ -529,12 +529,20 @@ a:link:after, a:visited:after {
right: 0px; right: 0px;
z-index: 3; z-index: 3;
opacity: 0; opacity: 0;
.activate {
display:none;
}
.deactivate {
display:inline;
}
} }
& > .dpt-actions, & > .dpt-actions-bottom { & > .dpt-actions, & > .dpt-actions-bottom {
display: none; display: none;
} }
& > .dpt-text { & > .dpt-text {
cursor: pointer; cursor: pointer;
min-height: 31px;
&:hover { &:hover {
color: $color_buttons; color: $color_buttons;
transition: color 0.3s ease; transition: color 0.3s ease;
@ -550,6 +558,7 @@ a:link:after, a:visited:after {
} }
&:hover { &:hover {
background-color: rgba(0, 0, 0, 0.01);
& > .dpt-actions-fixed { & > .dpt-actions-fixed {
opacity: 1; opacity: 1;
} }
@ -610,10 +619,11 @@ a:link:after, a:visited:after {
} }
.dpt-selected { .dpt-selected {
&.dpt { &.dpt {
margin: -0.2em -0.5em; margin: 0em -0.5em;
} }
} }
} /* fim dpt-alts */ } /* fim dpt-alts */
.dpt-selected { .dpt-selected {
&.dpt { &.dpt {
width: auto !important; width: auto !important;
@ -699,21 +709,34 @@ a:link:after, a:visited:after {
.dpt { .dpt {
box-shadow: 0 0 0; box-shadow: 0 0 0;
} }
} }
& > .dpt-actions-fixed { & > .dpt-actions-fixed {
display: none; opacity: 1;
margin-top: -1em;
margin-right: -0.5em;
.activate {
display:inline;
}
.deactivate {
display:none;
}
.btn-dpt-edit {
background-color: #02baf2;
color: white;
border: 0;
font-weight: bold;
}
} }
.dropdown-menu { .dropdown-menu {
right: auto !important; &.dropdown-menu-left {
left: 0; right: auto !important;
padding: 2px 0; left: 0;
& > .top.arrow { padding: 2px 0;
right: 88%; & > .top.arrow {
left: auto; right: 88%;
left: auto;
}
} }
li { li {
a { a {
@ -723,11 +746,16 @@ a:link:after, a:visited:after {
} }
} }
} }
.btn-group {
.radius-right {
border-bottom-right-radius: 4px !important;
border-top-right-radius: 4px !important;
}
}
&:hover { &:hover {
.dpt-actions-fixed { .dpt-actions-fixed {
margin-top: 1em;
margin-right: 1em;
} }
} }

27
sapl/templates/compilacao/ajax_actions_dinamic_edit.html

@ -1,19 +1,19 @@
{% load i18n %} {% load i18n %}
<div class="btn-group" role="group"> <div class="btn-group dropdown" role="group">
{% if object.dispositivo_subsequente == None %} {% if object.dispositivo_subsequente == None %}
{% for inserts in allowed_inserts %} {% for inserts in allowed_inserts %}
{% if inserts.itens %} {% if inserts.itens %}
<div class="btn-group" role="group"> <div class="btn-group btn-group-inserts" role="group">
<button type="button" class="btn btn-primary btn-sm dropdown-toggle" data-toggle="dropdown" aria-haspopup="true" aria-expanded="true"> <button type="button" class="btn btn-primary btn-sm dropdown-toggle" data-toggle="dropdown" aria-haspopup="true" aria-expanded="true">
{{inserts.icone|safe}}<span>{{inserts.tipo_insert}}</span> {{inserts.icone|safe}}<span>{{inserts.tipo_insert}}</span>
</button> </button>
<ul class="dropdown-menu"> <ul class="dropdown-menu dropdown-menu-left">
<div class="arrow top"></div> <div class="arrow top"></div>
{% for item in inserts.itens %} {% for item in inserts.itens %}
<li><a class="btn-inserts btn-action" action="{{inserts.action}}" pk="{{item.dispositivo_base}}" variacao="{{item.variacao}}" tipo_pk="{{item.tipo_pk}}">{{item.provavel|safe}}</a></li> <li><a class="btn-inserts btn-action " action="{{inserts.action}}" pk="{{item.dispositivo_base}}" variacao="{{item.variacao}}" tipo_pk="{{item.tipo_pk}}">{{item.provavel|safe}}</a></li>
{% endfor %} {% endfor %}
</ul> </ul>
</div> </div>
@ -21,3 +21,22 @@
{% endfor %} {% endfor %}
{%endif%} {%endif%}
</div> </div>
<div class="btn-toolbar pull-right" role="toolbar" >
<div class="btn-group " role="group">
<button type="button" class="btn btn-primary btn-sm radius-right" data-toggle="dropdown" aria-haspopup="true" aria-expanded="true">
<i class="fa fa-edit fa-lg"></i>
</button>
<ul class="dropdown-menu">
<div class="arrow top"></div>
<li><a class="btn-editor-type" editortype="construct">Construtor</a></li>
<li><a class="btn-editor-type" editortype="textarea">Editor Simples</a></li>
<li><a class="btn-editor-type" editortype="tinymce">Editor tinymce</a></li>
<li><a class="btn-editor-avancado" href="{% url 'sapl.compilacao:dispositivo_edit' object.ta_id object.pk %}" >Editor Avançado</a></li>
</ul>
</div>
</div>

4
sapl/templates/compilacao/text_edit_bloco.html

@ -5,11 +5,11 @@
{% dispositivotree dispositivos_list %} {% dispositivotree dispositivos_list %}
<div class="dpt" id="id{{node.dpt.id}}" pk="{{node.dpt.pk}}" ordem="{{node.dpt.ordem}}" name="{{node.dpt.pk}}" title="{{node.dpt.pk}} - {{node.dpt.ordem}}"> <div class="dpt" id="id{{node.dpt.id}}" pk="{{node.dpt.pk}}" ordem="{{node.dpt.ordem}}" name="{{node.dpt.pk}}" title="{{node.dpt.pk}} - {{node.dpt.ordem}}">
<div class="dpt-actions-fixed btn-group"> <div class="dpt-actions-fixed btn-group">
<a class="btn-action btn-dpt-edit btn btn-default btn-sm" pk="{{node.dpt.pk}}"><span class="deactivate">{% trans 'Editar'%}</span><span class="activate">{% trans 'Em Edição'%}</span> {{ node.td.nome }} {{ node.dpt.rotulo }}</a>
{% if not node.dpt.rotulo and not node.dpt.texto and node.td.dispositivo_de_articulacao%} {% if not node.dpt.rotulo and not node.dpt.texto and node.td.dispositivo_de_articulacao%}
<a class="btn-action btn-dpt-edit btn btn-primary btn-sm" pk="{{node.dpt.pk}}">{% trans 'Editar'%} {{ node.td.nome }} {{ node.dpt.rotulo }}</a>
{% endif %} {% endif %}
</div> </div>
<div class="dpt-actions btn-group"></div> <div class="dpt-actions"></div>
<div class="dpt-text {{node.td.class_css}} {%if node.dpt.fim_vigencia %}desativado{%endif%} {%if node.dpt.rotulo or node.dpt.texto or not node.td.dispositivo_de_articulacao %}btn-dpt-edit{%endif%}" title="{% trans 'Editar' %} {{node.td.nome}}"> <div class="dpt-text {{node.td.class_css}} {%if node.dpt.fim_vigencia %}desativado{%endif%} {%if node.dpt.rotulo or node.dpt.texto or not node.td.dispositivo_de_articulacao %}btn-dpt-edit{%endif%}" title="{% trans 'Editar' %} {{node.td.nome}}">
{{ node.td.rotulo_prefixo_html|safe }} {{ node.td.rotulo_prefixo_html|safe }}

Loading…
Cancel
Save