|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147 |
- # Plupload
-
- Plupload is a cross-browser multi-runtime file uploading API. Basically, a set of tools that will help you to
- build a reliable and visually appealing file uploader in minutes.
-
- Historically, Plupload comes from a dark and hostile age of no HTML5, hence all the alternative fallbacks,
- like Flash, Silverlight and Java (still in development). It is meant to provide an API, that
- will work anywhere and in any case, in one way or another. While having very solid fallbacks, Plupload
- is built with the future of HTML5 in mind.
-
- ### Table of Contents
- * [Backstory](https://github.com/moxiecode/plupload/blob/master/readme.md#backstory)
- * [Structure](https://github.com/moxiecode/plupload/blob/master/readme.md#structure)
- * [File API and XHR L2 pollyfills](https://github.com/moxiecode/moxie/blob/master/README.md)
- * [Plupload API](https://github.com/moxiecode/plupload/wiki/API)
- * [UI Widget](https://github.com/moxiecode/plupload/wiki/UI.Plupload)
- * [Queue Widget](https://github.com/moxiecode/plupload/wiki/pluploadQueue)
- * [Demos](https://github.com/jayarjo/plupload-demos/blob/master/README.md)
- * [Building Instructions](https://github.com/moxiecode/plupload/blob/master/readme.md#build)
- * [Getting Started](https://github.com/moxiecode/plupload/wiki/Getting-Started)
- * [Options](https://github.com/moxiecode/plupload/wiki/Options)
- * [Events](https://github.com/moxiecode/plupload/wiki/Uploader#wiki-events)
- * [Methods](https://github.com/moxiecode/plupload/wiki/Uploader#wiki-methods)
- * [Plupload in Your Language](https://github.com/moxiecode/plupload/wiki/Plupload-in-Your-Language)
- * [File Filters](https://github.com/moxiecode/plupload/wiki/File-Filters)
- * [Image Resizing on Client-Side](https://github.com/moxiecode/plupload/wiki/Image-Resizing-on-Client-Side)
- * [Chunking](https://github.com/moxiecode/plupload/wiki/Chunking)
- * [Upload to Amazon S3](https://github.com/moxiecode/plupload/wiki/Upload-to-Amazon-S3)
- * [FAQ](https://github.com/moxiecode/plupload/wiki/Frequently-Asked-Questions)
- * [Support](https://github.com/moxiecode/plupload/blob/master/readme.md##support)
- * [Create a Fiddle](https://github.com/moxiecode/plupload/wiki/Create-a-Fiddle)
- * [Contributing](https://github.com/moxiecode/plupload/blob/master/readme.md#contribute)
- * [License](https://github.com/moxiecode/plupload/blob/master/readme.md#license)
- * [Contact Us](http://www.moxiecode.com/contact.php)
-
- <a name="backstory" />
- ### Backstory
-
- Plupload started in a time when uploading a file in a responsive and customizable manner was a real pain.
- Internally, browsers only had the `input[type="file"]` element. It was ugly and clunky at the same time.
- One couldn't even change it's visuals, without hiding it and coding another one on top of it from scratch.
- And then there was no progress indication for the upload process... Sounds pretty crazy today.
-
- It was very logical for developers to look for alternatives and writing their own implementations, using
- Flash and Java, in order to somehow extend limited browser capabilities. And so did we, in our search for
- a reliable and flexible file uploader for
- our [TinyMCE](http://www.tinymce.com/index.php)'s
- [MCImageManager](http://www.tinymce.com/enterprise/mcimagemanager.php).
-
- Quickly enough though, Plupload grew big. It easily split into a standalone project.
- With major *version 2.0* it underwent another huge reconstruction, basically
- [from the ground up](http://blog.moxiecode.com/2012/11/28/first-public-beta-plupload-2/),
- as all the low-level runtime logic has been extracted into separate [File API](http://www.w3.org/TR/FileAPI/)
- and [XHR L2](http://www.w3.org/TR/XMLHttpRequest/) pollyfills (currently known under combined name of [mOxie](https://github.com/moxiecode/moxie)),
- giving Plupload a chance to evolve further.
-
- <a name="structure" />
- ### Structure
-
- Currently, Plupload may be considered as consisting of three parts: low-level pollyfills,
- Plupload API and Widgets (UI and Queue). Initially, Widgets were meant only to serve as examples
- of the API, but quickly formed into fully-functional API implementations that now come bundled with
- the Plupload API. This has been a source for multiple misconceptions about the API as Widgets were
- easily mistaken for the Plupload itself. They are only implementations, such as any of you can
- build by yourself out of the API.
-
- * [Low-level pollyfills (mOxie)](https://github.com/moxiecode/moxie) - have their own [code base](https://github.com/moxiecode/moxie) and [documentation](https://github.com/moxiecode/moxie/wiki) on GitHub.
- * [Plupload API](https://github.com/moxiecode/plupload/wiki/API)
- * [UI Widget](https://github.com/moxiecode/plupload/wiki/UI.Plupload)
- * [Queue Widget](https://github.com/moxiecode/plupload/wiki/pluploadQueue)
-
- <a name="build" />
- ### Building instructions
-
- Plupload depends on File API and XHR2 L2 pollyfills that currently have their
- [own repository](https://github.com/moxiecode/moxie) on GitHub. However, in most cases you shouldn't
- care as we bundle the latest build of mOxie, including full and minified JavaScript source and
- pre-compiled `SWF` and `XAP` components, with [every release](https://github.com/moxiecode/plupload/releases). You can find everything you may need under `js/` folder.
-
- There are cases where you might need a custom build, for example free of unnecessary runtimes, half the
- original size, etc. The difficult part of this task comes from mOxie and its set of additional runtimes
- that require special tools on your workstation in order to compile.
- Consider [build instructions for mOxie](https://github.com/moxiecode/moxie#build-instructions) -
- everything applies to Plupload as well.
-
- First of all, if you want to build custom Plupload packages you will require [Node.js](http://nodejs.org/),
- as this is our build environment of choice. Node.js binaries (as well as Source)
- [are available](http://nodejs.org/download/) for all major operating systems.
-
- Plupload includes _mOxie_ as a submodule, it also depends on some other repositories for building up it's dev
- environment - to avoid necessity of downloading them one by one, we recommended you to simply clone Plupload
- with [git](http://git-scm.com/) recursively (you will require git installed on your system for this operation
- to succeed):
-
- ```
- git clone --recursive https://github.com/moxiecode/plupload.git
- ```
-
- And finalize the preparation stage with: `npm install` - this will install all additional modules, including those
- required by dev and test environments. In case you would rather keep it minimal, add a `--production` flag.
-
- *Note:* Currently, for an unknown reason, locally installed Node.js modules on Windows, may not be automatically
- added to the system PATH. So, if `jake` commands below are not recognized you will need to add them manually:
-
- ```
- set PATH=%PATH%;%CD%\node_modules\.bin\
- ```
-
- <a name="support" />
- ### Support
-
- We are actively standing behind the Plupload and now that we are done with major rewrites and refactoring,
- the only real goal that we have ahead is making it as reliable and bulletproof as possible. We are open to
- all the suggestions and feature requests. We ask you to file bug reports if you encounter any. We may not
- react to them instantly, but we constantly bear them in my mind as we extend the code base.
-
- In addition to dedicated support for those who dare to buy our OEM licenses, we got
- [discussion boards](http://www.plupload.com/punbb/index.php), which is like an enormous FAQ,
- covering every possible application case. Of course, you are welcome to file a bug report or feature request,
- here on [GitHub](https://github.com/moxiecode/plupload/issues).
-
- Sometimes it is easier to notice the problem when bug report is accompained by the actual code. Consider providing
- [a Plupload fiddle](https://github.com/moxiecode/plupload/wiki/Create-a-Fiddle) for the troublesome code.
-
- <a name="contribute" />
- ### Contributing
-
- We are open to suggestions and code revisions, however there are some rules and limitations that you might
- want to consider first.
-
- * Code that you contribute will automatically be licensed under the LGPL, but will not be limited to LGPL.
- * Although all contributors will get the credit for their work, copyright notices will be changed to [Moxiecode Systems AB](http://www.moxiecode.com/).
- * Third party code will be reviewed, tested and possibly modified before being released.
-
- These basic rules help us earn a living and ensure that code remains Open Source and compatible with LGPL license. All contributions will be added to the changelog and appear in every release and on the site.
-
- An easy place to start is to [translate Plupload to your language](https://github.com/moxiecode/plupload/wiki/Plupload-in-Your-Language#contribute).
-
- You can read more about how to contribute at: [http://www.plupload.com/contributing](http://www.plupload.com/contributing)
-
- <a name="license" />
- ### License
-
- Copyright 2013, [Moxiecode Systems AB](http://www.moxiecode.com/)
- Released under [GPLv2 License](https://github.com/moxiecode/plupload/blob/master/license.txt).
-
- We also provide [commercial license](http://www.plupload.com/commercial.php).
|