Minimal Photo Upload
Welcome to the minimal photo upload guide! This app allows any user to scan a barcode that acts as a order number, add a name, attach up to ten photos and send them to an on-premise computer (acting as a receiver of the photos).
Frontend

The frontend features a form to enter an order id (can alternatively be scanned from a barcode) and a name. The user can then upload photos from a gallery or the file system or directly take them with the camera. When all information is available the Save to Server
button gets active and the files are transferred to the builder's computer (running a native file agent).
Backend

The optionally scanned barcode uses the
autofill
command to send its data directly to the form.The form data itself is received via an
echo
function, this way it can be triggered on page-load and the connected validation routine will be triggered (important to enable the upload button)Another
echo
functions retrieves the uploaded images / photos. Crucially, it uses theFile
storage option as camera images can be huge (> 5MB) each and buffers perform poorly on such large entities.The
combine
function does a live-validation whenever any of the input (form or photos) change and uses thetoggle
command to set the button according to the simple modifier logic.The
readFileToBuffer
actually must be dragged from the native file agent. It receives an array of pathes from the uploader widget and processes them one-by-one into a base64 buffer (on the backend) to subsequently write them to theimage
directory. When specified this way the path is interpreted relative to the native agent's executableFor improved UI the upload button will show an animation until the files arrived on the server (calling
done
on the button does this trick) and the widgets are cleared after success.
Try Yourself
In order to try yourself you can start from this template file. Make sure to install a native agent of type File
on the computer that should receive the photos.
Last updated