General Updates
- Allow mysql outputs of TANGY-TIMED and TANGY-UNTIMED-GRID data
Administration
- The
reporting-cache-clear
script will honor the environmnt variableT_ONLY_PROCESS_THESE_GROUPS
to limit the groups processed- Set
T_ONLY_PROCESS_THESE_GROUPS
to a comma-separated list of group names to limit the groups cleared and then processed by the script
- Set
Fixes
- Fixes for editing of Form Responses in the server web UI
- Edits of Attendence, Behavior, and Scoring are currently prohibited in the server web UI
- Verified and Archived Form Responses must be Unverified and Unarchived before editing is available
- Teacher Dashboard Scoring: Fix issues with custom scoring
- Fix output of Case Participants to mysql
- Fix online survey release
Libs and Dependencies
- Bump version of
tangy-form
to v4.54.4- Fix check for 'readOnly' input metadata
- Fix undefined access of input without tagName
- Fix missing function parens
Server upgrade instructions
See the Server Upgrade Insturctions.
Special Instructions for this release: N/A
New Features
-
Audio and Visual Feedback: A new Prompt Box widget available in form authoring allows a form designer to add audio and visual feedback connected to Radio Block widgets. This feature provides a toolset for creating self-guided assessments. See the example in tangy-forms. #3473
-
Client Login Screen Custom HTML: A new app-config.json setting,
customLoginMarkup
, allows for custom HTML to be added to the login screen. This feature is useful for adding custom branding or additional information to the login screen. As an example:
"customLoginMarkup": "<div style='text-align: center;'><img src='assets/media/logo.png' alt='logo' style='max-width: 100%;'></div>"
- Improved Data Management:
- Data Managers now have access to a full workflow to review, edit, and verify data in the Tangerine web server. The Data Manager can click on a record and enter a new screen that allows them to perform actions align with a data collection supervision process.
- Searching has been improved to allow seaqrching for a specific ID in the imported data. This feature is useful for finding specific records synced to the server when reviewing or editing completed form responses. #3681
Fixes
- Client Search Service: exclude archived cases from recent activity
- Media library cannot upload photos #3583
- User Profile Import: The process of importing an existing device user now allows for retries and an asynchronous process to download existing records. This fixes an issue cause by timeouts when trying to import a user with a large number of records. #3696
- When
T_ONLY_PROCESS_THESE_GROUPS
has a list of one or more groups, runningreporting-cache-clear
will only process the groups in the list
Tangerine Teach
- Add toggle in Attendence Check for 'late'. A teacher can click through the status of 'present', 'late', or 'absent' for each student.
- Use
studentRegistrationFields
to control showing name and surname of student in the student dashboard
Libs and Dependencies
- Bump version of
tangy-form
to v4.31.1 andtangy-form-editor
to v7.18.0 for the new Prompt Box widget - Bump version of
tangy-form
to v4.45.1 for disabling oftangy-gps
in server edits
Server upgrade instructions
See the Server Upgrade Insturctions.
Special Instructions for this release:
Once the Tangerine and CouchDB are running, run the upgrade script for v3.31.0:
docker exec -it tangerine /tangerine/server/src/upgrade/v3.31.0.js
New Features
- Customizable 'About' Page on client #3677 -- Form developers can create or update a form with the id 'about'. There is an example form in the Content Sets -- The form will appear in the 'About' page on the client
General Updates
- Password Visibility -- the login and register screen on the client shows an 'eye' icon used to hide or show passwords
- Re-organization of the client app menu
- Reintroduce
registrationRequiresServerUser
app config setting to make managing central user more flexible- use
registrationRequiresServerUser
to require an import code when registering users on the client - use
centrallyManagedUserProfile
to require an import code AND only allow changes to the user profile on the server - use
hideProfile
to hide the manage user profile page from on the client
- use
Teach Module Updates
- Behavior screen show a link instead of a checkbox to access the Behavior form
- Hint text added to attendance, behavior, and scoring tables
- Improved save messaging for attendance and scoring
- In Attendance Reports:
- add start and end dates to view a custom date range report
- Fix the names not displaying in the tables
Fixes
- Get Media Uploads working in Editor #3583
- CSV Generation broken with 'doLocalWorkaround is undefined' error
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space.
df -h
# If there is not more than 12 GB plus the size of the data folder, create more space before proceeding.
# Good candidates to remove are: data back-up folders and older versions of the Tangerine image
# rm -rf ../data-backup-<date>
# docker rmi tangerine/tangerine:<version>
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Check logs for the past hour on the server to ensure it's not being actively used. Look for log messages like "Created sync session" for Devices that are syncing and "login success" for users logging in on the server.
docker logs --since=60m tangerine
# Fetch the updates.
git fetch origin
git checkout -b v3.30.1 v3.30.1
./start.sh v3.30.2
# Run the update to copy the new About page to all groups on your site.
docker exec -it tangerine /tangerine/server/src/upgrade/v3.30.2.js
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:<previous_version>
New Features
- Multiple Location Lists can be configured using the Tangerine server web interface -- Create and manage location lists for use in Tangerine forms -- The default location list is used for device and device user assignment.
- The app-config.json teachProperties has new properties,
"unitDates"
and"studentRegistrationFields"
:The"unitDates": [{"name": "Unidad 1","start": "2023-02-15", "end": "2023-04-23"}, {"name": "Unidad 2","start": "2023-04-24", "end": "2023-06-30"}], "studentRegistrationFields": ["student_name", "student_surname", "phone", "classId"]
unitDates
property is used to configure the dates for each unit in the Class module. ThestudentRegistrationFields
property is used to configure the fields from the Student Registration form to be saved in the class attendance, behavior, and score register and CSV's. - The app-config.json teachProperties has a new property,
"showAttendanceCalendar"
, which enables the Attendance Calendar in the Class module when set to true. - Intl/locale support in Class: The class module currently supports the es-gt locale. Add additional locales in class/module.ts:
import { registerLocaleData } from '@angular/common'; import localeEsGt from '@angular/common/locales/es-GT'; registerLocaleData(localeEsGt);
- The "Request spreadsheets" CSV output form now has three new forms to view if
useAttendanceFeature
is set to true in app-config.json: Attendance, Behavior, and Score
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space.
df -h
# If there is not more than 12 GB plus the size of the data folder, create more space before proceeding.
# Good candidates to remove are: data back-up folders and older versions of the Tangerine image
# rm -rf ../data-backup-<date>
# docker rmi tangerine/tangerine:<version>
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Check logs for the past hour on the server to ensure it's not being actively used. Look for log messages like "Created sync session" for Devices that are syncing and "login success" for users logging in on the server.
docker logs --since=60m tangerine
# Fetch the updates.
git fetch origin
git checkout -b v3.30.1 v3.30.1
./start.sh v3.30.1
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:<previous_version>
New Features
- The 'teach' content-set now supports an optional 'Attendance' feature, enabled by adding
"useAttendanceFeature": true
and"homeUrl": "attendance-dashboard"
to app-config.json. It also has a new Class/Attendance menu which enables collection of those values per student, and an 'Attendance' report. - The Attendance records generate _id's based on the grade, curriculum, user, and date and time of the record, so that they can be sorted chronologically. See dashboard.service generateSearchableId for details.
- Class now supports
eventFormRedirect
to redirect to different url after submit:on-submit="window.eventFormRedirect =
/attendance-check"
- New app-config.json configuration for teach properties:
"teachProperties": { "units": ["Unidad 1", "Unidad 2"], "attendancePrimaryThreshold": 80, "attendanceSecondaryThreshold": 70, "scoringPrimaryThreshold": 70, "scoringSecondaryThreshold": 60, "behaviorPrimaryThreshold": 90, "behaviorSecondaryThreshold": 80, "useAttendanceFeature": true } The PrimaryThreshold and SecondaryThreshold values are used to determine the color of the cell in the reports.
- Updated docker-tangerine-base-image to v3.8.0, which adds the cordova-plugin-x-socialsharing plugin and enables sharing to WhatsApp.
Fixes
- Fixed PWA assets (sound,video) only work when online #1905
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Check logs for the past hour on the server to ensure it's not being actively used. Look for log messages like "Created sync session" for Devices that are syncing and "login success" for users logging in on the server.
docker logs --since=60m tangerine
# Fetch the updates.
git fetch origin
git checkout -b v3.30.0 v3.30.0
./start.sh v3.30.0
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.29.1
Fixes
- Fix undefined referencein markQualifyingEventsAsComplete
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space.
df -h
# If there is not more than 12 GB plus the size of the data folder, create more space before proceeding.
# Good candidates to remove are: data back-up folders and older versions of the Tangerine image
# rm -rf ../data-backup-<date>
# docker rmi tangerine/tangerine:<version>
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Check logs for the past hour on the server to ensure it's not being actively used. Look for log messages like "Created sync session" for Devices that are syncing and "login success" for users logging in on the server.
docker logs --since=60m tangerine
# Fetch the updates.
git fetch origin
git checkout -b v3.29.1 v3.29.1
./start.sh v3.29.1
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:<previous_version>
New Features
- Case, Event and Form Archive and Unarchive
We have released an update to Tangerine which allows for the archiving and un-archiving of both events, and forms within events. This is an extension of the already existing functionality by which an entire case can be archived. The purpose of this is to empower data management teams using Tangerine to "clean up" messy cases where extraneous data has been added to a case in error, or by a conflict situation. The purpose of this document is to summarize both the configuration to enable this, and to demonstrate the use of these functions. This functionality will only apply to the web-based version of Tangerine, and will not be available on tablets.
Package Updates
- Updated tangy-form to v4.40.0
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space.
df -h
# If there is not more than 12 GB plus the size of the data folder, create more space before proceeding.
# Good candidates to remove are: data back-up folders and older versions of the Tangerine image
# rm -rf ../data-backup-<date>
# docker rmi tangerine/tangerine:<version>
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Check logs for the past hour on the server to ensure it's not being actively used. Look for log messages like "Created sync session" for Devices that are syncing and "login success" for users logging in on the server.
docker logs --since=60m tangerine
# Fetch the updates.
git fetch origin
git checkout -b v3.29.0 v3.29.0
./start.sh v3.29.0
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:<previous_version>
- This became v4
New Features
- New server configuration setting for output value of optionally not answered questions
- The value set in the config variable
T_REPORTING_MARK_OPTIONAL_NO_ANSWER_WITH
inconfig.sh
will be the value of questions that are optional and not answered by the respondent. - The default value is "SKIPPED" for consistency with previous outputs
- The value set in the config variable
- CSV outputs now include the metadata variables
startDateTime
andendDateTime
auto-calculated from thestartUnixTime
andendUnixTime
variables - Additional parameter for the csv data set generation process to ignore
user-profile
andreports
from the output csv files
Fixes
- Copy all media directories from the client form directories to ensure assets are available in online surveys
- Allows form developers to publish images and sounds in online surveys
- Fix the language dropdown in online surveys
- Outputs will no longer try to process outputs for
TANGY-TEMPLTE
inputs
Breaking Changes
- Removes build dependencies for legacy python
mysql
output module- For those using the legacy module, see the documentation move to the new
mysql-js
module
- For those using the legacy module, see the documentation move to the new
Package Updates
- Lock @ts-stack/markdown to 1.4.0 to prevent breaking of builds
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Check logs for the past hour on the server to ensure it's not being actively used. Look for log messages like "Created sync session" for Devices that are syncing and "login success" for users logging in on the server.
docker logs --since=60m tangerine
# Fetch the updates.
git fetch origin
git checkout -b v3.27.8 v3.27.8
./start.sh v3.27.8
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.27.7
Fixes
- Enable mysql-js module outputs for online-survey app data
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Check logs for the past hour on the server to ensure it's not being actively used. Look for log messages like "Created sync session" for Devices that are syncing and "login success" for users logging in on the server.
docker logs --since=60m tangerine
# Fetch the updates.
git fetch origin
git checkout -b v3.27.7 v3.27.7
./start.sh v3.27.7
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.27.6
Fixes
- Address issues using the CaseService
createCaseEvent
API inon-submit
logic by making the function synchronous
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Check logs for the past hour on the server to ensure it's not being actively used. Look for log messages like "Created sync session" for Devices that are syncing and "login success" for users logging in on the server.
docker logs --since=60m tangerine
# Fetch the updates.
git fetch origin
git checkout v3.27.6
./start.sh v3.27.6
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.27.5
Fixes
- CSV Generation: Fix permissions on generate csv batch script
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Check logs for the past hour on the server to ensure it's not being actively used. Look for log messages like "Created sync session" for Devices that are syncing and "login success" for users logging in on the server.
docker logs --since=60m tangerine
# Fetch the updates.
git fetch origin
git checkout v3.27.5
./start.sh v3.27.5
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.27.4
Fixes
- Synchronization: Update Reduce Batch Size button to apply during normal sync for pull and push
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Check logs for the past hour on the server to ensure it's not being actively used. Look for log messages like "Created sync session" for Devices that are syncing and "login success" for users logging in on the server.
docker logs --since=60m tangerine
# Fetch the updates.
git fetch origin
git checkout v3.27.4
./start.sh v3.27.4
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.27.3
Fixes
- Fix running the
reporting-cache-clear
command on themysql-js
module - Extend the particpantID key to 80 chars to handle long keys for T_MYSQL_MULTI_PARTICIPANT_SCHEMA
- For those using
mysql-js
: This change requires runningreporting-cache-clear
to take effect.
- For those using
- Fix missing groupId in user-profile PR: #3494
- This bugfix added groupId to the user-profile.
- In mysql-js, it also throws an error when groupId is missing. Relevant commit. This is different from earlier behavior, which lets the document pass without an error. All docs should have a groupId.
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Check logs for the past hour on the server to ensure it's not being actively used. Look for log messages like "Created sync session" for Devices that are syncing and "login success" for users logging in on the server.
docker logs --since=60m tangerine
# Fetch the updates.
git fetch origin
git checkout v3.27.2
./start.sh v3.27.2
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.27.2
Fixes
- Tangerine on Android APK ignore requestFullscreen() #3539
- This fix above also adds a new app-config.json property -
exitClicks
- enables admin to set number of clicks to exit kioskMode. - Fixed: Tangy-radio button and tangy keyboard do not render on Online survey #3551
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Check logs for the past hour on the server to ensure it's not being actively used. Look for log messages like "Created sync session" for Devices that are syncing and "login success" for users logging in on the server.
docker logs --since=60m tangerine
# Fetch the updates.
git fetch origin
git checkout v3.27.2
./start.sh v3.27.2
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.27.1
Fixes
- Limit debugging logs in csv generation to prevent exec from hitting max_buffer issue
- Add protection to use of onEventOpen and onEventClose API
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Check logs for the past hour on the server to ensure it's not being actively used. Look for log messages like "Created sync session" for Devices that are syncing and "login success" for users logging in on the server.
docker logs --since=60m tangerine
# Fetch the updates.
git fetch origin
git checkout v3.27.1
./start.sh v3.27.1
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.27.0
NEW Features
- Update triggers for Case API hooks
The Case Service API has a set of functions that are triggered on events. An implementer of Tangerine using the Case module can add these triggers to their case definition json in order to hook into these actions. The variable name to add is the trigger, e.g. onCaseOpen
and the value is valid javascript that will run when the trigger is fired. The following changes were made to the hooks:
-- onCaseClose
hook will fire when the case is closed by the user by clicking the 'X' in the upper-left corner
-- onCaseOpen
hook will fire when the case is opened (no change)
-- onEventOpen
has been changed to fire when a Case Event is clicked on the Case Summary page
-- onEventClose
has been changed to fire when the Event page is closed
-- onEventCreate
has been added and will fire when the user creates a new event using the dropdown in the Case Summary page
-- onEventFormOpen
has been added and will fire when the user opens a form from the Event page
-- onEventFormClose
has been added and will fire when the user closes a form
Fixes
- Check for custom search js when creating user dbs (Tangerine Preview)
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Check logs for the past hour on the server to ensure it's not being actively used. Look for log messages like "Created sync session" for Devices that are syncing and "login success" for users logging in on the server.
docker logs --since=60m tangerine
# Fetch the updates.
git fetch origin
git checkout v3.27.0
./start.sh v3.27.0
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.26.2
DEPRECATION NOTICE AND UPCOMING MODULE DELETION
The mysql module is deprecated; it will be removed soon from this source code in the v3.28.0 release. We have been using the mysql-js in production for a few months and it is more performant and reliable than the output of the mysql module. We recommend switching to the mysql-js module. See the MySQL-JS Module doc for upgrade and configuration information.
New Features
- New group content-set dropdown: PR 3275 - #3275 - enables a content-set dropdown and is already in main. Modify the template (content-sets-example.json) and rename to content-sets.json to enable the dropdown.
Fixes
- Created Feedback dialog to resolve layout issue on mobile devices PR: #3533
- Fix for Class listing breaks if you archive all classes in Teach; unable to add new classes. Issue: #3491
- Fix for Mysql tables not populating; ER_TOO_BIG_ROWSIZE error in Tangerine logs. Issue: #3488
- Changed location of mysql-js config file to point to the mysql-js directory. Also increased memory parameters in conf.d/config-file.cnf.
- If you are using the mysql container and are having errors with very large forms, the new settings in ./server/src/mysql-js/conf.d/config-file.js should help. You will need to completely rebuild the mysql database. See the "Resetting MySQL databases" section in the MySQL-JS Module docs.
- Important: If you already have a mysql instance running and don't want to rebuild the mysql database, delete the
innodb-page-size=64K
line from ./server/src/mysql-js/conf.d/config-file.js; otherwise, your mysql instance will not start. - Fix for CSV Download fails with larger forms. Issue: #3483
Backports
The following feature was backported from v3.24.6 patch release:
- T_UPLOAD_WITHOUT_UPDATING_REV : A new config.sh setting for use in high-load instances using sync-protocol-1. *** Using this setting COULD CAUSE DATA LOSS. *** This setting uses a different function to process uploads that does not do a GET before the PUT in order to upload a document. Please note that if there is a conflict it try to POST the doc which will create a new id and copy the _id to originalId. If that fails, it will log the error and not upload the document to the server, but still send an 'OK' status to client. The failure would result in data loss.
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Check logs for the past hour on the server to ensure it's not being actively used. Look for log messages like "Created sync session" for Devices that are syncing and "login success" for users logging in on the server.
docker logs --since=60m tangerine
# Fetch the updates.
git fetch origin
git checkout v3.26.2
./start.sh v3.26.2
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.26.1
NEW Features
- New configuration parameter:
T_LIMIT_NUMBER_OF_CHANGES
- Number of change docs from the Couchdb changes feed queried by reporting-worker (i.e. use as the limit parameter). Default: 200. - Added volume mapping for translations dir in start script.
- A new
mysql-js
module replaces the oldmysql
module. Documentation is here. The newmysql-js
module is faster and more accurate than the oldmysql
module. It no longer uses an intermediate "group-uuid-mysql" couchdb; instead, it reads from the _changes feed and writes directly to a MySql database. To use the new module, addmysql-js
to the T_MODULES list of modules and configure the following settings:- T_MYSQL_CONTAINER_NAME="mysql" # Either the name of the mysql Docker container or the hostname of a mysql server or AWS RDS Mysql instance.
- T_MYSQL_USER="admin" # Username for mysql credentials
- T_MYSQL_PASSWORD="password" # Password for mysql credentials
- T_USE_MYSQL_CONTAINER="true" # If using a Docker container, set to true. This will automatically start a mysql container when using a Tangerine launch script.
Fixes
- Student subtest report incorrect for custom logic inputs #3464
- Init paid-worker file when server restarted.
- Fix bug in start.sh script for --link option
- Rename T_REBUILD_MYSQL_DBS to T_ONLY_PROCESS_THESE_GROUPS. Configure T_REBUILD_MYSQL_DBS to list group databases to be skipped when processing data through modules such as mysql and csv.
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Check logs for the past hour on the server to ensure it's not being actively used. Look for log messages like "Created sync session" for Devices that are syncing and "login success" for users logging in on the server.
docker logs --since=60m tangerine
# Fetch the updates.
git fetch origin
git checkout v3.26.1
./start.sh v3.26.1
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.26.0
NEW Features
- MySQL JS Module: -- Track and output changes through the CouchDB Changes Feed -- Connect to a MySQL Server of your choice via a url and credentials
- Add app-config flag to force confirmation of each form response created on the client
- Update to tangy-form and tangy-form-editor which enables configuration of automatic scoring in Editor for groups using Class. Issue: #1021
- Documented a list of Reserved words in Tangerine
- Bump docker-tangerine-base-image to v3.7.4 (enables RECORD_AUDIO permission for APK's), tangy-form to 4.38.3, tangy-form-editor to 7.15.4.
Fixes
- Add protection when using Case APIs that load other cases than the currently active case
- feat(custom-scoring): If customScore exists, use it [#3450](#3450
- fix(record-audio): Request audio permissions #3451
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Check logs for the past hour on the server to ensure it's not being actively used. Look for log messages like "Created sync session" for Devices that are syncing and "login success" for users logging in on the server.
docker logs --since=60m tangerine
# Fetch the updates.
git fetch origin
git checkout v3.26.0
./start.sh v3.26.0
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.26.0
Fixes
- Fix logic in has merge change permissions
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Check logs for the past hour on the server to ensure it's not being actively used. Look for log messages like "Created sync session" for Devices that are syncing and "login success" for users logging in on the server.
docker logs --since=60m tangerine
# Fetch the updates.
git fetch origin
git checkout v3.25.1
./start.sh v3.25.1
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.25.1
NEW Features
- Improvements to Issues on the Client and Server 3413 -- Add app-config flag to allow client users to Commit changes to Issues -- Add user-role permissions to select which events or forms Issue changes can be commited on the client -- Pull form responses changed in Issues on the server down to the client
- Add parameter to CSV Dataset Generation that allows exclusion of archived form definitions
Fixes
- Apply isIssueContext correctly on the client
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Check logs for the past hour on the server to ensure it's not being actively used. Look for log messages like "Created sync session" for Devices that are syncing and "login success" for users logging in on the server.
docker logs --since=60m tangerine
# Fetch the updates.
git fetch origin
git checkout v3.25.0
./start.sh v3.25.0
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.25.0
NEW Features
- T_UPLOAD_WITHOUT_UPDATING_REV : A new config.sh setting for use in high-load instances using sync-protocol-1. *** Using this setting COULD CAUSE DATA LOSS. *** This setting uses a different function to process uploads that does not do a GET before the PUT in order to upload a document. Please note that if there is a conflict it will copy the _id to originalId and POST the doc, which will create a new id. If that fails, it will log the error and not upload the document to the server, but still send an 'OK' status to client. The failure would result in data loss.
NEW Features
- Ability to add scoring from the interface (24 hours) #1021
Fixes
- User is forced to stay on form until submission [#3215] - changed current-form-id to incomplete-response-id
- Bumped tangy-form to 4.37.0 and tangy-form-editor to 7.14.11.
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Check logs for the past hour on the server to ensure it's not being actively used. Look for log messages like "Created sync session" for Devices that are syncing and "login success" for users logging in on the server.
docker logs --since=60m tangerine
# Fetch the updates.
git fetch origin
git checkout v3.24.4
./start.sh v3.24.4
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.24.3-final
Please note that this release is tagged v3.24.3-final, not v3.24.3. This is a deviation from our usual format; we will resume the previous format in the next release.
New Feature
- To force user to stay on form until submission, set `"forceCompleteForms":true' in the group app-config.json. Issue: #3215
Fixes
- Separate Archived and Active forms in Request Spreadsheet screen #3222
- When incomplete results upload is enabled on a group, do not save empty record when using sync-protocol 1. #3360
- Enable editing the "No" confirmation alert for tangy-consent #3025
- Fix Sync error caused by async directory error when creating media directories #3374
- Exclude client-uploads folder from APK and PWA releases #3371
- Remove ordering of inputs when creating spreadsheets #3252
- Bumped tangy-form-editor to v7.14.8 to add Video Capture input warning text #3376
- Bumped tangy-form to 4.36.3.
- Updated the online-survey-app routing to route to a specific form, and also adds an optional routing option. PR:#3387
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Check logs for the past hour on the server to ensure it's not being actively used. Look for log messages like "Created sync session" for Devices that are syncing and "login success" for users logging in on the server.
docker logs --since=60m tangerine
# Fetch the updates.
git fetch origin
git checkout v3.24.3-final
./start.sh v3.24.3-final
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.24.2
Fixes
- Hide Case Events form the Schedule View that are 'inactive'
- Add the 'endUnixTimestamp' to mysql outputs generated by the python module
- Remove unnecessary and expensive query for conflicts during synchronization on the client PR: #3365
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Check logs for the past hour on the server to ensure it's not being actively used. Look for log messages like "Created sync session" for Devices that are syncing and "login success" for users logging in on the server.
docker logs --since=60m tangerine
# Fetch the updates.
git fetch origin
git checkout v3.24.2
./start.sh v3.24.2
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.24.1
New Features
- Feature: New version of mysql module, called mysql-js, which is coded in javascript instead of python. This module exports records much faster than previous version. It should also use much less memory and provide more flexibility in terms of column data types and (eventually) support of different types of databases. Issue: #3047
- Feature: Enable upload of files created by the tangy-photo-capture and tangy-video-capture inputs. PR: #3354
Note: In order to cause minimal negative impact upon current projects, the default behavior will be to save image files created by the tangy-photo-capture input to the database, instead of saving to a file and uploading. That being said, it is preferable to save as a file and upload. To over-ride this default, set the new
mediaFileStorageLocation
property to 'file' in the group's app-config.json. The default is 'database'. If this property is not defined, it will save to the database. New groups will be created withmediaFileStorageLocation
set to 'file'. Videos created using the tangy-video-capture input will always be uploaded to the server due to their large file size.
Fixes
-
The default password policy (T_PASSWORD_POLICY in config.sh) has been improved to support most special characters and the T_PASSWORD_RECIPE description has been updated to list the permitted special characters. Issue: #3299
Example:
(\` ~ ! @ # $ % ^ & * ( ) \ - _ = + < > , . ; : \ | [ ] { } )
- Enable forms without location to be viewed in visits listing. PR: #3347
- Fix results with cycle sequences that do not generate a CSV file. Issue: #3249 PR: 3345
- Enable grids to be hidden based on skip logic #1391
- Add confirmation to consent form if 'No' selected before the form is closed #3025. Activate this feature using the new property:
confirm-no="true"
. - Fix app config doNotOptimize logic PR: #3358
- Those using the
doNotOptimize
flag must reverse the logic in theappConfig.sh
file when updating to this version
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Check logs for the past hour on the server to ensure it's not being actively used. Look for log messages like "Created sync session" for Devices that are syncing and "login success" for users logging in on the server.
docker logs --since=60m tangerine
# Fetch the updates.
git fetch origin
git checkout v3.24.1
./start.sh v3.24.1
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.24.0
New Features
- App user can reduce the batch size as a workaround when experiencing 'out-of-memory' errors with Rewind Sync
- On occasion Rewind Sync will fail to complete due to 'out-of-memory' issues. The Advanced Sync section of the Sync page now shows a checkbox that when checked will reduce the batch sizes used to perform the Rewind Sync. As noted in the UI, the Rewind Sync will take longer to process however in most cases it will be able to complete the process. The batch size reduction will be reverted once the Rewind Sync is complete or the user unchecks the box.
- System Admin can scan a QR code to download an APK or PWA release
- When deploying Tangerine, it can be a long process to download and install the APK or PWA on multiple devices. To improve the deployment process, the Release tables now show a QR code that when scanned will download the release directly to a new device without the need to type in the URL.
- Improvements to Sync: In case of false positives on push, keep pushing until nothing is pushed
- Client Case Service API:
- Case Event and Event Form (De)activation 3334
- activateCaseEvent: Marks a Case Event as 'active' and shows it in the Case Event list
- deactivateCaseEvent: Marks a Case Event as 'inactive' and hides it in the Case Event list
- activateEventForm: Marks an Event Form as 'active' and shows it in the Event Form list
- deactivateEventForm: Marks an Event Form as 'inactive' and hides it in the Event Form list
- Case Event and Event Form (De)activation 3334
- Editor Case Service API:
- Add useful APIs used in the client Case Service API to the editor Case Service API 3325
- Option to sync a case before viewing it 3237
- Support for showing photo and signatures in Issues
Fixes
- Fix after update messaging and async issues
Translations
- Include Vietnamese translations
Deprecations
- Comparison Sync has been removed from this release to reduce confusion reported by Tangerine users. The Rewind Sync functionality out-performs Comparison Sync and is recommended for use when needed on all deployments.
Fixes
- Fixed bug in sync on PWA's. Also, do note that video file upload using the new tangy-form input
<tangy-video-capture>
only works for APKs Issue: [#3338] #3338 - Fixed tangy-form-editor to 7.14.2 to fix bug with input widget for tangy-keyboard-input (postfix field).
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Check logs for the past hour on the server to ensure it's not being actively used. Look for log messages like "Created sync session" for Devices that are syncing and "login success" for users logging in on the server.
docker logs --since=60m tangerine
# Fetch the updates.
git fetch origin
git checkout v3.23.1
./start.sh v3.23.1
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.23.0
New Features
- Enabled video upload feature which uses the new tangy-form input
<tangy-video-capture>
. There is a new video file upload section in the sync feature for both sync-protocol 1 and 2. implementation details in this PR: 3327. Issue: #3212 The new tangy-form input<tangy-video-capture>
takes the following properties:- frontCamera: Boolean. Whether to use the front camera or the back camera. Default is
true
. - noVideoConstraints: Boolean. Whether to force use of front or back camera. If true, chooses the first available source. Default is
true
. - codec: String. The codec to use. Default is 'video/webm;codecs=vp9,opus' - AKA webm vp9. It is possible the device may not support all of these codecs. Other potential codecs include
video/webm;codecs=vp8,opus
andvideo/webm;codecs=h264,opus
. - videoWidth: Number. The width of the video. Default is
1280
and videoHeight: Number. The height of the video. Default is720
.
- frontCamera: Boolean. Whether to use the front camera or the back camera. Default is
- Bump tangy-form lib to 4.34.3, tangy-form-editor to 7.14.1.
Fixes
- Add postfix property to tangy-keyboard-input. Also add highlight to value entered. Issue: 3321
New Features
- Feature: Tangerine CLI for dropping mysql tables and resetting mysql .ini files. PR: #3281
Usage:
docker exec tangerine module-cache-clear mysql
Fixes
- Error when mysql module creates a table with duplicate participantId PR: #3279
- New languages - Bengali, Dari, Hindi, Pashto, Portuguese, Updated Russian, Swahili, Urdu #3263
- Filter archived case events out of Schedule View #3267
- Many fixes to Teach:
- Add Current Date to Teach Subtest Report #3273
- Remove some appended Teach CSV columns #3271
- Fix student subtest report failing by transforming data only for related curriculum #3272
- Student subtask report is failing with error #3270
- CSV file contains tangy-input metadata and displaces all inputs #3227
- Fix summary upload #3265
- Records should be one doc per Student per Curriculum per Class. Not per Student per Curriculum per Class per Item. #3264
- Provide Bengali number translation in Student Grouping Report #3255
- Bengali numbers are not being replaced in Class Grouping report #3228
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Check logs for the past hour on the server to ensure it's not being actively used. Look for log messages like "Created sync session" for Devices that are syncing and "login success" for users logging in on the server.
docker logs --since=60m tangerine
# Fetch the updates.
git fetch origin
git checkout v3.22.4
./start.sh v3.22.4
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.22.3
Fixes
- Fix all Tangy Templates are missing when reviewing completed form responses.
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Check logs for the past hour on the server to ensure it's not being actively used. Look for log messages like "Created sync session" for Devices that are syncing and "login success" for users logging in on the server.
docker logs --since=60m tangerine
# Fetch the updates.
git fetch origin
git checkout v3.22.3
./start.sh v3.22.3
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.22.2
Fixes
- Download All button on Spreadsheet Request info page does not download #3232
- Spreadsheet Requests page does not load for new groups #3233
- Fix use of window.eventFormRedirect #3211
- Spreadsheet Request will fail to generate Download All zip if one form has specific characters in the title #3217
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Check logs for the past hour on the server to ensure it's not being actively used. Look for log messages like "Created sync session" for Devices that are syncing and "login success" for users logging in on the server.
docker logs --since=60m tangerine
# Fetch the updates.
git fetch origin
git checkout v3.22.2
./start.sh v3.22.2
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.22.1
Fixes
- Fix: Tangy Template elements all say "false" if using environment variables like caseService and T #3203
- Make issue diffs less crash prone #3200
- Fix: Case fails to open after selecting Case in search behind a "load more" button #3194
- Fix: Unable to scroll to last item in search list if there is not more button #3195
- Fix: After typing a search, "load more" button appears with no search results for a few seconds #3196
- On a Spreadsheet Request page, style the download all button's icon as white.
- Unify and fix the exclude pii label on spreadsheet requests.
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Check logs for the past hour on the server to ensure it's not being actively used. Look for log messages like "Created sync session" for Devices that are syncing and "login success" for users logging in on the server.
docker logs --since=60m tangerine
# Fetch the updates.
git fetch origin
git checkout v3.22.1
./start.sh v3.22.1
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.22.0
Fixes
- Device User should not be able to register Device Account without username #3162
- CSV Datasets are not filtering by month and year when a 'Month' and 'Year' is selected #3181
- Make Loc and t available on Editor's window object for consistency with Client environment #3161
- Fix messaging during data optimization and reduce number of view optimized that are never used #3165
- Prevent menu items from jumping around on Deploy page #3169
- Fix bug causing document updates to get skipped over in sync after a Comparison Sync #3179
Deprecate single csv download in favor of Spreadsheet Requests
See screenshots here.
- Change terminology referring to "CSV" to more commonly recognized "Spreadsheet" term.
- "CSV Datasets" term changed to "Spreadsheet Requests".
- Fix "CSV Datasets are not filtering by month and year when a 'Month' and 'Year' is selected #3181"
- Request Spreadsheets page: Submit button now hovers and is sticky to bottom of page; "*" in Month/Year selection clarified as "All months"/"All years"; "Description" no longer required and given own line for better formatting; other formatting cleanup.
- Data page: Removed deprecated CSV Download button; updated language; added "Request Spreadsheets" button for quick access to making a request for spreadsheets.
- Spreadsheet Request Info page: Now dynamically updates as Spreadsheets are rendered with row counts and status; removed unnecessary filename to download all, instead it's a "download all" button; new types of status including "File removed", "Stopped", "Available", and "In progress"; Month and Year values of "*" now clarified as "All months" and "All years"; loading screen improvements; title of page now the date the spreadsheets were requested on.
- Spreadsheet Requests page: Updated language; fixed total Spreadsheet Requests calculation in pagination; if status of Spreadsheet Request is "Available" the status shows in green; if the status of the Spreadsheet Request is "In progress" a spinner is shown where the Download button will be; labels of "More Info" and "Download" added to corresponding buttons; loading overlay now shown on initial load and when changing pages.
- Spreadsheet Templates page: Updated terminology from CSV Templates to Spreadsheet Templates.
New Features
- Show recent activity as default search results #3171
- Make a cached version of the Device information available to form logic on T.device.device #3183
- Group Administrator configures Device Account password policy #3172
- On search UI: limit initial results to 10 for fast load, add a "Load More" button for pagination, and style improvements #3164
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.22.0
./start.sh v3.22.0
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.21.0
Developers:Good to Know
- The master branch has been moved to the main branch. No development will happen on the master branch, which has been deleted. Also, please note the updates to the Release Workflow
Fixes
- Prevent unnecessary CaseService saves by comparing hashes #3155
- Prevent loss of case changes when leaving incomplete form by always saving the case #3156
- Prevent on-submit of a form running in one Case from being able to run in another case by navigating quickly to another Case. We inject
T
andcase
(caseService) variables into Tangy Form (formPlayer) from EventFormComponent. This will addinstanceFrom: 'EventFormComponent'
to the caseService (and also assigns['instanceFrom'] = 'EventComponent'
in EventComponent). Note that if you have any use ofwindow.T
orwindow.caseService
, you will need to make themT
andcaseService
to take advantage of this fix. Commit: 716bc5e9 - Bump tangy-form to v4.29.1 and tangy-form-editor to v7.10.2 Commit: a3f785310
New Features
- Add support for running an SSL frontend. Issue: #3147
- Make CORS settings configurable by T_CORS_ALLOWED_ORIGINS Commit: 1f448f7e
- Add ability to generate CSV datasets for all groups and all forms. This feature provides the new generate-csv-datasets command and csvDataSets route. #3149
- Add support for Tangy Form's useShrinker flag, implemented as AppConfig.saveLessFormData. This is an experimental mode in Tangy Form that only captures the properties of inputs that have changed from their original state in the form. This should lead to smaller formResponses and quicker sync data transfers. Commit: 35a05c2b, Tangy-form pull: Add support for shrinking form responses #209
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.21.0
./start.sh v3.21.0
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.20.4
Fixes
- Fixes resuming an unfinished Event Form. Commit bf97492
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.20.4
./start.sh v3.20.4
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.20.3
Fixes
- Editing Timed Grids on Forms: Capture at item and Duration are compared as strings leading to unexpected validation scenarios #3130
- Fix CORs usage in Tangerine APIs when outside applications are using credentials. #3132
- When Tangerine creates CouchDB users for Sync, DB Administration, and Reporting, restrict that users access to the databases for the group they are assigned. This is a tightening of security to support use cases where users of groups on the same server should be restricted from accessing other groups data on the same server when Sync Protocol 2 and Database Administrator features are being used. #3118
- Data Manager views in CSV which cycle sequence was used in each form response #3128.
- Fix access denied message when using Tangerine APIs #3133
- Make status translateable on Tangerine Teach Task Report. #3089
- When editing Timed Grids on Forms, "Capture at Time" and "Duration" are compared as strings leading to unexpected validation scenarios. #3130
- Fix database export when using Sync Protocol 1 by using the correct database names #3120
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.20.3
./start.sh v3.20.3
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.20.2
Fixes
- Improve listing of items in the Data menu. Issue: #3125
- Fix issue where Group User on server with permission to access database would not have access. Commit: a10162d9
- Add Amharic translation.
- Fix issue when backup has never run, the Clean backups command in Maintenance on client fails, and the process alert does not go away. This PR also copies over a fix for clearing all progress messages from Editor. PR: #3098
- Fix bad url for Print Content feature in Editor/Author. PR: #3099
- Clicking on unavailable form in Case should not open it. Issue: #3063
- The csv and mysql outputs must carry over the 'archived' property from the group db. PR: #3104
- Bump tangy-form to v4.28.2 and tangy-form-editor to v7.9.5. Includes fix for tangy-input-groups change logic Issue: #2728
- Users should enter dataset description when creating a dataset in Editor PR: #3078
- Avoid crashes when properties on the markup are accessed before being available to the component #3080
- Replace special chars with underscore in CSV output. PR: #3003
- Refresh global reference to T.case when using a case so most importantly the correct context is set PR: #3108
- Link to download data set downloads a JSON file with headers and group config doc. Issue: #3114
- CSV template creation fails. Issue: #3115
- Restart couchdb container on failure. PR: #3112
- APK and PWA Updates fail with User not logged in (every time) #3111
- Fix error when looping through input values for data dictionary. PR: #3124
- Add config to allow output of multiple participants in MySQL. Consult the PR for implementation details. If you wish to enable this feature, add
T_MYSQL_MULTI_PARTICIPANT_SCHEMA:true
to the config.sh script. PR: #3110
Upgrade notice
If your project was already using the Data Conflicts tools that were installed manually, you must remove those in order to prevent a conflict with the Database Conflicts tool that is now automatically installed in Tangerine -> Deploy -> Database Conflicts. Reset the group-uuid/editor directory with the content-sets/case-module/editor components or the content-sets/case-module-starter/editor/index.html file.
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.20.2
./start.sh v3.20.2
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.20.1
# This will index all database views in all groups. It may take many hours if
# the project has a lot of data.
wedge pre-warm-views --target $T_COUCHDB_ENDPOINT
Fixes
- Fix Form Editor removes manually added on-resubmit logic in tangy-form #3017
- Support old PWAs that did not check for all permissions when installed in order to get permanent storage #3084
New Features
- Add Maintenance page to client to enable app administration tasks (clear out old backups and fix permissions) and disk space statistics. #3059
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.20.1
./start.sh v3.20.1
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.20.0
# This will index all database views in all groups. It may take many hours if
# the project has a lot of data.
wedge pre-warm-views --target $T_COUCHDB_ENDPOINT
Fixes
- Improve rendering of Device listing. PR: #2924 Note that you must run the update or else the Device view will fail.
- Converted print form view as a single table #2927
- Improvements to restoring a database from a backup PR: #2938
- On server group's security page, fix link to adding roles and show loading screen when saving role.
- Data outputs for CSV's now include the 'archived' property. #2988
- This one goes out to the coders: Prevent CaseService singleton injection into Case related components #2948. This is an important change in how cases are handled - they are no longer singletons. If you are developing scripts for a form and there are problems accessing T.case, see the comments in #2948 for a solution.
New Features
- New CSVs related to Cases now available for Case Participants, Case Events, and Case Event Forms. #2908
- Online Survey user is warned if they are using an unsupported web browser (Internet Explorer). #3001
- Data Manager generates CSV with specific columns using CSV Templates.
- Data Manager restores Case Event stuck in Conflict Revision. Add the
can_restore_conflict_event
permission to the users' role(s) to enable. #2949 - Enable Data Conflict Manager for groups. 2997 This is based on the couchdb-conflict-manager web component.
- In Offline App, when submitting a form, opening a case, creating a case, etc., a new loading screen is shown. #3000
- In Online Survey, new support for switching language without interrupting the survey. #2643
- For PWA's, there is a new device permissions step in device setup to guarantee persistent storage #3002
- The login screen may now have custom markup. #2979
- Statistical files are now available in Stata .do format for corresponding forms #2971
- The new
usePouchDbLastSequenceTracking
property in app-config.json and settings page enables the use of PouchDB's native last sequence tracking support when syncing. #2999 - The new
encryptionPlugin:'CryptoPouch'
property in app-config.json enables testing of the CryptoPouch extension currently in development. #2998 Please note that this feature is not yet ready for deployment. There are now three different possible storage configurations for Tangerine:- "encryptionPlugin":"CryptoPouch" - Configures the app to use CryptoPouch, which encrypts documents in the app's indexedb for storage.
- "turnOffAppLevelEncryption": true - Configures the app without encryption, using the app's indexedb for storage instead of sqlite/sqlCypher.
- "encryptionPlugin":"SqlCipher" - or without any additional configuration (SqlCipher is the default configuration.) - Configures the app to use SqlCipher, which encrypts documents in an external sqlLite database for storage.
- We have changed how we determine which storage engine is being used. In the past we exposed a window['turnOffAppLevelEncryption']
global variable based on the same flag in app-config.json; however, now we are determining in app-init.ts which engine is running and exposing either
window['cryptoPouchRunning']
orwindow['sqlCipherRunning']
to indicate which engine is running. It is important to note that even the app is configured withencryptionPlugin:'CryptoPouch'
in app-config.json, the app may have been installed without that setting and is actually running sqlCypher. This is why it is important to observe if eitherwindow['cryptoPouchRunning']
orwindow['sqlCipherRunning']
is set.
Backports/Good to Know
When we add new features or fix issues in patch releases of Tangerine, those code changes usually get added automatically to any new releases of Tangerine. To make sure users of new releases are aware of those changes, we will occasionally mention them in this section in case they have missed them in the Changelog for the corresponding earlier release. Please note that when you install or upgrade a new Tangerine release, please review the Changelog for any changes in minor or patch releases.
- Server admin can configure regex-based password policy for Editor. Instructions in the PR: #2858 Issue: #2844
- Show loading screen in more places that typically hang such as the Case loading screen, issue loading, issue commenting, and many other places when working with Issues on the sever. (demo: https://youtu.be/RkoUN41jqr4)
- Enhancements to support for archiving cases:
- Added backup and restore feature for Tangerine databases using device encryption. Increase the appConfig.json parameter
dbBackupSplitNumberFiles
(default: 200) to speed up the backup/restore process if your database is large. You may also change that parameter in the Export Backup user interface. Updated docs: Restoring from a Backup PR: #2910 - Updates to tangy-form lib to 4.25.18 (Changelog), which provides:
- Support for changing a page content's language and number system without reloading the page.
- A fix for photo-capture so that it de-activates the camera when going to the next page or leaving a form. Also a new feature for configuring compression
- Implemented a new 'before-submit' event to tangy-form in order to listen to events before the 'submit' event is dispatched.
- A fix for User defined Cycle Sequences.
- Important If your site uses csvReplacementCharacters to support search and replace configuration for CSV output, which was released v3.18.2, you must change the configuration string. See issue #2804 for information about the new schema.
- Feature: Editor User downloads CSVs for multiple forms as a set Issue: #2768 PR:#2777
- Feature: Remove configurable characters from CSV output #2787.
Server upgrade instructions
Important upgrade: Please note that you must run update below (v3.20.0.js) to install the new listDevices view. If you don't the Devices listing will fail.
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.20.0
./start.sh v3.20.0
# Run the update to install the new listDevices view.
docker exec -it tangerine /tangerine/server/src/upgrade/v3.20.0.js
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.19.1
# This will index all database views in all groups. It may take many hours if
# the project has a lot of data.
wedge pre-warm-views --target $T_COUCHDB_ENDPOINT
Fixes
- Fix issue where loading screen would not close after submitting a proposal on an Issue.
- Fixes from v3.18.8 incorporated.
- Fixes to how role based permission rules are applied on the schedule view.
- Fix CaseService.rebaseIssue from failing due to accessing eventForms incorrectly.
New Features
- Show loading screen in more places that typically hang such as the Case loading screen, issue loading, issue commenting, and many other places when working with Issues on the sever. (demo: https://youtu.be/RkoUN41jqr4)
- Material design applied to loading indicator on the server.
- New cancel button on loading indicator on the server. Will warn that this may cause data corruption and data loss. (demo: https://youtu.be/da9cxG5w8c0)
- Added ability to search archived cases. Issue: #2977
Important : Run
docker exec -it tangerine /tangerine/server/src/upgrade/v3.19.3.js
to enable searching archived cases.
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.19.3
./start.sh v3.19.3
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.19.2
# Run the v3.19.3.js update to enable indexing of archived documents.
docker exec -it tangerine /tangerine/server/src/upgrade/v3.19.3.js
# This will index all database views in all groups. It may take many hours if
# the project has a lot of data.
wedge pre-warm-views --target $T_COUCHDB_ENDPOINT
Fixes
- Added process indicator when archiving, un-archiving, or deleting a case. Issue: #2974
- Add v3.19.2 update to recover if v3.19.0 search indexing failed
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.19.2
./start.sh v3.19.2
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.19.1
# Perform additional upgrades.
docker exec -it tangerine bash
# This will index all database views in all groups. It may take many hours if
# the project has a lot of data.
wedge pre-warm-views --target $T_COUCHDB_ENDPOINT
Fixes
- Improved backup and restore file processing. Docs: Restoring from a Backup PR: #2910
- Added archive/unarchive Case functionality and permission for "can delete" #2954
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.19.1
./start.sh v3.19.1
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.19.0
# Perform additional upgrades.
docker exec -it tangerine bash
# This will index all database views in all groups. It may take many hours if
# the project has a lot of data.
wedge pre-warm-views --target $T_COUCHDB_ENDPOINT
New Features
- Data Manager requests and downloads CSVs for multiple forms as a set. When logged into the server and in a group, you will now find a "Download CSV Data Set" menu item under "Data". From there you can view all of the CSV Data Sets you have generated in the past, the status of wether or not they have finished generating, a link to download them, and other meta data. Click the "New Data Set" button and you will be able to select any number of forms to generate CSVs for, data for all time or a specific month, and wether or not to exclude PII. This is especially useful for generating CSVs that take longer to generate than the automatic logout built into the server. You may request a CSV Data Set, log out, and then log back in later to check in on the status and download it. A Server Administrator can also configure cron with a
generate-csv-data-set
command to generate a data set on a daily, weekly, or monthly basis, handy for situations where you want CSVs to automatically generate on the weekend and then download them on Monday. (Ticket: #2768) (PR: #2777) - Data Manager archives a Case to remove it from reporting output and Devices. This adds an "archive" button on Cases that flags all related Form Responses as archived and removes them from CSV output and Search on Devices. This uses the new T.case.archive() API which adds an 'archived' flag for those docs and saves a minimal version of the doc with enough data to be indexed on the server. Search on client and server CSV output are modified to filter archived docs. When viewing cases in Editor, displays "Archived" when viewing an archived case. When client syncs, it deletes any docs with the 'archived' flag and sets deletedArchivedDocs In the replicationStatus log. (Ticket: #2843) (PR: #2776)
- Devices Manager reconfigures claimed Device sync settings and selects multiple Sync Locations for a Device. Details: To change a Device's sync settings currently requires a reinstall of the app on the Device and setting up all the accounts again. This PR will allow system admins to change the sync settings for a Device which then triggers on next sync a Rewind Push, database delete, then a first pull with the new sync settings. Subsequent syncs then use the new sync settings. This PR also refactors the Create and Edit forms for Devices on the server so that multiple sync locations can be added. (Ticket: #2867) (PR: #2782)
- Device Manager estimates how large an initial sync will be given selected sync settings. When setting up sync settings for a Device, it is useful to know how many documents will need to be downloaded given which forms are configured for syncing down and the locations assigned. There is now a "calculate down-sync size" button at the bottom of Device edit/creation forms that when pressed will tally up the documents needing to be down synced given the device sync settings. (Ticket: #2845) (PR: #2818)
- Devices Manager monitors for Devices close to filling up disk space. Devices now report how much free space they have to the server after a sync. This can be monitored on the
Deploy > Devices
list. When a Device reports having less than 1GB free storage, a warning is shown on the Devices list. (Ticket: 2779) (PR: 2795) - Server User views the version of Tangerine installed. Any user on the server can now view the version of Tangerine installed by going to Help menu in the left nav bar. (Ticket: #2846) (PR: #2794)
- Database Consumer accesses Tangerine MySQL databases via web browser. Users of Tangerine's MySQL database sometimes are not allowed to install tools such as MySQL Workbench on their work computers. This PR makes starting PHPmyAdmin (a mysql viewer) as a web service a configuration option in Tangerine so no one has to install software on their computer to access Tangerine MySQL. (Ticket: #2847) (PR: #2793)
- Data Collector creates Account on Device and associates with any User Profile in Group (ignoring Device assignment/sync settings). By default, when a Data Collector creates an Account on Device, they can only associate with User Profiles that are assigned to the same location as the Device's Assigned Location. Add
"disableDeviceUserFilteringByAssignment":true
to the app-config.json for the group and this restriction will be removed. Tablets will also sync all User Profiles, ignoring the Device's configured Sync Location(s). (Ticket: #2848) (PR: #2792) - Form Developer writes code that can access Case's related Location metadata without writing asynchronous code. When working synchronously in forms, we don't currently have access to the related Location Node data without loading the Location List async and using T.case.case.location to search the hierarchy for the node we want. This PR loads all related Location Nodes into memory at T.case.location when the context of a Case is set. (Ticket: #2849) (PR: #2791)
- Server Administrator configures substitutions for CSV output. This feature allows a Server Administrator to update the group's configuration in the app database to contains Regex string replacements for CSV output. This can be handy in situations where Data Analysts are having trouble parsing CSV data that contains line breaks and commas. An example configuration to remove line breaks and commas from data would be
"csvReplacementCharacters": [{"search": ",", "replace": "|"}, {"search": "\n", "replace": "___"}]
. (Ticket: #2787) (PR: #2788) - Server Administrator configures Tangerine to not auto-commit in groups' data directories to preserver manually managed git content repositories. When using git to manage group content in a git flow like manner, the automatic commit can result in unnintentional commits. System Administrators can now turn off this auto-commit by configuring Tangerine's
config.sh
withT_AUTO_COMMIT="false"
. If set to true also include the frequencyT_AUTO_COMMIT_FREQUENCY="60000"
(Ticket: #2614) (PR: #2748) - Data Collector proposes change to a Form on a Case. The issues feature that has been available on the server is now optionally also available on Devices by
"allowCreationOfIssues": true
toclient/app-config.json
for the group you want this enabled. Most of the features of Issues you are familiar with from the server are there, except for merging proposals which is not allowed. Issues from Devices are uploaded to the server where proposals can be merged by a Data Manager. We also streamlined the Issue creation and proposal process by skipping the page to fill out an issue title/description, and then forward them directly to creating a proposal. To aid in issue titles/descriptions that make sense, Content Developers can now addtemplateIssueTitle
andtemplateIssueDescription
to Case Definition files. (Ticket: #2850) (PR: #2330) (Demo Video) - Data Manager updates Issue Title and Issue Description Data Managers will now find a metadata tab on an Issue where they can update the Title, Description, and new "Send to" settings. (Issue: #2851) (PR: #2330)
- Data Manager sends an Issue to all Devices in Sync Area or specific Device When create/configuring an Issue, Data Managers now have the option to send an Issue to a specific location in a Sync Area, or send it to a specific Device by Device ID. (Ticket: #2854) (PR: #2330)
- Forms Developer defines custom logic for Device's search of Cases and Forms In some cases there are situations where the standard variables for searching do not cover all things we want searched, or there is a compound field we want to be searched. Adding a client/custom-search.js file allows the Forms Developer to hook into the map function used to generate the search index. (Ticket: #2852) (PR: #2740)
- Data Manager views list of Issues related to Case When viewing a Case on the server, the first screen when opened will now show a list of related Issues. (Ticket: #2723) (PR: #2573)
- Form Developer uses API to override Device User based access to Event Forms on a per Case Event basis Currently we can configure in a Case Definition the operation permissions on all instances of an Event Form. This change allows a Form Developer to write logic that would control those permissions on a per Event Form basis by setting the same
permissions
property on the Event Form itself. (Ticket: #2624) (PR: #2660) - Form Developer configures Devices to skip optimization of database views not in use on Device. Some projects relying heavily on a custom app will find they do not use all of the standard Tangerine database views, thus they can be skipped during the data optimization phase after a sync. In
app-config.json
, you can add a newdoNotOptimize
property with a value as an array of views to skip. To discover what views your app is indexing, see the console logs from a device during the optimization phase. You may discover some views you can add todoNotOptimize
to speed up that optmization process. (Commit: https://github.com/Tangerine-Community/Tangerine/commit/4b8864470c1cad98e43152dd6bb3c91ee3e576a6) - System Administrator batch imports all forms from a Tangerine v2 group into a Tangerine v3 group Tangerine v3 now has a script that will import all v2 group forms into a v3 group without having to do each form individually. (Ticket: #2857) (PR: #2584)
Fixes
- Issue created programatically in on-submit says we must rebase but no button to rebase #2785 Cases that have used the
T.case.createIssue()
API in forms to create Issues on the current form have recently found the resulting issues are broken. This is due to a change in when the Form Response is associated with the case (later than when T.case.createIssue() is called in a form's on-submit). To remedy this, we've added a newT.case.queueIssueForCreation("Some label", "Some comment")
API. If you are using T.case.createIssue(), immediately upgrade and replace its usage with T.case.queueIssueForCreation(). (Ticket: #2785) (Example: https://github.com/Tangerine-Community/Tangerine/blob/next/content-sets/case-module/client/test-issues-created-programatically-on-client/form.html#L5) - Using a simpler reverse sort for device status (PR: #2775)
- Increase likelihood that migration of data to mysql will recover where it left off if server restarts. (PR: #2773)
- From Case Definitions, the
onCaseOpen
andonCaseClose
now also run in the server context. (PR: #2696) - "openEvent is not defined" when accessing a case in Editor (Ticket: #2800)
- Synclog date/time header is incorrect and sort is broken (Ticket: #2762)
- Synchronization UX Improvements - remove error state after retries when retry is successful (Ticket: #2808) (PR: #2826)
- Fix missing 'form' from id for v2 import_ (Ticket: #2856) (PR: #2726)
- Minor tweak to tangerine-preview README (PR: #2735)
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.19.0
./start.sh v3.19.0
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.18.3
# Perform additional upgrades.
docker exec -it tangerine bash
push-all-groups-views
update-down-sync-doc-count-by-location-id-index '*'
# This will index all database views in all groups. It may take many hours if
# the project has a lot of data.
wedge pre-warm-views --target $T_COUCHDB_ENDPOINT
Fixes
- Backport: Make status translateable on Tangerine Teach Task Report. #3089
- Backport: When editing Timed Grids on Forms, "Capture at Time" and "Duration" are compared as strings leading to unexpected validation scenarios. #3130
Fixes
- Backport: Restrict access to events by permissions when query by date on schedule view.
- Fix issue where logging in as a different user shows the previously logged in users data (Multiuser/Tablet sharing #2060)
- Add additional translateables to Tangerine Teach components (Translatable feedback status text: #2693) (Missing translatable strings: #2987)
- Allow class title to be anywhere on form #2994
- Add support for skipping indexes in form's cycle sequences.
- Fix radio button scoring in Teach by only adding the final value of max to the totalMax variable. #2947
- On Tangerine Teach reports, fix calculating of "percentile", AKA percent correct grouping. #2941
Fixes
- Back-ported some fixes to the backup and restore feature from the v3.19.1 branch.
- Fixed issue with Teach where third subtask would not open correctly.
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.18.7
./start.sh v3.18.7
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.18.6
Updates
- Updated tangy-form lib from 4.25.11 to 4.25.14 (Changelog), which provides:
- A fix for photo-capture so that it de-activates the camera when going to the next page or leaving a form.
- Implemented a new 'before-submit' event to tangy-form in order to listen to events before the 'submit' event is dispatched.
- A fix for User defined Cycle Sequences.
Fixes
- Remove incorrect exception classes for changes processing #2883 PR: #2883 Issue: #2882
- Added backup and restore feature for Tangerine databases using device encryption. Increase the appConfig.json parameter
dbBackupSplitNumberFiles
(default: 200) to speed up the backup/restore process if your database is large. You may also change that parameter in the Export Backup user interface. Updated docs: Restoring from a Backup PR: #2910
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.18.6
./start.sh v3.18.6
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.18.5
Fixes
- Server admin can configure regex-based password policy for Editor. Instructions in the PR: #2858 Issue: #2844
Fixes
- Backported a fix from the v3.19.0 branch for "Save the lastSequence number after each change is processed in the tangerine-mysql connector" Issue #2772
- Address crashes when importing data using the mysql module #2820
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.18.4
./start.sh v3.18.4
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.18.3
Fixes
- Important If your site uses csvReplacementCharacters to support search and replace configuration for CSV output, which was released v3.18.2, you must change the configuration string. See issue #2804 for information about the new schema.
- Backported a fix from the v3.19.0 branch for "Issue created programmatically in on-submit says we must rebase but no button to rebase #2785"
- Description: Cases that have used the
T.case.createIssue()
API in forms to create Issues on the current form have recently found the resulting issues are broken. This is due to a change in when the Form Response is associated with the case (later than when T.case.createIssue() is called in a form's on-submit). To remedy this, we've added a newT.case.queueIssueForCreation("Some label", "Some comment")
API. If you are using T.case.createIssue(), immediately upgrade and replace its usage with T.case.queueIssueForCreation(). - Ticket: #2785
- Example: https://github.com/Tangerine-Community/Tangerine/blob/next/content-sets/case-module/client/test-issues-created-programatically-on-client/form.html#L5
- Description: Cases that have used the
- Feature: Editor User downloads CSVs for multiple forms as a set Issue: #2768 PR:#2777
- Feature: Remove configurable characters from CSV output #2787.
- Documentation updates for backup/restore and fixes to image paths
- Fix default user profile so it doesn't assume use of roles or location
- Disabled "Print form backup" in Editor
- Improvements to display of "Print metadata" in Editor
- Update and fix for Cycle Sequences to enable numbering of sequences starting from 1. PR's: #231, #269
- Bump tangy-form to 4.25.11 and tangy-form-editor to 7.8.8.
- Fix backup when using os encryption and sync protocol 2 and cordova. (PR: #2767)
- Fix creating of new Device Users when using Sync Protocol 2. (PR: #2769)
- Fix default user profile form for Sync Protocol 1 users. We should not assume they are using roles or location.
- Enable configurable image capture in client #2695
- Serve base64 image data as image files #2706 PR: #2725
- Add Cycle sequences 1603
- Sort by lastModified in the client case search #2692
- Enable assigning multiple roles in forCaseRole in the eventFormDefinition #2694
- Enable defining custom functions or valid JavaScript expressions that will be called when an event is opened and when an event is closed. On open and close events for case and case-events: #2696
- Teach-specific strings in Russian for default content-set #2676
- Uploads status such as app version when updating the app #2756
- Initialize
git
in content repository before runninggit
commands #2667 - Only show the links to historical releases when T_ARCHIVE_PWAS_TO_DISK and T_ARCHIVE_APKS_TO_DISK in the config.sh are set to true #2608
- Fix form breaking when form name has single quote #2489
- Add print options to archived forms #1987
- Fix Grid having negative values #2294
- Fix to allow for running on m1 Macs #2631 #2631 Thanks @fmoko and @evansdianga!
- For projects using the Case Reporting screen but don't have anything in reports.js but do have markup in reports.html, avoid crash due to empty file #2657
- V2 import script fixes #2675
- Allow HTML markup in option labels 2453
- Reset grid values when grid is restarted #
- Mark last attempted automatically when grid is auto-stopped #2467
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.18.0
./start.sh v3.18.0
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.17.11
- Feature: Remove configurable characters from CSV output #2787.
This release also has bugfixes specific to the Class module, which now uses updated API's for form rendering.
- Feature for Class/Teach: Archive or enable a class. Issue: #2580
- Bugfix for Class/Teach: Teach loses data and blocks app if Class form is not submited #2783
- Bugfix for Class/Teach: App should return user to previous Curriculum when resuming app. Issue: #2648
- Refactor Class to handle changes in tangy-form; Bug in CSV rendering for Tangerine Teach. Issue: #2635
-
Added support for custom update scripts for each group. Add either a before-custom-updates.js or after-custom-updates.js to the root of your content depending on when you wish the script to run. Script needs to return a Promise. See Issue 2741 for script example. PR: #2742
-
Add support for filtering PII variables on Case Participant data and Event Form data in Synapse caches. List the variable names in your group's content folder
reporting-config.json
. For example:{ "pii": ["foo_variable"] }
. This config was previously stored in the groups database. -
Fixed bug that prevented rewind sync from working.
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.17.11
./start.sh v3.17.11
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.17.10
- Skip optimizing sync-queue, sync-conflicts, and tangy-form views after Sync Protocol 2 sync completes.
- Using
T.case.load()
in a form? This release fixes a bug where EventForm.formResponseId would be not set when submitting forms in cases where a form has loaded a different case and then the save case back again thus detaching the memory reference being previously set. - Remove trailing whitespace from variables for mysql outputs to avoid illegal column names.
- Add response-variable-value API with support for returning jpeg and png base64 values as files.
- Refactor TANGY-SIGNATURE and TANGY-PHOTO-CAPTURE output in CSVs to be URLs of the image files.
- Creates work-around for deployments that are unable to use custom-scripts. Issue #2711 PR #2712
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.17.10
./start.sh v3.17.10
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.17.9
- Prevent failed calls to
T.case.save()
in forms by avoiding any saves to a case when a form is active. PR, Issue - Enable assigning multiple roles in forCaseRole in the eventDefinition #2694 - Cherry-picked commit 3e4938a0a80c57 only.
- Enable defining custom functions or valid JavaScript expressions that will be called when an event is opened and when an event is closed. On open and close events for case and case-events: #2702
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.17.9
./start.sh v3.17.9
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.17.8
-
Fix use of initial batch size #2685
-
Created
generate-form-json
script that generates the form json for a group from its form.html file. Usage:docker exec tangerine generate-form-json group-uuid
The script loops through a group's forms.json and creates a form.json file in each form directory, next to its forms.html. Before using this script, runnpm install
. Issue: #2686 -
The synapse module now uses the json from
generate-form-json
to exclude PII. Also, the synapse module takes substitution and pii fields to accommodate schema changes and pii fields not identified in forms. PR: #2697Place these properties in the groups Couchdb:
"substitutions": {
"mnh_screening_and_enrollment_v2": "mnh01_screening_and_enrollment"
},
"pii": [
"firstname",
"middlename",
"surname",
"mother_dob"
]
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.17.8
./start.sh v3.17.8
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.17.7
- fix CSV generation issue: #2681
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.17.7
./start.sh v3.17.7
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.17.6
- fix issue w/ empty replicationStatus?.userAgent
- Switched from just-snake-case to @queso/snake-case - better Typescript compatability.
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.17.6
./start.sh v3.17.6
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.17.5
- Bumps tangy-form to 4.23.3, editor to 4.23.3. Issue: 2620
- Update date carousel to 5.2.1 with fix for clicking the today button. PR: #2677
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.17.5
./start.sh v3.17.5
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.17.4
-
Enables support for reducing the number of documents processed in the changed feed when syncing using the 'changes_batch_size' property in app-config.json. This new setting will help sites that experience crashes when syncing or indexing documents. Using this setting will slow sync times. Default is 50. During recent tests, the following settings have been successful in syncing a location with over 12,700 docs that was experiencing crashes:
- "batchSize": 50
- "writeBatchSize": 50
- "changes_batch_size": 20
Please do note that these particular settings do make sync very slow - especially for initial device sync.
-
Removed selector from push sync - was causing a crash on large databases. Using a filter instead in the push syncOptions to exclude '_design' docs from being pushed from the client.
-
Adds "Encryption Level" column to the Devices Listing, which shows if the device is running 'OS' encryption or 'in-app' encryption.
- 'OS' encryption: Encryption provided by the device operating system; typically this is File-based (Android 10) or Full-disk encryption (Android 5 - 9).
- 'in-app' encryption: Database is encrypted by Tangerine.
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.17.4
./start.sh v3.17.4
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.17.3
- Automatically retry after failed sync. (#2663)
- Do not associate form response with Event Form if only opened and no data entered.
- Fix issue causing Android Tablets using OS level encryption to spontaneously start using in-app encryption.
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.17.3
./start.sh v3.17.3
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.17.2
- Add support for depending on Android Disk encryption as opposed to App Level encryption. Set
turnOffAppLevelEncryption
totrue
inclient/app-config.json
. Note that enabling this will not turn off App Level encryption for devices already installed, only new installations. - Fix race condition data conflict on EventFormComponent that is triggered when opening and submitting a form quickly. Prevent data entry until Case is loaded to avoid conflicting Case save of a fast submit.
- Fix bug causing Device ID to not show up on About page on Devices.
- When syncing, push before pull to avoid having to analyze changes pulled down for push.
- Fix download links for archived APKs on Live channel.
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.17.2
./start.sh v3.17.2
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.17.1
- Add support for Form Versions when it hasn't been used before by defaulting the first entry in formVersions when a form version isn't defined on a Form Response.
- Fix issue causing Device Admin user log in to fail.
- Restore missing
sectionDisable
function in skip logic for forms.
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Ensure git is initialized in all group folders.
docker start couchdb
docker start tangerine
# Fetch the updates.
git fetch origin
git checkout v3.17.1
./start.sh v3.17.1
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.17.0
New Features and Fixes
- Device User Role access to Case Events and Event Forms #2598
- Deactivate Case Participant API #2594
- Data Collector with a single click opens all pages of a completed form response #2596
skip()
andunskip()
functions are now available intangy-form
levelon-change
logic for skipping and unskipping sections, not inputs.- Fix print form as table for some forms. (#2568)
- Update the group icon on server #2355
- Add window.uuid() API #2595
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Ensure git is initialized in all group folders.
docker start couchdb
docker start tangerine
# Fetch the updates.
git fetch origin
git checkout v3.17.0
./start.sh v3.17.0
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.16.4
Fixes
- T_ARCHIVE_APKS_TO_DISK and/or T_ARCHIVE_PWAS_TO_DISK setting have no effect. Issue: #2608
- Bug in CSV rendering for Tangerine Teach. Issue: #2635 new setting outputDisabledFieldsToCSV in groups doc
Developer Interest
There is now a content set for developing projects with the Class module enabled in content-sets/teach. Sets the following properties in app-config.json:
- "homeUrl": "dashboard"
- "uploadUnlockedFormReponses": true
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Ensure git is initialized in all group folders.
docker start couchdb
docker start tangerine
docker exec tangerine sh -c "cd /tangerine/groups && ls -q | xargs -i sh -c 'cd {} && git init && cd ..'"
# Fetch the updates.
git fetch origin
git checkout v3.16.5
# If you are enabling the new mysql module, follow the instructions in `docs/system-administrator/mysql-module.md` to update the config.sh file (steps 1 through 3)
# If you do not wish APK and PWA archives to be saved, set T_ARCHIVE_APKS_TO_DISK and/or T_ARCHIVE_PWAS_TO_DISK to false.
# Then return here before starting tangerine
# Now you are ready to start the server.
./start.sh v3.16.5
docker exec tangerine push-all-groups-views
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.16.4
# If setting up mysql return to step 5 in `docs/system-administrator/mysql-module.md`
New Features
-
Warning about data sync: Any site that upgraded to v3.16.2 is at risk of having records stay on the tablet unless they upgrade to v3.16.3 or v3.16.4. After upgrading to v3.16.4, go to the Online Sync feature and click the new 'Advanced Options' panel. There are two new options for sync - Comparison Sync and Rewind Sync. Comparison sync enables the Sync feature to compare all document id's on the local device with the server and uploads any missing documents. Rewind Sync resets the sync "placeholder" to the beginning, ensuring that all docs are synced. It doesn't actually re-upload all docs; it instead checks that all docs have been uploaded. It is more thorough than Comparison Sync. Both of the features are for special cases and should not be used routinely. Issue: #2623
There are two settings that can be configured for Comparison sync:
- compareLimit (default: 150) - Document id's must be collected from both the tablet and server in order to calculate what documents need to be sync'd to the server. This setting limits the number of docs queried in each batch.
- batchSize (default: 200) - Number of docs per batch when pushing documents to the server. This same configuration setting is used for normal sync, so please take care when making changes to it.
This new "Comparison" option is very new and may have rough edges. In our experience, if the app crashes while using it, re-open the app and try again; chances are that it will work. If it consistently fails, lower the value for app-config.json's compareLimit property.
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Ensure git is initialized in all group folders.
docker start couchdb
docker start tangerine
docker exec tangerine sh -c "cd /tangerine/groups && ls -q | xargs -i sh -c 'cd {} && git init && cd ..'"
# Fetch the updates.
git fetch origin
git checkout v3.16.4
# If you are enabling the new mysql module, follow the instructions in `docs/system-administrator/mysql-module.md` to update the config.sh file (steps 1 through 3)
# If you do not wish APK and PWA archives to be saved, set T_ARCHIVE_APKS_TO_DISK and/or T_ARCHIVE_PWAS_TO_DISK to false.
# Then return here before starting tangerine
# Now you are ready to start the server.
./start.sh v3.16.3
docker exec tangerine push-all-groups-views
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.16.3
# If setting up mysql return to step 5 in `docs/system-administrator/mysql-module.md`
New Features
-
Warning about data sync: Any site that upgraded to v3.16.2 is at risk of having records stay on the tablet unless they upgrade to v3.16.3. After upgrading to v3.16.3, run the new "Push all docs to the server" feature available from the Admin Configuration menu item. This feature resets push sync to the beginning, ensuring that all docs are pushed. It doesn't actually re-upload all docs; it instead checks that all docs have been uploaded.
-
Added "Push all docs to the server" feature to the Admin Configuration menu item.
-
Added Operating System and Browser Version to Device listing.
Fixes
- Data collected after first registering and after updates fails to upload. Issue: #2623
Server upgrade instructions
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Ensure git is initialized in all group folders.
docker start couchdb
docker start tangerine
docker exec tangerine sh -c "cd /tangerine/groups && ls -q | xargs -i sh -c 'cd {} && git init && cd ..'"
# Fetch the updates.
git fetch origin
git checkout v3.16.3
# If you are enabling the new mysql module, follow the instructions in `docs/system-administrator/mysql-module.md` to update the config.sh file (steps 1 through 3)
# If you do not wish APK and PWA archives to be saved, set T_ARCHIVE_APKS_TO_DISK and/or T_ARCHIVE_PWAS_TO_DISK to false.
# Then return here before starting tangerine
# Now you are ready to start the server.
./start.sh v3.16.3
docker exec tangerine push-all-groups-views
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.16.2
# If setting up mysql return to step 5 in `docs/system-administrator/mysql-module.md`
New Features
- Enables filtering of Case Event Schedule by Device's Assigned Location PR: #2591
Fixes
- Enables editing of device description. Commit: #2613
Server upgrade instructions
If you want to enable filtered Case Event Schedule by Device's Assigned Location, add filterCaseEventScheduleByDeviceAssignedLocation
to your groups' app-config.json
set to a value of true
.
Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Ensure git is initialized in all group folders.
docker start couchdb
docker start tangerine
docker exec tangerine sh -c "cd /tangerine/groups && ls -q | xargs -i sh -c 'cd {} && git init && cd ..'"
# Fetch the updates.
git fetch origin
git checkout v3.16.2
# If you are enabling the new mysql module, follow the instructions in `docs/system-administrator/mysql-module.md` to update the config.sh file (steps 1 through 3)
# If you do not wish APK and PWA archives to be saved, set T_ARCHIVE_APKS_TO_DISK and/or T_ARCHIVE_PWAS_TO_DISK to false.
# Then return here before starting tangerine
# Now you are ready to start the server.
./start.sh v3.16.2
docker exec tangerine push-all-groups-views
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.16.1
# If setting up mysql return to step 5 in `docs/system-administrator/mysql-module.md`
New Features
- Improves sync stats and add "Export Device List" feature PR: #2610
Fixes
- Fixes Editor form creation issue #2605 and form copy issue #2604
- Adds check for calculateLocalDocsForLocation before running update to index an index it depends upon.
- Update tangy-form to 4.21.3, tangy-form-editor to 7.6.5 to fix dynamically set level tangy location not resuming correctly #202
Server upgrade instructions Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Ensure git is initialized in all group folders.
docker start couchdb
docker start tangerine
docker exec tangerine sh -c "cd /tangerine/groups && ls -q | xargs -i sh -c 'cd {} && git init && cd ..'"
# Fetch the updates.
git fetch origin
git checkout v3.16.1
# If you are enabling the new mysql module, follow the instructions in `docs/system-administrator/mysql-module.md` to update the config.sh file (steps 1 through 3)
# If you do not wish APK and PWA archives to be saved, set T_ARCHIVE_APKS_TO_DISK and/or T_ARCHIVE_PWAS_TO_DISK to false.
# Then return here before starting tangerine
# Now you are ready to start the server.
./start.sh v3.16.1
docker exec tangerine push-all-groups-views
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.16.0
# If setting up mysql return to step 5 in `docs/system-administrator/mysql-module.md`
New Features
- Warning about data sync: If you have implementations that have multiple tablets syncing from the same location, some docs may not be on all tablets due to issues with earlier versions of sync. This release resolves that particular issue and provides ways to ensure that all tablets share the same data. We have implemented several ways to rectify and understand potential data inconsistencies across tablets in the field:
-
After updating the server to 3.16.0 and after updating and syncing the clients, the Device dashboard will now display the number of docs on each tablet ("All Docs on Tablet") and the number of docs according to the device's Location configuration ("Form Responses on Tablet for Location").
- Depending on the Configure/Sync settings, the "All Docs on Tablet" count may be close, but not exactly the same, since not all forms may be synced to the tablets.
- The "Form Responses on Tablet for Location" count should be the same for all tablets that share the same location configuration. Please note that "Form Responses on Tablet for Location" count needs to be activated by adding
"calculateLocalDocsForLocation": true
to app-config.json; also note that it has not been widely tested and may be unstable. (If you activate this feature, you may also add"findSelectorLimit"
to modify how many batches are used to calculate this value. Default is 200. Lower is safer but slower.)
These data points may help in identifying data inconsistencies. Remember - only after updating and syncing the tablets, will these new doc counts be populated with data in the Devices listing. Making a note of the document counts per tablet will help establish a baseline.
-
Next step would be to run the new "Force Full Sync" feature, which is implemented in two ways:
- If you add the new
"forceFullSync" : true
setting in the group's app-config.json, the client will perform a full sync upon the next update. Since this takes time and Internet bandwidth, you may wish to notify users before enabling this feature. - When logging in as "admin" user on the client tablet, a new menu item called "Admin Configuration" will be visible below the "Settings" item. This new item enables manual operation of the "Force Full Sync" feature. It is labeled "Pull all docs from the server" in the user interface.
- If you add the new
-
You may adjust the settings for how many documents "Force Full Sync" downloads at a time by adjusting the
initialBatchSize
property in app-config.json. The default is 1000 documents per batch. This setting is also used when performing the initial load of documents on a tablet.
-
- Tangerine Release Archives: Every Tangerine APK or PWA release is saved and tagged. If your site is configured for archives (which is the default), you may download previous Android releases. PR: #2567
- A "Description" field has been added to the Devices listing to faciliate identification of devices or groups of devices.
- Beta Release Mysql module: Data sync'd to Tangerine can be output to a MySQL database. Warning: This should not yet be deployed on a production server; the code for this feature is still in development. We recommend creating a separate server for the Tangerine/MySQL installation and replicate data from the production server to the Tangerine server that would provide the MySQL service.
Docs:
docs/system-administrator/mysql-module.md
PR: #2531 - Devices listing offers more information about the sync process, including version, errors, and sync duration.
Fixes
- Changes to the sync code should improve sync stability and speed. #2592 You may configure certain sync properties:
- initialBatchSize = (default: 1000) Number of documents downloaded in the first sync when setting up a device.
- batchSize (default: 200) - Number of documents downloaded upon each subsequent sync.
- writeBatchSize = (default: 50) - Number of documents written to the tablet during each sync batch.
- Updated tangy-form-editor to v7.6.4, which improves functionality of
duplicate entire section
. PR: #173 - Updates the Schedule View to use date-carousel 5.2.0 which provides unix timestamps instead of date strings. #2589
- Upgrade tangy-form to fix issue causing
on-open
of first items to not run when proposing changes in an Issue. - Deactivate App.checkStorageUsage if using Sync Protocol 2. This was not compatible and should not run.
- Allow projects to disable GPS warming to save on battery with
disableGpsWarming
inapp-config.json
. - Add missing import of
editor/custom-scripts.js
when using editor so Data Dashboards can have imported JS files.
Server upgrade instructions Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Ensure git is initialized in all group folders.
docker start couchdb
docker start tangerine
docker exec tangerine sh -c "cd /tangerine/groups && ls -q | xargs -i sh -c 'cd {} && git init && cd ..'"
# Fetch the updates.
git fetch origin
git checkout v3.16.0
# If you are enabling the new mysql module, follow the instructions in `docs/system-administrator/mysql-module.md` to update the config.sh file (steps 1 through 3)
# If you do not wish APK and PWA archives to be saved, set T_ARCHIVE_APKS_TO_DISK and/or T_ARCHIVE_PWAS_TO_DISK to false.
# Then return here before starting tangerine
# Now you are ready to start the server.
./start.sh v3.16.0
docker exec tangerine push-all-groups-views
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.15.6
# If setting up mysql return to step 5 in `docs/system-administrator/mysql-module.md`
- New Sync code reduces the number of network requests by disabling server checkpoints. It also supports three new app-config.json options to configure sync parameters that adjust data download size, how much data is written to the local database each batch, and initial data download:
- batchSize: Number of docs to pull from the server per batch. Increasing this setting will decrease the number of network requests to the server when doing a sync pull. Default: 200
- writeBatchSize: How many docs to write to the database at a time. If the database crashes, decreasing this option could be helpful. Default: 50
- useCachedDbDumps: Enables caching of the group database to a file for a single download to the client upon initial device setup. This is an experimental feature therefore it is not enabled by default. (Some server code is also currently disabled.) Those files are stored at data/groups/groupName/client/dbDumpFiles. At this point, you must delete the dbDumpFiles if you wish to update the data in the initial device load. 2560
- Disable the v3.15.0 update from groups that use sync-protocol 1.
- Added
2021
to the report year. - Added simple network statistics to the device replicationStatus, which is posted after every sync.
Server upgrade instructions Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.15.8
# Now you are ready to start the server.
./start.sh v3.15.8
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.15.7
New Features and Fixes
- Fixes a bug in the CSV generation code that caused sections of rows in the CSV to output improperly. PR:#2558
- Adds a server config that allows the user to control the string used for variables that are
undefined
:T_REPORTING_MARK_UNDEFINED_WITH="UNDEFINED"
- The default value of the new config file is set to "ORIGINAL_VALUE" so existing Tangerine instances will not be effected.
Server upgrade instructions Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
Please add the below line into your config.sh to preserve current behavior (as a workaround for #2564)
T_REPORTING_MARK_UNDEFINED_WITH=""
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.15.7
# Now you are ready to start the server.
./start.sh v3.15.7
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.15.6
New Features and Fixes
- New 'wakelock' feature for sync: When using the sync feature, the screen should not go to sleep or dim, enabling the sync process to proceed. This is especially useful during long sync processes. When you navigate to another page once Sync is complete, the wakeLock feature is disabled.
- The Devices listing has a new option, "View Sync Log", which enables viewing status of the most recent replication, when available.
- Added error messages when internet access drops during a sync. #2540
- Batch size for sync is configurable via
pullSyncOptions
andpushSyncOptions
variable in a group's app-config.json. Default is 200. If the value is set too high, the application will crash.
Server upgrade instructions Reminder: Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.15.6
# Now you are ready to start the server.
./start.sh v3.15.6
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.15.5
Fixes
- In CSV output, if a section on a form is opened and then the later skipped, inputs on that skipped section will appear in CSV output as skipped. However, if the section is never opened, the inputs would show up in the CSV as blank values. This fix ensures that these remaining inputs are marked as skipped in CSV output.
- Fix sync from breaking when syncing with a group with no data yet.
- Improve messaging during sync by removing floating change counts and showing the total number of docs in the database after sync.
Server upgrade instructions Consider using the Tangerine Upgrade Checklist for making sure you test the upgrade safely.
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.15.5
# Now you are ready to start the server.
./start.sh v3.15.5
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.15.4
Fixes
- Sync: Sites with large datasets were crashing; therefore, we implemented a new sync function that syncs batches of documents to the server. PR: #2532
Server upgrade instructions
# Fetch the updates.
cd tangerine
git fetch origin
git checkout v3.15.4
# Now you are ready to start the server.
./start.sh v3.15.4
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.15.3
Fixes
- After a large sync in sync protocol 2, improve overall app performance by indexing database queries. Because this may cause a long sync for projects not using this, you can set
indexViewsOnlyOnFirstSync
inapp-config.json
totrue
if you want to allow existing tables to avoid this long sync to catch up on views. - Add missing
custom-scripts.js
andcustom-styles.css
files to Editor app. We also addeditor
andclient
ID's to the body tag of the two app respectively. - Reduce database merge conflicts by preventing form responses from saving after completed. Prior to this version, on two tablets (or on a tablet and the server) if you opened the same form response and opened an item to inspect, it would cause a save on both tablets resulting in an unnesessary merge conflict.
- New
T.case.getCaseHistory(caseId)
function for getting the history of save for a Case. Returns an array of JSON patches in RFC6902 format. Open a Case and runawait T.case.getCaseHistory()
in the console and it will pick up on the context. - New
T.case.getEventFormHistory(caseId, caseEventId, eventFormId)
function for getting the history of save for a form response in a Case. Returns an array of JSON patches in RFC6902 format. Open a Case, a Case Event, then an Event Form and runawait T.case.getEventFormHistory()
in the console and it will pick up on the context. - New opt-in
app-config.json
settingattachHistoryToDocs
for enabling upload all history of Case and Event Form edits on a Tablet up to the Server. Without this setting on, the server only sees the history starting from time of upload. Note this has an impact on upload size of at least doubling it when turned on.
Important configuration notice
- Set
indexViewsOnlyOnFirstSync
inapp-config.json
totrue
if you want to allow existing tables to avoid this long sync to catch up on views.
Server upgrade instructions
# Fetch the updates.
cd tangerine
git fetch origin
git checkout v3.15.3
# Now you are ready to start the server.
./start.sh v3.15.3
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.15.2
Fixes
- Rshiny module: Replaces hard-coded underscore separator with the configurable
sep
variable. - Error when processing CSV's: 2517
Important configuration notice
The v3.15.0 release included an update to the Editor Search feature #2416 that requires adding a searchSettings
property to forms.json. In addition to running the upgrade script for v3.15.0; you must also make sure that all forms in a group's forms.json have searchSettings
configured, especially the shouldIndex
property. Examples are in the Case Module README "Configuring Text Search" section.
Server upgrade instructions
cd tangerine
# Check the size of the data folder.
du -sh data
# Check disk for free space. Ensure there is at least 10GB + size of the data folder amount of free space in order to perform the upgrade.
df -h
# Turn off tangerine and database.
docker stop tangerine couchdb
# Create a backup of the data folder.
cp -r data ../data-backup-$(date "+%F-%T")
# Fetch the updates.
git fetch origin
git checkout v3.15.2
# Now you are ready to start the server.
./start.sh v3.15.2
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.15.1
Fixes
- Prevent opening of Event Forms on Editor when there is no corresponding Form Response available.
- Fix Issue type detection when deciding what is going to be in the 'current' tab.
- Update CSV output for signatures to be 'signature captured' and ''.
- Fix Issues view causing Issue search result to appear once per event such as comment or proposal.
- Integrate fixes in v3.14.6 including
T.case.isIssueContext()
API, and better API partity between being in an Event Form in a Case and being in an Event Form in an Issue.
Server upgrade instructions
# Fetch the updates.
cd tangerine
git fetch origin
git checkout v3.15.1
# Now you are ready to start the server.
./start.sh v3.15.1
docker exec -it tangerine push-all-groups-views
docker exec -it tangerine reporting-cache-clear
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.15.0
-
New Features and fixes
- Editor User searches Cases by keyword #2416 - This feature enables searching by any of the variables assigned in searchSettings/variablesToIndex in forms.json.
- Transfer Participant between Cases #2419. Find Participant UI: #2439.
- Update to Content Set 2.1 adds a package.json and build step to pin lib versions and add a build step for custom-scripts.
- Added error message to Updates error alert. ccc1864
- New "Release Online Survey" menu on Server allows you to release a single form for data collection online. Note the original "Deploy -> Release" menu item has been moved to "Deploy -> Release Offline App".
- Fixed issue where "Tangy Gate" form element could be added in Editor but would not appear on Tablets.
- Support for new "" element that brings a Partial Date style form element with support for the Ethiopian Calendar.
- If using Sync Protocol 2, the first sync when registering a Device is now faster in cases where there is a lot of data already collected. Also the blank User Profile created for the Admin user on a device is no longer uploaded resulting in less noise in the Device Users list.
-
Important deprecation notice
- The groupName property, once used in app-config.json, is no longer supported in recent releases of Tangerine. The groupId property is used in its place. Groups that use groupName will not be able to sync; they must migrate to groupId. This issue affects groups using sync-protocol-1. #2447
- When form responses are unlocked in a Data Issue, the
on-submit
hook no longer runs. If you need logic to run, use the newon-resubmit
hook. - If using Sync Protocol 2, the "Auto Merge" feature that tries to fix database conflicts is now off by default and database conflicts will not be logged as Issues. If you would like to keep it on, set
"autoMergeConflicts": true
in your group'sclient/app-config.json
file. However be aware that turning this on will result in inconsistent results (#2484). Monitoring for database conflicts can now be done by monitoring thesyncConflicts
view via CouchDB Fauxton.
Server upgrade instructions:
# Fetch the updates.
cd tangerine
git fetch origin
git checkout v3.15.0
# Now you are ready to start the server.
./start.sh v3.15.0
# Update the views - there are new views for Searches and Participant Transfers.
docker exec -it tangerine reporting-cache-clear
docker exec -it tangerine /tangerine/server/src/upgrade/v3.15.0.js
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.14.6
Changes in v3.14.4 were abandoned, changes in v3.14.5 have been rolled into v3.15.0. The following are changes for v3.14.6.
- Improve first sync performance: On first sync, skip push but set the last push variable to whatever we left on after the first pull.
- Improve in-form API parity between context of a Case and context of an Issue proposal. Sets case context in more scenarious inside of Issue Form proposals.
- Prevent form crashes and unintentional logic by adding the new
T.case.isIssueContext()
API for detecting if in the Issue context in a form.
Server upgrade instructions:
# Fetch the updates.
cd tangerine
git fetch origin
git checkout v3.14.6
# Now you are ready to start the server.
./start.sh v3.14.6
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.14.3
- Bugfix
- Auto-merged conflicts overwrite "canonical" change made on Editor server #2441 - Prevents tablets from overwriting documents from Editor in special cases. After modifying the case record, add canonicalTimestamp to the document:
"canonicalTimestamp":1603854576785
- Auto-merged conflicts overwrite "canonical" change made on Editor server #2441 - Prevents tablets from overwriting documents from Editor in special cases. After modifying the case record, add canonicalTimestamp to the document:
- New Features and fixes for all Tangerine
- Upgrades in the Developers' Interest
- Removed webpack from the Docker image. Custom apps should build their apps using their own webpack; the APK service will no longer perform that task.
Server upgrade instructions:
# Fetch the updates.
cd tangerine
git fetch origin
git checkout v3.14.3
# Now you are ready to start the server.
./start.sh v3.14.3
# Update the views - there is a new view used for Issues.
docker exec -it tangerine push-all-groups-views
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.14.2
- Bugfix
- Fixes file path issue when bundling custom scripts in APK's.
Server upgrade instructions:
# Fetch the updates.
cd tangerine
git fetch origin
git checkout v3.14.2
# Now you are ready to start the server.
./start.sh v3.14.2
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.14.1
This is identical to v3.14.0 but was released to fix a problem with tangerine-preview v3.14.0 on npm.
- New Features and fixes for all Tangerine
- Usability Improvement for Device Registration: Added "Number of devices to generate" field to Device Registration. Submitting a single form to add multiple devices to a group should simplify large deployments. #2402
- Important bugfix for sync issue in poor network situations: If you currently have an active 3.13 deployment, run the 3.14 update on client to make sure all data is sync'd to the server. #2399
- Automatic conflict resolution on client: Basic support for automatic merges of conflicts in EventForms. #2272 Documentation for testing conflicts
- Form version support: Enables use of previous form versions for form display. #2365 Support for versioning is not yet implemented in the Editor; however, there is documentation on how to implement form versions manually.
- User Interface updates: The 4.19.0 tangy-form lib version features the following fixes:
- Setting packageName in app-config.json causes app to crash: The docker-tangerine-base-image update to 3.7.0 improves Android and Cordova lib dependencies, and the release-apk code now rebuilds the Android code whenever an APK is built. #2366
- New module for rshiny development: Adds option to csv module to change delimiter from '.' to '_'#2314
- Documentation Update: Re-organization of some documentation and addition of missing image files. #2401
- Upgrades in the Developers' Interest
- Important note for users of tangerine-preview There was a problem with v3.14.0 on npm; therefore, please use tangerine-preview v3.14.1.
- Fix: Issues on Editor always ask us to rebase #2376
- Fix: Issues screen will not load after upgrading from v3.10.0 to v3.13.0 #2378
- Fix: Issues go missing after upgrading to v3.13.0 from v3.12.x #2377
- Please be aware: this release was made in the release/v3.13.1-alt branch and to date has only been built as the v3.13.1-rc-2 image.
Server upgrade instructions:
# Fetch the updates.
cd tangerine
git fetch origin
git checkout v3.13.1
# Now you are ready to start the server.
./start.sh v3.13.1
# Run upgrade
docker exec -it tangerine /tangerine/server/src/upgrade/v3.13.1.js
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.13.0
- New Features and fixes for all Tangerine
- Download Location List as CSV: You can now download a location list as a CSV. If you prefer editing a Location List via something like Excel, this makes editing an existing location list easier, which can then be imported when done editing in Excel. Note: Advise careful use of this export feature until #2336 is fixed. #2107
- Duplicate a Section:When editing a form, you can now easily duplicate an entire section with the "duplicate section" button. #2109. Warning - this feature does not handle complex objects such as tangy checkbox groups well; be sure to check the code it generates. This issue will be addressed in the next 3.13 point release.
- Group Data Dashboard in Editor: "Dashboard" is now a menu item available in a Group under the Data menu. This link can be enabled by group role (disabled by default). When on the Dashboard page, it displays a customizable dashboard for that specific group. Customizing Dashboards currently requires HTML and Javascript knowledge but in the future we may build a configurator for Dashboards.
- More Menu Permissions in Editor:Add additional Editor permissions to completely cover menu level access in a group
- Automatic conflict resolution: After a sync pull on client, detects type of conflict and resolves it. View status of merges in the Issues feature. #1763
- Fix extending session in Editor - When prompted to extend session shows up session is not really extended. #2266
- New Features and Fixes for Case Module
- Client "Issues" feature: "Issues" previously could only be viewed using Editor. With this release, Issues can now be accessed from Client in a Case module enabled Group via the top level "Issues" tab. This tab can be disabled adding or modifying
"showIssues": false,
to app-config.json. Note that only issues created targeting the "CLIENT" context (See CaseService API documentation) will show up in the Client "Issues" tab. - Easier searching on Client: Previously on Client when searching for "Facility 8" you would need to type exactly "Facility 8". Now search is case insensitive and you may type "facility 8" to match against "Facility 8".
- T.case.setEventWindow API fix: Previously when setting an Event window, the end time for the window was mistakenly ignored and set to the start time. This is now fixed. #2304
- Client "Issues" feature: "Issues" previously could only be viewed using Editor. With this release, Issues can now be accessed from Client in a Case module enabled Group via the top level "Issues" tab. This tab can be disabled adding or modifying
- New Features for Sync Protocol 2 Module
- Export device sheets: When registering Devices, we now offer an option to print "Device Sheets". Device Sheets include the registration codes for a Device and also some human readable metadata. Each row can also be used as a label for each device that can be fastened to a device using affordable clear packing tape. #2269
- Restore Backup on Android Tablet: Backups can now be restored. Restore is an option when first opening a freshly installed APK. #2127
- Better support for working on the same Case on two devices: When working offline on the same Case on two Devices, after a sync, it may seem like the changes on one Tablet have gone missing for some time until the "database conflicts" are resolved using the CouchDB Futon interface on the server. Starting in v3.13.0 we'll start to employ algorithms for automatically merging to speed up the process of resolving these database conflicts.
- Notes for System Administrators
- After upgrade, you will no longer find group content directories in
./data/client/content/groups/
, they will be in./data/groups/
. Inside each group's directory you will also find they have been split into aclient
andeditor
directory. All previous content will now be in theclient
directory while you may place content for the Group's Data Dashboard in theeditor
folder.
- After upgrade, you will no longer find group content directories in
Server upgrade instructions:
This update changes the path to group content to /tangerine/groups/${groupId}/client
. If your group is managing content
via a Github/cron integration, you will need to change the path to content in its cron job. Change GROUP-UUID
to your
group id in the following command:
cd /home/ubuntu/tangerine/data/groups/GROUP-UUID/client && GIT_SSH_COMMAND='ssh -i /root/.ssh/arc-forms-dev' git pull origin master && git add . && git commit -m 'auto-commit' && GIT_SSH_COMMAND='ssh -i /root/.ssh/arc-forms-dev' git push origin master
The update:
# Fetch the updates.
cd tangerine
git fetch origin
git checkout v3.13.0
# Now you are ready to start the server.
./start.sh v3.13.0
# Run upgrade
docker exec -it tangerine /tangerine/server/src/upgrade/v3.13.0.js
# Add or modify `"showIssues": false,` to the group's app-config.json if you do not want to display the Issues tab in client.
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.12.0
- Fixed issue with black screen when moving from p2p tab to home
- Fixed issue with QR code boundary boxes in tangy-form #158. Bumped tangy-form v4.17.10 and tangy-form-editor to 7.2.5
- Fixed issue with mutually exclusive checkboxes in tangy-form #154. Bumped tangy-form v4.17.9 and tangy-form-editor to 7.2.3
- When saving edits to a form, "Show if" logic has been written as
tangy-if
logic in the HTML. Form now on it will be written asshow-if
logic for consistency. tangy-if
logic in has in the past in just showing/hiding an question on a form. It will now also reset the value if there is input and it is then hidden.- In v3.12.0,
caseService.getCurrentCaseEventId()
was incorrectly removed. It has been added back, and an additionalcaseService.getCurrentEventFormId()
function has been added for consistency. - Fix Android 10 compatibility issue with P2P Sync mechanism causing tablets to crash.
- Change behavior of
show-if
logic so that when a question hides, the value is reset. - Adjust behavior of how Event Forms are added: If
EventForm.autoPopulate
is left undefined and required is true, then the form should be added.
-
New Features for Case Module
- Data Collector finds Event Forms are automatically created on Case Event creation and after adding a Participant #2147 [Demo]
- Data Collector has found a non required form has become required #2233
- Demo Part 1: https://youtu.be/dnJk4LaGuQw
- Demo Part 2: https://youtu.be/I0JOZounZc4
- Data Collector finds Case Event is automatically marked as complete #2235 [Demo]
- Data Collector sees indicator on Event Form when corresponding Form Response has not been synced to a device #2232 [Demo]
- Data Collector views a dedicated page for a Participant's Event Forms for a specific Case Event #2236 [Demo]
- Data Collector is redirected to custom route after Event Form is submitted #2237 [Demo]
-
Fixes for Case Module
- Device User registering only sees user profiles they can associate with restricted by location the Device is assigned #2248
- When all optional and incomplete forms are removed (no required forms in the event) from an event on the client the + button is not shown to re-add any of them #2113
- Delete an incomplete form from a case does not refresh the screen #2114
-
Fixes for all of Tangerine
-
New features for Sync Protocol 2
- Restore encrypted backup on Device #2127
-
API Changes for Case Module
caseEvent.status
is nowcaseEvent.complete
which has a value oftrue
orfalse
as opposed to the status strings.caseService.startEventForm(...)
is nowcaseService.createEventForm(...)
.caseService.deleteEventFormInstance(...)
is nowcaseService.deleteEventForm(...)
.caseService.getCaseEventFormsData(...)
is nowcaseService.getEventFormData(...)
.caseService.setCaseEventFormsData(...)
is nowcaseService.setEventFormData(...)
.
Server upgrade instructions:
# Fetch the updates.
cd tangerine
git fetch origin
git checkout v3.12.0
# Now you are ready to start the server.
./start.sh v3.12.0
# Run upgrade
docker exec -it tangerine reporting-cache-clear
# Remove Tangerine's previous version Docker Image.
docker rmi tangerine/tangerine:v3.11.0
Note that after running the upgrade script, your reporting caches may take some time to finish rebuilding.
Android upgrade instructions: If you are upgrading an Android device that was installed with Tangerine v3.8.0 or greater, you will need to regenerate your APK and reinstall, otherwise you may use the over the air updater.
- New Features in all Tangerine
- New Features in Tangerine with Case Module enabled
- Developer notes
- Group permissions #2187
Server upgrade instructions:
# Fetch the updates.
cd tangerine
git fetch origin
git checkout v3.11.0
# Now you are ready to start the server.
./start.sh v3.11.0
# Run upgrade
docker exec -it tangerine /tangerine/server/src/upgrade/v3.11.0.js
Note that after running the upgrade script, your reporting caches may take some time to finish rebuilding.
Android upgrade instructions: If your groups are using Sync Protocol 2 module, an APK reinstall is required. Release the APK and reinstall on all Android Devices. If your groups are not using Sync Protocol 2, you may upgrade Android tablets over the air using the usual release process.
- New Features in all Tangerine
- Editor User updates own profile and/or password #2166 [demo]
- Editor User with appropriate permission manages site level permissions of users and edits details and password of user #2155 [demo]
- Editor User views question configuration by category (as opposed to long list) #2097 [demo]
- Server Admin creates group on command line with local or remote content set #2174
- New Features in Tangerine with Case Module enabled
- Tangerine User views form response in alternative templates #2176 [demo]
- Data Manager manages Data Issues #1982 [demo]
- Data Manager rebases proposed changes in Issue #2179 [demo]
- Data Manager creates Data Issue #2144 [demo]
- Data Collector causes Issue to be created due to use of API in the form #2145 [demo]
- Data Collector causes Issue to be created due to
discrepancy-if
logic in form #2171 [demo] - Synapse consumes structured outputs based on Case ER Diagram #2051
- New features in Tangerine with Sync Protocol 2 Enabled
- Improve two-way sync efficiency in PouchDB by using
doc_ids
filter as opposed to mango query #2040
- Improve two-way sync efficiency in PouchDB by using
- Developer notes
- Resolve problems with client compilation in Angular #2091
Upgrade instructions:
# Fetch the updates.
cd tangerine
git fetch origin
git checkout v3.10.0
# Now you are ready to start the server.
./start.sh v3.10.0
# Run upgrade
docker exec -it tangerine /tangerine/server/src/upgrade/v3.10.0.js
- Fixes
- Database views are missing when running
tangerine-preview
ornpm start
#2096 - Event Schedule day view duplicates day event and show it in previous day as well #2103
- According to date carousel, events appear off by one week #2094
- Event Schedule templates are failing #2085
- Reports form is not added to forms.json #2088
- Events appear off by one day in Schedule List #2101
- CouchDB port should be configurable in config.sh #2092
- When opening the schedule view the first page is missing the header dates #2082
- Data Collector unable to open an Event from the Event Schedule #2102
- When editing a radio button options in editor, options should be in one column, not two #2090
- Database views are missing when running
- Features
- Fixes
- Fix additional memory leaks in Case module causing tablets to slow down. PR
- Make
getValue()
function in Event Form List Item related templates less likely to crash. change - Fixed incompatibilities with 2-way sync and P2P Sync.
- Fixed issue causing tablets to crash when syncing with a database with tens of thousands of records.
- Developer notes
- Editor and Clients upgraded to Angular 8.
- Changes
- Due to current limitations of two way sync, two changes have been made to the Device form in Tangerine Editor. First, changing a Device's assigned location and sync settings after the Device record has been claimed will no longer be allowed. Second, devices will now always be required to be assigned to the last level in your location hierarchy.
Upgrade instructions:
When you run the upgrade script, if you are using sync protocol 2 and have enabled, forms configured for 2 way sync will now be configured to use CouchDB sync to push documents up as opposed to "custom sync".
# Fetch the updates.
cd tangerine
git fetch origin
git checkout v3.9.0
# If you did not upgrade your config.sh in v3.8.1, migrate it now.
# Move custom variables from config.sh_backup to config.sh. Note that T_ADMIN and T_PASS are no longer needed.
mv config.sh config.sh_backup
cp config.defaults.sh config.sh
# To edit both files in vim you would run...
vim -O config.sh config.sh_backup
# Now you are ready to start the server.
./start.sh v3.9.0
# Run upgrade
docker exec -it tangerine /tangerine/server/src/upgrade/v3.9.0.js
- Client app performance improvements
- Improved caching of files. We are caching important configuration files for faster page loads (app-config.json, forms.json, location-list.json) and the Roboto font and have reduced redundant rendering calls. 1991
- Loading spinner when opening an Event Form in a Case. #1992
- Fixed a memory leak when viewing a Case which was causing tablets to crash if spending too much time on a Case screen. #2000
- Radiobuttons now load faster on forms.
- Editor fixes
- Developer notes
- We focused on issues with slow performance on tablets when viewing forms. We are caching important configuration files (app-config.json, forms.json, location-list.json) and the Roboto font and have reduced redundant rendering calls. More information in the Globals doc.
- Server Admin notes
- We cleaned up config variables in
config.sh
, deprecatedT_ADMIN
andT_PASS
#1986 - New
generate-cases
command for load testing a large number of Cases based on your custom content in a group. #1993 - New
reset-all-devices
command for reseting the server token and database keys for all devices. Note that after running this command you will need to reinstall on all devices and reregister with new QR codes. This command is useful if you are migrating a large amount of devices to a new group or a new server and you want to maintain Device ID consistency with the Device Serial numbers you are tracking.
- We cleaned up config variables in
Upgrade instructions:
# Fetch the updates.
cd tangerine
git fetch origin
git checkout v3.8.1
# Now migrate custom variables from config.sh_backup to config.sh. Note that T_ADMIN and T_PASS are no longer needed.
mv config.sh config.sh_backup
cp config.defaults.sh config.sh
# To edit both files in vim you would run...
vim -O config.sh config.sh_backup
# Now you are ready to start the server.
./start.sh v3.8.1
v3.8.0 is a big and exciting release! To accomodate the long list of changes, we split up this round of release notes into sections: General, Sync Protocol 2 Module, and Case Module, and Developer notes.
The following are features and fixes that are coming to all Tangerine installs. With this release comes an improved Editor UI experience, a faster device setup process, new form features, and much more.
Group tabs are now in 4 sections | Breadcrumbs allows you to navigate back up deeply nested areas |
---|---|
- Editor User browses Group UI by nested categories (as opposed to flat list) #1880
- Device Administrator is prompted to authorize permissions on first app load #1896
- Data Collector defines password according to policy #1867
- Data Collector views device info such as Device ID, Assigned Location, Server URL, Group Name, and Release Channel. #1834
- Data Collector in checkboxes chooses "none of the above", then other options are unselected #1822
- Editor distinguishes between inputs that are hidden and skipped #1800
- Minor tweaks to the menu (now there is a single "Sync" item) and added tab bars to some pages for consistency.
Sync Protocol 2 is a new module that can be enabled on a Tangerine installation that adds Device management, the ability for form responses to sync to the server and back down to tablets, the ablity for two tablets to sync form responses with each other offline, and much more.
Manage which devices have access to sync, when they last synced, when they last updated and which version | Define which form responses are synced up and back down to tablets |
---|---|
- Data Collector generates encrypted backup of Device #1909
- Data Collector conducts a two-way sync with server only getting data from server relevant to their location #1755
- Device sync by Location: Sync Protocol 2: Enables a "Device Setup" process on first boot of the client application. This requires you set up a "Device" record on the server. When setting up a Device record on the server, it will give you a QR code to use to scan from the tablet in order to receive it's device ID and token.
- Data Collector syncs to server with large dataset #1757
- Data collector synchronizes data between devices using an Offline P2P mechanism #279
- Editor User configures two-way sync for form responses from specific forms #1753
- Editor revokes access to syncing with server for a lost Device #1894
- Data Collector views Case Events in Schedule with Estimated Day, Scheduled Day, Window, and Occurred On Dates #1737
- Data Collector creates (another) instance of a repeatable form for a specific participant in a specific event(8hrs) #1786
- Data Collector views which Participant they are filling out a form for #1820
- Data Collector searches for a Case in a large dataset #1893
- Improvements to Case Home search - limit docs to 25 when no phrase is entered: #1871. Added rule to delay search in Case Home until at least two characters have been entered. Search results now sorted by date record updated.
- Lazy loading tabs in Case Home - this helps resolve some of the slowness in loading Case Home. Also disabled animations on tabs to remove jankiness.
- Re-enabled git config in Dockerfile - still having git networking error even when off corp network.
- Updated docker-tangerine-base-image to v3.4.0
- New load testing doc.
- Added random name generation to the script that generates new cases - useful for load testing and checking how well search listing works. If using the 'case-mother' switch, record templates are pulled from your group.
On the server, backup your data folder and then run the following commands.
git fetch origin
git checkout v3.8.0
./start.sh v3.8.0
docker exec -it tangerine /tangerine/server/src/upgrade/v3.8.0.js
Replace all ocurrences of localStorage.getItem('currentUser')
with window.currentUser
.
- More fixes for upgrade process from v3.1.0.
- Fix translations update script.
- Fix client update process when upgrading from v3.1.0.
Upgrade instructions: On the server, backup your data folder and then run the following commands.
git fetch origin
git checkout v3.7.1
./start.sh v3.7.1
docker exec tangerine translations-update
- Fixes
- When editing forms, they will only save back to the server after clicking the top level "save" button. There is also now messaging around when the save either completes successfully or fails.
- Issue: #1645
- On
<tangy-timed>
when using auto stop, return the property instead of the instead of the truthfulness of the value which is always false. - When uploadUnlockedFormReponses is set to true only incomplete forms are Synced up.
- Issue: #1725
- In editor, modifying allowed pattern on text and number inputs does not work.
- Issue: #1770
- Fix spacing between checkboxes in client
- Issue: #1690
- Fix click target and style for Case Event Form list
- Fix Partial Date validation
- Issue: #1683
- PR: Tangerine-Community/tangy-form#71
- EF Touch changes
<tangy-eftouch multi-select go-next-on-selection="2">
should become<tangy-eftouch multi-select="2" go-next-on-selection>
. This allows for expanding functionality of being able to use multi-select without go-next-on-selection but still limit the number of choices the user can make minus the transition.no-corrections
has been deprecated for newdisable-after-selection
attribute. When used withmulti-select
, the number of selections are still limited by the setting onmulti-select
, but changing selection is not allowed.- The
required
attribute when used withmulti-select
will only require just one value selected. If you need form example 2 selections to be valid, you can combinerequired-all multi-select="2"
. - We have an API change where we used to have
TangyEftouch.value.selection
was sometimes a string when not usingmulti-select
and then when usingmulti-select
, is was an array of strings. NowTangyEftouch.value.selection
will always be an array of strings.
- When editing forms, they will only save back to the server after clicking the top level "save" button. There is also now messaging around when the save either completes successfully or fails.
- Features
- When editing forms, the user will be warned of any duplicate variable names that exist in the form.
- Issue: #1793
- Improve messaging when an APK update fails to download
- Data Collector sends SMS message from form
- Issue: #1745
- Data Collector views events in schedule with icons, estimated date info, and scheduled date info
- Issue: #1686
- Data Collector views Case Module screens in French
- Issue: #1711
- Data Collector confirms case when opened
- Improved support for changing color scheme of client app using
custom-styles.css
, possible to have "dark mode".- PR: #1742
- Data Collector shares all data on Device with other Users on the same Device.
- Data Collector finds Case Event status has changed to "complete" when all required forms are submitted.
- Data Collector finds all required Event Form instances in a Case Event are created upon opening the Case Event.
- Data Collector registers a Participant in a Case and views Event Forms grouped by Participant
- When editing forms, the user will be warned of any duplicate variable names that exist in the form.
Upgrade instructions: On the server, backup your data folder and then run the following commands.
git fetch origin
git checkout v3.7.0
./start.sh v3.7.0
docker exec tangerine translations-update
- Fix timed grid output to exclude item level variables in logstash output #1806
Upgrade instructions:
After the usual upgrade commands, also clear reporting caches with docker exec -it tangerine reporting-cache-clear
.
- Fix usage of
T_CSV_MARK_DISABLED_OR_HIDDEN_WITH
in some cases.
- Allow disabled or hidden inputs output in CSV to be overridden using CSV_MARK_DISABLED_OR_HIDDEN_WITH in
config.sh
. The default value inconfig.defaults.sh
is"999"
which is what it has been for a few releases. When upgrading, do nothing if you want this to stay the same, otherwise use"ORIGINAL_VALUE"
if you want to turn off the feature or set to your own custom value such as"SKIPPED"
.
- Fix import of location list from CSV https://github.com/Tangerine-Community/Tangerine/pull/1732/commits/05e57e8f1bb869dbd52b927d45fc223903e201db
- Fix form routing for archived and active forms.
- Fix "Mark entire line as incorrect in grids is not reflected in csv #1713"
- Issue: #1713
- PR: Tangerine-Community/tangy-form#103
- New Features
- Support for changing the order of forms.
- Support for archiving a form.
- Improvements and support on all inputs for
error-text
,hint-text
,question-number
, and content translations. - Add support to
<tangy-qr>
for scanning data matrix codes.- Issue: #1653
- PR: Tangerine-Community/tangy-form#87
- New "Capture Item at N Seconds" feature for
<tangy-timed>
will prompt Data Collector to mark which item the child last read after a specific amount of time.- Issue: #1586
- PR: Tangerine-Community/tangy-form#95
- New
goTo('itemID')
helper function to navigate users to a specific item given some item levelon-change
logic.- Issue: #1652
- PR: Tangerine-Community/tangy-form#92
- New
<tangy-signature>
input for capturing signatures.- Issue: #1656
- PR: Tangerine-Community/tangy-form#90
- Visibility of labels and/or icons on item navigation now configurable with
<tangy-form-item hide-nav-icons>
and<tangy-form-item hide-nav-labels>
.- Issue: #1682
- PR: Tangerine-Community/tangy-form#73
- Fixes
- Fix Class tablets that are filling up their disk too fast.
- Issue: #1706
- Fix metadata print screen options
- Fix missing camera permission blocking APK installs form using QR or Photo Capture
- Fix performance issues caused by needless TangyForm.on-change events from firing when they don't need to.
- Issue: #1656
- PR: Tangerine-Community/tangy-form#89
- Fix data collector reviews completed fullscreen form
- Issue: #1629
- PR: Tangerine-Community/tangy-form#75
<tangy-eftouch auto-progress>
now distinguishes between going next on the time limit and going next on a number of selections. The API is now<tangy-eftouch go-next-on-selection=2>
for going next on 2 selection and<tangy-eftouch go-next-on-time-limit>
for going next on the time limit.- Issue: #1597
- PR: Tangerine-Community/tangy-form#84
<tangy-eftouch>
content is now more likely to fit above the fold, not overlap with content above it, be more consistent on smaller screens, and also adapt to screen size changes.- Issue: #1591, #1587
- PR: Tangerine-Community/tangy-form#79
<tangy-eftouch>
suffered from going to next item twice due to time limit and selection being made at in a close window. This is now fixed.- Issue: #1596
- PR: Tangerine-Community/tangy-form#76
- Fix Partial Date validation and for disabled attribute not reflecting
- Issue: #1683
- PR: Tangerine-Community/tangy-form#71
- Fix variable names in Editor to allow for only valid variable names. 2 or more characters, begin with alpha, no spaces, periods, allow _ no dash
- Issue: #1566, #1558, #1461
- PR: Tangerine-Community/tangy-form-editor#77
- Fix for Autostop for radio buttons -
- Fix Class tablets that are filling up their disk too fast.
- Experimental Features
- When using the experimental Case module, Editors can now program forms to trigger the creation of a "Data Query" when Data Collectors are entering data. Data queries are then shown later in a "Data Queries" tab where clarification on prior data entered is requested.
- PR: #1661
- When using the experimental Case module, Editors can now program forms to trigger the creation of a "Data Query" when Data Collectors are entering data. Data queries are then shown later in a "Data Queries" tab where clarification on prior data entered is requested.
Upgrade instructions:
On the server, backup your data folder and then run the following commands.
git fetch origin
git checkout v3.6.0
./start.sh v3.6.0
Now you may publish a release to your Devices and run the "Check for Update" on each Device. Note that if you are looking to use the QR Code scanner and you have been using Android Installation, you will need to reinstall the App on Devices and make sure to note the additional permissions installation instructions noted in the README.md file for enabling the App to have Camera Access. If using the Web Browser Installation, there is no need to reinstall the app for Camera access.
- New Features
- Forms with fullscreen enabled now have a toggle button for the user to enable/disable fullscreen mode. Form designers may specify the number of taps in order for fullscreen to disable. Tangerine-Community/tangy-form#51, Tangerine-Community/tangy-form#72, Tangerine-Community/tangy-form-editor#73
- An
inputs
object keyed by input name is now available for use invalid-if
statements. Tangerine-Community/tangy-form#65 - A new Partial Date item is available Tangerine-Community/tangy-form#57
- Translations updates. #1613
- New
custom-styles.css
file which can be added by modifying a group's assets folder. You may define CSS classes and then utilize them in the editor by adding them under each widget's class attribute. - New "Copy form" feature added to to Editor and more descriptive icon for adding a database record #1627
- Fixes
- Helper functions for timed grids are now safer, will not crash if a grid was skipped and info is not availble. Tangerine-Community/tangy-form#61
- Print view for a form had a bug where only the first page was printable. This is now fixed so that all pages may be printed. #1605
- Fix tangy-select test regression and work on EFTouch transition sound plays only on auto-progress #137
- API change in tangy-select - use of secondaryLabel is supported but deprecated; Use optionSelectLabel instead. #1602
- Fix the display of uploaded docs #1609
- Enable auto-stop for untimed grids #1522
- Increased clickable target for forms list and visits tab #1628
Upgrade instructions:
Backup your data folder and then run the following commands.
git fetch origin
git checkout v3.5.0
./start.sh v3.5.0
docker exec -it tangerine /tangerine/server/src/upgrade/v3.5.0.js
If any of your on-change logic looks into a form item's contents using tangyFormItemEl.shadowRoot.querySelector(...)
or
this.$.content.querySelector(...)
, you must change it. The contents of the form can now be accessed at tangyFormItemEl.querySelector(...)
.
Also, the content
element is no longer available.
For example:
// replace
var el = this.$.content.querySelector('tangy-input[name=\'classId\']')
//with
var el = this.querySelector('tangy-input[name=\'classId\']')
The advantage of moving this content out of the shadow DOM is that you can now style it directly from your app.
- New Features
- New groups now ordered by creation date: Creating new groups will now order them by the date the were created in the group list. #1584
- Configurable Web App Device Orientation: You can now specify the Web App orientation (portrait, landscape, or any) on device using the
T_ORIENTATION
variable inconfig.sh
. AddT_ORIENTATION="any"
to config.sh to have more flexible orientations for PWA's. The options for T_ORIENTATION are at https://developer.mozilla.org/en-US/docs/Web/Manifest/orientation - Media Library and Image support for Forms: Each group now has a media library tab where they can uplaod images which can then be utilized when inserting the new "Image" item on forms. #1138
- New ACASI widget: The ACASI widget is braodly based on the EFTouch widget, but focused on a more static presentation of images and sounds. #56
- Configurable font size in grids: You may now configure the font size in tangy-timed and tangy-untimed grids using the Option Font Size input. In tangy-form, it is exposed as option-font-size. Example of generated code:
<tangy-timed required columns="3" duration=80 name="class1_term2" option-font-size="5">
- Auto-stop for tangy-radio-buttons: Add support for autostop in tangy-radio-buttons #49. In Editor, set the Threshold to the number of incorrect answers: screenshots. Autostop is implemented by using the hideInputsUponThreshhold helper, which takes a tangy-form-item element and compares the number of correct radio button answers to the value in its incorrect-threshold attribute. Example of generated code:
<tangy-form-item id="item1" incorrect-threshold="2">
- New "correct" attribute for radio button options: A new "correct" attribute has been added to tangy-list-item to store the correct value. There is a "Correct" checkbox next to each option. Example of generated code:
<tangy-radio-buttons name="fruit_selection2" label="What is your favorite fruit?"> <option name="tangerine">Tangerine</option> <option name="cherry" correct>Cherry</option> </tangy-radio-buttons>
- Fixes
- Critical Sync and "data loss" fix: Some variants of v3.3.x saw cases where data seemed to be lost on the tablet and sync no longer worked. After this release is deployed to the server, release for your groups and instruct all tablets to upgrade. The upgrade process may take many minutes depending on the amount of data stored on the tablet due to a schema update in the database. For an in depth look at what this update does, see the code here.
- Logstash Improvements #1516
- User profiles were in a nested object, now they have been merged to be flat in the logstash output doc. See example here.
- If a form response uses a location element, it will now be extracted out into a top level
"geoip"
property whose value is an object with"lat"
and"lon"
properties. See example here. - When new forms are created in the editor, they will no longer have a
.
character in their ID. This was causing some uneccessary and confusing logic in logstash config files. See PR here.
- EFTouch: A large number of fixes have been made for EFTouch. See recent issues here.
- Updated to tangy-form-editor ^5.18.0 for Change grid variables in CSV starting with variable_0 to variable_1.
- A previous update to tangy-form to 3.15.1, tangy-form-editor to 5.17.0 to fixed Editing form level HTML requires two Save clicks
- Beta Features
- Two-way Sync: Allows for two-way sync of form responses. Can be configured to two way sync form responses for specific forms and also by geographic region defined in the user profile. See
docs/feature-two-way-sync.md
. and Add a tangy input inside a tangy box duplicates items, and enable Adjustable letter size for grids - Case Module
- Add the "case" module to
T_MODULES
inconfig.sh
and the default landing page for a group will be the cases search page and new "Case Management Editor" tab will appear in groups for creating and editing Case Definitions. #1517 - Clientside search of Forms for Case Management Groups allows Cases to be found using the device camera to scan a QR code. See
docs/case-management-group.md
. - Add event time and scheduling to Case Mangement Groups #1518
- New layout for Case and Case Event pages.
- Add the "case" module to
- Two-way Sync: Allows for two-way sync of form responses. Can be configured to two way sync form responses for specific forms and also by geographic region defined in the user profile. See
Upgrade instructions:
Backup your data folder and then run the following commands.
git fetch origin
git checkout v3.4.0
./start.sh
This release fixes a feature that made it into v3.3.0 but had a bug and was disabled. This release fixes that bug and makes it available.
- As an Editor user I want to be able to do an initial import of my location structure. #1117
- Features
- Assessor reviews high level case variables, AKA "Case Manifest" #1399
- Assessor changes language setting to Russian #1402
- Untimed Grid subtest #1366
- Editor Style Upgrades (April 2019) #1421
- Group Names can now have spaces and special characters #1424
- Editor configures Timed Grid to show or hide labels on buttons #1432
- Server Admin tunes the reporting delay between when an upload occurs and it shows up in reporting outputs #1441
- CSV output for single checkboxes now show up as "0" and "1" as opposed to "" and "on" #1367
- CSV output for single radiobuttons now show up as "0" and "1" as opposed to "null" and "on" #1433
- You can now limit who can add/see sitewide users to only the USER1 account by setting
T_USER1_MANAGED_SERVER_USERS
to"true"
inconfig.sh
#1381. - Client now has an "About" page with details about what Tangerine is #1465.
Upgrade instructions:
Backup your data folder and then run the following commands.
git fetch origin
git checkout v3.3.0
./start.sh
docker exec -it tangerine /tangerine/server/src/upgrade/v3.3.0.js
- Features
- Assessor changes language of App #1315
- Editor provides feedback given data entered earlier in the form #1384
- Assessor starts new Case is immediately forwarded to first form #1362
- Assessor finds Form and Event in Case has been disabled/enabled due to custom logic #1363
- Assessor confirms participant info using data from another form #1385
- Server Admin restarts machine to find containers have automatically come back up #1388
- Server Admin sets up Tangerine outage alarm #1389
- Developer Notes
Upgrade instructions:
git fetch origin
git checkout v3.2.0
./start.sh
docker exec tangerine /tangerine/upgrades/v3.2.0.js
- In each group's
app-config.json
, change"direction"
to"languageDirection"
. - If using a translation other than English, change in each group's
app-config.json
, change"languageCode"
to the corresponding language code. Current codes other thanen
for English isJO_ar
for Jordanian andKH_km
for Khmer.
- Features
- Item Editor UX Improvements #810
- Assessor verifies correct location selected by reviewing metadata of location #1191
- As an assessor I'd like to include a hint option to be displayed below the question text #1279
- Grids: helper functions for grids #1183
- Ability to mark an entire row as incorrect on grids #1333
- Assessor's backed up form responses are archived when storage is filling up #1304
- Assessor scans a QR Code into form #1309
- All hidden inputs have reporting values of
"999"
#1349 - Merge reporting output of radiobuttons into one column.
- Bug fixes
- Editor not properly logging users out resulting in getting stuck every 24 hours #1314
- Min and Max for input number cannot be saved through the interface #1297
- time on grids cannot be changes and is always 60 seconds #1301
- Unclosed tags in html container can break form #1289
- Tangy timed option values disappear #1302
Note that #1349 will bve optional in future releases and you may not want to upgrade until that time.
Upgrade instructions:
git fetch origin
git checkout v3.1.0
./start.sh
docker exec tangerine reporting-cache-clear
git fetch origin
git checkout v3.0.0
# Note the new T_UPLOAD_TOKEN variable which is a replacement for the old upload account variables.
mv config.sh config.sh_backup
cp config.defaults.sh config.sh
vim config.sh
./start.sh
docker exec tangerine push-all-groups-views
docker exec tangerine reporting-cache-clear
For existing groups, you need to edit their app-config.json
files in the ./data/client/content/groups
folders. Replace them with the following template and make sure to update variables such as groupName
, uploadToken
, and serverUrl
.
{
"listUsernamesOnLoginScreen" : true,
"modules" : [ ],
"groupName" : "pineapple",
"securityQuestionText" : "What is your year of birth?",
"hideProfile" : false,
"direction" : "ltr",
"columnsOnVisitsTab" : [],
"hashSecurityQuestionResponse" : false,
"uploadUnlockedFormReponses" : false,
"uploadToken" : "change this to match T_UPLOAD_TOKEN in config.sh",
"securityPolicy" : [
"password"
],
"homeUrl" : "case-management",
"serverUrl" : "https://f571f419.ngrok.io/",
"centrallyManagedUserProfile" : false,
"registrationRequiresServerUser" : false
}
- Server admin imports client archives into server #1166
- After exporting data from clients, we now have an easy command line tool to import them. Place those exported files in
./data/archives
folder and then rundocker exec tangerine import-archives
.
- After exporting data from clients, we now have an easy command line tool to import them. Place those exported files in
- Consumers of reporting API find user profile data appended to form responses #1147
- New
logstash
module for installations that want to use logstash to migrate data to an Elastic Search instance. - Enable by adding
logstash
to the list of modules inconfig.sh
, then clear reporting cachesdocker exec -it tangerine bash; cd /tangerine/server/src/scripts; ./clear-all-reporting-cache.js;
. You will find new<groupName>-logstash
databases in CouchDB that you can configure logstash to consume.
- New
- Upload Tokens instead of upload usernames and passwords.
- In your
config.sh
changeT_UPLOAD_TOKEN
to a secret phrase and then in existing groups add that toapp-config.json
as an"uploadToken"
property anduploadUrl
toserverUrl
but without the username and password andupload/<groupName>
. For example,"uploadUrl": "http://uploader:[email protected]/upload/foo"
would become"serverUrl":"http://foo.tangerinecentral.org", "groupName":"foo", "uploadToken":"secret_foo_passphrase"
. - If you not planning on updating clients right away, in
config.sh
setT_LEGACY="true"
to support the older upload API that those clients expect. When all clients are upgraded, set that variable back to false.
- In your
- Editor edits location list for group #982
- @TODO
- Editor creates, edits, and deletes form responses on the server #1047
- Editor exports CSV of a form for a month of their choosing #1143
- Editor sees user profile form related columns joined to CSV of all forms #1142
- On client, prevent users from editing their own profile.
- To impact new groups, change
T_HIDE_PROFILE
to"true"
inconfig.sh
. - To modify existing groups, change
"hideProfile"
in group levelapp-config.json
totrue
.
- To impact new groups, change
- Assessor registers on tablet, downloads form responses created on server #1129
- On device registration, after user creates account, will force user to enter 6 character code that references online account.
- To impact new groups, change
T_REGISTRATION_REQUIRES_SERVER_USER
to"true"
. - To modify existing groups, change
"registrationRequiresServerUser"
in group levelapp-config.json
totrue
.
- Editor updates client user profile on server, Assessor sees updated profile after next sync #1134
- On client sync, will result in any changes made to a user profile on the server to be downloaded and reflected on the client.
- To impact new groups, change
T_CENTRALLY_MANAGED_USER_PROFILE
to"true"
inconfig.sh
. - To modify existing groups, change
"centrallyManagedUserProfile"
in group levelapp-config.json
totrue
.
- Editor views tangy-timed items_per_minute calculation in the CSV #1100
<tangy-location>
can be filtered by entries in the profile by adding attribute<tangy-location filter-by-global>
. In the editor when editing a<tangy-location>
you will find a new option "Filter by locations in the user profile?" you can check.- Advanced forms features (no GUI for these features)
<tangy-input-group>
can be used to create repeatable groups of inputs. See the demo here.- Geofence for v3 #941
- Upload incomplete form responses (important for Class module)
- To modify existing groups, set
"uploadUnlockedFormReponses"
totrue
inapp-config.json
.
- To modify existing groups, set
- Server Admin clears reporting cache #1064
- Server Admin runs script to update views in databases #962
- Server Admin limits by site or by group the number of form responses uploaded end up in reporting outputs #1155
- This feature brings two new settings to
config.sh
. - Set
T_PAID_MODE
to"site"
to limit on a sitewide level, use"group"
to limit on a per group level. - Set
T_PAID_ALLOWANCE
from"umlimited"
to a specific number like"1000"
to limit form responses that end up in reporting outputs to one thousand. - This mechanism works by marking uploaded form responses as "paid". When you first upgrade to this release, none of your form responses will be marked as paid and will not end up in reporting outputs until they are marked as paid against the allowance. If you want to mark all current uploaded form responses as paid and only mark against their allowance for future uploads, set the allowance to unlimited and after the reporting caches have been built, set the allowance desired and run
./start.sh
again.
- This feature brings two new settings to
- Optional Modules you can turn on and off in
config.sh
T_MODULES
list.- Note that if you are going to override the default
T_MODULES
list with an additional module such asclass
, don't forget to add modules such ascsv
if you still need them!
- Note that if you are going to override the default
- Reporting outputs (inluding CSVs) include the information about the number of children a location has. #1174
- Memory leak results in
Error: spawn ENOMEM
#886- On the server command line run
crontab -e
and then add the following entry to restart the program every 24 hours0 0 * * * docker stop tangerine; docker start tangerine
.
- On the server command line run
- As a Tangerine Database admin, I want to control which users have the "Manager" role for creating new groups #218
- As a Tangerine Editor User, I expect to see timestamps on CSVs down to the second #223
- As a user, if I end up on a http:// URL I want to be redirected to the https:// version of that URL #98
- New groups default Client tabs are set up for workflow, should be vanilla tangerine #230
- When Tangerine is first installed, User1 does not have the required Manager role so groups cannot be created #229
- School Location Subtest does not render after upgrading from Tangerine 0.4.x to v2.0.0 #189
- If a group was upgraded from 0.x.x and does not have a media folder, APK generating fails #186
- Deleting group does not set security correctly on resulting "deleted" database #227
- Large CSVs fail to generate #221
- When a new Workflow is created it is missing retrictToRole, reporting, and authenticityParameters #228
- Ensure /var/log/couchdb exists so CouchDB does not crash #216
- Document how to use SSL with Tangerine #219
- Things to add to .gitignore #185
- Clean up build process so client does not need to compile twice #74
- This is the first release with upgrade scripts so you will need to run all upgrade scripts between the version you started at and this one.
For example, if you are at Tangerine 0.4.6, then you must run...
docker exec -it tangerine-container /tangerine-server/upgrades/v1.0.0.sh
docker exec -it tangerine-container /tangerine-server/upgrades/v2.0.0.sh
If you are at Tangerine 1.7.8, then you must run...
docker exec -it tangerine-container /tangerine-server/upgrades/v2.0.0.sh
- As a Site Owner I want to know how many results have been uploaded given arbitrary time period #457
- Refactor start.sh and config.defaults.sh to allow configurable ports and tag #456
docker exec -it tangerine-container /tangerine-server/upgrades/v2.2.0.sh