265 lines
7.5 KiB
JavaScript
265 lines
7.5 KiB
JavaScript
const FileUploadProps = [
|
|
{
|
|
name: "name",
|
|
type: "string",
|
|
default: "null",
|
|
description: "Name of the request parameter to identify the files at backend."
|
|
},
|
|
{
|
|
name: "url",
|
|
type: "string",
|
|
default: "null",
|
|
description: "Remote url to upload the files."
|
|
},
|
|
{
|
|
name: "mode",
|
|
type: "string",
|
|
default: "advanced",
|
|
description: 'Defines the UI of the component, possible values are "advanced" and "basic".'
|
|
},
|
|
{
|
|
name: "multiple",
|
|
type: "boolean",
|
|
default: "false",
|
|
description: "Used to select multiple files at once from file dialog."
|
|
},
|
|
{
|
|
name: "accept",
|
|
type: "string",
|
|
default: "null",
|
|
description: 'Pattern to restrict the allowed file types such as "image/*".'
|
|
},
|
|
{
|
|
name: "disabled",
|
|
type: "boolean",
|
|
default: "false",
|
|
description: "Disables the upload functionality."
|
|
},
|
|
{
|
|
name: "auto",
|
|
type: "boolean",
|
|
default: "false",
|
|
description: "When enabled, upload begins automatically after selection is completed."
|
|
},
|
|
{
|
|
name: "maxFileSize",
|
|
type: "number",
|
|
default: "null",
|
|
description: "Maximum file size allowed in bytes."
|
|
},
|
|
{
|
|
name: "invalidFileSizeMessage",
|
|
type: "string",
|
|
default: '"{0}: Invalid file size, file size should be smaller than {1}."',
|
|
description: "Message of the invalid fize size."
|
|
},
|
|
{
|
|
name: "invalidFileTypeMessage",
|
|
type: "string",
|
|
default: '"{0}: Invalid file type, allowed file types: "{1}."'
|
|
},
|
|
{
|
|
name: "invalidFileLimitMessage",
|
|
type: "string",
|
|
default: "Maximum number of files exceeded, limit is {0} at most.",
|
|
description: "Message to display when number of files to be uploaded exceeeds the limit."
|
|
},
|
|
{
|
|
name: "fileLimit",
|
|
type: "number",
|
|
default: "null",
|
|
description: "Maximum number of files that can be uploaded."
|
|
},
|
|
{
|
|
name: "withCredentials",
|
|
type: "boolean",
|
|
default: "false",
|
|
description: "Cross-site Access-Control requests should be made using credentials such as cookies, authorization headers or TLS client certificates."
|
|
},
|
|
{
|
|
name: "previewWidth",
|
|
type: "number",
|
|
default: "50",
|
|
description: "Width of the image thumbnail in pixels."
|
|
},
|
|
{
|
|
name: "chooseLabel",
|
|
type: "string",
|
|
default: "null",
|
|
description: "Label of the choose button. Defaults to PrimeVue Locale configuration."
|
|
},
|
|
{
|
|
name: "uploadLabel",
|
|
type: "string",
|
|
default: "Upoad",
|
|
description: "Label of the upload button. Defaults to PrimeVue Locale configuration."
|
|
},
|
|
{
|
|
name: "cancelLabel",
|
|
type: "string",
|
|
default: "Cancel",
|
|
description: "Label of the cancel button. Defaults to PrimeVue Locale configuration."
|
|
},
|
|
{
|
|
name: "customUpload",
|
|
type: "boolean",
|
|
default: "false",
|
|
description: "Whether to use the default upload or a manual implementation defined in uploadHandler callback. Defaults to PrimeVue Locale configuration."
|
|
},
|
|
{
|
|
name: "showUploadButton",
|
|
type: "boolean",
|
|
default: "true",
|
|
description: "Whether to show the upload button."
|
|
},
|
|
{
|
|
name: "showCancelButton",
|
|
type: "boolean",
|
|
default: "true",
|
|
description: "Whether to cancel the upload button."
|
|
},
|
|
{
|
|
name: "buttonStyle",
|
|
type: "any",
|
|
default: "null",
|
|
description: "Inline style of the component."
|
|
},
|
|
{
|
|
name: "buttonClass",
|
|
type: "string",
|
|
default: "null",
|
|
description: "Style class of the component."
|
|
}
|
|
];
|
|
|
|
const FileUploadEvents = [
|
|
{
|
|
name: "before-upload",
|
|
description: "Callback to invoke before file upload begins to customize the request such as post parameters before the files.",
|
|
arguments: [
|
|
{
|
|
name: "event.xhr",
|
|
type: "object",
|
|
description: "XmlHttpRequest instance."
|
|
},
|
|
{
|
|
name: "event.formData",
|
|
type: "object",
|
|
description: "FormData object."
|
|
}
|
|
]
|
|
},
|
|
{
|
|
name: "before-send",
|
|
description: "Callback to invoke before file send begins to customize the request such as adding headers.",
|
|
arguments: [
|
|
{
|
|
name: "event.xhr",
|
|
type: "object",
|
|
description: "XmlHttpRequest instance."
|
|
},
|
|
{
|
|
name: "event.formData",
|
|
type: "object",
|
|
description: "FormData object."
|
|
}
|
|
]
|
|
},
|
|
{
|
|
name: "upload",
|
|
description: "Callback to invoke when file upload is complete.",
|
|
arguments: [
|
|
{
|
|
name: "event.xhr",
|
|
type: "object",
|
|
description: "XmlHttpRequest instance."
|
|
},
|
|
{
|
|
name: "event.files",
|
|
type: "object",
|
|
description: "Uploaded files."
|
|
}
|
|
]
|
|
},
|
|
{
|
|
name: "error",
|
|
description: "Callback to invoke if file upload fails.",
|
|
arguments: [
|
|
{
|
|
name: "event.xhr",
|
|
type: "object",
|
|
description: "XmlHttpRequest instance."
|
|
},
|
|
{
|
|
name: "event.files",
|
|
type: "object",
|
|
description: "Files that are not uploaded."
|
|
}
|
|
]
|
|
},
|
|
{
|
|
name: "clear",
|
|
description: "Callback to invoke when files in queue are removed without uploading."
|
|
},
|
|
{
|
|
name: "select",
|
|
description: "Callback to invoke when file upload is complete.",
|
|
arguments: [
|
|
{
|
|
name: "event.originalEvent",
|
|
type: "object",
|
|
description: "Original browser event."
|
|
},
|
|
{
|
|
name: "event.files",
|
|
type: "object",
|
|
description: "List of selected files."
|
|
}
|
|
]
|
|
},
|
|
{
|
|
name: "progress",
|
|
description: "Callback to invoke when files are selected.",
|
|
arguments: [
|
|
{
|
|
name: "event.originalEvent",
|
|
type: "object",
|
|
description: "Original browser event."
|
|
},
|
|
{
|
|
name: "event.progress",
|
|
type: "number",
|
|
description: "Calculated progress value."
|
|
}
|
|
]
|
|
},
|
|
{
|
|
name: "uploader",
|
|
description: "Callback to invoke to implement a custom upload.",
|
|
arguments: [
|
|
{
|
|
name: "event.files",
|
|
type: "object",
|
|
description: "List of selected files."
|
|
}
|
|
]
|
|
}
|
|
];
|
|
|
|
const FileUploadSlots = [
|
|
{
|
|
name: "empty",
|
|
description: "Custom content when there is no selected file"
|
|
}
|
|
];
|
|
|
|
module.exports = {
|
|
fileupload: {
|
|
name: "FileUpload",
|
|
description: "FileUpload is an advanced uploader with dragdrop support, multi file uploads, auto uploading, progress tracking and validations.",
|
|
props: FileUploadProps,
|
|
events: FileUploadEvents,
|
|
slots: FileUploadSlots
|
|
}
|
|
};
|