dev-master
9999999-dev https://github.com/excelwebzone/EWZUploaderBundleThis bundle enhances the Symfony2 file upload experience using AjaxUpload library
MIT
The Requires
uploader
 Wallogit.com
                    
                    2017 © Pedro Peláez
                         Wallogit.com
                    
                    2017 © Pedro Peláez
                    
                    
                    
                    
                
                
            
This bundle enhances the Symfony2 file upload experience using AjaxUpload library
The EWZUploaderBundle enhances the Symfony2 file upload experience using the
AjaxUpload library., (*1)
To install EWZUploaderBundle with Composer just add the following to your
composer.json file:, (*2)
// composer.json
{
    // ...
    require: {
        // ...
        "excelwebzone/uploader-bundle": "master-dev"
    }
}
NOTE: Please replace master-dev in the snippet above with the latest stable
branch, for example 1.0.*., (*3)
Then, you can install the new dependencies by running Composer's update
command from the directory where your composer.json file is located:, (*4)
$ php composer.phar update
Now, Composer will automatically download all required files, and install them
for you. All that is left to do is to update your AppKernel.php file, and
register the new bundle:, (*5)
<?php
// in AppKernel::registerBundles()
$bundles = array(
    // ...
    new EWZ\Bundle\UploaderBundle\EWZUploaderBundle(),
    // ...
);
deps file (Symfony 2.0.x)First, checkout a copy of the code. Just add the following to the deps
file of your Symfony Standard Distribution:, (*6)
[EWZUploaderBundle]
    git=http://github.com/excelwebzone/EWZUploaderBundle.git
    target=/bundles/EWZ/Bundle/UploaderBundle
Then register the bundle with your kernel:, (*7)
<?php
// in AppKernel::registerBundles()
$bundles = array(
    // ...
    new EWZ\Bundle\UploaderBundle\EWZUploaderBundle(),
    // ...
);
Make sure that you also register the namespace with the autoloader:, (*8)
<?php
// app/autoload.php
$loader->registerNamespaces(array(
    // ...
    'EWZ'              => __DIR__.'/../vendor/bundles',
    // ...
));
Now use the vendors script to clone the newly added repositories
into your project:, (*9)
$ php bin/vendors install
The configuration is as easy as choosing an upload directory and setting default file permissions (like size and mime types):, (*10)
# app/config/config.yml
ewz_uploader:
    load_jquery: false
    media:
        max_size: 5120k
        mime_types: ['audio/wav', 'audio/x-wav', 'audio/wave', 'audio/x-pn-wav']
        dir: %kernel.root_dir%/../media
        folder: uploads
    url:
        upload: ewz_uploader_file_upload
        remove: ewz_uploader_file_remove
        download: ewz_uploader_file_download
NOTE:If you enabled load_jquery it will automatically include the library
directly from Google API., (*11)
NOTE:To disabled downloading files, just set download: false., (*12)
Congratulations! You're ready!, (*13)
Now that all configurations have been made, we will explore how you can integrate EWZUploaderBundle into your application. We will assume that you already have created a form type object that will include the uploader field. So All you need to do is:, (*14)
<?php
public function buildForm(FormBuilder $builder, array $options)
{
    // ...
    $builder->add('audio', 'ewz_uploader');
    // ...
}
You can also set special configuration for each field:, (*15)
<?php
public function buildForm(FormBuilder $builder, array $options)
{
    // ...
    $builder->add('audio', 'ewz_uploader', array(
        'max_size'     => '5120k',
        'mime_types'   => array(
            'audio/wav',
            'audio/x-wav',
            'audio/wave',
            'audio/x-pn-wav'
        ),
        'folder'       => 'music',
        'url_upload'   => $this->router->generate('ewz_uploader_file_upload'),
        'url_remove'   => $this->router->generate('ewz_uploader_file_remove'),
        'url_download' => $this->router->generate('ewz_uploader_file_download'),
    ));
    // ...
}
NOTE: Validate is simple, treat it like a hidden field., (*16)
Cool, now you are ready to add the form widget into your page:, (*17)
PHP:, (*18)
<?php
// load resources
echo $view['ewz_uploader']->initialize();
// ...
$view['form']->setTheme($form, array('EWZUploaderBundle:Form'));
echo $view['form']->widget($form['audio'], array(
    'mime_types' => array(
        'audio/wav',
        'audio/x-wav',
        'audio/wave',
        'audio/x-pn-wav'
    ),
));
Twig:, (*19)
{# load resources #}
{{ ewz_uploader_initialize() }}
{# ... #}
{% form_theme form 'EWZUploaderBundle:Form:ewz_uploader_widget.html.twig' %}
{{ form_widget(form.audio, { 'attr': {
    'mime_types': [
        'audio/wav',
        'audio/x-wav',
        'audio/wave',
        'audio/x-pn-wav'
    ],
} }) }}
        This bundle enhances the Symfony2 file upload experience using AjaxUpload library
MIT
uploader