diff --git a/sigi/apps/ocorrencias/static/ocorrencias/css/painel_ocorrencias.css b/sigi/apps/ocorrencias/static/ocorrencias/css/painel_ocorrencias.css index 6e57638..678137d 100644 --- a/sigi/apps/ocorrencias/static/ocorrencias/css/painel_ocorrencias.css +++ b/sigi/apps/ocorrencias/static/ocorrencias/css/painel_ocorrencias.css @@ -1,14 +1,11 @@ -#content { - display: block; -} - .user-image { width: 64px; height: 64px; font-size: 64px !important; + display: block; } -commenter-image { +.user-image-sm { width: 32px; height: 32px; font-size: 32px !important; @@ -17,53 +14,4 @@ commenter-image { .card-details, .user-name { font-size: 10px; -} - -.priority { - background-color: grey; -} - -.priority { - background-color: antiquewhite; - margin-left: 5px; - min-width: 60px; -} - -.chip>img { - float: left; - margin: 0 8px 0 -12px; - height: 32px; - width: 32px; - border-radius: 50%; -} - -.span-list { - padding: 2px 6px; - margin-left: 4px; - background-color: var(--selected-bg); - line-height: 24px; - border-radius: 12px; - white-space: nowrap; -} - -.card-inbox { - width: 100%; - border: 1px solid var(--hairline-color); - padding: 12px; - border-radius: 12px; -} - -.card-inbox p { - margin-bottom: 6px !important; -} - -.inbox-title { - font-weight: bold; - text-transform: uppercase; - font-size: smaller; -} - -.strong { - font-weight: 800; - text-transform: uppercase; } \ No newline at end of file diff --git a/sigi/apps/ocorrencias/templates/ocorrencias/painel.html b/sigi/apps/ocorrencias/templates/ocorrencias/painel.html new file mode 100644 index 0000000..1b7799c --- /dev/null +++ b/sigi/apps/ocorrencias/templates/ocorrencias/painel.html @@ -0,0 +1,102 @@ +{% extends "admin/base_site.html" %} +{% load i18n static admin_urls djbs_extras %} + +{% block extrastyle %} + {{ block.super }} + +{% endblock %} + +{% block content_title %} +

{{ panel_title }}

+{% endblock content_title %} + +{% block content_subtitle %} + {% if panel_subtitles %} +
+
+
{% trans "Filtros aplicados:" %}
+
+ {% for subt in panel_subtitles %} + {{ subt }} + {% endfor %} +
+
+
+ {% endif %} +{% endblock %} + +{% block search %} + +{% endblock %} + +{% block object-tools %} + {% if has_add_permission %} + + {% icon 'add' %} {% translate "Nova Ocorrência" %} + + {% endif %} +{% endblock %} + +{% block breadcrumbs %} + + +{% endblock %} + +{% block content %} + {% block ocorrencia_cards %} + {% for ocorrencia in ocorrencias %} + {% include 'ocorrencias/painel_snippet.html' %} + {% endfor %} + {% endblock ocorrencia_cards %} + + {% block paginator %} + {% if is_paginated %} + + {% endif %} + {% endblock paginator %} +{% endblock %} + +{% block sidebar-title %}{% translate 'Filter' %}{% endblock sidebar-title %} + +{% block sidebar-body %} +
+ +
+ {{ filter.form }} + +
+
+{% endblock %} + +{% block footer %} + {{ block.super }} + +{% endblock %} \ No newline at end of file diff --git a/sigi/apps/ocorrencias/templates/ocorrencias/painel_snippet.html b/sigi/apps/ocorrencias/templates/ocorrencias/painel_snippet.html new file mode 100644 index 0000000..fb09465 --- /dev/null +++ b/sigi/apps/ocorrencias/templates/ocorrencias/painel_snippet.html @@ -0,0 +1,169 @@ +{% load i18n djbs_extras %} + +
+
+ {% block edit_link %} + {% if user.is_staff %} + {% if has_change_permission %} + {% icon "edit" %} + {% endif %} + {{ ocorrencia.casa_legislativa.nome }}, {{ ocorrencia.casa_legislativa.municipio.uf.sigla }} + {% else %} + {{ ocorrencia.assunto }} + {% endif %} + {% endblock edit_link %} +

+ {% blocktrans with data_criacao=ocorrencia.data_criacao|date:"SHORT_DATE_FORMAT" tipo_contato=ocorrencia.tipo_contato categoria=ocorrencia.categoria status=ocorrencia.get_status_display prioridade=ocorrencia.get_prioridade_display %} + Criado em {{ data_criacao }} via {{ tipo_contato }} solicitando {{ categoria }}, com status {{ status }}. Prioridade: {{ prioridade }} + {% endblocktrans %} +

+
+
+
+
+ {% if ocorrencia.servidor_registro.foto %} + + {% else %} + {% icon "user" "user-image" %} + {% endif %} + {{ ocorrencia.servidor_registro.get_apelido }} +
+

{{ ocorrencia.descricao }}

+
+ + {% block card-adesao %} + {% if 'solicita_convenio' in ocorrencia.infos %} +
+
+
{% trans "Solicitação de convênio" %}
+ {% if user.is_staff %} + {% icon "config" %} Gerenciar + {% endif %} +
+
+ {% translate "Etapas:" %} + {% for key, value in ocorrencia.get_infos_details.items %} + + {% if value.0 %}{% icon "check" "text-success" %}{% else %}{% icon "dismiss" "text-danger" %}{% endif %} + {{ value.1 }} + + {% endfor %} +
+
+ {% endif %} + {% endblock card-adesao %} + + {% block card-oficina %} + {% if 'solicita_oficinas' in ocorrencia.infos %} +
+
+
{% trans "Solicitação de oficinas" %}
+ {% if user.is_staff %} + {% icon "config" %} Gerenciar + {% endif %} +
+
+ + + + + + + + + + + + + +
{% trans "Oficinas solicitadas:" %} + {% for oficina in ocorrencia.get_infos_oficinas %} + {{ oficina.nome }} + {% endfor %} +
{% trans "Oficinas autorizadas:" %} + {% for oficina in ocorrencia.evento_set.all %} + {{ oficina }} + {% empty %} + {% trans "Nenhuma" %} + {% endfor %} +
{% trans "Senadores selecionados:" %} + {% for senador in ocorrencia.get_infos_senadores %} + {{ senador.nome_completo }} ({{ senador.partido.sigla }}) + {% endfor %} +
+
+
+ {% endif %} + {% endblock card-oficina %} + + {% block card-anexos %} +
+
{% trans "Anexos" %}
+
+ + + + + + + + + + {% for anexo in ocorrencia.anexo_set.all %} + + + + + + {% empty %} + + {% endfor %} + +
{% trans "Data de publicação" %}{% trans "Descrição" %}{% trans "Arquivo" %}
{{ anexo.data_pub|date:"SHORT_DATE_FORMAT" }}{{ anexo.descricao }}{% icon anexo.arquivo.name|filesuffix|default:"upload" %} {{ anexo.arquivo.name|filename }}
{% trans "Nenhum anexo" %}
+
+ {% if anexo_form %} +
{% csrf_token %} + + {{ anexo_form }} + +
+ {% endif %} +
+ {% endblock card-anexos %} + + {% block card-comentarios %} +
+
{% trans "Comentários" %}
+
    + {% for comentario in ocorrencia.comentarios.all %} + {% if user.is_staff or comentario.interno == False %} +
  • + {% if comentario.usuario.foto %} + + {% else %} + {% icon "user" %} + {% endif %} + {% blocktranslate with data=comentario.data_criacao nome=comentario.usuario.get_apelido %}Em {{ data }}, {{ nome }} disse:{% endblocktranslate %} + {{ comentario.descricao }} + {% if comentario.novo_status %} + {% blocktranslate with status=comentario.get_novo_status_display|default:"-" %}Status: {{ status }}{% endblocktranslate %} + {% endif %} +
  • + {% endif %} + {% empty %} +
  • {% trans "Nenhum comentário" %}
  • + {% endfor %} + {% if comentario_form %} +
  • +
    {% csrf_token %} + + {{ comentario_form }} + +
    +
  • + {% endif %} +
+
+ {% endblock card-comentarios %} +
+
\ No newline at end of file diff --git a/sigi/apps/ocorrencias/views.py b/sigi/apps/ocorrencias/views.py index 5c93a12..3572fc0 100644 --- a/sigi/apps/ocorrencias/views.py +++ b/sigi/apps/ocorrencias/views.py @@ -56,6 +56,7 @@ class PainelOcorrenciaFilter(django_filters.FilterSet): label=_("Nome da casa contém"), field_name="casa_legislativa__search_text", lookup_expr=_("icontains"), + method="nome_casa_filter", ) gerente = django_filters.ModelChoiceFilter( label=_("Casas gerenciadas por"), @@ -92,6 +93,10 @@ class PainelOcorrenciaFilter(django_filters.FilterSet): "categoria", ] + def nome_casa_filter(self, queryset, name, value): + value = to_ascii(value).lower() + return queryset.filter(**{f"{name}__icontains": value}) + def servidor_filter(self, queryset, name, value): return queryset.filter( Q(servidor_registro=value) | Q(comentarios__usuario=value) @@ -311,9 +316,11 @@ class OficinaChangeView(BaseOcorrenciaChangeView): f"{tipo_evento.nome} na {ocorrencia.casa_legislativa.nome}, oriunda da Ocorrência #{ocorrencia.id}" ), virtual=dados["virtual"], - solicitante=ocorrencia.casa_legislativa.presidente.nome_completo - if ocorrencia.casa_legislativa.presidente - else "", + solicitante=( + ocorrencia.casa_legislativa.presidente.nome_completo + if ocorrencia.casa_legislativa.presidente + else "" + ), num_processo=ocorrencia.processo_sigad, data_pedido=ocorrencia.data_criacao, solicitacao=ocorrencia, @@ -602,13 +609,19 @@ class SolicitaConvenioCreateView(ContatoInterlegisViewMixin, UpdateView): self.tab = ( "casa" if "casa_legislativa" not in self.infos - else "presidente" - if "presidente" not in self.infos - else "contato" - if "contato" not in self.infos - else "documentos" - if "documento" in self.infos - else "resumo" + else ( + "presidente" + if "presidente" not in self.infos + else ( + "contato" + if "contato" not in self.infos + else ( + "documentos" + if "documento" in self.infos + else "resumo" + ) + ) + ) ) else: return self.cria_solicitacao(request, *args, **kwargs)