231 lines
6.7 KiB
Dart
231 lines
6.7 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:flutter_map/flutter_map.dart';
|
|
import 'package:get/get.dart';
|
|
import 'package:rogapp/pages/index/index_controller.dart';
|
|
|
|
|
|
class PerfectureWidget extends StatefulWidget {
|
|
|
|
IndexController indexController;
|
|
MapController mapController;
|
|
|
|
PerfectureWidget({Key? key, required this.indexController, required this.mapController}) : super(key: key){
|
|
//indexController.zoomtoMainPerf("9", mapController);
|
|
}
|
|
|
|
@override
|
|
State<PerfectureWidget> createState() => _PerfectureWidgetState();
|
|
}
|
|
|
|
class _PerfectureWidgetState extends State<PerfectureWidget> {
|
|
|
|
|
|
List<DropdownMenuItem<String>> getDropdownItems() {
|
|
List<DropdownMenuItem<String>> dropDownItems = [];
|
|
|
|
for (Map<String, dynamic> currency in widget.indexController.perfectures[0]) {
|
|
//print(currency["id"].toString());
|
|
var newDropdown = DropdownMenuItem(
|
|
child: Text(currency["adm1_ja"].toString()),
|
|
value: currency["id"].toString(),
|
|
);
|
|
|
|
dropDownItems.add(newDropdown);
|
|
}
|
|
return dropDownItems;
|
|
}
|
|
|
|
List<DropdownMenuItem<String>> getSubDropdownItems() {
|
|
List<DropdownMenuItem<String>> dropDownItems = [];
|
|
|
|
if(widget.indexController.subPerfs.isNotEmpty){
|
|
|
|
for (Map<String, dynamic> currency in widget.indexController.subPerfs[0]) {
|
|
var newDropdown = DropdownMenuItem(
|
|
child: Text(currency["adm2_ja"].toString()),
|
|
value: currency["id"].toString(),
|
|
);
|
|
|
|
dropDownItems.add(newDropdown);
|
|
}
|
|
}
|
|
return dropDownItems;
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return Obx(() =>
|
|
Row(
|
|
children: [
|
|
DropdownButton<String>(
|
|
value: widget.indexController.dropdownValue,
|
|
icon: const Icon(Icons.arrow_downward),
|
|
elevation: 16,
|
|
style: const TextStyle(color: Colors.deepPurple),
|
|
underline: Container(
|
|
height: 2,
|
|
color: Colors.deepPurpleAccent,
|
|
),
|
|
onChanged: (String? newValue) {
|
|
//setState(() {
|
|
if(newValue != null){
|
|
widget.indexController.dropdownValue = newValue;
|
|
widget.indexController.populateForPerf(newValue, widget.mapController);
|
|
}
|
|
//});
|
|
},
|
|
items: getDropdownItems()
|
|
),
|
|
|
|
widget.indexController.subPerfs.isNotEmpty ?
|
|
|
|
DropdownButton<String>(
|
|
value: widget.indexController.subDropdownValue,
|
|
icon: const Icon(Icons.arrow_downward),
|
|
elevation: 16,
|
|
style: const TextStyle(color: Colors.deepPurple),
|
|
hint: const Text("select"),
|
|
underline: Container(
|
|
height: 2,
|
|
color: Colors.deepPurpleAccent,
|
|
),
|
|
onChanged: (String? newValue) {
|
|
setState(() {
|
|
if(newValue != null){
|
|
widget.indexController.populateForSubPerf(newValue, widget.mapController);
|
|
//widget.indexController.loadLocationforSubPerf(newValue, widget.mapController);
|
|
//widget.indexController.subDropdownValue = newValue;
|
|
}
|
|
});
|
|
},
|
|
items:
|
|
getSubDropdownItems()
|
|
) :
|
|
const Text("")
|
|
|
|
],
|
|
),
|
|
);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
// class PerfectureWidget extends StatefulWidget {
|
|
|
|
// HomeController homeController;
|
|
// MapController mapController;
|
|
|
|
// PerfectureWidget({required this.homeController, required this.mapController});
|
|
|
|
// @override
|
|
// State<PerfectureWidget> createState() => _PerfectureWidgetState();
|
|
// }
|
|
|
|
// class _PerfectureWidgetState extends State<PerfectureWidget> {
|
|
// String dropdownValue = "9";
|
|
|
|
// List<DropdownMenuItem<String>> getDropdownItems() {
|
|
// List<DropdownMenuItem<String>> dropDownItems = [];
|
|
|
|
// for (Map<String, dynamic> currency in widget.homeController.perfectures[0]) {
|
|
// //print(currency["id"].toString());
|
|
// var newDropdown = DropdownMenuItem(
|
|
// child: Text(currency["adm1_ja"].toString()),
|
|
// value: currency["id"].toString(),
|
|
// );
|
|
|
|
// dropDownItems.add(newDropdown);
|
|
// }
|
|
// return dropDownItems;
|
|
// }
|
|
|
|
// List<DropdownMenuItem<String>> getSubDropdownItems() {
|
|
// List<DropdownMenuItem<String>> dropDownItems = [];
|
|
|
|
// if(widget.homeController.subPerfs.length > 0){
|
|
|
|
// for (Map<String, dynamic> currency in widget.homeController.subPerfs[0]) {
|
|
// var newDropdown = DropdownMenuItem(
|
|
// child: Text(currency["adm2_ja"].toString()),
|
|
// value: currency["id"].toString(),
|
|
// );
|
|
|
|
// dropDownItems.add(newDropdown);
|
|
// }
|
|
// }
|
|
// return dropDownItems;
|
|
// }
|
|
|
|
// @override
|
|
// void initState() {
|
|
// super.initState();
|
|
// widget.homeController.loadSubPerfFor("9");
|
|
// widget.homeController.zoomtoMainPerf("9", widget.mapController);
|
|
// }
|
|
|
|
// @override
|
|
// Widget build(BuildContext context) {
|
|
|
|
// return Obx(() =>
|
|
// Row(
|
|
// children: [
|
|
// DropdownButton<String>(
|
|
// value: dropdownValue,
|
|
// icon: const Icon(Icons.arrow_downward),
|
|
// elevation: 16,
|
|
// style: const TextStyle(color: Colors.deepPurple),
|
|
// underline: Container(
|
|
// height: 2,
|
|
// color: Colors.deepPurpleAccent,
|
|
// ),
|
|
// onChanged: (String? newValue) {
|
|
// //setState(() {
|
|
// if(newValue != null){
|
|
// dropdownValue = newValue;
|
|
// widget.homeController.loadLocationforPerf(newValue, widget.mapController);
|
|
// widget.homeController.loadSubPerfFor(newValue);
|
|
// //SubDropdownValue = widget.homeController.getSubInitialVal();
|
|
// //widget.mapController.fitBounds(widget.homeController.currentBound[0]);
|
|
// widget.homeController.zoomtoMainPerf(newValue, widget.mapController);
|
|
// }
|
|
// //});
|
|
// },
|
|
// items: getDropdownItems()
|
|
// ),
|
|
|
|
// widget.homeController.subPerfs.length > 0 ?
|
|
|
|
// DropdownButton<String>(
|
|
// value: widget.homeController.SubDropdownValue,
|
|
// icon: const Icon(Icons.arrow_downward),
|
|
// elevation: 16,
|
|
// style: const TextStyle(color: Colors.deepPurple),
|
|
// hint: Container(
|
|
// child: Text("select"),
|
|
// ),
|
|
// underline: Container(
|
|
// height: 2,
|
|
// color: Colors.deepPurpleAccent,
|
|
// ),
|
|
// onChanged: (String? newValue) {
|
|
// //setState(() {
|
|
// if(newValue != null){
|
|
// widget.homeController.loadLocationforSubPerf(newValue, widget.mapController);
|
|
// widget.homeController.SubDropdownValue = newValue;
|
|
// widget.homeController.zoomtoSubPerf(newValue, widget.mapController);
|
|
// }
|
|
// //});
|
|
// },
|
|
// items:
|
|
// getSubDropdownItems()
|
|
// ) :
|
|
// Text("")
|
|
|
|
// ],
|
|
// ),
|
|
// );
|
|
// }
|
|
// }
|
|
|