210 lines
10 KiB
Dart
210 lines
10 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:gymlink_module_web/components/app_bar.dart';
|
|
import 'package:gymlink_module_web/components/item_card.dart';
|
|
import 'package:gymlink_module_web/pages/basket.dart';
|
|
import 'package:gymlink_module_web/pages/detail.dart';
|
|
import 'package:gymlink_module_web/pages/order_history.dart';
|
|
import 'package:gymlink_module_web/tools/relative.dart';
|
|
import 'package:url_launcher/url_launcher.dart';
|
|
|
|
const List<Map<String, String>> testData = [
|
|
{
|
|
"name": "Протеин",
|
|
"image": "product.png",
|
|
"price": "120",
|
|
"details": "Test details",
|
|
"id": "34fa3126-bfaf-5dec-8f4a-b246c097ef73"
|
|
},
|
|
{
|
|
"name": "Протеин",
|
|
"image": "product.png",
|
|
"price": "150",
|
|
"details":
|
|
"that name factory say string eaten order harbor easier said tone now floor nest it comfortable such difficulty labor bridge fact market women badly chamber heading forest allow shirt possibly story strip elephant extra even joy lungs than low discussion barn rapidly evidence is stream crew let more sold bag river triangle court slept knowledge flat package research balloon station underline careful market better make curious secret boy poor captured creature harder public tool ring subject charge planet tone scientist piece page stone support bush way feathers summer describe back should said complex song giant his that name factory say string eaten order harbor easier said tone now floor nest it comfortable such difficulty labor bridge fact market women badly chamber heading forest allow shirt possibly story strip elephant extra even joy lungs than low discussion barn rapidly evidence is stream crew let more sold bag river triangle court slept knowledge flat package research balloon station underline careful market better make curious secret boy poor captured creature harder public tool ring subject charge planet tone scientist piece page stone support bush way feathers summer describe back should said complex song giant his that name factory say string eaten order harbor easier said tone now floor nest it comfortable such difficulty labor bridge fact market women badly chamber heading forest allow shirt possibly story strip elephant extra even joy lungs than low discussion barn rapidly evidence is stream crew let more sold bag river triangle court slept knowledge flat package research balloon station underline careful market better make curious secret boy poor captured creature harder public tool ring subject charge planet tone scientist piece page stone support bush way feathers summer describe back should said complex song giant his that name factory say string eaten order harbor easier said tone now floor nest it comfortable such difficulty labor bridge fact market women badly chamber heading forest allow shirt possibly story strip elephant extra even joy lungs than low discussion barn rapidly evidence is stream crew let more sold bag river triangle court slept knowledge flat package research balloon station underline careful market better make curious secret boy poor captured creature harder public tool ring subject charge planet tone scientist piece page stone support bush way feathers summer describe back should said complex song giant his",
|
|
"id": "34a26e82-7656-5e98-a44a-c2d01d0b1ad1123"
|
|
},
|
|
{
|
|
"name": "Протеин",
|
|
"image": "product.png",
|
|
"price": "250",
|
|
"details": "Test details",
|
|
"id": "4fb204b7-3f9e-52a2-bed1-415c00a31a37123"
|
|
},
|
|
{
|
|
"name": "Протеин",
|
|
"image": "product.png",
|
|
"price": "300",
|
|
"details": "Test details",
|
|
"id": "09b2f5bb-683e-5c39-ae89-b8e152fa8bcf123"
|
|
},
|
|
{
|
|
"name": "Протеин",
|
|
"image": "product.png",
|
|
"price": "100",
|
|
"details": "Test details",
|
|
"id": "cd1b6817-db94-5394-be1d-af88af79749f123"
|
|
}
|
|
];
|
|
|
|
class MainPage extends StatefulWidget {
|
|
final bool isLoading;
|
|
|
|
const MainPage({
|
|
super.key,
|
|
required this.isLoading,
|
|
});
|
|
|
|
@override
|
|
State<MainPage> createState() => _MainPageState();
|
|
}
|
|
|
|
class _MainPageState extends State<MainPage> {
|
|
Future<void> _goToPage() async {
|
|
final Uri url = Uri.parse('https://google.com');
|
|
if (!await launchUrl(url, webOnlyWindowName: '_blank')) {
|
|
throw 'Could not launch $url';
|
|
}
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return Scaffold(
|
|
appBar: widget.isLoading ? null : const GymLinkAppBar(),
|
|
body: widget.isLoading
|
|
? const Center(child: CircularProgressIndicator())
|
|
: Column(
|
|
mainAxisAlignment: MainAxisAlignment.start,
|
|
children: <Widget>[
|
|
Padding(
|
|
padding: const EdgeInsets.symmetric(horizontal: 5),
|
|
child: Row(
|
|
mainAxisAlignment: MainAxisAlignment.spaceAround,
|
|
children: [
|
|
Expanded(
|
|
child: TextField(
|
|
decoration: InputDecoration(
|
|
hintText: 'Search',
|
|
border: OutlineInputBorder(
|
|
borderRadius: BorderRadius.circular(10),
|
|
),
|
|
suffixIcon: Padding(
|
|
padding: const EdgeInsets.only(right: 8),
|
|
child: ElevatedButton(
|
|
onPressed: _goToPage,
|
|
style: ElevatedButton.styleFrom(
|
|
padding: const EdgeInsets.symmetric(
|
|
vertical: 8,
|
|
horizontal: 0,
|
|
),
|
|
minimumSize:
|
|
const Size(50, kMinInteractiveDimension),
|
|
backgroundColor:
|
|
Theme.of(context).primaryColor,
|
|
shape: const CircleBorder(),
|
|
),
|
|
child: const Icon(
|
|
Icons.search,
|
|
color: Colors.white,
|
|
size: 24,
|
|
),
|
|
),
|
|
),
|
|
),
|
|
),
|
|
),
|
|
getSpacer(context: context, flex: 2),
|
|
ElevatedButton(
|
|
onPressed: () {
|
|
Navigator.of(context).push(MaterialPageRoute(
|
|
builder: (context) => const BasketPage(),
|
|
));
|
|
},
|
|
style: ElevatedButton.styleFrom(
|
|
padding: const EdgeInsets.all(0),
|
|
minimumSize: const Size(50, kMinInteractiveDimension),
|
|
backgroundColor: Theme.of(context).primaryColor,
|
|
shape: const CircleBorder(
|
|
side: BorderSide(
|
|
color: Colors.black,
|
|
width: 1,
|
|
),
|
|
),
|
|
),
|
|
child: const Icon(
|
|
Icons.shopping_basket,
|
|
color: Colors.white,
|
|
size: 24,
|
|
),
|
|
),
|
|
const SizedBox(
|
|
width: 8,
|
|
),
|
|
ElevatedButton(
|
|
onPressed: () {
|
|
Navigator.of(context).push(MaterialPageRoute(
|
|
builder: (context) => const HistoryPage(),
|
|
));
|
|
},
|
|
style: ElevatedButton.styleFrom(
|
|
padding: const EdgeInsets.all(0),
|
|
minimumSize: const Size(50, kMinInteractiveDimension),
|
|
backgroundColor: Theme.of(context).primaryColor,
|
|
shape: const CircleBorder(
|
|
side: BorderSide(
|
|
color: Colors.black,
|
|
width: 1,
|
|
),
|
|
),
|
|
),
|
|
child: const Icon(
|
|
Icons.history,
|
|
color: Colors.white,
|
|
size: 24,
|
|
),
|
|
),
|
|
const SizedBox(
|
|
width: 10,
|
|
)
|
|
],
|
|
),
|
|
),
|
|
Expanded(
|
|
child: GridView.builder(
|
|
gridDelegate: SliverGridDelegateWithFixedCrossAxisCount(
|
|
crossAxisCount:
|
|
(MediaQuery.sizeOf(context).width ~/ 250).floor(),
|
|
),
|
|
itemCount: testData.length,
|
|
itemBuilder: (context, index) {
|
|
final product = testData[index];
|
|
return ProductCard(
|
|
imagePath: Image(
|
|
image: AssetImage('assets/${product['image']!}'),
|
|
width: 100,
|
|
),
|
|
name: product['name']!,
|
|
price: product['price']!,
|
|
onTap: () => Navigator.of(context).push(
|
|
MaterialPageRoute(
|
|
builder: (context) => DetailPage(
|
|
name: product['name']!,
|
|
description: product['details']!,
|
|
price: product['price']!,
|
|
id: product['id']!,
|
|
image: Image(
|
|
image:
|
|
AssetImage('assets/${product['image']!}'),
|
|
width: 300),
|
|
),
|
|
),
|
|
),
|
|
);
|
|
},
|
|
),
|
|
),
|
|
],
|
|
),
|
|
);
|
|
}
|
|
}
|