All Downloads are FREE. Search and download functionalities are using the official Maven repository.

package.src.vaadin-upload.js Maven / Gradle / Ivy

There is a newer version: 24.5.3
Show newest version
/**
 * @license
 * Copyright (c) 2016 - 2024 Vaadin Ltd.
 * This program is available under Apache License Version 2.0, available at https://vaadin.com/license/
 */
import '@vaadin/button/src/vaadin-button.js';
import './vaadin-upload-icon.js';
import './vaadin-upload-icons.js';
import './vaadin-upload-file-list.js';
import { html, PolymerElement } from '@polymer/polymer/polymer-element.js';
import { ControllerMixin } from '@vaadin/component-base/src/controller-mixin.js';
import { defineCustomElement } from '@vaadin/component-base/src/define.js';
import { ElementMixin } from '@vaadin/component-base/src/element-mixin.js';
import { ThemableMixin } from '@vaadin/vaadin-themable-mixin/vaadin-themable-mixin.js';
import { UploadMixin } from './vaadin-upload-mixin.js';

/**
 * `` is a Web Component for uploading multiple files with drag and drop support.
 *
 * Example:
 *
 * ```
 * 
 * ```
 *
 * ### Styling
 *
 * The following shadow DOM parts are available for styling:
 *
 * Part name          | Description
 * -------------------|-------------------------------------
 * `primary-buttons`  | Upload container
 * `drop-label`       | Element wrapping drop label and icon
 *
 * The following state attributes are available for styling:
 *
 * Attribute | Description | Part name
 * ---|---|---
 * `nodrop` | Set when drag and drop is disabled (e. g., on touch devices) | `:host`
 * `dragover` | A file is being dragged over the element | `:host`
 * `dragover-valid` | A dragged file is valid with `maxFiles` and `accept` criteria | `:host`
 * `max-files-reached` | The maximum number of files that the user is allowed to add to the upload has been reached | `:host`
 *
 * See [Styling Components](https://vaadin.com/docs/latest/styling/styling-components) documentation.
 *
 * @fires {CustomEvent} file-reject - Fired when a file cannot be added to the queue due to a constrain.
 * @fires {CustomEvent} files-changed - Fired when the `files` property changes.
 * @fires {CustomEvent} max-files-reached-changed - Fired when the `maxFilesReached` property changes.
 * @fires {CustomEvent} upload-before - Fired before the XHR is opened.
 * @fires {CustomEvent} upload-start - Fired when the XHR is sent.
 * @fires {CustomEvent} upload-progress - Fired as many times as the progress is updated.
 * @fires {CustomEvent} upload-success - Fired in case the upload process succeeded.
 * @fires {CustomEvent} upload-error - Fired in case the upload process failed.
 * @fires {CustomEvent} upload-request - Fired when the XHR has been opened but not sent yet.
 * @fires {CustomEvent} upload-response - Fired when on the server response before analyzing it.
 * @fires {CustomEvent} upload-retry - Fired when retry upload is requested.
 * @fires {CustomEvent} upload-abort - Fired when upload abort is requested.
 *
 * @customElement
 * @extends HTMLElement
 * @mixes ControllerMixin
 * @mixes ThemableMixin
 * @mixes ElementMixin
 * @mixes UploadMixin
 */
class Upload extends UploadMixin(ElementMixin(ThemableMixin(ControllerMixin(PolymerElement)))) {
  static get template() {
    return html`
      

      
`; } static get is() { return 'vaadin-upload'; } /** * Fired when a file cannot be added to the queue due to a constrain: * file-size, file-type or maxFiles * * @event file-reject * @param {Object} detail * @param {Object} detail.file the file added * @param {string} detail.error the cause */ /** * Fired before the XHR is opened. Could be used for changing the request * URL. If the default is prevented, then XHR would not be opened. * * @event upload-before * @param {Object} detail * @param {Object} detail.xhr the xhr * @param {Object} detail.file the file being uploaded * @param {Object} detail.file.uploadTarget the upload request URL, initialized with the value of vaadin-upload `target` property */ /** * Fired when the XHR has been opened but not sent yet. Useful for appending * data keys to the FormData object, for changing some parameters like * headers, etc. If the event is defaultPrevented, `vaadin-upload` will not * send the request allowing the user to do something on his own. * * @event upload-request * @param {Object} detail * @param {Object} detail.xhr the xhr * @param {Object} detail.file the file being uploaded * @param {Object} detail.formData the FormData object */ /** * Fired when the XHR is sent. * * @event upload-start * @param {Object} detail * @param {Object} detail.xhr the xhr * @param {Object} detail.file the file being uploaded */ /** * Fired as many times as the progress is updated. * * @event upload-progress * @param {Object} detail * @param {Object} detail.xhr the xhr * @param {Object} detail.file the file being uploaded with loaded info */ /** * Fired when we have the actual server response, and before the component * analyses it. It's useful for developers to make the upload fail depending * on the server response. If the event is defaultPrevented the vaadin-upload * will return allowing the user to do something on his own like retry the * upload, etc. since he has full access to the `xhr` and `file` objects. * Otherwise, if the event is not prevented default `vaadin-upload` continues * with the normal workflow checking the `xhr.status` and `file.error` * which also might be modified by the user to force a customized response. * * @event upload-response * @param {Object} detail * @param {Object} detail.xhr the xhr * @param {Object} detail.file the file being uploaded */ /** * Fired in case the upload process succeed. * * @event upload-success * @param {Object} detail * @param {Object} detail.xhr the xhr * @param {Object} detail.file the file being uploaded with loaded info */ /** * Fired in case the upload process failed. * * @event upload-error * @param {Object} detail * @param {Object} detail.xhr the xhr * @param {Object} detail.file the file being uploaded */ /** * Fired when retry upload is requested. If the default is prevented, then * retry would not be performed. * * @event upload-retry * @param {Object} detail * @param {Object} detail.xhr the previous upload xhr * @param {Object} detail.file the file being uploaded */ /** * Fired when retry abort is requested. If the default is prevented, then the * file upload would not be aborted. * * @event upload-abort * @param {Object} detail * @param {Object} detail.xhr the xhr * @param {Object} detail.file the file being uploaded */ } defineCustomElement(Upload); export { Upload };




© 2015 - 2024 Weber Informatics LLC | Privacy Policy