<h4>What Will I Learn?
<p dir="auto">Write here briefly the details of what the user is going to learn in a bullet list.
<ul>
<li>Integrate Realm in an iOS project
<li>Create a simple to do list iOS using tableView and Realm
<li>Browse Realm Data using Realm Studio
<h4>Requirements
<p dir="auto">Write here a bullet list of the requirements for the user in order to follow this tutorial.
<ul>
<li>Xcode
<li>Understanding of CocoaPods files
<li>Understanding of Objective-C programming language
<li>Basic understanding of Realm
<li>Protocol and delegate in iOS development
<li>UITableView iOS components
<li>AutoLayout constraining
<h4>Difficulty
<ul>
<li>Intermediate
<h4>Tutorial Contents
<p dir="auto"><b>What is Realm?<br />
Realm is a mobile platform and a replacement for SQLite & Core Data. Build offline-first, reactive mobile experiences using simple data sync. We'll using Realm that use Objective Language. Realm is a very powerful platform that help you build offline app and can sync to the server though. When one data is update in a specific realm object, it will update in a real-time.
<p dir="auto"><b>Integrate Realm in an iOS project<br />
Make sure you have install Cocoapods to your project first. In order to integrate Realm in our project, we must first do the following steps:
<ul>
<li>Run this command <code>pod repo update to make CocoaPods aware of the latest available Realm versions.
<li>Open up the Podfile and add <code>pod 'Realm' to the app target and <code>pod 'Realm/Headers' to the test target.<br />
<img src="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516459893/qmjhcdkntv52h2x16mkp.png" alt="Screen Shot 2018-01-20 at 9.51.10 PM.png" srcset="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516459893/qmjhcdkntv52h2x16mkp.png 1x, https://images.hive.blog/1536x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516459893/qmjhcdkntv52h2x16mkp.png 2x" />
<li>Open up your terminal, change the directory to the project and install it using <code>pod install command
<li>Once finished, open the xcworkspace to get started with the Realm<br />
<img src="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516460346/wswtwemwhjio3jgd1rhi.png" alt="Screen Shot 2018-01-20 at 9.58.34 PM.png" srcset="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516460346/wswtwemwhjio3jgd1rhi.png 1x, https://images.hive.blog/1536x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516460346/wswtwemwhjio3jgd1rhi.png 2x" />
<p dir="auto"><b>Defining Task Model Class<br />
Model is just like a table representative in a database. Before we go further, we need to make our model first. We'll make our class named <code>Task to manipulate data with our tasks later. Follow these steps:
<ul>
<li>For neat folder structure i recommend create a model group folder first by clicking AlertDemoApp folder first and Choose New group option.<br />
<img src="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516461048/bk8kuhao3b5nwhox4xab.png" alt="Screen Shot 2018-01-20 at 10.10.05 PM.png" srcset="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516461048/bk8kuhao3b5nwhox4xab.png 1x, https://images.hive.blog/1536x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516461048/bk8kuhao3b5nwhox4xab.png 2x" />
<li>Rename the folder to "Model"<br />
<img src="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516461098/fddvnnhvih1vouqyi8fl.png" alt="Screen Shot 2018-01-20 at 10.11.13 PM.png" srcset="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516461098/fddvnnhvih1vouqyi8fl.png 1x, https://images.hive.blog/1536x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516461098/fddvnnhvih1vouqyi8fl.png 2x" />
<li>Point your cursor to the model folder and choose New File<br />
<img src="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516461263/vkcuokzjkgnm4szpn7tg.png" alt="Screen Shot 2018-01-20 at 10.13.49 PM.png" srcset="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516461263/vkcuokzjkgnm4szpn7tg.png 1x, https://images.hive.blog/1536x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516461263/vkcuokzjkgnm4szpn7tg.png 2x" />
<li>Choose Cocoa Touch Class<br />
<img src="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516460616/t250fvzhrjglj6kraufi.png" alt="Screen Shot 2018-01-20 at 10.02.33 PM.png" srcset="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516460616/t250fvzhrjglj6kraufi.png 1x, https://images.hive.blog/1536x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516460616/t250fvzhrjglj6kraufi.png 2x" />
<li>Name it depending on your needs. In this case, we give the name the model class <code>Task<br />
<img src="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516460788/zy8nutbxbf5lfjji4jug.png" alt="Screen Shot 2018-01-20 at 10.03.59 PM.png" srcset="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516460788/zy8nutbxbf5lfjji4jug.png 1x, https://images.hive.blog/1536x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516460788/zy8nutbxbf5lfjji4jug.png 2x" />
<li>Click Create and Finish<br />
After the above steps done, create these 2 properties in the Task.h file by write the following code.
<pre><code>//
// Task.h
// AlertDemoApp
//
// Created by Andri on 1/19/18.
// Copyright © 2018 Andri. All rights reserved.
//
#import <Realm/Realm.h>
@interface Task : RLMObject
@property NSString *taskId;
@property NSString *name;
@end
<p dir="auto">The taskId property will represent id of each task.<br />
The name property will represent name of each task.<br />
<b>Creating UITableView Cell<br />
UITableViewCell is the cell representing each row in a tableview. Create by doing the following steps:
<ul>
<li>File -> New -> CocoaTouchClass
<li>Give the name and don't forget to check the Also create XIB file. This will create 3 files consist of .h file, .m file and the XIB file<br />
<img src="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516462016/htozlxrc8hzkgbfpvkcm.png" alt="Screen Shot 2018-01-20 at 10.26.07 PM.png" srcset="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516462016/htozlxrc8hzkgbfpvkcm.png 1x, https://images.hive.blog/1536x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516462016/htozlxrc8hzkgbfpvkcm.png 2x" />
<li>Open the DemoTableViewCell.xib file and drag a UIButton to the xib file like below (We don't need to drag a UILabel because we'll use textLabel built-in from the UITableViewCell)<br />
<img src="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516462211/sg42oj0urtwkko7m1di8.png" alt="Screen Shot 2018-01-20 at 10.29.21 PM.png" srcset="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516462211/sg42oj0urtwkko7m1di8.png 1x, https://images.hive.blog/1536x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516462211/sg42oj0urtwkko7m1di8.png 2x" />
<li>Then Drag in a UIButton and named it "Delete"
<li>Set the constraint of x axis of the UIButton by dragging the element to right of space and choose Trailing Space to container
<li>Set the constraint of y axis of the UIButton by dragging the element to top of space and click Top Space to the container<br />
<img src="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516462970/iuyeua7ep3aqf7wl6qzm.png" alt="Screen Shot 2018-01-20 at 10.42.24 PM.png" srcset="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516462970/iuyeua7ep3aqf7wl6qzm.png 1x, https://images.hive.blog/1536x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516462970/iuyeua7ep3aqf7wl6qzm.png 2x" />
<li>Open Assistant Editor <img src="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516464171/jrgka5frrt7hdvgxidbl.png" alt="Screen Shot 2018-01-20 at 11.02.31 PM.png" srcset="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516464171/jrgka5frrt7hdvgxidbl.png 1x, https://images.hive.blog/1536x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516464171/jrgka5frrt7hdvgxidbl.png 2x" />
<li>Drag the delete Button to the DemoTableViewCell.h as follow to be used later<br />
<img src="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516464285/gliwkilkgtcmxlmtx9cf.png" alt="Screen Shot 2018-01-20 at 11.02.01 PM.png" srcset="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516464285/gliwkilkgtcmxlmtx9cf.png 1x, https://images.hive.blog/1536x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516464285/gliwkilkgtcmxlmtx9cf.png 2x" /><br />
<b>Creating the .h file<br />
In order to use our Realm and model class we defined, we must import them using these lines
<pre><code>#import <UIKit/UIKit.h>
#import "Task.h"
#import <Masonry/Masonry.h>
#import "DemoTableViewCell.h"
<p dir="auto">Once we imported them, we can use them later. Now declare the:
<ul>
<li>UITextField for user to input task
<li>UITableView to display the list of task
<li>NSMutableArray to save and get data of the Realm<br />
A protocol declares a programmatic interface that any class may choose to implement. Protocols make it possible for two classes distantly related by inheritance to communicate with each other to accomplish a certain goal. A delegate is an object that acts on behalf of, or in coordination with, another object when that object encounters an event in a program.<br />
Don't forget to conform to <code>UITableViewDelegate protocol and <code>UITableViewDataSource protocol because we will implement the delegate method in our .m file<br />
Create them by writing this following entire .h file
<pre><code>//
// RealmViewController.h
// AlertDemoApp
//
// Created by Andri on 1/16/18.
// Copyright © 2018 Andri. All rights reserved.
//
#import <UIKit/UIKit.h>
#import "Task.h"
#import <Masonry/Masonry.h>
#import "DemoTableViewCell.h"
@interface RealmViewController : UIViewController<UITableViewDelegate, UITableViewDataSource>{
UITextField *textField;
UITableView *tableView;
NSMutableArray<Task*> *taskArray;
}
@end
<p dir="auto"><b>Setup the UI<br />
Now, we will create a function named setupUI to create our views as well. We will create a label, a textField, a button and a tableview in this function. Write the following code.
<pre><code>- (void)setupUI{
self.view.backgroundColor = [UIColor whiteColor];
taskArray = [[NSMutableArray alloc] init];
UILabel *taskLabel = [UILabel new];
taskLabel.text = @"Task";
[taskLabel setFont:[UIFont systemFontOfSize:24]];
[self.view addSubview:taskLabel];
[taskLabel mas_makeConstraints:^(MASConstraintMaker *make) {
make.centerX.equalTo(self.view);
make.top.equalTo(self.view).offset(16);
}];
textField = [UITextField new];
textField.textColor = [UIColor colorWithRed:0/256.0 green:84/256.0 blue:129/256.0 alpha:1.0];
textField.font = [UIFont fontWithName:@"Helvetica-Bold" size:14];
textField.backgroundColor=[UIColor whiteColor];
[textField setBorderStyle:UITextBorderStyleLine];
[self.view addSubview:textField];
[textField mas_makeConstraints:^(MASConstraintMaker *make) {
make.left.equalTo(self.view).offset(16);
make.right.equalTo(self.view).offset(-16);
make.top.equalTo(taskLabel.mas_bottom).offset(16);
make.height.mas_equalTo(44);
}];
UIButton *addTaskButton = [UIButton buttonWithType:UIButtonTypeCustom];
[addTaskButton setTitle:@"Add" forState:UIControlStateNormal];
[addTaskButton setTitleColor:[UIColor blueColor] forState:UIControlStateNormal];
[addTaskButton addTarget:self action:@selector(addDidTap) forControlEvents:UIControlEventTouchUpInside];
[self.view addSubview:addTaskButton];
[addTaskButton mas_makeConstraints:^(MASConstraintMaker *make) {
make.centerX.equalTo(taskLabel);
make.top.equalTo(textField.mas_bottom).offset(16);
}];
tableView = [UITableView new];
tableView.backgroundColor = [UIColor whiteColor];
tableView.delegate = self;
tableView.dataSource = self;
tableView.estimatedRowHeight = 100;
tableView.rowHeight = UITableViewAutomaticDimension;
tableView.separatorInset = UIEdgeInsetsMake(0, 24, 0, 24);
[self.view addSubview:tableView];
[tableView registerNib:[UINib nibWithNibName:@"DemoTableViewCell"
bundle:[NSBundle mainBundle]]
forCellReuseIdentifier:@"DemoTableViewCell"];
[tableView mas_makeConstraints:^(MASConstraintMaker *make) {
make.left.bottom.right.equalTo(self.view);
make.top.equalTo(addTaskButton).offset(48);
}];
[self fetchTask];
}
<p dir="auto">In the above codes, we also use this line to register our DemoTableViewCell to the tableview. We also assign taskArray using <code>[[NSMutableArray alloc] init] because we'll use to save and delete each task to the array.
<pre><code>[tableView registerNib:[UINib nibWithNibName:@"DemoTableViewCell"
bundle:[NSBundle mainBundle]]
forCellReuseIdentifier:@"DemoTableViewCell"];
<p dir="auto"><b>Create Fetching All Tasks Data Function<br />
You may notice in the setupUI we call the fetchTask function. Now that we have setup the UI, we need to create a function that fetch data from the realm to display it later. Write the following code
<pre><code>- (void)fetchTask{
RLMResults<Task *> *tasks = [Task allObjects];
for (RLMObject *object in tasks) {
Task *task = [[Task alloc] initWithValue:object];
[taskArray addObject:task];
}
}
<p dir="auto">Explanation:<br />
<code>RLMResults<Task *> *tasks = [Task allObjects]; means we get allObjects of the Task Realm and assign it to RLMResults which is tasks variable<br />
We then create a single task and loop until the tasks end. Then, add the task object to taskArray in these lines
<pre><code>for (RLMObject *object in tasks) {
Task *task = [[Task alloc] initWithValue:object];
[taskArray addObject:task];
}
<p dir="auto"><b>Add task to the realm<br />
We'll create addDidTap method that will be triggered when <code>addTaskButton is tapped. We'll also save what the user input the Task Realm. First, create the task object and assign the taskId & name to the task object by writing the following code.
<pre><code>Task *task = [[Task alloc] init];
task.taskId = [NSUUID UUID].UUIDString;
task.name = textField.text;
<p dir="auto">We assign the textField.text to our <code>task.name. Because Realm hasn't any auto incremental primary keys. You should set it for each record. You can use a unique primary key for each record. That's why we'll assign the taskId to <code>[NSUUID UUID].UUIDString.<br />
After that, we'll need to do transaction with our realm to save the task the user input. Do that by writing the following code.
<pre><code>RLMRealm *realm = [RLMRealm defaultRealm];
[realm transactionWithBlock:^{
[realm addObject:task];
}];
<p dir="auto">Once finished, add the task to taskArray and reload the tableView to display in a real-time. We also clear the textfield when user has added the task
<pre><code>[taskArray addObject:task];
[tableView reloadData];
textField.text = @"";
<p dir="auto">We're done with the add to realm functionality. This is the method of addDidTap function
<pre><code>- (void)addDidTap{
Task *task = [[Task alloc] init];
task.taskId = [NSUUID UUID].UUIDString;
task.name = textField.text;
RLMRealm *realm = [RLMRealm defaultRealm];
[realm transactionWithBlock:^{
[realm addObject:task];
}];
[taskArray addObject:task];
[tableView reloadData];
textField.text = @"";
}
<p dir="auto"><b>Implement delegate methods of tableView<br />
Now that we have setup our tableview in setupUI method, we will implement the delegate methods of the tableview. First of all, this delegate method return count of our taskArray.
<pre><code>-(NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section{
return taskArray.count;
}
<p dir="auto">After done with that, we will configure our each cell and the listeners in this delegate method
<pre><code>-(UITableViewCell*)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath{
}
<p dir="auto">Inside the method, we first declare the cell using the <code>dequeueReusableCellWithIdentifier method. Then, check if it is nil we use UITableViewStyleDefault and give identifier.
<pre><code>static NSString *identifier = @"DemoTableViewCell";
DemoTableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:identifier];
if (nil == cell) {
cell = [[DemoTableViewCell alloc] initWithStyle:UITableViewCellStyleDefault
reuseIdentifier:identifier];
}
<p dir="auto">After done with that, we'll set our taskArray that we get from the realm and display it using the indexPath.row index
<pre><code>cell.textLabel.text = taskArray[indexPath.row].name;
<p dir="auto">Then, we add listener delete button in the cell and assign the tag using indexPath.row so we can track which cell we are selecting.
<pre><code>[cell.deleteButton addTarget:self action:@selector(deleteDidTap:) forControlEvents:UIControlEventTouchUpInside];
cell.deleteButton.tag = indexPath.row;
<p dir="auto">This is the full delegate methods code
<pre><code>#pragma mark - uitable
-(NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section{
return taskArray.count;
}
-(UITableViewCell*)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath{
static NSString *identifier = @"DemoTableViewCell";
DemoTableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:identifier];
if (nil == cell) {
cell = [[DemoTableViewCell alloc] initWithStyle:UITableViewCellStyleDefault
reuseIdentifier:identifier];
}
cell.textLabel.text = taskArray[indexPath.row].name;
[cell.deleteButton addTarget:self action:@selector(deleteDidTap:) forControlEvents:UIControlEventTouchUpInside];
cell.deleteButton.tag = indexPath.row;
return cell;
}
<p dir="auto"><b>Creating the delete functionality<br />
Now that we have the add functionality, we will make for delete too. Remember to include the sender parameter because we need to get the tag of our selected that indicates the index of the cell.
<pre><code>- (void)deleteDidTap:(UIButton*)sender{
}
<p dir="auto">Inside the method, we'll get a single task by query where taskId is equalTo the selected task
<pre><code>Task *task = [[Task objectsWhere:@"taskId = %@", taskArray[sender.tag].taskId] firstObject];
<p dir="auto">Then, we'll make delete transaction to realm by these codes
<pre><code>RLMRealm *realm = [RLMRealm defaultRealm];
[realm transactionWithBlock:^{
[realm deleteObject:task];
}];
<p dir="auto">After that, don't forget to remove from taskArray and reload the tableView
<pre><code>[taskArray removeObject:taskArray[sender.tag]];
[tableView reloadData];
<p dir="auto">This is the full deleteDidTap function
<pre><code>- (void)deleteDidTap:(UIButton*)sender{
Task *task = [[Task objectsWhere:@"taskId = %@", taskArray[sender.tag].taskId] firstObject];
RLMRealm *realm = [RLMRealm defaultRealm];
[realm transactionWithBlock:^{
[realm deleteObject:task];
}];
[taskArray removeObject:taskArray[sender.tag]];
[tableView reloadData];
}
<p dir="auto">If you want to see the full code of the RealmViewController.m. This is it.
<pre><code>//
// RealmViewController.m
// AlertDemoApp
//
// Created by Andri on 1/16/18.
// Copyright © 2018 Andri. All rights reserved.
//
#import "RealmViewController.h"
@interface RealmViewController ()
@end
@implementation RealmViewController
- (void)viewDidLoad {
[super viewDidLoad];
[self setupUI];
}
- (void)setupUI{
self.view.backgroundColor = [UIColor whiteColor];
taskArray = [[NSMutableArray alloc] init];
UILabel *taskLabel = [UILabel new];
taskLabel.text = @"Task";
[taskLabel setFont:[UIFont systemFontOfSize:24]];
[self.view addSubview:taskLabel];
[taskLabel mas_makeConstraints:^(MASConstraintMaker *make) {
make.centerX.equalTo(self.view);
make.top.equalTo(self.view).offset(16);
}];
textField = [UITextField new];
textField.textColor = [UIColor colorWithRed:0/256.0 green:84/256.0 blue:129/256.0 alpha:1.0];
textField.font = [UIFont fontWithName:@"Helvetica-Bold" size:14];
textField.backgroundColor=[UIColor whiteColor];
[textField setBorderStyle:UITextBorderStyleLine];
[self.view addSubview:textField];
[textField mas_makeConstraints:^(MASConstraintMaker *make) {
make.left.equalTo(self.view).offset(16);
make.right.equalTo(self.view).offset(-16);
make.top.equalTo(taskLabel.mas_bottom).offset(16);
make.height.mas_equalTo(44);
}];
UIButton *addTaskButton = [UIButton buttonWithType:UIButtonTypeCustom];
[addTaskButton setTitle:@"Add" forState:UIControlStateNormal];
[addTaskButton setTitleColor:[UIColor blueColor] forState:UIControlStateNormal];
[addTaskButton addTarget:self action:@selector(addDidTap) forControlEvents:UIControlEventTouchUpInside];
[self.view addSubview:addTaskButton];
[addTaskButton mas_makeConstraints:^(MASConstraintMaker *make) {
make.centerX.equalTo(taskLabel);
make.top.equalTo(textField.mas_bottom).offset(16);
}];
tableView = [UITableView new];
tableView.backgroundColor = [UIColor whiteColor];
tableView.delegate = self;
tableView.dataSource = self;
tableView.estimatedRowHeight = 100;
tableView.rowHeight = UITableViewAutomaticDimension;
tableView.separatorInset = UIEdgeInsetsMake(0, 24, 0, 24);
[self.view addSubview:tableView];
[tableView registerNib:[UINib nibWithNibName:@"DemoTableViewCell"
bundle:[NSBundle mainBundle]]
forCellReuseIdentifier:@"DemoTableViewCell"];
[tableView mas_makeConstraints:^(MASConstraintMaker *make) {
make.left.bottom.right.equalTo(self.view);
make.top.equalTo(addTaskButton).offset(48);
}];
[self fetchTask];
}
- (void)addDidTap{
Task *task = [[Task alloc] init];
task.taskId = [NSUUID UUID].UUIDString;
task.name = textField.text;
NSLog(@"Name of task: %@", task.name);
RLMRealm *realm = [RLMRealm defaultRealm];
[realm transactionWithBlock:^{
[realm addObject:task];
}];
[taskArray addObject:task];
[tableView reloadData];
textField.text = @"";
}
#pragma mark - uitable
-(NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section{
return taskArray.count;
}
-(UITableViewCell*)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath{
static NSString *identifier = @"DemoTableViewCell";
DemoTableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:identifier];
if (nil == cell) {
cell = [[DemoTableViewCell alloc] initWithStyle:UITableViewCellStyleDefault
reuseIdentifier:identifier];
}
cell.textLabel.text = taskArray[indexPath.row].name;
[cell.deleteButton addTarget:self action:@selector(deleteDidTap:) forControlEvents:UIControlEventTouchUpInside];
cell.deleteButton.tag = indexPath.row;
return cell;
}
- (void)fetchTask{
RLMResults<Task *> *tasks = [Task allObjects];
for (RLMObject *object in tasks) {
Task *task = [[Task alloc] initWithValue:object];
[taskArray addObject:task];
}
}
- (void)deleteDidTap:(UIButton*)sender{
Task *task = [[Task objectsWhere:@"taskId = %@", taskArray[sender.tag].taskId] firstObject];
RLMRealm *realm = [RLMRealm defaultRealm];
[realm transactionWithBlock:^{
[realm deleteObject:task];
}];
[taskArray removeObject:taskArray[sender.tag]];
[tableView reloadData];
}
- (void)didReceiveMemoryWarning {
[super didReceiveMemoryWarning];
// Dispose of any resources that can be recreated.
}
@end
<p dir="auto">And this is the result.<br />
<img src="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516473077/khxvjbkmlpulfc5ximpc.png" alt="Screen Shot 2018-01-21 at 1.30.55 AM.png" srcset="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516473077/khxvjbkmlpulfc5ximpc.png 1x, https://images.hive.blog/1536x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516473077/khxvjbkmlpulfc5ximpc.png 2x" /><br />
You can view the video here to see how it works<br />
<br />
Now we're done with the simple to do list app. But, there is something really important to notice and that is our realm data. It is very time consuming if we want to log each realm and must run every time to see the data. And because of that we'll use Realm Studio.<br />
<b>What is Realm Studio?<br /><br />
Then, open the Realm Studio and open a local realm<br />
<img src="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516471875/ocnmd9wyxofei26fuv3z.png" alt="Screen Shot 2018-01-21 at 1.10.06 AM.png" srcset="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516471875/ocnmd9wyxofei26fuv3z.png 1x, https://images.hive.blog/1536x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516471875/ocnmd9wyxofei26fuv3z.png 2x" /><br />
Then, copy the url you have got to the finder and click go to folder<br />
<img src="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516472034/if3ouc19lxa7kiprtpob.png" alt="Screen Shot 2018-01-21 at 1.13.31 AM.png" srcset="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516472034/if3ouc19lxa7kiprtpob.png 1x, https://images.hive.blog/1536x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516472034/if3ouc19lxa7kiprtpob.png 2x" /><br />
Once you go to the folder, drag the default.realm to the realm studio window and it will choose the realm file quickly from our path that we log before.<br />
<img src="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516472210/pzfi1jaau1zczn5huo3s.png" alt="Screen Shot 2018-01-21 at 1.12.42 AM.png" srcset="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516472210/pzfi1jaau1zczn5huo3s.png 1x, https://images.hive.blog/1536x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516472210/pzfi1jaau1zczn5huo3s.png 2x" /><br />
Click Open and you can browse your data in realm studio. Just notice the Task Realm in this case. The Task Realm consist of taskId and name column.<br />
<img src="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516473492/sihzs4hdmzw0xf6jkgkz.png" alt="Screen Shot 2018-01-21 at 1.37.36 AM.png" srcset="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516473492/sihzs4hdmzw0xf6jkgkz.png 1x, https://images.hive.blog/1536x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1516473492/sihzs4hdmzw0xf6jkgkz.png 2x" /><span>
Realm Studio is premiere developer tool, built so you can easily manage the Realm Database and Realm Platform. You can download from the official page <a href="https://realm.io/products/realm-studio/" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">https://realm.io/products/realm-studio/. You can get your realm file by logging using `` NSLog(@"%@",[RLMRealmConfiguration defaultConfiguration].fileURL);```.
<p dir="auto">Okay, that's all for this tutorial. Thanks for reading this tutorial.
<p dir="auto"><br /><hr /><em>Posted on <a href="https://utopian.io/utopian-io/@andrixyz/working-with-realm-to-create-a-simple-to-do-list-ios-app-development" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">Utopian.io - Rewarding Open Source Contributors<hr /><p>
Thank you for the contribution. It has been approved.
You can contact us on Discord.
[utopian-moderator]
Meski ga ngerti.. Tp smoga sukses :)
Hey @andrixyz I am @utopian-io. I have just upvoted you!
Achievements
Suggestions
Get Noticed!
Community-Driven Witness!
I am the first and only Steem Community-Driven Witness. Participate on Discord. Lets GROW TOGETHER!
Up-vote this comment to grow my power and help Open Source contributions like this one. Want to chat? Join me on Discord https://discord.gg/Pc8HG9x