Флажок оповещения Таблица данных диалога флажок - PullRequest
0 голосов
/ 07 июля 2019

У меня есть таблица данных с флажком внутри диалогового окна оповещения. Когда я нажимаю флажок, флажок не проверяется (отмечен = установлен).Я следовал за этим видео

Вот моя попытка

import 'package:flutter/material.dart';

void main(){
  runApp(new MaterialApp(
    debugShowCheckedModeBanner: false,
    home: new DataTableDemo(),
    theme: ThemeData.light(),
  ));
}

class DataTableDemo extends StatefulWidget {

  final String title = "Data Table Flutter Demo";

  @override
  DataTableDemoState createState() => DataTableDemoState();
}

class DataTableDemoState extends State<DataTableDemo> {
  List<User> users;
  List<User> selectedUsers;
  bool sort;

  @override
  void initState() {
    sort = false;
    selectedUsers = [];
    users = User.getUsers();
    super.initState();
  }

  onSortColum(int columnIndex, bool ascending) {
    if (columnIndex == 0) {
      if (ascending) {
        users.sort((a, b) => a.firstName.compareTo(b.firstName));
      } else {
        users.sort((a, b) => b.firstName.compareTo(a.firstName));
      }
    }
  }

  onSelectedRow(bool selected, User user) async {
    setState(() {
      if (selected) {
        selectedUsers.add(user);
      } else {
        selectedUsers.remove(user);
      }
    });
  }

  deleteSelected() async {
    setState(() {
      if (selectedUsers.isNotEmpty) {
        List<User> temp = [];
        temp.addAll(selectedUsers);
        for (User user in temp) {
          users.remove(user);
          selectedUsers.remove(user);
        }
      }
    });
  }

  SingleChildScrollView dataBody() {

    return SingleChildScrollView(
      scrollDirection: Axis.vertical,
      child: DataTable(
        sortAscending: sort,
        sortColumnIndex: 0,
        columns: [
          DataColumn(
              label: Text("FIRST NAME"),
              numeric: false,
              tooltip: "This is First Name",
              onSort: (columnIndex, ascending) {
                setState(() {
                  sort = !sort;
                });
                onSortColum(columnIndex, ascending);
              }),
          DataColumn(
            label: Text("LAST NAME"),
            numeric: false,
            tooltip: "This is Last Name",
          ),
        ],
        rows: users
            .map(
              (user) => DataRow(
                      selected: selectedUsers.contains(user),
                      onSelectChanged: (b) {
                        print("Onselect");
                        onSelectedRow(b, user);
                      },
                      cells: [
                        DataCell(
                          Text(user.firstName),
                          onTap: () {
                            print('Selected ${user.firstName}');
                          },
                        ),
                        DataCell(
                          Text(user.lastName),
                        ),
                      ]),
            )
            .toList(),
      ),
    );
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text(widget.title),
      ),
      floatingActionButton: new FloatingActionButton(
        child: new Icon(Icons.add),
        onPressed: (){
          showDialog(
            context: context,
            builder: (_) => new AlertDialog(
              title: new Text('Data Table Flutter'),
              content: new Container(
                height: 500,
                width: 400,
                child: new SingleChildScrollView(
                  scrollDirection: Axis.horizontal,
                  child: new Column(
                    children: <Widget>[
                      dataBody()
                    ],
                  ),
                )
              ),
              actions: <Widget>[
                new OutlineButton(
                  child: Text('SELECTED ${selectedUsers.length}'),
                  onPressed: () {},
                ),
                new OutlineButton(
                  child: Text('DELETE SELECTED'),
                  onPressed: selectedUsers.isEmpty
                      ? null
                      : () {
                          deleteSelected();
                        },
                ),
              ],
            )
          );
        },
      ),
    );
  }
}

class User {
  String firstName;
  String lastName;

  User({this.firstName, this.lastName});

  static List<User> getUsers() {
    return <User>[
      User(firstName: "Aaryan", lastName: "Shah"),
      User(firstName: "Ben", lastName: "John"),
      User(firstName: "Carrie", lastName: "Brown"),
      User(firstName: "Deep", lastName: "Sen"),
      User(firstName: "Emily", lastName: "Jane"),
    ];
  }
}

Пожалуйста, дайте мне знать, что-то отсутствует или что-то, что мне нужно изменить.Это будет очень полезно для меня.Заранее спасибо.

1 Ответ

1 голос
/ 07 июля 2019

SetState, который вы используете для обновления диалога, не предназначен для диалога.Он вызывает setState для класса DataTableDemoState.Если вы хотите обновить диалоговое окно, сделайте его другим виджетом с отслеживанием состояния, а затем, когда вы хотите обновить, вызовите его метод setState.Примерно так:

        ......
        content: new SingleChildScrollView(
        child: new Material(
          child: new MyDialogContent(list: countries),
        ),
      ),
    );
  },

Где MyDialogContent - это виджет с состоянием, и вы обновляете содержимое диалога в классе MyDialogContentState.Надеюсь, это поможет

...