Download the PHP package raffaelj/cockpit-imageresize without Composer
On this page you can find all versions of the php package raffaelj/cockpit-imageresize. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Informations about the package cockpit-imageresize
ImageResize
This addon is not compatible with Cockpit CMS v2.
See also Cockpit CMS v1 docs, Cockpit CMS v1 repo and Cockpit CMS v2 docs, Cockpit CMS v2 repo.
Addon for Cockpit CMS to resize and optimize uploaded images automatically
Requirements, compatibility
Since v0.2.0, ImageResize requires Cockpit v0.10.1 or above.
I rewrote a lot of the code to make use of the new cockpit.asset.upload
event. It should now also be compatible with the cloud storage addon, but I wasn't able to test it, yet.
If you enable the optimize
option, the [ImageOptimizer addon] is obsolute. Don't use both addons together.
Installation
Copy this repository into /addons
and name it ImageResize
or use the cli.
via git
via cp cli
via composer
Make sure, that the path to cockpit addons is defined in your projects' composer.json
file.
Usage
A copy of the original file is stored in /uploads/full/filename.jpg
. The default file will be replaced with the resized file. From now on, you don't have to create thumbnails from 8MB sized files again, but you are still able to use the original file, if you want to.
If users upload very large images, it will take a while to process the files.
There is no option in the assets manager to choose the original file, but your api autput has two additional keys:
original keys:
extra keys:
Options
The GUI is outdated and doesn't provide all options.
config/config.php
:
ACL
If users without admin rights should have access to the settings, you have to give them manage rights.
CLI
Call ./cp imageresize/replace
to replace all existing images.
Warning
- Create a backup before processing.
- Make sure to set
memory_limit = 512M
in yourphp.ini
if you have to process large files. - Use a sequential bash command if you still have memory issues
If you run into memory problems, use the script sequentially. First call the following command and read the output, e. g. "151".
./cp imageresize/replace --count
Then call the following command and replace "151" with your assets count. Now the script processes only 10 files at once.
for i in
seq 0 10 151; do ./mp imageresize/replace --skip $i --limit 10 --s --loud; done
Customized assetsmanager/cp-assets component
extra features:
- "select all" checkbox
copyright
field for assets- select different sizes (profiles) in assetsmanager
Spatie image optimizer
If you wonder, why the optimizer doesn't work, you have to install some binaries in your environment. See: https://github.com/spatie/image-optimizer#optimization-tools
I tested it successfully on my local devolopment machine with the raffaelj/php7-apache-imgopt docker image.
To do
- [x] batch action for existing files
- cli commands
- [x] batch convert all assets
- [ ] update entries
- [x] multiple profiles, e. g. "thumbnail", "banner"...
- [x] overwrite default date pattern in uploads folder to custom folder
- [ ] force recreation when changing defaults
- [ ] GUI for profiles
- [ ] fine tuning for image optimizer (especially SVG)
Credits and third party libraries
- Spatie image optimizer, MIT Licensed, https://spatie.be/