An enhanced HTML 5 file input for Bootstrap 5.x/4.x./3.x with file preview, multiple selection, and more features.
fork from : https://github.com/kartik-v/bootstrap-fileinput.git

Kartik Visweswaran 408cf042fb Updated preview template 11 năm trước cách đây
css b6b2b0e452 Updated plugin functionality 11 năm trước cách đây
examples c666314215 Completed documentation 11 năm trước cách đây
js 1c6f033b42 Updated documentation and IE typos 11 năm trước cách đây
CHANGE.md 587d4a6c7e Updated change log 11 năm trước cách đây
LICENSE.md b6b2b0e452 Updated plugin functionality 11 năm trước cách đây
README.md 408cf042fb Updated preview template 11 năm trước cách đây
bower.json 37daa259fe Updated keywords 11 năm trước cách đây
composer.json 37daa259fe Updated keywords 11 năm trước cách đây

README.md

bootstrap-fileinput

An enhanced HTML 5 file input for Bootstrap 3.x with file preview for images and text, multiple selection, and more. This plugin is inspired by this blog article and Jasny's File Input plugin. The plugin enhances these concepts and simplifies the widget initialization with simple HTML markup on a file input. It also offers support for multiple file preview and previewing both images and text types.

Features

  1. The plugin will convert a simple HTML file input to an advanced file picker control. Will help fallback to a normal HTML file input for browsers not supporting JQuery or Javascript.
  2. The file input consists of the following three sections with options and templates to control the display:
    • file caption section: to display a brief information of the file(s) selected
    • file action buttons section: to browse, remove, and upload files.
    • file preview section: to display the selected files on client for preview (supports images and text file types). Other file types will be displayed as normal thumbnails.
  3. The plugin automatically converts an input with type = file to an advanced file picker input if you set its class = file. All options to the input can be passed as HTML5 data attributes.
  4. Ability to select and preview multiple files. Uses HTML 5 File reader API to read and preview files. Displays the progress of files being being loaded onto the preview zone, in case many files are chosen.
  5. Offers predefined templates and CSS classes which can be changed to style your file-input display as per your needs.
  6. Option to show/hide any or all of the following:
    • caption section
    • preview section
    • upload button
    • remove button
  7. Customise the location of the target container elements to display the entire plugin, the caption container, the caption text, the preview container, preview image, and preview status.
  8. For text file previews, autowrap the text to the thumbnail width, and show a wrap indicator link to display complete text on hover. You can customize the wrap indicator (which defaults to …).
  9. Customise the messages for preview, progress, and files selected.
  10. Upload action defaults to form submit. Supports an upload route/server action parameter for custom ajax based upload.
  11. Triggers JQuery events for advanced development. Events currently available are filereset and fileclear.
  12. Disabled and readonly file input support.
  13. Size of the entire plugin is less than 11KB (about 9KB for the minified JS and 2KB for the minified CSS).

Demo

View the plugin documentation and plugin demos at Krajee JQuery plugins.

Pre-requisites

  1. Bootstrap 3.x
  2. Latest JQuery
  3. Most modern browsers supporting HTML5 file inputs and FileReader API including CSS3 & JQuery. For Internet Explorer, one must use IE versions 10 and above. IE9 and below will work as a normal file input, and will not support multiple file selection or the HTML 5 FileReader API.

Restrictions

The plugin supports only file input and preview at client level. It does not actually process the upload of the files to the server.

Installation

Using Bower

You can use the bower package manager to install. Run:

bower install bootstrap-fileinput

Using Composer

You can use the composer package manager to install. Either run:

$ php composer.phar require kartik-v/bootstrap-fileinput "dev-master"

or add:

"kartik-v/bootstrap-fileinput": "dev-master"

to your composer.json file

Manual Install

You can also manually install the plugin easily to your project. Just download the source ZIP or TAR ball and extract the plugin assets (css and js folders) into your project.

Usage

Step 1: Load the following assets in your header.

<link href="http://netdna.bootstrapcdn.com/bootstrap/3.1.0/css/bootstrap.min.css" rel="stylesheet">
<link href="path/to/css/fileinput.min.css" media="all" rel="stylesheet" type="text/css" />
<script src="//ajax.googleapis.com/ajax/libs/jquery/1.11.0/jquery.min.js"></script>
<script src="path/to/js/fileinput.min.js" type="text/javascript"></script>

If you noticed, you need to load the jquery.min.js and bootstrap.min.css in addition to the fileinput.min.css and fileinput.min.js.

Step 2: Initialize the plugin on your page. For example,

// initialize with defaults
$("#input-id").fileinput();

// with plugin options
$("#input-id").fileinput({'showUpload':false, 'previewFileType':'any'});

The #input-id is the identifier for the input (e.g. type = file) on your page, which is hidden automatically by the plugin.

Alternatively, you can directly call the plugin options by setting data attributes to your input field.

<input id="input-id" type="file" class="file" data-preview-file-type="text" >

Documentation

Plugin Options

The plugin supports these following options:

showCaption

boolean whether to display the file caption. Defaults to true.

showPreview

boolean whether to display the file preview. Defaults to true.

showRemove

boolean whether to display the file remove/clear button. Defaults to true.

showUpload

boolean whether to display the file upload button. Defaults to true. This will default to a form submit button, unless the uploadUrl is specified.

captionClass

string any additional CSS class to append to the caption container.

previewClass

string any additional CSS class to append to the preview container.

mainClass

string any additional CSS class to append to the main plugin container.

mainTemplate

string the template used to render the widget. The following template variables will be parsed:

  • {class}: any additional CSS class to append to the main widget container.
  • {preview}: the content parsed by the previewTemplate and will be displayed only if showPreview is true.
  • {caption}: the content parsed by the captionTemplate and will be displayed only if showCaption is true.
  • {remove}: the file remove/clear button and will be displayed only if showRemove is true.
  • {upload}: the file upload button and will be displayed only if showUpload is true.
  • {browse}: the main file browse button to select your files for input.

The mainTemplate if not passed, will be automatically set based on showCaption settings.

  • If showCaption is set to true, the mainTemplate will default to:

    {preview}\n
    <div class="input-group {class}">\n
    {caption}\n
    <div class="input-group-btn">\n
       {remove}\n
       {upload}\n
       {browse}\n
    </div>\n
    </div>\n
    
    • If showCaption is set to false, the mainTemplate will default to: html {preview}\n{remove}\n{upload}\n{browse}\n

captionTemplate

string the template used to render the caption. The following template variables will be parsed:

  • {class}: any additional CSS class to append to the caption container.

The captionTemplate if not set will default to:

<div class="form-control file-caption {class}">\n
   <span class="glyphicon glyphicon-file"></span> <span class="file-caption-name"></span>\n
</div>

previewTemplate

string the template used to render the preview. The following template variables will be parsed:

  • {class}: any additional CSS class to append to the preview container.

The previewTemplate if not set will default to:

<div class="file-preview {class}">\n
   <div class="file-preview-status text-center text-success"></div>\n
   <div class="close fileinput-remove text-right">&times;</div>\n
   <div class="file-preview-thumbnails"></div>\n
   <div class="clearfix"></div> +
</div>

browseLabel

string the label to display for the file picker/browse button. Defaults to Browse &hellip;.

browseIcon

string the icon to display before the label for the file picker/browse button. Defaults to <i class="glyphicon glyphicon-folder-open"></i> &nbsp;.

browseClass

string the CSS class for the file picker/browse button. Defaults to btn btn-primary.

removeLabel

string the label to display for the file remove button. Defaults to Remove.

removeIcon

string the icon to display before the label for the file picker/remove button. Defaults to <i class="glyphicon glyphicon-ban-circle"></i> &nbsp;.

removeClass

string the CSS class for the file remove button. Defaults to btn btn-default.

uploadLabel

string the label to display for the file upload button. Defaults to Upload.

uploadIcon

string the icon to display before the label for the file upload button. Defaults to <i class="glyphicon glyphicon-upload"></i> &nbsp;.

uploadClass

string the CSS class for the file upload button. Defaults to btn btn-default.

uploadUrl

string the URL for the upload processing action (typically for ajax based processing). Defaults to null. If this is not set or null, then the upload button action will default to form submission.

msgLoading

string the message displayed when the files are getting read and loaded for preview. Defaults to Loading &hellip;.

msgProgress

string the progress message displayed as each file is loaded for preview. Defaults to Loaded {percent}% of {file}. The following variables will be replaced:

  • {percent}: the percentage of file read and loaded.
  • {file}: the name of the file being loaded.

msgSelected

string the progress message displayed in caption window when multiple (more than one) files are selected. Defaults to {n} files selected. The following variables will be replaced:

  • {n}: the number of files selected.

previewFileType

string the type of files that are to be displayed in the preview window. Defaults to image. Can be one of the following:

  • image: Only image type files will be shown in preview.
  • text: Only text type files will be shown in preview.
  • any: Both image and text files content will be shown in preview.

Files other than image or text will be displayed as a thumbnail with the filename in the preview window.

wrapTextLength

integer the number of characters after which the content will be stripped/wrapped for text preview. Defaults to 250.

wrapIndicator

string the type of files that are to be displayed in the preview window. Defaults to <span class="wrap-indicator" title="{title}">[&hellip;]</span>. The following variables will be replaced:

  • {title}: the content of the entire text file that will be displayed as a span title element.

elCaptionContainer

DOM Element the container element containing the caption. If not set, will default to the container with CSS class file-caption inside the main plugin container.

elCaptionText

DOM Element the container element containing the caption text. If not set, will default to the container with CSS class file-caption-name inside the main plugin container.

elPreviewContainer

DOM Element the container element containing the preview. If not set, will default to the container with CSS class file-preview inside the main plugin container.

elPreviewImage

DOM Element the container element containing the preview image thumbnails. If not set, will default to the container with CSS class file-preview-thumbnails inside the main plugin container.

elPreviewStatus

DOM Element the container element containing the preview progress status. If not set, will default to the container with CSS class file-preview-status inside the main plugin container.

Plugin Events

The plugin supports these events:

fileclear

This event is triggered when the file input is cleared with the remove button.

Example:

$('#input-id').on('fileclear', function(event) {
    console.log("fileclear");
});

filereset

This event is triggered when the file input is reset to initial value.

Example:

$('#input-id').on('filereset', function(event) {
    console.log("filereset");
});

Plugin Methods

The plugin supports these methods:

reset

Reset the file input.

$('#input-id').fileinput('reset');

clear

Clear the file input.

$('#input-id').fileinput('clear');

License

bootstrap-fileinput is released under the BSD 3-Clause License. See the bundled LICENSE.md for details.