Search code examples
flutterdartflutter-layoutcheckboxlist

How to select only one checkbox from Checkbox List tile in Flutter and show selected item in textField


Here there's a text field that shows bottom sheet of train stations how could i select only one checkbox and show the selected in text field and here is the code thanks in advance and i will appreciate if you taught me how to search by name in the text field from check box list

 Scaffold(
            backgroundColor: Colors.grey[300],
            appBar: AppBar(
              leading: IconButton(
                icon: Icon(Icons.arrow_back),
                onPressed: () {
                  Navigator.push(
                      context,
                      MaterialPageRoute(
                          builder: (context) => ticketbookinghomepage()));
                },
              ),
              backgroundColor: Color(0xff240e8b),
              title: Text('Search By Station'),
              centerTitle: true,
            ),
            body: Container(
              child: Column(
                mainAxisAlignment: MainAxisAlignment.start,
                children: [
                  Container(
                      padding: EdgeInsets.all(10),
                      child: Column(
                        children: [
                          Text('Departure Station'),
                          Container(
                              padding: EdgeInsets.all(10),
                              decoration: BoxDecoration(
                                color: Colors.white,
                                borderRadius: BorderRadius.circular(16),
                              ),
                              child: TextField(
                                controller: startController,
                                autocorrect: true,
                                decoration: InputDecoration(
                                    labelText: '-Select Station',
                                    floatingLabelBehavior:
                                        FloatingLabelBehavior.never,
                                    filled: true,
                                    fillColor: Colors.white,
                                    suffixIcon: InkWell(
                                      onTap: () {
                                        showSourceBottomSheet(context);
                                      },
                                      child: Icon(
                                        Icons.arrow_drop_down_circle_outlined,
                                        color: Colors.black,
                                      ),
                                    ),
                                    border: OutlineInputBorder(
                                        borderRadius: BorderRadius.all(
                                            Radius.circular(30)))),
                              ))
                        ],
                      )),
                  SizedBox(height: 12),
                  IconButton(
                    icon: Icon(Icons.wifi_protected_setup_rounded),
                    color: Colors.black,
                    onPressed: () {},
                  ),
                  SizedBox(height: 12),
                  Container(
                      padding: EdgeInsets.all(10),
                      child: Column(
                        children: [
                          Text('ِِِArrival Station'),
                          Container(
                              padding: EdgeInsets.all(10),
                              decoration: BoxDecoration(
                                color: Colors.white,
                                borderRadius: BorderRadius.circular(16),
                              ),
                              child: TextField(
                                controller: arriveController,
                                autocorrect: true,
                                decoration: InputDecoration(
                                    labelText: '-Select Station',
                                    floatingLabelBehavior:
                                        FloatingLabelBehavior.never,
                                    filled: true,
                                    fillColor: Colors.white,
                                    suffixIcon: InkWell(
                                      onTap: () {
                                        showDestinationBottomSheet(context);
                                      },
                                      child: Icon(
                                        Icons.arrow_drop_down_circle_outlined,
                                        color: Colors.black,
                                      ),
                                    ),
                                    border: OutlineInputBorder(
                                        borderRadius: BorderRadius.all(
                                            Radius.circular(30)))),
                              ))
                        ],
                      )),
                  SizedBox(
                    height: 20,
                  ),
                  Container(
                    child: SizedBox(
                      height: 80,
                      width: 170,
                      child: ElevatedButton(
                        style: ButtonStyle(
                            backgroundColor:
                                MaterialStateProperty.all(Colors.amberAccent),
                            padding:
                                MaterialStateProperty.all(EdgeInsets.all(15)),
                            shape: MaterialStateProperty.all(
                                RoundedRectangleBorder(
                                    borderRadius: BorderRadius.circular(25)))),
                        onPressed: () {},
                        child: Icon(
                          Icons.train,
                          color: Colors.deepPurple,
                        ),
                      ),
                    ),
                  ),
                  SizedBox(
                    height: 15,
                  ),
                  
                ],
              ),
            ),
          )  

Bottom Sheet Code

import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
class sourceBottomSheet extends StatefulWidget {
  const sourceBottomSheet({Key? key}) : super(key: key);

  @override
  State<sourceBottomSheet> createState() => _sourceBottomSheetState();
}
bool? checkBox1=false;
bool? checkBox2=false;
bool? checkBox3=false;
bool? checkBox4=false;
bool? checkBox5=false;
bool? checkBox6=false;
bool? checkBox7=false;
bool? checkBox8=false;
class _sourceBottomSheetState extends State<sourceBottomSheet> {
  @override
  Widget build(BuildContext context) {
    return StatefulBuilder(builder: (context, setState) {
      return Container(
        color: Colors.grey[600],
        child: Container(
          decoration: BoxDecoration(
            color:Colors.white,
            borderRadius: BorderRadius.only(topLeft: Radius.circular(30),topRight: Radius.circular(30))
          ),
          child: SingleChildScrollView(
            child: Column(
              children: [
                CheckboxListTile(
                    activeColor:Color(0xff070000),
                    checkColor:Color(0xffffffff) ,
                    title: Text('Cairo'),
                    value: checkBox1, onChanged: (v) {
                  setState(() {
                    checkBox1 = v;
                  });
                }),
                CheckboxListTile(
                    activeColor:Color(0xff070000),
                    checkColor:Color(0xffffffff) ,
                    title: Text('Alexandria')
                    , value: checkBox2, onChanged: (v) {
                  setState(() {
                    checkBox2 = v;
                  });
                }),
                CheckboxListTile(
                    activeColor:Color(0xff070000),
                    checkColor:Color(0xffffffff) ,
                    title: Text('Mansoura'),
                    value: checkBox3, onChanged: (v) {
                  setState(() {
                    checkBox3 = v;
                  });
                }),
                CheckboxListTile(
                    activeColor:Color(0xff070000),
                    checkColor:Color(0xffffffff) ,
                    title: Text('Shoubra Elkhema'),
                    value: checkBox4, onChanged: (v) {
                  setState(() {
                    checkBox4 = v;
                  });
                }),
                CheckboxListTile(
                    activeColor:Color(0xff070000),
                    checkColor:Color(0xffffffff) ,
                    title: Text('Banha'),
                    value: checkBox5, onChanged: (v) {
                  setState(() {
                    checkBox5 = v;
                  });
                }),
                CheckboxListTile(
                    activeColor:Color(0xff070000),
                    checkColor:Color(0xffffffff) ,
                    title: Text('Louxor'),
                    value: checkBox7, onChanged: (v) {
                  setState(() {
                    checkBox7 = v;
                  });

                }
                ),
                CheckboxListTile(
                    activeColor:Color(0xff070000),
                    checkColor:Color(0xffffffff) ,
                    title: Text('Port Said'),
                    value: checkBox8, onChanged: (v) {
                  setState(() {
                    checkBox8 = v;
                  });
                }),
                ListTile(
                    title:Text('Submit',textAlign: TextAlign.center,),
                    onTap:(){

                      Navigator.pop(context);
                    }),
              ],
            ),
          ),
        ),
      );
    }
    );
  }
}     

Home ERROR Home class error

enter image description here

show bottom sheet error he want context and builder


Solution

  • Bottom Source Sheet Function code

    sourceBottomSheet bs = sourceBottomSheet(_cont);
    //bs.sourceBottomSheet1(_cont);
    showModalBottomSheet(
        context: context,
        builder: (buildContext) {
          return bs;
          //    return sourceBottomSheet();
        });
    } ```