Flutter 三级联动

2020-08-14  本文已影响0人  Wuthier

1 (2).png

组件

import 'package:bandexapp/src/pages/common/bottom_container_widget.dart';
import 'package:bandexapp/src/utils/log_utils.dart';
import 'package:flutter/material.dart';

/// 设备选择组件
/// [child] 组件样式
/// [deviceListData] 设备数据
/// [onTap] 回调
/// [singleChoice] 单选、多选
class DeviceSelectWidget extends StatefulWidget {
  final Widget child;
  final List deviceListData;
  final Function onTap;
  final bool singleChoice;

  DeviceSelectWidget(
      {@required this.child,
      @required this.deviceListData,
      @required this.onTap,
      this.singleChoice = false});

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

class _DeviceSelectWidgetState extends State<DeviceSelectWidget> {
  // 设备选择组
  List _companyGroup = [];

  // 当前选中公司
  int _nowClickCompany;

  // 设备型号选择组
  List _typeGroup = [];

  // 设备名称选择组
  List _nameGroup = [];

  // 当前选择公司组的数据
  List _nowChooseGroup = [];

  bool _isFirst = true;

  @override
  Widget build(BuildContext context) {
    return GestureDetector(
      child: widget.child,
      onTap: () async {
        LogUtils.e("选择设备。。。");
        if (_isFirst) {
          initData();
          _isFirst = false;
        }
        List chooseDevice = await showModalBottomSheet(
          context: context,
          builder: (BuildContext context) {
            return StatefulBuilder(
              builder: (BuildContext context, StateSetter modalSetState) {
                return Container(
                  child: Column(
                    children: <Widget>[
                      Expanded(
                        child: buildDeviceContainer(modalSetState),
                      ),
                      Expanded(
                        flex: 0,
                        child: buildBottomButton(modalSetState),
                      ),
                    ],
                  ),
                );
              },
            );
          },
        );
        LogUtils.e("chooseDevice $chooseDevice");
        widget.onTap(chooseDevice);
      },
    );
  }

  // 初始化数据
  void initData() {
    _companyGroup = [];
    whileCompany(widget.deviceListData);
    LogUtils.e("_companyGroup $_companyGroup");
    setState(() {});
  }

  // 格式化设备组
  void whileCompany(data) {
    for (int i = 0; i < data.length; i++) {
      if (null != data[i] && data[i]['MEMO'] != '-1') {
        _companyGroup
            .add({'name': data[i]['GP_NAME'], 'value': data[i]['NODES']});
      }
      if (null != data[i] &&
          null != data[i]['NODES'] &&
          data[i]['NODES'].length > 0) {
        whileCompany(data[i]['NODES']);
      }
    }
  }

  // 选择设备区域
  buildDeviceContainer(StateSetter modalSetState) {
    return Row(
      children: <Widget>[
        Expanded(
          child: selectCompanyItem(modalSetState),
        ),
        Expanded(
          child: Column(
            children: <Widget>[
              Expanded(
                flex: 0,
                child: Row(
                  mainAxisAlignment: MainAxisAlignment.center,
                  children: <Widget>[
                    Expanded(
                      child: FlatButton(
                        child: Text('全选'),
                        onPressed: () {
                          for (int i = 0; i < _typeGroup.length; i++) {
                            _typeGroup[i]['check'] = true;
                          }
                          whileName();
                          modalSetState(() {});
                        },
                      ),
                    ),
                    Expanded(
                      child: FlatButton(
                        child: Text('取消'),
                        onPressed: () {
                          for (int i = 0; i < _typeGroup.length; i++) {
                            _typeGroup[i]['check'] = false;
                          }
                          whileName();
                          modalSetState(() {});
                        },
                      ),
                    ),
                  ],
                ),
              ),
              Expanded(
                child: selectTypeItem(modalSetState),
              ),
            ],
          ),
        ),
        Expanded(
          child: Column(
            children: <Widget>[
              widget.singleChoice
                  ? Container()
                  : Expanded(
                flex: 0,
                child: Row(
                  mainAxisAlignment: MainAxisAlignment.center,
                  children: <Widget>[
                    Expanded(
                      child: FlatButton(
                        child: Text('全选'),
                        onPressed: () {
                          for (int i = 0; i < _nameGroup.length; i++) {
                            _nameGroup[i]['check'] = true;
                          }
                          modalSetState(() {});
                        },
                      ),
                    ),
                    Expanded(
                      child: FlatButton(
                        child: Text('取消'),
                        onPressed: () {
                          for (int i = 0; i < _nameGroup.length; i++) {
                            _nameGroup[i]['check'] = false;
                          }
                          modalSetState(() {});
                        },
                      ),
                    ),
                  ],
                ),
              ),
              Expanded(
                child: selectNameItem(modalSetState),
              ),
            ],
          ),
        ),
      ],
    );
  }

  // 底部操作按钮
  buildBottomButton(StateSetter modalSetState) {
    return BottomContainerWidget(
      child: Row(
        mainAxisAlignment: MainAxisAlignment.spaceEvenly,
        children: <Widget>[
          RaisedButton(
            child: Text('重置'),
            onPressed: () {
              modalSetState(() {
                _nowClickCompany = null;
                _typeGroup = [];
                _nameGroup = [];
                _nowChooseGroup = [];
              });
            },
          ),
          RaisedButton(
            child: Text('确定'),
            onPressed: () {
              List devices = [];
              for (int i = 0; i < _nameGroup.length; i++) {
                if (_nameGroup[i]['check']) {
                  devices.add(_nameGroup[i]);
                }
              }
              Navigator.pop(context, devices);
            },
          ),
        ],
      ),
    );
  }

  // 公司列表
  selectCompanyItem(StateSetter modalSetState) {
    return ListView.separated(
      itemBuilder: (BuildContext context, int index) {
        return Container(
          color: Colors.grey[300],
          child: GestureDetector(
            child: ListTile(
              title: Text(
                  _companyGroup.length > 0
                      ? _companyGroup[index]['name'] ?? ' '
                      : ' ',
                  style: _nowClickCompany == index
                      ? TextStyle(color: Colors.blue)
                      : TextStyle()),
            ),
            onTap: () {
              if (_nowClickCompany != index) {
                _typeGroup = [];
                _nameGroup = [];
                _nowClickCompany = index;
                _nowChooseGroup = _companyGroup[index]['value'];
                whileType(_companyGroup[index]['value']);
                modalSetState(() {});
              }
            },
          ),
        );
      },
      separatorBuilder: (BuildContext context, int index) {
        return Divider(
          height: 0.0,
        );
      },
      itemCount: _companyGroup.length,
    );
  }

  // 型号列表
  selectTypeItem(StateSetter modalSetState) {
    return ListView.separated(
      itemBuilder: (BuildContext context, int index) {
        return Container(
          color: Colors.grey[200],
          child: GestureDetector(
            child: ListTile(
              title: Text(
                  _typeGroup.length > 0 ? _typeGroup[index]['name'] ?? ' ' : ' ',
                  style: _typeGroup[index]['check']
                      ? TextStyle(color: Colors.blue)
                      : TextStyle()),
            ),
            onTap: () {
              _typeGroup[index]['check'] = !_typeGroup[index]['check'];
              whileName();
              modalSetState(() {});
            },
          ),
        );
      },
      separatorBuilder: (BuildContext context, int index) {
        return Divider(
          height: 0.0,
        );
      },
      itemCount: _typeGroup.length,
    );
  }

  // 名称列表
  selectNameItem(StateSetter modalSetState) {
    return ListView.separated(
      itemBuilder: (BuildContext context, int index) {
        return Container(
          color: Colors.grey[300],
          child: GestureDetector(
            child: ListTile(
              title: Text(
                _nameGroup.length > 0 ? _nameGroup[index]['name'] ?? ' ' : ' ',
                style: _nameGroup[index]['check']
                    ? TextStyle(color: Colors.blue)
                    : TextStyle(),
              ),
            ),
            onTap: () {
              if (!widget.singleChoice) {
                _nameGroup[index]['check'] = !_nameGroup[index]['check'];
              } else {
                for (int i = 0; i < _nameGroup.length; i++) {
                  _nameGroup[i]['check'] = false;
                }
                _nameGroup[index]['check'] = true;
              }
              modalSetState(() {});
            },
          ),
        );
      },
      separatorBuilder: (BuildContext context, int index) {
        return Divider(
          height: 0.0,
        );
      },
      itemCount: _nameGroup.length,
    );
  }

  // 获取设备型号
  whileType(data) {
    for (int i = 0; i < data.length; i++) {
      if (null != data[i]['MACHINE_FEILD']) {
        if (!_typeGroup.any(
            (val) => val['name'] == data[i]['MACHINE_FEILD']['MAC_NAME'])) {
          _typeGroup.add(
              {'name': data[i]['MACHINE_FEILD']['MAC_NAME'], 'check': false});
        }
      }
    }
  }

  // 获取设备名称
  whileName() {
    _nameGroup = [];
    for (int i = 0; i < _nowChooseGroup.length; i++) {
      if (null != _nowChooseGroup[i]['MACHINE_FEILD']) {
        for (int k = 0; k < _typeGroup.length; k++) {
          if (_typeGroup[k]['check'] &&
              _typeGroup[k]['name'] ==
                  _nowChooseGroup[i]['MACHINE_FEILD']['MAC_NAME']) {
            _nameGroup.add({
              'name': _nowChooseGroup[i]['MACHINE_FEILD']['MAC_NO'],
              'value': _nowChooseGroup[i]['MACHINE_FEILD']['MAC_NBR'],
              'check': false
            });
          }
        }
      }
    }
  }
}

使用

DeviceSelectWidget(
 child: Text("选择设备", style: TextStyle(color: Colors.blue)),
 deviceListData: [],
 singleChoice: true,
 onTap: (value) {},
)
上一篇 下一篇

猜你喜欢

热点阅读