Commit 747a18a8 authored by Arham Aulia Nugraha's avatar Arham Aulia Nugraha

Merge branch 'master' of http://103.44.149.204/qorridi/medapp_eksad

 Conflicts:
	lib/screen/solution.dart
parents 8014f89a 4ace81ac
...@@ -24,3 +24,28 @@ class Animasi_Kanan_Kiri extends StatelessWidget { ...@@ -24,3 +24,28 @@ class Animasi_Kanan_Kiri extends StatelessWidget {
); );
} }
} }
class Animasi_Kanan_Kiri_Justify extends StatelessWidget {
const Animasi_Kanan_Kiri_Justify({Key? key, required this.judul}) : super(key: key);
final String judul;
@override
Widget build(BuildContext context) {
return ShowUpAnimation(
delayStart: const Duration(seconds: 1),
curve: Curves.decelerate,
direction: Direction.horizontal,
child: Center(
child: Text(
judul,
style: GoogleFonts.poppins(
fontSize: 13,
fontWeight: FontWeight.w500,
letterSpacing: 1.2,
height: 1.4),
textAlign: TextAlign.justify,
),
),
);
}
}
import 'dart:convert';
import 'package:http/http.dart' as http;
import 'package:medapp_eksad/model/contact_model.dart';
Future<bool> savecontact(nama, email, nohp, message) async {
final response = await http.post(
Uri.parse('http://10.3.4.231:8081/medapp/v1/api/contact/save'),
body: jsonEncode({
"nama": nama,
"email": email,
"noHp": nohp,
"message": message}),
headers: {
'Content-type': 'application/json; charset=UTF-8',
});
if (response.statusCode == 200) {
return true;
} else {
return false;
}
}
Future<List<contact>> showcontact() async {
var response = await http
.get(Uri.parse('http://10.3.4.231:8082/medapp/v1/api/contact/get'));
var resultJson = jsonDecode(response.body)['data'];
List<contact> contactlist = await resultJson
.map<contact>((json) => contact.fromJson(json))
.toList();
return contactlist;
}
\ No newline at end of file
import 'dart:convert';
import 'package:http/http.dart' as http;
import 'package:medapp_eksad/model/wa_model.dart';
Future<bool> savewa(nama, nohp) async {
final response = await http.post(
Uri.parse('http://10.3.4.231:8081/medapp/v1/api/whatapps/save'),
body: jsonEncode({
"nama": nama,
"no": nohp
}),
headers: {
'Content-type': 'application/json; charset=UTF-8',
});
if (response.statusCode == 200) {
return true;
} else {
return false;
}
}
Future<List<dynamic>> showa() async {
var response = await http
.get(Uri.parse('http://10.3.4.231:8082/medapp/v1/api/whatapps/get'));
var resultJson = jsonDecode(response.body)['data'];
List<wa> walist = await resultJson
.map<wa>((json) => wa.fromJson(json))
.toList();
return walist;
}
\ No newline at end of file
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:medapp_eksad/appbar/appbar_home.dart'; import 'package:medapp_eksad/appbar/appbar_home.dart';
import 'package:medapp_eksad/screen_small/small_contact/small_contact_us2.dart';
import 'package:medapp_eksad/screen/contact_us/contact_us2.dart'; import 'package:medapp_eksad/screen/contact_us/contact_us2.dart';
import 'package:medapp_eksad/screen/footer.dart'; import 'package:medapp_eksad/screen/footer.dart';
import 'package:medapp_eksad/screen/home/home1.dart'; import 'package:medapp_eksad/screen/home/home1.dart';
...@@ -7,6 +8,9 @@ import 'package:medapp_eksad/screen/home/home2.dart'; ...@@ -7,6 +8,9 @@ import 'package:medapp_eksad/screen/home/home2.dart';
import 'package:medapp_eksad/screen/home/home3.dart'; import 'package:medapp_eksad/screen/home/home3.dart';
import 'package:medapp_eksad/screen/home/home4.dart'; import 'package:medapp_eksad/screen/home/home4.dart';
import 'package:medapp_eksad/screen_small/small_footer.dart'; import 'package:medapp_eksad/screen_small/small_footer.dart';
import 'package:medapp_eksad/screen_small/small_home/small_home1.dart';
import 'package:medapp_eksad/screen_small/small_home/small_home2.dart';
import 'package:medapp_eksad/screen_small/small_home/small_home3.dart';
import 'package:medapp_eksad/widget/drawer.dart'; import 'package:medapp_eksad/widget/drawer.dart';
import 'package:medapp_eksad/widget/responsive.dart'; import 'package:medapp_eksad/widget/responsive.dart';
import 'package:medapp_eksad/widget/whatsapp.dart'; import 'package:medapp_eksad/widget/whatsapp.dart';
...@@ -42,12 +46,12 @@ class _HomePageState extends State<HomePage> { ...@@ -42,12 +46,12 @@ class _HomePageState extends State<HomePage> {
drawer: const DrawerMeddApp(), drawer: const DrawerMeddApp(),
body: ResponsiveWidget.isSmallScreen(context) body: ResponsiveWidget.isSmallScreen(context)
? ListView( ? ListView(
children: [ children: const [
const Home1(), SmallHome1(),
const Home2(), SmallHome2(),
const Home3(), SmallHome3(),
ContactUs2(), ContactUs2_small(),
const FooterSmall(), FooterSmall(),
], ],
) )
: ListView( : ListView(
......
class contact {
int? idContact;
String? namaContact;
String? emailContact;
String? noHp;
String? messageContact;
contact(
{this.idContact,
this.namaContact,
this.emailContact,
this.noHp,
this.messageContact});
contact.fromJson(Map<String, dynamic> json) {
idContact = json['idContact'];
namaContact = json['namaContact'];
emailContact = json['emailContact'];
noHp = json['noHp'];
messageContact = json['messageContact'];
}
Map<String, dynamic> toJson() {
final Map<String, dynamic> data = new Map<String, dynamic>();
data['idContact'] = this.idContact;
data['namaContact'] = this.namaContact;
data['emailContact'] = this.emailContact;
data['noHp'] = this.noHp;
data['messageContact'] = this.messageContact;
return data;
}
}
class user {
String? idUser;
String? namaUser;
String? emailUser;
String? noHp;
String? username;
String? password;
String? statusUser;
user(
{this.idUser,
this.namaUser,
this.emailUser,
this.noHp,
this.username,
this.password,
this.statusUser});
user.fromJson(Map<String, dynamic> json) {
idUser = json['idUser'];
namaUser = json['namaUser'];
emailUser = json['emailUser'];
noHp = json['noHp'];
username = json['username'];
password = json['password'];
statusUser = json['statusUser'];
}
Map<String, dynamic> toJson() {
final Map<String, dynamic> data = new Map<String, dynamic>();
data['idUser'] = this.idUser;
data['namaUser'] = this.namaUser;
data['emailUser'] = this.emailUser;
data['noHp'] = this.noHp;
data['username'] = this.username;
data['password'] = this.password;
data['statusUser'] = this.statusUser;
return data;
}
}
class wa {
int? idWa;
String? namaWa;
String? noWa;
String? statusWa;
bool? activeWa;
wa({this.idWa, this.namaWa, this.noWa, this.statusWa, this.activeWa});
wa.fromJson(Map<String, dynamic> json) {
idWa = json['idWa'];
namaWa = json['namaWa'];
noWa = json['noWa'];
statusWa = json['statusWa'];
activeWa = json['activeWa'];
}
Map<String, dynamic> toJson() {
final Map<String, dynamic> data = new Map<String, dynamic>();
data['idWa'] = this.idWa;
data['namaWa'] = this.namaWa;
data['noWa'] = this.noWa;
data['statusWa'] = this.statusWa;
data['activeWa'] = this.activeWa;
return data;
}
}
\ No newline at end of file
...@@ -20,7 +20,7 @@ class Home1 extends StatelessWidget { ...@@ -20,7 +20,7 @@ class Home1 extends StatelessWidget {
color: Colors.transparent, color: Colors.transparent,
image: DecorationImage( image: DecorationImage(
image: AssetImage( image: AssetImage(
"assets/logo/homepage.png", "assets/images/homepage.png",
), ),
fit: BoxFit.cover), fit: BoxFit.cover),
), ),
......
...@@ -2,9 +2,9 @@ import 'package:flutter/material.dart'; ...@@ -2,9 +2,9 @@ import 'package:flutter/material.dart';
import 'package:medapp_eksad/appbar/appbar_home.dart'; import 'package:medapp_eksad/appbar/appbar_home.dart';
import 'package:medapp_eksad/screen/footer.dart'; import 'package:medapp_eksad/screen/footer.dart';
import 'package:medapp_eksad/screen/solution/our_solution.dart'; import 'package:medapp_eksad/screen/solution/our_solution.dart';
import 'package:medapp_eksad/screen/solution/our_solution2.dart';
import 'package:medapp_eksad/widget/responsive.dart'; import 'package:medapp_eksad/widget/responsive.dart';
import 'package:flutter/services.dart'; import 'package:flutter/services.dart';
import 'package:medapp_eksad/screen/solution/home3.dart';
void setPageTitle(String title, BuildContext context) { void setPageTitle(String title, BuildContext context) {
SystemChrome.setApplicationSwitcherDescription(ApplicationSwitcherDescription( SystemChrome.setApplicationSwitcherDescription(ApplicationSwitcherDescription(
...@@ -21,7 +21,7 @@ class Solutions extends StatefulWidget { ...@@ -21,7 +21,7 @@ class Solutions extends StatefulWidget {
} }
class _SolutionsState extends State<Solutions> { class _SolutionsState extends State<Solutions> {
final GlobalKey<ScaffoldState> _scaffoldKey = new GlobalKey<ScaffoldState>(); final GlobalKey<ScaffoldState> _scaffoldKey = GlobalKey<ScaffoldState>();
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
setPageTitle('MeddApp Solutions', context); setPageTitle('MeddApp Solutions', context);
...@@ -33,10 +33,10 @@ class _SolutionsState extends State<Solutions> { ...@@ -33,10 +33,10 @@ class _SolutionsState extends State<Solutions> {
: AppbarHomeLarge(screenSize, context, Colors.black, Colors.black, : AppbarHomeLarge(screenSize, context, Colors.black, Colors.black,
Colors.blue, Colors.black, Colors.black), Colors.blue, Colors.black, Colors.black),
body: ListView( body: ListView(
children: [ children: const [
OurSolution(), OurSolution(),
Home3(), OurSolution2(),
Footer() Footer(),
], ],
), ),
); );
...@@ -46,7 +46,7 @@ class _SolutionsState extends State<Solutions> { ...@@ -46,7 +46,7 @@ class _SolutionsState extends State<Solutions> {
return AppBar( return AppBar(
leading: IconButton( leading: IconButton(
onPressed: () => _scaffoldKey.currentState!.openDrawer(), onPressed: () => _scaffoldKey.currentState!.openDrawer(),
icon: Icon( icon: const Icon(
Icons.list_outlined, Icons.list_outlined,
size: 30, size: 30,
color: Colors.black, color: Colors.black,
...@@ -54,12 +54,10 @@ class _SolutionsState extends State<Solutions> { ...@@ -54,12 +54,10 @@ class _SolutionsState extends State<Solutions> {
), ),
backgroundColor: Colors.white, backgroundColor: Colors.white,
centerTitle: true, centerTitle: true,
title: Container( title: SizedBox(
child: SizedBox( height: 50,
height: 50, width: 150,
width: 150, child: Image.asset("assets/logo/medapp-logo.png"),
child: Image.asset("assets/logo/medapp-logo.png"),
),
), ),
// ), // ),
......
import 'package:flutter/material.dart';
import 'package:medapp_eksad/widget/image_slide.dart';
class OurSolution2 extends StatefulWidget {
const OurSolution2({Key? key}) : super(key: key);
@override
State<OurSolution2> createState() => _OurSolution2State();
}
class _OurSolution2State extends State<OurSolution2> {
@override
Widget build(BuildContext context) {
var screenSize = MediaQuery.of(context).size;
return Container(
width: screenSize.width,
height: screenSize.height*0.75,
padding: EdgeInsets.symmetric(horizontal: screenSize.width*0.1, vertical: screenSize.height*0.1),
child: Container(
width: screenSize.width*0.75,
height: screenSize.height*0.65,
child: VerticalSlider(),
),
);
}
}
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:google_fonts/google_fonts.dart'; import 'package:google_fonts/google_fonts.dart';
class ContactUs1_small extends StatefulWidget { class ContactUs1_small extends StatefulWidget {
const ContactUs1_small({Key? key}) : super(key: key); const ContactUs1_small({Key? key}) : super(key: key);
...@@ -26,13 +27,12 @@ class _ContactUsState extends State<ContactUs1_small> { ...@@ -26,13 +27,12 @@ class _ContactUsState extends State<ContactUs1_small> {
fit: BoxFit.cover)), fit: BoxFit.cover)),
), ),
Container( Container(
width: screenSize.width * 0.5, width: screenSize.width,
height: screenSize.height * 0.34, height: screenSize.height * 0.4,
padding: EdgeInsets.only( padding: EdgeInsets.only(top: screenSize.height*0.07),
right: screenSize.width * 0.30, left: screenSize.height * 0.06),
child: Column( child: Column(
crossAxisAlignment: CrossAxisAlignment.start, crossAxisAlignment: CrossAxisAlignment.center,
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: [ children: [
Text( Text(
'Contact Us', 'Contact Us',
...@@ -40,7 +40,6 @@ class _ContactUsState extends State<ContactUs1_small> { ...@@ -40,7 +40,6 @@ class _ContactUsState extends State<ContactUs1_small> {
fontSize: 37, fontSize: 37,
fontWeight: FontWeight.bold, fontWeight: FontWeight.bold,
color: Colors.white), color: Colors.white),
overflow: TextOverflow.ellipsis,
), ),
], ],
), ),
......
...@@ -6,9 +6,15 @@ import 'dart:convert'; ...@@ -6,9 +6,15 @@ import 'dart:convert';
import 'package:http/http.dart' as http; import 'package:http/http.dart' as http;
import 'package:medapp_eksad/widget/button_color.dart'; import 'package:medapp_eksad/widget/button_color.dart';
class ContactUs2_small extends StatelessWidget {
ContactUs2_small({Key? key}) : super(key: key);
class ContactUs2_small extends StatefulWidget {
const ContactUs2_small({Key? key}) : super(key: key);
@override
State<ContactUs2_small> createState() => _ContactUs2_smallState();
}
class _ContactUs2_smallState extends State<ContactUs2_small> {
final _formKey = GlobalKey<FormState>(); final _formKey = GlobalKey<FormState>();
final nameController = TextEditingController(); final nameController = TextEditingController();
...@@ -20,7 +26,7 @@ class ContactUs2_small extends StatelessWidget { ...@@ -20,7 +26,7 @@ class ContactUs2_small extends StatelessWidget {
Widget build(BuildContext context) { Widget build(BuildContext context) {
var screenSize = MediaQuery.of(context).size; var screenSize = MediaQuery.of(context).size;
return Container( return Container(
height: screenSize.height * 1.5, height: screenSize.height * 1.75,
width: screenSize.width, width: screenSize.width,
padding: EdgeInsets.symmetric(horizontal: 15), padding: EdgeInsets.symmetric(horizontal: 15),
// color: Colors.blue, // color: Colors.blue,
...@@ -40,214 +46,222 @@ class ContactUs2_small extends StatelessWidget { ...@@ -40,214 +46,222 @@ class ContactUs2_small extends StatelessWidget {
crossAxisAlignment: CrossAxisAlignment.start, crossAxisAlignment: CrossAxisAlignment.start,
mainAxisAlignment: MainAxisAlignment.spaceEvenly, mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: [ children: [
Text( Center(
'Yes, you need ' child: Text(
'\n' 'Yes, you need '
'an outsourcing partner ' '\n'
'you can trust and thrive with', 'an outsourcing partner '
textAlign: TextAlign.left, 'you can trust and thrive with',
style: GoogleFonts.poppins( textAlign: TextAlign.left,
color: Colors.white, style: GoogleFonts.poppins(
fontSize: 30, color: Colors.white,
fontWeight: FontWeight.bold)), fontSize: 30,
Text( fontWeight: FontWeight.bold)),
'Go for the one who knows what they are doing, those who you share values with, ' ),
'and those who will celebrate your success, and help you win over your biggest challenges. ' Center(
'Looking for an outsourcing partner? ', child: Text(
textAlign: TextAlign.justify, 'Go for the one who knows what they are doing, those who you share values with, '
style: GoogleFonts.poppins( 'and those who will celebrate your success, and help you win over your biggest challenges. '
color: Colors.white, 'Looking for an outsourcing partner? ',
fontSize: 18, textAlign: TextAlign.justify,
// fontWeight: FontWeight.bold, style: GoogleFonts.poppins(
letterSpacing: 1.1)), color: Colors.white,
Text("We’ll contact you immediately to discuss to help you.", fontSize: 18,
style: GoogleFonts.poppins( // fontWeight: FontWeight.bold,
color: Colors.white, fontSize: 18, letterSpacing: 1.2)), letterSpacing: 1.1)),
Form( ),
key: _formKey, Center(
child: Column( child: Text("We’ll contact you immediately to discuss to help you.",
crossAxisAlignment: CrossAxisAlignment.start, style: GoogleFonts.poppins(
mainAxisAlignment: MainAxisAlignment.spaceEvenly, color: Colors.white, fontSize: 18, letterSpacing: 1.2)),
children: [ ),
Container( Center(
child: Text( child: Form(
"Name", key: _formKey,
style: GoogleFonts.poppins( child: Column(
color: Colors.white, crossAxisAlignment: CrossAxisAlignment.start,
fontSize: 20, mainAxisAlignment: MainAxisAlignment.spaceEvenly,
fontWeight: FontWeight.w400), children: [
Container(
child: Text(
"Name",
style: GoogleFonts.poppins(
color: Colors.white,
fontSize: 20,
fontWeight: FontWeight.w400),
),
), ),
), Container(
Container( width: 450,
width: 450, child: TextFormField(
child: TextFormField( controller: nameController,
controller: nameController, decoration: const InputDecoration(
decoration: const InputDecoration( hintText: "Enter your Name",
hintText: "Enter your Name", fillColor: Colors.white,
fillColor: Colors.white, filled: true,
filled: true, enabledBorder: OutlineInputBorder(
enabledBorder: OutlineInputBorder( borderRadius: BorderRadius.zero,
borderRadius: BorderRadius.zero, borderSide:
borderSide: BorderSide(width: 1, color: Colors.white),
BorderSide(width: 1, color: Colors.white), ),
), focusedBorder: OutlineInputBorder(
focusedBorder: OutlineInputBorder( borderRadius: BorderRadius.zero,
borderRadius: BorderRadius.zero, borderSide:
borderSide: BorderSide(width: 1, color: Colors.white),
BorderSide(width: 1, color: Colors.white), ),
), ),
), ),
), ),
), const SizedBox(
const SizedBox( height: 20,
height: 20,
),
Container(
child: Text(
"Phone Number",
style: GoogleFonts.poppins(
color: Colors.white,
fontSize: 20,
fontWeight: FontWeight.w400),
), ),
), Container(
const SizedBox( child: Text(
width: 80, "Phone Number",
), style: GoogleFonts.poppins(
Container( color: Colors.white,
width: 450, fontSize: 20,
child: TextFormField( fontWeight: FontWeight.w400),
controller: phoneController, ),
decoration: const InputDecoration( ),
hintText: "Enter a valid phone number", const SizedBox(
fillColor: Colors.white, width: 80,
filled: true, ),
enabledBorder: OutlineInputBorder( Container(
borderRadius: BorderRadius.zero, width: 450,
borderSide: child: TextFormField(
BorderSide(width: 1, color: Colors.white), controller: phoneController,
decoration: const InputDecoration(
hintText: "Enter a valid phone number",
fillColor: Colors.white,
filled: true,
enabledBorder: OutlineInputBorder(
borderRadius: BorderRadius.zero,
borderSide:
BorderSide(width: 1, color: Colors.white),
),
focusedBorder: OutlineInputBorder(
borderRadius: BorderRadius.zero,
borderSide:
BorderSide(width: 1, color: Colors.white),
),
), ),
focusedBorder: OutlineInputBorder( ),
borderRadius: BorderRadius.zero, ),
borderSide: const SizedBox(
BorderSide(width: 1, color: Colors.white), height: 20,
),
Container(
child: Text(
"Email",
style: GoogleFonts.poppins(
color: Colors.white,
fontSize: 20,
fontWeight: FontWeight.w400),
),
),
const SizedBox(
width: 7,
),
Container(
width: 450,
child: TextFormField(
controller: emailController,
decoration: const InputDecoration(
hintText: "Enter a valid email address",
fillColor: Colors.white,
filled: true,
enabledBorder: OutlineInputBorder(
borderRadius: BorderRadius.zero,
borderSide:
BorderSide(width: 1, color: Colors.white),
),
focusedBorder: OutlineInputBorder(
borderRadius: BorderRadius.zero,
borderSide:
BorderSide(width: 1, color: Colors.white),
),
), ),
), ),
), ),
), const SizedBox(
const SizedBox( height: 20,
height: 20, ),
), Text(
Container( "Message",
child: Text(
"Email",
style: GoogleFonts.poppins( style: GoogleFonts.poppins(
color: Colors.white, color: Colors.white,
fontSize: 20, fontSize: 20,
fontWeight: FontWeight.w400), fontWeight: FontWeight.w400),
), ),
), Container(
const SizedBox( width: 450,
width: 7, child: TextFormField(
), controller: messageController,
Container( decoration: const InputDecoration(
width: 450, hintText: "Enter your message",
child: TextFormField( fillColor: Colors.white,
controller: emailController, filled: true,
decoration: const InputDecoration( enabledBorder: OutlineInputBorder(
hintText: "Enter a valid email address", borderRadius: BorderRadius.zero,
fillColor: Colors.white, borderSide:
filled: true, BorderSide(width: 1, color: Colors.white),
enabledBorder: OutlineInputBorder( ),
borderRadius: BorderRadius.zero, focusedBorder: OutlineInputBorder(
borderSide: borderRadius: BorderRadius.zero,
BorderSide(width: 1, color: Colors.white), borderSide:
), BorderSide(width: 1, color: Colors.white),
focusedBorder: OutlineInputBorder( ),
borderRadius: BorderRadius.zero,
borderSide:
BorderSide(width: 1, color: Colors.white),
), ),
maxLines: 5,
validator: (value) {
if (value == null || value.isEmpty) {
return '*Required';
}
return null;
},
), ),
), ),
), const SizedBox(
const SizedBox( height: 20,
height: 20,
),
Text(
"Message",
style: GoogleFonts.poppins(
color: Colors.white,
fontSize: 20,
fontWeight: FontWeight.w400),
),
Container(
width: 450,
child: TextFormField(
controller: messageController,
decoration: const InputDecoration(
hintText: "Enter your message",
fillColor: Colors.white,
filled: true,
enabledBorder: OutlineInputBorder(
borderRadius: BorderRadius.zero,
borderSide:
BorderSide(width: 1, color: Colors.white),
),
focusedBorder: OutlineInputBorder(
borderRadius: BorderRadius.zero,
borderSide:
BorderSide(width: 1, color: Colors.white),
),
),
maxLines: 5,
validator: (value) {
if (value == null || value.isEmpty) {
return '*Required';
}
return null;
},
), ),
), SizedBox(
const SizedBox( height: 45,
height: 20, width: 100,
), child: TextButton(
SizedBox( style: Btn_Submit(),
height: 45, onPressed: () async {
width: 100, if (_formKey.currentState!.validate()) {
child: TextButton( final response = await SendEmail(
style: Btn_Submit(), nameController.value.text,
onPressed: () async { phoneController.value.text,
if (_formKey.currentState!.validate()) { emailController.value.text,
final response = await SendEmail( messageController.value.text);
nameController.value.text, ScaffoldMessenger.of(context).showSnackBar(
phoneController.value.text, response == 200
emailController.value.text, ? const SnackBar(
messageController.value.text); content: Text('Message Sent!'),
ScaffoldMessenger.of(context).showSnackBar( backgroundColor: Colors.green)
response == 200 : const SnackBar(
? const SnackBar( content:
content: Text('Message Sent!'), Text('Failed to send message!'),
backgroundColor: Colors.green) backgroundColor: Colors.red),
: const SnackBar( );
content:
Text('Failed to send message!'),
backgroundColor: Colors.red),
);
nameController.clear(); nameController.clear();
phoneController.clear(); phoneController.clear();
emailController.clear(); emailController.clear();
messageController.clear(); messageController.clear();
} }
}, },
child: const Text( child: const Text(
'Submit', 'Submit',
style: TextStyle(fontSize: 16, color: Colors.white), style: TextStyle(fontSize: 16, color: Colors.white),
),
), ),
), ),
), ]),
]), ),
), ),
]), ]),
), ),
...@@ -278,3 +292,5 @@ class ContactUs2_small extends StatelessWidget { ...@@ -278,3 +292,5 @@ class ContactUs2_small extends StatelessWidget {
return response.statusCode; return response.statusCode;
} }
} }
import 'package:flutter/material.dart';
import 'package:google_fonts/google_fonts.dart';
import 'package:medapp_eksad/widget/button_color.dart';
import 'package:show_up_animation/show_up_animation.dart';
class SmallHome1 extends StatelessWidget {
const SmallHome1({Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
var screenSize = MediaQuery.of(context).size;
return Stack(
children: [
Container(
width: screenSize.width,
height: screenSize.height * 0.7,
decoration: const BoxDecoration(
color: Colors.transparent,
image: DecorationImage(
image: AssetImage(
"assets/images/homepage.png",
),
fit: BoxFit.cover),
),
),
Container(
width: screenSize.width,
height: screenSize.height * 0.7,
decoration: BoxDecoration(
color: Colors.blue,
gradient: LinearGradient(
colors: [
Colors.blue.withOpacity(0.0),
Colors.blue,
],
stops: const [0.0, 1.0],
),
),
),
Container(
width: screenSize.width,
height: screenSize.height * 0.65,
padding: EdgeInsets.only(
left: screenSize.width * 0.4, top: screenSize.height * 0.05),
child: Column(
//crossAxisAlignment: CrossAxisAlignment.center,
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: [
Container(
width: screenSize.width * 0.5,
height: screenSize.height * 0.09,
child: ShowUpAnimation(
delayStart: const Duration(seconds: 1),
direction: Direction.horizontal,
child: Text(
'Engage With Your Patients More Efficiently',
textAlign: TextAlign.center,
style: GoogleFonts.poppins(
fontSize: 20,
fontWeight: FontWeight.bold,
color: Colors.white),
// overflow: TextOverflow.ellipsis,
),
),
),
Container(
// padding: EdgeInsets.only(top: 1),
width: screenSize.width * 0.47,
height: screenSize.height * 0.31,
child: ShowUpAnimation(
delayStart: const Duration(seconds: 1),
curve: Curves.bounceIn,
direction: Direction.horizontal,
// offset: -0.2,
child: Text(
'Welcome to healthcare’s most powerful collaboration suite. '
'Enhance clinical workflows, speed decisions, and improve'
' patient outcomes, safely and securely.',
textAlign: TextAlign.center,
style: GoogleFonts.poppins(
fontSize: 15,
// letterSpacing: 1.3,
// height: 1.5,
fontWeight: FontWeight.bold,
color: Colors.white),
),
),
),
Container(
width: screenSize.width * 0.36,
height: screenSize.height * 0.1,
child: ShowUpAnimation(
delayStart: const Duration(seconds: 1),
curve: Curves.bounceIn,
direction: Direction.horizontal,
offset: -0.2,
child: ElevatedButton(
onPressed: () {
Navigator.pushNamed(context, '/contact');
},
style: DefaultColors(),
child: const Text(
'TALK WITH EXPERT',
style: TextStyle(
fontSize: 16,
letterSpacing: 2,
color: Colors.white,
fontWeight: FontWeight.w500),
textAlign: TextAlign.center,
),
),
),
)
],
),
),
],
);
}
}
import 'package:flutter/material.dart';
import 'package:google_fonts/google_fonts.dart';
import 'package:medapp_eksad/animation/kiri_kanan_small.dart';
import 'package:show_up_animation/show_up_animation.dart';
class SmallHome2 extends StatelessWidget {
const SmallHome2({Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
var screenSize = MediaQuery.of(context).size;
return Container(
width: screenSize.width * 0.5,
color: const Color.fromARGB(255, 227, 235, 253),
height: screenSize.height*2,
padding: EdgeInsets.only(
left: screenSize.width * 0.10,
right: screenSize.width * 0.10,
),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: [
SizedBox(height: 1,),
Container(
width: screenSize.width,
child: Text('How do we help ?',
style: GoogleFonts.poppins(
fontSize: 30,
color: const Color.fromARGB(255, 12, 66, 101),
fontWeight: FontWeight.bold)),
),
Container(
width: screenSize.width,
height: screenSize.height*0.35,
child: Text(
'We understand that the global healthcare industry is experiencing several challenges, thus requiring a company`s ability to respond to these challenges quickly and innovatively, '
'and seize opportunities that arise will be critical to ensuring the company`s sustainability in the future.',
textAlign: TextAlign.justify,
style: GoogleFonts.poppins(
fontSize: 15,
letterSpacing: 1.1,
height: 1.5,
fontWeight: FontWeight.w500)),
),
Column(
// mainAxisAlignment: MainAxisAlignment.start,
children: [
ShowUpAnimation(
delayStart: const Duration(seconds: 1),
curve: Curves.decelerate,
direction: Direction.horizontal,
offset: -0.3,
child: list_help(
screenSize: screenSize,
titel: 'Costs are getting more expensive'),
),
ShowUpAnimation(
delayStart: const Duration(seconds: 2),
curve: Curves.decelerate,
direction: Direction.horizontal,
child: list_help(
screenSize: screenSize,
titel: "Demographic Change",
),
),
ShowUpAnimation(
delayStart: const Duration(seconds: 3),
curve: Curves.decelerate,
direction: Direction.horizontal,
offset: -0.3,
child: list_help(
screenSize: screenSize,
titel: "Rare talents"),
),
ShowUpAnimation(
delayStart: const Duration(seconds: 4),
curve: Curves.decelerate,
direction: Direction.horizontal,
child: list_help(
screenSize: screenSize,
titel: "Rapid technological Change",
),
),
ShowUpAnimation(
delayStart: const Duration(seconds: 5),
curve: Curves.decelerate,
direction: Direction.horizontal,
offset: -0.3,
child: list_help(
screenSize: screenSize,
titel: "Changes in consumer behavior"),
),
],
),
Container(
width: screenSize.width,
height: screenSize.height*0.4,
child: Text(
'Too much admin. Longer work hours. Less time spent with patients.'
'You’re not alone in the stress and frustration these cause. At MedApps, '
'our medical practice management software is designed to make your life easier,'
'not harder. Which means you can get on with doing what you do best, in ways that work best for you.',
textAlign: TextAlign.justify,
style: GoogleFonts.poppins(
fontSize: 15,
letterSpacing: 1.1,
height: 1.5,
fontWeight: FontWeight.w500)),
),
Container(
width: screenSize.width,
height: screenSize.height*0.4,
child: Text(
'MedApps combines practice management and clinical workflows into one seamless, modern interface. '
'Manage all patient interactions securely on the go, or in your practice.'
'Benefit from server-free* infrastructure, automatic upgrades and simple licensing.',
textAlign: TextAlign.justify,
style: GoogleFonts.poppins(
fontSize: 15,
letterSpacing: 1.1,
height: 1.5,
fontWeight: FontWeight.w500)),
),
],
),
);
}
}
class list_help extends StatelessWidget {
const list_help({Key? key, required this.screenSize, required this.titel})
: super(key: key);
final Size screenSize;
final String titel;
@override
Widget build(BuildContext context) {
return ListTile(
leading: const Icon(
Icons.circle_rounded,
size: 12,
color: Colors.black,
),
title: Container(
// padding: const EdgeInsets.only(left: 10),
// width: screenSize.width * 0.35,
// height: screenSize.height * 0.1,
child: Text(
titel,
style: GoogleFonts.poppins(
fontSize: 16,
height: 1.3,
),
textAlign: TextAlign.left,
),
));
}
}
import 'package:flutter/material.dart';
import 'package:google_fonts/google_fonts.dart';
import 'package:medapp_eksad/animation/animasi_kanan_kiri.dart';
import 'package:medapp_eksad/animation/animasi_kiri_kanan.dart';
import 'package:show_up_animation/show_up_animation.dart';
class SmallHome3 extends StatefulWidget {
const SmallHome3({Key? key}) : super(key: key);
@override
State<SmallHome3> createState() => _SmallHome3State();
}
class _SmallHome3State extends State<SmallHome3> {
@override
Widget build(BuildContext context) {
var screenSize = MediaQuery.of(context).size;
return Container(
padding: EdgeInsets.symmetric(horizontal: 15),
height: screenSize.height * 2.6,
width: screenSize.width,
child: Column(
children: [
const SizedBox(
height: 40,
),
Text("Why MedApps ?",
style: GoogleFonts.poppins(
fontSize: 36,
color: const Color(0xff1e5ea8),
fontWeight: FontWeight.bold)),
const SizedBox(
height: 20,
),
SizedBox(
width: screenSize.width,
height: screenSize.height * 0.45,
child: Row(
children: [
Container(
width: screenSize.width*0.4,
height: screenSize.height * 0.65,
child: Column(
crossAxisAlignment: CrossAxisAlignment.center,
mainAxisAlignment: MainAxisAlignment.center,
children: [
Container(
width: screenSize.width * 0.4,
child: Animasi_Kiri_Kanan(
screenSize: screenSize,
widget: Image.asset(
'assets/icons/why1.png',
height: 60,
width: 60,
))),
SizedBox(height: 20,),
Container(
padding: EdgeInsets.symmetric(horizontal: 10),
width: 200,
height: 20,
child: const Text(
'QUEUE SYSTEM',
style: TextStyle(
color: Colors.blueAccent,
fontSize: 15,
letterSpacing: 1.1,
fontWeight: FontWeight.w600),
textAlign: TextAlign.center,
),
),
],
),
),
Container(
width: screenSize.width*0.5,
height: screenSize.height * 0.65,
child: const Animasi_Kanan_Kiri_Justify(
judul:
'Simplify the process of getting queue numbers for various hospital services such as: '
'consulting with doctors, using hospital facilities (radiology, laboratories, etc.) and '
'purchasing drugs from pharmacies.'))
],
),
),
SizedBox(
width: screenSize.width,
height: screenSize.height * 0.45,
child: Row(
children: [
Container(
width: screenSize.width*0.4,
height: screenSize.height * 0.65,
child: Column(
crossAxisAlignment: CrossAxisAlignment.center,
mainAxisAlignment: MainAxisAlignment.center,
children: [
Container(
width: screenSize.width * 0.4,
child: Animasi_Kiri_Kanan(
screenSize: screenSize,
widget: Image.asset(
'assets/icons/why2.png',
height: 60,
width: 60,
))),
SizedBox(height: 20,),
Container(
padding: EdgeInsets.symmetric(horizontal: 10),
width: 200,
height: 70,
child: const Text(
'ENGAGEMENT TO PATIENTS WITH NOTIFICATIONS',
style: TextStyle(
color: Colors.blueAccent,
fontSize: 15,
letterSpacing: 1.1,
fontWeight: FontWeight.w600),
textAlign: TextAlign.center,
),
),
],
),
),
Container(
width: screenSize.width*0.5,
height: screenSize.height * 0.65,
child: const Animasi_Kanan_Kiri_Justify(
judul:
'Patients get \nnotifications of queue movements so they can adjust their arrival schedule to the hospital. '
'Arrivals close to this service time will have an impact on reducing the crowd of people queuing at the hospital. '
'Queue information is integrated with the queue display panel in the hospital.'))
],
),
),
SizedBox(
width: screenSize.width,
height: screenSize.height * 0.45,
child: Row(
children: [
Container(
width: screenSize.width*0.4,
height: screenSize.height * 0.65,
child: Column(
crossAxisAlignment: CrossAxisAlignment.center,
mainAxisAlignment: MainAxisAlignment.center,
children: [
Container(
width: screenSize.width * 0.4,
child: Animasi_Kiri_Kanan(
screenSize: screenSize,
widget: Image.asset(
'assets/icons/why3.png',
height: 60,
width: 60,
))),
SizedBox(height: 20,),
Container(
padding: EdgeInsets.symmetric(horizontal: 10),
width: 200,
height: 70,
child: const Text(
'SELF-REGISTRATION THROUGH MOBILE APPLICATION OR KIOSK',
style: TextStyle(
color: Colors.blueAccent,
fontSize: 15,
letterSpacing: 1.1,
fontWeight: FontWeight.w600),
textAlign: TextAlign.center,
),
),
],
),
),
Container(
width: screenSize.width*0.5,
height: screenSize.height * 0.65,
child: const Animasi_Kanan_Kiri_Justify(
judul:
'Patients can self-register through a mobile application or kiosk, '
'thereby reducing queues at the hospital.'))
],
),
),
SizedBox(
width: screenSize.width,
height: screenSize.height * 0.35,
child: Row(
children: [
Container(
width: screenSize.width*0.4,
height: screenSize.height * 0.65,
child: Column(
crossAxisAlignment: CrossAxisAlignment.center,
mainAxisAlignment: MainAxisAlignment.center,
children: [
Container(
width: screenSize.width * 0.4,
child: Animasi_Kiri_Kanan(
screenSize: screenSize,
widget: Image.asset(
'assets/icons/why4.png',
height: 60,
width: 60,
))),
SizedBox(height: 20,),
Container(
padding: EdgeInsets.symmetric(horizontal: 10),
width: 200,
height: 60,
child: const Text(
'MULTI CHANNEL PAYMENT',
style: TextStyle(
color: Colors.blueAccent,
fontSize: 15,
letterSpacing: 1.1,
fontWeight: FontWeight.w600),
textAlign: TextAlign.center,
),
),
],
),
),
Container(
width: screenSize.width*0.5,
height: screenSize.height * 0.65,
child: const Animasi_Kanan_Kiri_Justify(
judul:
'Acceptance of payments can be done easily and flexibly with the availability of '
'online payment systems (credit cards, transfers, digital-wallet).'))
],
),
),
SizedBox(
width: screenSize.width,
height: screenSize.height * 0.35,
child: Row(
children: [
Container(
width: screenSize.width*0.4,
height: screenSize.height * 0.55,
child: Column(
crossAxisAlignment: CrossAxisAlignment.center,
mainAxisAlignment: MainAxisAlignment.center,
children: [
Container(
width: screenSize.width * 0.4,
child: Animasi_Kiri_Kanan(
screenSize: screenSize,
widget: Image.asset(
'assets/icons/why4.png',
height: 60,
width: 60,
))),
SizedBox(height: 20,),
Container(
padding: EdgeInsets.symmetric(horizontal: 10),
width: 200,
height: 40,
child: const Text(
'DRUG DELIVERY',
style: TextStyle(
color: Colors.blueAccent,
fontSize: 15,
letterSpacing: 1.1,
fontWeight: FontWeight.w600),
textAlign: TextAlign.center,
),
),
],
),
),
Container(
width: screenSize.width*0.5,
height: screenSize.height * 0.55,
child: const Animasi_Kanan_Kiri_Justify(
judul:
'Drug delivery works in collaboration with goods delivery service providers '
'which are currently developing fast.',))
],
),
),
SizedBox(
width: screenSize.width,
height: screenSize.height * 0.35,
child: Row(
children: [
Container(
width: screenSize.width*0.4,
height: screenSize.height * 0.45,
child: Column(
crossAxisAlignment: CrossAxisAlignment.center,
mainAxisAlignment: MainAxisAlignment.center,
children: [
Container(
width: screenSize.width * 0.4,
child: Animasi_Kiri_Kanan(
screenSize: screenSize,
widget: Image.asset(
'assets/icons/why4.png',
height: 60,
width: 60,
))),
SizedBox(height: 20,),
Container(
padding: EdgeInsets.symmetric(horizontal: 10),
width: 200,
height: 70,
child: const Text(
'OTHER FEATURES',
style: TextStyle(
color: Colors.blueAccent,
fontSize: 15,
letterSpacing: 1.1,
fontWeight: FontWeight.w600),
textAlign: TextAlign.center,
),
),
],
),
),
Container(
width: screenSize.width*0.5,
height: screenSize.height * 0.45,
child: const Animasi_Kanan_Kiri_Justify(
judul:
'Online consultation (to be integrated with the current RSSC system), '
'Emergency assistance to call ambulances and doctors, '
'Rating by consumers for each service',))
],
),
),
],
),
);
}
}
import 'package:flutter/material.dart';
import 'package:carousel_slider/carousel_slider.dart';
final List<String> imgList = [
'/images/homepage.png',
'/images/solution.jpg',
'/images/contactus1.jpg',
];
final List<Widget> imageSliders = imgList
.map((item) => Container(
child: Container(
margin: const EdgeInsets.all(5.0),
child: ClipRRect(
borderRadius: const BorderRadius.all(Radius.circular(5.0)),
child: Stack(
children: <Widget>[
Image.asset(
item,
fit: BoxFit.cover,
width: 840,
),
Positioned(
bottom: 0.0,
left: 0.0,
right: 0.0,
child: Container(
decoration: const BoxDecoration(
gradient: LinearGradient(
colors: [
Color.fromARGB(200, 0, 0, 0),
Color.fromARGB(0, 0, 0, 0)
],
begin: Alignment.bottomCenter,
end: Alignment.topCenter,
),
),
// padding: const EdgeInsets.symmetric(
// vertical: 10.0, horizontal: 20.0),
// child: const Text(
// 'Bootcamp',
// //'No. ${imgList.indexOf(item)} image',
// style: TextStyle(
// color: Colors.white,
// fontSize: 20.0,
// fontWeight: FontWeight.bold,
// ),
// ),
),
),
],
)),
),
))
.toList();
final CarouselController _controller = CarouselController();
@override
void initState() {
initState();
}
class VerticalSlider extends StatelessWidget {
@override
Widget build(BuildContext context) {
var screenSize = MediaQuery.of(context).size;
return Stack(
children: [
Container(
width: screenSize.width*0.8,
child: CarouselSlider(
carouselController: _controller,
options: CarouselOptions(
aspectRatio: 2.0,
enlargeCenterPage: true,
scrollDirection: Axis.horizontal,
autoPlay: true,
),
items: imageSliders,
),
),
Center(
child: Row(
crossAxisAlignment: CrossAxisAlignment.center,
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
Flexible(
child: ElevatedButton(
onPressed: () => _controller.previousPage(),
child: Icon(Icons.arrow_back_ios_new_outlined),
style: ElevatedButton.styleFrom(primary: Colors.grey),
),
),
Flexible(
child: ElevatedButton(
onPressed: () => _controller.nextPage(),
child: Icon(Icons.arrow_forward_ios_outlined),
style: ElevatedButton.styleFrom(primary: Colors.grey),
),
),
],
),
)
],
);
}
}
...@@ -15,6 +15,20 @@ packages: ...@@ -15,6 +15,20 @@ packages:
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "2.1.0" version: "2.1.0"
carousel_indicator:
dependency: "direct main"
description:
name: carousel_indicator
url: "https://pub.dartlang.org"
source: hosted
version: "1.0.6"
carousel_slider:
dependency: "direct main"
description:
name: carousel_slider
url: "https://pub.dartlang.org"
source: hosted
version: "4.1.1"
characters: characters:
dependency: transitive dependency: transitive
description: description:
...@@ -261,6 +275,13 @@ packages: ...@@ -261,6 +275,13 @@ packages:
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "4.2.4" version: "4.2.4"
scaled_list:
dependency: "direct main"
description:
name: scaled_list
url: "https://pub.dartlang.org"
source: hosted
version: "2.0.0"
show_up_animation: show_up_animation:
dependency: "direct main" dependency: "direct main"
description: description:
......
...@@ -46,6 +46,9 @@ dependencies: ...@@ -46,6 +46,9 @@ dependencies:
show_up_animation: ^2.0.0 show_up_animation: ^2.0.0
http: ^0.13.4 http: ^0.13.4
spring: ^2.0.2 spring: ^2.0.2
carousel_slider: ^4.1.1
carousel_indicator: ^1.0.6
scaled_list: ^2.0.0
dev_dependencies: dev_dependencies:
flutter_test: flutter_test:
......
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