Skip to content
Snippets Groups Projects
Select Git revision
  • 9bc0d8a2a80c2ff631a0a3210b106f25b7c02460
  • develop default
  • feat/dev-test
  • feat/router
  • feat/diet-merged
  • feat/Workout
  • feat/scrap
  • feat/루틴
  • feat/HabitTracker
  • feat;식단관리
  • feat/User-merged
  • feat/User
  • feat/diet
  • feat/back
  • feat/SignIn
  • feat/dbconf
  • master
  • revert-b2deab70
  • feat/certbot
  • hotfix/nginx
  • feature/ssl
21 results

api.js

Blame
  • main.dart 1.89 KiB
    import 'package:english_words/english_words.dart';
    import 'package:flutter/material.dart';
    import 'package:provider/provider.dart';
    
    void main() {
      runApp(MyApp());
    }
    
    class MyApp extends StatelessWidget {
      const MyApp({super.key});
    
      @override
      Widget build(BuildContext context) {
        return ChangeNotifierProvider(
          create: (context) => MyAppState(),
          child: MaterialApp(
            title: 'Namer App',
            theme: ThemeData(
              useMaterial3: true,
              colorScheme: ColorScheme.fromSeed(seedColor: Colors.blue),
            ),
            home: MyHomePage(),
          ),
        );
      }
    }
    
    class MyAppState extends ChangeNotifier {
      var current = WordPair.random();
    
      void getNext(){
        current = WordPair.random();
        notifyListeners();
      }
    }
    
    class MyHomePage extends StatelessWidget {
      @override
      Widget build(BuildContext context) {
        var appState = context.watch<MyAppState>();
        var pair = appState.current;
    
        return Scaffold(
          body: Center(
            child: Column(
              mainAxisAlignment: MainAxisAlignment.center,
              children: [
                // Text('A random AWESOME idea:'),
                BigCard(pair: pair),
                SizedBox(height: 10,),
                ElevatedButton(onPressed: (){appState.getNext();}, child: Text('Next'),),
              ],
            ),
          ),
        );
      }
    }
    
    class BigCard extends StatelessWidget {
      const BigCard({
        super.key,
        required this.pair,
      });
    
      final WordPair pair;
    
      @override
      Widget build(BuildContext context) {
        final theme = Theme.of(context);
        final style = theme.textTheme.displayMedium!.copyWith(