Skip to content

Latest commit

 

History

History
136 lines (100 loc) · 4.8 KB

README.md

File metadata and controls

136 lines (100 loc) · 4.8 KB

Squiz Matrix Multiple File Upload jQuery Plugin

This plugin is for the Squiz Matrix CMS and when used in conjunction with an Asset Builder you can have simple and beautiful multiple file upload using jQuery and javascript.

MatrixUpload2 has the following features:

  • Multiple file upload using drag and drop or choosing the files.
  • Upload on mobile/tablet or desktop.
  • Simple integration with an Asset Builder.
  • Create Type enforcement. Won't let you upload files the Asset Builder doesn't allow.
  • Max file size upload enforcement based on your Squiz Matrix settings.
  • Two layouts to choose from
  • File upload progress
  • File information such as name, file size, etc.
  • Thumbnail image previews
  • Fully responsive layout

Coming soon:

  • Set attributes before uploading

Layouts

There are two layouts to choose from, ZSSMatrixLayoutGrid or ZSSMatrixLayoutList.

List

List

Grid

Grid

How It Works

  1. Create an Asset Builder.
  2. Configure Asset Types to Create. Choose only the types that you want to be allowed to upload.
  3. Set the Create Location.
  4. Add %create_form% to the Logged In or Not Logged In bodycopy.
  5. Include jquery.matrixupload2.js and matrixupload2.css in your page or Design file. Optionally include Font Awesome if you want icons to be used for various asset types (recommended).
  6. Include the plugin:

In the Logged In or Not Logged In bodycopy add the following script:

$('form[id*="asset_builder"]').matrixUpload();

Additional options can be included if you want to change the layout or use some of the callbacks:

$('form[id*="asset_builder"]').matrixUpload({
    progress: function(progress) {
        console.log(progress);	
    },
    filesSelected: function(files) {
        console.log(files.length);	
    }
});

Optional query parameters can be sent which will be appended to the URL when each asset is created. This can be used with Additional Create Locations and GET Variable Name.

$('form[id*="asset_builder"]').matrixUpload({
    queryParameters: {
        'root': '1234'
    }
});

To return the created asset id for each image, add the following to the Asset Builder Created bodycopy:

<div id="asset-id">%created_assetid%</div>

Use the returned response from the complete callback to capture the asset id:

$('form[id*="asset_builder"]').matrixUpload({
    complete: function(e, response) {
        console.log($(response).find('#asset-id').text());	
    }
});

Make sure to call the plugin inside of the jQuery ready method so that the DOM will be fully loaded.

Options

The full list of options that can be used:

Option Default Type Description
hideMatrixLabels true boolean Hides all labels that the Asset Builder includes.
showAttributes false boolean Shows attribute fields for each file. NOT READY FOR USE
uploadOnSelected true boolean If the files should upload after they are chosen. Else use an upload button.
layoutType ZSSMatrixLayoutGrid string Which layout to use. Options are ZSSMatrixLayoutGrid and ZSSMatrixLayoutList.
numColumns 6 number How many columns to use for the desktop layout. Mobile and tablet are automatic. Options are 1, 2, 3, 4, 6, 12.
errorFileTooLarge File size too large to upload string Label to use when a file is too large to upload
uploadButtonTitle Upload Files string Label to use for the upload button
concurrentUploads 4 number Number of uploads at one time. Max of 6 due to browser support.
queryParameters {} object Key/value pairs to send as part of the query string

Callbacks

| Callback | Returned objects | Description | | :------------- | :-------------| :----- | :----- | | filesSelected | files | Called when files are selected or dropped | | progress | progress | Progress of the upload | | start | e | When the upload starts for a file | | complete | e, reponseText | When the upload completes for a file | | failed | e | When the upload fails for a file | | canceled | e | When the upload is canceled for a file | | browserNotSupported | | If the browser does not support file upload using ajax |

Responsive

In order to have responsive layouts work for mobile and tablet, you must include the following viewport line into the head of your page:

<meta name="viewport" content="width=device-width, initial-scale=1">

Requirements

MatrixUpload2 requires jQuery 1.7 or later and a modern browser.