import 'package:easy_localization/easy_localization.dart';
import 'package:flutter/material.dart';
import 'package:provider/provider.dart';
import 'package:surface/providers/sn_network.dart';
import 'package:surface/types/post.dart';
import 'package:surface/widgets/navigation/app_scaffold.dart';
import 'package:very_good_infinite_list/very_good_infinite_list.dart';

class ExploreScreen extends StatefulWidget {
  const ExploreScreen({super.key});

  @override
  State<ExploreScreen> createState() => _ExploreScreenState();
}

class _ExploreScreenState extends State<ExploreScreen> {
  bool _isBusy = true;

  final List<SnPost> _posts = List.empty(growable: true);
  int _postCount = 0;

  void _fetchPosts() async {
    setState(() => _isBusy = true);

    final sn = context.read<SnNetworkProvider>();

    final resp = await sn.client.get('/cgi/co/posts', queryParameters: {
      'take': 10,
      'offset': 0,
    });

    _postCount = resp.data['count'];
    _posts.addAll(
        resp.data['data']?.map((e) => SnPost.fromJson(e)).cast<SnPost>() ?? []);

    if (mounted) setState(() => _isBusy = false);
  }

  @override
  void initState() {
    super.initState();
    _fetchPosts();
  }

  @override
  Widget build(BuildContext context) {
    return AppScaffold(
      appBar: AppBar(
        title: Text('screenExplore').tr(),
      ),
      body: InfiniteList(
        itemCount: _posts.length,
        isLoading: _isBusy,
        onFetchData: _fetchPosts,
        itemBuilder: (context, idx) {
          return Text(_posts[idx].toString());
        },
      ),
    );
  }
}