<?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/Form.php';
include_once $root . '/phpformbuilder/plugins/fileuploader/server/class.fileuploader.php';
function cleanDir($dir)
{
$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', 'tailwind');
$form->setMode('development');
$fileUpload_config = 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-2xl dark:text-white my-6');
$form->addHelper('Accepted File Types : .pdf, .doc[x], .xls[x], .txt', 'single-file', 'after');
$form->addFileUpload('single-file', '', 'Attach a file', '', $fileUpload_config);
$form->endFieldset();
$fileUpload_config = 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-2xl dark:text-white my-6');
$form->addHelper('3 files maximum. Accepted File Types : .pdf, .doc[x], .xls[x], .txt', 'multiple-files', 'after');
$form->addFileUpload('multiple-files', '', 'Upload your documents', '', $fileUpload_config);
$form->endFieldset();
$fileUpload_config = 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-2xl dark:text-white my-6');
$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', '', $fileUpload_config);
$form->endFieldset();
$current_file = '';
$current_file_path = $root . '/file-uploads/images/';
$current_file_name = 'art-creative-metal-creativity.jpg';
if (file_exists($current_file_path . $current_file_name)) {
$current_file_size = filesize($current_file_path . $current_file_name);
$current_file_type = mime_content_type($current_file_path . $current_file_name);
$current_file = array(
'name' => $current_file_name,
'size' => $current_file_size,
'type' => $current_file_type,
'file' => '/file-uploads/images/' . $current_file_name,
'data' => array(
'listProps' => array(
'file' => $current_file_name
)
)
);
}
$fileUpload_config = 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-2xl dark:text-white my-6');
$form->addHelper('Accepted File Types : Accepted File Types : .jp[e]g, .png, .gif', 'prefilled-uploader', 'after');
$form->addFileUpload('prefilled-uploader', '', 'Your image', 'required', $fileUpload_config, $current_file);
$form->endFieldset();
$fileUpload_config = 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-2xl dark:text-white my-6');
$form->addHelper('Accepted File Types : .pdf, .doc[x], .xls[x], .txt', 'drag-and-drop', 'after');
$form->addFileUpload('drag-and-drop', '', 'Drag and drop', '', $fileUpload_config);
$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>Tailwind File Upload Form - How to create PHP forms easily</title>
<meta name="description" content="Tailwind Form Generator - how to create a File Upload with Php Form Builder">
<link rel="canonical" href="https://www.phpformbuilder.pro/templates/tailwind-forms/fileupload-test-form.php" />
<script src="https://cdn.tailwindcss.com"></script>
<link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.15.4/css/solid.css" integrity="sha384-Tv5i09RULyHKMwX0E8wJUqSOaXlyu3SQxORObAI08iUwIalMmN5L6AvlPX2LMoSE" crossorigin="anonymous">
<link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.15.4/css/fontawesome.css" integrity="sha384-jLKHWM3JRmfMU0A5x5AkjWkw/EYfGUAGagvnfryNV3F9VqM98XiIH7VBGVoxVSc7" 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 mx-auto md:px-5 lg:px-10 xl:px-48">
<div class="grid-cols-1">
<div class="text-center mb-10">
<a href="https://www.phpformbuilder.pro/documentation/javascript-plugins.php#fileuploader" class="text-white bg-gray-700 hover:bg-gray-800 focus:ring-4 focus:ring-gray-300 font-medium rounded-lg text-sm px-5 py-2.5 text-center mr-2 mb-2 dark:bg-gray-600 dark:hover:bg-gray-700 dark:focus:ring-gray-900 btn-sm"><strong>File uploader plugin</strong> - documentation here <i class="fas fa-arrow-right ml-4"></i></a>
</div>
<?php
$form->render();
?>
</div>
</div>
<script src=" https://code.jquery.com/jquery-3.6.0.min.js" integrity="sha256-/xUj+3OJU5yExlq6GSYGSHk7tPXikynS7ogEvDej/m4=" 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>