Ionic Quickstart Database Tutorial
Ionic TodoList sample app for adding, editing, deleting, and updating items in a connected Appery.io database.
Introduction
In this quick start tutorial, you’ll learn how to build a mobile app that displays a list of data from a cloud database. The app communicates with the database via a REST API.
Before You Start
- Tutorial level: beginner; your first mobile app.
- Prerequisites: an Appery.io account.
Want to know more?
You can also check our Appery.io Community video that shows how to create a List Details application with database integration using the Appery.io List Details plug-in here:
Downloads and Resources
You can also try it yourself by creating from the backup:
- Download the app backup file.
- Click Create new app.
- Click From backup and select the project backup file on your drive.
- Type in the app name.
- Click Create:
data:image/s3,"s3://crabby-images/7994f/7994fee45608a81998d9e25ea95ca32ccf3114b1" alt="2023-03-23_11-53-20.png 1027"
Create new app from backup
Defining DB credentials
Note, that if you decide to create from backup but would like to use your database, you will need to modify the default todoDB service in your app.
To do it, in the Project view, unfold the Services > todoDB > todoDB_settings folder and replace the default database_id value with your database ID (can be found in the browser search field or in YOUR DATABASE > Settings > API keys:
data:image/s3,"s3://crabby-images/78205/782054d97a9340ebe9a441af218f0d119365efd4" alt="Untitled.png 3141"
Database ID
But if you are interested in the detailed tutorial, please follow the steps below.
Database Setup
First, we will need to setup the database.
Creating New Database
- Create a new database from the Databases tab, click Create new database:
data:image/s3,"s3://crabby-images/831ff/831fffe3f099e4da5c414bf392c99b767accfeb3" alt="Screen Shot 2020-04-20 at 1.27.48 PM.png 1267"
Create new database
- Name your database todoDB and click Create:
data:image/s3,"s3://crabby-images/a32b0/a32b033e267d3237566d35016227554717998379" alt="Screen Shot 2020-04-20 at 1.29.32 PM.png 506"
Create todoDB database
Adding New Collection to Database
After creating a new database you will see a list of its predefined collections. Also, you can create custom collections.
- Click Create new collection to create a new custom database collection.
- Enter tasks as the collection name and click Add:
data:image/s3,"s3://crabby-images/fb89e/fb89ec3fd23a246fa05701f9e3405d4b869e3f27" alt="Screen Shot 2020-04-20 at 1.46.28 PM.png 1243"
Create tasks collection
Adding New Column to Collection
Then, we need to fill the created collection with data.
- First, select the tasks collection from the list. Click + Col. Name the column taskName, select the String type and click Create column:
data:image/s3,"s3://crabby-images/fd51e/fd51e64dbb9625ce54f494eb9fbeac9ccf2b2631" alt="Screen Shot 2020-04-15 at 9.30.59 AM.png 297"
Create taskName collection
- New taskName column appears in the table:
data:image/s3,"s3://crabby-images/cbe41/cbe4186432015020d5988c6df9c085a151747f89" alt="Screen Shot 2020-04-15 at 9.51.13 AM.png 866"
Create taskName column
- Now, using +Row, enter a few records. For example, add the following tasks:
- Do the task
- Create a new DB
- Create my first app in Appery
- Learn to code, etc.
That's what it should look like:
data:image/s3,"s3://crabby-images/bc47d/bc47da6572d0b520b9981e578f21d886b8353f46" alt="2023-03-23_12-08-28.png 868"
Now the database for our app is ready. Let's move on to creating the app itself.
Mobile App
Creating New App
- From the Apps tab, click Create new app:
data:image/s3,"s3://crabby-images/21fcd/21fcd626637a7d21aa12b50e2518e8601b7a96d0" alt="Screen Shot 2020-04-15 at 9.56.32 AM.png 1226"
Create a new app
- Select Ionic > Ionic Blank as the application type, enter Ionic ToDoList App for the app name, and click Create:
data:image/s3,"s3://crabby-images/90789/9078985bab0561727d92d06ffd30b9fd332a4f8a" alt="2023-03-23_11-56-42.png 1027"
Ionic App create dialog
The first thing you can see is our App Builder Educational Video Guide page with the Project View section on the left where all the predefined project data can be found:
data:image/s3,"s3://crabby-images/f0579/f0579b8387a5d313d3d59ded4ae74dcf8ff177df" alt="2023-03-23_11-59-52.png 1920"
Building UI
- Every new app comes with a default Screen1 page. Let's open it: Pages > Screen1 and under the page PROPERTIES panel, set the Page Footer property to False as we won't need the bottom app toolbar:
data:image/s3,"s3://crabby-images/e738b/e738baeda86c393a7e882f1e586445b7a70f8b6f" alt="ToDo List App _ Apps - Google Chrome 2023-03-23 12.png 1920"
- Click the Toolbar title in the app screen and under the Common tab, change it to My Todo App by changing the Text property on the right menu (or enter the text string right in the mobile frame):
data:image/s3,"s3://crabby-images/25465/25465d9f63dcbc6b0c27a26a2959e07e13c227e7" alt="2023-03-23_12-20-24.png 1920"
Toolbar properties
- In our app, we would need a list for showing the records that we have in the database. So, from the components PALETTE, drag the List component and drop it to the screen:
data:image/s3,"s3://crabby-images/87395/87395b115fbb096999d9013143c25b0f02a43b6a" alt="2023-03-23_12-22-18.png 1666"
List component
- Click the second List item - ListItem2 and click on the red cross to delete it:
data:image/s3,"s3://crabby-images/21692/216927d8e7f00c723ae7964a88b27c3d7eee9f55" alt="2023-03-23_12-23-08.png 1091"
We won't need the second list item since we are going to use a dynamic service for displaying lists in our app.
You can use the OUTLINE view menu and the Breadcrumbs for navigating between the app UI components.
Also, from here, deleting and hiding/showing UI components is possible:
data:image/s3,"s3://crabby-images/e28c1/e28c1f8816d8fb1ac0390a4632c5da9099dbdd61" alt="2023-03-23_12-24-06.png 205"
- Select the ListItem1 component. In the PROPERTIES panel, open the component's Styles tab and set its Class property to todoListItem:
data:image/s3,"s3://crabby-images/c38ae/c38aebe0b871a2734b01778115b20915979c958b" alt="2023-03-23_12-25-16.png 1667"
- Then, switch to the Common tab and add the *ngFor attribute with the let task of tasksList value:
data:image/s3,"s3://crabby-images/d55f4/d55f427db3f482bbe624344b98aae95016b0ac56" alt="2023-03-23_12-26-31.png 1667"
List properties
- Let's now add some flavor to our list element and customize its color. Open the SCSS panel and add the following code:
.todoListItem:nth-child(odd) {
--background: #f2f2f2;
}
- Click SAVE and see if the SCSS file was applied correctly and the styles (the item color changes to grey) were applied on the app DESIGN panel:
data:image/s3,"s3://crabby-images/49a08/49a08ce3d26329c5eed928f80438636c53c269d7" alt="2023-03-23_12-27-43.png 603"
Adding Buttons
Okay, so far, the app looks good! Now let's add some elements to manage our tasks list.
- Under the page DESIGN panel, drag the Button and drop it into the ListItem1 element, placing it to the right:
data:image/s3,"s3://crabby-images/72da5/72da5b8f11f87bdec712472fd9f7d06387d9cd4f" alt="2023-03-23_12-28-50.png 601"
- Now, select the created Button, clear the default Text value and set the following properties:
- Icon > Style = remove
- Icon > Slot = Icon Only
- (click) = deleteTask(task._id):
data:image/s3,"s3://crabby-images/89dcf/89dcff10bf8a03de9792a3581c83eef02bdeed0c" alt="2023-03-23_12-30-07.png 1666"
For the Common > Icon > Style property, click the Default icon button to select (or filter for) the icon you need:
data:image/s3,"s3://crabby-images/91280/91280b5ab52badffc9094d37cb9b2eee14aea260" alt="2023-03-23_12-32-09.png 966"
After that, switch to the component's Styles tab and set the Button Color property to Danger:
data:image/s3,"s3://crabby-images/b9909/b99096c12538bef77cbcf01346995ce65708fdf3" alt="2023-03-23_12-33-35.png 1183"
- Inside the list item, select ItemLabel1 and set its Text property to {{task.taskName}}:
data:image/s3,"s3://crabby-images/31f5f/31f5f91117cfa74689687f1bcb516636571febf4" alt="2023-03-23_12-34-52.png 1666"
- Finally, add another Button component to the ToolbarButtons area, go to its Common tab to clear the default Text value and set its properties to:
- Icon > Style =
add
icon - Icon > Color = primary
- Icon > Slot = Icon Only:
data:image/s3,"s3://crabby-images/bc45d/bc45d5988229abb057f9b5a23f842777d488ae9e" alt="2023-03-23_12-36-39.png 1380"
Button2 layout overview
Creating Task Page
We will need a separate page for adding a new task to the list, so let's create it.
- Click CREATE NEW > Page and name the created page AddTaskPage:
data:image/s3,"s3://crabby-images/444af/444af6eb3de66eeae5346473733e42d1e56db1b8" alt="2023-03-23_12-38-02.png 1249"
Create new page
Note that the Create navigation route for this page check box is selected. You can find and edit all routes in the Project menu > Routing asset.
- On the new page, disable the Page footer by setting its Footer property to False. Also, change the Toolbar Title Text to Add new task:
data:image/s3,"s3://crabby-images/bcbe9/bcbe954026524372176f5a1abfdc988dad4cf66d" alt="2023-03-23_12-40-38.png 1915"
- Drag a Button element and drop it into the Toolbar Buttons area. We will use this button for back navigation. To do this, under the Common tab, change the Comp. Type value to Ionic Back Button in the PROPERTIES panel.
- Next, unfold the Back Button group and set the Text property to Back:
data:image/s3,"s3://crabby-images/430d8/430d83e51847ed783b722e2ae3bb55ec277eb1a7" alt="2023-03-23_12-43-04.png 1692"
Back button properties
To enter the names of new tasks, we will need an Input component.
- Let's drag it to the page from PALETTE and set the following Common tab properties:
- Placeholder = Enter task
- Label >Text = empty
- [(ngModel)] = newTaskName
data:image/s3,"s3://crabby-images/2f197/2f197930a7ec1d300f628f43d51305f596f1c4dd" alt="2023-03-23_12-44-49.png 1695"
- Then, under the input, add another Button that will be used to save the entered tasks. Set its Common > Text property to Add Task:
data:image/s3,"s3://crabby-images/6fd7e/6fd7ea7d3b541fe6a80debd925cba3531a8f5f28" alt="2023-03-23_12-46-40.png 1105"
That's it, the app UI is ready and we can move on to implementing the app logic.
Application Logic
Getting Tasks List
The first thing we need to do is to get the full list of tasks from the database.
- Go to Screen1 CODE panel. In the Variables section, enter
tasksList
as a variable name, click Add and change the type of the created variable to Any:
data:image/s3,"s3://crabby-images/920e7/920e7af5ddfdbedc8cfa85f08656ea5a460ba0c2" alt="2023-03-23_12-47-54.png 1023"
- Click Create New > Database Service and select the todoDB database from the drop-down. Expand the list of the tasks collection services and select the Create, List and Delete services. Click Import selected services:
data:image/s3,"s3://crabby-images/39199/39199490e1b413b694ddd05b9ec395d4b0ebcc19" alt="Untitled1.png 1249"
Import database services
- After importing the database services, they should appear in the Project tree in the Services > todoDB folder:
data:image/s3,"s3://crabby-images/cf2ff/cf2ffe52d638c04ef5f99fd26536e5038096c7ff" alt="2023-03-23_12-52-20.png 281"
- Now we need to use these services in our app. Under the Project > Pages folder, navigate to the Screen1 DATA panel. Here, add the todoDB_tasks_list_service as a datasource and change the service's generated local name to getTasksList:
data:image/s3,"s3://crabby-images/0f951/0f95144857d0dda19433d323b54ec67ffbd81406" alt="2023-03-23_12-53-29.png 1892"
- Then, we need to save the data that is returned from the service to the variable. Click the Mapping button next to the service's Success event:
data:image/s3,"s3://crabby-images/53dbf/53dbf185d493bc04fa69549fbb97536162d83ce0" alt="Screenshot_33.png 507"
- Map the service response to the
tasksList
variable. Don't forget to click Save & Replace after that:
data:image/s3,"s3://crabby-images/4325e/4325e80a2a787fe0502ea4fdbb4023c8542611bc" alt="2023-03-23_13-14-07.png 1625"
- As we need to load the list of tasks on the page load, let's add the required event. Go back to the DESIGN panel. In the EVENTS tab for the Page component, add the Before page showing event. Select Invoke service as the Action and getTasksList service as the Datasource. Click Save:
data:image/s3,"s3://crabby-images/c3730/c3730cc37845daad9092345f35cb7c1594340813" alt="2023-03-23_12-56-56.png 1628"
The service will be invoked each time you enter the Screen1 page, and the list of tasks will be loaded from our database.
- Also, let's set up some routing. We need to navigate to the AddTaskPage when the user clicks the
+
button in the toolbar. To do that, select the Button2 component inside the Toolbar Buttons area and create a new Click event in the EVENTS tab. Select Navigate to page as the Action and AddTaskPage as the Route name. Click Save:
data:image/s3,"s3://crabby-images/404d0/404d0e11c4ea5a314a3c93ad3f9ebfbf49c322ec" alt="2023-03-23_12-59-04.png 1627"
At this point, we can test our app in the browser. Click the TEST button in the App Builder Toolbar to launch the app. Check that tasks will appear on the app screen, and you can navigate to the AddTasksPage by clicking on the + button in the toolbar. Also, make sure that the back navigation works too:
data:image/s3,"s3://crabby-images/e286e/e286e774715f5b7d518883498aaa7adff43d6f0e" alt="Animation1.gif 428"
Deleting Tasks
Let's proceed with the app. The next thing we need to do is to implement the functionality to remove tasks from the list.
- Go to the Screen1 CODE panel. Scroll to the Functions section and create a Method named
deleteTask
withtaskId
as its argument. - From the list of services on the left, drag the todoDB_task_delete_service and drop it into the function code window. This will automatically add the code of the service invocation:
data:image/s3,"s3://crabby-images/b6469/b6469c5de0a8b37df53cae7591a60356d3180558" alt="Animation2.gif 1178"
- Add some edits to the code. Insert the Execute DataService snippet instead of
console.log(res);
(line 13). Replace"service_name"
with"getTasksList"
which is the name of the previously imported service. This will reload the list of tasks from the database right after one of them is removed:
data:image/s3,"s3://crabby-images/d3aee/d3aee25ce22e8679692ad8cd7cf06a597a10b86c" alt="Screen Shot 2020-04-15 at 6.42.29 PM.png 875"
- Then, add
"_id": taskId
to the params block. Save the changes. As a result, the function code will look like this:
data:image/s3,"s3://crabby-images/9fc66/9fc66b048004e8239b28f6f73893062f9df427da" alt="2023-03-23_13-09-28.png 1831"
deleteTask code
Adding Tasks
Now we can remove tasks from the list, but we also need the ability to create new ones.
- Now, open the CODE panel of the AddTaskPage, and add a new variable to store the name of a new task. Enter
newTaskName
as its name and select the String type:
data:image/s3,"s3://crabby-images/e67ee/e67eedbed12bfdbf09c356f4f9ebb4c210451768" alt="2023-03-23_13-11-01.png 1096"
- Navigate to the page DATA paneland add the todoDB_tasks_create_service as the new Datasource. Change its local name to createTask:
data:image/s3,"s3://crabby-images/b2391/b2391afe179bd71d633181ca039002000196858b" alt="2023-03-23_13-12-04.png 1912"
- Then, click the Mapping button next to the Before send event and map the newTaskName variable to the taskName service request parameter. After editing, click Save & Replace:
data:image/s3,"s3://crabby-images/48609/486097996f4d76dfb75647af159af73b95f660f3" alt="2023-03-23_13-13-16.png 1625"
- Also, we need to clear the input field if the task was successfully added. Click Add next to the Success event and select Run TypeScript in the list. In the code editor, type in
this.newTaskName = "";
and click Save:
data:image/s3,"s3://crabby-images/c0d36/c0d36eaa43cb3641b27135860f9fc936f9c49833" alt="Screen Shot 2020-04-15 at 7.20.18 PM.png 1226"
- And the last thing we need to do when the task is successfully added is to return to the main page. Сlick the Add button next to the Success event again. Select Navigate to page as the Action and Screen1 as the Route name. Don't forget to save the changes:
data:image/s3,"s3://crabby-images/58235/58235879aa694aa2c7a8ce80b5b15efd6c50b718" alt="Screen Shot 2020-04-15 at 7.33.19 PM.png 1237"
- And finally, we need to invoke the createTask service when the user clicks the Add task button. So, go to the DESIGN panel, unfold the EVENTS tab from the bottom and for the Button2 component create a new Click event. Select Invoke service as the Action and createTask as the Datasource:
data:image/s3,"s3://crabby-images/fc441/fc441fafad5fedcb1b0b749ebde545a44fa3d8f2" alt="2023-03-23_13-16-59.png 1628"
Editing Tasks
Let's also add the ability to edit the existing items on the todo list.
- In the App Builder, click CREATE NEW > Database Service. Here, select the todoDB database from the drop-down. Expand the list of the tasks collection services and select the Update service. Click Import selected services:
data:image/s3,"s3://crabby-images/b7af8/b7af8cb9d6fe167e1ab0430dfec59e4d6f67509a" alt="Screenshot_50.png 594"
-
Go to Screen1 page's DESIGN panel. Here, drop one more Button into the ListItem1 element, placing it next to the existing button.
-
Now, select the created button, and under the Common tab, set the following properties:
- Icon > Style =
create
icon - Icon > Slot = Icon Only
- Text = empty
- (click) = editTask(task._id, task.taskName):
data:image/s3,"s3://crabby-images/41f0a/41f0ac45bddee60ef542ed3893c4bd20dbc9926a" alt="2023-03-23_13-20-30.png 1652"
- Then, switch to the CODE panel and in the Functions section create a new Async method named editTask with taskId and taskName as its arguments and the following code:
const alert = await this.Apperyio.getController("AlertController").create({
header: 'Edit task',
inputs: [{
name: 'task',
type: 'text',
value: taskName
}],
buttons: [{
text: 'Cancel',
role: 'cancel',
cssClass: 'secondary',
}, {
text: 'Edit',
handler: (res) => {
if (res.task.length) {
this.Apperyio.getService("todoDB_tasks_update_service").then(
service => {
if (!service) {
console.log("Error. Service was not found.");
return;
}
service.execute({
data: {
taskName: res.task
},
params: {
_id: taskId
},
}).subscribe(
(res: any) => {
this.Apperyio.execDataService(this, "getTasksList");
},
(err: any) => {
console.log(err)
}
)
}
)
}
}
}]
});
await alert.present();
data:image/s3,"s3://crabby-images/1afac/1afacc270591267bfc876ef7fff75b9a1968dd4b" alt="2023-03-23_13-23-41.png 1543"
Save all the app changes, and we are ready to test the app!
Testing App
Click the TEST button in the App Builder Toolbar to launch the app in the browser.
Try removing tasks from the list, creating new and editing existing ones. Everything should work as follows:
data:image/s3,"s3://crabby-images/e8608/e860859a07bf37e98acd7c022c24e5d4f07fefdc" alt="Animation3.gif 423"
When testing, you can open your database (here, it's todoDB) to check its tasks custom collection and make sure that new file entries are already there (you may need to click the Refresh button to update the list):
data:image/s3,"s3://crabby-images/e2aa3/e2aa329954f2ff6578104df935668dff2c2e7f8b" alt="2023-03-23_13-27-40.png 1233"
Testing on Device
Now, 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/49260/492602b9da39faca5a6832428ae4522a18abe6e2" alt="2023-03-23_13-28-59.png 467"
Want to know more?
You might also like to check our advanced ToDo List tutorial that uses an external PostgreSQL database with creating a secured API Express project.
Updated about 1 month ago