Ionic ngx-datatable Tutorial Basic
Introduction
This sample app tutorial and part 1 (basic part) of the ngx-datatable Ionic application tutorial that provides step-by-step instructions to walk you through the process of developing a basic DataTable Ionic application where you can apply sorting:
Downloads and Resources
You can also download the basic Ionic DataTable basic app backup file to import it under your account. In this case, the database and the database service will be imported automatically.
Pre-condition
There are some important pre-conditions to make your app work: you will need to make sure the database and a related database service are created; please, check Steps 1 and 2 for details.
Step 1: Creating Database
Let's start by creating a database where the data will be stored.
data:image/s3,"s3://crabby-images/db6f9/db6f93bc26ee17bc4c97275abc01d1804551eb41" alt="03-28 12.41..png"
- Click Create new collection and, in the new window, enter the new custom collection name: BooksList.
- Click +Col to add two columns both of String type: Title and Author:
data:image/s3,"s3://crabby-images/9e56f/9e56fa522fd7d62bfc0a2bef135f71bc26430f8e" alt="03-28 12.44..png"
- Then, add another column with Name= Year and type = number.
- Finally, add one more column: Image of the file type for uploading all the needed book cover images:
data:image/s3,"s3://crabby-images/0b799/0b799d0fae8feeca3dee7f768bee44ad13606d41" alt="03-28 12.48..png"
- To add some sample data, click +Row and fill in the table rows.
Uploading Media to Database
To upload the images for the book covers (need to be prepared beforehand), use the Media Manager tool:
data:image/s3,"s3://crabby-images/8fef4/8fef48fecc98b50ef7d2f003a22e95df5a2474f1" alt="1.gif"
- When ready, click Refresh to see the table with sample collection data:
data:image/s3,"s3://crabby-images/3429e/3429ee926d2e43540b580b2000efd51f29b3de2d" alt="03-28 12.58..png 1240"
BooksDB
Downloads and Resources
- You can also download the database backup file from this step to import it to your own app.
- You might like to get more information from Appery.io Database documentation.
Step 2: Creating Database Service
To create a new database service:
- We need to, first of all, create a new Ionic app (Blank); you can name it Ionic DataTable Basic App:
- Now, we can proceed with creating a service for our database. Click CREATE NEW > Database Service:
data:image/s3,"s3://crabby-images/38cbc/38cbc262a9d4405f0411bf7fc41b09e1847ba685" alt="03-28 13.13..png 244"
- In a new window, select the database we have just created (BooksDB), select the List service of the BooksList collection (expand it first) and confirm import:
data:image/s3,"s3://crabby-images/4bf82/4bf827219f57225a4e30ae153ed43c911a5637de" alt="03-28 13.15..png 536"
Importing DB sevices
The services will be instantly imported under the Project tab Services folder:
data:image/s3,"s3://crabby-images/1faa2/1faa25a6f3408dca88ce22f4822aad4960405e04" alt="03-28 13.150..png 260"
data:image/s3,"s3://crabby-images/3fe49/3fe499bb25798cec5120af7edd0201a8e83a77c3" alt="03-28 13.20..png"
- Hover the mouse cursor over the DataTable Context menu and click the green plus icon to add two more DataTable columns so that there are 4 of them in the table:
data:image/s3,"s3://crabby-images/f0447/f04472e3267ee16d117fa44c4372d07d48c74e5c" alt="03-28 13.25..png 589"
Adding DataTable columns
- Now, switch to the screen DATA panel and, for datasource, select the created before BooksDB_BooksList_list_service and click the Add button:
Customizing Service Name
You can change the name of your service to for e.g. BooksList.
data:image/s3,"s3://crabby-images/b2421/b2421401e287bf0db5f5f2b33f2789c1cff765d2" alt="03-28 13.28..png 1593"
Adding new datasource
- Click the Success mapping button and, in the mapping editor, click the Expand all link for both Service response and Page. We should relate our service with the DataTable component and bind the service scope with the rows of our DataTable as well as the columns of the table. To do it, create the below mapping and save:
data:image/s3,"s3://crabby-images/838b9/838b9a7c222d8c5146dd38e99e37faac69f0a970" alt="03-28 14.08..png 1322"
Service Success mapping
- Go back to the DESIGN panel and select the DataTable1 component.
You can also use the OUTLINE view menu or the Breadcrumbs for navigating between the app UI components:
data:image/s3,"s3://crabby-images/0623d/0623d59b197ef94368d124fb4afff07bb9034a58" alt="03-28 14.11..png"
- Under the PROPERTIES panel, expand the Data Mode property, leave Client Pages for Mode, then select our service (BooksList) for Service Name.
data:image/s3,"s3://crabby-images/7797d/7797d0b33ed57faca772eeb5c7b54965689fd54b" alt="03-28 14.14..png 1598"
Configuring Data Mode
- To initialize the table, expand the EVENTS tab and select the Page component from the list. For EVENT, select Before page showing and then select [DataTable update](https://docs.appery.io/docs/5-event-handling#datatable-update) for the ACTION drop-down with indicating our DataTable1 component. Save the event:
data:image/s3,"s3://crabby-images/58279/58279149dc287bd5da236896437c2a60d0e4a012" alt="03-28 14.18..png 1597"
Setting up Page event
Step 3: Defining App UI
- On the Screen1 DESIGN panel and use the Breadcrumbs to select the Page component. Then, under its PROPERTIES panel, set the Footer property to False. After that, select the Header Toolbar title component and enter Books to read for its Text property:
data:image/s3,"s3://crabby-images/54950/54950ed17ccf3d43209da557cc148d12aa5dde8d" alt="03-28 14.22..png 1595"
Defining Toolbar Title
- Now, select the DataTable1 component and go to its PROPERTIES panel to define it as follows:
- Selection Type: Checkbox;
- Limit: 2;
- ScrollbarH: true.
- Expand Messages and type in Data is missing for Empty Message.
- Now, expand Sorts and, for Column Name, insert Year; for Direction, select asc:
data:image/s3,"s3://crabby-images/63e62/63e62cd3bf45f050e91d00fa95ef9f1a3ccbf9bd" alt="03-28 14.27..png 1598"
Defining DataTable properties
-
Next, select the first column of the table, DataTableCol1, this is where the database image files will be mapped to. Under the PROPERTIES panel, define the following DataTableCol1 properties as follows:
- Checkboxable: true;
- Header Checkboxable: true;
- Max Width: 120;
- Name: Image.
-
Also, click the Editbutton of the Cell Template property and enter the next code:
<ion-img src = "https://api.appery.io/rest/1/db/files/PUT YOUR DB ID HERE/{{value}}"></ion-img>
The DataTableCol1 component's properties should look like this:
data:image/s3,"s3://crabby-images/3cc64/3cc6495347bddfac6a050c16509d1a2459a780d1" alt="03-28 14.33..png"
Database ID Credentials
Note that inside the script, you will need to replace the PUT YOUR DB ID HERE template with your database ID (can be found in the browser search field or in YOUR DB > Settings > API keys):
data:image/s3,"s3://crabby-images/2533c/2533c4f1df6b1602e469da2ea68c8fea7529cb87" alt="DB_ID.jpg 713"
Locating your database ID
Note!
You might also like to adjust the UI components properties of other table columns to fit the needed content, for example, we used the next Max Width property values for our table columns:
- DataTableCol2 = 150,
- DataTableCol3 = 120,
- DataTableCol4 = 80.
Step 4: Testing App
Now, your app looks well-rounded and should work as expected.
Click TEST in the App Builder Toolbar to check:
data:image/s3,"s3://crabby-images/e39ee/e39ee34b5950035242cf0b6701f476ab28e22fed" alt="Untitled.png 1407"
App in work
Testing on Device
When your app version is ready, you might also like to test it on the device.
Appery.io Tester App
A great option to quickly test the app on the device is to use our Appery.io Tester app.
The app is free and available for both iOS and Android.
You can check out this page to learn more about using the Appery.io Tester app.
data:image/s3,"s3://crabby-images/533ac/533ac83717ab291a6f063b15a03a6e7e499c055d" alt="06-07 12.57..png 467"
Updated about 1 month ago
It's time that we proceed with the Advanced tutorial that shows how to create an Ionic app by using API Express service.