Add: category on detail page and searching by API

This commit is contained in:
2024-06-04 15:29:41 +03:00
parent db39169907
commit eaa8b138a4
2 changed files with 34 additions and 20 deletions

View File

@@ -9,6 +9,7 @@ import 'package:gymlink_module_web/interfaces/items.dart';
import 'package:gymlink_module_web/pages/basket.dart'; import 'package:gymlink_module_web/pages/basket.dart';
import 'package:gymlink_module_web/providers/cart.dart'; import 'package:gymlink_module_web/providers/cart.dart';
import 'package:gymlink_module_web/providers/main.dart'; import 'package:gymlink_module_web/providers/main.dart';
import 'package:gymlink_module_web/tools/items.dart';
import 'package:gymlink_module_web/tools/prefs.dart'; import 'package:gymlink_module_web/tools/prefs.dart';
import 'package:gymlink_module_web/tools/routes.dart'; import 'package:gymlink_module_web/tools/routes.dart';
import 'package:http/http.dart' as http; import 'package:http/http.dart' as http;
@@ -29,6 +30,7 @@ class _DetailPageState extends State<DetailPage> {
bool isInCart = false; bool isInCart = false;
int quantity = 0; int quantity = 0;
GymItem? item; GymItem? item;
String categoryName = '';
final CarouselController _carouselController = CarouselController(); final CarouselController _carouselController = CarouselController();
int _currentImage = 0; int _currentImage = 0;
@@ -47,21 +49,33 @@ class _DetailPageState extends State<DetailPage> {
super.initState(); super.initState();
} }
void _getItem() async { Future<void> _getItem() async {
final Uri url = final Uri url =
Uri.http('gymlink.freemyip.com:8080', 'api/product/get/${widget.id}'); Uri.http('gymlink.freemyip.com:8080', 'api/product/get/${widget.id}');
final response = await http.get(url, headers: { final response = await http.get(url, headers: {
'Authorization': 'Bearer ${context.read<GymLinkProvider>().token}', 'Authorization': 'Bearer ${context.read<GymLinkProvider>().token}',
}); });
if (response.statusCode == 200) { if (response.statusCode == 200) {
final data =
GymItem.fromJson(jsonDecode(utf8.decode(response.bodyBytes)));
setState(() { setState(() {
item = GymItem.fromJson(jsonDecode(utf8.decode(response.bodyBytes))); item = data;
}); });
WidgetsBinding.instance.addPostFrameCallback((_) { WidgetsBinding.instance.addPostFrameCallback((_) {
for (var element in item!.images) { for (var element in item!.images) {
precacheImage(NetworkImage(element.url), context); precacheImage(NetworkImage(element.url), context);
} }
}); });
if (mounted) {
getCategories(context).then((value) {
categoryName = value
.firstWhere(
(element) => element.id == (item!.categoryId),
orElse: () => GymCategory(id: item!.categoryId, name: ''),
)
.name;
});
}
} }
} }
@@ -249,6 +263,12 @@ class _DetailPageState extends State<DetailPage> {
: Image.network(item!.images[0].url, : Image.network(item!.images[0].url,
width: min( width: min(
550, MediaQuery.sizeOf(context).width)), 550, MediaQuery.sizeOf(context).width)),
Padding(
padding: const EdgeInsets.symmetric(vertical: 10),
child: Center(
child: Text(
'Категория: ${categoryName == "" ? "Без категории" : categoryName}'),
)),
item!.description != '' item!.description != ''
? Padding( ? Padding(
padding: const EdgeInsetsDirectional.all(30), padding: const EdgeInsetsDirectional.all(30),

View File

@@ -14,7 +14,6 @@ import 'package:gymlink_module_web/tools/relative.dart';
import 'package:gymlink_module_web/tools/routes.dart'; import 'package:gymlink_module_web/tools/routes.dart';
import 'package:lazy_load_scrollview/lazy_load_scrollview.dart'; import 'package:lazy_load_scrollview/lazy_load_scrollview.dart';
import 'package:provider/provider.dart'; import 'package:provider/provider.dart';
import 'package:url_launcher/url_launcher.dart';
const List<Map<String, String>> testData = [ const List<Map<String, String>> testData = [
{ {
@@ -67,10 +66,10 @@ class MainPage extends StatefulWidget {
class _MainPageState extends State<MainPage> { class _MainPageState extends State<MainPage> {
String searchText = ''; String searchText = '';
List<GymItem> filteredData = []; List<GymItem> filteredData = [];
List<GymItem> items = [];
int cartLength = 0; int cartLength = 0;
int itemViewCount = 0; int itemViewCount = 0;
bool isLoading = false; bool isLoading = false;
List<GymCategory> categories = [];
@override @override
void initState() { void initState() {
@@ -82,7 +81,6 @@ class _MainPageState extends State<MainPage> {
}); });
getItems(context).then((value) => setState(() { getItems(context).then((value) => setState(() {
filteredData = value; filteredData = value;
items = value;
itemViewCount = min(5, value.length); itemViewCount = min(5, value.length);
WidgetsBinding.instance.addPostFrameCallback((_) { WidgetsBinding.instance.addPostFrameCallback((_) {
for (var element in filteredData.sublist(0, itemViewCount)) { for (var element in filteredData.sublist(0, itemViewCount)) {
@@ -90,13 +88,9 @@ class _MainPageState extends State<MainPage> {
} }
}); });
})); }));
} getCategories(context).then((value) => setState(() {
categories = value;
Future<void> _goToPage() async { }));
final Uri url = Uri.parse('https://google.com');
if (!await launchUrl(url, webOnlyWindowName: '_blank')) {
throw 'Could not launch $url';
}
} }
void _onLoad() async { void _onLoad() async {
@@ -112,12 +106,12 @@ class _MainPageState extends State<MainPage> {
} }
} }
void _onSearch() { void _onSearch() async {
final data = await getItems(context, searchText: searchText);
setState(() { setState(() {
filteredData = items filteredData = data;
.where((element) => (element.title).contains(searchText)) itemViewCount =
.toList(); min(filteredData.length, searchText == '' ? 5 : itemViewCount);
itemViewCount = min(filteredData.length, itemViewCount);
}); });
WidgetsBinding.instance.addPostFrameCallback((_) { WidgetsBinding.instance.addPostFrameCallback((_) {
for (var element in filteredData.sublist(0, itemViewCount)) { for (var element in filteredData.sublist(0, itemViewCount)) {
@@ -216,10 +210,10 @@ class _MainPageState extends State<MainPage> {
child: Scrollbar( child: Scrollbar(
child: ListView( child: ListView(
children: [ children: [
items.isEmpty filteredData.isEmpty && searchText != ''
? const Center(child: CircularProgressIndicator())
: filteredData.isEmpty
? const Center(child: Text('Ничего не найдено')) ? const Center(child: Text('Ничего не найдено'))
: filteredData.isEmpty
? const Center(child: CircularProgressIndicator())
: GridView.builder( : GridView.builder(
physics: const NeverScrollableScrollPhysics(), physics: const NeverScrollableScrollPhysics(),
shrinkWrap: true, shrinkWrap: true,