.. ================================================== .. Header hierarchy .. == .. -- .. ^^ .. "" .. ;; .. ,, .. .. --------------------------------------------used to the update the records specified ------ .. Best Practice T3 reST: https://docs.typo3.org/m/typo3/docs-how-to-document/master/en-us/WritingReST/CheatSheet.html .. Reference: https://docs.typo3.org/m/typo3/docs-how-to-document/master/en-us/WritingReST/Index.html .. Italic *italic* .. Bold **bold** .. Code ``text`` .. External Links: `Bootstrap `__ .. Internal Link: :ref:`downloadButton` (default url text) or :ref:`Download Button` (explicit url text) .. Anker for internal link: .. _`download`: .. Add Image: .. image:: ./Images/a4.jpg .. .. Add image with caption: .. figure:: ./Images/black_dot.png .. :class: with-border .. :width: 20px .. Add Attachment (place in Documentation/_static): `Download CSV <_static/yourfile.csv>`__ .. .. Admonitions .. .. note:: .. important:: .. tip:: .. warning:: .. Color: (blue) (orange) (green) (red) .. .. Definition: .. some text becomes strong (only one line) .. description has to indented .. .. Code Block: .. code-block:: sql .. .. -*- coding: utf-8 -*- with BOM. .. include:: Includes.txt .. _`release`: Release ======= Version 26.x.x -------------- Date: Notes ^^^^^ Features ^^^^^^^^ Bug Fixes ^^^^^^^^^ Version 26.3.1 -------------- Date: 24.03.2026 Notes * Attention: if a UZH CD Extension (2010, 2023) is used, update that UZH CD extension to a build after 22.03.2026. Bug Fixes ^^^^^^^^^ * #23463 / QFQ / tablesorter bootstrap.css not found Version 26.3.0 -------------- Date: 21.03.2026 Features ^^^^^^^^ * #23160 / QFQ / QSLUGIFY / Convert umlaute to ae, ue, oe. * #23182 / Report / sqldirect v2. * #23201 / QFQ / Log SIP errors: none/always/feUser. * #23348 / Form / TinyMCE: fix dynamic update. TinyMCE & datetimepicker: update only by focus lost. * #23358 / QFQ / Update build tooling for Node.js 24 compatibility - finally update Node.js to v20. * #23362 / QFQ / Clean store user on login. * QFQ / Add CLAUDE.md. * QFQ / Doc: Fix broken references. Update Copyright to 2026. Add Roman Fehr as contributor. Bug Fixes ^^^^^^^^^ * #4454 / Form / Incorrect marking for multiple required elements in a row. * #22832 / QFQ / Dev panel incompatible with T3 admin panel (26.1.0). * #22993 / QFQ / Keyword col missing highlight. * #22994,#11695,#14028,#22155 / Form / FE mode required. * #23000 / QFQ / undefined method guzzlehttp. * #23098 / Report / Throw exception if deprecated token 'f' is used in download links. * #23166 / Report / sqldirect missing sql. * #23175 / Report / img dont have an alt. * #23295 / Form / MultiForm Datetimepicker not aligmed to input field. * #23297 / Report / Unknown constant SYSTEM_PDF_DUMMY_MODE. * #23327 / Form / datetimepicker & typeahead interferes with QFQ suggestions. * #23328 / QFQ / API calls missing store typo3 feuser. * #23329 / Form / missing recordId in FormSubmitLog. Restoring FSL at least for 'record modified' entries. * #23373 / Form / Active Radiobutton is not centered. * #23398 / Form / getDbByIndex() broken for non qfq.data-db's. * #23432 / Form / record lock error multi db. Version 26.2.0 -------------- Date: 07.02.2026 Notes ^^^^^ * Small change with big improvement - `alnumx` now accepts '*', in combination with ref:`flexible_person_search` this offers a search functionality as expected by the user. Features ^^^^^^^^ * #22972 / QFQ / version.php refactoring. Implemented 'extension deployment'. * #23085 / QFQ / Extend alnumx to allow '*'. * Doc / Flexible search - replace bullet list by table. * Doc / Enhanced doc of action class 'f'. Bug Fixes ^^^^^^^^^ * #21747 / Form / 'btnPreviousNextSql' - use of id attribute fixed. * #22863 / Form / TinyMce dynamic update: content purged after key press. * #22990 / Report / link 'm' (mailto) always add 'mailto' in the text (should only in the a-tag). Version 26.1.3 -------------- Date: 30.01.2026 Bug Fixes ^^^^^^^^^ * #22978 / QFQ / Check Persisted Store Value Type * #22974 / QFQ / DB Update: fix always create table DeployRef * Doc Fix Typo Version 26.1.2 -------------- Date: 29.01.2026 Features ^^^^^^^^ * #22912 / Form / Fixed inputCollectionJson issue with duplicated variables. * #22916 / Form / Multiform supports now tablesorter. Check `multiFormTableClass` in :ref:`multi-form-table`. * #22944 / QFQ / qfq merge query view removed from start page. Bug Fixes ^^^^^^^^^ * #22457 / Form / Maxlength for radio button broken. * #22681 / Doc / 'Icon Dev-Panel' in QFQ Doc broken. * #22888, #22889, #22905 / QFQ / Fixed wrong ruleId. Added potentiallyDeleted flag. * #22909 / Report / SQL `QMORE()` crashes on NULL. Version 26.1.1 -------------- Date: 21.01.2026 Notes ^^^^^ * Since 04.2024, the content for the MAIL_LOG has been copied to MERGE_LOG instead. * Due to the BS3 version, we're forced to pin JQuery to version 3.7.1 Features ^^^^^^^^ * #22673 / Form / BS Dropdowns (auto exclude selected ones) * #22890 / Form / InputCollectionJson adjustments * #22904 / Form / Increase maxImageDimension to 5000x5000 * Add chapter Basic Knowledge in the Tutorial. * Php8.3 deprecations Bug Fixes ^^^^^^^^^ * #22369 / QFQ / Mail log file path wrong Version 26.1.0 -------------- Date: 19.01.2026 Notes ^^^^^ * 'Sync by Rule' (sbr) - :ref:`syncByRule` - Copy&Paste records, infrastructure to sync T3/QFQ installations. * :ref:`versionApi` - Infrastructure to fetch version number of T3, QFQ, extension and OS-packages. Manage BE User remotely. * :ref:`input-inputCollectionJson` - FE.type=InputCollectionJson - JSON based FormElement definition * :ref:`column-input` - Special column name '_input' - Ajax based FE Element (Select, Chekbox, Radio, Text), without HTML form tag. Features ^^^^^^^^ * #20249 / Form / Removed AbstractBuildForm.php and BuildFormBootstrap.php * #20345 / Report / Special column name '_input' - Ajax based FE Element (Select, Chekbox, Radio, Text), without HTML form tag. * #22510 / QFQ / Sync By Rule (sbr) - Copy&Paste Records, infrastructure to sync T3/QFQ installations. * #22651 / QFQ / Typo3 Custom redirect handler. * #22671 / QFQ / versionApi pulls version information of `wkhtml`. * #22749 / Report / Security message visible on page * #22750 / QFQ / BE user management via versionApi (API Call). * #22766 / QFQ / versionApi, QFQ-Services: Dokumentation * #22783 / Report / QMORE: count html entities as one character. * #22788 / QFQ / Delayed User store. * #22833 / Form / Issue Form bugs and improvements * #22839 / Form / FE.type=InputCollectionJson - JSON based FormElement definition * Refactor class upper case names Bug Fixes ^^^^^^^^^ * #18057 / QFQ / {{sqlLog:Y}} returns empty string when not configured * #21208 / Form / Show table definition in Form/FormElement * #22707, #22879 / Form / TemplateGroup, Character count - causes Generic Error. * #22769 / Form / Doc update * #22772 / Form / Undefined array key "s" * #22773 / Form / Undefined array key "r" - FillStoreForm.php * #22787 / QFQ / U store cleared too late * #22795 / Form / CodeMirror: Typeahead in Form/FormElement.parameter missing keywords * #22830 / Report / Tablesorter triggered when button in is clicked * #22831 / QFQ / QuickFormQuery does not restore global settings * #22832 / QFQ / Dev panel incompatible with T3 admin panel * #22853 / QFQ/ Dynamic variables updated on user change * Several PHP 8.3 deprecations fixed. * Doc: fix several typos. Add pickr.js to License.rst. Version 25.12.0 --------------- Date: 07.12.2025 Features ^^^^^^^^ * #18456 / QFQ / QFQ-function additional parameters. * #21931 / Report / SQL-Report-Level-Wrap. Implemented libeg and liend functionality. Extended codemirror... * #21937 / Doc / a) 'code-block:: sql' >> QFQ, b) code block in Admonitions, c) Anmerkungen zur Dokumentation, d) New: Documentation-develop/READ_THE_DOCS.md. * #22260 / QFQ / QFQ RTD Docs are now version related. Links from Form Editor points to correspoding version of RTD QFQ doc. * #22322 / Form / Toggle input - custom label. * #22343 / From / Upload: Check if PDF is protected before unprotect. Add timeout. * #22472 / Report / T3 BE QFQ Content Element: Rename 'subheader' to 'QFQ function name'. * Form: Missing closing div breaks html. * formEditor.qfqr added missing closing div. * maxFileSize: allow curly braces. * PHP 8.3 deprecation fixes. Creation of dynamic property IMATHUZH\Qfq\Core\Report\Report::$aliases is deprecated. Bug Fixes ^^^^^^^^^ * #22078 / QFQ / Add sql keyword: VALUES(). * #22258 / Form / Undefined variable $fileUpload. * #22259 / Form / File.php: Trying to access array offset on value of type null. * #22335 / QFQ / padding using tablesorter. * #22401 / Form / Child FE in fieldset not affected by mode readonly. * #22403 / Form / FE.type=subrecord: readonly / hidden / modesql - broken. * #22404 / QFQ / Tablesorter filter-select height. * #22417 / Form / Hidden FEs that are required trigger incomplete form. * #22421 / Wiki / Wiki dropdown open to the left. * #22493 / Form / Subrecord detail and QFQ function do not take the same parameter value twice. * #22495 / Form / Fieldset mode not updated after save. * #22520 / Form / modeSql overwrites mode that was passed down from container. * #22608 / Form / TinyMCE mark dirty already on modified (not on focus lost). Badge height aligned to title font. Color required more dezent. * Change SQL statements for update on 25.8.0 from drop to change. * Respect dnd-reorder-desc. * Add syntax highlight for some skipped keywords. Add multiMsgNoRecord as accepted parameter keyword. Version 25.9.0 -------------- Date: 18.09.2025 Features ^^^^^^^^ * Doc: Fix Build-Warnings (rest errors and warnings), sql lexer extend with qfq-syntax. Add chapter Basic Knowledge in the Tutorial. * #21483 / Form / Upload BibTex: Fixed ignoring pId as variable from store. Bug Fixes ^^^^^^^^^ * Doc: Correct macro for wiki links. * #20147 / Report / tablesorter incompatible with 'qfq-table-50'. * #21821 / Form / TinyMCE config for image_class_list is overwritten by defaults. * #21835 / Wiki / UZH CD breaks indentation for table of contents. * #21891 / Form / FE.type=date: a) dynamic update broken, b) element position issues when required block appears. * #21998 / Form / FE.parameter: parameter unknown 'messageFail'. * #21999 / Form / FE.type=subrecord: Return value must be of type string, null returned. Version 25.8.0 -------------- Date: 29.08.2025 Notes ^^^^^ Features ^^^^^^^^ * #7660 / QFQ / IMAP Integration: doc info, removed qfq config for imap. :ref:`emailSync`. * #15790 / Form / Record lock (dirty): same user should be able to unlock. * #16630 / QFQ / Dev Panel. * #17146 / QFQ / Ticket App: Issue. * #17401 / Form / Upload PDF: deny if it is protected / convert to unprotect if possible. * #18977 / Form / FE.type=upload: split PDF for multiple upload files. * #19298 / Form / Upload: delete file in advanced mode. * #20833 / Form / FE.type=colorPicker. * #20903 / Form / FormElement.name: Warning if SQL reserved words are used. * #20911 / Form / TinyMCE Config: Inline files (HTML with tag) from protected folder. * #20975 / Form / DateTime Picker: select only month and/or year. * #21003 / Form / Feature Closed Normal TinyMCE default image size. * #21004 / Form / TinyMCE image click to enlarge. * #21005 / Form / TinyMCE change font size. * #21159 / Form / Purge FormElement: dateJQW, datetimeJQW, gridJQW. * #21208 / Form / Form & FormElement: disable pill 'table definition' if primary table is unknown. * #21221 / Form / FE.type=select: Multi-Select. * #21245 / Form / fileUpload: Note per Upload. * #21261 / Form / F.parameter: column[] = . * #21296 / Form / FE.parameter.toggleInput - enable/disable input element. * #21420 / Report / 'AS _mailto' with email selector. * #21424 / Form / CSS Position: a) Dropdown Pfeil, b) Input: ClearMe. * #21445 / Report / Dummy Excel Template. * #21464 / Form / Step by Step Arrows Design - added css for step by step. * #21500 / Report / Search & Refactor: incl. FE.name, F.name, ... * #21507 / Report / Dev Panel Performance. * #21520 / Form / Add 'Tooltip Sticky' to all Form: a) Save Button, b) FormEdit Button. * #21521 / QFQ / QFQ Dev Panel: a) doc, b) hide in print-view. * #21547 / Form / QFQ Wiki / Images: a) by default with border, b) enhance dialog. * #21569 / Form / New FE parameter typeAheadGlueUpdate. * #21575 / Form / TypeAheadTag: a) 'x' ersetzen gegen Trash, b) Abstand 'Tag / Input'. * #21607 / Report / New Full Calendar advanced implementation with observer and ... * #21622 / Report / Added new options in Setting table. * #21797 / QFQ / Tablesorter: Indicator when filter/sorter is active. * Gruntfile renamed, cause it should not be uses anymore. * Table Setting: New type notification-popup. * Doc: Add note about CHARSET and COLLATION. Add SQL-Advanced. Add comments to add new version auf RTD. Add comments for nested, variables, internal link. Fixes styling errors. Fixes code-block missing lf. Fixes more places deprecated 10.sql style. Replace all .sql in Report.sql. Fix external links. Update ReST Tipps on each document. Add attachment tutorial-erd.drawio. Update Coding Guidelines. Add extension sphinx_copybutton. Add Coding Guidelines to QFQ Doc. Add dynamic setup of variables. Sync QFQ / T3 config setup with documentation. Update for FE.type=imagecut. Add doc for mailto. Update doc for Form.parameter.column and FormElement.parameter.toggleInput. Generaltips.md: add comment to escape '|'. Add ZZ, MV as Further Contributors. Update copyright to 2025. Set as author: Carsten Rose, Benjamin Baer, Enis Nuredini, Jan Haller, Krzysztof Putyra. * Exclude general .env files from git deployment. Bug Fixes ^^^^^^^^^ * #16965 / QFQ / Unhandled exception on SQL query. * #17201 / Form / FE Upload readonly not visible. * #21191 / Form / {{fileNameUnique:V}}: a) duplicate prefix, b) upload multiple files with same name not possible. * #21368 / Form Report / filepond: a) Update Doc, b) `accept:...` broken. * #21376 / Form / TinyMce Editor after load wrong chars. * #21402 / QFQ / Link with renderMode 3 is still clickable when attribute data-ignore-history is used. * #21408 / Report / Variables set to U-Store no longer set to R-Store. * #21415 / Report / AS _thumbnail broken. * #21440 / Form / Bug Fixes TinyMCE and Dynamic Update. * #21465 / Form / FormElement type chat is missing. * #21466 / Form / extraButtonLock broken with formModeGlobal=readonly. * #21469 / Form / clearMe problems. * #21472 / Form / Filepond Upload: 'Forward URL / Page=close' leads to reshow last upload. * #21474 / Form / emptyItemAtStart is broken. * #21475 / Form / Query in FormElement title replaces single ticks and causes error. * #21484 / Form / clearMe broken in multi form. * #21488 / Form / {{alias.line.insertId}} not working after first insert. * #21489 / Form / Generic Exception: preg_match(): Argument #2 ($subject) must be of type string, array given. * #21514 / Form / On Record Delete: Table Split now gets checked. * #21517 Form / undefined $pillHref. * #21518 / Report / Download PDF Modal broken. * #21519 / Report / Report: syntax highlight for keyword 'function' missing. * #21522 / Form / Form Load: If first pill is hidden, the FE of second pill are hidden - unitl pills are switched. * #21525 / Form / FormEditor/Element: Umlaut broken. * #21526 / QFQ / QENT_ENCODE: Spaces removed. * #21533 / Form / Hidden Pill Required. * #21543 / Form / The action 'sqlAfter' is not enclosed by {{ }} and will not execute. * #21572 / Form / datetimepicker: value hidden after save. * #21590 / Form / Frontend email check fails. * #21634 / Form / FE time not loaded correctly. * #21718 / QFQ / Uncaught Error: Class "GenericException" not found. * #21786 / QFQ / Support::wrapUnexpectedException gets into fatal error if executed (by api). * QFQ / a) img2pdf not found: report. b) deliver dummy.png if missingFile=dummy. Version 25.6.0 -------------- Date: 05.06.2025 Notes ^^^^^ Breaking Change: * Please update crontab entry `...typo3conf/ext/qfq/Classes/External/auto-cron.php` (old: `autocron.php`). * FE.type=upload: maxImageDimension New features: * New Escape/Action type: 'f (find)' - used in Person Search: a) Report , b) TypeAhead. * Report: process shead/stail/althead/alttail even without sql/function. * FormNote" to "Issue * iNotify Service file and configuration * Websocket Service * Fail2Ban * Merge Feature * History Feature Features ^^^^^^^^ * #7660 / QFQ / Import Mails via IMAP. :ref:`emailSync` * #11523 / Form / Mit dynamic Update erkennen, ob Upload gemacht wurde. * #14187 / QFQ / qfq.log: show current URL * #14719 / Form / Form > Subrecord: Drag'n'Drop - only activate if column 'columnOrd' exist * #14869 / Report / Generic BACK Button via '... AS _link'. * #15321 / Form / Checkbox with more than 2 states - like doodle 'yes', 'no', 'maybe', ... * #15534 / Form / FormEditor > CodeMirror > a) sql1: 'Home/End' jumps to technical line start/end, not the visual one, b) Matching Bracket, c) Comment, d) Shift-Tab. * #15656 / QFQ / SearchReplace: improvement. * #16172 / QFQ / Tablesorter: Update {{10.10.line.count}} after every sort. * #16219 / QFQ / Security: IPs von Hacking Angriffen sperren - Integration voin Fail2Ban. * #16346 / Report / Tablesorter: clearme missing. * #16849 / QFQ / Mail: check FROM address for pattern or specific sender address. * #17146 / QFQ / Refactoring from "FormNote" to "Issue". * #17266 / Form / Upgrade TinyMCE V7. * #17359 / Form / Form: new record - skip history. * #17813 / Form / bsColumns - bisher: col-md-12 col-lg-10 / neu: col-md-12 col-lg-8. * #18013 / QFQ / Tablesorter: column view selector. * #18481 / Report / thumbnail: when missing placeholder (no exception). * #18499 / Form / FE.type upload: a) guarantee unique filename, b) on download, offer orig filename. * #18679 / QFQ / Tooltip: a) sticky, b) copy to clipboard. * #18964 / Report / Dummy PDF in development mode. * #19032 / QFQ / Tablesorter: column selector a) icons missing, b) button group / UI, c) page selector - button group /UI. * #19997 / Form / filepond/upload: Message 'upload complete' customizeable. * #20314 / Form / Form History missing in Refactor Rendering. * #20337 / Form / Recent List. * #20472 / Form / Custom border/style for fieldset. * #20565 / Form / btnPreviousNextSql without saving first should trigger alert instead of browser popup. * #20635 / Form / Upload / create new filenames: new option 'filenameToLower'. * #20799 / Report / In '_link\|_page\|_pdf\|...' allow multiple '\|o:'. * #20891 / Report / Allow {{ ... AS _script }}. * #20894 / QFQ / New Escape/Action type: 'f (find)' - used in Person Search: a) Report , b) TypeAhead. * #20896 / QFQ / Prepared Statement: create them if they are missing. * #20903 / Form / FormElement.name: Warning if SQL reserved words are used. * #20915 / Form / Excel Import: named columns. * #20918 / Form / Multi Upload in Form. * #20931 / QFQ / iNotify Service file and configuration. * #20972 / Form / Alphabetical order for FE types. * #21019 / Report / Report: process shead/stail/althead/alttail even without sql/function. * #21020 / QFQ / Two new stores: STORE_WEB, STORE_ACCESS. * #21130 / Form / Multiform: Toggle element. * #21193 / QFQ / QFQ Nchan Implementation. * #21205 / Form / MultiForm: FE.mode=required - a) indicate with red asterik, b) highlight on save if input is missing. * #21215 / QFQ / Stored function & sanatize class to escape '|'. * #21223 / Form / Improve implicit 'Save'-action. * #21337 / Form / FE.type=upload: maxImageDimension. * #21386 / Form / Added BibTeX Upload & Mode M for Download in Link Class (* #18274). * #21388 / QFQ / triggerScript on form-save (* #20741). * Increased size of Form.title to TEXT (64k). * Release.rst: reformat some bullet lists. * Add CSS class 'badge-title' - adds a margin around the badge and the font-size is the regular one (not reduced). Bug Fixes ^^^^^^^^^ * #3682 / Form / Dynamic update: Radio buttons. * #3811 / Form / Dynamic Update: extraButtonInfo - Text aktualisieren. * #4528 / Form / extraButtonLock mit SQLAhead Bug. * #5221 / Form / Download Dialog: Bleibt stehen in FF wenn Datei automatisch gespeichert wird. * #6116 / Form / value of checkbox not saved. * #7616 / Form / Selectlist with Enum & Dynamic Update. * #8106 / Form / Dynamic Update: Feld kann nicht auf empty zurückgesetzt werden. * #9121 / QFQ / sip links have r and __dbIndexData set. * #9347 / Form / FE.type=upload with dynamic show/hidden: required not detected. * #9531 / Form / FE.type=upload: Dynamic Update / modeSql / required detected even it not set. * #9534 / Form / FE.type=upload: 'Unknown Mode: ID' * #12513 / Form / Implement server side check of maxlength * #12545 / QFQ / sql.log not created / updated * #12974 / Form / Added logic to validate formElement parameter, modeSql and sql1 v1. * #13659 / QFQ / wrong sanitize class applied to R-store. * #15047 / Form / {{allRequiredGiven:V}} = 0, if Note Formelement is required. * #15050 / Form / Farbe Textfeld grau bei Wechsel von readonly auf show. * #15083 / Form / Tags: Input & ExtraButtonInfo/Lock/Show password - shifted. * #15108 / Form / Wert in Note nach speichern nicht aktualisiert. * #15317 / Report / view-saver (tablesorter) is blocking header if header column contains linebreak * #15795 / Form / Upload: download button not shown after pressing save. * #16348 / Form / Typeahead + extraButtonInfo: no rendered as Button Group. * #16620 / Report / wkhtml: PDF shows QFQ FE editing form if BE User is logged in. * #16994 / QFQ / Stacktrace in QFQ error message. * #17215 / QFQ / QFQ Doku: Encode ‘none’, ‘specialchar’ - 'single tick' missing. * #18184 / QFQ / _link combination of g:_blank and q:.. not working * #18601 / Form / typeahead: sanatize Class applied to value, should be applied to key. * #18755 / Form / Multi DB: FormElement broken if QfqData-DB does not have a table 'Form'. * #18785 / Form / DatetimePicker: min/max - report invalid date, instead of changing. * #18922 / Form / qfqWiki improvements. * #18973 / Form / NoteForm: broken in MultiDb. * #18981 / Report / dbIndex not recursive. * #19001 / Form / FormEditor: problems to show table definition - save broken. * #19182 / Report / Deleting a record using tablename and record id in report does not work. * #19349 / Form / Mode sql unreliable. * #19913 / QFQ / mergeLog does not respect qfq.project.path.php. * #19934 / Form / TinyMCE: on read only, show in gray. * #19965 / Form / Form previous/next record: disabled button still clickable. * #19990 / QFQ / Migration Wizard: after a clean new QFQ installation, the wizard complains about found 'id={{pageId...'. * #20013 / Form / QFQ-Wiki issue: updating new records. * #20168 / Form / DirtyURL not found * #20197 / Form / Form Delete Button Disabled on Dev * #20203 / QFQ / qfq.log File: on security exception only default path. * #20244 / Form / extraButtonLock broken * #20245 / Form / Download Button missing in filepound. * #20279 / QFQ / Messes up LDAP password. * #20286 / Form / qfq variable without store not working (slaveId) * #20287 / Form / Texteare resize not working. * #20305 / Form / MultiDB: Form 'form' / tableName on {{indexData}}: ok for 'data', broken for 'form/formElement'. * #20309 / Form / MultiDB: typahead SQL broken. * #20313 / Form / BE-Admin / subrecord: icon for edit FE missing. * #20348 / Form / Form: delete button always disabled. * #20356 / Form / Checkbox broken. * #20363 / Form / Missing SIP Parameter in Form Creation. * #20365 / Form / Debug Symbols missing. * #20373 / QFQ / Clean unnecessary console.log entries. * #20384 / Form / Develop Branch always show: Record modified. * #20389 / Form / typeaheadSql: 'hideZero=1' not applied on formload. * #20392 / Form / On page 'form' (=FormEditor): Button 'new' / 'json' is not on the same line. * #20466 / QFQ / Chat messages of FE type chat do not use linebreaks. * #20505 / QFQ / Check timeout / session.gc_maxlifetime triggered without a reason. * #20561 / Form / Form note button too big. * #20562 / Form / FE type chat mark done does not change button color. * #20600 / Form / TypeAhead shows same suggestion twice. * #20715 / Report / More than 1 Table sorter on a single Page Brakes it. * #20718 / Form / QFQ Wiki: New file button not restricted. * #20722 / QFQ / NoteItem not working with new UZH CD. * #20751 / Form / Drag and Drop throws General error. * #20780 / Report / QMORE() in FormElement.label not working with dynamic update. * #20781 / Form / Textarea grows every time when a switch between pills happens. * #20782 / Form / Form.parameter btnCustom[?] not included in Parameter check. * #20790 / Form / HTML comment when using inside link text. * #20829 / QFQ / phpUnit: Abstract test case classes with "Test" suffix are deprecated. * #20861 / Form / tablesorter align vertical titles. * #20869 / Form / btnCustom[new] requires form name. * #20878 / Report / .line.insertId not working. * #20880 / Form / FE Edit QFQ-report code: shows blank. * #20881 / Form / Plichtfeld im Radio nicht highlighted. * #20892 / Form /Subrecords whit attachments get sql error while deleting. * #20909 / Form / Missing FE.parameter for editor. * #20923 / QFQ / PSR4: Auto-Cron.php rename to AutoCron.php: update crontab typo3conf/ext/qfq/Classes/External/auto-cron.php. * #20929 / Form / FE.type=subrecord with tablesorter: JS breaks. * #20948 / Form / extraButtonLock disabled after save. * #20950 / Form / Umlaute are encoded to HTML entities in form. * #20952 / Form / F|FE.parameter syntax check: missing parameters (Form/FormElement). * #20962 / QFQ / STORE_CLIENT['cookieQfq'] missing in Doc. * #20964 / Report / qfq function: loading from cache leads to error. * #20971 / Form / Multiform: hidden. * #20976 / Form / Multiform: Invalid fieldContainer-Referenzes after removing a container. * #20925 Form / Form as JSON contains errors * #20999 / QFQ / QFQ Wiki page forward anchor and type conflict * #21001 / QFQ / Behaviour of URL parameter type. * #21002 / QFQ / QFQ Wiki navigation broken * #21016 / QFQ / PDF Download Broken. * #21042 / Form / Multi Form: Form store is not updated * #21060 / Form / extraButtonInfo missing for FE.type=editor. * #21061 / Form / data-title attribute breaks HTML if it contains double ticks * #21062 / QFQ / QFQ wiki content should not be evaluated * #21064 / Form / FormEditor: FormElement 'JSON' broken * #21066 / QFQ / SQL error: problem not underlined. * #21079 / Form / FormElement parameter wrapRow, wrapLabel, wrapInput and wrapNote are broken. * #21106 / Form / Undefined array key "form-update". * #21119 / Form / Label Align for FormElements is broken * #21367 / Form / filepond: a) download broken, b) text for downloadButton broken * #21141 / Report / QMORE() does not work with HTML content over multiple lines. * #21156 / Report / Copy to clipboard (AS _yank) cannot be used in button group. * #21158 / Form / extraButtonLock, extraButtonInfo: for all native elements * #21165 / Form / MultiForm Save: does not work in advanced mode with slaveId/sqlBefore/sqlUpdate/.. directly in FE Elements * #21181 / Form / Multiform: missing plus button while multiFormAddRow is active. * #21182 / Form / FormEditor: a) Sort FE column 'Dyn' broken, b) Check for MultiForm to force Mode!=none * #21188 / Form / FE type checkbox adds
after dynamic update. * #21191 / Form / {{fileNameUnique:V}}: a) duplicate prefix, b) upload multiple files with same name not possible. * #21198 / QFQ / Missing table 'Split' throws exception on 'delete'. * #21207 / Form / 'FE.parameter.slaveId = 123 ' fails. * #21216 / Form / Syntax Highlight FE.parameter: 'unchecked' not highlighted * #21217 / Form / After form-save typeAhead fails required. * #21220 / Form / FormElement.sql1: "sql1 is not wrapped correctly". * #21262 / Form / Save record: via press Enter - visual confirmation 'Save', but record is not saved! * #21265 / Form / 'password hash' broken for bcrypt. * #21266 / Form / MultiForm Checkboxes not working. * #21267 / QFQ / QFQ Config Dynamic: Fill store 'SYSTEM' by SQL Row Error. * #21290 / Form / Form Element with checkType "email" accepts "abc.def" * #21310 / Form / Form JSON Control Buttons. * #21312 / Form / Multi Form multiFormAddRow does not copy the hidden Input Element. * #21313 / Form / ToolTip MultiForm. * #21331 / Form / Store.php(516): UserFormException: Value of 'btnTopRightOrder' already set in store 'D'. * #21365 / Form / filepond/report: a) Icon on error shiftet, b) error message bigger. * #21367 / Form / filepond: a) download broken, b) text for downloadButton broken. * #21216 / Form / Syntax Highlight FE.parameter: 'unchecked' not highlighted. * Fixed wrong dbIndex in dnd logic. Version 24.12.0 --------------- Date: 14.12.2024 Notes ^^^^^ * Class AbstractBuildForm refactored - the form renderer is now much cleaner to maintain. Features ^^^^^^^^ * #17252 / Form / Form renderer refactor. * #10119 / Form / Style & catagorize dropdown lists (selectBS) - :ref:`input-select`. Bug Fixes ^^^^^^^^^ * 17998 / Form / By default, curly braces are now html encoded saved - this protects LaTeX code not to be treated as QFQ variables. Version 24.10.0 --------------- Date: 27.10.2024 Notes ^^^^^ New Feature 'record history'. Features ^^^^^^^^ * #7480 / Form / Record History. * #18909 / Form / QFQ Merge: Manual. * #18922 / QFQ / qfqWiki: improvements. * #19033 / QFQ / authentication in qfq. * #19054 / Report / show format definition in developer tooltip of '... AS _link'. * #19672 / QFQ / Typo3 extension QFQ version number now cotains branch name. * #19764 / Docker / Integration of autocron in typo3docker repo. * #19788 / Docker / Integrated postfix and cron email configuration. * Doc: Update RST hints at the top. Bug Fixes ^^^^^^^^^ * #17991 / Form / filepond (upload): file extension always converted to lowercase and behaves case independent. * #18583 / QFQ / qfqWiki: Replaced 'id=...' parameters. * #19194 / Form / Codemirror fixed double initialization. * #19661 / Form / Radio: fixed vertical problem. * #19747 / Form / htmlAfter: fixed problem with dynamic update. * #19776 / Form / extraButtonLock: fixed for dynamic update. * Fix used constant name RENDER_MODE_7(_ONLY_URL). Version 24.7.0 -------------- Date: 10.07.2024 Notes ^^^^^ * uploadType: options v1/v2 are now deprecated and replaced by button/dnd. * Config.FormElement.subrecotrd FormElement.parameter.subrecord. Features ^^^^^^^^ * #15528 / Form / Subrecord: display configurable in case no record is selected. * #15762 / Form / Copy Formelement as json. * #16988 / Form / New FormElement.type = ImageCut. * #17989 / QFQ / oidc_in_T_store. * #18047 / Form / Filepond: uploadType: a) report invalid value, b) change `v1/v2` to `dnd/button`, c) CodeMirror keyword. * #18244 / Form / Filepond: Update documentation. * #18479 / QFQ / Extension config 'update'='once'. * #18922 / QFQ / qfqWiki improvements. * #19033 / QFQ / Authentication in qfq. * #19034 / QFQ / HTTP redirection from QFQ via `... AS _link`. * QFQ / Extension config: Clean up various texts / Change qfq extension config options to drop down lists / Add new pill 'Form-Element'. Add option 'uploadType' to system config and form config. * Sendmail: automatically remove '\r' in mail body text. Bug Fixes ^^^^^^^^^ * #17991 / Form / Filepond: broken filter in file dialog box. * #18549 / QFQ / Added SYSTEM STORE variable {{indexWiki:Y}} to configuration. * #18713 / Form / Check for filepond parameters. * #18742 / Form / Codemirror btncustom. * #18793 / QFQ / T3 LocalConfiguration.php: seems to be corrupted by QFQ. * #18984 / Form / In multiform tinymce miss to trigger dirty. * #19042 / Form / multiform STORE_VAR variables are not replaced. * #19043 / Form / Hidden columns (' AS "_") in MultiSql treated as without '_'. * #19044 / Form / FE.typ='time' broken for column datetime on creating new records. * Form / Add keyword 'processRow' in syntax highlight. Minor doc update. Version 24.5.1 -------------- Date: 29.05.2024 Bug Fixes ^^^^^^^^^ * #18668 / Form / File download from upload FE (filepond) not possible with formModeGlobal=readonly. * #18669 / Form / File download button from upload FE (button/v1) is disabled when using formModeGlobal=readonly. Version 24.5.0 -------------- Date: 28.05.2024 Notes ^^^^^ * :ref:`customize-form-buttons` - Customize standard form buttons and add custom buttons to form. * Heavy improvements in syntax highlighting and QFQ keyword typeahead. Best is to use the FrontEnd QFQ Edit. * :ref:`formNote` - Add per form and record individual notes, inckl. reminder / tags / done and access control. * :ref:`fillStoreSystemBySqlRow` - FillStoreSystemBySqlRowVariable can be used together with QFQ config variables. * :ref:`merge-data` - Wizard to merge data, update slave id's. * :ref:`qfq_keywords` - new report keyword *performanceReport* in report to show a SQL Query Performance Report. * Thumbnails will now be loaded with the HTML option 'lazy'. * :ref:`imageCut` - new awesome FormElement ImageCut - reposition and cut image directly in the form, original not touch. * From now on, only the most crucial QFQ delivered tables are created automatically - all others on demand. Features ^^^^^^^^ * #10080 / Form / Popup on 'save' / 'close': configure dialog (answer yes/no/cancel). * #12262 / Form / Buttons on top: more customable. * #17393 / Report / Improve FE Report Editor: add CodeMirror qfq language. * #17412 / Form / note, tag, reminder date, done flag. * #18022 / Form / Filepond colors / element size / font size (new UZH CD) / border. * #18141 / QFQ / Config: new FillStoreSystemBySqlRowVariable. * #18164 / QFQ / Wizard to merge duplicate data. * #18193 / Report / SQL Query Performance Report. * #18243 / QFQ / Variable / Escape: a) htmlentity, b) htmlentity all (incl. curly braces), c) striptags. * #18250 / Form / MultiForm fake outer record. * #18280 / Report / thumbnail: loading="lazy". * #18285 / Form / FormElement ImageCut (ImageAdjust). * #18404 / QFQ / New Default CharSet: utf8mb4. * #18454 / Form / Upload: Visual changes for upload FE (filepond). * #18547 / QFQ / Create QFQ tables on demand. * Doc: Removed parameter "title" for subrecord. Comment from ticket: "Korrekt - 'title' wurde nie implementiert. Der Value von 'label' wird angezeigt.". * Doc: Add package/lib requirement for PHP /password: libargon2. Bug Fixes ^^^^^^^^^ * #9281 / QFQ / Allow STRICT_TRANS_TABLES * #10766 / Form / Radiobutton - parameter.buttonClass=btn-default: dynamic update. * #11237 / Form / Radiobutton - parameter.buttonClass= btn-default - kein dirty Trigger. * #14530 / QFQ / Variables: Action 'X' does not output Type message. * #17257 / QFQ / Migrate QFQ system tables: set default value. * #17272 / Form / Save button dirty. * #17384 / Report / Thumbnail: a) touch(): Unable to create file, b) s:0 broken. * #17498 / Form / Bugfix Previous/Next Buttons on Form. * #17569 / Form / Form.title text/children not centered. * #17570 / Report / qfq-badge same as badge from bootstrap. * #17656 / Form / Browser: regexp Pattern Match broken/error. * #17778 / Form / Upload: Filepond Dynamic Update - first load hidden. * #17785 / QFQ / Undefined download storeSystem. * #17992 / Form / Upload: Filter on file extension is case dependent. * #18031 / QFQ / Fixed not compatible unit tests for php 8 and phpunit 9.6.15. * #18045 / Report / Download Jupyter Files (.ipynb): should offer 'save as', but shows inline. * #18048 / Form / Upload: FE.downloadButton missing tooltip. * #18058 / Report / Monitor not working: missing JS file. * #18073 / Form / typeAheadTagInsert failed to insert new tags. * #18094 / Form / Loading Fabric without Form not working anymore. * #18186 / QFQ / Autocron Timezone Problems. * #18289 / QFQ / Merge Feature: Missing function for merge.log. * #18331 / Form / Implement to save multiple record with ID = 0 for multiform Refs. * #18354 / Form / Visual bug while saving multiform. * #18412 / Form / Upload: mimetype image/* broken. * #18507 / Form / Buttons customable: vertical alignment. * #18509 / Form / After saving Formelement need a reload. * #18604 / Form / CodeCorrection throws malformed json error. * #18610 / Form / ImageCut: Exception 'Missing imageSource' after upload + save. Version 24.3.0 -------------- Date: 02.03.2024 Features ^^^^^^^^ * Form / Add 'ø' to alnumx. * Add wikiScript.php to build. * CHAT.md: Add thougts about notfication. * #17393,#15361 / Form / Frontend Editing: highlighting, improve table.column hinting, support table aliases, improve indentation, add SQL highlighting inside QFQ variables, Generalize QFQ SQL variables to work for FormElement value and sql1, allow extra keyword definition in codemirror config and apply to FormEditor, add qfq sql functions to syntax highlighting. * #17593 / Report / Improve documentation and use constants for codemirror editor FE config. * #17739 / Form / multiform grid. * #17989 / Form / BE_FE_OIDC_as_QFQ_STORE_TYPO3_variables. * #18008 / Form / Refactoring upload columns. Bug Fixes ^^^^^^^^^ * Form / Access to undefined index in FE datetime and FE upload. * #17576 / Form / QFQ FrontEnd Editor head styling, fixes. * #17681 / Form / Wiki Bugfixing. * #17854 / Form / Fixed broken filepond css rules for chrome and brave. * #17907 / Form / Fixed tableviewsaver js error in subrecords. Fixed not working combination of rememberLastPill and subrecord tableview. * #17950 / Form / Readonly now disables filepond upload on client side. * #17964 / Form / Added r upload support for filepond. Added new documentation about currently accepted extensions. Added xml upload support for filepond. * #17997 / Form / Fixed client side check for maxFileSize. Add system maxFileSize for upload element in report. * #18029 / Form / Store fillStoreVars in save process. * #18044 / Form / Fabric not working. Version 24.1.0.rc1 ------------------ Date: 16.01.2024 Notes ^^^^^ * Report: QFQ Syntax without numbering :ref:`nesting_alias`' * Chat: Full chat server with datebase support. FormElement :ref:`input-chat`, Config Web Socket :ref:`install-websocket`. Check necessary Javascript includes (popper.min.js) :ref:`setup-css-js` or update to latest UZH_CD template. * File Upload: New file upload function - either a FormElement :ref:`input-upload` or directly in Report :ref:`column-upload`. Supports Drag'n'Drop. Check necessary Javascript & CSS includes (filepond*.css|js)) :ref:`setup-css-js` or update to latest UZH_CD template. * QfqWiki: Use TinyMCE together with QFQ to implement WIKI functionality :ref:`wiki`. * Edit Report: syntax highlight, suggestions, indention - via FrontEnd :ref:`inline-report` editing or partly in the BackEnd (enable T3 extension `Editor with syntax highlighting` ). Check necessary Javascript includes (codemirror-qfq.min.js). :ref:`setup-css-js` or update to latest UZH_CD template. * Form: Optional buttons for previous/next record, see :ref:`btnPreviousNextSql`. Features ^^^^^^^^ * #4026 / QFQ / sqlLog.sql: log number of FE.id. * #4413 / Form / fieldset: show/hidden, modeSql, dynamicUpdate. * #8702 / Form / Load Record which is locked: missing user info. * #8975 / Report / Notation 2.0 - without numbers. * #10793 / QFQ / Update NPM Package. * #15324 / Report / Direct upload via qfq/report - special case of 'Inline-Edit' ('formlet'). * #15634 / QFQ / Wiki. * #15790 / Form / Record lock (dirty): same user should be able to unlock. * #16236,#9129 / Form / FormEditor: sqlValidate - Dialog enhancements. * #16754 / QFQ / Web link checker. * #16990 / QFQ / Link 'A:data-ignore-history'. * #17086 / Form / Multiple Forms on a page. * #17192 / QFQ / Stored procedure: QIFPREPEND. * #17200 / QFQ / Alert Container change description/buttons. * #17255 / Form / Migrate Record Locking Alerts to 'AlertInfo': not logged in qfq.log, friendly UI. * #17393 / Form / FE Report Editor: add CodeMirror qfq language. * #17461 / QFQ / Include WITH keyword. * #17462,#17540 / Form / FormElement Chat V1.0 & 1.1 - see `Documentation-develop/CHAT.md`. * #17498 / Form / Previous/Next Buttons on Form to change records. Bug Fixes ^^^^^^^^^ * #14233 / Report / AS _link: question - HTML is not rendered. * #14464 / Form / Exception: Missing button to edit FormElement with broken sqlValidate / beforeLoad. * #15880 / Form / FE Input type text and automatic slash before 'fileadmin/...'. * #16736 / QFQ / Destroys it own config. * #17169 / Form / FE.type=datetime: missing dirty on 'remove date'. * #17224 / Form / Undefined variable $rowHtml. * #17228 / T3 / Typo3 v11 deprecation registerPlugin. * #17229 / QFQ / QFQ writes Switch feUser logs. * #17256 / QFQ / Rename 'Autocron.php' - collision with 'autocron.php'. * #17293 / Doc / Undocumented Feature: emptyMeansNull works not just for text. * #17315 / Report / AS _encrypt=(...) does not encrypt data or truncates sql statement. * #17397 / Form / Dynamic Update Broken After CodingWeek23 only for r>0. * #17487 / Form / Dropdown disabled elements not showing correct width. * #17519 / Upload / FilePond js error. * #17529 / QFQ / Missing Chart.min.js in dev branch. * #17531 / QFQ / Inline editor dark mode path changed. * #17536 / QFQ / filepond upload initialization broken with multiple pills. Version 23.10.1 --------------- Date: 22.10.2023 Notes ^^^^^ Features ^^^^^^^^ * #15682 / Subrecord hide please save record first if there is no table title. * #15098 / Implemented qfqFunction in QFQ variable for usage in forms. * Doc: Replace many places single back tick by double back tick. Add hint for 'Row size too large'. Add hint how to use mysqldump to export one row per record. * index.rst: Added Enis & Jan as Developer. Bug Fixes ^^^^^^^^^ * #17003 / inline edit - dark mode has wrong css path. * #17075 / Fix broken '... AS _restClient'. * #17091 / upload_Incorrect_integer_value_fileSize. * #17148 / RTD: Fix broken readthedocs rendering. Version 23.10.0 --------------- Date: 05.10.2023 Features ^^^^^^^^ * #16350 / QFQ Table 'FormSubmiLog': update recordid after insert. * #16350 / sql.log: reference to FormSubmitLog entry. All SQL statements generated by one HTTP Post (Form Submit) can be identified. * #16350 / Do not log Dirty. * #16350 / If the T3 instance is behind a proxy, log HTTP_X_REAL_IP instead of REMOTE_ADDR in logfiles. * #16584 / FormEditor Report: Default without statistics. * #16589 / Implemented language configuration in backend for tt-content type qfq. * #16798 / Report inline edit v2. Improved search inside inline edit report. Whole content will be searched. Added ability to switch the editor to dark mode. * Doc: Refactor description of {{random:V}}. * Doc: Add config option 'protectedFolderCheck'. Bug Fixes ^^^^^^^^^ * #16573 / Fixed wrong built date and datetime string if default value was given. * #16574 / Added multiple siteConfigurations compatibility for typo3 v10 and 11. * #16616 / Fixed typeahead api query response problem if typeahead sql is not used. * #16664 / Fix multi db user error. * #16975 / Fix problem if a 'Form Submit' contains more than 64kB data. This can happen easily for 'fabric' elements. Version 23.6.4 -------------- Date: 26.06.2023 Bug Fixes ^^^^^^^^^ * #16485 / TypeAhead: strpos() string, array given error. * #16488 / Missing default values break saving records. New custom FE.parameter.defaultValue. * #16491 / FE Typ Upload - JS failure: document.querySelector() is null. Version 23.6.3 -------------- Date: 22.06.2023 Bug Fixes ^^^^^^^^^ * #16478 / Rest API: Fixed stream_get_contents failure in PHP8.1 Generic Error. Version 23.6.2 -------------- Date: 21.06.2023 Bug Fixes ^^^^^^^^^ * #16475 / Spontaneous spaces in HTML emails. * #16476 / SQL columns Text/Blog with default empty string becomes "''" Version 23.6.1 -------------- Date: 16.06.2023 Notes ^^^^^ * QFQ is Typo3 V11 compatible Bug Fixes ^^^^^^^^^ * #16372 / Upload Element 'Undefined index htmlDownloadButton' und 'unknown mode ID' * #16381 / Form title dynamic update broken. * #16392 / Reevaluate sanitize class for each store. * Fix db column enum dropdown 'data truncated' * DB Update 'alter index' pre check if exists * FE: Upload - fix undefined index. Version 23.6.0 -------------- Date: 09.06.2023 Features ^^^^^^^^ * Typo3 V11 compatible * #9579 / Multiform with Process Row. * #15770 / httpOrigin: Parameter missing in QFQ Config. * #16285 / PHP V8 Migration. * #16364 / T3 >=V10 pageSlug and ForwardPage. * Add .phpunit.result.cache to .gitignore. * Add bullet-orange.gif. * Add index createdFeUserFormId to table FormSubmitLog. * Doc: Add link to icons. Update use-case self-registration and add info in case of namesake. Unify word 'spam' to 'junk'. Add bootstrap links. * Remove Form/FormElement parameter 'feGroup'. * QFQ Typo3 Updatewizard: Sort output by page and tt-content ordering. Add page uid an title to be reported. Inline Edit: add tt_content uid and header as tooltip. * Update package.json. * Update to PHPUnit version 9. Bug Fixes ^^^^^^^^^ * #12468 / Form: Dynamic Update Form.title after save. * #14636 / 'Clear Me'-cross lighter and 2 px up. * #15445 / Doc: JS Output Widged added. * #15497 / Delete link: a) broken for 'table', b) broken with 'r:3'. * #15527 / Form/subrecord: class 'qfq-table-50' no impact. * #15654 / Form FE required 'Undefined index Error'. * #15659 / Multi Form: Datetime Picker not aligned. * #15691 / T3 V10: Export PDF (PDF Generator) invalid link causes error. * #15726 / Formelement upload stays required when changed from required to hidden. * #15729 / Form: text readonly input should show newline as '
'. * #15747 / Typeahead does not work with special character. Added croatian special chars (Ć,ć,Č,č,Đ,đ,Š,š,Ž,ž) to alnumx whitelist. * #15763 / Search/Refactor: a) search for ID, b) message if nothing is found - New highlighting for disabled content. Added output for not found in search. * #15773 / TypeAhead missing check type warning. * #15813 / Pressing 'Enter' in Form asks: Do you really want to delete the record? * #15875 / Unecessary qfq-config save. * #15905 / FE type time undefined index. * #15913 / Refactor: Footer displayed at the wrong place. * #15921 / Frontend edit Report Codemirror resizeable. * #16004 / Template Group Fields broken. * #16046 / Datepicker not initialized in Template Group. * #16051 / Dropdown menu: Download file broken with ZIP File. * #16055 / Dropdown option with render mode 3 format problem. * #16064 / Dynamic Update Checkbox and Form Store in parameter. * #16073 / saveButtonActive is disabled after first save. * #16201 / Character Count Class Quotation Mark. * #16204 / TypeAhead Prefetch Expects String Array Given. * #16228 / extraButtonPassword unhide broken. * #16264 / Multi DB Broken since QFQ V23.2.0. * #16273 / TinyMCE image upload path incorrect for T3 v10 and upwards. Version 23.3.1 -------------- Date: 31.03.2023 Bug Fixes ^^^^^^^^^ * #15920 / QFQ variable evaluation broken: wrong variable name Version 23.3.0 -------------- Date: 30.03.2023 Features ^^^^^^^^ * #15491 / Search refactor redesign and T3 V10 compatiblity: underscore character, counter fixed, page alias and slug handling. * #15529 / Form/subrecord: Design Titel / Box. * #15570 / Changed DB handling in class FormAction. Fixed multi-db problem with this. Included change for check of existing form editor report. * #15579 / Ability for searching all possible characters, includes not replaced QFQ variables. * #15627 / Added character count and maxLength feature for TinyMCE. * Add various icons to documentation. * Doc: Form.rst: reference 'orderColumn'. * Doc: Report.rst: fix typo, add icons, improved example for tablesorter. * Add indexes for table FormSubmitLog. * FormEditor: Show Tablename in pill 'table definition'. * FormEditor: FE subrecord > show container id below name. Bug Fixes ^^^^^^^^^ * #14754 / Using double quotes in tableview config caused sql error. * #15474 / Form save button activated after clicking in TinyMCE editor. Should only activate after change. * #15483 / Protected folder check fixed. Changed default of wget, preventing errors. Changed handling from protected folder check, new once a day. * #15521 / FormEditor assigns always container, even none is selected. Change handling of form variables from type select, radio and checkbox. Expected 0 from client request instead of empty string. * #15523 / Search/Refactor broken for Multi-DB. * #15626 / Multi-DB: FormEditor save error. Version 23.10.1 --------------- Date: 22.10.2023 Notes ^^^^^ Features ^^^^^^^^ * #15098 / Implemented qfqFunction in QFQ variable for usage in forms. * Doc: Replace many places single back tick by double back tick. Add hint for 'Row size too large'. Added Enis & Jan as Developer. Add hint use mysqldump with one row per record. Bug Fixes ^^^^^^^^^ * #17003 / inline edit - dark mode has wrong css path. * #17075 / Fix broken '... AS _restClient'. * #17091 / upload_Incorrect_integer_value_fileSize. * #15795 / Upload: download button not shown after pressing save. * RTD: Fix broken readthedocs rendering. Version 23.10.0 --------------- Date: 05.10.2023 Features ^^^^^^^^ * #16350 / QFQ Table 'FormSubmiLog': update recordid after insert. * #16350 / sql.log: reference to FormSubmitLog entry. All SQL statements generated by one HTTP Post (Form Submit) can be identified. * #16350 / Do not log Dirty. * #16350 / If the T3 instance is behind a proxy, log HTTP_X_REAL_IP instead of REMOTE_ADDR in logfiles. * #16584 / FormEditor Report: Default without statistics. * #16589 / Implemented language configuration in backend for tt-content type qfq. * #16798 / Report inline edit V2. Improved search inside inline edit report. Whole content will be searched. Added ability to switch the editor to dark mode. * Doc: Refactor description of {{random:V}}. * Doc: Add config option 'protectedFolderCheck'. Bug Fixes ^^^^^^^^^ * #16573 / Fixed wrong built date and datetime string if default value was given. * #16574 / Added multiple siteConfigurations compatibility for typo3 v10 and 11. * #16616 / Fixed typeahead api query response problem if typeahead sql is not used. * #16664 / Fix multi db user error. * #16975 / Fix problem if a 'Form Submit' contains more than 64kB data. This can happen easily for 'fabric' elements. Version 23.6.4 -------------- Date: 26.06.2023 Bug Fixes ^^^^^^^^^ * #16485 / TypeAhead: strpos() string, array given error. * #16488 / Missing default values break saving records. New custom FE.parameter.defaultValue. * #16491 / FE Typ Upload - JS failure: document.querySelector() is null. Version 23.6.3 -------------- Date: 22.06.2023 Bug Fixes ^^^^^^^^^ * #16478 / Rest API: Fixed stream_get_contents failure in PHP8.1 Generic Error. Version 23.6.2 -------------- Date: 21.06.2023 Bug Fixes ^^^^^^^^^ * #16475 / Spontaneous spaces in HTML emails. * #16476 / SQL columns Text/Blog with default empty string becomes "''" Version 23.6.1 -------------- Date: 16.06.2023 Notes ^^^^^ * QFQ is Typo3 V11 compatible Bug Fixes ^^^^^^^^^ * #16372 / Upload Element 'Undefined index htmlDownloadButton' und 'unknown mode ID' * #16381 / Form title dynamic update broken. * #16392 / Reevaluate sanitize class for each store. * Fix db column enum dropdown 'data truncated' * DB Update 'alter index' pre check if exists * FE: Upload - fix undefined index. Version 23.6.0 -------------- Date: 09.06.2023 Features ^^^^^^^^ * Typo3 V11 compatible * #9579 / Multiform with Process Row. * #15770 / httpOrigin: Parameter missing in QFQ Config. * #16285 / PHP V8 Migration. * #16364 / T3 >=V10 pageSlug and ForwardPage. * Add .phpunit.result.cache to .gitignore. * Add bullet-orange.gif. * Add index createdFeUserFormId to table FormSubmitLog. * Doc: Add link to icons. Update use-case self-registration and add info in case of namesake. Unify word 'spam' to 'junk'. Add bootstrap links. * Remove Form/FormElement parameter 'feGroup'. * QFQ Typo3 Updatewizard: Sort output by page and tt-content ordering. Add page uid an title to be reported. Inline Edit: add tt_content uid and header as tooltip. * Update package.json. * Update to PHPUnit version 9. Bug Fixes ^^^^^^^^^ * #12468 / Form: Dynamic Update Form.title after save. * #14636 / 'Clear Me'-cross lighter and 2 px up. * #15445 / Doc: JS Output Widged added. * #15497 / Delete link: a) broken for 'table', b) broken with 'r:3'. * #15527 / Form/subrecord: class 'qfq-table-50' no impact. * #15654 / Form FE required 'Undefined index Error'. * #15659 / Multi Form: Datetime Picker not aligned. * #15691 / T3 V10: Export PDF (PDF Generator) invalid link causes error. * #15726 / Formelement upload stays required when changed from required to hidden. * #15729 / Form: text readonly input should show newline as '
'. * #15747 / Typeahead does not work with special character. Added croatian special chars (Ć,ć,Č,č,Đ,đ,Š,š,Ž,ž) to alnumx whitelist. * #15763 / Search/Refactor: a) search for ID, b) message if nothing is found - New highlighting for disabled content. Added output for not found in search. * #15773 / TypeAhead missing check type warning. * #15813 / Pressing 'Enter' in Form asks: Do you really want to delete the record? * #15875 / Unecessary qfq-config save. * #15905 / FE type time undefined index. * #15913 / Refactor: Footer displayed at the wrong place. * #15921 / Frontend edit Report Codemirror resizeable. * #16004 / Template Group Fields broken. * #16046 / Datepicker not initialized in Template Group. * #16051 / Dropdown menu: Download file broken with ZIP File. * #16055 / Dropdown option with render mode 3 format problem. * #16064 / Dynamic Update Checkbox and Form Store in parameter. * #16073 / saveButtonActive is disabled after first save. * #16201 / Character Count Class Quotation Mark. * #16204 / TypeAhead Prefetch Expects String Array Given. * #16228 / extraButtonPassword unhide broken. * #16264 / Multi DB Broken since QFQ V23.2.0. * #16273 / TinyMCE image upload path incorrect for T3 v10 and upwards. Version 23.3.1 -------------- Date: 31.03.2023 Bug Fixes ^^^^^^^^^ * #15920 / QFQ variable evaluation broken: wrong variable name Version 23.3.0 -------------- Date: 30.03.2023 Features ^^^^^^^^ * #15491 / Search refactor redesign and T3 V10 compatiblity: underscore character, counter fixed, page alias and slug handling. * #15529 / Form/subrecord: Design Titel / Box. * #15570 / Changed DB handling in class FormAction. Fixed multi-db problem with this. Included change for check of existing form editor report. * #15579 / Ability for searching all possible characters, includes not replaced QFQ variables. * #15627 / Added character count and maxLength feature for TinyMCE. * Add various icons to documentation. * Doc Form.rst: reference 'orderColumn'. * Doc Report.rst: fix typo, add icons, improved example for tablesorter. * Add indexes for table FormSubmitLog. * FormEditor: Show Tablename in pill 'table definition'. * FormEditor: FE subrecord > show container id below name. Bug Fixes ^^^^^^^^^ * #14754 / Using double quotes in tableview config caused sql error. * #15483 / Protected folder check fixed. Changed default of wget, preventing errors. Changed handling from protected folder check, new once a day. * #15521 / FormEditor assigns always container, even none is selected. Change handling of form variables from type select, radio and checkbox. Expected 0 from client request instead of empty string. * #15523 / Search/Refactor broken for Multi-DB. * #15626 / Multi-DB: FormEditor save error. Version 23.2.0 -------------- Date: 05.02.2023 Notes ^^^^^ * QMANR, QMARK: new SQL prepared function to format Swiss Matrikelnumbers and mark found text. * Refactoring: Search form to support refactoring. Search over tables FormElement,Form,tt_content,pages. On T3 page 'form', replace `file=_formEditor` by `file={{file:SU:::_formEditor}}` Features ^^^^^^^^ * #7650 / For FormElement which are required: `indicateRequired=0|1` show or hide the 'required asterix'. * #10013 / FormEditor: Several textarea inputs changed to 'editor' incl. SQL syntax highlighting. * #14995 / Support for refactoring: search in QFQ Form/FormElement and Typo3 pages/tt-content tables. * QMANR: SQL prepared function to format Swiss Matrikelnumbers Bug Fixes ^^^^^^^^^ * #7899 / Fe.type=password / retype / required: always complain about missing value - bug has been fixed earlier. * #8668 / Fix that if a pill becomes disabled, child FE should not respected during save. * #15168 / Fixed language form save problem for t3 v >= 9. * #15420 / TypeAhead Prefetch triggers 'form changed' after save. * #15482 / Added missing password font file. Version 23.1.1 -------------- Date: 22.01.2023 Notes ^^^^^ * Additional option to dynamically fill the STORE_SYSTEM: fillStoreSystemBySqlRow Features ^^^^^^^^ * #11980 / check protected folder for access from outside after new qfq installation or update. * #13566 / Cleanup: Delete config-example.qfq.php * #15053 / New dynamic QFQ config option: fillStoreSystemBySqlRow. * Update SANITIZE_ALLOW_EMAIL_MESSAGE to be more generic: 'Invalid email format' * Update Documentation/Form.rst: Added QFQ Function QMANR(manr), broken ref to restAuthorization, fixed typos. * Update copyright year Bug Fixes ^^^^^^^^^ * #2665 / Fixed not working dynamic update with tinymce and codemirror. Improved frontend edit visualization, elements in window will be resized automatically. * #11517 / Fixed Bug not showing extraInfoButton on certain FormElements like: TextArea, Select, Checkbox, Radio, Upload, Editor. * #12066 / Form: Enter as submit forward not working. Version 23.1.0 -------------- Date: 05.01.2023 Features ^^^^^^^^ * #6250 / Enhance layout subrecord. * #10003 / Fieldset: stronger visualize group. * #15036 / FormElement subrecord summary additional row(s). * #15154 / FormElement input check via regexp: trim whitespace before regexp. Bug Fixes ^^^^^^^^^ * #14305 / Bug "No form found with this id". * #14997 / Tablesorter: Filter value shown but no effect after 'Browser Back' * #15191 / Broken datepicker in template group. * #15214 / Inline report save history. * #15229 / Typeahead and qfq-clear-me will be initialized after adding new fields. * #15230 / Set own button class for dropdown. * #15314 / FE & BE Email now filled in 'sipForTypo3Vars' and therefore available in API calls. * #15316 / config.baseUrl might be overwritten if no scheme or multiple urls are given. * Doc: Fix missing ! in doc: sqlValidate. Fix index undefined htmlAllow. Fix filemtime() Warning. * Fixed date to datetime convert bug. * Fixed error coming from typeahead when array is empty. Version 22.12.1 --------------- Date: 18.12.2022 Notes ^^^^^ * New Button Sizes: btn-tiny, btn-small. * Caching for on the fly rendered files (PDF, Excel, ZIP). * Inline Report edit saves history to T3. Features ^^^^^^^^ * #5715 / Caching for on the fly rendred files (PDF, Excel, ZIP). * #6250 / Enhance form layout: a) Subrecord, b) Subrecord-Title * #9927 / Do QFQ Update (config, table defintion) only if there is a BE user logged in the current session. * #12503 / Detect likely unwanted UPDATE statement with missing WHERE. * New Button Sizes: btn-tiny, btn-small Bug Fixes ^^^^^^^^^ * #14305 / Inline Report edit saves history to Typo 3. * #14506 / Tablesorter: after form close, already defined filter criteria in tablesorter will be applied. * #15188 / Clean up config to T3 parameter. * #15193 / No form found with this id error in MultiDB Setup. * #15206 / Form Save: Internal Error in MultiDB Setup. * Fix Doc: latest CCS/JS includes. Version 22.12.0 --------------- Date: 11.12.2022 Notes ^^^^^ * Customable list of FE names that won't be logged to SubmitFormLog. Default is 'password'. List of FE can be customized per QFQ installation and/or per form. * Subrecord: * Dynamically computed 'new' button in subrecord: FE.parameter.new. Use regular `... AS _link` syntax. * Per row customizeable edit and delete button. Use special column name `_rowEdit` and `_rowDelete`. Use regular `... AS _link` syntax. * Link/Tablesorter: New link qualifier `|Y:...` which is invisible to the user, but will be respected by tablesorter and filter. * Link: Text before and/or after a link - `|v:...|V:...`. Example: if fbeg/fend () is used and there should be more than one link inside:: 'p:{{pageAlias:T}}|t:Reload 1|v:Some text before |V: - ' AS '_link|_noWrap', 'p:{{pageAlias:T}}|t:Reload 2|V:' AS '_link|_noWrap' * QFQ Config option: forceSmtpSender - force sendmail to use specified sender address. Features ^^^^^^^^ * #8187 / Subrecord: Dynamically computed subrecord 'new' button. Per row customizeable edit and delete button. * #11892 / Link/Buttons in HTML table column sort/filterable via tablesorter. Qualifier 'Y:...'. * #13945 / Link/Buttons: Text before and after link. * #14320 / TinyMCE: htmlAllow parameter - client and serverside check. Removes not allowed html tags. * #15075 / New QFQ config sendmail configuration: forceSmtpSender * #15111 / Special column name: _saveZip. Save zip on server. * Documentation-develop/\*.md: CONFIG.md, Reformat * Fix undefined index in SendMail.php. Show message 'forceSmtpSender is active' in catch all mail. Skip forcing sender address in redirectAll mode. Bug Fixes ^^^^^^^^^ * #8891 / doNotLogColumn: list of FE.name in qfq config and/or form parameter. Value of such column will be logged as '*hide in log*'. List default is 'password'. * #13716 / Mask typed password: Added new (local) font file. * #14245 / After change via datetimepicker form save button keeps disabled. * #14303 / Datetime broken with picker * #14323 / Render mode: Fixed unit test. * #15013,#15014 / (Again) Excel Import: fix import of regions. * #15026 / Multiple checkbox dynamic update not working correctly. * #15027 / Excel Export error when BE user is logged in. * #15028 / Encryption with special column name broken. * #15079 / Dynamic Update / Readonly: lost value * #15090 / typeahead: fixed bug with given empty array. * #15091 / Hidden FormElement: After save, value in typeahead input will be refreshed with actual data. Usability of processReadOnly is given even when dynamic update is active. Jquery serialize caused problems with checkbox setup. Version 22.11.0 --------------- Date: 27.11.2022 Features ^^^^^^^^ * #15075 / sendmail: special option forceSmtpSender Bug Fixes ^^^^^^^^^ * #11325 / SQL CALL() - insert() and select() should be supported now. * #14622 / FormElement `unexpected error` on save. * #15005 / TypeAhead Dynamic Update Mode Hidden to Required * #15014 / Excel import broken if multiple regions defined. * #15048 / STORE_USER broken. Version 22.10.1 --------------- Date: 24.10.2022 Notes ^^^^^ * Migration of existing Typo3 V9 to V10: Check #12584, #12440 Features ^^^^^^^^ * #12584, #12440 / Typo3 V10 Migration Script Replace Alias Patterns * #14738 / Datetimepicker: verify various setups * #14802 / DateTime own class and unit tests * Add doc to table vertical column via CSS, * Add qfq-badge-* to doc Bug Fixes ^^^^^^^^^ * #14618 / Changed logic behind getting first value from array (check for typeahead array was already given but was placed after the checkForEncryptedValue function). No exception possible. Function name changed to generic. Added new function is_multi_array to check if array is multidimensional and return true or false. * #14736 / Datetimepicker: FormElement.parameter.dateFormat - required. * #14755 / Fix for typeahead problem in t3 v9 and higher. Typeahead url will be setup same as save.php. Results to an absolute path. * #14813 / Report: dbIndex - missing per level definition * #14844 / Fixed bug of no working dynamic update and empty output in Form Store with Datetimepicker. * #14857 / String expected, array given. * #14885 / Fabric zoom problem. Version 22.10.0 --------------- Date: 04.10.2022 Notes ^^^^^ * TinyMCE Feature "upload images via drag'n'drop" now supported. Features ^^^^^^^^ * #14813 / Report: dbIndex - missing per level definition * #12474 / Check BaseConfigURL if it is given and the the last char is '/' * #12452 / baseUrl: add automatically '/' at end * #10782 / Tiny MCE: Image Upload & Image drag'n'drop Bug Fixes ^^^^^^^^^ * #14803 / MultiDB (different DB hosts): broken 'show table definition' in FormEditor - * #14791 / datetimepicker: undefined index: timeParts[2] * #14619 / Added note to missed bug fix. * #12630 / Added code commentary. Reformatted code. getUniqueFileName function changed. New logFileMessages implemented. * #14463 / llow statusbar (resize button included) to show as default. * #14455 / Drag and drop triggers record lock. * #13818 / htmlspecialchars_decode() - expects parameter 1 to be string, array given Version 22.9.2 -------------- Date: 22.09.2022 Features ^^^^^^^^ * #12630 / dateTimePicker refactored. Mode: 'qfq', 'browser', 'no'. Default: 'qfq' * Add release notes to update UZH CD to latest version and to remove QFQ JS/CSS includes from custom typoscript template. Bug Fixes ^^^^^^^^^ * #14619 / dateTimePicher: missing popup on first click, record not dirty Version 22.9.1 -------------- Date: 18.09.2022 Notes ^^^^^ In 22.5.0 CodeMirror has been implemented for Report editing in the front end. QFQ delivers now the minimized Javascript version too. Please check http://docs.qfq.io/en/master/Installation.html#setup-css-js for updated JS includes. T3 extension 'UZH_CD' should be updated to latest version >=22.09.18! Attention: since 22.09.07 UZH_CD includes all JS/CSS (exception: fabric). Remove all QFQ standard JS/CSS includes like datetimepicker, codemirror, ... from your typoscript template(s). Features ^^^^^^^^ * #14616 / Fabric updated to version 5. Annotation of images should now be supported again by modern browsers. * #10011,#10012 / RedirectAllMailto: optionally dynamically set by current logged in FE or BE User. * #14718 / Added prepared MySQL statement: QLEFT(), QRIGHT(). * #14635 / Add comment to update /etc/ImageMagick-6/policy.xml in case of 'convert-im6.q16: no images defined'. * #9052 / Report: CodeMirror with SQL Syntax Highlight in FE - minimized JS versions. * #T3 QFQ extension config: change 'enter-as-submit' from string to boolean. Bug Fixes ^^^^^^^^^ * #12452 / T3 QFQ extension setup: Fixes broken string in doc for 'baseUrl'. Version 22.9.0 -------------- Date: 04.09.2022 Features ^^^^^^^^ * Report.rst: Add description details to tablesorter view saver. Fix Typo QESC_SQUOTE. Bug Fixes ^^^^^^^^^ * #14660 / Tablesorter View Saver: Broken in Multi-DB Setup * #14622 / Temp workaround for broken exception - Encrypt/Decrypt detection. Version 22.8.1 -------------- Date: 28.08.2022 Features ^^^^^^^^ * #9221 / If FE_TYPEAHEAD_LDAP or FE_TYPEAHEAD_SQL is set, skip forcing maxlength to table column definition. Instead use custom supplied value. * Minor update form 'FormElement' * Refactor $buildElementFunctionName: remove indirect function calls from AbtractBuildForm.php to simplify debugging. * Extend Support::getColumnSize with further MariaDB column type sizes * Extension config description baseUrl: updated. Bug Fixes ^^^^^^^^^ * #14618 / string expected, null given. * #14611 / MultiDB: broken 'show table definition' in FormEditor. Add pill 'Table Definition' to form FormElement. * #14590 / emptyTypeAheadRequest'. * #9281 / QFQ system tables: Allow STRICT_TRANS_TABLES - Default '0' is now set for all INT columns. DB-Update will change column definition. TEXT columns still don't have a default: Before MariaDB 10.2.1, BLOB and TEXT columns could not be assigned a DEFAULT value. This restriction was lifted in MariaDB 10.2.1. * Removed empty typeahead request at the beginning Version 22.8.0 -------------- Date: 22.08.2022 Notes ^^^^^ * Add Enis Nuredini as developer. Features ^^^^^^^^ * #11262 / stored Procedure: QNBSP - replace space by ' '. * #14270 / FormEditor: add pill 'Table Definition'. * #14321 / Remember last used pill: on/off via QFQ config or per form. * #14588 / FormEditor: Remove bell for debugging Form/Session mode. * FormEditor: Column fe.mode shows now fe.modeSql by default. If empty, fe.mode will be shown. * QFQ_Encrypt_Decrypt - pre version - not finalized. Bug Fixes ^^^^^^^^^ * #4018 / Typeahead Attack Detected: Implement renamed keywords _ta_query, _ta_prefetch. Fix broken detection of typeahead mode. * #13689 / Enter auf Eingabefeld mit ungültigem Wert führt zu blurry Seite. * #14288 / Upload: removed upload + save > triggers general error. * #14291 / Doc minor fix: Upload Doku table broken. * #14292 / Upload: mode=required broken for advanced upload (non primary column) after first save. * #14302 / Doc minor fix. SanitizeTest.php: minor const replacement. * #14587 / Use case: Self Registration - table definiton broken in doc: Changed Table Person, to include index and auto increment + authExpire default Null. * SYSTEM_SECURITY_GET_MAX_LENGTH: take care that minimum is 32. * Update Release.rst and Installation.rst: add missing Codemirror.css|js * RestClient undefined array element fix. Version 22.5.0 -------------- Date: 16.05.2022 Notes ^^^^^ Please update your CSS and JS (T3 Main Template > Setup) to include the new DateTime Picker. Forms cannot save if the JS files are missing:: page.includeCSS.file08 = typo3conf/ext/qfq/Resources/Public/Css/bootstrap-datetimepicker.min.css page.includeCSS.file09 = typo3conf/ext/qfq/Resources/Public/Css/codemirror.css page.includeJS.file14 = typo3conf/ext/qfq/Resources/Public/JavaScript/moment.min.js page.includeJS.file15 = typo3conf/ext/qfq/Resources/Public/JavaScript/bootstrap-datetimepicker.min.js page.includeJS.file16 = typo3conf/ext/qfq/Resources/Public/JavaScript/codemirror.min.js page.includeJS.file17 = typo3conf/ext/qfq/Resources/Public/JavaScript/code-mirror-mode/sql/sql.min.js Features ^^^^^^^^ * #9052 / Report frontend editing: CodeMirror with syntax highlight. * #10096 / Date time picker. * #10782 / TinyMCE: image upload via drag'n'drop. 'fileUploadPath=fileadmin/...'. * #13440 / Form: remember last used pill in localstore. * #13543 / System - base url: multiple base url can be configured. * #13562 / System - base url: if not set, set base url. * #13572 / Form Load: better error message on try to load non existent record. * #13581 / Copy to clipboard: small animation on icon. * #13657 / Added two new twig report files to system: FormEditorTwig and autoCronTwig. * #13679 / tablesorter/subrecord: view-saver added. * #13788 / Date time picker: selectable weekdays. * Update / doc: datetimepicker requires moment.js - put it in example code before datetimepicker. * Update / QFQ config note to baseUrl. * Skip selenium to speed up. * Move Marc Egger to further contributor. Bug Fixes ^^^^^^^^^ * #9520 / Button Save inside form. * #10646 / typeAhead: maxLength by default 512. * #11134 / Set samesite header for cookies. * #11325 / SQL CALL is handled seperate. All statements will execute. If only a SELECT statement is used in PROCEDURE then the output will shown, otherwise not. * #13658 / qfq.json: remove world readable. * #12483 / qfq.json - Doc: update all references of config.qfq.php to qfq.json * #12484 / config.render: old Both, new: Single. * #13084,9724 / Dropdown list on iOS not clickable. * #13527 / Form Multi: by default set r=0. * #13677 / FormEditor: Preview disabled if 'new.required' is given. * #13722 / Detect and fix pdfunite problems "Gen inside xref table too large (bigger than INT_MAX)" via pdf2ps, ps2pdf. * #13767 / Date time picker: up down button better design if required. * #13827 / Date time picker should not offer user credentials (like username / password). * #13751 / Date time picker dynamic update aware. * #13797 / Checkbox: dynamic update (single and multi) fixed. * #13818 / typeahead: fix for key/value problem: expects parameter 1 to be string, array given. * #13842 / Broken SIP: wkhtml and qfqpdf. * #13933 / Broken SIP: exception handling buggy. * #13860 / Safari: broken typeahead input. Version 21.12.0 --------------- Date: 13.12.2021 Notes ^^^^^ * New HTML to PDF renderer: puppeteer. Wrapped and used by qfqpdf. Solves various JS and CSS problems of wkhtml. Install: mkdir /opt/qfqpdf; cd /opt/qfqpdf curl -L -o qfqpdf https://www.math.uzh.ch/repo/qfqpdf/current/qfqpdf-linux chmod a+x qfqpdf * Module php-curl not needed anymore - has been replaced by php-stream. Features ^^^^^^^^ * #4812 / Subrecord - check for reserved Typo3 keywords (id, type, L) and throw exception. * #10145 / Typeahead Min Length = 0 is now possible. * #10715 / qfqpdf (puppeteer). * #13113 / Rewrite REST Client as php stream, add contentFile option. * #13242 / Apply given sanitize class to all defined stores. * #13330 / Multi Form: Upload. * #13333 / Option: Switch off attack detect. * #13496 / TinyMCEfontselect - Fontselect and fontsize are removed from the default configuration. * #12511 / Typo3 Store: new variables. * #13526 / QFQ tablesorter: Rename 'private view' to 'personal view' and 'public view' to 'group view'. * #12541 / Page and link without pageAlias. Bug Fixes ^^^^^^^^^ * #3446 / Unknown permission mode: 'logged_in' * #9268 / SELECT with outer brackets not recognized as SELECT * #13030 / Max length cuts - line endings \r\n has been counted as two chars. During input they are counted as 1 and therefore on data load the string has been cutted. * #13139 / Tablesorter: some elements are in front of a sticky title row * #13507 / QFQ function should work without 'sql=' * #13525 / makefile adjusted for multiple users Version 21.6.0 -------------- Date: 29.06.2021 Notes ^^^^^ * For full image HEIC/HEIF support, please install package ``libheif-examples``. Features ^^^^^^^^ * #8945 / Best practice :ref:`self-registration` * #12551 / Add QFQ bootstrap diagram * #12615 / Implements silent HEIC/HEIF conversion to png. * #12636 / New FormElement.encoding = 'single tick' * Form.rst: Update doc of Multi-Form Bug Fixes ^^^^^^^^^ * #12701 / Bug 'spaces in mails'. Replaces '
' by '
\r\n' * #9371 / MultiSQL now accepts `_id` too. * #12674 / QFQ Function subheader: skip deleted * Remove keySemId and keySemIdUser - outdated / deprecated since 0.19.0 (pre 09.2017) * Download.php: Fix broken variable $this->$downloadDebugLog. Version 21.5.1 -------------- Date: 17.05.2021 Notes ^^^^^ * The `log` directory was moved into the `qfqProject` directory in version 21.2.0 for new installations. But if the directory `fileadmin/protected/log` already exists then QFQ keeps storing logs there. This was added to release notes of 21.2.0 in hindsight. Features ^^^^^^^^ * #12183 / Download table as csv * #12159 / Make url paths absolute (relative to baseUrl) Bug Fixes ^^^^^^^^^ * #12516 / Password Hashing Exception Version 21.5.0 -------------- Date: 02.05.2021 Features ^^^^^^^^ * CodingGuideline.rst: add Form Best practice Bug Fixes ^^^^^^^^^ * #10505 / Drag'n'Drop broken on Multi DB Instance - all checks done * #10754 / Clean up stale requirements.txt * #11769 / Missing description table in Form.rst * #12352 / Form As Json: copy via JSON in FormEditor broken. * #12398 / Fix check required for uploads * #12475 / During QFQ update take care that all system tables exist. * #12479 / Remove unwrap('p-tag') for TinyMCE - currently, this breaks regular consecutive

tags Version 21.4.0 -------------- Date: 11.04.2021 Notes ^^^^^ * The new introduced 'Form As File' Feature in QFQ Version 21.3.* has been disabled. Instead every form can be imported and exported as JSON. The automatic import/export was not stable and a manual process promises less problems. Features ^^^^^^^^ * #12015 / useAdvancedFormEditor: disable form sync using feature flag * #12346 / Add new formJson.json to system forms * #12345 / Update documentation of special column formJson * REST.rst: small reformat. * Add Test copyToClipboard * HTTP Header: Add 'X-Api-Key'. Fix problem for token without argument name. Update doc. * Add margin to qfq-badge * Fix undefined clearMe * File formEditor.sql only contains QFQ system table definitions anymore. Bug Fixes ^^^^^^^^^ * #12341 / FormSubmitLog also saves FormName (not only FormId) * #11265 / Dropdown Menu: wrap with

breaks dropdown * #12268 / Enhanced FormSubmitLog Page Sample Code * gitlab-ci.yml: ``mkdir -p ...`` suppresses warning if directory already exist. Add more descriptive message. * docker/run_qfq_docker.sh: 'source' eines files, das nicht existiert, gibt immer einen Fehler auf stdout. * Fix problem: /var/www/html/my/typo3conf/ext/qfq/Classes/Core/Form/FormAction.php / Line: 394 / Undefined index: saveFormJson * extension/Classes/Core/Helper/SessionCookie.php: Index 'host' was empty Version 21.3.2 -------------- Date: 22.03.2021 Features ^^^^^^^^ * #9528 / Implement option 'clearMe' to show a small X in input & textaera fields per FormElement, per Form or global. Bug Fixes ^^^^^^^^^ * #12015 / use Advanced Form Editor - problem with uppercase f in Form for form name. Version 21.3.1 -------------- Date: 21.03.2021 Notes ^^^^^ * Custom QFQ Function: * Call QFQ function from inside a report, at any place, as often as needed. The QFQ function code will be parsed only one time. Variables will be replaced in time. * Based on QFQ function: a new download source can be specified : source: Features ^^^^^^^^ * #11998 / Custom QFQ-Function * #12015 / Use Advanced FormEditor Bug Fixes ^^^^^^^^^ * Bug with empty Fabric string fixed Version 21.3.0 -------------- Date: 07.03.2021 Notes ^^^^^ * To enforce usage of the new form-list we throw an exception on QFQ update if the line "file=_formEditor" is not present in any tt-content bodytext. :ref:`form-editor`. * Persistent download links, combined with SQL based access check. :ref:`download`. * Check new file based definition of forms `form-as-file` - this makes it easier to work in team with GIT based files. Features ^^^^^^^^ * #12085 / Persistent download links. * #12022 / New Escape class HtmlSpecialChar 'h' * #11957 / Get European Timezone {{start:R::t}} * #11926 / Update Form As File Documentation * #12015 / Add formEditor as a system QFQ report and enforce formEditor existence * #11926 / Use alternate form and report directories for phpunit (form_phpunit) * #11953 / Logger.php: replace makePathAbsolute with Path functions * #11931 / Report minimal required PHP version and stop, if PHP version is too low. * #9213 / Add note for tablesorter. * Add EV tips for tablesorter as a table in doc Bug Fixes ^^^^^^^^^ * #12016 / Run Typo3 autoloader before password hashing if API request * #5444 / Typeahead FE value is now prefetched after save. Version 21.2.0 -------------- Date: 01.02.2021 Notes ^^^^^ * The `log` directory was moved into the `qfqProject` directory in version 21.2.0 for new installations. But if the directory `fileadmin/protected/log` already exists then QFQ keeps storing logs there. This was added to release notes of 21.2.0 in hindsight. Features ^^^^^^^^ * #10286 / Download Links: Glyphicon selbst wählen/ausblenden * #11878 / Purge extension option config.documentation * #6793 / Source files for ZIP archives might now specified with a path/filename how they are called inside the ZIP. * log directory was moved into qfqProject directory Bug Fixes ^^^^^^^^^ * #11925 / downloadButton Parameter 'd:Filename' * #9355 / Increase column width header & attach * #11865 / Form Editor exception when edited after saved * #11798 / Use T3 password hashing API instead of hack * #11750 / Checkbox does not work together correctly with required fields * #11666 / PHP 7.4: Trying to access array offset on value of type int * #11245 / If forwardMode column is set to '', set forwardMode to 'auto' Version 20.11.0 --------------- Date: 12.11.2020 Features ^^^^^^^^ * #7156 / Throw exception when a report level is defined twice. * #11335 / Sanitize Alnumx: allow 'ß' * #11325 / Allow SQL CALL(). Unsupported: Multiple (like query_multi()) - only the first one will be returned. * #11269 / REST Post might return a customized answer. * #11512 / Twig: add access to Var store * #11118 / Uniqueness is now guaranteed in {{random:V}} * #11513 / Add special column AS _script * #11509 / PDF split fails for broken PDF * #10979 / Ajax Calls an API - dataReport Bug Fixes ^^^^^^^^^ * #11430 / phpSpreadsheet throws exception that '' is not numeric * #10257 / Delete AS _link only worked with certain parameter order. * #11511 / Tablesorter: fix encoding error, sanitize base64 encoding * #11146 / Sendmail dynamic PDF broken * #10554 / Fix extrabuttonlock also for select, radio and checkbox * #11245 / If forwardMode column is set to '', set forwardMode to 'auto' Version 20.9.0 -------------- Date: 06.09.2020 Notes ^^^^^ * New SIP protected AJAX calls. * Report now fires calls to websocket (remote hosts). * Report now fires REST calls to remote hosts. Features ^^^^^^^^ * #10979 / Report: do SIP protected AJAX calls to typo3conf/ext/qfq/Classes/Api/dataReport.php. * #11076 / Report: trigger call to websockets. * #11119 / Report: REST Client calls - incl. processing of answer. * Add CodingGuideline.rst. Bug Fixes ^^^^^^^^^ * #10919 / AutoCron: Fix missing FillStoreSystemBySql. * #11075 / Form: Missing SQL error message in FE Action Elements. * #11039 / Fix CSS for Checkbox. Version 20.6.2 -------------- Date: 25.06.2020 Bug Fixes ^^^^^^^^^ * #10641 / TypeAheadTag: Fehler beim gleichzeitigen anlegen mehrerer neuer Tags * #10794 / Documentation: Crontab entry more clearly Version 20.6.1 -------------- Date: 24.06.2020 Features ^^^^^^^^ * #10778 / Upload ZIP and unpack Version 20.6.0 -------------- Date: 14.06.2020 Notes ^^^^^ * Add note in Installation.rst to start Apache with Locale en_US.UTF-8. This helps to support Umlaut and other characters in filenames and wkhtml commandline options (like header/footer). * Migrate documentation from T3 to ReadTheDocs.io - looks older but 'search' is much more better. New: chapters separated in individual files. * For the image to PDF feature, installation of `img2pdf` is required (please check :ref:`preparation`). Features ^^^^^^^^ * #10751 / Allow images to be concatenated for PDF download. * Fontawesome updated 5.13. * Extend FE.label size to 1023. * Local documentation rendering directly via Sphinx. * Manual: Search is working, table width not truncated anymore, PDF & epub export, redirect qfq.io/doc to docs.qfq.io. * Update copyright notice. Bug Fixes ^^^^^^^^^ * #10507 / FormElement.type: 'annotate' is defined two times in Enum * #10705 / New function 'HelperFile::joinPathFilename($pre, $post)'. Joins only if $post is without leading slash. Version 20.4.1 -------------- Date: 30.04.2020 Notes ^^^^^ * Developer: update local npm/font awesome packages via ``make bootstrap``. Features ^^^^^^^^ * #10433 / Update to Font Awesome 5.0 * #10379 / Stored Procedure: SLUGIFY() * Manual.rst: Example Report 'render'. Update several places to fit latest ReST layout rules. Version 20.4.0 -------------- Date: 05.04.2020 Notes ^^^^^ * New Feature: :ref:`type-ahead-tag` - extend regular input with multiple values via typeAhead. _ * MySQL StoredProcedure: * strip_tags() - Simple strip html tags. * QCC() - Escape colon / coma. Useful for QFQ link arguments like 'text' or 'tooltip'. Features ^^^^^^^^ * #9686 / Download: sanitize output filename. * #10358 / Configure path/environment via QFQ config: qpdf, gs, pdfunite. * #9517, #10145, #10177, #10117 / typeAheadTag. * #10152 / QCC() - Stored Procedure to escape colon / coma. * FabricJS: replaced glyphicons with font awesome. * Rename config.qfq.example.php config-example.qfq.php. Bug Fixes ^^^^^^^^^ * #6798 / Close didn't worked with r=0. * #10199 / Form.forwardMode: missing mode 'Close' / 'Auto'. * #10173 / Dynamic Update: Readonly element can't be activated via dynamic update. * Fix broken default value for Form.forwardMode. * Fix problem with reporting broken TG-FormElements. * Add error message if primary table does not exist. Version 20.2.0 -------------- Date: 02.02.2020 Notes ^^^^^ * Add new keyword 'render' in tt-content Report and QFQ config. 'render' will control if a) only Form OR Report will be rendered (render=single) or b) as previous Form AND Report together (render=both). * Advantage: with 'render=single' no more SELECT ... FROM (SELECT '') AS fake WHERE '{{form:SE}}'=''. * Attention: NEW default behaviour in new QFQ installations - render=single. Behaviour in old installations is unchanged. * tt-content records with 'render = api' can stay on the same page as the link to get the content (e.g. Excel Export). * Change default doc page to qfq.io/doc. * Add new specialColumnName: '_noWrap' - skips wrapping of fbeg,fsep,fend. * First version of 'FullCalendar.io' - new SpecialColumnName will follow in the future. Features ^^^^^^^^ * #9929 / New keyword '_noWrap' for column names (alias) - skips wrapping of fbeg/fskip/fend. * #9905 / Keyword 'render' in Report. Final implementation. Doc updated. * #9959 / Update QFQ Config on the fly. * #9990 / Describe order of FormElement processing - :ref:`form-process-order`. * #8658 / FullCalendar.io V3 implemented. * #9535 / VerticalText new implementation. * Manual.rst: Add list of icons. Enhance sendmail doc. * Change color of qfq-info-* from blue to light-blue. Add qfq-primary, qfq-danger. Bug Fixes ^^^^^^^^^ * #10010 / FE.type=sendmail will now be fired together with fe.type=after* (not after). * #5869 / Table names not properly escaped. * #9638 / TextArea: Autosize - broken when using clipboard, * Fixed problem with border showing when qfq-color-white is set. * Fix selenium tests, remove chromedriver from npm. * Log problem that crashes qfq when calendar dependencies are missing. * Fixed gruntfile problem. Version 20.1.1 -------------- Date: 13.01.2020 Bug Fixes ^^^^^^^^^ * #7705 / Fix problem with wrong value after save and form update. * #8587 / A form triggers a save only, if there are real table columns. Version 20.1.0 -------------- Date: 09.01.2020 Notes ^^^^^ * Deprecated: Form.parameter.mode. Use Form.parameter.formModeGlobal Features ^^^^^^^^ * #9805 / Form.parameter.activateFirstRequiredTab. * #9858 / Form.parameter: replace 'mode' by 'formModeGlobal' * #9860 / SQL function QMORE(): change text '...' to '[...]'. * Update Developer doc for record locking. * Mockup for error handling. Bug Fixes ^^^^^^^^^ * #7925 / Error in split PDF file during upload. Fix the cwd error in Logger. * #9789 / Record lock release to early on 'leave page'. QfqJS: Moved release lock to before unload. * #9861 / Fix problem with broken sql.log filename. * #8851 / Revert implementation: LogMode 'modify' vs. 'modifyAll'. * #9859 / Database Update: check for 'Update specialColumnName needed' breaks new QFQ install. * #9813 / During QFQ database update, skip errors like 'Error 1060 - Duplicate Column'. * Manual.rst: Fix various broken table layouts. Version 19.12.0 --------------- Date: 17.12.2019 Notes ^^^^^ * Switch the whole homepage to readonly: FormModeGlobal and STORE_USER Features ^^^^^^^^ * TinyMCE: grey out controls when readonly. * Mockup: * Update files to get CSS & JS files from their own directory structure (not an installed QFQ extension). * Add fontawesome, tablesorter to mockup 'formCheckbox.html'. * CI: Download selenium logs (only failed) under artifacts. * Dev: .gitignore: exclude some docker & selenium. * Merge Selenium Python Checks into Master. * #9686 / html decode and sanitize an export filename to become the 'save as'-filename. * #9666 / min-width for extraButtonInfo. * FormEditor: optimize minWidth for 'rowLabelInputNote' field. Bug Fixes ^^^^^^^^^ * #9720 / Checkbox dynamic update varoious settings: * Multi Plain Vertical & Horizontal, Checkbox Multi BS. * Fixed that label of 'checkbox' are bold and label of 'checkbox-inline' are normal. * #7974 / TinyMCE: ReadOnly. * #9424 / modeSql: skip if it starts with '#'. * #9674 / Select Required Dynamic Update. * #9678 / textarea now trigger DynamicUpdate. * #9679 / FormModeGlobal: add STORE_USER - system wide readonly. * #9690 / Select Required. * #9691 / Checkbox: dynamic update > readonly. HTML ID for checkbox elements. Dynamic update switch 'readonly' for 'checkbox plain multi' and 'radio plain multi'. * #9692 / Keyboard Select Checkbox. * #9720 / Checkbox: Various setups with dynamic update. * #9733 / Identify different tabs. Record lock for same tab will always be granted. * #9734 / Fix 'dirty lock release' - leaving a dirty form without closing, leaves a stale lock record. Added a releaselock() before window.unload. Dirty remove on goBack. * #9735 / File Delete: no dirty trigger. * Download / PDF merge: skip leading errors, interpret only 'Could not merge encrypted files'. * DragAndDrop broken: after refactoring Support.php, the dragAndDrop was broken - missed init of '$store'. Version 19.11.3 --------------- Date: 29.11.2019 Features ^^^^^^^^ * #8886 / Check pattern: after focus lost. * #9655 / Checkboxes and radios now defined with a min-width in horizontal plain mode. * #9617 / formModeGlobal: * Two modes of 'formModeGlobal' available: 'requiredOff' and 'requiredOffButMark'. * 'requiredOffButMark': * Renamed temporary 'skipRequiredCheck' to 'requiredOffButMark'. * Keep required marks after save. * Stop hiding helpblocks per default, set with class qfq-only-active-error. * Radio: new class 'qfq-disabled' if readonly is set. Softer blue. Mark disabled - changed hover. Text in darker orange. Simple-error renamed to qfq-notify - removed box around error. * New default class for 'form' tag: 'qfq-notify'. * Manual.rst: Add info for 'letter-no-break'. * Add validator.js to list of used packages. Bug Fixes ^^^^^^^^^ * #9670 / If `qpdf` fails to decrypt a PDF, try `gs`. * #3995 / Implemented partly: CheckBox and Radio can now be locked. * #8091 / Checkbox required: * If radio or checkbox is required and empty on submit, form save brings the element to front. * Fix radio plain vertical. * Fix label2 not to be bold. * Checkbox Plain Vertical: forces 'font-weight: 400;'. * Updated colors for checkboxes/radios. * #9638 / Textarea Sizing: Now also listens for paste. * #7891 / Added missing 'type="button"' to button element. * Remove ' style="font-size: 1em;"' in extraButton - this causes extra space between multiple extraButton inline in one input element. Version 19.11.2 --------------- Date: 25.11.2019 Notes ^^^^^ * Enhance formModeGlobal=requiredOff/-ButMark (temporarily skipRequiredCheck): fill's '{{allRequiredGiven:V}}' before save to 1 (all given) else 0. * Offers user to save form, even if not all required data are given and offers application logic to check easily if all required fields has been filled. Features ^^^^^^^^ * #9526 / Mark required fields more visible. * #9617 / Improve 'formModeGlobal=requiredOff'. * Feature `Form.formModeGlobal` implemented - STORE_SIP overwrites form definition. * New STORE_VAR variable 'allRequiredGiven'. Becomes '1' if all required fields are given, else 0. * Add param 'L' & 'type' automatically to form save. * Manual.rst: Procedure to find an irreproducible error. * Change definition of QFQ system tables for 'modified' and 'created'. Use DATETIME instead of TIMESTAMP. Bug Fixes ^^^^^^^^^ * #7639 / subrecord drag n drop: * `orderInterval` has not been respected. * Update Manual.rst. * Fake STORE_SIP so it can be used during processing sql1. * The record, currently loaded into form, is available via STORE_RECORD. * Check for id/_id and ord/_ord. * Throw meaningful exception if missing 'id' or 'ord'. * Fixes bug that no mime_type_content is called if there is on file. * Fix broken regex101 url. Version 19.11.1 --------------- Date: 11.11.2019 Bug Fixes ^^^^^^^^^ * #9532 / 'Advanced Upload' broken - slaveId/sqlUpdate/... have been processed two times, after multiform code changes. Version 19.11.0 --------------- Date: 08.11.2019 Notes ^^^^^ New CSS Class: * 'qfq-sticky' - to make an element sticky. Update/new stored procedures: * QMORE: change symbols from '..more' / '..less' to '...' / '<<'. * QIFEMPTY: add empty detection for a) date, b) datetime, c) '0'. * QDATE_FORMAT(timestamp). Return text in 'dd.mm.yyyy hh:mm' format or '-' if timestamp is empty. Features ^^^^^^^^ * #9521 / Textarea auto-grow. Update Manual.rst. New class qfq-auto-grow for textareas. * Update FormEditor to 80,1,350. * Alerts a) changed overlay to blur and white, b) optimized to better reading for developer - ':hover' inside of error messages: black text and blue highlight. * Add new CSS class 'qfq-sticky-element' - to stick individual elements. Bug Fixes ^^^^^^^^^ * #9354 / Missing border around form if there are no pills / no title * #9053 / Using the tablesorter filter in form triggers dirty detection for save. Set qfq-skip-dirty on all tablesorter-filter. * #2720 / Formelement 'radio' - required failed. * #9512 / PDF merge fails on encrypted PDFs. Try to use qpdf to decrypt. * #6232 / Missing required: Pill/Input not 'bring to front' - Textarea, Editor, Radio. * #9300 / Fix Name restMethod-FormElement. * Add '@' to various PHP/IO function to suppress generic OS exception - now QFQ will report customized messages. * FormEditor / error message: fix missing formId in STORE_SIP on calling FE directly from error message. * Manual.rst: Tip for wkhtml added. Add description for 'fileButtonText'. Adjustments for 'slaveId' concept. Version 19.10.0 --------------- Date: 17.10.2019 Notes ^^^^^ * Background color of popups & error messages changed. * slaveId/sqlInsert/sqlUpdate/sqlDelete are now available for all FormElements. * New MySQL stored procedure strip_tags() function. Features ^^^^^^^^ * #5695 / First implementation of multiform. * #7495 / Removed dirty flag when 'enable-save-button' is set. * Add MySQL strip_tags() function. Bug Fixes ^^^^^^^^^ * #9329 / Fabric annotations. Fixed Scaling Problem on Static Canvas instances. * #9298 / Fix timeout of file_get_contents. Extend timeout for downloadPage to 10min. * #9274 / PHP 7.3 reports: switch statement with 'continue 2'. * #9269 / fillStoreForm now fired two times in API calls. The first time during loadFormDefinition and the second time after the STORE_TYPO3 has been faked via SIP. * Manual.rst: Add '!' to fillStoreVar Query * Increase z-index in CSS 'dropdown-menu' class to 1060. The 'tablesorter > columnselector' will be hidden with 'qfq-sticky' by values < 1000. * Reduce z-index in CSS 'qfq-sticky' class from 9999 to 1000. The 'tablesorter > columnselector' will be hidden with values > 1060. Version 19.9.1 -------------- Date: 21.09.2019 Notes ^^^^^ * Use the CSS class 'qfq-sticky' in `` to make a table header 'sticky' - on long pages such tables headers are always visible. * The page with the list of all forms: a new best practice report includes useful statistics :ref:`form-editor` - best is to replace the old code. * The DB User needs privileges to the Typo3 database of at least table `tt_content` with SELECT. Features ^^^^^^^^ * #9203 / Pin the header of table (CCS 'sticky'), to make it always visible even if the page scrolls down. * #9172 / AutoCron: new colum 'autoGenerated', 'xId' * #9089 / Move Stored Procedure to SECURITY=INVOKER * Manual.rst: Best practice :ref:`form-editor` * Reduce BS legend.font-size from 21 to 17. * Change doc of tablesorter to use 'sorter-false' as class. Bug Fixes ^^^^^^^^^ * #9074 / QFQ query with nested QFQ query failed, if the outer QFQ query is a multi column query ( ='{{!' ). Fixed. Version 19.9.0 -------------- Date: 09.09.2019 Notes ^^^^^ * Size of input elements now might be specified dynamically (with min and max height). * Twig converts JSON objects to an array. Features ^^^^^^^^ * Report.php: Twig, convert JSON object into associative array. * Test SQL stored procedure in Form report. * qfq-bs.css.less: a) reduce 'qfq-note' padding-top from 7 to 2 px, b) reduce 'legend' margin-bottom from 25 to 0. * Debug output sendmail redirect all: addresses now always space delimited. * FormEditor: * Remove FormElement 'tabindex'. * Change FormElement.class from 'Select' to 'Radio'. * Manual.rst: * Clean syntax highlight. * Update realtime log file QFQ code. * Add 'Best Practice' code to show QFQ log files in realtime. Reformat some content. * #7849 / New option 'fileTrash' and 'fileTrashText'. * #7682 / 'Input textarea auto height' * #4434 / Special column names now have to start with underscore. Earlier it was recognised even if there was no underscore. Bug Fixes ^^^^^^^^^ * #7860 / Special column name 'mailto' no handles text correctly if multi byte encoded. Fixed. * #7849 / Missed filename after the file chooser selected an file. Fixed. * #1201 / FE.parameter option 'tabindex' has never been implemented. Removed. According https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/tabindex only the values '0' and '-1' are good. * Add table html-id to subrecords, created by QFQ. Needed for tablesorter. * Add TinyMCE to list of 'Software distributed together with QFQ' Version 19.8.0 -------------- Date: 28.08.2019 Features ^^^^^^^^ * Manual.rst: * Update tablesorter ``class="sorter-false"``. * Add note to include font-awesome. * :ref:`dbg-qfq-log` documentation. * Enhance wkhtml debug info. * Add link to https://mariadb.com/kb/en/library/stored-routine-privileges/ * Increase Length of column Form.forwardPage limit from 255 to 511. * Index.rst: Add Rafi, Elias, Nicola as further contributors. * Add SQL stored procedure QIFEMPTY(). * #8806 / Add SQL stored procedure QNL2BR(). * #8851 / Add sqlLogMode modifyAll and restrict sqlLogMode modify. * #8859 / FormEditor: Filter + ColumnSelector. * #8856 / AutoCron: SQL logMode should be defined separately. Bug Fixes ^^^^^^^^^ * #8933 / Broken record lock: lock extend does not work - fixed. * #8846 / FormEditor: subrecord of FormElement might be wider than Form. * #8853 / fe.class=action: container should be hidden - hidden is wrong - FE-action might be assigned to templateGrou Container. New solution: if FE.class='action' only templateGroups are in the 'container' list. * #6656 / Merge DragnDrop into 'master' * Update compatibility: API change in T3 makes QFQ incompatible with Typo3 >=9.4. Change compatibility back to <9.3. Problem: sys_language_uid * Update QFQ from earlier/equal version than 0.19.2 fails to create table 'Cron'. Version 19.7.1 -------------- Date: 17.07.2019 Notes ^^^^^ * TWIG integration Features ^^^^^^^^ * TWIG: * Add Twig Extension to parse QFQ Links * Pass assoc-array of query result as context * allow to pass template as string * Database.php: extend function sql error message * #8179 / extraButtonLock and extraButtonPassword might be specified without a value or with 0 or with 1. Bug Fixes ^^^^^^^^^ * Database.php: fix CodeException * Fabric: Readonly now displays annotations again. Version 19.7.0 -------------- Date: 02.07.2019 Notes ^^^^^ * Settings for tablesorter can now be saved. * Selenium docker based is integrated now. Features ^^^^^^^^ * #7284 / tablesorter save sort order * #8592 / Fixed button display, added Alert instead of disabled button. * #8204 / position required mark * Excel.php: Delete superficial autoloader require * Cleanup: hashPassword.php moved from Api to External. * Cleanup unwanted git tracked files: Documentation-develop/jsdoc|... * Selenium + Docker * Update .gitignore - documentation directory moved several days ago. Bug Fixes ^^^^^^^^^ * #6917 / Fix Monitor does not work. * #8098 / Fix Language specific retype label or note has not been set correctly. * Fix undefined index and potential undefined index. * Fix Autoloader for External/AutoCron.php. * Small fixes Manual.rst. * Fix broken Manual: unwanted '<' after '{{!' lead to fully broken Manual. * Fix path Source/api to Source/Api. Version 19.6.2 -------------- Date: 21.06.2019 Notes ^^^^^ The Rest API path changed: * old: typo3conf/ext/qfq/Source/api/rest.php * new: typo3conf/ext/qfq/Classes/Api/rest.php QFQ is now PSR4 compliant. Features ^^^^^^^^ * #8520 / Switch to psr4 composer. * #8272 / Disable 'save' button as long as an upload is running. * #7529 / Guarantee Sip Action plays only once. * #8577 / Documentation enhanced for behaviour of SELECT '_test'. Bug Fixes ^^^^^^^^^ * #7903 / Delete with 'table' as parameter doesn't work anymore. * #8571 / Primary Key: report error if lower/uppercase don't match - in general if given primary key is not found in table definition. * #8465 / Var substitute: '{{name:R:::0}}' default not used if it is '0'. Version 19.6.1 -------------- Date: 16.06.2019 Notes ^^^^^ * 'pdftk' is no longer used. * Please install 'poppler-utils' - the command 'pdfunite' is the replacement of 'pdftk'. Features ^^^^^^^^ * #8558 / Split error message in toUser and toDeveloper. Add error code. * #8562 / Replace pdftk by pdfunite. 'pdftk' is outdated. It's hard to install on Ubuntu 18. It fails for recent PDFs. 'pdfunite' is based on poppler. URLs are preserved. Orientation and size are preserved. Bug Fixes ^^^^^^^^^ * Fix uniqIdQfq() - returned always badcaffeee1234 * Refactor function.sql to function.sql. Implement constants for Version numbers. * Update NewDoc.md Version 19.6.0 -------------- Date: 12.06.2019 Notes ^^^^^ * Add Marc Egger as Developer Bug Fixes ^^^^^^^^^ * #8523 / htmlid: remove spaces (war #8460). Replace uniqid() by uniqIdQfq() which delivers a constant id in case of running unit tests * #8430 / QFQ Doc mising. * Index.rst: customize URL for 'report a problem'. * Sitemap.rst: new created to be included by Index.rst. * Reformat Index.rst according https://github.com/TYPO3-Documentation/TYPO3CMS-Example-ExtensionManual.git. * Move doc to docker generation. Update ReST Syntax URLs. * Remove 'extension/Documentation.outdated'. * Update .gitignore to not commit rendered doc. * Manual.rst: Excel Export / PDF export replace 'uid:' with 'uid:' * Update SQL functions to hanlde errors more efficient. Version 19.5.1 -------------- Date: 22.05.2019 Notes ^^^^^ * New dropdown menu, fully dynamic via '... AS _link' incl. SIP generation. * New SQL stored procedure for use directly in SQL queries: * QMORE(text, length) - limits a text to 'length' characters, click on 'more' shows complete text. * QBAR(text) - escapes the character '|'. That one is heavily used in format strings for '... AS _link'. Features ^^^^^^^^ * #8391 / Additional line 'Website: ...' in sendmail redirect all. * #8270 / SQL Stored procedure QMORE(text,length): Limit long text to 'length' characters. Show button 'more'. * #8270 / SQL Stored procedure QBAR(text): Escape the character '|'. * #8348 / Dynamic Dropdown menu via '... AS _link' Bug Fixes ^^^^^^^^^ * #8116 / Error-Dialog - Button for FE element is broken. First problem: replacing '\n' with '
' failed for FE link. Second problem: FormEditor fixed in case missing {{formId:S}}. * #8315 / FE Datetime: 'd.m.yy hh:mm' thows an error * #8278: Too long GET var crashes QFQ - Bug 1 - check GET Vars but try to report problem from POST var. Bug 2: writing log message crashed due to not initialized QFQ-config. * Html2Pdf.php: Change logfile from sql.log to qfq.log * formEditor.sql: Add specific pattern message for Form.name allowed characters * Config.php: more precise error message Version 19.5.0 -------------- Date: 03.05.2019 Notes ^^^^^ * QFQ is now T3 V9.5 compatible. * Minimal required version increased to T3 V7. * QFQ description in ext_emconf.php updated > will be displayed on TER. Features ^^^^^^^^ * #5103 / Upload any file type: ``accept=*`` or ``accept=*/*`` or ``accept=*.*``. * Manual.rst: update all links to bootstrap to fixed version 3.4: https://getbootstrap.com/docs/3.4/... Bug Fixes ^^^^^^^^^ * Manual.rst: Update BS glyphicon URL * Manual.rst: replace '{{feUser:Y}}' by '{{feUser:T}}' * #8109 / Change email pattern and disable sanitize for FORM_UPDATE * #8149 / Excel Export cutoff at Column AA * #8113 / Fehler in Dokumentation für Default value Version 19.3.2 -------------- Date: 18.03.2019 Notes ^^^^^ * New Escape/Action Class: * 'X': Throw an exception if a variable isn't found. Custom message can be defined. * 'S': Stop replacing nested variables. * Form forward: * 'url-sip': Call a target page with SIP encoded parameter * 'url-sip-skip-history': Call a target page with SIP encoded parameter, do not add current page to browser history. * Report: new token 'fskipwrap' - comma separated list of column indexes. Suche columns won't be rendered with 'fbeg, fend'. * Upload max file size: * Default changed: * old: 10MB * new: System limit * Definition via a) system configuration, b) qfq setup, c) per Form, d) per FormElement Features ^^^^^^^^ * #8043 / New Escape/Action Class "Exception" if variable is not found. * #8012 / New Escape/Action Class "Stop replace" of nested variables. * #8067 / url-sip / url-sip-skip-history - Form forwarding can now be used with SIP encoded parameter. * #8072 / New token for Report: fskipwrap - wrapping of fields can be disabled per column. * #8041 / Upload: maxFileSize based on system maximum, qfq config, form config, formElement config * Manual.rst / Add more detailed description for '... AS _exec'. Add notes for 'fileSplit'. Bug Fixes ^^^^^^^^^ * #8035 / Missing sql.log: throws an error - fixed. * #8077 / PDF/fileSplit: uploaded PDF file with missing extension '.pdf' have not been recognized as PDF files - fixed. * #8076 / splitPdf: using 'fileSplit=jpeg' and uploading a PDF with only one page, results in filename 'split.jpg' (missing index '-0'). New: split.jpg is renamed internally to split-0.jpg to provide a unified naming scheme. * #8075 / Catch exception on filesize() - fixed: now return '-' for non existing files. Version 19.3.1 -------------- Date: 15.03.2019 Bug Fixes ^^^^^^^^^ * 8058 / Form > fillStoreVar: broken for TemplateGroup - Form.fillStoreVar not available during fillStoreForm(). * 8048 / A retype FE should not be checked for 'required' during save. Version 19.3.0 -------------- Date: 05.03.2019 Notes ^^^^^ * New FormElement 'datalist' for fe.type='select'. * FormElement 'annotate': * Now supports 'ReadOnly'. * 'grafic': Undo/Redo Features ^^^^^^^^ * #7729 / Select as datalist * #7783 / FormElement 'annotate' - ReadOnly mode is now supported for grafic/text. * FormElement 'annotate/grafic' History for undo / redo * FormEditor: by creating a new FormElement, the feIdContainer is now preselected based on the last choice. * Manual.rst: started to use more predefined Sphinx formatting styles. Bug Fixes ^^^^^^^^^ * #7978 / mail.log: not written in some cases - fixed * #7949 / Table MailLog: missing column 'cc,bcc' * Manual.rst: correct parameter 'mode' for special column name '_sendMail' Version 19.2.3 -------------- Date: 22.02.2019 Notes ^^^^^ New: `QFQ REST `__ interface implemented. Features ^^^^^^^^ * Rest Implementation with GET,PUT,POST,DELETE and authorization token * REST.md: add * Manual.rst: reformat all sql code to use tyoposcript - it seems mysql does not work * Manual.rst: Add some admonitions Bug Fixes ^^^^^^^^^ * #7925 / Change CWD during split reduced to splitting only. * #7925 / Fixed problem in mkDirParent() with absolute paths. * #7925 / Make logger independent of CWD. * #7925 / Fixed problem with ``mktemp --tmpdir`` (difference Ubuntu 16 / 18) by using PHP function again. * #7925 / Fixed some 'undefined index' problems. Version 19.2.2 -------------- Date: 19.02.2019 Notes ^^^^^ * QFQ now offers a basic REST API. Check https://docs.typo3.org/p/IMATHUZH/qfq/master/en-us/Manual.html#rest Features ^^^^^^^^ * 7910 / Check for double form names * 7904 / REST api export. Manual.rst: describe QFQ REST API * Latest phpStorm IDE complains about missing ext-json in composer.json. Added. * Manual.rst: Example how to use 'password' escape class. Bug Fixes ^^^^^^^^^ Version 19.2.1 -------------- Date: 18.02.2019 Notes ^^^^^ * New default session timeout: if nothing special is needed, leave the config.sessionTimeout empty. If there is an old value best is to remove it. * Variables with escape class='p' now hashes the content to be used as T3 FE passwords. This let's QFQ handle FE User registration or password reset. Features ^^^^^^^^ * Manual.rst: update pathFilename to pathFileName an all places. * Apply padding-top|botttom to fieldset via qfq-fieldset class. * F7165 / fe user registration. New escape type 'p' for T3 passwords. Bug Fixes ^^^^^^^^^ * #7634 / Session Timeout too short. Annoying 'session expired' message removed. Default timeout now takes the system defautl. * #7864 / 'required'-FE Elements, deactivated via formModeGlobal=requiredOff missed the read marker. Class 'required-field' is now always assigned. The final 'required' mode is still temporarily disabled. * #7848 / extraColumName 'paged' - easier handling in case 'r=0' or empty 'U:...' - fixes #7848 Version 19.2.0 -------------- Date: 07.02.2019 Bug Fixes ^^^^^^^^^ * #7714 / autocron fails to open logfiles - adjust CWD based on argv(0). Version 19.1.3 -------------- Date: 28.01.2019 Notes ^^^^^ * If a variable violates a sanitize class, the substituted result can now be configured: a) !!!!, b) '0', c) '', d) ''. * Alerts (based on _link class), might now show only 'ok' (alone, without 'cancel'). * Excel Import - three new options: importNamedSheetsOnly, importSetReadDataOnly, importListSheetNames Features ^^^^^^^^ * SQL Error / underlining in exception dialog: Add two SQL errors to be underlined in exceptions. Extend to "... in 'order clause'" * Extend allowed SQL commands in QFQ vars (have been already subscribed in that way in Manual.rst). * New escape mode 'C' - escapes ':' by '\'.' - useful for variables in variable definition. * fillStoreVar: Replace setStore() with appendToStore() * #6914 / Customized typeMessageViolation. Incl. unit tests. * #7743 / Move error messages to Constants.php. Unit tests use those constants now. 'data-pattern-error' only delivered if a 'pattern' is given. 'required' attribute only delivered is set. Detection of 'pattern error' on per QFQ default, custom instance wide, per form or per FormElement - per FormElement overwrites other. Move default pattern to constants. Make default error text more specific (only if default error text is not explicit set in config, form or form-element) * #7747 / New options to import Excel files: importNamedSheetsOnly, importSetReadDataOnly, importListSheetNames * #7684 / Optional hide second button (cancel) in link/question alerts. Bug Fixes ^^^^^^^^^ * #7743 / Form-Element: Explicit given '0' for MIN or MAX has been interpreted as 'not set'. * #7702 / Form,Form-Element: Unnecessary evaluation of column 'noteInternal' / 'adminNote'. * #7695 / Form/URL Forward: pageAlias not substituted. * #7686 / FormAction/sendmail: uninitialised sendMailAttachment. * #7685 / Open FormElement from QFQ error message and save modified record: report error about missing {{formId:F}}. * FormElement.type=select: fixed problem with dynamic update and mode=readonly - list was still selectable. * Hint to skip leading zeros in version number. Version 19.1.2 -------------- Date: 17.01.2019 Notes ^^^^^ * Align FormElement labels left/center/right. * Cleanup FormEditor. * All SQL commands now are allowed. Features ^^^^^^^^ * #7620 / Label align left/center/right. Defined by config/form/formelement. * #7647 / Preparation for Selenium Tests - Implement new token 'A' to add any custom attribute to '... AS _link' * Cleanup FormEditor: FormElement as second pill. Hide MultiForm as long as it not active. Rename Various to Layout. * Manual.rst: Add some tips. Add note how to extend TinyMCE valid_elements. * Delete composer in Resources dir, run phpunit tests in gitlab pipeline. * Database.php: allow all SQL commands. Bug Fixes ^^^^^^^^^ * #7671 / On FormElements, 'fillStoreVar' is now detected and fired at first. * Fix for checkbox-inline / radio-inline. * Check for non unique FormElements: multiple empty FE.name (e.g. for FE.type=subrecord) are allowed now. Version 19.1.1 -------------- Date: 04.01.2019 Bug Fixes ^^^^^^^^^ * #7600 / Path to sendEmail has changed and is updated now. * #7603 / Fix problem: formEditor.sql broken - missing semicolon. QFQ updates did not played formEditor.sql. Unit test for DatabaseUpdate(). Especially that formEditor.sql is running fine. * #7594 / FE.type=extra: don't name it 'type' or 'id' or 'L' - more detailed error message and an explanation in Manual.rst. * Config.php: error message about to high session timeout now reports the PHP settings. Version 19.1.0 -------------- Date: 03.01.2019 Features ^^^^^^^^ * Session expired: report details about session timestamps * File not found in FE.type=file: Show more clearly that the pathfilename is only shown when ShowDebugInfo=on. Bug Fixes ^^^^^^^^^ * #7553 / If a pill is hidden, FE on that one should not be processed during save/update. * #7573 / Upload: Do FillStoreVar before slaveId. * #7551 / General error: Access to undefined index. * #7544 / General error: Download.php / Line: 175. * #7543 / General error: QuickFormQuery.php / Line: 1364. Happened during upload. * Download Excel (and all other download types): Content-Disposition header delivered/suppressed in the opposite meaning as it should be. Seems to be fixed now. Version 18.12.3 --------------- Date: 25.12.2018 Features ^^^^^^^^ * Form: Add text 'Record id/Created/Modified' to tooltip of save button. Bug Fixes ^^^^^^^^^ * #7540 / Form: Upload broken. HelperFile.php: correctRelativePathFileName() broken after refactor of qfq paths. * #7514 / Report: Broken defaults in _pdf, _file, _link. * #7538 / Report: Excel.php - access to undefined index. * #7289 / Report: {{.line.insertId}} - missing for altsql. * #7539 / Report: Copy to clipboard not reliable. 'Direct' content now correctly encoded. 'Copy file content' fully implemented for text files. Version 18.12.2 --------------- Date: 24.12.2018 Notes ^^^^^ * Version skipped. Build problems in CI queue. Version 18.12.1 --------------- Date: 22.12.2018 Notes ^^^^^ * Existing installations: update QFQ extension config form-layout.formBsColumns/formBsLabelColumns/formBsInputColumns,formBsNoteColumns. old: '12', new: 'col-md-12 col-lg10' resp. smaller values for individual columns. * New config values: * Config/flagProduction: yes/now - differentiate between development und production system. Will be used for 'throwExceptionGeneralError' too. * Debug/throwExceptionGeneralError - shows/hide exception of general errors. * Renamed config values: * SITE_PATH >> sitePath * EXT_PATH >> extPath * _dbName >> dbName * Record locking: revert to old behaviour, that a locked record can't be modified by another form, even if the second form has modeRecordLock=NONE. * Autocron: update the system crontab entry to the new path (old 'qfq', new 'Source'): .../typo3conf/ext/qfq/Classes/External/autocron.php Features ^^^^^^^^ * #7228 / Show error if form element with same name and class already exists. * #7494 / Exception 'General Error': disable/enable per config. * Adapt class paths in composer.json to the newly refactored folder names. * Add 'col-lg-10' to notes section. * Added Alert Manager to have better control over the Alerts. * Config.php: make 'reading dbname' Typo3 version dependent. * Delete two old composer.json and call new composer in Makefile. * Excel.php: change autoload.php path to new composer folder. * Manual.rst: several places where the bs-column description are updated with the new way 'col-md-...' instead of '12'. Replace ''{{pageId' with '{{pageAlias'. Replace '... AS _Page' by '... AS _page'. Add 'tablesorter tablesorter-filter' to FormEditor example page. * Move bootstrap.php and BindParamTest.php due to refactoring. * phpunit.xml: implement const 'PHPUNIT_QFQ'. Store.php: set self::$phpUnit on const 'PHPUNIT_QFQ' * Refactor: 'extension/qfq/qfq/...' to 'extension/Classes/Core/...' * Refactor: Manual.rst update config variables (reorder), add 'qfqLog'. Support.php: formSubmitLog hardcoded to fileadmin/protected/log. DOCUMENTATION_QFQ > SYSTEM_DOCUMENTATION_QFQ. Remove config var 'logDir'. * Refactor: SITE_PATH >> sitePath, EXT_PATH >> extPath, SYSTEM_PATH_EXT >> SYSTEM_EXT_PATH * Remove report/Define.php, report/Error.php. Bug Fixes ^^^^^^^^^ * #3464 / Checkboxes now disabled (readonly), even when rendered as Bootstrap. Fixes missing readonly for Template Groups. * #6467 / Sanitizing a hidden field makes the form unsubmittable. Updated elementupdate for pattern, added "false" as an alternative to null. 'element-update' now get's 'pattern=|false' on element-update. * #7089 / FE.type=extra: value already set in SIP store. * #7223 / Add "-" as allowed characters in filenames. * #7455 / phpunit: Remove outdated report syntax. Catch exception on trying to open a non existing logfile. * #7461 / Bug in Doku. * #7464 / DragAndDrop - Undefined index: ord. Bug in subrecord fixed. * AbstractException.php: fixed problem with empty $match in sql syntax highlighting. * Block screen stuck seems fixed. * Check not to try to number_format() empty string. * config.qfq.example.php: add missing '>'. * Fixed broken init in phpunit run. Fixed access to uninitialized var. Throw exception if dndTable or form is missing. * Fixed missing $formElement[FE_DECIMAL_FORMAT]. Add 'missing primary record' check. Fixed missing fe['id']. * Fixed problem with '?:' - implemented in 2016. * Fixed problem with resultset in 'altsql'. * formEditor.sql, Manual.rst: renamed '{{_dbName...:Y}}' to '{{dbName...:Y}}'. * Manual.rst: Unify 'dbName*' documentation.. * phpunit: Update fixtures table 'Form', 'FormElement' & 'Dirty' definition. Update LDAP Test - surrounding spaces seems to be escaped now by '\20'. Create tests dir outside of source, create phpunit.xml, move some tests and make them work. Rename tests directory to Tests * Record Lock. Revert change in cb2e2a70cfe5c251cffbfce65bdc0899da75a9c5: if a record lock exist, another form, with record lock mode=NONE, can't get write access to it. This is what the manual describes. * Sanitize.php: fixes "Uninitialized string offset: 0" error. * Save.php: Fixed exception (file size, mime type) for non-existing uploads. * Store.php: fixed problem with wrong config varname for DB. * Timeout check throws error since php.ini cookie lifetime is zero during unit test. Fix filepath relative to Typo3 dir when running unit test. Version 18.12.0 --------------- Date: 10.12.2018 Notes ^^^^^ * Config.qfq.php: the variable T3_DB_NAME is not necessary anymore. * Following SYSTEM_STORE variables renamed. Old: '_dbNameQfq' ,'_dbNameData'. New: 'dbNameQfq' ,'dbNameData' * New: Bootstrap 'col-lg-10' is defined on every form. On screens greater than 'md' the forms won't be expanded to 100% anymore. Features ^^^^^^^^ * #3992 / STORE_SYSTEM: dbNameQfq, dbNameData, dbNameT3 * Config.php: read 'dbNameT3' from TYPO3_CONF_VARS or from T3 config file. * Download.php: get dbNameT3 now from STORE_SYSTEM * #4906 / Php Session Timeout: can be specified globally in configuration and per form. Affects only logged in FE User. * #6866 / On logout destroy STORE_USER. Session.php: check if _COOKIE['fe_typo_user'] has changed - yes: clear STORE_USER. Store.php: Rearrange functions. * #6999 / Bootstrap/Form: define columns for desktop 'col-lg-10' * #7138 / PDF / single source: deliver without converting * #7293 / Implement new logging for file upload. * #7406 / dbinit might contain multiple sql statements now. * #7407 / MariaDB / Ubuntu 18 complains about missing values if column of type TEXT isn't explicit specified in INSERT. New default for database.init=SET sql_mode = "NO_ENGINE_SUBSTITUTION" * #7431 / FE.type=afterSave (FE Action): SQL won't report the causing FE.name/id * #7434 / FE.type=beforeLoad / sqlValidate: Validation message not shown to user * FormEditor.sql: Switch off 'MySQL strict setting of default values' * Logger.php: remove UserAgent - that one is logged in FormSubmitLog Table. Add 'cookie' to filter individual actions. * New css classes for icons: .icon-flipped (mirrors icon), .icon-spin (icon spins once on hover), .icon-spin-reverse (mirror of icon spin). Bug Fixes ^^^^^^^^^ * #7001 / Error message: if 'modeSql' fails, error message does not contain a reference to the causing FE. * ErrorHandler.php: raise an error as an exception has been stopped in mid 2017 - reactivated now. * Fix problem in upload elements: a) in exception FE_ID was not reported, b) fillStoreVar was not fired. * FormAction.php: throw exception if 'fillStoreVar' selects more than one row. Version 18.10.3 --------------- Date: 29.10.2018 Notes ^^^^^ * QFQ now recommends ImageMagick instead of GraphicsMagic, due to much better 'auto orient' (JPEG) capabilities. Features ^^^^^^^^ * #4901 / Implement 'delete split files' if primary file is deleted (record) or replaced against a new one. * #4901 / Implement 'fileSplitOptions'. * #4901 / Implement PDF split based on IM 'convert' (jpeg). * #7012 / Memory limit for file download - replace file_get_content() by readfile(). * #7112 / fabric: configure default color. * thumbnail: empty path filename is no ignored, instead of throwing an exception. This is the same behaviour as building links - no definition means 'no link', and not 'error'. * Refactor chmod(), unlink(), rename(), rmdir(), copy() to use by QFQ version which throws an exception. Bug Fixes ^^^^^^^^^ * #3613 - Revert due to bug in dynamic show/hide (Revision 0bb99fd, Revision 77096ca7) - Version 18.10.2 --------------- Date: 13.10.2018 Features ^^^^^^^^ * #2509 / Render encrypted mailto as single link * #3281 / Trim form inputs * #4649 / Add sqlBefore & sqlAfter to sendmail FE, move validate() before sqlBefore()/sqlAfter(). * #4922 / Some minor improvements to the excel import * #5112 / Add incompatibility warning for encode specialchar and checkType allbut… * #5450 / MySQL Exception: underline faulty area * #6596 / uid ExcelExport / PDF * #6944 / Add double comma SQL Hint Bug Fixes ^^^^^^^^^ * #3529 / No double urldecode() of GET parameters * #3613 / Label input note layout * #3850 / Change set input maxlength * #4545 / After delete: reload page with original parameters * #4751 / Add bulleted und numbered lists back to tinyMCE Editor * #4765 / Extend tooltip visibility for checkboxes and radio buttons * #6911 / Only fire afterInsert on new record (also fix afterUpdate, beforeInsert,… * #6929 / Treat single file argument like several file argument (savePdf: copy,… Version 18.10.1 --------------- Date: 12.10.2018 Features ^^^^^^^^ * #5578 / Safari only handles one filetype in upload dialog. * #6991 / Optional process 'readonly' FE during save. New FE parameter 'processReadOnly = 0|1'. Bug Fixes ^^^^^^^^^ * #6880 / Fixed Exceptions with too many details to end user. * 'Drag and drop' failed due to fillStoreForm requests {{form:S}} which was not necessary for drag and drop. * Upload: rename 'chmod' to 'chmodFile'. Implement 'chmodDir'. Permissions applied for all new created directories. * Upload: replace 'rename' with 'copy/unlink' Version 18.10.0 --------------- Date: 04.10.2018 Features ^^^^^^^^ * #6894 / Upload: chmod for file creation. * #6886 / Upload: Auto Orient - implementation. * #6721 / Log switching {{feUser:U}} to qfq.log. Log {{feUser:U}} to sql.log. * #5458 / Add '{{feUser:U}}' to be shown on exception. * Manual.rst: Fix missing single tick in special column name '_=' * Report / Variables copied to STORE_USER via "... AS '_='" are now available in STORE_RECORD by {{:R}} Bug Fixes ^^^^^^^^^ * #6902 / Drag and drop in subrecords: expect 1 row got nothing. Version 18.9.2 -------------- Date: 16.09.2018 Notes ^^^^^ * To use the new 'tablesorter' feature, please add 'tablesorter-bootstrap.css', 'jquery.tablesorter.combined.min.js', 'jquery.tablesorter.pager.min.js', 'widget-columnSelector.min.js' in your Typo3 template record. See https://docs.typo3.org/p/IMATHUZH/qfq/master/en-us/Manual.html#setup-css-js * *Existing* QFQ installations: update your CSS/JS includes! The new tablesorter jquery plugin might break (JS errors seen on the console) your installation, if it isn't included! * If you use the extension 'UZH Corporate Design Template': * Update to the latest version 18.9.0. * Add constants in the Typo3 template record 'ext: main': :: cd.extra.css.file5 = typo3conf/ext/qfq/Resources/Public/Css/tablesorter-bootstrap.css cd.extra.js.file10 = typo3conf/ext/qfq/Resources/Public/JavaScript/jquery.tablesorter.combined.min.js cd.extra.js.file11 = typo3conf/ext/qfq/Resources/Public/JavaScript/jquery.tablesorter.pager.min.js cd.extra.js.file12 = typo3conf/ext/qfq/Resources/Public/JavaScript/widget-columnSelector.min.js * STORE_USER: check the examples - great new feature to temporary save user settings. Features ^^^^^^^^ * #6721 / STORE_USER: variables per browser session * #6690 / Tablesorter for subrecords Version 18.9.1 -------------- Date: 15.09.2018 Notes ^^^^^ * Report * Type of nesting delimiter in 'report' now limited to '{', '[', '(', '[' * Hide/reuse report content later: `10.content=hide` and later `1000.head = {{10.content}}` * New Excel import - copy Excel files directly into a DB table. * Forms with named primary key different than 'id' are now supported. Features ^^^^^^^^ * #1261 / Tablesorter, incl. saved sort, combined column sort, filters, pagination * #3129 / suggestion for subrecord title design * #4922 / Excel import * #6300 / Disable preview button for requiredNew forms * #6314 / HTML Mode & sendMailSubjectHtmlEntity for Forms. * #6481 / Add custom primary key option to Forms. * #6645 / better error message for incomplete download as link * #6650 / Report hide content (line) - use later via a variable. First version - problem with enclosed ticks. * #6653 / Add save button class/glyphicon/tooltip for submit button * Thesis code correction * Update QFQ download URL Bug Fixes ^^^^^^^^^ * AbtractBuildForm.php: fix problem with subrecords in MultiDB Environment. * #2340 / Report: Problematic Bracket - form now on, only ''{[(<'' will change the nesting token. * #3333 / Fixed subquery recognition in reports '10.sql, 10.1.sql ...' * #4837 / Don't display hidden pills * #5467 / Fill Record Store when evaluating min/max parameters * #6621 / Fix shifted subrecord head * #6646 / Fix broken extraInfoButton for some FEs Version 18.9.0 -------------- Date: 07.09.2018 Features ^^^^^^^^ * #6357 / Save pdf on server * #5381 / Stored procedures can be called from QFQ Reports * #4996 / Log QFQ Update with timestamp. * #6255 / Inline Report Editing - now with SIP and save.php api Bug Fixes ^^^^^^^^^ * #6465 / Allow newlines in form action queries (e.g. sqlInsert) * #4654 / Better FE color highlighting (UX) * #5689 / Default BS Columns for FormElement match Form setting * #6484 / Download Links mit css class * #6576 / download buttons are now rendered disabled with render mode r:3 * Cookie Sitepath: wrong detected in case of API calls. Version 18.8.2 -------------- Date: 28.08.2018 Features ^^^^^^^^ * #6563 / Accept 0 as required. Bug Fixes ^^^^^^^^^ * DatabaseUpdateData.php: add missed 'on the fly' update for Form.title, changed in FormEditor.sql in 18.8.1 * 6562 / sendmail: redirect all mail - the sender is replaced too. * Manual.rst: several typos fixed Version 18.8.1 --------------- Date: 26.08.2018 Features ^^^^^^^^ * #4432 / Every 'form submit' will be logged with raw data. * #4763 / Render vertical text more stable: '... AS _vertical' * #4996 / Log QFQ Version update * #5403 / Tooltip on pills are now supported * #5876 / Subrecord title of column 'Edit' & 'Delete' are now customizable. * #6249 / Subrecords can now be reordered via drag and drop. * #6333 / Add to qfq.log: IP Address, User Agent, QFQ Cookie, FE User Bug Fixes ^^^^^^^^^ * #6401 / Handle Backticks in sendmail * #6452 / Empty form title: no title row will be rendered anymore. Version 18.8.0 -------------- Date: 25.08.2018 Notes ^^^^^ * Excel export * Copy to clipboard Features ^^^^^^^^ * #4922 / Excel Export - create Excel sheets from scratch or based on a template. * #3294 / Improve Typo3 QFQ backend layout. Add sparql syntax highlighting. * #5878 / Formelement.type=note with #!report - whitespace is trimmed. * #6314 / HTML Mails enabled by specifying flag 'mode=html'. * Import/Merge form: A new form 'copyFormFromExt' (see file `copyFormFromExt.sql`) offers a one click import of external QFQ forms (incl. renumbering of id's). * formEditor.sql: resized Form.title from 255 to 511 (requested by IK Tool) * Drag and Drop now offers the possibility to show the renumbered values. * Manual.rst: security hints, T3 Setup best practice, text input retype, charactercountwrap. * Config.qfq: central defaults for DATA_MATCH, DATA_ERROR * Bootstrap QFQ development: switched from bower to npm only. Bug Fixes ^^^^^^^^^ * #5843 / File upload: limitation to file extensions are no case insensitive. * #6247 / Replace deprecated each function * #6281 / FormElement / column 'note': token '#!report' - STORE_RECORD does not work. * #6331 / File Upload: Wrong error message if filesize is much too big. * #6229 / Add QFQ icon to content element and content element wizard * AbstractException.php: fixed problem with htmlEntities() on link to 'Edit Form' and 'Edit FormElement'. Version 18.6.1 -------------- Date: 21.06.2018 Notes ^^^^^ * Configuration QFQ: form-config.formDataPatternError. New behaviour: If this field is empty, a more specific default message is shown (instead of one message for all situations). Best is to clear this field. Features ^^^^^^^^ * sqlHint / Note if a query fails and contains some not replaced variables. * #4438 / Log attack detected: will be logged now to fileadmin/protected/log/qfq.log. * #4041 / Subrecord: Spalte 'id' automatisch mit '' wrappen. * #5885 / show 'sql.log' in FE. * #6121 / Formular: ID per Default in Titel. Bug Fixes ^^^^^^^^^ * #6283 / Form: hide title frame if empty. * #4299 / HiddenSelect' into 'master'. * #6276 / default data-required-error moved to central Config.php. * #5884 / sql.log by default public - protect against access. * #6276 / Default check_type messages not shown. * #6233 / Alert 'Form incomplete' - stays until click - auto disappear would be better. Version 18.6.0 -------------- Date: 13.06.2018 Notes ^^^^^ * config.qfq.ini migrated to config.qfq.php - the old config.qfq.ini get's `chmod 000`. * Most of config.qfq.ini migrated to Typo3 / Extension Manager - all but the DB /LDAP credentials. * Keep in config.qfq.ini: :: # Rename DB credentials from DB_ to DB_1_, with key = 'NAME|HOST|USER|PASSWORD' DB_1_USER = ... DB_1_SERVER = ... DB_1_PASSWORD = ... DB_1_NAME = ... * NEW: Drag and drop to sort elements! Check the Manual. * `URL forwardMode` * `client` renamed to `auto`. * `close` added. Features ^^^^^^^^ * #6100 / Url Forward Auto: Update Manual.rst. The F.parameter.saveAndClose has been removed again. Mode 'close' can be assigned statically or dynamic. * #6178 / Input: Step: New option 'step' for FE.parameter. * Download.php: references to non existing files now reported as missing file, not 'wrong mimetype' anymore. * #4918 / Drag'n'Drop reorder elements DRAGANDDROP.md, PROTOCOL.md: Doc for "drag'n' drop" implementation. * dragAndDrop.php: API endpoint DragAndDrop.php: Class for implementing drag'n' drop functionality. * Link.php: implement new renderMode=8 - returning only the sip. QuickFormQuery.php: New entry point for processing "drag'n' drop". * #3971 / Form title: new design from form title. Bug Fixes ^^^^^^^^^ * #5077 / Dynamic Update & FE.type=required: Server fixed - a) dynamic calculated modeSql respected, b) formModeGlobal=requiredOff respected, c) dynamic FE with mode='hidden' are not saved anymore. * #6176 / Icon not aligned when error text: Buttons now wrapped in one 'input-group'. * Manual.rst: reformat autocron QFQ code. * #5880 / Skip Error Message during dynamicUpdate. * #5870 / Missing file config.qfq.ini: Clean QFQ message. * #5924 / config.qfq.ini/LocalConfiguration.php: several places in formEditor.sql still contained the 'dbIndex...'. * #6168 Configuration language setting ignored: Form and FormElement editor still used uppercase config values for language configuration. Updated to the new camel case notation. * #5890 / config.qfq.ini is public readable. Renamed file to config.qfq.php. Implement a basic migration assistant to copy DB credentials to new config.qfq.php. All other values have to be copied to extmanager/qfq-configuration manually. * #6216 / Oops, an error occurred! Code - unhandled exception will be caught now. Version 18.4.4 -------------- Date: 28.04.2018 Bug Fixes ^^^^^^^^^ * Fix broken ext_emconf.php Version 18.4.3 -------------- Date: 28.04.2018 Bug Fixes ^^^^^^^^^ * Version Number ...04... not supported by TE. Changing naming scheme to omit leading zero. Version 18.04.1 --------------- Date: 28.04.2018 Bug Fixes ^^^^^^^^^ * config: broken dbIndexQfq, dbIndexData. Version 18.04.0 --------------- Date: 26.04.2018 Notes ^^^^^ * QFQ marked as 'stable' * New version numbering: Year.Month.Index * Manual.rst: * AutoCron documentation enhanced. * Replace '{{form:S}}' against '{{form:SE}}'. * Check list for 'new installations'. * Description for config variables enhanced. * Details 'how record locking' is done. * Details: extraButtonInfo. * Replace config.qfq.ini on most places with 'configuration'. * Path of 'sql.log' / 'mail.log' are now relative to (not as before). Features ^^^^^^^^ * formEditor.sql: update table cron. * AutoCron.php: allow https connections with invalid certificate (e.g. 'localhost' is not listed as a valid hostname). * ext_conf_template.txt: Extension manager configuration setup. Bug Fixes ^^^^^^^^^ * AutoCron: * Update form 'cron' to load/save records in DB_INDEX_QFQ. * Fix problem with array in checkForOldJobs(). * Implement check that re-trigger asynchronous cron jobs are handled correctly. Version 0.25.15 --------------- Date: 20.03.2018 Features ^^^^^^^^ * Fabric Read Only mockup. Bug Fixes ^^^^^^^^^ * #5706 / Fixed that problematic characters in 'fileDestination' has not been sanitized. * Fixed problem with buttons clipping trough alert. * Client: wrong variable, updated CSS for long errors. Version 0.25.14a ---------------- Date: 15.03.2018 Features ^^^^^^^^ * Change getMimeType() in Report in case file is missing or `file` beaks: instead to throw an exception, an empty string is returned. * Updated protocol.md with Alert description. * Update Status message for save/delete. * Makefile: 1) remove sonar, add dependency to let update-qfq-doc run. 2) do qfq doc commit inside of the Makefile. * Client: Changed save timeout from 1500 to 3000. * Client: removing the blackout screen when modal gets dismissed. * Client: modal alerts are now blocking everything. * Manual.rst: fix RST syntax errors. Bug Fixes ^^^^^^^^^ * #5677-TinyMCE broken - fixed. Version 0.25.14 --------------- Date: 14.03.2018 Features ^^^^^^^^ * Change notification from 'save: success' to 'Save' and 'delete: success' to 'Delete'. * DB update: write intermediate QFQ version after every step. Bug Fixes ^^^^^^^^^ * #5652 / TypeAheadSql: destroyed SQL statement. Fixed broken compare and missing init of $sqlTest. * #5668 / Fix Broken SIP after login. Version 0.25.13 --------------- Date: 08.03.2018 Features ^^^^^^^^ * AutoCron: Added doc for autocron. Extend AutoCron.php to be MultiDB aware. Update der AutoCron form. * #4720 / Separate Database for Form & FormElement - Multi DB - fixed problem that 'Quick Edit Form / FormElement' has been broken in MultiDB Setup. * #5603 / Report: final value of report columns (special column name). * Fabric / delete now triggers form.changed / emojis work again. * #5571 / File Upload: save filesize and mimetype automatically in 'upload mode simple',if those columns exist. * #5423 / two new column names 'filesize', 'mimetype'. * #5571 / File Upload: save filesize and mimetype. * STORE_VARS contains now 'mimeType' and 'fileSize'. * sqlBefore and sqlAfter will be fired in Upload Advanced and new in Upload Simple as well. * STORE_VARS contains now `filenameOnly`. It can be used in downloadButton=.... Bug Fixes ^^^^^^^^^ * Fabric: Corrected resizing with changed width in editor. * #5640 / UTF8 encoded strings: MAX LENGTH wrong. Version 0.25.12 --------------- Date: 18.02.2018 Notes ^^^^^ * New * FE.parameter: * timeIsOptional * enterAsSubmit * FE.checkType: Auto * Thumbnail rendering. Public or secure. * Update * Multi DB Support: Form & Report Features ^^^^^^^^ * #5064 / Throw user form exception on invalid date. * #5308 / TimeIsOptional parameter. * #5318 / Allow sendmail speaking word token, adjust documentation and fix some typos. * #5347 / Error Message (Exception): BS colored box for report error messages. Hide technical informations, show it on click. * #5392 / Violate message with expected date format. * #5414 / Add checkType Auto, refactor setDefault methods, add smart detection of defaults, extend documentation and rules. * #3470 / Enter As Submit= on/off - implemented. * #4437 / violate sanitize message. * #4542 / input-type-decimal' into 'master'. * #5298 / Update docs for HTML mails. * #5333 / Thumbnail: implementation. * #5425 / Thumbnail: render mode 7 - implemented, rewrite - secure thumbnails are now rendered on first access, not when 'AS _thumbnail' is called. * Implemented $dbIndex for Report. * Implemeted two new STORE_SYSTEM variables: '_dbNameData' and '_dbNameQfq' - those will be automatically filled qfq during instantiation QuickFormQuery(). They can be used in Report to easily access the needed DB. * Increased Formelement.label from 255 to 511. * Make DB_INIT in config.qfq.ini set by default. * Notes how to optimize PDF thumbnailing. * Reformat manual for config.qfq.ini. Copy config.qfq.example.ini to MANUAL.rst. Migrate config defaults from setIfNotSet() to array_merge(). * Security: hide $SQL in error messages to regular user. * New FE.parameter 'inputType'. Can optional be given by webmaster. Additional, the 'type="number"' will be automatically set, if the column is of type 'int' or if 'min' and 'max' is numerically. Bug Fixes ^^^^^^^^^ * #3192 / Fill STORE_RECORD before loading table title. * #5285 / Make typeAheadPedantic the default. * #5348 / Exception/Report: level key missing. * #5367 / Error Report: reworked alerts, updated css for alerts, 'full level' missing, content too much escaped: Fixed too much escaping. Form / FormElement Links in error messages now with BS Buttons. * #5382 / Double quotes in tooltips are now escaped with ". * #5390 / input validation decimal broken. fixed. * #5430 / Add unique ID to each radio button for dynamic update. * Form: 'FormElement' > 'Container' - relied on '{{formId:S}}' even if the FE record already exist - fixed. * Subrecord Title - now wrapped with