dg_direct_link 1.0.22 copy "dg_direct_link: ^1.0.22" to clipboard
dg_direct_link: ^1.0.22 copied to clipboard

retracted

Min Thant Htet.

example/lib/main.dart

import 'package:dg_direct_link/dg_direct_link.dart';
import 'package:dg_direct_link/widgets/dg_direct_link_widget.dart';
import 'package:flutter/material.dart';

void main() {
  runApp(const MyApp());
}

class MyApp extends StatelessWidget {
  const MyApp({super.key});

  // This widget is the root of your application.
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        colorScheme: ColorScheme.fromSeed(seedColor: Colors.deepPurple),
        useMaterial3: true,
      ),
      home: const MyHomePage(title: 'DG direct link Demo'),
    );
  }
}

class MyHomePage extends StatefulWidget {
  const MyHomePage({super.key, required this.title});

  // This widget is the home page of your application. It is stateful, meaning
  // that it has a State object (defined below) that contains fields that affect
  // how it looks.

  // This class is the configuration for the state. It holds the values (in this
  // case the title) provided by the parent (in this case the App widget) and
  // used by the build method of the State. Fields in a Widget subclass are
  // always marked "final".

  final String title;
  

  @override
  State<MyHomePage> createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {

TextEditingController controller = TextEditingController();
 String support = "\n- VK"+
"\n- SolidFiles"+
"\n- MediaFire"+
"\n FEmbed"+
"\n- GoogleDrive"+
"\n- Ok.ru"+
"\n- Dropbox"+
"\n- Vimeo"+
"\n- Facebook"+
"\n- Instagram"+
"\n- Youtube"+
"\n- IMDB"+
"\n- Xnxx"; 

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        backgroundColor: Theme.of(context).colorScheme.inversePrimary,
        title: Text(widget.title),
      ),
      body: Container(
        alignment: Alignment.center,
        padding: EdgeInsets.all(40),
        child: SingleChildScrollView(
          child: Column(
            crossAxisAlignment: CrossAxisAlignment.start,
            mainAxisAlignment: MainAxisAlignment.start,
            children: <Widget>[
              TextField(
                decoration: InputDecoration(hintText: 'Paste your link'),
                controller: controller),
              SizedBox(height: 20),
              SizedBox(
                width: double.infinity,
                child: ElevatedButton(
                  
                  onPressed: (){
                 showModalBottomSheet(context: context, builder:(context) {
                   return Container(
                    width: double.infinity,
                      padding: EdgeInsets.all(29),
                     child:  DGDirectLinkWidget(
                  url: controller.text,
                  loading: (){
                  return Padding(
                    padding: const EdgeInsets.all(20),
                    child: CircularProgressIndicator(),
                  );
                  }, error: (){
                  return Padding(
                    padding: const EdgeInsets.all(20),
                    child: Text('Error'),
                  );
                  }, complete: (links){
                  return  ListTile(title: Text(links[0].link),);
                  } )
                   );
                 },);
                }, child: Text('Get single quality')),
              ),
               SizedBox(height: 20),
        
                 SizedBox(
                width: double.infinity,
                child: ElevatedButton(
                  
                  onPressed: (){
                 showModalBottomSheet(
                  
                  context: context, builder:(context) {
                   return Container(
                    width: double.infinity,
                      padding: EdgeInsets.all(29),
                     child:  DGDirectLinkWidget(
                  url: controller.text,
                  loading: (){
                  return Padding(
                    padding: const EdgeInsets.all(20),
                    child: CircularProgressIndicator(),
                  );
                  }, error: (){
                  return Padding(
                    padding: const EdgeInsets.all(20),
                    child: Text('Error'),
                  );
                  }, complete: (links){
                  return  ListView.separated(
                    shrinkWrap: true,
                    itemCount: links.length,
                    separatorBuilder: (context, index) => SizedBox(height: 10,),
                    itemBuilder:(context, index) {
                    ListTile(title: Text(links[index].link),);
                  },);
                  } )
                   );
                 },);
                }, child: Text('Get Multiple quality')),
              ),
              SizedBox(height: 20,),
               Text('Support links',style: TextStyle(fontSize: 18,fontWeight: FontWeight.bold),),
               Text(support)
        
            ],
          ),
        ),
      ),
    );
  }
}