Как создать красивый alertDialog как в Интернете (всплывающая подсказка)? - PullRequest
0 голосов
/ 23 мая 2019

Мне нужно создать что-то вроде представления предупреждений для политики паролей дисплея. Но я не знаю, как спроектировать это. Если нажать кнопку, чтобы просмотреть этот вид оповещения?

Мой дизайн и код

enter image description here

 viewPolicy() {
    return showDialog(
        context: context,
        builder: (BuildContext context) {
          return AlertDialog(
            title: Text("Password Policy"),
            content: Container(
              width: 10.0,
              child: Column(
                children: <Widget>[
                  Row(
                    children: <Widget>[
                      Expanded(
                        child: Text(
                            "Minimum Password Length : ${widget.minPwdlength}"),),],),
                  Row(
                    children: <Widget>[
                      Expanded(
                        child:
                            Text("Minimum Password Uppercase Characters : 1"),),],),
                  Row(
                    children: <Widget>[
                      Expanded(
                        child:
                            Text("Minimum Password lowercase Characters : 1"),),],),
                  Row(
                    children: <Widget>[
                      Expanded(
                        child: Text("Minimum Password Numeric Characters : 1"),),],),
                  Row(
                    children: <Widget>[
                      Expanded(
                        child: Text("Minimum Special Characters : 1"),),], ),
                  Row(
                    children: <Widget>[
                      Expanded(
                        child: Text(
                          "Allowed Characters : ! @ # \$ & * ~ Password cannot contain spaces",
                          style: TextStyle(color: Colors.grey),
                        ),),], ),], ), ),
            actions: <Widget>[
              FlatButton(
                  onPressed: () {
                    Navigator.of(context).pop();
                  },
                  child: Text(
                    "OK",
                    style: TextStyle(fontWeight: FontWeight.bold),
                  ))], ); });}

Мне нужно спроектировать так,

enter image description here


@AbdulMajeed Saad Answer look like

1 Ответ

0 голосов
/ 24 мая 2019

Вот код, надеюсь, он будет полезен. Скриншот

Dialog errorDialog = Dialog(
            //this right here
            child: Theme(
              data: ThemeData().copyWith(
                inputDecorationTheme: InputDecorationTheme(
                  border: OutlineInputBorder(),
                ),
              ),
              child: Container(
                color: Colors.blueGrey[100],
                height: MediaQuery.of(context).size.height / 3.5,
                width: MediaQuery.of(context).size.width / 1,
                child: Padding(
                  padding: const EdgeInsets.all(8.0),
                  child: Column(
                    mainAxisAlignment: MainAxisAlignment.spaceAround,
                    children: <Widget>[
                      Row(
                        mainAxisAlignment: MainAxisAlignment.spaceBetween,
                        children: <Widget>[
                          Text("Minimum Password Length"),
                          Text(": 6")
                        ],
                      ),
                      Row(
                        mainAxisAlignment: MainAxisAlignment.spaceBetween,
                        children: <Widget>[
                          Text("Minimum Password Uppercase Characters"),
                          Text(": 1")
                        ],
                      ),
                      Row(
                        mainAxisAlignment: MainAxisAlignment.spaceBetween,
                        children: <Widget>[
                          Text("Minimum Password lowercase Characters"),
                          Text(": 1")
                        ],
                      ),
                      Row(
                        mainAxisAlignment: MainAxisAlignment.spaceBetween,
                        children: <Widget>[
                          Text("Minimum Password Numeric Characters"),
                          Text(": 1")
                        ],
                      ),
                      Row(
                        mainAxisAlignment: MainAxisAlignment.spaceBetween,
                        children: <Widget>[
                          Text("Minimum Special Characters"),
                          Text(": 1")
                        ],
                      ),
                      Padding(
                        padding: const EdgeInsets.all(8.0),
                        child: Row(
                          children: <Widget>[
                            Expanded(
                              child: Text(
                                "Allowed Characters:\n! @ # \$ & * ~\nPassword cannot contain spaces",
                                style: TextStyle(color: Colors.grey[700]),
                              ),
                            ),
                          ],
                        ),
                      ),
                      // you can remove this Row if you don't want the ok button, the user can dismiss the dialog by pressing anywhere in the screen.
                      Row(
                        mainAxisAlignment: MainAxisAlignment.end,
                        children: <Widget>[
                          FlatButton(
                            child: Text(
                              "Ok",
                              style: TextStyle(fontWeight: FontWeight.bold),
                            ),
                            onPressed: () => Navigator.of(context).pop(),
                          )
                        ],
                      )
                    ],
                  ),
                ),
              ),
            ),
          );
          showDialog(
              context: context,
              builder: (BuildContext context) => errorDialog);
...