Download the PHP package nowo-tech/pdf-signable-bundle without Composer
On this page you can find all versions of the php package nowo-tech/pdf-signable-bundle. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download nowo-tech/pdf-signable-bundle
More information about nowo-tech/pdf-signable-bundle
Files in nowo-tech/pdf-signable-bundle
Package pdf-signable-bundle
Short Description Define signature box coordinates on PDFs in Symfony: form type with PDF.js viewer, drag-and-drop placement, validation, and signing hooks.
License MIT
Homepage https://github.com/nowo-tech/pdfSignableBundle
Informations about the package pdf-signable-bundle
PdfSignable Bundle
β Found this useful? Install from Packagist Β· Give it a star on GitHub to help others find it.
Symfony bundle to define signature box coordinates on PDFs. Form type with an in-browser PDF.js viewer: users place and resize signature areas by clicking and dragging. Supports units (mm, cm, pt), validation, proxy for external PDFs, and hooks for PKI/timestamp/batch signing. Symfony 6.1+, 7.x, 8.x Β· PHP 8.1+.
What is this?
This bundle helps you define signature box coordinates on PDFs in your Symfony applications for:
- π PDF signature placement β Let users visually place and resize signature areas on a PDF
- π Units and origin β Work in mm, cm, pt, px or in; choose coordinate origin (e.g. bottom-left)
- π External PDFs β Optional proxy to load external PDFs without CORS issues
- βοΈ Named configs β Reuse presets (fixed URL, units, limits) via
config: 'name'in YAML - β Validation β Required box names, unique names per form, min/max entries
- π― Events β Hook into proxy request/response and coordinate submission for custom logic
Quick Search Terms
Looking for: PDF signature coordinates, signature box placement, PDF.js Symfony, PDF form coordinates, signature position configurator, Symfony PDF viewer, signature overlay, PDF signing workflow, coordinate picker, document signing? You've found the right bundle!
Features
- β
Form type β
SignatureCoordinatesTypewith PDF URL, units (mm, cm, pt, px, in), coordinate origin (corners) and collection of signature boxes - β PDF viewer β In-browser viewer (PDF.js) with overlays for each box; click to add, drag to move, drag corners to resize
- β
Optional proxy β Load external PDFs without CORS; configurable via
nowo_pdf_signable.proxy_enabled - β
Named configurations β Define presets in
nowo_pdf_signable.signature.configs(oracroform.configs) and useconfig: 'alias'when adding the form type - β
URL modes β Free-text URL input or dropdown choice (
url_mode: choice,url_choices) - β
Box options β Name as text or dropdown (
name_mode: choice); min/max entries; optional unique box names validation; page restriction (allowed_pages); sort order on submit (sort_boxes); no overlapping boxes (prevent_box_overlap, default true); minimum box size (min_box_width,min_box_height); optional rotation (enable_rotation); default values per name (box_defaults_by_name); snap to grid (snap_to_grid) and snap to other boxes (snap_to_boxes, default true); guides and grid (show_grid,grid_step); viewer lazy load (viewer_lazy_load); batch signing (batch_sign_enabled, βSign allβ button). Audit: optional fill from request (audit.fill_from_request), placeholders for TSA and signing service (see SIGNING_ADVANCED) - β Viewer β Thumbnails: page strip to jump to a page; Zoom: toolbar (zoom in, zoom out, fit width, translated); Touch: pinch to zoom, two-finger pan on tablets
- β
Validation β Required box name (NotBlank);
unique_box_namesglobal (true/false) or per-name (array) to enforce unique box names - β
Events β
PdfProxyRequestEvent,PdfProxyResponseEvent,SignatureCoordinatesSubmittedEvent,BatchSignRequestedEvent,PdfSignRequestEventfor integration (see SIGNING_ADVANCED) - β Compatibility β Symfony 6.1+, 7.x, 8.x and PHP 8.1+
Screenshots
Demo index β Each card shows a different way to configure SignatureCoordinatesType (named configs, URL options, box validation, model prefill):
Signature coordinates form β PDF viewer with draggable signature boxes; unit/origin selector and box list on the right:
Signature form (alternate view) β Same form with thumbnails strip, zoom toolbar and optional rotation; boxes can be placed flush to page edges at any angle:
Installation
Symfony Flex registers the bundle automatically. Otherwise see Installation to register the bundle and routes.
Unreleased / dev: To use the latest default branch (main or master), add the VCS repo and require dev-main or dev-master β see docs/INSTALLATION.md.
Quick Start
-
Add the form type to your form (or use the default route
/pdf-signable): -
Render the form with the bundle form theme so the PDF viewer and boxes render correctly:
- On submit you get a
SignatureCoordinatesModelwithpdfUrl,unit,originandsignatureBoxes(each with name, page, x, y, width, height, and angle whenenable_rotationis true).
Configure nowo_pdf_signable (proxy, example URL, optional Usage for full options and examples.
Requirements
- PHP >= 8.1
- Symfony >= 6.1 || >= 7.0 || >= 8.0
- PHP extensions required by Symfony (e.g. json, mbstring, ctype, xml, fileinfo). Optional:
ext-yamlfor faster YAML config parsing (seecomposer suggest)
Configuration
The bundle works with default settings. Create or edit config/packages/nowo_pdf_signable.yaml:
See CONFIGURATION.md for the full tree (proxy_url_allowlist, audit, tsa_url, signing_service_id, acroform.*, etc.) and default values.
Demos
Dockerized demos (Symfony 7 and 8, Bootstrap, Vite, TypeScript) with multiple usage examples. They run with FrankenPHP (Caddy + PHP): the Dockerfile ships a production Caddyfile with php_server worker, but with APP_ENV=dev the container entrypoint swaps in Caddyfile.dev (no worker, cache-busting headers) so local dev matches screenshots above show the demo home (configuration cards), the signature coordinates form (PDF viewer + boxes), and an alternate view with thumbnails, zoom and rotation.
Twenty-plus demos: no config, default config, fixed_url, overridden config, URL as dropdown, limited boxes, same signer (multiple locations), unique per name (array), page restriction, sorted boxes, no-overlap, allow-overlap, min-size-boxes, rotation, defaults-by-name, snap-to-grid, guides-and-grid, viewer lazy-load, AcroForm editor, AcroForm editor min-size, latest features (combined), predefined boxes; plus signing (draw, upload, legal disclaimer, predefined boxes β sign only, signing options). See demo/Makefile.
Xdebug
Demos include Xdebug. Your IDE should listen on port 9003. To start only on demand, set XDEBUG_START_WITH_REQUEST=trigger in the demo docker-compose.yml and use your IDE trigger.
Frontend (Vite + TypeScript)
The PDF viewer is built with Vite and TypeScript. The bundle ships a built file at src/Resources/public/js/pdf-signable.js. After installing the bundle:
To rebuild from source (bundle root):
Tests and QA
From the bundle root (optionally via Docker):
Or locally: composer test, composer test-coverage, composer cs-check, composer qa. The bundle Docker image includes PCOV for coverage.
Documentation
- Installation
- Configuration
- Usage
- Contributing
- Changelog
- Upgrading
- Release
- Security
- Engram
- Roadmap
Additional documentation
- Demo with FrankenPHP (development and production)
- Workflow
- AcroForm backend
- Events
- Advanced signing
- Styles
- Testing
- Accessibility
Tests and coverage
- Tests: PHPUnit (PHP), pytest (Python scripts)
- PHP: 99.18%
- TS/JS: 81.28%
- Python: 21%
License
The MIT License (MIT). Please see LICENSE for more information.
Contributing
We welcome contributions! Please see SECURITY.md.
Author
Created by HΓ©ctor Franco Aceituno at Nowo.tech
All versions of pdf-signable-bundle with dependencies
symfony/framework-bundle Version ^6.0 || ^7.0 || ^8.0
symfony/form Version ^6.0 || ^7.0 || ^8.0
symfony/http-client Version ^6.0 || ^7.0 || ^8.0
symfony/process Version ^6.0 || ^7.0 || ^8.0
symfony/twig-bundle Version ^6.0 || ^7.0 || ^8.0
symfony/translation Version ^6.0 || ^7.0 || ^8.0
symfony/validator Version ^6.0 || ^7.0 || ^8.0
symfony/yaml Version ^6.0 || ^7.0 || ^8.0