Как дать динамику c no PopupMenuItem для PopupMenuButton с флаттером? - PullRequest
0 голосов
/ 17 июня 2020

Как динамически установить номер PopupMenuItem на PopupMenuButton с индексом, например ListView.builder().

На самом деле я использую FutureBuilder для получения данных из api и в ответ 4 элемента получены означает, что он дает динамику c no элементов. и хотите отобразить их в PopupMenuItem в виде списка. но в PopupMenuButton нет конструктора count, в отличие от ListView.builder().

Код:

FutureBuilder<CommonModel>(
                future: futureListMaterialStatusCommonModel,
                builder:(BuildContext context, AsyncSnapshot<CommonModel> snapshot ){
                  if(!snapshot.hasData){
                    return Text("loading...");
                  }
                   if(snapshot.hasError){
                    return Text(snapshot.error);
                  }
                 //I tried to get solution by loop before showing items but went wrong
                 for(int i ; i< snapshot.data.content.length; i++){
                    itemList.add(
                      PopupMenuItem(
                        value: snapshot.data.content[i].title,//919876543210,
                        child: Text(
                          snapshot.data.content[0].title,
                          style: TextStyle(
                          color: Colors.black, fontWeight: FontWeight.w700),
                        ),
                      ),
                    );
                  }

                 return  PopupMenuButton<String>(
                    itemBuilder: (context) => [
                      PopupMenuItem(
                        value: snapshot.data.content[0].title,
                        child: Text(
                          snapshot.data.content[0].title,
                          style: TextStyle(
                          color: Colors.black, fontWeight: FontWeight.w700),
                        ),
                      ),

                    ],
                    onSelected: (value) { 
                      setState(() {
                        materialStatus = value;
                      });

                    },
                    child: materialStatus==null? Text("Select...", 
                      style: TextStyle(color:Colors.orange),)
                      :Text(materialStatus, 
                      style: TextStyle(color:Colors.black, fontWeight: FontWeight.bold),)
                  );
                } ,
              )

1 Ответ

0 голосов
/ 17 июня 2020

Наконец-то я это сделал. это было так просто, на самом деле так глупо.

return  PopupMenuButton<String>(
                   itemBuilder: (context ) => 
                  snapshot.data.content
                     .map((item) => PopupMenuItem<String>(
                           value: item.title,
                           child: Text(
                             item.title,
                           ),
                         ))
                     .toList(),


                   onSelected: (value) { 
                     setState(() {
                       materialStatus = value;
                     });

                   },
                   child: materialStatus ==null? Text("Select...", 
                     style: TextStyle(color:Colors.orange),)
                     :Text(materialStatus, 
                     style: TextStyle(color:Colors.black, fontWeight: FontWeight.bold),)
                 );
...