- Pastikan anda sudah menginstall serta konfigurasi NPM serta Node.js.
- Pertama tama, ketik ionic start LoginApp
data:image/s3,"s3://crabby-images/bdf87/bdf87ac74859f35d0dfa0fd1a712254fdf62ba14" alt=""
3. Pilih blank .
data:image/s3,"s3://crabby-images/2d7f4/2d7f45937ae79149b5b17bceaf8e58753fb2d80e" alt=""
4. input y
data:image/s3,"s3://crabby-images/3db4a/3db4a0c991ff27877f738bbbb0557aaa0ba4cc97" alt=""
5. input n
data:image/s3,"s3://crabby-images/7980e/7980eeb1a53278f973f247320c3323675fa7aba3" alt=""
6. Apabila proses instalasi sudah selesai, masuk ke folder anda dengan mengetik cd LoginApp
data:image/s3,"s3://crabby-images/8591d/8591dce8a75c7afe35ca8defa7ddbcc405b97ebd" alt=""
7. Untuk mengecek apakah sudah berhasil, ketik ionic serve -ctl
data:image/s3,"s3://crabby-images/484fa/484fa06e3bd6bb80a54cc93c004737fefd6d8cf8" alt=""
data:image/s3,"s3://crabby-images/cd4ea/cd4eaf0f98fb9953418bb07779f7145ece11eb1a" 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/2fa48/2fa48911e792c65c01e8d131696ec94926efa620" alt=""
data:image/s3,"s3://crabby-images/1651f/1651fdf159d89bd22ef6da4b8c9e5935a0ba2cef" alt=""
9. Kemudian buka folder project LoginApp dengan IDE anda, pada tutorial ini menggunakan Visual Code.
data:image/s3,"s3://crabby-images/03ad7/03ad76e7700ddff02dae7a9ef7cf365b021779c0" alt=""
10. Lalu masuk ke src/pages/login/login.html
data:image/s3,"s3://crabby-images/564fb/564fbfe207ebe94db6005c89aa501868548d5ee5" 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/3b9cb/3b9cb1deac7cdd1c47fa1befd0f990e8d5f16510" alt=""
13. Lalu masuk ke src/providers/auth/auth.ts
data:image/s3,"s3://crabby-images/fbbdf/fbbdf7311ada7e4ba089b209e411a4a3c9182547" 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/f3372/f3372642b08c7344cdb3db39925d540ff7b00315" 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/14675/1467571b85212e9450f2a7ef4340632c070755f8" 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/4dbe8/4dbe8e2cb464a461d8dd5b1bb3b4a636af2bf924" 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/0174e/0174e3824deedcf5b94f357e83416b2d417f7a10" alt=""
data:image/s3,"s3://crabby-images/b8ebb/b8ebb08f5690107b8ba70c103d9daa58e3c329fd" alt=""
data:image/s3,"s3://crabby-images/31c87/31c875c5d1eee3dfc42f7a88d2df9c38d9be85e7" alt=""
0 Comments