JS SDK

Release 3.16.0 (Jan 7, 2025)


Improvements

  • Performance Enhancements for Very Large Forms (NO-783): Optimized performance for handling large-scale forms efficiently.
  • Layout Engine Phase 1 (NO-578): Improved PDF generation with better page-breaking for non-dynamic fields.
  • Duplicate Field Bug Fix (NO-832): Resolved an issue with duplicate fields in horizontal display type for MultiSelect.
  • Chart Coordinates Fix (NO-764): Addressed x and y label cut-off issues in chart coordinates.
  • Chart Field Enhancements (NO-814): Added full-width Min/Max inputs for chart field settings.
  • Signature Field V2 (NO-680): Enhanced signature field with improved design and functionality for seamless user experience.
    Enjoy these improvements! 🚀

Breaking Change

  • JoyDocExporter no longer defaults to sans-serif font family. You are now required to set the fontFamily by using the theme property. See SDK README.md for how to properly set the theme font family.
  • JoyDocExporter now requires an initial measurement phase before PDF is ready to be captured. An element with .pdf-capture-ready will be added to the DOM when measuring is completed and PDF is ready to be captured.




Release 3.15.1 (Dec 6, 2024)


Improvements

🚀 Form Building, Now with Superpowers!

  • Field Duplication: Say goodbye to repetitive typing! With our new duplication feature, you can clone fields faster than you can say “ctrl + D” (or cmd + D for our Mac friends). (NO-662)
  • Page Names In Page Navigation Bar: Navigation just got smarter—page names now appear in the page navigation items, so you’ll always know where you’re headed. (NO-657)

🎨 A Visual Makeover

  • Formula Hide-and-Seek: Formulas on individual table cells fields properly handle formulas, staying hidden unless the field is focused (NO-813)
  • Custom Field Option Icons: Customize your field options with snazzy custom icons—because plain is boring. You can now use SVG Components and image urls. (NO-817)
  • Signature Distortion Fix: Signatures now look flawless, no matter the size of the field. No more distortions, just pure sleekness. (NO-822)

🔧 Bugs? Squashed.

  • Corrupted Table Data Crashing Fix: Missing row.cells values within table field causing an SDK crash? Not anymore! We’ve patched this bug to prevent crashing. (NO-795)
  • Selection Fields Border Fix: Checkbox and radio button borders are now visible at all times—before, during, and after selection. (NO-761)
  • New onSelect SDK Event: Developers, rejoice! The new onSelect handler is here to keep you in the loop every time a field is clicked. Whether you’re enhancing interactivity or tracking user actions, this feature ensures you’re always one step ahead. (NO-762)

We’re always working to make your experience better (and maybe crack a smile or two along the way). Thanks for being part of this journey! 🛠️




Release 3.14.1 (Oct 23, 2024)


Improvements

  • Added the ability to re-order pages within the builder (NO-656)
  • Implemented multiple UI fixes and bug fixes (NO-686, NO-647, NO-650, NO-679, NO-639)
  • Added confirmation modal for toggling mobile syncing (NO-653)
  • Added validation helper method. See README helper methods to learn more. (NO-677)
  • Updated peer dependencies to support React version >18.0.0 (NO-684)
  • Metadata field settings structure has been updated to follow consistent pattern (NO-684)

Release 3.13.0 (August 9, 2024)


Improvements

  • Validation helper (NO-579)
  • Support to sort fields based on x and y coordinates inside conditional logic modal has been added (NO-643)
  • Fixes for a bug that would make a field disappear when zIndex is set as the negative number has been fixed (NO-644)
  • Fixes for a bug that would cut off field settings due to accordion height(NO-639)
  • Fixes to filter out orphaned fields (ie fields without any field positions) from the Joydoc have been added(NO-559)
  • Fixes for the style bug that cut off the field settings as a whole have been added (NO-614)

Release 3.12.0 (July 26, 2024)


Improvements

  • Enhanced mobile device responsive web forms (NO-592)
  • Fix for invalid JSON payload freezing SDK (NO-613)

Release 3.11.0 (July 21, 2024)


Improvements

  • Added getDefaultPage helper method (#NO-604)
  • Removed vulnerable dependencies (#NO-604)

Release 3.10.0 (July 10, 2024)


Improvements

  • Updated JS SDK Internals (NO-528)
  • Add loading indicator for image / file uploads (NO-298)
    Uploads Unveiled! Say goodbye to upload anxiety! A shiny new loading indicator lets you know exactly when your precious images and files are on their way.
  • Enhanced table column settings (NO-352)
  • Added support for scaling pdf background images (NO-470)

Release 3.9.1 (May 13, 2024)


Improvements

Your Color Picker Just Leveled Up (Can See Through Walls Now!) (NO-451)

  • The struggle is real... no more pretending white is "almost transparent" enough!
  • We finally added transparent color support to the Settings Color Picker. Now you can create designs that are truly see-through awesome (because who needs walls anyway?).

Adjust height of field scroll selector (NO-522)

  • This release adds the necessary styles that would prevent the menu items of field identifiers from overflowing their wrapper making it look messy

Release 3.9.0 (May 4, 2024)


Improvements

This update is so fly, it'll make your form builder blush.

  • File Upload Field: Level Up Your Uploading Game (NO-498)
    • Forget the days of clicking "Browse" and praying your file finds its way. We've revolutionized the file upload field with features so cool, that they'll make your grandma say "What in the internet is that?"
      • Multiple files? Bring it on! We're like a buffet for your digital documents.
      • Drag-and-drop? Yes, please! Your files will be uploaded faster than you can say "convenience."
      • Your files your Style: Unleash the Data Fashionista Within! Choose styles, colors, and layouts that match your unique look.
      • Conditional Logic: Tailor your data flow to each user's unique needs, like showing cat videos only to cat people.
  • Default values for table columns fixed (NO-499)
    • No More Hide-and-Seek! Your default values will now show up like a magician pulling a rabbit out of a hat (except less fluffy).
  • Identifier Filter is not clearing post search (NO-492)
    • We Evicted the Sticky Residue! Your search results will no longer be haunted by the ghosts of past searches.
  • Enable/Disable Field Settings Options (NO-479)
    • Introducing the On/Off Switch for your field settings! You can hide any setting now by passing it as false in the field settings object and they will vanish instantly.
  • Page loading bug (NO-484)
    • We've solved the mysterious loading indicator that haunted the Form builder after deleting the current page so there is no more unnecessary confusion or ghostly loading animations.
  • The "Exports is Undefined" Mystery Solved! (NO-494)
    • We've cracked the case of the missing "Exports" It turns out it was nothing more than a digital ghost story. We've banished it to the land of forgotten bugs.

Release 3.8.0 (April 2, 2024)


Improvements

Bug Squashing Bonanza!

  • We heard you! We have fixed a bug where the option width couldn’t be removed from multi-select fields (NO-459)
  • We’ve squashed a bug that caused the SDK to crash when encountering invalid JoyDoc payloads (NO-432).
  • Identifier Enhancements (NO-469)
    • Customize identifiers your way! You can now enable or disable custom identifier creation.
    • Filter fix! We’ve wrestled with a pesky bug where identifier filter results wouldn’t clear after you removed your search query. Now your filters will reset properly, making it easier to find exactly what you’re looking for.
  • We’ve made some subtle adjustments to the interface to create a cleaner and more streamlined look (NO-433).
    • Field margin control for a polished look.
    • Default page padding for a consistent design.
    • Read-only mode to make any field read-only by the read-only option on field settings.

Release 3.7.1 (Mar 11, 2024)


Improvements

  • Spring cleaning! We tidied up some errors for a sparkling console (NO-398)
  • Unleash the PDF Beast! Our new developer-friendly SDK lets you forge PDFs with ease (NO-355)
  • Say goodbye to drab, hello to fab! SDK Themes are here to elevate your forms! (NO-396)
  • Performance on point! This update fine-tunes your experience for improved smoothness (NO-450)
  • New Look, Who Dis? We've revamped your favorite SDK for a stunning experience (NO-58)

Release 3.6.1(Feb 19,2024)


Improvements

  • Fix to prevent crashes after Loading External Form (NO-395)

Release 3.6.0 (Feb 6,2024)


Improvements

  • Added support for original file dimensions in PDF Form Engine (NO-349)
  • Enabled text wrapping for text based fields (NO-307)
  • Field icon added to field settings(NO-315)
  • Fix for display corresponding field settings of individual table cells when focused (NO-310)
  • Style fix to ensure field wrapping doesn’t cut off text within pdf and pdf exports (NO-107)
  • Fix for hidden property causing validation issue in older SDK version (NO-377)

Release 3.5.0 (Dec 16, 2023)


Improvements

  • Conditional logic (#NO-288)
  • onFocus and onBlur event handlers now supported in SDK (#NO-223)
  • Support for initialPageId on SDK for setting the initial page when the form is displayed (#NO-297)
  • Enhancements to PDF exports (#NO-250)
  • Enhancements to responsive web view for mobile form filling (#NO-252)
  • PDF form view enhancements (#NO-279)
  • Enhancements to required field indicators (#NO-295)
  • Style fix for Identifier selector (#NO-278)

Breaking Changes

  • Improved vanilla JS implementation for JS modules and CDN approach. See new implementation methods below (#NO-277)

Javascript Usage (CDN)

<!DOCTYPE html>
<html>
  <head>
    <title>Joyfill for Javascript Example</title>
    <base href=".">
    <meta charset="UTF-8" />
    <script src=" https://cdn.jsdelivr.net/npm/@joyfill/components@latest/dist/joyfill.min.js"></script>
  </head>
  <body>
    <div id="joyfill"></div>
    <script>

      Joyfill.JoyDoc(
        document.getElementById('joyfill'),
        {
          mode: 'edit',
          onChange: (changelogs, doc) => console.log('onChange: ', changelogs, doc),
        }
      );

    </script>
  </body>
</html>

Javascript Usage (Module)

//index.html

<!DOCTYPE html>
<html>
  <head>
    <title>Joyfill for Javascript Example</title>
    <base href=".">
    <meta charset="UTF-8" />
  </head>
  <body>
    <div id="joyfill"></div>
    <script type="module" src="./index.js"></script>
  </body>
</html>

//index.js

import Joyfill from "@joyfill/components/dist/joyfill.min.js";

Joyfill.JoyDoc(
  document.getElementById('joyfill'),
  {
    mode: 'edit',
    onChange: (changelogs, doc) => console.log('onChange: ', changelogs, doc),
  }
);

Release 3.4.2 (Oct 19, 2023)


Improvements

  • Fix for chart field label read-only error in build.
  • Misc enhancements and bug fixes.

Release 3.4.1 (Oct 18, 2023)


Improvements

  • Identifier selector field customization. Learn more https://docs.joyfill.io/docs/customize-settings (NO-87)
  • PDF dynamic field measurement enhancements (NO-113)
  • Auto remove individual table cell field positions associated with deleted columns (NO-254)
  • Misc enhancements and bug fixes

Release 3.3.1 (Oct 4, 2023)


Improvements

  • Page duplication support with page menu and duplicatePage helper method (#NO-95)
  • Table field now supports image uploading directly to table image cells (#NO-114)
  • Field tooltips now supported for additional field context and instructions (#NO-130)
  • Misc enhancements and bug fixes

Release 3.2.0 (Sep 12, 2023)


Improvements

  • Joyfill template library UI and visual requirements support (#NO-17)
  • Table columns are responsive by default now (#NO-17)
  • Added field groups display mode for table fields (#NO-17)
  • Added rich text field support (#NO-17)
  • Multi image upload adds the to current images and no longer overwrites them (#NO-149)
  • Table field settings enhancements (#NO-163)
  • Signature is properly scaled to fit within field dimensions (#NO-172)

Release 3.1.0 (Aug 22, 2023)


Improvements

  • Multi-user collaboration support via changelogs.
  • Changelogs are now passed directly to the onChange handler. See package README.
  • Added helper methods for generating and duplicating documents and templates. See package README.
    • getDefaultDocument get a default Joyfill Document.
    • getDefaultTemplate get a default Joyfill Template.
    • getDocumentFromTemplate get a Joyfill Document generated from a Joyfill Template.
    • duplicate duplicate a Joyfill Document or Template. Useful for adding a template from your library to an individual group.
  • Field lazy loading. See package README

Breaking Changes

  • onChange argument list has been changed. onChange now only receives two arguments: changelogs and doc. See README.