<?php
use fileuploader\server\FileUploader;
use phpformbuilder\Form;
use phpformbuilder\Validator\Validator;
$root = rtrim($_SERVER['DOCUMENT_ROOT'], DIRECTORY_SEPARATOR);
session_start();
include_once $root . '/phpformbuilder/autoload.php';
function cleanDir($dir)
{
if ($files = glob($dir)) {
foreach ($files as $file) {
if (is_file($file) && basename($file) != 'art-creative-metal-creativity.jpg' && (time() - filectime($file) > 3600)) {
unlink($file);
}
}
}
}
cleanDir($root . '/file-uploads/images/thumbs/lg/*');
cleanDir($root . '/file-uploads/images/thumbs/md/*');
cleanDir($root . '/file-uploads/images/thumbs/sm/*');
cleanDir($root . '/file-uploads/images/*');
cleanDir($root . '/file-uploads/*');
if ($_SERVER['SERVER_NAME'] == 'www.phpformbuilder.pro' && !file_exists($root . '/file-uploads/images/art-creative-metal-creativity.jpg')) {
copy($root . '/assets/images/art-creative-metal-creativity.jpg', $root . '/file-uploads/images/art-creative-metal-creativity.jpg');
}
$form = new Form('fileupload-test-form', 'horizontal', 'novalidate', 'bs4');
$form->setMode('development');
$fileUploadConfig = array(
'upload_dir' => '../../../../../file-uploads/',
'limit' => 1,
'file_max_size' => 2,
'extensions' => ['pdf', 'doc', 'docx', 'xls', 'xlsx', 'txt'],
'debug' => true
);
$form->startFieldset('Single file upload', '', 'class=text-center mb-4');
$form->addHelper('Accepted File Types : .pdf, .doc[x], .xls[x], .txt', 'single-file');
$form->addFileUpload('single-file', '', 'Attach a file', '', $fileUploadConfig);
$form->endFieldset();
$fileUploadConfig = array(
'upload_dir' => '../../../../../file-uploads/',
'limit' => 3,
'file_max_size' => 2,
'extensions' => ['pdf', 'doc', 'docx', 'xls', 'xlsx', 'txt'],
'debug' => true
);
$form->startFieldset('Multiple files upload', '', 'class=text-center mb-4');
$form->addHelper('3 files maximum. Accepted File Types : .pdf, .doc[x], .xls[x], .txt', 'multiple-files');
$form->addFileUpload('multiple-files', '', 'Upload your documents', '', $fileUploadConfig);
$form->endFieldset();
$fileUploadConfig = array(
'xml' => 'image-upload',
'uploader' => 'ajax_upload_file.php',
'upload_dir' => '../../../../../file-uploads/images/',
'limit' => 3,
'file_max_size' => 2,
'extensions' => ['jpg', 'jpeg', 'png', 'gif'],
'thumbnails' => true,
'editor' => true,
'width' => 960,
'height' => 720,
'crop' => false,
'debug' => true
);
$form->startFieldset('Multiple images upload with resizing, thumbnails and image editor (crop/rotate)', '', 'class=text-center mb-4');
$form->addHtml('<p>The uploader resizes the uploaded image (960px * 720px), then generates large, medium & small thumbnails for each uploaded image.</p>');
$form->addHelper('3 files max. Accepted File Types : .jp[e]g, .png, .gif<br>Click on the uploaded preview image to crop/rotate.', 'uploaded-images');
$form->addFileUpload('uploaded-images', '', 'Upload up to 3 images', '', $fileUploadConfig);
$form->endFieldset();
$currentFile = [];
$currentFile_path = $root . '/file-uploads/images/';
$currentFile_name = 'art-creative-metal-creativity.jpg';
if (file_exists($currentFile_path . $currentFile_name)) {
$currentFile_size = filesize($currentFile_path . $currentFile_name);
$currentFile_type = mime_content_type($currentFile_path . $currentFile_name);
$currentFile = array(
'name' => $currentFile_name,
'size' => $currentFile_size,
'type' => $currentFile_type,
'file' => '/file-uploads/images/' . $currentFile_name,
'data' => array(
'listProps' => array(
'file' => $currentFile_name
)
)
);
}
$fileUploadConfig = array(
'xml' => 'image-upload',
'uploader' => 'ajax_upload_file.php',
'upload_dir' => '../../../../../file-uploads/images/',
'limit' => 1,
'file_max_size' => 2,
'extensions' => ['jpg', 'jpeg', 'png'],
'thumbnails' => true,
'editor' => true,
'width' => 960,
'height' => 720,
'crop' => false,
'debug' => true
);
$form->startFieldset('Prefilled upload with existing image', '', 'class=text-center mb-4');
$form->addHelper('Accepted File Types : Accepted File Types : .jp[e]g, .png, .gif', 'prefilled-uploader');
$form->addFileUpload('prefilled-uploader', '', 'Your image', 'required', $fileUploadConfig, $currentFile);
$form->endFieldset();
$fileUploadConfig = array(
'xml' => 'drag-and-drop',
'upload_dir' => '../../../../../file-uploads/',
'limit' => 2,
'file_max_size' => 2,
'extensions' => ['pdf', 'doc', 'docx', 'xls', 'xlsx', 'txt'],
'debug' => true
);
$form->startFieldset('Drag and drop', '', 'class=text-center mb-4');
$form->addHelper('Accepted File Types : .pdf, .doc[x], .xls[x], .txt', 'drag-and-drop');
$form->addFileUpload('drag-and-drop', '', 'Drag and drop', '', $fileUploadConfig);
$form->endFieldset();
$form->addPlugin('formvalidation', '#fileupload-test-form');
?>
<!DOCTYPE html>
<html lang="en-US">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
<title>Bootstrap 4 File Upload Form - How to create PHP forms easily</title>
<meta name="description" content="Bootstrap 4 Form Generator - how to create a File Upload with Php Form Builder">
<link rel="canonical" href="https://www.phpformbuilder.pro/templates/bootstrap-4-forms/fileupload-test-form.php" />
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@4.6.0/dist/css/bootstrap.min.css" integrity="sha384-B0vP5xmATw1+K9KRQjQERJvTumQW0nPEzvF6L/Z6nronJ3oUOFUFpCjEUQouq2+l" crossorigin="anonymous">
<?php $form->printIncludes('css'); ?>
<style>
form fieldset {
background: #fafafa;
padding: 0 20px;
margin-bottom: 60px;
}
fieldset legend {
padding: 10px 20px;
margin: 0 -20px 20px;
width: calc(100% + 40px);
color: #fff;
background: #3E5DC2;
}
</style>
</head>
<body>
<h1 class="text-center">Php Form Builder - File Upload Form<br><small>Upload documents or images</small></h1>
<div class="container">
<div class="row justify-content-center">
<div class="col-md-11 col-lg-10">
<div class="text-center mb-5">
<a href="https://www.phpformbuilder.pro/documentation/javascript-plugins.php#fileuploader" class="btn btn-secondary btn-sm"><strong>File uploader plugin</strong> - documentation here <i class="fas fa-arrow-right ml-2"></i></a>
</div>
<?php
$form->render();
?>
</div>
</div>
</div>
<script src="https://code.jquery.com/jquery-3.6.0.min.js" integrity="sha256-/xUj+3OJU5yExlq6GSYGSHk7tPXikynS7ogEvDej/m4=" crossorigin="anonymous"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.7/umd/popper.min.js" integrity="sha384-UO2eT0CpHqdSJQ6hJty5KVphtPhzWj9WO1clHTMGa3JDZwrnQq4sF86dIHNDz0W1" crossorigin="anonymous">
</script>
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js" integrity="sha384-JjSmVgyd0p3pXB1rRibZUAYoIIy6OrQ6VrjIEaFf/nJGzIxFDsf4x0xIM+B07jRM" crossorigin="anonymous">
</script>
<?php
$form->printIncludes('js');
$form->printJsCode();
?>
<script>
var fvCallback = function() {
var form = forms['fileupload-test-form'];
form.fv.addField(
'prefilled-uploader', {
validators: {
notEmpty: {
message: 'file is required'
}
}
}
).removeField('uploader-prefilled-uploader');
};
</script>
</body>
</html>