The purpose of this book is for readers to acquire the necessary skills to develop applications using the digital note applications “GEMBA Note.” Through exercises, readers will learn the following fundamental knowledge related to the development and operation of GEMBA Note applications.
Explain the features and uses of GEMBA Note before starting to read. Describe the themes and objectives of each chapter, the steps to follow when verifying the sample code, how to proceed with the exercises, and the notation of sample code and commands that appear in the text.
eYACO/GEMBA Note is a digital notebook application designed for use in the “GEMBA(field)” to support team work and improve productivity by centrally managing various types of information. It allows users to record current events through handwritten notes, text, photos, and videos, annotate the same drawings and images with multiple members, and collaboratively create field reports.
Not just a simple note-taking app, but also a development platform with features such as:
GEMBA Note and eYACHO are sister products that have the same features. eYACHO was developed in collaboration with a general construction company in Japan and includes content specialized for construction and civil engineering tasks (e.g., crane diagrams, survey calculation templates, construction photo management, etc.).
On the other hand, GEMBA Note is positioned as a general-purpose application intended for use not only in construction sites but also in various other field operations.
Balancing High Functionality and Ease of Use for “No Wait” Field Operations
It is not practical to switch between several applications at various sites where conditions change from moment to moment. In this respect, GEMBA Note is a digital notebook with numerous functions needed in the field.
Although it is such a multifunctional application, it has various customization functions such as a toolbox and UI customization, and can provide menus focused on necessary operations, so even beginners can start using it right away.
Real-Time Transmission Technology that “Connects People in the Moment”
MetaMoJi’s real-time information transfer technology “Share” enables stress-free information sharing between remote locations such as the field and the office, or between distant sites and the headquarters.
The “Share” technology does not compress and transmit screen images, but only the updated edited differences, greatly reducing the transmission volume. Even the most detailed forms can be shared quickly and without loss of resolution, allowing stress-free exchange of drawings and detailed management forms.
Fusion of “Freedom” and “Standardization”
GEMBA Note is a digital notebook that allows you to write anything as Freely as you would in a paper notebook. Additionally, it enables end users to quickly create forms required for Standardization tasks, integrate with task systems, and import/export data, making it suitable for standardized operations as well.
Aggregation for Collecting and Displaying Information in a List
GEMBA Note has database functions based on tag schemas. By using the application to paste tags by note, page, or object, database processing such as searching and aggregation across notes and pages becomes possible.
It is possible to display a list that aggregates data and information from accumulated data and external services, matched for the specific purpose. This helps field managers to understand information from various aspects.
Possible uses include:
These functions allow for the construction of business systems.
Extension Features for Customization
GEMBA Note comes equipped with a wide range of features that cover various on-site operations, making it usable without the need for individual development. Additionally, it can be customized to have a user-friendly UI and menu structure that is common across different sites, even without advanced IT skills.
GEMBA Note offers customization capabilities at various levels. These range from creating and sharing form templates by end-users to advanced system development by IT departments and system integrators.
By providing a flexible and multi-layered customization environment, it can serve as an application development foundation for the digitization of on-site operations.
Who Uses It and How?
Creating and sharing the necessary forms at each site without relying on the IT department or external SI companies. Systemization is driven by on-site personnel rather than the management department, ensuring that the digitization efforts meet the specific needs and satisfaction of the site staff.
Detailed and dense information can be shared in real-time across departments and locations, significantly improving productivity and realizing true “work style reform.”
Additionally, advanced business system construction integrated with other systems is also possible through system development companies and SI companies.
The following figure depicts what applications developed in GEMBA Note can do:
🔳 Creating Forms using Form Components
You can create a business form using a variety of form components such as text and table that are placed on a note.
🔳 Making Tag Schemas into a Database
Form components linked with tag schemas on a form page of GEMBA Note allows you to utilize the form information as a database.
🔳 Cascading Inputs
GEMBA Note offers drop-down menus for selecting dynamically-updated items.
🔳 Defining Search Conditions
You can define search conditions that consist of search connectors and SQLs to declare data extraction methods.
🔳 Aggregations
Commands and button components allow you to run your defined search conditions.
🔳 Exporting the Results of Aggregations (Not described in this document)
Using button components, the results of executing search conditions can be exported as files as image, PDF, and CSV formats.
🔳 Connecting to External Systems (Not described in this document)
Using REST APIs, you can import/export data from/to external systems.
🔳 Launching URL Scheme (Not described in this document)
URL scheme is used as an identifier in launching applications and performing a set of commands on iOS and Windows devices from other Web applications. This feature allows you to import/export data to/from GEMBA Note.
Users who intend to develop an GEMBA Note application using this book are assumed to already be using either product and to be able to perform the following basic operations.
Having knowledge of SQL (Structured Query Language), a specialized language for manipulating and defining data in relational database systems, is likely to accelerate understanding of the definition and execution of aggregations.
This book is composed of eight chapters. Below is an overview of each chapter, the key points to be learned, and examples of the deliverables for each chapter.
From Chapter 2, through practical exercises, new content and features will be sequentially added to the previous tasks, ultimately completing a single development package.
Ultimately, this will result in a “Property Management Application” consisting of one to two notes, a couple of tag schemas to represent them, and aggregation search conditions.
🔳 Chapter 2: Preparing for Application Development
To develop an application on GEMBA Note, you must start by preparing the “development package.” This involves explaining the required permissions and necessary preparations.
🔳 Chapter 3: Creating Forms
In GEMBA Note, various types of content such as handwriting, text, and images are primarily placed on notes to organize information. There are form components available to construct forms and items. These components can be placed on notes or shapes to create standardized forms.
🔳 Chapter 4: Defining Data
Simply placing form components in a note allows the note to hold information, but it does not enable the retrieval and utilization of those values. The expression of what each component “means” is missing. Therefore, a structure called a “tag schema” is prepared to define the meaning and role of each component.
🔳 Chapter 5: Defining Search Conditions
GEMBA Note can process form components linked to a tag schema as a database. Its search function, called “aggregation,” extracts and displays data that matches the search conditions from the data collected by various connectors. This chapter will cover how to create search conditions.
🔳 Chapter 6: Executing Search Conditions
This chapter focuses on executing the aggregation search conditions defined in Chapter 5. You will learn how to display the results of cross-form searches and understand how to update tag schema values through button actions.
🔳 Chapter 7: Customizing UI
The UI display of GEMBA Note can be customized by creating XML definition files and loading them into notes or note templates. This chapter will cover the customization methods and the procedures for registering the created forms as reusable standard UIs.
🔳 Chapter 8: Deploying Applications
Explain the tasks and procedures for sharing completed development packages with other users.
Each chapter includes exercises designed to reinforce the concepts and skills learned. When working on these exercises, you will add or modify content within the same development package. The files required for the exercises and reference materials can be downloaded directly from the locations below, or you can view the contents on the web and save the files.
Backup
File name | Description |
---|---|
PropertyManagementMaster__1.0.2__backup.gncproj | Backup file for providing as model answers for the exercises |
Property Forms
File name | Description |
---|---|
property.css | Stylesheet of the property info HTML |
property.html | Property info HTML |
propertyForm.dydoc | GEMBA format file for the property form [1] |
propertyList.csv | To be used in the exercise for importing data |
[1] Import the file when skipping the exercise to create the Property form
Shared List
File name | Description |
---|---|
propertyTypes.txt | To be used in the exercise for registering a shared list [2] |
[2] Use the file to shorten the exercise of a shared list
UI Definition
File name | Description |
---|---|
simple_ui.xml | To be used in the exercise for customizing UI |
Each chapter may contain supplementary explanations related to the development of the GEMBA Note apps, which are referred to as “Suppliments.” These sections might also include more anecdotal content. While they are not entirely unrelated to GEMBA Note, their purpose is to broaden and enrich the reader’s knowledge by providing explanations about widely used technologies by offering comparisons or analogies with GEMBA Note.
In this book, numbers and symbols are used to differentiate between code descriptions and execution commands. Their meanings are as follows.
Examples of Code Formatting
SELECT *
FROM P_TABLE
WHERE name != '' -- Comment
When presenting expressions or code similar to SQL, write a comment after – to highlight and explain specific sections.
Example of Command Execution Formatting
> sqlite3 property_management.db
When executing commands, use the Windows Command Prompt. Place the > symbol at the beginning of the command, followed by the command itself.
There are cases where the product names appearing on this book are used as company trademarks.
The exercises are designed to be performed on a PC running Windows 10 or 11.
The documents related to application development are as follows:
This chapter describes the necessary usage permissions, the configuration for using developer features, and key points for operating on a Windows PC to start development on GEMBA Note.
The following figure shows how to develop and to deploy an application in GEMBA Note.
[1] Using Developer Mode
Enable the package development features to show development package folders.
[2] Creating a Package
Prepare a development package.
[3] Creating a Form
You can create a business form with various form components on a page of a note.
[4] Creating Tag Schemas
Define tag schemas and their properties to structure the data to be utilized as a database.
[5] Configuring the Tag Schemas
Link each form component with a tag property of the tag schemas.
[6] Defining an Aggregation Search Condition
Define a search condition using the tag schemas and their properties.
[7] Setting the Aggregation Search Condition
There are two ways to execute an aggregation search condition. The one is for displaying results on a table or with sumnails. Another is to invoke from a button component.
[8] Executing the Aggregation Search Condition
Run the aggregation search condition to confirm the behavior as expected.
[9] Registering the Form
Put the created form as a template in the development package to easily reuse them.
[10] Publish the Package
The development package can be shared among other users by releasing or deloying it.
[11] Managing the Package
You can manage the development package to back it up or to modify it for a new version.
GEMBA Note can be installed from the App Store, Google Play Store, or Microsoft Store. Although the app is available for free installation, a license is required for use. You will need to set up an organization ID, user ID, and password to log in to the cloud service provided by MetaMoJi Corporation.
If you have not yet purchased a license or development options, contact MetaMoJi Global Team by sending a request mail to sales@metamoji.com. A trial license will be issued.
While it is possible to use development environments on iPads, it is recommended to use the Windows version of the app for easier development tasks such as copy and paste with mouse operations and multi-window support.
To develop applications for GEMBA Note, not only a product license but also “Developer Permissions” are required to access developer features for package development.
There is also a “Package Administrator Permission” for managing the developed packages. Each permission should be allocated to the appropriate users according to the application development policies within the organization.
The configuration of these permissions is performed using an account that can log in to the web-based user management tool, commonly referred to as the “Green Tool.”
When logged in as a developer user, you can enable package development features.
A “Package Development Folder” will appear in the folder tree.
A development package is a container on GEMBA Note for developing forms and items, and storing content that provides aggregation functionality known as “Aggregation.”
Select the package development drive and start creating a package by choosing + > Create Package from the navigation menu.
Applications installed on a Windows PC come in two types: “Store Apps” and “Desktop Apps.” GEMBA Note is a Store App, originally developed for smartphones and tablets like iPhones, iPads, and Android devices.
In a Windows environment, some devices, such as the Microsoft Surface, support touch screen operations. However, on most commonly used Windows PCs, which do not have touch screens, you will need to use a mouse and keyboard for operation.
Gesture on Smartphone/Tablet | Operation on Windows PC |
---|---|
Tap with one finger or pen | Left click |
Long press with one finger or pen | Right click |
Double-tap, then long press and drag | Left click and drag |
Tap with two fingers | Right click |
Double-tap with two fingers, then long press and drag | Right click and drag |
Pinch in | Ctrl + Ctrl + Mouse wheel up |
Pinch out | Ctrl + Mouse wheel down |
On a Windows PC, copying text with Ctrl + C and pasting it with Ctrl + V cannot be done within GEMBA Note’s notes. Instead, right-click on the item to bring up the context menu, select “Copy,” then right-click in the desired location and choose “Paste” from the menu.
Create the “Property Management Package” using the following steps. Note: The provided examples are for reference only; please customize them according to your needs.
In programming languages, a “package” is a way to organize and distribute code so that it can be easily reused, shared, and maintained. Packages typically bundle related code files, such as libraries, modules, classes, and functions, into a single unit that can be easily imported into a development project.
Here are some key aspects of packages:
For example, in Python, you use a tool called “pip” to install and manage the necessary packages.
The packages for GEMBA Note will be explained in the Chapter 8. They are essentially ZIP files that contain tag schemas, aggregation search conditions, shared lists, and paper or note templates that make up the application.In GEMBA Note, content refers to items, tables, shapes, photos, videos, etc. Specifically, standardized documents used for entering or printing information necessary for business or transactions, such as ledgers, forms, and application forms, are called “forms.” In GEMBA Note, these forms are realized by arranging “form components” on the pages of a note.
In this chapter, you will learn how to place form components and create standardized, reusable forms.
Open the note, click the + icon in the navigation menu, then select Add Form Component. Available form components will appear in the toolbox. Click on the desired component and paste it into the current note.
For details about each component, refer to the ‘Form Creation Manual’ in the ‘References’.
Click the desired form component from the toolbox and paste it onto the currently open page.
Manually, the positions of the components may vary horizontally and vertically. To align the components, select them with the Lasso tool, then from the context menu, choose Alignment and then Align Left and Distribute Vertically. This will align the left positions of the components and arrange them at equal vertical intervals.
When form components are placed, they are initially set with default settings. To change the behavior of a component, long-press/right-click the target component, click Form in the context menu, and select (Target Component Name) Settings. The example below shows settings for a single-line text field.
In the toolbox on the right side of the screen, the attribute information for the selected component will appear. Modify these attributes according to your purpose and requirements.
Among the form components, single-line text fields and numeric fields can have an option to select items from a drop-down menu. Settings for these can be adjusted either through the settings on the toolbox or by registering them for shared use within the development package.
To start registration, long-press/right-click on the development package and select More > Manage Shared Lists. Before completing the registration, enter a “password” to prevent unintended changes by other users.
Follow these steps to register property types so that they can be used in the menu:
In the “Property Management Package,” create a new note, place the headings and form components as shown in the diagram, configure each component, and complete the property form.
HTML (Hyper Text Markup Language) is used to create Web pages. The following code shows a Web page that is similar to the Property form.
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Property Information Form</title>
</head>
<body>
<h1>Property Information</h1>
<form method="post" action="something">
<table>
<tr>
<th>Name</th>
<td><input type="text" name="name" placeholder="Enter the property name"></td>
</tr>
<tr>
<th>Property Type</th>
<td><input type="text" name="type" placeholder="Enter the property type"></td>
<!-- Text input sample rather than selecting an item from a menu -->
</tr>
<tr>
<th>Price</th>
<td><input type="number" name="price" placeholder="Enter the price"></td>
</tr>
<tr>
<th>Address</th>
<td><textarea name="address" rows=5></textarea></td>
</tr>
</table>
</form>
</body>
</html>
Generally an action is triggered from a button within the ‘form’ element with input parameters. For example, the button action can send a mail or save input values in a database.
To collect input values for the button action, the ‘name’ attribute and the ‘id’ attribute are referred to. These attributes are correspoinding to ‘tag properties’ of a ‘tag scheme’, which is described in the next chapter.
This HTML file (property.html) exists as a reference material. Inside the HTML file, a CSS file can be referred to for arranging the UI style. However, GEMBA Note does not have such means used uniformly.A schema refers to a description used to define the structure of information. In GEMBA Note, a “tag schema” is prepared to define the structure of pages, shapes, and form components placed on them. By defining the structure, it is possible to perform information retrieval, aggregation, and processing (calculation).
In this chapter, the form created in the previous chapter will be given a data structure, preparing it for aggregation searches in the next chapter.
On the target development package, long press/right-click and select
More > Tag Schema List from the
context menu to start creating a tag schema. When a note is open, you
can also create and edit tag schemas from the navigation menu by
selecting >
Edit Tag Schema.
Add tag properties, which are components of a tag schema. Repeat steps 1 to 3 for each property.
A gear-shaped icon is provided in the section where the Tag ID and Property ID are specified. By clicking here, you can specify display strings in Japanese or English, which will be used as headings when displaying aggregation search results in a table.
Define property information using the tag schema editing function.
Defining a Tag Schema:
Tag ID |
---|
Property |
Definition of Tag Properties:
Property ID | Data Type |
---|---|
Name | String |
Type | String |
Price | Integer |
Address | String |
Set which tag schema the content is related to.
The target for setting can be the page where the note exists, strings on
the form, shapes, form components, or any other components that make up
the content. However, when displaying aggregation search results in a
“box,” this setting will be reflected in the list display.
Here is an example of associating with a page.
Set which tag properties the form components are related to.
Using the link function to tag properties, associate each property form component with the respective property tag property.
Form Components and Tag Property IDs to Link:
Form Component | Tag Property ID |
---|---|
Name | Name |
Property Type | Type |
Price | Price |
Address | Address |
To check the operation of the aggregate search function in the next chapter, prepare data for testing by filling in the values on the property form that is associated with the tag schema and its tag properties.
The article shows how the similar Property schema is defined in SQLite. SQLite is an open-source software and lightweight database management system. It is often embedded in applications rather than used as a server. The SQL syntax defined for the aggregation search to be described in the next chapter comes from those of SQLite.
First download the command-line tools of SQLite from the official site:
[SQLite Official Site] https://www.sqlite.org/download.html
> sqlite3 property_management.db
> create table property(name text, type text, price integer, address text); sqlite
> insert into property values('Green Valley Apartments', 'Apartment', 1200, '5678 Oak Avenue, Apt 3B, Los Angeles, CA 90001');
sqlite> insert into property values('Downtown Office Space', 'Office', 2500, '321 Business Ln, San Francisco, CA 94101'); sqlite
> select * from property; sqlite
> .exit sqlite
Just as data stored in a relational database can be searched using the SQL language, the same can be done in GEMBA Note.
In GEMBA Note, form input data linked to a tag schema can be manipulated as a Tag Database (Tag DB). This is called the “Aggregation” feature. The aggregation search system provides a mechanism to extract and display data that matches the search conditions from the data collected by various DB connectors.
There are two entry points for creating search conditions.
The following diagram shows the process of creating search conditions.
Search conditions are defined by setting the configuration ID, result tag schema, search parameters, connectors, and SQL. The actual entity is an XML file, and you can view its contents by exporting it.
The breakdown of the elements that make up the search condition is as follows.
Component | Description |
---|---|
Configuration ID | Identifies the aggregation search conditions |
Package Information | Identifies the development package |
Extraction Setting | Consists of the extraction table name, connector type (refer to the next page), target tag schema for the search, and connector-specific parameters |
SQL | Describes the method for extracting data from the connector using the database manipulation language SQL |
Result Tag Schema | Represents the tag schema of the search results |
Search Parameters | Corresponds to variables used during the search. They are used within SQL expressions |
There are different types of connectors provided by GEMBA Note, depending on the search methods for tag schemas.
Connector Type | Description |
---|---|
NoteTagDB | Searches the tag database within the same note |
LocalTagDB | Cross-searches tag databases within the same local environment |
ServerTagDB | Cross-searches tag databases within the same server environment |
REST | Searches data sources accessible via HTTP methods such as GET and POST |
Unit | Searches table units within the same note |
Salesforce | Searches from Salesforce Apex REST |
If the connector type is LocalTagDB or ServerTagDB, specify folders to be searched.
Place | Description of the folder element |
---|---|
Home | /home/ |
Personal Folder | /home/private/ |
All Teams | /home/team/ |
Team | /home/team/team_name/ |
Folder within Team | /home/team/team_name/folder1/…/folderN/ |
Folder where the current note exists | /context/ |
Create a condition to search for the property tag schema (ID: Property). The settings for the condition are as follows.
Components of search conditions | Values to be set (example) |
---|---|
Configuration ID | propertyList |
Result Tag Schema | Property |
Table Name | P_TABLE |
Connector Type | LocalTagDB |
Tag Schema to Search | Property |
Target Path for Search | /context/ |
SQL | SELECT * FROM P_TABLE WHERE Name != ’’ |
The WHERE clause means that property data without a property name will not be searched.
SQL (Structured Query Language) is the standard language for interacting with databases. A database contains multiple tables. A table is a collection of data organized into rows and columns. Each row represents a record, and each column represents a data field.
Here are the basic SQL commands:
SELECT: Retrieve data
SELECT name, age FROM users;
-- Get values of the name field and the age field
WHERE: Specifies conditions to filter the data
SELECT * FROM users WHERE age > 20;
-- Get records in the users table where the age value is greater than 20
ORDER BY: Sorts the data by a specific column
SELECT * FROM users ORDER BY age DESC;
-- Get records from the users table in descending order of age value
JOIN: Combines data from multiple tables based on a related column between them
SELECT users.name, orders.order_id
FROM users
JOIN orders ON users.user_id = orders.user_id;
-- Get the values of the name and order_id columns of the records in the users and orders tables that have matching user_id values
GROUP BY and Aggregate Functions
SELECT department, COUNT(*)
FROM employees
GROUP BY department;
-- Get the count for each value of department in the employees table
This chapter explains how to execute the aggregation search conditions defined in the previous chapter. Additionally, it provides an explanation on how to change the values of the tag schema using button actions.
To execute the aggregation search condition created in the previous chapter, first open the note on the development package, then click + > Aggregation on that page to start.
The search results will be added to the note in a tabular format. The table headers will be the columns (tag properties) specified in the SQL statement from the result tag schema defined when setting up the aggregation search conditions.
On the note where the aggregation search condition was executed, you
can update it to the latest content by using a button of the form
components.
Long press/right-click on the placed button to start the
configuration.
By default, the label of the button component changes to “UPDATE”. Change the label name as you wish.
If you right-click on a row for a property, a context menu will appear. By selecting Move to Original Data from the menu, you can jump to the corresponding form and view or edit the content.
When executing a search and using the value of a form component as a search condition, use ‘search parameters’.
The procedure is described here using an example of a condition that narrows down the search results from the value of a form component that allows you to select a property type.
Create a Tag Schema for Search Parameters
Create a tag schema linked to the form component for property type.
Definition of Tag Schema:
Tag ID |
---|
PropertySearch |
Definition of Tag Properties:
Property ID | Data Type |
---|---|
propertyType | String Type |
Prepare the Form Component for the Property Type
Update the Search Condition
Edit the Update Button
Referencing the aforementioned ‘Use Search Parameters,’ place a single-line text field to specify the property type. Define the search conditions so that when you click the Update button, the property list switches to show properties by type.
This command is used to reflect the execution results of the aggregation into the tag property values of the specified tag schema through a button component. It is a convenient command for transferring or processing data.
To reuse the property form, place a “Min Price” button, and when the button is clicked, the name, type, price, and address of the relevant property are reflected in the input components on the form. Define the aggregation search conditions.
The settings for the conditions are as follows:
Search Condition Component | Set Value (example) |
---|---|
Configuration ID | propertyMinPrice |
Result Tag Schema | Property |
Table name | P_TABLE |
Connector Type | LocalTagDB |
Search Tag Schema | Property |
Search Path | /context/ |
SQL | SELECT * FROM P_TABLE WHERE Name != ’’ AND Price > 0 ORDER BY Price LIMIT 1 |
The SQL statement retrieves property data where the property name is set, the price is greater than 0 $, and the first property when sorted in ascending order of price.
In the previous exercise, after extracting the lowest-priced property and saving the note, when executing the propertyList defined in Chapter 5, the same lowest-priced property appears twice. This occurs because the “Result Tag Schema” of propertyMinPrice is the same as the “Search Tag Schema.”
To resolve this, the following modifications are required:
Result tag schemas can be applied for to interpret output data. They are used to show a different set of property values, to change the order of displaying values, and to show calculation results.
A single-line text field or a numeric field allows you to select an item using a drop-down menu. If the candidates of selection are static, you can set them in the settings or a shared list in a development package.
However, if the candidates are changed dynamically, the aggregation feature will be applied to. In this case, the target tag scheme to be used is either StringValue or NumberValue. Both are embedded in the GEMBA Note product.
For example, the settings to allow you to select a property name from all existing properties are as follows:
Search Condition Component | Set Value (example) |
---|---|
Configuration ID | menuProperty |
Result Tag Schema | StringValue |
Table name | P_TABLE |
Connector Type | LocalTagDB |
Search Tag Schema | Property |
Search Path | /context/ |
SQL | SELECT Name as v, Name AS ja, Name AS en FROM P_TABLE WHERE Name != ’’ |
Put a single-line text field on a page and open the settings, choose List Settings > Filter (aggregation) to specify the search condition above.
The user interface of the GEMBA Note product itself can be customized by preparing an XML definition file and importing it into a note or note template.
In the default settings of the GEMBA Note editing screen, all available menus and commands are displayed. For certain content, many commands and menus may be unnecessary for the user. Therefore, the “UI definition file” allows only the necessary menus and commands to be displayed during editing.
To define the UI, names for the UI and IDs used in the XML file are assigned for each area of the editing screen. The following figure illustrates this.
To customize the UI of GEMBA Note, prepare a file in XML format. The main structure is as follows:
<?xml version="1.0" encoding="UTF-8"?>
uicustomsetting xmlns="http://xmlns.metamoji.com/noteanytime/uicustomsetting/1.0" version="1" name="Check for updates by looking at these attribute values.">
<custom key="Key value that distinguishes the custom element">
<name string="Input UI"/>
<navibarleft>
<<!-- Define the left-side menu items -->
navibarleft>
</navibarmode>
<<!-- Define the items to be placed in the center -->
navibarmode>
</navibarright>
<<!-- Define the right-side menu items -->
navibarright>
</pagetab>
<<!-- Define the page tab items -->
pagetab>
</menuset>
<<!-- Define the menus and their items -->
menuset>
</custom>
</uicustomsetting> </
The UI definition file is customized by importing it into a note template or note.
[In the case of a note template]
[In the case of a note]
If there are multiple custom elements in the UI definition file, check which one to use.
Content such as forms you have created can be registered as templates so they can be quickly reused from the menu.
Using a sample UI definition file, you can customize the UI.
Register the property form as a paper template using the following steps.
You can import data from a CSV file using a regisrated template. Try to import property data as follows:
UI definition files, exported tag schema files, and aggregation search condition files are in XML format. Editing these files with a simple text editor like Notepad could potentially corrupt them, so a more advanced text editing tool is needed.
Visual Studio Code (VS Code) is a versatile source code editor provided by Microsoft. VS Code has the following features:
Although it’s not mandatory to install VS Code, as it’s just one of many editors available for editing program code or text, it integrates well with Git, which you’ll likely use later for source file management. For this reason, We recommend using this editor.
Install the software according to your environment from the following URL.
https://code.visualstudio.com/downloadThis chapter explains the process and operations for making the GEMBA Note development packages available to other users.
To publish a developed package to other users, the entire company, or specific teams, follow these steps:
In general, a backup refers to creating a copy of data and storing it on a separate medium to enable recovery in case of equipment failure, data corruption, or loss. Similarly, in GEMBA Note, it is recommended to regularly back up development packages or before starting a new development phase to be prepared for any unexpected situations.
When creating a backup, long press or right-click on the target package development folder.
The saved file will be named
When restoring, select the “Development Package Folder,” then choose the backup file to import from the navigation menu by selecting + > Import File > Backup Format.
Developers can send the package from the package development folder. Create a package file that consolidates the settings, including templates, tag schemas, and aggregation search conditions.
Long press or right-click on the target package development folder.
The saved file will be named
The package manager can publish the development package, created by
the developers, so that it is available for all users. First, click on
in the navigation
menu, then select Manage Packages from the menu.
If the package is not deployed company-wide, it can be published to specific teams. To do this, long press or right-click on the target team folder, and select More from the context menu to begin.
Deploy the Property Management Package using the following steps:
An English word “deploy” has meanings such as “to move”, “to spread out” or “to position.” Regarding software system development, “deployment” refers to making a developed application available by positioning it on a server.
For example, in the case of a web application, the application is made available to users by uploading the executable files to a web server or application server and then starting those files so that the application runs on the server. This entire process is known as deployment.
To perform deployment, preparation is necessary. As part of this preparation, converting source programs into executable files is called “building,” and the process of making the runtime environment, including the executable files, publicly available is called “releasing.”
In the development environment of GEMBA Note, the build process is not required. However, the process of releasing and deploying the development package is necessary due to this background. Generally, deployment requires stopping and restarting the server before and after the deployment process, but GEMBA Note does not require this either.Date | Description |
---|---|
November 26, 2024 | Updated backup file |
October 2, 2024 | Corrected; column -> suppliment, etc. |
August 28, 2024 | Beta version |
July 31, 2024 | Translated in English |
June 26, 2024 | Alpha version |