Plug-in Development Guide
Overview
"Plug-ins" are packaged JavaScript and CSS customizations for Kintone Apps.
Kintone allows users to install plug-ins to expand on functionality via JavaScript. When performing normal JavaScript customizations, it is necessary to update your uploaded JavaScript files when updating the customization. However plug-ins can manage customizations individually via the plug-in settings page.
This article explains more about creating and installing plug-ins.
Steps
- Create files for the Kintone plug-in customization.
- Create a manifest file.
- Package your files using a packaging tool (plug-in packer)
- Import the plug-in into your Kintone environment.
Creating Each File
First, you'll need to get the files ready to be packaged.
|
|
Plug-in Icon icon.png
The icon image for the plug-in
- This file is required
- Use the following file types: png、jpg、gif, or bmp
- The maximum file size is 20MB
App Customization for Desktop customize.js
The JavaScript file that is initiated on desktop browsers.
This is where the main Kintone customization codes will be written.
If you're planning on making a mobile-only plug-in, you can skip this file.
The file can pull information from the Plug-in Settings page.
The maximum file size is 20MB.
kintone.plugin.app.getConfig()
can be used to pull information from the Plug-in Settings page. These information though need to be initially set by the config.js file using kintone.plugin.app.setConfig()
. The variable kintone.$PLUGIN_ID
will hold the Plug-in ID which will be needed.
*The Plug-in ID is an ID with 32 characters e.g. qrhfefwgeehqkanwmjwmhbgecsfgalbf
Sample code for retrieving the Plug-in ID
Apps can have multiple plug-ins. In this case, variables may set into the kintone.$PLUGIN_ID
more than twice. For this reason, use the code below to hold the plug-in ID variable.
|
|
Stylesheet for Desktop View customize.css
The CSS file that is initiated on Desktop browsers.
You can follow the
Kintone stylesheet if you want to use the Kintone design.
The maximum file size is 20MB.
App Customization for Desktop mobile-customize.js
The JavaScript App customization for Desktop customize.jsfile initiated on the mobile.
This is optional, and can be left out if you will be using the plug-in on only desktop browsers. kintone.plugin.app.getConfig()
can be used to pull information from the Plug-in Settings page. This information needs to be initially set by the config.js file using kintone.plugin.app.setConfig()
. Follow the
Sample code for retrieving the Plug-in ID.
The maximum file size is 20MB.
HTML for Plug-in Settings config.html
The HTML file that is used to display the settings page of the plug-in.
This is optional, and can be ignored.
The maximum file size is 64KB.
JavaScript Initiated on Plug-in Settings config.js
The JavaScript file that is initiated on the settings page of the plug-in.
This is optional,Sample code for retrieving the Plug-in ID and can be ignored.
Follow the
Sample code for retrieving the Plug-in ID.
The maximum file size is 20MB.
kintone.plugin.app.setConfig()
is used to save variables to the plug-in.
Stylesheet for Plug-in Settings config.css
The stylesheet initiated on the settings page of the plug-in
This is optional, and can be ignored.
You can follow the
Kintone stylesheet if you want to use the Kintone design.
The maximum file size is 20MB.
The Manifest File
You'll need a manifest file to create your plug-in.
Manifest File Format
The manifest file format is as below. Specify each parameter in a JSON format.
PARAMETER | TYPE | REQUIRED | DETAILS | SAMPLE |
---|---|---|---|---|
manifest_version | Integer | Yes | The manifest version of the plug-in. Only 1 can be stated for this value. |
"manifest_version": 1 |
version | Integer or String | Yes | The plug-in version. | "version": 1 |
type | String | Yes | The type of the plug-in. Specify the string "APP". |
"type":"APP" |
name | Object.<String> | Yes | The name of the plug-in for various Locales. | "name": { |
name.<locale> | String | Yes | The localized name of the plug-in. Must be between 1 to 64 characters. name.en is required. |
|
description | Object.<String> | Optional | The description of the plug-in for various Locales. | "description": { |
description.<locale> | String | Yes | The localized description of the plug-in. Must be between 1 to 200 characters. description.en is Required. |
|
icon | String | Yes | The plug-in icon file. Only files within the plug-in can be specified. |
"icon": "image/sample.png" |
homepage_url | Object.<String> | Optional | Websites for the plug-in for various
Locales. A navigation icon will be added next to the plug-in name in the plug-in list. Click the navigation icon to go to the specified website. The icon is only displayed if the specified locale matches the locale in the name parameter. |
"homepage_url": { |
homepage_url.<locale> | String | Optional | The Website of the plug-in for the user's locale. | |
desktop | Object.<String> | Optional | The JavaScript and CSS files for the Desktop. | "desktop": { |
desktop.js | Array.<String> | Optional | An array of JavaScript file URLs for the Desktop. Up to 30 files can be set. If multiple files have the same name, an error will occur. |
|
desktop.css | Array.<String> | Optional | An array of CSS file URLs for the Desktop. Up to 30 files can be set. If multiple files have the same name, an error will occur. |
|
mobile | Object.<String> | Optional | The JavaScript and CSS files for the mobile. | "mobile": { |
mobile.js | Array.<String> | Optional | An array of JavaScript file URLs for the Mobile. Up to 30 files can be set. If multiple files have the same name, an error will occur |
|
config | Object.<String> | Optional | The html, js and css files for the Plug-in Settings page. | "config": { |
config.html | String | Optional | The HTML file for the Plug-in Settings page. Only files within the plug-in can be specified. |
|
config.js | Array.<String> | Optional | An array of JavaScript file URLs for the Plug-in Settings page. Up to 30 files can be set. If multiple files have the same name, an error will occur. |
|
config.css | Array.<String> | Optional | An array of CSS file URLs for the Plug-in Settings page. Up to 30 files can be set. If multiple files have the same name, an error will occur. |
|
config.required_params | Array.<String> | Optional | An array of parameters that are required to be filled in in the Plug-in Settings page. Must be between 1 to 64 ASCII characters. |
Locales
The following language codes can be specified:
en
: Englishja
: Japanesezh
: Simplified Chinesees
: Spanish
Sample Manifest File
|
|
Packaging
The Plugin-packer tool is used to package the customization. Read through the Package Plug-in Files using plugin-packer article for steps on how to use the plug-in packer tool. Move on to the next step once zip file for the plug-in has been created.
Importing
Now that you have the zip file, you're nearly done!
Log into your Kintone environment with an Administrator level account, and go to the Kintone Administration page, which is an option you can find from the top right cog wheel near your name. Click on "Plug-ins", and then on "Import". Here, you can import your plug-in (your zip file) into your Kintone environment.
Notes
If a plug-in with the same Plug-in ID is uploaded, it will automatically overwrite the plug-in, and will take effect on all apps that are using that plug-in.