Download the PHP package codeneuss/image-bundle without Composer

On this page you can find all versions of the php package codeneuss/image-bundle. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.

FAQ

After the download, you have to make one include require_once('vendor/autoload.php');. After that you have to import the classes with use statements.

Example:
If you use only one package a project is not needed. But if you use more then one package, without a project it is not possible to import the classes with use statements.

In general, it is recommended to use always a project to download your libraries. In an application normally there is more than one library needed.
Some PHP packages are not free to download and because of that hosted in private repositories. In this case some credentials are needed to access such packages. Please use the auth.json textarea to insert credentials, if a package is coming from a private repository. You can look here for more information.

  • Some hosting areas are not accessible by a terminal or SSH. Then it is not possible to use Composer.
  • To use Composer is sometimes complicated. Especially for beginners.
  • Composer needs much resources. Sometimes they are not available on a simple webspace.
  • If you are using private repositories you don't need to share your credentials. You can set up everything on our site and then you provide a simple download link to your team member.
  • Simplify your Composer build process. Use our own command line tool to download the vendor folder as binary. This makes your build process faster and you don't need to expose your credentials for private repositories.
Please rate this library. Is it a good library?

Informations about the package image-bundle

This Package is a fork of ComurImageBundle an will only support Symfony3 right now. This packet is only conditionally maintained.

Readme from forked Repository.


Use 0.X releases for compatibility with bootstrap 2.x.

Compatibility with bootstrap 2.X is no more maintained

ComurImageBundle

Image upload / crop bundle for Symfony2

This bundle helps you easily create an image upload / crop field in your forms. You don't need to use any type of generator or there is no other requirements. It uses bootstrap to make it look well but you can use any other css to customize it.

It uses beautiful Jquery File Upload to upload files (original UploadHandler has been modified to add namespace and a new config parameter to generate random filenames) and JCrop to let you crop uploaded images.

New Since Version 0.2.3 !! you can also save original file in a separate field See saveOriginal parameter below.

New Since Version 0.2.0 !! you can also create sortable & croppable gallery widgets without any specific configuration. It only needs an array typed property in your entity (and a text column in your database). See below for examples, screenshots and how to use it.

Screen shots

Here are some screen shots since i didn't have time to put a demo yet:

Simple Image widget

alt tag

Gallery widget

alt tag

Upload image screen

alt tag

Select image from library screen

alt tag

Crop image screen

alt tag

Change gallery image order screen

alt tag

Installation

  1. Add this bundle to your project in composer.json:

  2. Register FOSJsRouting and this bundle to your app/AppKernel.php:

  3. Add this route to your routing.yml:

  4. Add Modal template after body tag of your layout:

Note: This template includes many script and styles including jquery and bootstrap. You can use following parameters to avoid jquery and/or bootstrap being included:

  1. Do not forget to put FOSJSRoutingBundle script in your :

That's it !

Configuration


All parameters are optional:

image:
    config:
        cropped_image_dir: 'cropped'
        thumbs_dir: 'thumbnails'
        media_lib_thumb_size: 150
        web_dirname: 'web'
        translation_domain: 'ComurImageBundle'
        gallery_thumb_size: 150
        gallery_dir: 'gallery'

cropped_image_dir

It's used to determine relative directory name to put cropped images (see above).

Default value: 'cropped'

thumbs_dir

It's used to determine relative directory name to put thumbnails (see above).

Default value: 'thumbnails'

media_lib_thumb_size

It's used to determine thumbnails size in pixels (squares) used in media library.

Default value: 150

upload_dir

Dirname of your public directory. It's used to check thumb existence in thumb twig helper.

Default value: 'web'

translation_domain

Domain name for translations. For instance two languages are provided (en & fr). To override the domain name, change this parameter to whatever you want.

Default value: 'ComurImageBundle'

gallery_thumb_size

That's the image size in pixels that you want to show in gallery widget. Gallery widget will automaticaly create square thums having this size and show them in the gallery widget.

Default value: 150

gallery_dir

That's the gallery directory name. The widget will store all gallery images in a specific directory inside the root directory that you will give when you will add the widget to your forms.

For eg. if you put 'uploads/images' as webDir when you add the widget, gallery images will be stored in 'uploads/images/[gallery_dir]'. This is added to make gallery use easier so you don't have to add new functions to your entities to get gallery dirs.

Usage

There are two widgets provided with this bundle. They both have exacly same config parameters.

Image widget

Use widget in your forms (works with SonataAdmin too) to create a simple image field :

public function buildForm(FormBuilderInterface $builder, array $options)
{
    // get your entity related with your form type
    $myEntity = $builder->getForm()->getData();
    ...
    ->add('image', CroppableImageType::class, array(
        'uploadConfig' => array(
            'uploadRoute' => 'api_upload',      //optional
            'uploadUrl' => $myEntity->getUploadRootDir(),       // required - see explanation below (you can also put just a dir path)
            'webDir' => $myEntity->getUploadDir(),              // required - see explanation below (you can also put just a dir path)
            'fileExt' => '*.jpg;*.gif;*.png;*.jpeg',    //optional
            'libraryDir' => null,                       //optional
            'libraryRoute' => 'api_image_library', //optional
            'showLibrary' => true,                      //optional
            'saveOriginal' => 'originalImage',          //optional
            'generateFilename' => true          //optional
        ),
        'cropConfig' => array(
            'minWidth' => 588,
            'minHeight' => 300,
            'aspectRatio' => true,              //optional
            'cropRoute' => 'api_crop',  //optional
            'forceResize' => false,             //optional
            'thumbs' => array(                  //optional
                array(
                    'maxWidth' => 180,
                    'maxHeight' => 400,
                    'useAsFieldImage' => true  //optional
                )
            )
        )
    ))

You need to create a field (named image in this example but you can choose whatever you want):

// YourBundle\Entity\YourEntity.php

…

/**
 * @ORM\Column(type="string", length=255, nullable=true)
 */
protected $image;

…

And create your functions in your entity to have directory paths, for ex :

public function getUploadRootDir()
{
    // absolute path to your directory where images must be saved
    return __DIR__.'/../../../../../web/'.$this->getUploadDir();
}

public function getUploadDir()
{
    return 'uploads/myentity';
}

public function getAbsolutePath()
{
    return null === $this->image ? null : $this->getUploadRootDir().'/'.$this->image;
}

public function getWebPath()
{
    return null === $this->image ? null : '/'.$this->getUploadDir().'/'.$this->image;
}

That's all ! This will add an image preview with an edit button in your form and will let you upload / select from library and crop images without reloading the page.

To save original image path, you have to create another field and name it same as saveOriginal parameter:

// YourBundle\Entity\YourEntity.php

…

/**
 * @ORM\Column(type="string", length=255, nullable=true)
 */
protected $originalImage;

…

I will put a demo soon…

Gallery widget

Use widget in your forms (works with SonataAdmin too) to create a sortable list of images (so a gallery :)) stored in an array typed field :

->add('gallery', CroppableGalleryType::class, array(
    //same parameters as image
))

And create your array typed field for storing images in it. Doctrine (or other ORM) will serialize this field to store it as string in the DB.

// YourBundle\Entity\YourEntity.php

…

/**
 * @ORM\Column(type="array", nullable=true)
 */
protected $gallery;

…

And create your functions in your entity to have directory paths, for ex :

public function getUploadRootDir()
{
    // absolute path to your directory where images must be saved
    return __DIR__.'/../../../../../web/'.$this->getUploadDir();
}

public function getUploadDir()
{
    return 'uploads/myentity';
}

public function getAbsolutePath()
{
    return null === $this->image ? null : $this->getUploadRootDir().'/'.$this->image;
}

public function getWebPath()
{
    return null === $this->image ? null : '/'.$this->getUploadDir().'/'.$this->image;
}

That's all ! This will create a widget like on the following image when you will use it in your forms. You can also reorder them since php serialized arrays are ordered:

Gallery images will be stored in uploadUrl / gallery_dir (default is gallery). Cropped images will be stored in uploadUrl / gallery_dir / cropped_dir (same as image widget) and thumbs in uploadUrl / gallery_dir / cropped_dir / thumb_dir with specified width. So if you pu

uploadConfig

uploadRoute (optional)

Route called to send uploaded file. It's recommended to not change this parameter except if you know exactly what you do.

Default value: api_upload

uploadUrl (required)

Absolute url to directory where put uploaded image. I recommend you to create a function in your entity and call it like it's showen in the example:

public function getUploadRootDir()
{
    // absolute path to your directory where images must be saved
    return __DIR__.'/../../../../../web/'.$this->getUploadDir();
}

public function getUploadDir()
{
    return 'uploads/myentity';
}

public function getAbsolutePath()
{
    return null === $this->image ? null : $this->getUploadRootDir().'/'.$this->image;
}

public function getWebPath()
{
    return null === $this->image ? null : '/'.$this->getUploadDir().'/'.$this->image;
}

webDir (required)

Url used to show your image in templates, must be relative url. If you created related functions as explained in uploadUrl section, then you can user getWebPath() function for webDir parameter.

fileExt (optional)

Permitted image extensions.

Default value: '.jpg;.gif;.png;.jpeg'

libraryDir (optional)

Directory to look into for images to show in image library.

Default value: uploadUrl

libraryRoute (optional)

Route called to get images to show in library. I recommend you to not change this parameter if you don't know exactly what it does.

Default value: api_image_library

showLibrary (optional)

Set this to false if you don't want the user see existing images in libraryDir.

Default value: true

saveOriginal (optional)

Use this parameter if you want to save original file's path (for eg. to show big image in a lightbox). You have to put property name of your entity and the bundle will use it to save original file path in it.

Attention: This parameter is disabled for gallery for instance. It will be implemented soon.

Default value: false

generateFilename (optional)

This parameter is used to generate an uniq file name. Setted to false, it will keep the original filename.

Default value: true

cropConfig

minWidth (optional)

Minimum with of desired image.

Default value: 1

minHeight (optional)

Minimum height of desired image.

Default value: 1

aspectRatio (optional)

True to aspect ratio of crop screen.

Default value: true

cropRoute (optional)

Route to crop action. I recommend you to not change this parameter if you don't know exactly what it does.

Default value: api_crop

forceResize (optional)

If true, system will resize image to fit minWidth and minHeight.

thumbs (optional)

Array of thums to create automaticly. System will resize images to fit maxWidth and maxHeight. It will put them in "uploadDir/cropped_images_dir/thumbs_dir/widthxheight-originalfilename.extension" so you can use included Thumb Twig extension to get them, ex:

New in 0.2.2: You can use 'useAsFieldImage' option to use this thumb as image field's preview (in your form you will see this thumb instead of original cropped image). Usefull when you have big cropped images.

TODO LIST


All versions of image-bundle with dependencies

PHP Build Version
Package Version
Requires php Version >=5.3.2
ext-gd Version *
symfony/http-foundation Version ~2.2|3.*
symfony/form Version ~2.2|3.*
symfony/validator Version ~2.2|3.*
symfony/routing Version ~2.2|3.*
symfony/config Version ~2.2|3.*
symfony/twig-bridge Version ~2.2|3.*
symfony/class-loader Version ~2.2|3.*
twig/twig Version ~1.12
twig/extensions Version ~1.0
friendsofsymfony/jsrouting-bundle Version @stable
jms/translation-bundle Version ^1.2.2
Composer command for our command line client (download client) This client runs in each environment. You don't need a specific PHP version etc. The first 20 API calls are free. Standard composer command

The package codeneuss/image-bundle contains the following files

Loading the files please wait ....