diff --git a/docker/docker-prepare.sh b/docker/docker-prepare.sh
index d6eab4281..9cf41d42c 100755
--- a/docker/docker-prepare.sh
+++ b/docker/docker-prepare.sh
@@ -80,7 +80,7 @@ django_checks() {
search_index() {
- local -r index_version=4
+ local -r index_version=5
local -r index_version_file=${DATA_DIR}/.index_version
if [[ (! -f "${index_version_file}") || $(<"${index_version_file}") != "$index_version" ]]; then
diff --git a/src-ui/src/app/components/common/filterable-dropdown/toggleable-dropdown-button/toggleable-dropdown-button.component.html b/src-ui/src/app/components/common/filterable-dropdown/toggleable-dropdown-button/toggleable-dropdown-button.component.html
index 211bef756..af935b0db 100644
--- a/src-ui/src/app/components/common/filterable-dropdown/toggleable-dropdown-button/toggleable-dropdown-button.component.html
+++ b/src-ui/src/app/components/common/filterable-dropdown/toggleable-dropdown-button/toggleable-dropdown-button.component.html
@@ -20,5 +20,5 @@
{{item.name}}
-
{{count ?? item.document_count}}
+
{{count ?? item.document_count}}
diff --git a/src-ui/src/environments/environment.prod.ts b/src-ui/src/environments/environment.prod.ts
index 2cb175a6c..56fdce31e 100644
--- a/src-ui/src/environments/environment.prod.ts
+++ b/src-ui/src/environments/environment.prod.ts
@@ -5,7 +5,7 @@ export const environment = {
apiBaseUrl: document.baseURI + 'api/',
apiVersion: '2',
appTitle: 'Paperless-ngx',
- version: '1.14.3',
+ version: '1.14.3-dev',
webSocketHost: window.location.host,
webSocketProtocol: window.location.protocol == 'https:' ? 'wss:' : 'ws:',
webSocketBaseUrl: base_url.pathname + 'ws/',
diff --git a/src-ui/src/locale/messages.ca_ES.xlf b/src-ui/src/locale/messages.ca_ES.xlf
index abf1025f1..5a65f86b8 100644
--- a/src-ui/src/locale/messages.ca_ES.xlf
+++ b/src-ui/src/locale/messages.ca_ES.xlf
@@ -4570,7 +4570,7 @@
src/app/components/manage/settings/settings.component.html135
- Comprova actualització
+ Comprovant actualització Update checking works by pinging the public Github API for the latest release to determine whether a new version is available. Actual updating of the app must still be performed manually.
@@ -4578,7 +4578,7 @@
src/app/components/manage/settings/settings.component.html140,142
- Comprovació d'actualització funciona fent ping a Github API per a la darrera versió per determinar si hi ha una versió nova disponible Aactualització real de l'aplicació s'ha de fer manualment.
+ Comprovació d'actualització funciona fent ping a Github API per a la darrera versió per determinar si hi ha una versió nova disponible l'Actualització real de l'aplicació s'ha de fer manualment. No tracking data is collected by the app in any way.
diff --git a/src-ui/src/locale/messages.de_DE.xlf b/src-ui/src/locale/messages.de_DE.xlf
index 5b91dbd44..dc3d71881 100644
--- a/src-ui/src/locale/messages.de_DE.xlf
+++ b/src-ui/src/locale/messages.de_DE.xlf
@@ -3402,7 +3402,7 @@
src/app/components/document-list/bulk-editor/bulk-editor.component.ts316,320
- Diese Aktion wird die Tags hinzufügen und die Tags ertfernen von ausgewählten Dokument(en).
+ Diese Aktion wird die Tags hinzufügen und die Tags entfernen von ausgewählten Dokument(en).Confirm correspondent assignment
diff --git a/src-ui/src/locale/messages.es_ES.xlf b/src-ui/src/locale/messages.es_ES.xlf
index 39bafd0b4..0b4697e00 100644
--- a/src-ui/src/locale/messages.es_ES.xlf
+++ b/src-ui/src/locale/messages.es_ES.xlf
@@ -404,7 +404,7 @@
src/app/app.component.ts178
- The filtering tools allow you to quickly find documents using various searches, dates, tags, etc.
+ Las herramientas de filtrado le permiten encontrar rápidamente documentos usando diferentes búsquedas, fechas, etiquetas, etc.Any combination of filters can be saved as a 'view' which can then be displayed on the dashboard and / or sidebar.
@@ -412,7 +412,7 @@
src/app/app.component.ts189
- Any combination of filters can be saved as a 'view' which can then be displayed on the dashboard and / or sidebar.
+ Cualquier combinación de filtros puede ser guardada como una "vista" que puede ser luego mostrada en el panel de control y/o panel lateral.Tags, correspondents, document types and storage paths can all be managed using these pages. They can also be created from the document edit view.
@@ -1257,7 +1257,7 @@
src/app/components/document-list/bulk-editor/bulk-editor.component.html81
- Permissions
+ PermisosCreate new user group
@@ -1449,7 +1449,7 @@
src/app/components/common/edit-dialog/mail-account-edit-dialog/mail-account-edit-dialog.component.ts88
- Successfully connected to the mail server
+ Conectado con éxito al servidor de correoUnable to connect to the mail server
@@ -1457,7 +1457,7 @@
src/app/components/common/edit-dialog/mail-account-edit-dialog/mail-account-edit-dialog.component.ts89
- Unable to connect to the mail server
+ No se ha podido conectar con el servidor de correoAccount
@@ -1525,7 +1525,7 @@
src/app/components/common/edit-dialog/mail-rule-edit-dialog/mail-rule-edit-dialog.component.html16
- Rule order
+ Orden de las reglasPaperless will only process mails that match all of the filters specified below.
@@ -1557,7 +1557,7 @@
src/app/components/common/edit-dialog/mail-rule-edit-dialog/mail-rule-edit-dialog.component.html22
- Filter subject
+ Filtrar asuntoFilter body
@@ -1573,7 +1573,7 @@
src/app/components/common/edit-dialog/mail-rule-edit-dialog/mail-rule-edit-dialog.component.html24
- Filter attachment filename
+ Filtrar nombre del fichero adjuntoOnly consume documents which entirely match this filename if specified. Wildcards such as *.pdf or *invoice* are allowed. Case insensitive.
@@ -1777,7 +1777,7 @@
src/app/components/common/edit-dialog/mail-rule-edit-dialog/mail-rule-edit-dialog.component.ts60
- Mark as read, don't process read mails
+ Marcar como leído, no procesar archivos leídosFlag the mail, don't process flagged mails
@@ -1793,7 +1793,7 @@
src/app/components/common/edit-dialog/mail-rule-edit-dialog/mail-rule-edit-dialog.component.ts68
- Tag the mail with specified tag, don't process tagged mails
+ Etiqueta el correo con la etiqueta especificada, no procesar correos etiquetadosUse subject as title
@@ -2017,7 +2017,7 @@
src/app/components/manage/settings/settings.component.html367
- Groups
+ GruposCreate new user account
@@ -2025,7 +2025,7 @@
src/app/components/common/edit-dialog/user-edit-dialog/user-edit-dialog.component.ts42
- Create new user account
+ Crear nuevo usuarioEdit user account
@@ -2033,7 +2033,7 @@
src/app/components/common/edit-dialog/user-edit-dialog/user-edit-dialog.component.ts46
- Edit user account
+ Editar cuenta de usuarioAll
diff --git a/src-ui/src/locale/messages.fi_FI.xlf b/src-ui/src/locale/messages.fi_FI.xlf
index 284e748b5..e3e3f9d91 100644
--- a/src-ui/src/locale/messages.fi_FI.xlf
+++ b/src-ui/src/locale/messages.fi_FI.xlf
@@ -5719,7 +5719,7 @@
src/app/services/settings.service.ts213
- Finnish
+ SuomiFrench
diff --git a/src-ui/src/locale/messages.nl_NL.xlf b/src-ui/src/locale/messages.nl_NL.xlf
index 7de0ad553..f8b013637 100644
--- a/src-ui/src/locale/messages.nl_NL.xlf
+++ b/src-ui/src/locale/messages.nl_NL.xlf
@@ -1333,7 +1333,7 @@
src/app/components/common/edit-dialog/mail-account-edit-dialog/mail-account-edit-dialog.component.html18
- Password is token
+ Wachtwoord is tokenCheck if the password above is a token used for authentication
@@ -1341,7 +1341,7 @@
src/app/components/common/edit-dialog/mail-account-edit-dialog/mail-account-edit-dialog.component.html18
- Check if the password above is a token used for authentication
+ Controleer of het bovenstaande wachtwoord een token is dat wordt gebruikt voor authenticatieCharacter Set
@@ -1401,7 +1401,7 @@
src/app/components/common/edit-dialog/mail-account-edit-dialog/mail-account-edit-dialog.component.html32
- Test
+ TestenNo encryption
@@ -1449,7 +1449,7 @@
src/app/components/common/edit-dialog/mail-account-edit-dialog/mail-account-edit-dialog.component.ts88
- Successfully connected to the mail server
+ Succesvol verbonden met de mailserverUnable to connect to the mail server
@@ -1457,7 +1457,7 @@
src/app/components/common/edit-dialog/mail-account-edit-dialog/mail-account-edit-dialog.component.ts89
- Unable to connect to the mail server
+ Kan geen verbinding maken met de mailserverAccount
@@ -2357,7 +2357,7 @@
src/app/components/common/permissions-select/permissions-select.component.ts62
- Inherited from group
+ Overgenomen van groepSelect
@@ -2992,7 +2992,7 @@
src/app/components/document-detail/document-detail.component.ts226,228
- An error occurred loading content:
+ Er is een fout opgetreden bij het laden van de inhoud: Error retrieving metadata
@@ -3020,7 +3020,7 @@
src/app/components/document-detail/document-detail.component.ts492
- Document saved successfully.
+ Document succesvol opgeslagen.Error saving document
@@ -3076,7 +3076,7 @@
src/app/components/document-detail/document-detail.component.ts595,597
- Error deleting document:
+ Fout bij verwijderen document: Redo OCR confirm
@@ -3746,7 +3746,7 @@
src/app/components/document-list/document-list.component.html126
- Sort by ASN
+ Sorteer op ASNASN
@@ -3770,7 +3770,7 @@
src/app/components/document-list/document-list.component.html133
- Sort by correspondent
+ Sorteer op correspondentSort by title
@@ -3778,7 +3778,7 @@
src/app/components/document-list/document-list.component.html140
- Sort by title
+ Sorteer op titelSort by notes
@@ -3786,7 +3786,7 @@
src/app/components/document-list/document-list.component.html147
- Sort by notes
+ Sorteer op notitiesNotes
@@ -3810,7 +3810,7 @@
src/app/components/document-list/document-list.component.html154
- Sort by document type
+ Sorteer op documenttypeSort by storage path
@@ -3818,7 +3818,7 @@
src/app/components/document-list/document-list.component.html161
- Sort by storage path
+ Sorteer op opslagpadSort by created date
@@ -3826,7 +3826,7 @@
src/app/components/document-list/document-list.component.html168
- Sort by created date
+ Sorteer op aanmaakdatumSort by added date
@@ -3834,7 +3834,7 @@
src/app/components/document-list/document-list.component.html175
- Sort by added date
+ Sorteer op datum toegevoegdAdded
@@ -4338,7 +4338,7 @@
src/app/components/manage/management-list/management-list.component.ts175,177
- Error occurred while saving .
+ Fout opgetreden tijdens opslaan .Successfully updated .
@@ -4354,7 +4354,7 @@
src/app/components/manage/management-list/management-list.component.ts188,190
- Error occurred while saving : .
+ Fout opgetreden tijdens opslaan : .Do you really want to delete the ?
@@ -4578,7 +4578,7 @@
src/app/components/manage/settings/settings.component.html140,142
- Update checking works by pinging the public Github API for the latest release to determine whether a new version is available. Actual updating of the app must still be performed manually.
+ Updatecontrole werkt door de openbare Github API te pingen voor de nieuwste release om te bepalen of er een nieuwe versie beschikbaar is. Het daadwerkelijk updaten van de app moet nog handmatig worden gedaan. No tracking data is collected by the app in any way.
@@ -5671,7 +5671,7 @@
src/app/services/settings.service.ts177
- Catalan
+ CatalaansCzech
@@ -5719,7 +5719,7 @@
src/app/services/settings.service.ts213
- Finnish
+ FinsFrench
diff --git a/src-ui/src/locale/messages.pt_BR.xlf b/src-ui/src/locale/messages.pt_BR.xlf
index fd3316800..badb52a89 100644
--- a/src-ui/src/locale/messages.pt_BR.xlf
+++ b/src-ui/src/locale/messages.pt_BR.xlf
@@ -380,7 +380,7 @@
src/app/app.component.ts145
- The dashboard can be used to show saved views, such as an 'Inbox'. Those settings are found under Settings > Saved Views once you have created some.
+ O painel pode usar usado para mostrar visualizações salvas, como uma 'Caixa de Entrada'. Essas configurações são encontradas em Configurações > Visualizações assim que você criar algumas.Drag-and-drop documents here to start uploading or place them in the consume folder. You can also drag-and-drop documents anywhere on all other pages of the web app. Once you do, Paperless-ngx will start training its machine learning algorithms.
@@ -388,7 +388,7 @@
src/app/app.component.ts155
- Drag-and-drop documents here to start uploading or place them in the consume folder. You can also drag-and-drop documents anywhere on all other pages of the web app. Once you do, Paperless-ngx will start training its machine learning algorithms.
+ Arraste e solte documentos aqui para começar a carregá-los ou coloque-os na pasta de consumo. Você também pode arrastar e soltar documentos em qualquer lugar em todas as outras páginas do aplicativo web. Quando o fizer, Paperless-ngx vai começar a treinar seus algoritmos de aprendizado de máquina.The documents list shows all of your documents and allows for filtering as well as bulk-editing. There are three different view styles: list, small cards and large cards. A list of documents currently opened for editing is shown in the sidebar.
@@ -396,7 +396,7 @@
src/app/app.component.ts165
- The documents list shows all of your documents and allows for filtering as well as bulk-editing. There are three different view styles: list, small cards and large cards. A list of documents currently opened for editing is shown in the sidebar.
+ A lista de documentos mostra todos seus documentos e permite filtragem e edição em massa. Há três diferentes estilos de visualização: lista, cartões pequenos e cartões grandes. Uma lista com documentos atualmente abertos para edição é mostrada na barra lateral.The filtering tools allow you to quickly find documents using various searches, dates, tags, etc.
@@ -404,7 +404,7 @@
src/app/app.component.ts178
- The filtering tools allow you to quickly find documents using various searches, dates, tags, etc.
+ As ferramentas de filtragem permitem que você encontre documentos rapidamente usando várias pesquisas, datas, etiquetas, etc.Any combination of filters can be saved as a 'view' which can then be displayed on the dashboard and / or sidebar.
@@ -420,7 +420,7 @@
src/app/app.component.ts199
- Tags, correspondents, document types and storage paths can all be managed using these pages. They can also be created from the document edit view.
+ Etiquetas, correspondentes, tipos de documentos e caminhos de armazenamento podem ser gerenciados usando essas páginas. Eles também podem ser criados a partir da visualização da edição do documento.File Tasks shows you documents that have been consumed, are waiting to be, or may have failed during the process.
@@ -673,7 +673,7 @@
src/app/components/app-frame/app-frame.component.html155
- Storage paths
+ Caminhos de ArmazenamentoFile Tasks
@@ -685,7 +685,7 @@
src/app/components/manage/tasks/tasks.component.html1
- File Tasks
+ Tarefas de ArquivoFile Tasks
@@ -2150,7 +2150,7 @@
src/app/components/common/input/permissions/permissions-form/permissions-form.component.html25
- Objects without an owner can be viewed and edited by all users
+ Documentos sem um proprietário podem ser visualizados e editados por todos os usuáriosView
@@ -2389,7 +2389,7 @@
src/app/components/dashboard/dashboard.component.ts36
- Hello , welcome to Paperless-ngx
+ Olá , bem-vindo(a) ao Paperless-ngxWelcome to Paperless-ngx
@@ -2481,7 +2481,7 @@
src/app/components/dashboard/widgets/statistics-widget/statistics-widget.component.html5
- Documents in inbox
+ Documentos na caixa de entradaGo to documents
@@ -2497,7 +2497,7 @@
src/app/components/dashboard/widgets/statistics-widget/statistics-widget.component.html9
- Total documents
+ Total de documentosTotal characters
@@ -2505,7 +2505,7 @@
src/app/components/dashboard/widgets/statistics-widget/statistics-widget.component.html13
- Total characters
+ Total de caracteresOther
@@ -3802,7 +3802,7 @@
src/app/services/rest/document.service.ts25
- Notes
+ NotasSort by document type
@@ -4794,7 +4794,7 @@
src/app/components/manage/settings/settings.component.html327
- Users & Groups
+ Usuários & GruposUsers
@@ -5174,7 +5174,7 @@
src/app/components/manage/tasks/tasks.component.ts62
- Dismiss
+ DispensarOpen Document
@@ -5222,7 +5222,7 @@
src/app/components/manage/tasks/tasks.component.ts26
- Dismiss selected
+ Dispensar selecionadoDismiss all
@@ -5234,7 +5234,7 @@
src/app/components/manage/tasks/tasks.component.ts60
- Dismiss all
+ Dispensar todosConfirm Dismiss All
@@ -5242,7 +5242,7 @@
src/app/components/manage/tasks/tasks.component.ts58
- Confirm Dismiss All
+ Confirmar Dispensar Todostasks?
diff --git a/src/documents/index.py b/src/documents/index.py
index 6aef2c047..0b0493514 100644
--- a/src/documents/index.py
+++ b/src/documents/index.py
@@ -54,6 +54,7 @@ def get_schema():
path_id=NUMERIC(),
has_path=BOOLEAN(),
notes=TEXT(),
+ num_notes=NUMERIC(sortable=True, signed=False),
owner=TEXT(),
owner_id=NUMERIC(),
has_owner=BOOLEAN(),
@@ -138,6 +139,7 @@ def update_document(writer: AsyncWriter, doc: Document):
path_id=doc.storage_path.id if doc.storage_path else None,
has_path=doc.storage_path is not None,
notes=notes,
+ num_notes=len(notes),
owner=doc.owner.username if doc.owner else None,
owner_id=doc.owner.id if doc.owner else None,
has_owner=doc.owner is not None,
@@ -173,8 +175,12 @@ class DelayedQuery:
if k == "correspondent__id":
criterias.append(query.Term("correspondent_id", v))
elif k == "correspondent__id__in":
+ correspondents_in = []
for correspondent_id in v.split(","):
- criterias.append(query.Term("correspondent_id", correspondent_id))
+ correspondents_in.append(
+ query.Term("correspondent_id", correspondent_id),
+ )
+ criterias.append(query.Or(correspondents_in))
elif k == "correspondent__id__none":
for correspondent_id in v.split(","):
criterias.append(
@@ -186,11 +192,18 @@ class DelayedQuery:
elif k == "tags__id__none":
for tag_id in v.split(","):
criterias.append(query.Not(query.Term("tag_id", tag_id)))
+ elif k == "tags__id__in":
+ tags_in = []
+ for tag_id in v.split(","):
+ tags_in.append(query.Term("tag_id", tag_id))
+ criterias.append(query.Or(tags_in))
elif k == "document_type__id":
criterias.append(query.Term("type_id", v))
elif k == "document_type__id__in":
+ document_types_in = []
for document_type_id in v.split(","):
- criterias.append(query.Term("type_id", document_type_id))
+ document_types_in.append(query.Term("type_id", document_type_id))
+ criterias.append(query.Or(document_types_in))
elif k == "document_type__id__none":
for document_type_id in v.split(","):
criterias.append(query.Not(query.Term("type_id", document_type_id)))
@@ -215,8 +228,10 @@ class DelayedQuery:
elif k == "storage_path__id":
criterias.append(query.Term("path_id", v))
elif k == "storage_path__id__in":
+ storage_paths_in = []
for storage_path_id in v.split(","):
- criterias.append(query.Term("path_id", storage_path_id))
+ storage_paths_in.append(query.Term("path_id", storage_path_id))
+ criterias.append(query.Or(storage_paths_in))
elif k == "storage_path__id__none":
for storage_path_id in v.split(","):
criterias.append(query.Not(query.Term("path_id", storage_path_id)))
@@ -253,6 +268,7 @@ class DelayedQuery:
"correspondent__name": "correspondent",
"document_type__name": "type",
"archive_serial_number": "asn",
+ "num_notes": "num_notes",
}
if field.startswith("-"):
diff --git a/src/documents/tests/test_api.py b/src/documents/tests/test_api.py
index b9989ee86..e8c6dee7c 100644
--- a/src/documents/tests/test_api.py
+++ b/src/documents/tests/test_api.py
@@ -1150,6 +1150,8 @@ class TestDocumentApi(DirectoriesMixin, DocumentConsumeDelayMixin, APITestCase):
self.assertEqual(r.data["count"], 4)
def test_search_sorting(self):
+ u1 = User.objects.create_user("user1")
+ u2 = User.objects.create_user("user2")
c1 = Correspondent.objects.create(name="corres Ax")
c2 = Correspondent.objects.create(name="corres Cx")
c3 = Correspondent.objects.create(name="corres Bx")
@@ -1159,6 +1161,7 @@ class TestDocumentApi(DirectoriesMixin, DocumentConsumeDelayMixin, APITestCase):
content="test",
archive_serial_number=2,
title="3",
+ owner=u1,
)
d2 = Document.objects.create(
checksum="2",
@@ -1166,6 +1169,7 @@ class TestDocumentApi(DirectoriesMixin, DocumentConsumeDelayMixin, APITestCase):
content="test",
archive_serial_number=3,
title="2",
+ owner=u2,
)
d3 = Document.objects.create(
checksum="3",
@@ -1174,6 +1178,21 @@ class TestDocumentApi(DirectoriesMixin, DocumentConsumeDelayMixin, APITestCase):
archive_serial_number=1,
title="1",
)
+ Note.objects.create(
+ note="This is a note.",
+ document=d1,
+ user=u1,
+ )
+ Note.objects.create(
+ note="This is a note.",
+ document=d1,
+ user=u1,
+ )
+ Note.objects.create(
+ note="This is a note.",
+ document=d3,
+ user=u1,
+ )
with AsyncWriter(index.open_index()) as writer:
for doc in Document.objects.all():
@@ -1202,6 +1221,14 @@ class TestDocumentApi(DirectoriesMixin, DocumentConsumeDelayMixin, APITestCase):
search_query("&ordering=-correspondent__name"),
[d2.id, d3.id, d1.id],
)
+ self.assertListEqual(
+ search_query("&ordering=num_notes"),
+ [d2.id, d3.id, d1.id],
+ )
+ self.assertListEqual(
+ search_query("&ordering=-num_notes"),
+ [d1.id, d3.id, d2.id],
+ )
def test_statistics(self):
doc1 = Document.objects.create(
diff --git a/src/locale/pt_BR/LC_MESSAGES/django.po b/src/locale/pt_BR/LC_MESSAGES/django.po
index 267d1c5d3..5c06131a2 100644
--- a/src/locale/pt_BR/LC_MESSAGES/django.po
+++ b/src/locale/pt_BR/LC_MESSAGES/django.po
@@ -3,7 +3,7 @@ msgstr ""
"Project-Id-Version: paperless-ngx\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2023-03-03 19:15+0000\n"
-"PO-Revision-Date: 2023-05-02 19:20\n"
+"PO-Revision-Date: 2023-05-03 20:18\n"
"Last-Translator: \n"
"Language-Team: Portuguese, Brazilian\n"
"Language: pt_BR\n"
@@ -35,7 +35,7 @@ msgstr "Todas as palavras"
#: documents/models.py:39
msgid "Exact match"
-msgstr "Detecção exata"
+msgstr "Correspondência exata"
#: documents/models.py:40
msgid "Regular expression"
@@ -56,11 +56,11 @@ msgstr "nome"
#: documents/models.py:47
msgid "match"
-msgstr "detecção"
+msgstr "correspondência"
#: documents/models.py:50
msgid "matching algorithm"
-msgstr "algoritmo de detecção"
+msgstr "algoritmo de correspondência"
#: documents/models.py:55
msgid "is insensitive"
@@ -144,7 +144,7 @@ msgstr "tipo mime"
#: documents/models.py:178
msgid "checksum"
-msgstr "some de verificação"
+msgstr "soma de verificação"
#: documents/models.py:182
msgid "The checksum of the original document."
@@ -662,7 +662,7 @@ msgstr "Filtro"
#: paperless_mail/admin.py:51
msgid "Paperless will only process mails that match ALL of the filters given below."
-msgstr "Paperless processará somente e-mails que se encaixam em TODOS os filtros abaixo."
+msgstr "Paperless processará somente e-mails que se encaixem em TODOS os filtros abaixo."
#: paperless_mail/admin.py:66
msgid "Actions"
@@ -678,7 +678,7 @@ msgstr "Metadados"
#: paperless_mail/admin.py:80
msgid "Assign metadata to documents consumed from this rule automatically. If you do not assign tags, types or correspondents here, paperless will still process all matching rules that you have defined."
-msgstr "Atribua metadados aos documentos consumidos por esta regra automaticamente. Se você não atribuir etiquetas, tipos ou correspondentes aqui, paperless ainda sim processará todas as regras de detecção que você definiu."
+msgstr "Atribua metadados aos documentos consumidos por esta regra automaticamente. Se você não atribuir etiquetas, tipos ou correspondentes aqui, Paperless ainda sim processará todas as regras de correspondência que você definiu."
#: paperless_mail/apps.py:10
msgid "Paperless mail"
diff --git a/src/paperless_mail/mail.py b/src/paperless_mail/mail.py
index 3851cf590..45cf57aa1 100644
--- a/src/paperless_mail/mail.py
+++ b/src/paperless_mail/mail.py
@@ -168,7 +168,7 @@ class TagMailAction(BaseMailAction):
if self.supports_gmail_labels:
return AND(NOT(gmail_label=self.keyword), no_keyword=self.keyword)
else:
- return NOT(no_keyword=self.keyword)
+ return {"no_keyword": self.keyword}
else: # pragma: nocover
raise ValueError("This should never happen.")