The Ultimate Hands-on Flutter And Mvvm - Build ... Page

class MyApp extends StatelessWidget @override Widget build(BuildContext context) return ChangeNotifierProvider( create: (ctx) => UserViewModel(), child: MaterialApp(home: UserScreen()), );

// services/api_service.dart import 'dart:convert'; import 'package:http/http.dart' as http; class ApiService final String baseUrl = "https://jsonplaceholder.typicode.com";

import 'package:flutter/material.dart'; import 'package:provider/provider.dart'; import 'viewmodels/user_viewmodel.dart'; import 'views/user_screen.dart'; void main() => runApp(MyApp()); The Ultimate Hands-On Flutter and MVVM - Build ...

It sounds like you’re referring to a course (likely on Udemy or similar) titled something like:

Future<List<dynamic>> fetchUsers() async final response = await http.get(Uri.parse("$baseUrl/users")); if (response.statusCode == 200) return json.decode(response.body); else throw Exception("Failed to load users"); child: MaterialApp(home: UserScreen())

Future<void> fetchUsers() async _isLoading = true; notifyListeners(); _users = await _repository.getUsers(); _isLoading = false; notifyListeners();

// viewmodels/user_viewmodel.dart import 'package:flutter/material.dart'; import '../models/user.dart'; import '../repositories/user_repository.dart'; class UserViewModel extends ChangeNotifier final UserRepository _repository = UserRepository(); List<User> _users = []; bool _isLoading = false; // services/api_service.dart import 'dart:convert'

// repositories/user_repository.dart import '../models/user.dart'; import '../services/api_service.dart'; class UserRepository final ApiService _api = ApiService(); Future<List<User>> getUsers() async final data = await _api.fetchUsers(); return data.map((json) => User.fromJson(json)).toList();

List<User> get users => _users; bool get isLoading => _isLoading;

// views/user_screen.dart import 'package:flutter/material.dart'; import 'package:provider/provider.dart'; import '../viewmodels/user_viewmodel.dart'; class UserScreen extends StatelessWidget @override Widget build(BuildContext context) final viewModel = Provider.of<UserViewModel>(context); return Scaffold( appBar: AppBar(title: Text("MVVM Users")), body: viewModel.isLoading ? Center(child: CircularProgressIndicator()) : ListView.builder( itemCount: viewModel.users.length, itemBuilder: (ctx, i) => ListTile( title: Text(viewModel.users[i].name), ), ), floatingActionButton: FloatingActionButton( onPressed: () => viewModel.fetchUsers(), child: Icon(Icons.refresh), ), );