jak zaktualizować widżet rodzica po zamknięciu showDialog w Flutterze?

Nov 29 2020

Mam widżet z ikoną, kiedy go klikam, pojawia się widżet okna dialogowego, oto wywołanie okna dialogowego:

// this icon is in widget parent
           IconButton(
              icon: Icon(
                Icons.info_outline,
                size: mobileWidth * 0.07,
              ),
              tooltip: 'information',
              color: Colors.blueGrey,
              onPressed: () {
                showAlertInfo(context, code);
                setState(() {});
              },
            ),

oto moje okno dialogowe:

showAlertInfo(BuildContext context, String code) {
  showDialog(
    context: context,
    builder: (context) {
      return StatefulBuilder(
        builder: (context, setState) {
          return AlertDialog(
            title: Text(
              "Information sur le client $code", ),
            content: SingleChildScrollView(
               child: Container( ..... 
               /* ...
               this dialog has some operations that changes info 
               values of the widget that called this in first place
               it is a big code to put here*/
             // here I have a close button
                    actions: [
            FlatButton(
            child: Text(
              "Fermer",
              style: TextStyle(
                color: Colors.red,
                fontSize: mobileWidth * 0.035,
                fontWeight: FontWeight.bold,
              ),
            ),
            onPressed: () {
              Navigator.of(context).pop(); // dismiss dialog
            },
          ),
        ],
      );  

to, co próbuję osiągnąć, to zamknięcie okna dialogowego. Chcę, aby widget nadrzędny został zaktualizowany, więc jak wywołać setStatewidget nadrzędny, gdy widget okna dialogowego zostanie zamknięty?

Odpowiedzi

2 TahaMalik Nov 29 2020 at 06:58

Dla funkcji Async

Dodaj awaitprzed showDialog()i zadzwoń setState((){})na następną linię.

await showDialog(
    context: context,
    builder: (context) {
       return yourWidget;
    }
);
setState((){});

Funkcja synchronizacji

Skorzystaj z .then()oddzwaniania i zadzwoń setState((){})do niego.


showDialog(
    context: context,
    builder(context) {
        return yourWidget;
    }).then((_){
        setState((){});
    }
);