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.html 135 - 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.html 140,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.ts 316,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.ts 178 - 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.ts 189 - 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.html 81 - Permissions + Permisos Create new user group @@ -1449,7 +1449,7 @@ src/app/components/common/edit-dialog/mail-account-edit-dialog/mail-account-edit-dialog.component.ts 88 - Successfully connected to the mail server + Conectado con éxito al servidor de correo Unable 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.ts 89 - Unable to connect to the mail server + No se ha podido conectar con el servidor de correo Account @@ -1525,7 +1525,7 @@ src/app/components/common/edit-dialog/mail-rule-edit-dialog/mail-rule-edit-dialog.component.html 16 - Rule order + Orden de las reglas Paperless 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.html 22 - Filter subject + Filtrar asunto Filter body @@ -1573,7 +1573,7 @@ src/app/components/common/edit-dialog/mail-rule-edit-dialog/mail-rule-edit-dialog.component.html 24 - Filter attachment filename + Filtrar nombre del fichero adjunto Only 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.ts 60 - Mark as read, don't process read mails + Marcar como leído, no procesar archivos leídos Flag 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.ts 68 - Tag the mail with specified tag, don't process tagged mails + Etiqueta el correo con la etiqueta especificada, no procesar correos etiquetados Use subject as title @@ -2017,7 +2017,7 @@ src/app/components/manage/settings/settings.component.html 367 - Groups + Grupos Create new user account @@ -2025,7 +2025,7 @@ src/app/components/common/edit-dialog/user-edit-dialog/user-edit-dialog.component.ts 42 - Create new user account + Crear nuevo usuario Edit user account @@ -2033,7 +2033,7 @@ src/app/components/common/edit-dialog/user-edit-dialog/user-edit-dialog.component.ts 46 - Edit user account + Editar cuenta de usuario All 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.ts 213 - Finnish + Suomi French 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.html 18 - Password is token + Wachtwoord is token Check 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.html 18 - Check if the password above is a token used for authentication + Controleer of het bovenstaande wachtwoord een token is dat wordt gebruikt voor authenticatie Character Set @@ -1401,7 +1401,7 @@ src/app/components/common/edit-dialog/mail-account-edit-dialog/mail-account-edit-dialog.component.html 32 - Test + Testen No encryption @@ -1449,7 +1449,7 @@ src/app/components/common/edit-dialog/mail-account-edit-dialog/mail-account-edit-dialog.component.ts 88 - Successfully connected to the mail server + Succesvol verbonden met de mailserver Unable 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.ts 89 - Unable to connect to the mail server + Kan geen verbinding maken met de mailserver Account @@ -2357,7 +2357,7 @@ src/app/components/common/permissions-select/permissions-select.component.ts 62 - Inherited from group + Overgenomen van groep Select @@ -2992,7 +2992,7 @@ src/app/components/document-detail/document-detail.component.ts 226,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.ts 492 - Document saved successfully. + Document succesvol opgeslagen. Error saving document @@ -3076,7 +3076,7 @@ src/app/components/document-detail/document-detail.component.ts 595,597 - Error deleting document: + Fout bij verwijderen document: Redo OCR confirm @@ -3746,7 +3746,7 @@ src/app/components/document-list/document-list.component.html 126 - Sort by ASN + Sorteer op ASN ASN @@ -3770,7 +3770,7 @@ src/app/components/document-list/document-list.component.html 133 - Sort by correspondent + Sorteer op correspondent Sort by title @@ -3778,7 +3778,7 @@ src/app/components/document-list/document-list.component.html 140 - Sort by title + Sorteer op titel Sort by notes @@ -3786,7 +3786,7 @@ src/app/components/document-list/document-list.component.html 147 - Sort by notes + Sorteer op notities Notes @@ -3810,7 +3810,7 @@ src/app/components/document-list/document-list.component.html 154 - Sort by document type + Sorteer op documenttype Sort by storage path @@ -3818,7 +3818,7 @@ src/app/components/document-list/document-list.component.html 161 - Sort by storage path + Sorteer op opslagpad Sort by created date @@ -3826,7 +3826,7 @@ src/app/components/document-list/document-list.component.html 168 - Sort by created date + Sorteer op aanmaakdatum Sort by added date @@ -3834,7 +3834,7 @@ src/app/components/document-list/document-list.component.html 175 - Sort by added date + Sorteer op datum toegevoegd Added @@ -4338,7 +4338,7 @@ src/app/components/manage/management-list/management-list.component.ts 175,177 - Error occurred while saving . + Fout opgetreden tijdens opslaan . Successfully updated . @@ -4354,7 +4354,7 @@ src/app/components/manage/management-list/management-list.component.ts 188,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.html 140,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.ts 177 - Catalan + Catalaans Czech @@ -5719,7 +5719,7 @@ src/app/services/settings.service.ts 213 - Finnish + Fins French 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.ts 145 - 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.ts 155 - 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.ts 165 - 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.ts 178 - 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.ts 199 - 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.html 155 - Storage paths + Caminhos de Armazenamento File Tasks @@ -685,7 +685,7 @@ src/app/components/manage/tasks/tasks.component.html 1 - File Tasks + Tarefas de Arquivo File Tasks @@ -2150,7 +2150,7 @@ src/app/components/common/input/permissions/permissions-form/permissions-form.component.html 25 - 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ários View @@ -2389,7 +2389,7 @@ src/app/components/dashboard/dashboard.component.ts 36 - Hello , welcome to Paperless-ngx + Olá , bem-vindo(a) ao Paperless-ngx Welcome to Paperless-ngx @@ -2481,7 +2481,7 @@ src/app/components/dashboard/widgets/statistics-widget/statistics-widget.component.html 5 - Documents in inbox + Documentos na caixa de entrada Go to documents @@ -2497,7 +2497,7 @@ src/app/components/dashboard/widgets/statistics-widget/statistics-widget.component.html 9 - Total documents + Total de documentos Total characters @@ -2505,7 +2505,7 @@ src/app/components/dashboard/widgets/statistics-widget/statistics-widget.component.html 13 - Total characters + Total de caracteres Other @@ -3802,7 +3802,7 @@ src/app/services/rest/document.service.ts 25 - Notes + Notas Sort by document type @@ -4794,7 +4794,7 @@ src/app/components/manage/settings/settings.component.html 327 - Users & Groups + Usuários & Grupos Users @@ -5174,7 +5174,7 @@ src/app/components/manage/tasks/tasks.component.ts 62 - Dismiss + Dispensar Open Document @@ -5222,7 +5222,7 @@ src/app/components/manage/tasks/tasks.component.ts 26 - Dismiss selected + Dispensar selecionado Dismiss all @@ -5234,7 +5234,7 @@ src/app/components/manage/tasks/tasks.component.ts 60 - Dismiss all + Dispensar todos Confirm Dismiss All @@ -5242,7 +5242,7 @@ src/app/components/manage/tasks/tasks.component.ts 58 - Confirm Dismiss All + Confirmar Dispensar Todos tasks? 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.")