Skip to content
Snippets Groups Projects
Release.rst 90.79 KiB

Release

Version 19.x.x

Date: <date>

Notes

Features

Bug Fixes

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.
  • #7849 / Missed filename after the file chooser selected an file. fixed.
  • #1201 / FE.parameter option 'tabindex' has never been implemented. 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

Notes

Features

  • Manual.rst:

  • 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 / 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.
  • Manual.rst: Excel Export / PDF export replace 'uid:<int>' with 'uid:<tt-content record id>'
  • Update SQL functions to hanlde errors more efficient.

Version 19.5.1

Date: 22.5.19

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 '<br>' 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

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.1.2019

Notes

  • If a variable violates a sanitize class, the substituted result can now be configured: a) !!<class>!!, b) '0', c) '', d) '<custom message>'.
  • 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

Notes

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: {{<level>.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=<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 '_=<var>'
  • Report / Variables copied to STORE_USER via "... AS '_=<varname>'" are now available in STORE_RECORD by {{<varname>: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.8.18

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 '<span class="text-muted">' 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_<key> to DB_1_<key>, 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 -
  1. dynamic calculated modeSql respected,
  2. formModeGlobal=requiredOff respected,
  3. 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.18

Bug Fixes

  • Fix broken ext_emconf.php

Version 18.4.3

Date: 28.04.18

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 <site path> (not <ext path> 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 sanatized.
  • 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.18

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 &quot;.
  • #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 <label class='control-label'>.

Version 0.25.11

Date: 31.01.2018

Notes

  • Violating a sanitize class now returns '!!<sanitize class>!!' instead of an empty string.

Features

  • #5022 / Variable violates sanatize class: 'msg' instead of empty string - new identifier "!!<sanitize class>!!".
  • #4813 / Exception during form load: show 'form edit link' if editor is logged in.
  • formEditor.sql: Increas size of Form.title to give more room for SQL statements in.
  • Manual.rst: enhance debug tipps.
  • #5321 / Plain Link - render mode- only url - implemented.
  • Add regex101 link to checkPattern FormEditor.

Bug Fixes

  • Fixed some broken help links in formEditor.sql.
  • #5306 / Exception: tt_content_uid wrong - fixed.
  • #4303 / Download von doc/docx-Dateien / Download.php - Mime type wird nicht mehr an Dateiname angehängt.
  • #5316 / Help on how to send an E-Mail is wrong - several places fixed.
  • #5311 / Error Msg SLQ_RAW != SQL_FINAL: Debug message shows outdated SQL_RAW.
  • #5309 / min/max broken for date fields. Add min/max attributes to input and date input tag.
  • Fabric now detects 'dirty'.
  • Manual.rst: Remove broken link to W3C file upload.

Version 0.25.10

Date: 26.01.2018

Notes

  • PROTOCOL.md: update notes.
  • Form / Upload: new option 'downloadButton' - if given renders a download button instead of showing the pathFileName.

Features

  • #5023 / Fabric: Cut, rotate and enhance uploaded images. Update Manual.
  • All FE 'typeahead' fields are set to 'autocomplete="off"'. Respect user setting for 'autocomplete' - if none given (mostly), set it for FE 'typeahead' to 'off'.
  • #5295 / Upload: check if given QFQ 'maxFileSize' is higher than php.in post_max_size, upload_max_filesize.
  • FE.Subrecord: rearranged column order, start columns with uppercase letter.
  • New CSS class 'qfq-full-width-left': especially for buttons to become full width.
  • New CSS class 'qfq-table-100' - 100% width, with auto width per column. FE.subrecord changed to 'qfq-table-100'.
  • #5302 / remove CSS class 'internal / external'.

Bug Fixes

  • #5189 / BCC SendMail Problem - fixed missing double ticks.
  • Manual.rst: Update documentation that the default escape type is 'm'. Remove subrecord/list (have been removed long time ago). Fix enumeration problem FE.type=radio classButton. Add short note for typeahead.js. Remove never implemented 'keySemdId...', 'ANREDE'. Fixed typo - replace '' by '\' on most places (not in code sections). More generic SQL to extract filename from pathFileName. Fixed several phinx syntax errors. Add example for 'recent list'-records.
  • Fixed problem with missing 'if note exits' in CREATE TABLE Split.
  • #5030 / Manual.rst: Fixed example with XSS vulnerability.
  • #5275 / typeahead.bundle.min.js missing in Manual.rst: fixed.
  • FormEditor: 'typeahead' for column 'name' fixed. Attention: only succeed if DB_1_NAME is the final DB (mostly given).
  • #5048 / Default value NULL in pathFileName breaks uploads.
  • #5028 / Links im FormularEditor zeigen ins Leere (Fehlende Ziel-Anker) - fixed.
  • Make readonly BS radio buttons non-selectable.

Version 0.25.9

Date: 17.12.2017

Features

  • #5133 / sendmail: subject and body html entity decode: Introduce options for 'subject' and 'body' to switch on/off HTML encoding / decoding
  • Manual.rst: Add notes to QFQ installation, wkhtml problems, paragraph on 'sendEmail' Html2Pdf.php: Add error codes and a hint on wkhtml fails.
  • Reformat table qfq-letter.css.less: redefined h1, letter-receiver.

Bug Fixes

Version 0.25.8

Date: 11.12.2017

Features

  • #5080 / Dynamic PDF Letter.
  • #5083 / Bodytext / Report: join lines without spaces.

Bug Fixes

  • Fix problem with commit from 8.12.17 / Store.php: appendToStore.php stopped working - 'report' failed to replace '{{<column>:R}}'.
  • Store.php: fix problem with empty 'appendToStore()' call.

Version 0.25.7

Date: 07.12.2017

Notes

  • Report: parameter in '... AS _sendmail' needs token now - position dependent is removed now.
  • Report: parameter 'a:' in '... AS _sendmail' replaced by 'F:' to be compatible with downloads. Do not separate files by comma.
  • Manual: most occurences of 'U:' replaced by 'p:' - same meaning.

Features

  • #4255 / Attachments for emails implemented.

Bug Fixes

  • Bug - PHP Warning: Declaration of qfqBuildFormTable::head() should be compatible with qfqAbstractBuildForm::head($mode = qfqFORM_LOAD) - fixed.

Version 0.25.6

Date: 03.12.2017

Notes

Bigger changes in update form after save/dynamic update.

Bug Fixes

  • #4865 / Pill Dynamic Updates Show / Hide.
  • #5031 / Missing details in DbException: New definition of SYSTEM_SHOW_DEBUG_INFO: even after config.qfq.ini is parsed and SIP Infos has been read - if there is no BE User logged in, the value stays on 'auto' (earlier it has been replaced to 'no'). Staying on 'auto' keeps the information that replacing is still open and not replaced means 'no'-BE User logged in.
  • #5016 / Loose checkbox value on save - Dirty workaround - better solution necessary.
  • #5017 / STORE_RECORD used in FormElement and via '#!report' - save & restore STORE_RECORD.
  • #5004 / FormElement with state 'ReadOnly' will be saved with empty value - existing values will be overwritten - fixed.
  • 'element-update' for type 'UPLOAD seems to make trouble. Exclude it like 'SELECT'.

Version 0.25.5

Date: 23.11.17

Bug Fixes

  • #4771: Workaround which switches off updates to SELECT lists, if they are part of a Multi-FE-Row.

Version 0.25.4

Date: 22.11.2017

Notes

  • New keywords / features in report:
    • altsql: Fire the query if there is no record selected in sql. Shown after althead.
    • shead: Static head - will always be shown (before head), independent of sql selects records or not.
    • stail: Static tail - will always be shown (after tail), independent of sql selects records or not.

Features

  • #2948 / altsql, shead, stail - new directives in Report.
  • #4255 / Attachments fuer 'Email'. Static files can be attached to mails.

Bug Fixes

  • #4980 / Variables in Report: a) nested not replaced, b) 'rbeg' not replaced, c) missing unit tests.

Version 0.25.3

Date: 19.11.2017

Notes

  • Report:
  • The config.qfq.ini directive VAR_ADD_BY_SQL is replaced by FILL_STORE_SYSTEM_BY_SQL_?. Up to 3 statements are possible.

Features

  • Report / sendmail: control via token.
  • #4967 / config.qfq.ini: Rename 'VAR_ADD_BY_SQL' to 'FILL_STORE_SYSTEM_BY_SQL_1'. Handle up to 3 FILL_STORE_SYSTEM_SQL_x. Implement an optional error message together with a full stop.
  • #4766 / Set STORE_RECORD in Report per row.

Bug Fixes

  • #4966 / Variable {{feUser:T}} is not available in config.qfq.ini FILL_STORE_SYSTEM_? - changed ordering of store initialization. Now: TCY...
  • #4944 / Delete: broken when using 'tableName' (instead of form).
  • #4904 / Undefined Index: DIRTY_FE_USER - PHP problem that constants cant be replaced inside of single ticks. Fixed.
  • #4965: insert path to QFQ cookie/session, to make usage of multiple QFQ installation on one host possible.

Version 0.25.2

Date: 8.11.2017

Notes

  • Starting with this release, the default escape mode is 'm' (mysql_real_escape).

Features

  • Default Escape Type changed from 's' to 'm'. DatabaseUpdateData.php: removed the DB update from last commit - not necessary. Config.php: New default 'm' Evaluate.php: Respect EscapeTypeDefault in form definition. QuickFormQuery.php: Replace 'EscapeTypeDefault' in form defintion very early.
  • #4049 / QFQ Variables '{{...}}' might now contain a default value.
  • If 'pageAlias:T' is empty, take 'pageId:T'.

Bug Fixes

  • #4836 / Multiple entries in table after several clicks on save. Created a saveInProgress Variable.
  • Replaced latest project homepage URL in Manual.rst.
  • Fix example SQL for periodId in config.qfq.ini in Manual.rst.
  • Remove multiple header 'RELEASE' - there has to be only one.

Version 0.25.1

Date: 3.11.2017

Bug Fixes

  • #4857 / broken (stale) download: multiple 'u:..' or 'u:...'.
  • #4212 / Broken JSON on response to save new record 'Unknown index' fixed by isset().

Version 0.25.0

Date: 10.10.2017

Notes

  • The config.qfq.ini directives DB_USER, DB_NAME, DB_HOST, DB_PASSWORD are replaced by DB_1_USER, DB_1_NAME, DB_1_HOST, DB_1_PASSWORD. The old directives are still used, as long as the new directives does not exist.
  • New config.qfq.ini directives: DB_INDEX_DATA, DB_INDEX_QFQ.

Features

  • #4720 / Separate database handles for QFQ 'form' and QFQ 'data' - 'Form' might now load/save from forign database/host/user.

Version 0.24.0

Date: 09.10.2017

Notes

  • Change Remove SYSTEM_SECURITY_ABSOLUTE_GET_MAX_LENGTH - makes no sense to hardcode an upper limit.

Features

  • Feature Manual.rst: Doc updated for latest subrecord column special names.
  • Feature AbstractBuildForm.php: new function subrecordHead(). Replaced several hard coded subrecord column names against constants.
  • Feature #4456 / formModeGlobal=requiredOff - update Manual.rst.
  • Feature #4606 / _link: qualifier to render bootstrap button - fix unit tests for tooltip. Add tooltip to button/text, even if there is no link. Implement token 'b:...' for link class. Manual is updated. Open: pageX should be recoded to use the new 'b:' instead of hardcoed behaviour to render a button.
  • Feature: Upload Button - wrapped with Bootstrap Button. New option 'fileButtonText' to specify a button text.
  • Feature #3752 / Pills auf mode|modeSql=hidden|readonly setzen - implemented during 'form load' (not dynamic update).
  • Feature: Neu wird nach dem Speichern das Formular nochmal komplett geladen. Das ist wichtig um die durch aftersave geaenderten Records in die Formularelemente zu bekommen.
  • Feature #4511 / Form: URL Forward - mode dynamic computed - more generic implementation.

Bug Fixes

  • Bug #4731 / Dynamic Update: load(post) triggers 'check required' - makes no sense during filling a form - fixed.
  • Bug #4730 / InvalidDate-00-00-2000 FE.type=date - detection of empty date was broken for '00.00.0000'.
  • Bug Fixed problem in subrecord when no record is selected.
  • Bug #4620 / Easy Fix: saveButtonText / closeButtonText Formatierung.

Version 0.23.1

Date: 23.9.2017

Bug Fixes

  • #4620 / Easy Fix: saveButtonText / closeButtonText Formatierung.

Version 0.23.0

Date: 17.09.2017

Features

  • #3752 / Pills auf mode|modeSql=hidden|readonly setzen - implemented during 'form load' (not dynamic update).

Bug Fixes

  • #4548 /Template Group: 'form-update' broken - Broken Redirect after Save - Broken same HTML ID for FE copies in a template group.
  • #4548 /Template Group: 'form-update' broken - max tg element value/index shown after save instead of last user supplied value, but save is ok. Neu wird nach dem Speichern das Formular nochmal komplett geladen. Das ist wichtig um die durch aftersave geaenderten Records in die Formularelemente zu bekommen.

Version 0.22

Date: 14.09.2017

Notes

  • Form Editor: element 'forwardPage' is static again (no dynamic update) - see features in #4511.

Features

  • #4511 / Form: URL Forward - mode dynamic computed.

Bug Fixes

  • #4512 | SIP URL does not respect anker token '#'- fixed PLUS: L and type _GET Params included in links which contain a SIP (regular links still open).
  • #4508 / Form: during Save with FE with 'report'-Note/Values an exception is thrown - report does not expect, to be called without typo3 - but this is the case during save and generating the JSON.
  • #4021 / "required" asterik does not handle multi column labels correctly.
  • #4423 / Date inputs with readonly: label is grey.
  • Empty date might create '2001-00-00'.
  • #4504 / Upload Button: required asterik missing after save - seems to be a problem for every element - should be fixed now.