SelectWithOnChange function

Widget SelectWithOnChange(
  1. dynamic Item,
  2. Map<String, dynamic> map,
  3. dynamic pType, {
  4. dynamic onchange,
  5. dynamic row = '',
  6. dynamic width = 400,
  7. dynamic height,
  8. dynamic firstItem,
  9. dynamic enable,
})

Implementation

Widget SelectWithOnChange(Item, Map<String, dynamic> map, pType,
    {onchange, row= '', width= 400, height, firstItem,enable}) {
  StreamController selectStream = new StreamController.broadcast();
 var listMap=[];
 selectStream.stream.listen((data){
   if(data !=null)
    listMap=data;
 });
 Future.delayed(Duration(seconds: 1)).then((value){
    GetSeletItemsMap(selectStream, Item,firstItem: firstItem);
 },);


  printO("Contains  ${Item["key"]}  ${map.containsKey(Item["key"])}");
  return StreamBuilder(
      stream: selectStream.stream,
      builder: (context, AsyncSnapshot snapshot) {
        // if(firstItem!=null && !(snapshot.data as List<DropdownMenuItem>).contains(firstItem))
        //   (snapshot.data as List<DropdownMenuItem>).insert(0,firstItem);
       printO(" ==================== StreamBuilder ${Item["key"]}========  ${snapshot.data}");
      return      Padding(
              padding: const EdgeInsets.only(left: 8, right: 8),
              child: Column(
                crossAxisAlignment: CrossAxisAlignment.start,
                mainAxisSize: MainAxisSize.min,
                children: [
                  Flexible(
                          flex: 1,
                          fit: FlexFit.loose,
                          child: Text(Item["label"])),
                          const SizedBox(height: 5),


                     StatefulBuilder(
                       builder: (context,setStateWidget) {
                         return SearchFieldSelect(
                          hint:Item['placeholder']??Item["label"] ,//labelText: Item["label"],
                          suffixIcon: Icon(Icons.arrow_drop_down_circle),
                          items:snapshot.hasData?(snapshot.data).map<DropItem>((e)=>DropItem(text:e['text'],value: e['value'] )).toList():[],
                          isMultiple:Item["multiple"]??false,
                          onChanged: Item["multiple"]==null || Item["multiple"]==false? (value){
                          setStateWidget(() =>  map[Item["key"]]=value.value);
                          }:null,
                          onChangedMulti: Item["multiple"]!=null && Item["multiple"]==true? (values){
                           setStateWidget(() => map[Item["key"]]=values.map((e)=>e.value).toList());
                           print('=============== list select  ${map[Item["key"]]}');

                          }:null,
                          value: Item["multiple"]==null || Item["multiple"]==false? map[Item["key"]]: null ,
                          values:Item["multiple"]!=null && Item["multiple"]==true? map[Item["key"]]:null ,
                           readOnly: enable,

                          validator: (v){


                          if (Item['validate'] != null &&
                              Item['validate']['required'] != null &&
                              Item['validate']['required'] &&( map[Item["key"]]==null || map[Item["key"]].isEmpty ) )

                             { return Item['validate']['customMessage']??'Field is Required';}

                          return null;
                          }


                         );
                       }
                     )

                  //     FormBuilderDropdown<Object?>(
                  //   //enabled: true,
                  //    enabled: !enable,
                  //   name: Item["key"],
                  //   initialValue:
                  //       map.containsKey(Item["key"]) ? map[Item["key"]] : null,
                  //   onSaved: (value) {
                  //     if(value!=null)
                  //     map[Item["key"]] = value;
                  //   },


                  //   decoration: InputDecoration(
                  //       fillColor: Color(0xfff0f0f5),
                  //       suffixIcon: InkWell(
                  //         child: Icon(
                  //           Icons.refresh,
                  //           color: ThemeApp.primaryColor,
                  //         ),
                  //         onTap: () {
                  //           GetSeletItemsMap(selectStream, Item);
                  //         },
                  //       ),

                  //       labelText: Item["label"],
                  //       border: OutlineInputBorder(
                  //           borderSide:
                  //               BorderSide(color: Color(0xfff0f0f5), width: .5),
                  //           borderRadius: BorderRadius.all(Radius.circular(12)))),
                  //   items: snapshot.hasData?(snapshot.data)
                  //   .map<DropdownMenuItem<Object?>>((e)=> DropdownMenuItem<Object?>(child: Text('${e['text']}'),value:e['value'] )).toList()
                  //   // [
                  //   //   //if(Item)
                  //   //   for (DropdownMenuItem<String> list in (snapshot.data as List<DropdownMenuItem<String>>))
                  //   //   //for( snapshot.data in item)
                  //   //     list,
                  //   // ]
                  //       :listMap!=null?(listMap)
                  //   .map<DropdownMenuItem<Object?>>((e)=> DropdownMenuItem<Object?>(child: Text('${e['text']}'),value:e['value'] )).toList()
                  //    :[
                  //         //  DropdownMenuItem(child: Text('tess'),value:1)
                  //       ],
                  //   validator: FormBuilderValidators.compose([
                  //     if (Item['validate'] != null &&
                  //         Item['validate']['required'] != null &&
                  //         Item['validate']['required'])
                  //        FormBuilderValidators.required(errorText: Item['validate']['customMessage']??'Field is Required'),
                  //   ]),
                  //   onChanged: onchange,
                  // ),


                ],
              ),

          );


      });
}