API Updates for November 2023

API Updates

The next Kintone update is on 13th November 2023. The release also includes the following API updates.

Update Summary

On the update scheduled on February 2024, the Event Object and JavaScript APIs will be updated to handle non-numeric values when retrieving or rewriting the Number field. This option will be available in preview in the November update.

Before the update:

When using JavaScript APIs to work with the Number field, users could retrieve or rewrite with non-numeric values.
Therefore, it was necessary to implement codes to determine whether the value retrieved was a number or not.

After the update:

  • When retrieving a non-numeric value, #INVALID is returned.
  • If the value in the Number Field is set to a non-numeric value, an error will occur.

This update makes it simpler to implement Kintone customization when dealing with non-numeric values, allowing a more efficient implementation. Additionally, this can reduce the costs for future product updates, leading to improved maintainability.

Release Schedule

  • November 2023: Preview of the new features.
  • February 2024: Official release. The feature can be disabled from the Disable New Features settings.
  • May 2024: The feature will no longer be able to be disabled from Disable New Features settings.

Settings

From Kintone Administration > Other > Update Options screen, set the options as follows:

  • Check Enable this feature: Changes to How Invalid Values Are Handled by JavaScript APIs for Getting or Setting "Number" Field Values
  • Uncheck Enable this feature: Support for Full-Width Numbers and Separating Thousands by Commas in Number Fields on New Record and Edit Record Screens

Changes

Values that can be retrieved or changed to in the Number field

  • Numbers
    • "+" or "-" can be used to express positive and negative values
    • "." can be used to express decimals
    • "e" or "E" can be used to express exponentials
  • Whitespaces

Only single-byte characters can be used for numbers and symbols.

In addition, the following values can be used for Event Objects and JavaScript APIs when changing the value in the Number fields:

  • undefined null: The value in the Number field will be empty.
  • #INVALID!: The value in the Number field will not be changed.

Values that are not specified above are treated as invalid values in the Number field.

Getting invalid values

Entering an invalid value in the Number field will return #INVALID!.

Record Create Events:

  • Onload Events
    app.record.create.show mobile.app.record.create.show
  • Field Change Event
    app.record.create.change.(fieldcode) mobile.app.record.create.change.(fieldcode)
  • Save Event
    app.record.create.submit mobile.app.record.create.submit

Record Edit Events:

Get Record:

Notes

Before determining whether the value is invalid, the following actions are performed:

  • PC screen:
    • Conversion to Single-byte characters
    • Elimination of comma separators
    • Removal of spaces
  • Mobile screen:
    • Removal of space

Setting invalid values

Setting the value of the Number field with an invalid value using Event Objects or JavaScript API will result in an error.

Record Create Events:

  • Onload Events
    app.record.create.show mobile.app.record.create.show
  • Field Change Event
    app.record.create.change.(fieldcode) mobile.app.record.create.change.(fieldcode)
  • Save Event
    app.record.create.submit mobile.app.record.create.submit

Record Edit Events:

Record List Event:

Set Record:

Changing the value to "#INVALID!"

When changing the value to #INVALID! using Event Objects or JavaScript API, the field change event will not be triggered, and the value will remain the same.

Record Create Events:

Record Edit Events:

Set Record:

Whitespaces in the mobile view

In the mobile view, if whitespaces are entered before or after a value, they will be sanitized. When whitespaces are sanitized, as long as the final value does not change, an event will not be triggered.

Record Create Events:

Record Edit Events:

Get Record:

Set Record: