Commit 3236cc49 authored by Dio Maulana's avatar Dio Maulana

final

parent 60d56b7e
<manifest xmlns:android="http://schemas.android.com/apk/res/android" <manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.movie_app"> package="com.example.movie_app">
<uses-permission android:name="android.permission.INTERNET" />
<application <application
android:label="movie_app" android:label="movie_app"
android:name="${applicationName}" android:name="${applicationName}"
android:icon="@mipmap/ic_launcher"> android:icon="@mipmap/ic_launcher"
android:usesCleartextTraffic="true">
<activity <activity
android:name=".MainActivity" android:name=".MainActivity"
android:exported="true" android:exported="true"
......
...@@ -3,20 +3,24 @@ import 'dart:convert'; ...@@ -3,20 +3,24 @@ import 'dart:convert';
import 'dart:async'; import 'dart:async';
import 'package:movie_app/config.dart'; import 'package:movie_app/config.dart';
import 'package:movie_app/models/movie_detail_api.dart';
import 'package:movie_app/models/populars.dart';
import 'package:movie_app/models/post_rate_model.dart';
import 'package:movie_app/models/upComings.dart';
class ApiPopular { class Api {
final String vote_average; static Future<movieDetail> getDetail(String movieId) async {
final String title; var apiUrl = "https://api.themoviedb.org/3/movie/" +
final String poster_path; movieId +
final String id; "?api_key=" +
apiKey +
ApiPopular(this.vote_average, this.title, this.poster_path, this.id); "&language=en-US";
var response = await http.get(Uri.parse(apiUrl));
factory ApiPopular.createPopular(Map<String, dynamic> json) { var json = jsonDecode(response.body);
return ApiPopular(json['vote_average'].toString(), json['title'], return movieDetail.fromJson(json);
json['poster_path'], json['id'].toString());
} }
static Future<List<ApiPopular>> getPopular() async {
static Future<List<Popular>> getPopular() async {
String apiUrl = "https://api.themoviedb.org/3/movie/popular?api_key=" + String apiUrl = "https://api.themoviedb.org/3/movie/popular?api_key=" +
apiKey + apiKey +
"&language=en-US&page=1"; "&language=en-US&page=1";
...@@ -25,40 +29,101 @@ class ApiPopular { ...@@ -25,40 +29,101 @@ class ApiPopular {
List<dynamic> listPopular = (jsonObject as Map<String, dynamic>)['results']; List<dynamic> listPopular = (jsonObject as Map<String, dynamic>)['results'];
List<ApiPopular> populars = []; List<Popular> populars = [];
for (int i = 0; i < listPopular.length; i++) for (int i = 0; i < listPopular.length; i++)
populars.add(ApiPopular.createPopular(listPopular[i])); populars.add(Popular.createPopularComing(listPopular[i]));
return populars; return populars;
} }
}
class ApiUpComing {
final String vote_average;
final String title;
final String poster_path;
final String id;
ApiUpComing(this.vote_average, this.title, this.poster_path, this.id);
factory ApiUpComing.createUpComing(Map<String, dynamic> json) { static Future<List<Coming>> getComing() async {
return ApiUpComing(json['vote_average'].toString(), json['title'],
json['poster_path'], json['id'].toString());
}
static Future<List<ApiUpComing>> getUpcoming() async {
String apiUrl = "https://api.themoviedb.org/3/movie/upcoming?api_key=" + String apiUrl = "https://api.themoviedb.org/3/movie/upcoming?api_key=" +
apiKey + apiKey +
"&language=en-US&page=1"; "&language=en-US&page=1";
var apiResult = await http.get(Uri.parse(apiUrl)); var apiResult = await http.get(Uri.parse(apiUrl));
var jsonObject = json.decode(apiResult.body); var jsonObject = json.decode(apiResult.body);
List<dynamic> listUpComing = List<dynamic> listPopular = (jsonObject as Map<String, dynamic>)['results'];
(jsonObject as Map<String, dynamic>)['results'];
List<Coming> populars = [];
for (int i = 0; i < listPopular.length; i++) {
populars.add(Coming.createComing(listPopular[i]));
}
print(populars);
return populars;
}
static Future<PostRateResult> postReview(
String movieId, double rating) async {
String apiUrl = "https://api.themoviedb.org/3/movie/" +
movieId +
"/rating?api_key=" +
apiKey;
var apiResult = await http.post(Uri.parse(apiUrl), body: {
"value": rating.toString(),
"guest_session_id": "aa9837cfeac9f0f53b69d75fd11a001e"
});
var jsonObject = json.decode(apiResult.body);
List<ApiUpComing> upcomings = []; return PostRateResult.fromJson(jsonObject);
for (int i = 0; i < listUpComing.length; i++)
upcomings.add(ApiUpComing.createUpComing(listUpComing[i]));
print(upcomings);
return upcomings;
} }
} }
// class ApiPopular {
// final String vote_average;
// final String title;
// final String poster_path;
// final String id;
// ApiPopular(this.vote_average, this.title, this.poster_path, this.id);
// factory ApiPopular.createPopular(Map<String, dynamic> json) {
// return ApiPopular(json['vote_average'].toString(), json['title'],
// json['poster_path'], json['id'].toString());
// }
// static Future<List<ApiPopular>> getPopular() async {
// String apiUrl = "https://api.themoviedb.org/3/movie/popular?api_key=" +
// apiKey +
// "&language=en-US&page=1";
// var apiResult = await http.get(Uri.parse(apiUrl));
// var jsonObject = json.decode(apiResult.body);
// List<dynamic> listPopular = (jsonObject as Map<String, dynamic>)['results'];
// List<ApiPopular> populars = [];
// for (int i = 0; i < listPopular.length; i++)
// populars.add(ApiPopular.createPopular(listPopular[i]));
// return populars;
// }
// }
// class ApiUpComing {
// final String vote_average;
// final String title;
// final String poster_path;
// final String id;
// ApiUpComing(this.vote_average, this.title, this.poster_path, this.id);
// factory ApiUpComing.createUpComing(Map<String, dynamic> json) {
// return ApiUpComing(json['vote_average'].toString(), json['title'],
// json['poster_path'], json['id'].toString());
// }
// static Future<List<ApiUpComing>> getUpcoming() async {
// String apiUrl = "https://api.themoviedb.org/3/movie/upcoming?api_key=" +
// apiKey +
// "&language=en-US&page=1";
// var apiResult = await http.get(Uri.parse(apiUrl));
// var jsonObject = json.decode(apiResult.body);
// List<dynamic> listUpComing =
// (jsonObject as Map<String, dynamic>)['results'];
// List<ApiUpComing> upcomings = [];
// for (int i = 0; i < listUpComing.length; i++)
// upcomings.add(ApiUpComing.createUpComing(listUpComing[i]));
// print(upcomings);
// return upcomings;
// }
// }
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:movie_app/pages/account.dart';
import 'package:movie_app/pages/home.dart'; import 'package:movie_app/pages/home.dart';
import 'package:movie_app/pages/main_page.dart'; import 'package:movie_app/pages/main_page.dart';
import 'package:movie_app/pages/movie_detail.dart'; import 'package:movie_app/pages/movie_detail.dart';
...@@ -37,6 +38,7 @@ class _MyAppState extends State<MyApp> { ...@@ -37,6 +38,7 @@ class _MyAppState extends State<MyApp> {
'/detail': (context) => detailMovie( '/detail': (context) => detailMovie(
// ModalRoute.of(context)!.settings.arguments as ScreenArguments), // ModalRoute.of(context)!.settings.arguments as ScreenArguments),
ModalRoute.of(context)!.settings.arguments as String), ModalRoute.of(context)!.settings.arguments as String),
'/account': (context) => AccountPage(),
}, },
); );
} }
......
class movieDetail { class movieDetail {
final String id;
final String title; final String title;
final String poster_path; final String poster_path;
final String overview; final String overview;
final double vote_average; final double vote_average;
List<dynamic> genre = []; List<dynamic> genre;
movieDetail(this.title, this.poster_path, this.overview, this.vote_average, movieDetail(
this.genre); {required this.id,
required this.title,
required this.poster_path,
required this.overview,
required this.vote_average,
required this.genre});
factory movieDetail.fromJson(dynamic json) { factory movieDetail.fromJson(dynamic json) {
var nameGenre = []; var nameGenre = [];
for (int i = 0; i < json['genres'].length; i++) { for (int i = 0; i < json['genres'].length; i++) {
var genreName = ''; var genreName = '';
if (json['genres'][i]['name'] == null) { if (json['genres'][i]['name'] == null) {
...@@ -20,10 +27,11 @@ class movieDetail { ...@@ -20,10 +27,11 @@ class movieDetail {
nameGenre.add(genreName); nameGenre.add(genreName);
} }
return movieDetail( return movieDetail(
json['title'] as String, id: json['id'].toString(),
json['poster_path'] as String, title: json['title'] as String,
json['overview'] as String, poster_path: json['poster_path'] as String,
json['vote_average'] as double, overview: json['overview'] as String,
nameGenre as List<dynamic>); vote_average: json['vote_average'] as double,
genre: nameGenre as List<dynamic>);
} }
} }
class Popular {
final String id;
final String vote_average;
final String title;
final String poster_path;
Popular(
{required this.id,
required this.vote_average,
required this.title,
required this.poster_path});
factory Popular.createPopularComing(Map<String, dynamic> json) {
return Popular(
id: json['id'].toString(),
vote_average: json['vote_average'].toString(),
title: json['title'],
poster_path: json['poster_path']);
}
}
import 'dart:convert';
import 'package:http/http.dart' as http; import 'package:http/http.dart' as http;
import 'package:movie_app/config.dart';
class PostRateResult { class PostRateResult {
final int status_code; final int status_code;
......
class Coming {
final String id;
final String vote_average;
final String title;
final String poster_path;
Coming(
{required this.id,
required this.vote_average,
required this.title,
required this.poster_path});
factory Coming.createComing(Map<String, dynamic> json) {
return Coming(
id: json['id'].toString(),
vote_average: json['vote_average'].toString(),
title: json['title'],
poster_path: json['poster_path']);
}
}
...@@ -19,7 +19,10 @@ class _MainPagesState extends State<MainPages> { ...@@ -19,7 +19,10 @@ class _MainPagesState extends State<MainPages> {
var _populars = []; var _populars = [];
var _upComing = []; var _upComing = [];
bool isLoading = true; var nowDate = DateTime.now().toUtc();
bool isLoadingPopular = true;
bool isLoadingComing = true;
// void getPopularData(String apiKey) async { // void getPopularData(String apiKey) async {
// var response = await http.get(Uri.parse( // var response = await http.get(Uri.parse(
...@@ -36,39 +39,58 @@ class _MainPagesState extends State<MainPages> { ...@@ -36,39 +39,58 @@ class _MainPagesState extends State<MainPages> {
// } // }
void getPopular() async { void getPopular() async {
var apiPopular = await ApiPopular.getPopular(); var apiPopular = await Api.getPopular();
// var apiUpComing = await ApiUpComing.getUpcoming();
setState(() { setState(() {
isLoadingPopular = false;
_populars = apiPopular; _populars = apiPopular;
// _upComing = apiUpComing;
}); });
} }
void getUpComingData(String apiKey) async { void getComing() async {
var response = await http.get(Uri.parse( var apiUpComing = await Api.getComing();
"https://api.themoviedb.org/3/movie/upcoming?api_key=" +
apiKey +
"&language=en-US&page=1"));
var jsonObject = jsonDecode(response.body);
List<dynamic> listUpComing =
(jsonObject as Map<String, dynamic>)['results'];
setState(() { setState(() {
_upComing = listUpComing; isLoadingComing = false;
isLoading = false; _upComing = apiUpComing;
}); });
} }
// void getComings() async {
// // var apiPopular = await Api.getPopular();
// var apiUpComing = await Api.getComing();
// setState(() {
// // _populars = apiPopular;
// isLoading = false;
// _upComing = apiUpComing;
// });
// }
// void getUpComingData(String apiKey) async {
// var response = await http.get(Uri.parse(
// "https://api.themoviedb.org/3/movie/upcoming?api_key=" +
// apiKey +
// "&language=en-US&page=1"));
// var jsonObject = jsonDecode(response.body);
// List<dynamic> listUpComing =
// (jsonObject as Map<String, dynamic>)['results'];
// setState(() {
// _upComing = listUpComing;
// isLoading = false;
// });
// }
@override @override
void initState() { void initState() {
// TODO: implement initState // TODO: implement initState
super.initState(); super.initState();
getPopular(); getPopular();
getUpComingData(apiKey); getComing();
// getUpComingData(apiKey);
} }
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
print(nowDate);
return Scaffold( return Scaffold(
backgroundColor: backgroundColor, backgroundColor: backgroundColor,
body: Stack( body: Stack(
...@@ -80,7 +102,7 @@ class _MainPagesState extends State<MainPages> { ...@@ -80,7 +102,7 @@ class _MainPagesState extends State<MainPages> {
child: Row( child: Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween, mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [ children: [
Text( const Text(
"Hi, Dio Maulana", "Hi, Dio Maulana",
style: TextStyle( style: TextStyle(
color: textColor, color: textColor,
...@@ -88,11 +110,19 @@ class _MainPagesState extends State<MainPages> { ...@@ -88,11 +110,19 @@ class _MainPagesState extends State<MainPages> {
fontWeight: FontWeight.w800), fontWeight: FontWeight.w800),
), ),
ClipRRect( ClipRRect(
child: Icon( child: GestureDetector(
onTap: () {
Navigator.pushNamed(
context,
'/account',
);
},
child: const Icon(
Icons.person, Icons.person,
color: textColor, color: textColor,
size: 30, size: 30,
), ),
),
) )
], ],
), ),
...@@ -108,8 +138,8 @@ class _MainPagesState extends State<MainPages> { ...@@ -108,8 +138,8 @@ class _MainPagesState extends State<MainPages> {
padding: EdgeInsets.fromLTRB(10, 5, 5, 5), padding: EdgeInsets.fromLTRB(10, 5, 5, 5),
// ignore: prefer_const_constructors // ignore: prefer_const_constructors
child: TextField( child: TextField(
style: TextStyle(color: textColor), style: const TextStyle(color: textColor),
decoration: InputDecoration( decoration: const InputDecoration(
border: InputBorder.none, border: InputBorder.none,
icon: Icon( icon: Icon(
Icons.search, Icons.search,
...@@ -123,7 +153,7 @@ class _MainPagesState extends State<MainPages> { ...@@ -123,7 +153,7 @@ class _MainPagesState extends State<MainPages> {
Container( Container(
margin: EdgeInsets.fromLTRB(10, 10, 10, 10), margin: EdgeInsets.fromLTRB(10, 10, 10, 10),
child: Row( child: Row(
children: [ children: const [
Text( Text(
"Popular", "Popular",
style: titleText, style: titleText,
...@@ -133,7 +163,7 @@ class _MainPagesState extends State<MainPages> { ...@@ -133,7 +163,7 @@ class _MainPagesState extends State<MainPages> {
], ],
), ),
), ),
isLoading isLoadingPopular
? Container( ? Container(
margin: defaultCardPading, margin: defaultCardPading,
height: 400, height: 400,
...@@ -169,7 +199,7 @@ class _MainPagesState extends State<MainPages> { ...@@ -169,7 +199,7 @@ class _MainPagesState extends State<MainPages> {
Container( Container(
margin: defaultCardPading, margin: defaultCardPading,
child: Row( child: Row(
children: [ children: const [
Text( Text(
"Up coming", "Up coming",
style: titleText, style: titleText,
...@@ -182,7 +212,7 @@ class _MainPagesState extends State<MainPages> { ...@@ -182,7 +212,7 @@ class _MainPagesState extends State<MainPages> {
], ],
), ),
), ),
isLoading isLoadingComing
? Container( ? Container(
margin: defaultCardPading, margin: defaultCardPading,
height: 400, height: 400,
...@@ -208,10 +238,10 @@ class _MainPagesState extends State<MainPages> { ...@@ -208,10 +238,10 @@ class _MainPagesState extends State<MainPages> {
popularCard( popularCard(
context, context,
"https://image.tmdb.org/t/p/w500" + "https://image.tmdb.org/t/p/w500" +
_upComing[i]['poster_path'], _upComing[i].poster_path,
_upComing[i]['title'], _upComing[i].title,
_upComing[i]['vote_average'].toString(), _upComing[i].vote_average.toString(),
_upComing[i]['id'].toString()), _upComing[i].id.toString()),
], ],
), ),
), ),
...@@ -278,7 +308,7 @@ class _MainPagesState extends State<MainPages> { ...@@ -278,7 +308,7 @@ class _MainPagesState extends State<MainPages> {
), ),
), ),
), ),
SizedBox( const SizedBox(
height: 10, height: 10,
), ),
Container( Container(
...@@ -287,14 +317,14 @@ class _MainPagesState extends State<MainPages> { ...@@ -287,14 +317,14 @@ class _MainPagesState extends State<MainPages> {
title, title,
textAlign: TextAlign.center, textAlign: TextAlign.center,
maxLines: 1, maxLines: 1,
style: TextStyle( style: const TextStyle(
fontSize: 14, fontSize: 14,
color: Colors.white, color: Colors.white,
fontWeight: FontWeight.w900, fontWeight: FontWeight.w900,
overflow: TextOverflow.ellipsis), overflow: TextOverflow.ellipsis),
), ),
), ),
SizedBox( const SizedBox(
height: 5, height: 5,
), ),
Row( Row(
...@@ -303,15 +333,15 @@ class _MainPagesState extends State<MainPages> { ...@@ -303,15 +333,15 @@ class _MainPagesState extends State<MainPages> {
rating, rating,
maxLines: 1, maxLines: 1,
textAlign: TextAlign.center, textAlign: TextAlign.center,
style: TextStyle( style: const TextStyle(
color: Colors.grey, color: Colors.grey,
fontSize: 12, fontSize: 12,
fontWeight: FontWeight.w500), fontWeight: FontWeight.w500),
), ),
SizedBox( const SizedBox(
width: 5, width: 5,
), ),
Icon( const Icon(
Icons.star, Icons.star,
color: Colors.yellow, color: Colors.yellow,
size: 14, size: 14,
......
...@@ -3,6 +3,7 @@ import 'dart:async'; ...@@ -3,6 +3,7 @@ import 'dart:async';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter_rating_bar/flutter_rating_bar.dart'; import 'package:flutter_rating_bar/flutter_rating_bar.dart';
import 'package:movie_app/apiMovie.dart';
import 'package:movie_app/config.dart'; import 'package:movie_app/config.dart';
import 'package:http/http.dart' as http; import 'package:http/http.dart' as http;
...@@ -23,26 +24,35 @@ class _detailMovieState extends State<detailMovie> { ...@@ -23,26 +24,35 @@ class _detailMovieState extends State<detailMovie> {
double rating = 0; double rating = 0;
movieDetail? _movieDetail; movieDetail? _movieDetail;
PostRateResult? _postRateResult; PostRateResult? _postRateResult;
void postRate(double rating, String apiKey, String movieId) async { void postRate(double rating, String movieId) async {
var response = await http.post( var postReview = await Api.postReview(movieId, rating);
Uri.parse("https://api.themoviedb.org/3/movie/" +
movieId +
"/rating?api_key=" +
apiKey),
body: {
"value": rating.toString(),
"guest_session_id": "aa9837cfeac9f0f53b69d75fd11a001e"
});
var json = jsonDecode(response.body);
setState(() { setState(() {
_postRateResult = PostRateResult.fromJson(json); _postRateResult = postReview;
}); });
var status_code =
_postRateResult == null ? '' : _postRateResult!.status_code.toString();
var message = '';
if (status_code == "1") {
if (rating == 10.0) {
message = "Wow!! kamu memberikan nilai sempurna ^.^";
} else {
message = "Kamu memberikan " + rating.toString() + " bintang";
}
} else if (status_code == '12') {
if (rating == 10.0) {
message = "Wow!! kamu memberikan nilai update sempurna ^.^";
} else {
message =
"Kamu update rating menjadi " + rating.toString() + " bintang";
}
} else {
message = "Something went error";
}
final snackBar = SnackBar( final snackBar = SnackBar(
backgroundColor: backgroundColor, backgroundColor: backgroundColor,
content: Text( content: Text(
_postRateResult == null ? '' : _postRateResult!.status_message, message,
style: TextStyle( style: const TextStyle(
color: textColor, fontSize: 15, fontWeight: FontWeight.w800), color: textColor, fontSize: 15, fontWeight: FontWeight.w800),
), ),
duration: Duration(seconds: 2), duration: Duration(seconds: 2),
...@@ -50,17 +60,19 @@ class _detailMovieState extends State<detailMovie> { ...@@ -50,17 +60,19 @@ class _detailMovieState extends State<detailMovie> {
ScaffoldMessenger.of(context).showSnackBar(snackBar); ScaffoldMessenger.of(context).showSnackBar(snackBar);
} }
void getDetailMovie(String apiKey, String movieId) async { void getDetailMovie(String movieId) async {
var response = await http.get(Uri.parse( // var response = await http.get(Uri.parse(
"https://api.themoviedb.org/3/movie/" + // "https://api.themoviedb.org/3/movie/" +
movieId + // movieId +
"?api_key=" + // "?api_key=" +
apiKey + // apiKey +
"&language=en-US")); // "&language=en-US"));
var json = jsonDecode(response.body); // var json = jsonDecode(response.body);
var response = await Api.getDetail(movieId);
setState(() { setState(() {
_movieDetail = movieDetail.fromJson(json); _movieDetail = response;
}); });
} }
...@@ -68,7 +80,7 @@ class _detailMovieState extends State<detailMovie> { ...@@ -68,7 +80,7 @@ class _detailMovieState extends State<detailMovie> {
void initState() { void initState() {
// TODO: implement initState // TODO: implement initState
super.initState(); super.initState();
getDetailMovie(apiKey, widget.id); getDetailMovie(widget.id);
} }
@override @override
...@@ -91,19 +103,19 @@ class _detailMovieState extends State<detailMovie> { ...@@ -91,19 +103,19 @@ class _detailMovieState extends State<detailMovie> {
context, context,
); );
}, },
child: Icon( child: const Icon(
Icons.arrow_back_ios_new, Icons.arrow_back_ios_new,
color: textColor, color: textColor,
), ),
), ),
Text( const Text(
"Detail Movies", "Detail Movies",
style: TextStyle( style: TextStyle(
color: textColor, color: textColor,
fontSize: 20, fontSize: 20,
fontWeight: FontWeight.w800), fontWeight: FontWeight.w800),
), ),
Icon( const Icon(
Icons.bookmark_border_outlined, Icons.bookmark_border_outlined,
color: textColor, color: textColor,
), ),
...@@ -124,7 +136,7 @@ class _detailMovieState extends State<detailMovie> { ...@@ -124,7 +136,7 @@ class _detailMovieState extends State<detailMovie> {
child: ClipRRect( child: ClipRRect(
borderRadius: BorderRadius.circular(40), borderRadius: BorderRadius.circular(40),
child: _movieDetail == null child: _movieDetail == null
? SizedBox( ? const SizedBox(
width: 10, width: 10,
) )
: Image( : Image(
...@@ -147,7 +159,7 @@ class _detailMovieState extends State<detailMovie> { ...@@ -147,7 +159,7 @@ class _detailMovieState extends State<detailMovie> {
child: Text( child: Text(
_movieDetail == null ? '' : _movieDetail!.title, _movieDetail == null ? '' : _movieDetail!.title,
textAlign: TextAlign.start, textAlign: TextAlign.start,
style: TextStyle( style: const TextStyle(
fontSize: 25, fontSize: 25,
fontWeight: FontWeight.w700, fontWeight: FontWeight.w700,
color: textColor), color: textColor),
...@@ -157,7 +169,7 @@ class _detailMovieState extends State<detailMovie> { ...@@ -157,7 +169,7 @@ class _detailMovieState extends State<detailMovie> {
margin: EdgeInsets.fromLTRB(50, 30, 30, 10), margin: EdgeInsets.fromLTRB(50, 30, 30, 10),
child: Row( child: Row(
children: [ children: [
Text( const Text(
'Director: Dio Maulana | ', 'Director: Dio Maulana | ',
style: TextStyle( style: TextStyle(
fontSize: 15, fontSize: 15,
...@@ -168,12 +180,12 @@ class _detailMovieState extends State<detailMovie> { ...@@ -168,12 +180,12 @@ class _detailMovieState extends State<detailMovie> {
_movieDetail == null _movieDetail == null
? '' ? ''
: _movieDetail!.vote_average.toString(), : _movieDetail!.vote_average.toString(),
style: TextStyle( style: const TextStyle(
fontSize: 15, fontSize: 15,
color: textColor, color: textColor,
fontWeight: FontWeight.w400), fontWeight: FontWeight.w400),
), ),
Icon( const Icon(
Icons.star, Icons.star,
color: Colors.yellow, color: Colors.yellow,
) )
...@@ -184,7 +196,7 @@ class _detailMovieState extends State<detailMovie> { ...@@ -184,7 +196,7 @@ class _detailMovieState extends State<detailMovie> {
margin: EdgeInsets.fromLTRB(50, 0, 30, 10), margin: EdgeInsets.fromLTRB(50, 0, 30, 10),
height: 50, height: 50,
child: _movieDetail == null child: _movieDetail == null
? SizedBox( ? const SizedBox(
width: 1, width: 1,
) )
: ListView( : ListView(
...@@ -212,7 +224,7 @@ class _detailMovieState extends State<detailMovie> { ...@@ -212,7 +224,7 @@ class _detailMovieState extends State<detailMovie> {
Container( Container(
margin: EdgeInsets.only(top: 10), margin: EdgeInsets.only(top: 10),
width: 300, width: 300,
child: Text( child: const Text(
"Synopsis", "Synopsis",
textAlign: TextAlign.start, textAlign: TextAlign.start,
style: TextStyle( style: TextStyle(
...@@ -226,12 +238,12 @@ class _detailMovieState extends State<detailMovie> { ...@@ -226,12 +238,12 @@ class _detailMovieState extends State<detailMovie> {
child: Text( child: Text(
_movieDetail == null ? '' : _movieDetail!.overview, _movieDetail == null ? '' : _movieDetail!.overview,
textAlign: TextAlign.start, textAlign: TextAlign.start,
style: TextStyle( style: const TextStyle(
color: textColor, color: textColor,
fontSize: 15, fontSize: 15,
fontWeight: FontWeight.w400), fontWeight: FontWeight.w400),
)), )),
SizedBox( const SizedBox(
height: 35, height: 35,
) )
], ],
...@@ -257,18 +269,21 @@ class _detailMovieState extends State<detailMovie> { ...@@ -257,18 +269,21 @@ class _detailMovieState extends State<detailMovie> {
mainAxisAlignment: MainAxisAlignment.center, mainAxisAlignment: MainAxisAlignment.center,
mainAxisSize: MainAxisSize.min, mainAxisSize: MainAxisSize.min,
children: <Widget>[ children: <Widget>[
Text( const Text(
"Rate this movie ", "Rate this movie ",
style: TextStyle(color: textColor), style: TextStyle(color: textColor),
), ),
SizedBox( const SizedBox(
height: 10, height: 10,
), ),
RatingBar.builder( RatingBar.builder(
initialRating: 1,
minRating: 1, minRating: 1,
itemSize: 46, itemSize: 46,
itemPadding: allowHalfRating: true,
EdgeInsets.symmetric(horizontal: 5), itemCount: 10,
// itemPadding:
// EdgeInsets.symmetric(horizontal: 5),
itemBuilder: (context, _) => itemBuilder: (context, _) =>
Icon(Icons.star, color: Colors.yellow), Icon(Icons.star, color: Colors.yellow),
updateOnDrag: true, updateOnDrag: true,
...@@ -283,7 +298,7 @@ class _detailMovieState extends State<detailMovie> { ...@@ -283,7 +298,7 @@ class _detailMovieState extends State<detailMovie> {
BorderRadius.circular(25)), BorderRadius.circular(25)),
color: Colors.yellow, color: Colors.yellow,
onPressed: () { onPressed: () {
postRate(rating, apiKey, widget.id); postRate(rating, widget.id);
Navigator.pop(context); Navigator.pop(context);
}) })
], ],
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment