app/lib/components/new_arrival_products.dart

85 lines
3 KiB
Dart
Raw Normal View History

import 'package:flutter/material.dart';
2022-05-15 16:45:01 +02:00
import 'package:nekoya_flutter/api/api.dart';
2022-05-15 17:08:20 +02:00
import 'package:nekoya_flutter/components/product_detail.dart';
2022-05-16 02:51:47 +02:00
import 'package:nekoya_flutter/components/product_card.dart';
import 'package:nekoya_flutter/components/section_title.dart';
import 'package:nekoya_flutter/utils/utils.dart';
class NewArrivalProducts extends StatelessWidget {
const NewArrivalProducts({
Key? key,
}) : super(key: key);
@override
Widget build(BuildContext context) {
return Column(
children: [
Padding(
padding: const EdgeInsets.symmetric(vertical: defaultPadding),
child: SectionTitle(
title: "New Arrival",
pressSeeAll: () {},
),
),
2022-05-15 16:45:01 +02:00
FutureBuilder<dynamic>(
future: getProducts(),
builder: (context, snapshot) {
if (snapshot.hasData) {
var sourceData = snapshot.data;
sourceData.shuffle();
var data = sourceData.take(6).toList();
return SingleChildScrollView(
physics: const BouncingScrollPhysics(
parent: AlwaysScrollableScrollPhysics()),
scrollDirection: Axis.horizontal,
child: Row(
children: List.generate(
data.length,
(index) => Padding(
padding: const EdgeInsets.only(right: defaultPadding),
child: ProductCard(
title: data[index]['TITLE'],
imageUrl: "https://nekoya.moe.team/img/${data[index]['IMAGE']}",
bgColor: const Color(0xFFFEFBF9),
2022-05-15 17:08:20 +02:00
press: () {
showModalBottomSheet(
isScrollControlled: true,
backgroundColor: Colors.transparent,
context: context,
builder: (context) => productDetail(context, data[index]['ID']),
);
},
2022-05-15 16:45:01 +02:00
),
),
),
),
2022-05-15 16:45:01 +02:00
);
} else {
return SingleChildScrollView(
physics: const BouncingScrollPhysics(
parent: AlwaysScrollableScrollPhysics()),
scrollDirection: Axis.horizontal,
child: Row(
children: List.generate(
6,
(index) => Padding(
padding: const EdgeInsets.only(right: defaultPadding),
child: ProductCard(
title: 'Loading...',
imageUrl: "https://i.ibb.co/QJFLZC4/La-Darknesss-Portrait.webp",
bgColor: const Color(0xFFFEFBF9),
press: () {},
),
),
),
),
);
}
}
)
],
);
}
}