Commit Graph

45 Commits

Author SHA1 Message Date
Carlos Roca
c01450311d [FIX] base_report_to_printer: Fixed tests 2024-03-08 10:00:40 +01:00
Alexis de Lattre
145d231449 [MIG] base_report_to_printer: Migration to v14 2024-03-08 10:00:40 +01:00
Carlos Roca
d03814d170 [IMP] base_report_to_printer: black, isort, prettier 2024-03-08 10:00:40 +01:00
Jaime Arroyo
27b944ae03 [IMP] base_report_to_printer: archive printers 2024-03-08 10:00:40 +01:00
Ignacio Buioli
74018a0935 Translated using Weblate (Spanish (Argentina))
Currently translated at 100.0% (141 of 141 strings)

Translation: report-print-send-13.0/report-print-send-13.0-base_report_to_printer
Translate-URL: https://translation.odoo-community.org/projects/report-print-send-13-0/report-print-send-13-0-base_report_to_printer/es_AR/
2024-03-08 10:00:40 +01:00
Ignacio Buioli
ed6d3bff18 Added translation using Weblate (Spanish (Argentina)) 2024-03-08 10:00:40 +01:00
Florian Pose
363f498ae7 Added job state 'cups-filter-crashed'.
Missing state caused periodic backtraces in the logs.
2024-03-08 10:00:40 +01:00
Rod Schouteden
4e73f44bbf Update base_report_to_printer/__manifest__.py
[13.0] [MIG] set correct website in manifest

Co-Authored-By: Raf Ven <raf.ven@dynapps.be>
2024-03-08 10:00:40 +01:00
Pedro M. Baeza
f685fca3c5 [FIX] .travis.yml: Update definition 2024-03-08 10:00:40 +01:00
Rod Schouteden
0e53482bbb [MIG] base_report_to_printer: Migration to 13.0 2024-03-08 10:00:40 +01:00
Graeme Gellatly
e94fb3da48 [WIP] Migrate base_report_to_printer to V12 2024-03-08 10:00:40 +01:00
Enric Tobella
9272ae08ea Translated using Weblate (Spanish)
Currently translated at 99.3% (139 of 140 strings)

Translation: report-print-send-11.0/report-print-send-11.0-base_report_to_printer
Translate-URL: https://translation.odoo-community.org/projects/report-print-send-11-0/report-print-send-11-0-base_report_to_printer/es/
2024-03-08 10:00:40 +01:00
Maxime Chambreuil
a6baed8fe8 [FIX] Group inheritance 2024-03-08 10:00:40 +01:00
Oscar Ulises Garza Cordova
98f42b2920 [FIX][base_report_to_printer] - behaviour to print the report succesfully. 2024-03-08 10:00:40 +01:00
Enric Tobella
80ba33048e [FIX] missing super declaration 2024-03-08 10:00:40 +01:00
Bhavesh Odedra
593837c486 [FIX] Permission issue 2024-03-08 10:00:40 +01:00
Sylvain GARANCHER
5ddaaafaa9 [FIX] Allow to generate printing options without a report 2024-03-08 10:00:40 +01:00
Yannick Vaucher
b9ab055f0d Bump base_report_to_printer version to 11.0.2.1.0 2024-03-08 10:00:40 +01:00
Jairo Llopis
1ae93fa38d [FIX] base_report_to_printer: Stateless tests (#123)
If the test was run in a database with the `account` module installed, they were failing for 2 reasons:

- It was searching for the first report it could find, with the first 5 records to report. This made it load the `account.report_agedpartnerbalance` report, which caused a fake `TypeError: 'NoneType' object has no attribute '__getitem__'` error.
- It was running tests without loading the full module graph, thus not getting the default value for the new required `invoice_warn` field.

Now tests are run in `post_install` mode to load full module graph, and they use stateless data.
2024-03-08 10:00:40 +01:00
Florent de Labarre
63bfa39aa2 FIX view 2024-03-08 10:00:40 +01:00
Graeme Gellatly
91cb4e166d [WIP] Commit before rebase on latest #109 for user and view updates
Migration of printer_tray to v11 and integration with base_report_to_printer
2024-03-08 10:00:40 +01:00
Sylvain GARANCHER
321c97435c [MIG] base_report_to_printer: Migrate to v11.0 2024-03-08 10:00:40 +01:00
Graeme Gellatly
4d5e2b9cd9 [FIX] Minor bugfixes
Printer Tray isn't an app
Base Report To printer ir.actions.report.xml view xpath error and missing page name
Put to before security as security tab doesn't do much and if this module is installed it should be the hero page
2024-03-08 10:00:40 +01:00
Sylvain GARANCHER
7b9f0bcc26 [FIX] base_report_to_printer: A button method should be @api.multi 2024-03-08 10:00:40 +01:00
BLUTEC™ Solutions
025f40ffab Update README.rst
Provided steps to installing PyCups
2024-03-08 10:00:40 +01:00
Angel Moya - PESOL
d7cf6cc17c [10] FIX format parameter (#84)
* FIX format parameter

To be able to print files in raw format it's needed to set this parameter.

Previous code was not able to print raw files, but it didn't get error because 'format' used on line 107 is assumed as a format funtion, because format parameter was not on this scope.

* FIX pep8
2024-03-08 10:00:40 +01:00
Pedro M. Baeza
75a65af439 [MIG] Rename manifest files 2024-03-08 10:00:40 +01:00
Sylvain Garancher
ed27efa2db [10.0][MIG] base_report_to_printer (#68)
* Set api.multi for action called as `object` on view

* Merge syleam printers module into base_report_to_printer (#60)

* [IMP] Updated unit tests

* [FIX] Fixed renamed attributes

* [FIX] Remove deleted fields

* [IMP] Add printing.server and printing.job models

* [IMP] Allow to cancel all jobs, enable, and disable printers

* [IMP] Split the cups part of print_document into a new print_file method

* [IMP] Updated cron job to run the action_update_jobs method

* [ADD] Add a migration script to create a printing server from configuration

* [MIG] Migrate base_report_to_printer to v10.0

Removed deprecated methods on printing.printer (replaced by methods on
        printing.server)

* [IMP] Add wkhtmltopdf in travis configuration file

* [FIX] base_report_to_printer: Fix Update Job Cron
* Fix API issue with Update Job Cron
** Forward Port from 9.0

* [FIX] Fixed the res.users view

The string attribute should not be used as a selector, because it is
translatable.

* [FIX] Fixed the print_document method of report

The new API migration was made to @api.multi because of the "cr, uid,
ids" signature, but "ids" was the ids of the records to print here, not
the report's ids.
Also, the new API version of "get_pdf" get directly the ids of the
records to print in the standard module, not a recordset.

* [FIX] UI is now (un)blocked only when using qweb-pdf reports in standard addons
2024-03-08 10:00:40 +01:00
yvaucher
fe2015bbfd Fix placeholder for repo in readme.rst 2024-03-08 10:00:40 +01:00
Dave Lasley
90e5624304 [MIG] base_report_to_printer: Upgrade to v9 2024-03-08 10:00:40 +01:00
Roel Adriaans
946ffce485 [IMP] Soft fail on missing cups import
cups is an external dependency, if it is not installed Odoo will not start.
OCA guidelines specify guidelines for External dependencies, code is from there.
2024-03-08 10:00:40 +01:00
Alexis de Lattre
95e7f39d41 Add support for multiple copies 2024-03-08 10:00:40 +01:00
czoellner
227998c87f pass context to printer to use it for example in print_options()
* context was lost while getting report
* now it will be passed using with_context
* could be used for print_options (example: pass copies amount for
productlabals)
2024-03-08 10:00:40 +01:00
Stéphane Bidoul
5eecebe949 [UPD] prefix versions with 8.0 2024-03-08 10:00:40 +01:00
Yannick Vaucher
e4d9f2c914 [PEP8] 2024-03-08 10:00:40 +01:00
vrenaville
5f40c65f2d [FIX] test if the module is installed before monkey patching 2024-03-08 10:00:40 +01:00
Anthony Muschang
84beced9cd [FIX] base_report_to_printer: make get_pdf callable from 8.0 api 2024-03-08 10:00:40 +01:00
Nicolas Bessi
d98539e6ac Improve bloated condition test 2024-03-08 10:00:40 +01:00
Guewen Baconnier
3c6e9e4b19 The alteration of the context has no effect 2024-03-08 10:00:40 +01:00
Nicolas Bessi
366044658b Compatibility fix for report with custom parser
By calling `super.get_pdf` in print_document we can encounter trouble with MRO resolution
that prevent custom report parser (e.g. override of `get_pdf`) to be called.

The fix consist of not calling `super` and prevent multiple call to 'printer.print_document'
2024-03-08 10:00:40 +01:00
Alexandre Fayolle
dee1ce7971 Add OCA as author of OCA addons
In order to get visibility on https://www.odoo.com/apps the OCA board has
decided to add the OCA as author of all the addons maintained as part of the
association.
2024-03-08 10:00:40 +01:00
Guewen Baconnier
8c0e4ba731 Do no longer returns a PDF when a report is printed
Instead, a notification is displayed to the user.
When report.get_pdf() is called on a report that must be printer,
it will print the report *and* returns the pdf, thus code that
calls directly report.get_pdf() will print the pdf on the printer
as expected.

Fixes #16
2024-03-08 10:00:40 +01:00
Alexis de Lattre
3a61fafe58 [FIX] Bug #19 avoid crash when using 'raw' option
[Usability] Auto-add Administrator user to the Print group
Make XML code more readable

base_report_to_printer: add support for remote CUPS server (not just localhost)
More logging and better error handling

Add CUPS_HOST in more debug logs
2024-03-08 10:00:40 +01:00
Guewen Baconnier
ab7fbbdf64 base_calendar passed away
Migrate ir_report.py to new API

Migrate printing.py to new API

Migrate res_users.py to new API

Migrate report_xml_action.py to new API

Migrate wizard/update_printers.py to new API

Better view for wizard

Recursion when calling a method with old-style api signature from browse

Remove the Lock because it is useless on multiprocess

Replace it by a database lock so the different processes are
all aware of the lock and the last update timestamp.

browse is called often enough to call the update routine (even too much)

Implements the print on the new 'report' model

Restore the print capability on deprecated reports

Update copyrights

Improve form view, add search view for printers

Update translations, add a string to URI so it is uppercased

missing api decorator

We need the report in print_document and print options (needed in
printer_tray)

Move the 'skip_update' right in the browse, it prevents a loop

See https://github.com/odoo/odoo/issues/3644

Also, it helps to have the value set/read in context close to each
other.

Avoid to hits the database too many times to check if the list of
printers needs to be refreshed.

Keep the last update datetime in cache and invalidate this datetime if is
is older than POLL_INTERVAL.  Thus, one process won't hit the DB more
than 1 time every POLL_INTERVAL (10 seconds currently) to check if it
needs to update the list.

Refresh the list of printers every 15 seconds instead of 10

Extract a method so it will be easier to override in printer_tray

Error on installation of the module

Invalidate the cache when the table is created so the table_exists()
method returns a fresh value after creation of the table

Use a cron instead of threads to update printers status

The implementation with threads was blocking the loading of the
server in multiprocess.  Using a cron will lower the frequency of
the updates but at least it is simple and reliable.

Fixes #14

Do not write the printer status if it has not changed

Avoid unnecessary UPDATE every minute

Clean the XML file (remove eval, reindent)

Give access to models to all users for reading

So they are able to print
2024-03-08 10:00:40 +01:00
oca-git-bot
b93ee81806 Initialize 17.0 branch 2023-11-12 16:06:27 +01:00