addresspicker_packages 0.0.2 copy "addresspicker_packages: ^0.0.2" to clipboard
addresspicker_packages: ^0.0.2 copied to clipboard

It's a custom addresspicker. More easy .

example/lib/main.dart

import 'package:addresspicker_packages/Address.dart';
import 'package:addresspicker_packages/addresspicker_package.dart';
import 'package:flutter/material.dart';
import 'dart:async';

import 'package:flutter/services.dart';
import 'package:addresspicker_packages/addresspicker_packages.dart';
import 'package:get/get.dart';

void main() {
  runApp(MyApp());
}

class MyApp extends StatefulWidget {
  @override
  _MyAppState createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {
  String _platformVersion = 'Unknown';

  @override
  void initState() {
    super.initState();
    initPlatformState();
  }

  // Platform messages are asynchronous, so we initialize in an async method.
  Future<void> initPlatformState() async {
    String platformVersion;
    // Platform messages may fail, so we use a try/catch PlatformException.
    try {
      platformVersion = await AddresspickerPackages.platformVersion;
    } on PlatformException {
      platformVersion = 'Failed to get platform version.';
    }

    // If the widget was removed from the tree while the asynchronous platform
    // message was in flight, we want to discard the reply rather than calling
    // setState to update our non-existent appearance.
    if (!mounted) return;

    setState(() {
      _platformVersion = platformVersion;
    });
  }

  @override
  Widget build(BuildContext context) {
    return MaterialApp(home: AddressPicker());
  }
}

class AddressPicker extends StatefulWidget {
  @override
  _AddressPickerState createState() => _AddressPickerState();
}

class _AddressPickerState extends State<AddressPicker> {
  List<Address> provinceList = [
    Address(code: '1', name: 'province1'),
    Address(code: '2', name: 'province2'),
    Address(code: '3', name: 'province3'),
    Address(code: '4', name: 'province4'),
    Address(code: '5', name: 'province5'),
  ];
  List<Address> districtList = [
    Address(code: '1', name: 'distri1'),
    Address(code: '2', name: 'distri2'),
    Address(code: '3', name: 'distri3'),
    Address(code: '4', name: 'distri4'),
    Address(code: '5', name: 'distri5'),
  ];
  List<Address> villageList = [
    Address(code: '1', name: 'village1'),
    Address(code: '2', name: 'village2'),
    Address(code: '3', name: 'village3'),
    Address(code: '4', name: 'village4'),
    Address(code: '5', name: 'village5'),
  ];
  List<Address> communeList = [
    Address(code: '1', name: 'commun1'),
    Address(code: '2', name: 'commun2'),
    Address(code: '3', name: 'commun3'),
    Address(code: '4', name: 'commun4'),
    Address(code: '5', name: 'commun5'),
  ];
  List<Address> listData = [];
  Address city;
  Address district;
  Address commune;
  Address village;
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: const Text('Address Picker'),
      ),
      body: Container(
        child: GestureDetector(
            child: Text('ShowAddress'),
            onTap: () {
              listData.clear();
              onShowAddressPicker(
                  gridIndex: 2,
                   //initial value
                   city: city,
                   commune: district,
                  district: commune,
                  village: village,
                  context: context,
                  onCancel: () {
                    Navigator.pop(context);
                    Navigator.pop(context);
                  },
                  onSelectProvince: (Address province) {
                    print(province.name);
                    setState(() {

                      listData.add(province);
                    });
                  },
                  onSelectCommune: (Address commune) {
                    setState(() {
                      listData.add(commune);
                    });
                  },
                  onSelectDistrict: (Address disctrict) {
                    setState(() {
                      listData.add(disctrict);
                    });
                  },
                  onSelectVillage: (Address village) {
                    setState(() {
                      if(listData.length!=4)
                        listData.add(village);
                         else {
                        listData[3] = village;
                             }
                    });
                  },
                  //list all value
                  selectAddress: listData,
                  communeList: communeList,
                  provinceList: provinceList,
                  villageList: villageList,
                  districtList: districtList,
                  onSave: () {
                    city=listData[0];
                    district=listData[1];
                    commune=listData[2];
                    village=listData[3];
                  });
            }),
      ),
    );
  }
}
0
likes
20
pub points
0%
popularity

Publisher

unverified uploader

It's a custom addresspicker. More easy .

Homepage

License

unknown (LICENSE)

Dependencies

flutter, flutter_svg, get

More

Packages that depend on addresspicker_packages