- Pastikan anda sudah menginstall serta konfigurasi NPM serta Node.js.
- Pertama tama, ketik ionic start LoginApp
data:image/s3,"s3://crabby-images/d1d81/d1d819d94da23a18527f86da5e89191a3deba153" alt=""
3. Pilih blank .
data:image/s3,"s3://crabby-images/e2a37/e2a372a6d0612ec658535509a084135acaa27e35" alt=""
4. input y
data:image/s3,"s3://crabby-images/48381/48381c8834f2b70379eac1688d66f6fcec84d8bb" alt=""
5. input n
data:image/s3,"s3://crabby-images/82aa3/82aa3b557371556017ec246057c11f54485962be" alt=""
6. Apabila proses instalasi sudah selesai, masuk ke folder anda dengan mengetik cd LoginApp
data:image/s3,"s3://crabby-images/b1a76/b1a76aa477f766f6aa57f1f43494944cef1a6b7a" alt=""
7. Untuk mengecek apakah sudah berhasil, ketik ionic serve -ctl
data:image/s3,"s3://crabby-images/f4d8f/f4d8f64505da24f9e3faaf09c97c7644559b53c1" alt=""
data:image/s3,"s3://crabby-images/9272a/9272a5cd333ef31b59bb06e7f1508dbbadb79b69" alt=""
8. Sekarang kita akan membuat 2 buah halaman yaitu login dan home dengan megetik ionic generate page login untuk halaman login, serta
ionic generate page home untuk halaman home.
data:image/s3,"s3://crabby-images/29c20/29c20b005445fd9961f4e0de6751d49a74270e25" alt=""
data:image/s3,"s3://crabby-images/5cfa4/5cfa4b0a51313f31c3025c397f90fda6649aaeab" alt=""
9. Kemudian buka folder project LoginApp dengan IDE anda, pada tutorial ini menggunakan Visual Code.
data:image/s3,"s3://crabby-images/97d6c/97d6cd5a6c8c2c0d7074bed06ab7878e08850745" alt=""
10. Lalu masuk ke src/pages/login/login.html
data:image/s3,"s3://crabby-images/f3dc6/f3dc6e5fbcb42ea070adf596ba28e6839a0a4e1a" alt=""
11. Masukkan code berikut , ubah code aslinya yang ada pada gambar di atas
<ion-content padding>
<ion-list text-center>
<br>
<H3> Welcome </H3>
<br>
<ion-item>
<ion-label color="primary" >Username</ion-label>
<ion-input type="email" [(ngModel)]="credentials.username" ></ion-input>
</ion-item>
<br>
<ion-item>
<ion-label color="primary" >Password</ion-label>
<ion-input type="password" [(ngModel)]="credentials.password" ></ion-input>
</ion-item>
<br>
<br>
<button ion-button round center (click)="login()">Login</button>
<br>
<p text-center tappable> Forget Password </p>
<p text-center tappable (click)="register()" > Don't have account? Register </p>
</ion-list>
</ion-content>
12. Sekarang kita akan membuat Auth Provider untuk menangani login, ketik ionic generate provider auth
data:image/s3,"s3://crabby-images/b539f/b539ff9ab67ce87892cede9c3c114a5e117400c6" alt=""
13. Lalu masuk ke src/providers/auth/auth.ts
data:image/s3,"s3://crabby-images/c8b26/c8b26b09068ff3d4b54f5b3f3158c7d23b11dec3" alt=""
14. Masukkan code berikut , ubah code aslinya yang ada pada gambar di atas
import { Injectable } from '@angular/core';
@Injectable()
export class AuthProvider {
constructor() {
// console.log("belum dipake");
}
public login(credentials) {
return new Promise((resolve, reject) => {
if (credentials.username == "" || credentials.password == "") {
reject("Username / password harus diisi")
} else if (credentials.username == "admin" && credentials.password=="admin") {
localStorage.setItem("isLogin", "true");
resolve("Berhasil Login")
} else {
reject("Username / password salah");
}
})
}
public logOut() {
localStorage.setItem("isLogin", "false");
}
}
15. Setelah login.html dan auth.ts diubah, sekarang kita akan mengubah
src/pages/login/login.ts
data:image/s3,"s3://crabby-images/bedfe/bedfe22d8b33b25ae4811d24bd1f1e3fd6c45782" alt=""
16. Masukkan code berikut , ubah code aslinya yang ada pada gambar di atas
import { Component } from '@angular/core';
import { IonicPage, NavController, NavParams, ToastController } from 'ionic-angular';
import { HomePage } from '../home/home';
// import auth provider
import { AuthProvider } from '../../providers/auth/auth';
@IonicPage()
@Component({
selector: 'page-login',
templateUrl: 'login.html',
})
export class LoginPage {
credentials: any = {
username: "",
password: ""
}
constructor(public navCtrl: NavController, public navParams: NavParams,
public auth: AuthProvider, public toastCtrl: ToastController) {}
ionViewDidLoad() {
//check apakah sudah dalam kondisi login?
let status = localStorage.getItem("isLogin");
if (status == "true") {
this.navCtrl.setRoot(HomePage);
}
}
login() {
this.auth.login(this.credentials).then((resp) => {
let toast = this.toastCtrl.create({
message: "Berhasil",
duration: 3000,
position: 'bottom'
});
toast.present();
this.navCtrl.setRoot(HomePage);
}).catch((err) => {
let toast = this.toastCtrl.create({
message: err,
duration: 2000,
position: 'bottom'
});
toast.present();
})
}
}
17. Lalu masuk ke src/pages/home/home.html
data:image/s3,"s3://crabby-images/fa69a/fa69a6740153a8984119b82b9077053c03b6c9cf" alt=""
18. Masukkan code berikut , ubah code aslinya yang ada pada gambar di atas
<ion-header>
<ion-navbar>
<ion-title>
Ionic Blank
</ion-title>
</ion-navbar>
</ion-header>
<ion-content padding>
Selamat Datang
<br>
<br>
<button ion-button round (click)="logout()">Logout</button>
</ion-content>
19. Kemudian masuk ke src/pages/home/home.ts
data:image/s3,"s3://crabby-images/5eea5/5eea5a7382cdc7734da4f87fbf3aa3517250cf0f" alt=""
20. Masukkan code berikut , ubah code aslinya yang ada pada gambar di atas
import { AuthProvider } from './../../providers/auth/auth';
import { Component } from '@angular/core';
import { NavController } from 'ionic-angular';
@Component({
selector: 'page-home',
templateUrl: 'home.html',
providers: [AuthProvider]
})
export class HomePage {
constructor(public navCtrl: NavController, public auth: AuthProvider) {
}
logout() {
this.auth.logOut()
this.navCtrl.setRoot("LoginPage")
}
}
21. Sekarang buka cmd baru, lakukan cara di no 7
data:image/s3,"s3://crabby-images/07f84/07f841f87a317b690f2df71d7d27826e0e5f3d53" alt=""
data:image/s3,"s3://crabby-images/ca703/ca70359ea165a6a20478af402ba14706922e9f94" alt=""
data:image/s3,"s3://crabby-images/df619/df6194bb58dd0937a14b97a1a97d3729df0a5453" alt=""