import 'package:cached_network_image/cached_network_image.dart'; import 'package:flutter/cupertino.dart'; import 'package:flutter/material.dart'; import 'package:flutter_easyrefresh/easy_refresh.dart'; import 'package:shared_preferences/shared_preferences.dart'; import 'package:ysairplane/code/YSPay.dart'; import 'package:ysairplane/code/YSShortDetail.dart'; import 'package:ysairplane/tools/YSNetWorking.dart'; import 'package:ysairplane/tools/YSTools.dart'; import 'YSMarryPlane.dart'; class YSSearchResult extends StatefulWidget { final searchStr; final type; final siftValue; const YSSearchResult({Key key, this.searchStr, this.type, this.siftValue}) : super(key: key); @override _YSSearchResultState createState() => _YSSearchResultState(); } class _YSSearchResultState extends State { TextEditingController _searchStr = TextEditingController(); List _tabValues = [{'name':'空中浏览','type':9},{'name':'短途客运','type':6},{'name':'短途货运','type':33},{'name':'航空运动','type':5}, {'name':'婚庆典礼','type':4}]; int _page = 1; List _dataArray = []; int _index = 0; int _typeIndex = 0; List _priceList = []; List _kinds = []; bool _isOrder = false; int _selected = 0; Map _kind; String _timeStr; List _historyList = []; TextEditingController _name = TextEditingController(); TextEditingController _volume = TextEditingController(); TextEditingController _weight = TextEditingController(); @override void initState() { if(widget.type!=null){ for(int i = 0;i<_tabValues.length;i++){ if(_tabValues[i]['type']==int.parse('${widget.type}')){ _typeIndex = i; } } } if(widget.searchStr!=null){ _searchStr.text = widget.searchStr; } _timeStr = DateTime.now().year.toString()+'-'+DateTime.now().month.toString().padLeft(2,'0')+'-' +DateTime.now().day.toString().padLeft(2,'0')+' '+DateTime.now().hour.toString().padLeft(2,'0')+':' +DateTime.now().minute.toString().padLeft(2,'0'); SharedPreferences.getInstance().then((value){ setState(() { _historyList = value.getStringList('history')??[]; }); }); Future.delayed(Duration(seconds: 0)).then((value){ _refreshData(); }); super.initState(); } @override Widget build(BuildContext context) { return Scaffold( body: SingleChildScrollView( child: Stack( children: [ SingleChildScrollView( child: Column( children: [ Container( margin: EdgeInsets.only(top: MediaQuery.of(context).padding.top+hsp(42),left: wsp(32),right: wsp(32)), child: Row( mainAxisAlignment: MainAxisAlignment.spaceBetween, children: [ GestureDetector(child: Icon(Icons.arrow_back_ios,size: hsp(40),color: Color(0xFF000000),),onTap: (){Navigator.pop(context);},), Container( width: MediaQuery.of(context).size.width-wsp(140), margin: EdgeInsets.only(left: wsp(34)), padding: EdgeInsets.only(left: wsp(26),right: wsp(26)), height: hsp(66), decoration: BoxDecoration( border: Border.all(color: Color(0xFF007AFF),width: 1), borderRadius: BorderRadius.all(Radius.circular(5)) ), child: CupertinoTextField( placeholder: '', placeholderStyle: TextStyle(fontSize: zsp(25),color: Color(0xFF545454)), style: TextStyle(fontSize: zsp(25),color: Color(0xFF545454)), prefix: Icon(Icons.search,size: hsp(40),color: Color(0xFF8E8E93),), suffix: GestureDetector(child: Icon(Icons.close,size: hsp(40),color: Color(0xFF8E8E93),),onTap: (){_searchStr.text = '';},), suffixMode: OverlayVisibilityMode.editing, controller: _searchStr, padding: EdgeInsets.all(0), decoration: BoxDecoration(), onSubmitted: (value){ if(value.isNotEmpty){ if(_historyList.contains(value)){ _historyList.remove(value); } _historyList.insert(0, value); SharedPreferences.getInstance().then((prefer){ prefer.setStringList('history', _historyList); _refreshData(); }); }else{ _refreshData(); } }, textInputAction: TextInputAction.search, ), ), ], ), ), Container( height: hsp(100), width: MediaQuery.of(context).size.width, child: ListView.builder( itemBuilder: (context,index){ return GestureDetector( onTap: (){ _typeIndex = index; _refreshData(); }, child: Container( width: MediaQuery.of(context).size.width/4, padding: EdgeInsets.only(top: hsp(20)), child: Column( children: [ Text('${_tabValues[index]['name']}',style: TextStyle(color: index==_typeIndex?Color(0xFF007AFF):Colors.black, fontWeight: _typeIndex==index?FontWeight.bold:FontWeight.normal),), Container(height: 2,color: index==_typeIndex?Color(0xFF007AFF):Colors.transparent,width: MediaQuery.of(context).size.width/8, margin: EdgeInsets.only(top: hsp(10)),) ], ), ), ); }, padding: EdgeInsets.all(0), itemCount: _tabValues.length, scrollDirection: Axis.horizontal, ), ), Container( height: MediaQuery.of(context).size.height-MediaQuery.of(context).padding.top-hsp(208), color: Color(0xFFF1F2F3), child: PageView( children: [ Container( height: MediaQuery.of(context).size.height-MediaQuery.of(context).padding.top-hsp(208), color: Color(0xFFF1F2F3), child: EasyRefresh( onRefresh: _refreshData, onLoad: _loadMoreData, header: TaurusHeader( ), footer: TaurusFooter( ), child: ListView.separated( itemBuilder: (context,index){ return GestureDetector( behavior: HitTestBehavior.opaque, onTap: (){ if(_typeIndex==2){ _index = index; _getPriceData(); }else{ Navigator.of(context).push( CupertinoPageRoute( builder: (context){ return _typeIndex==1?YSShortDetail(shortId: _dataArray[index]['id'],): YSMarryPlane(marryId: _dataArray[index]['id'],type: _typeIndex==0?9:_typeIndex==3?5:4); } ) ); } }, child: Container( padding: EdgeInsets.all(hsp(30)), child: _typeIndex==1?Row( children: [ Container( height: hsp(200), width: hsp(250), margin: EdgeInsets.only(right: hsp(30)), child: CachedNetworkImage( imageUrl: '${_dataArray[index]['cover']}', fit: BoxFit.fill, ), ), Container( width: MediaQuery.of(context).size.width-hsp(340), height: hsp(200), child: Column( mainAxisAlignment: MainAxisAlignment.spaceBetween, crossAxisAlignment: CrossAxisAlignment.start, children: [ Row( children: [ Text('${_dataArray[index]['setoutInfo']['display']}',style: TextStyle(fontSize: zsp(40),color: Colors.black,fontWeight: FontWeight.bold),), Container( height: 2, width: wsp(40), margin: EdgeInsets.only(left: wsp(20),right: wsp(20)), color: Color(0xFFCCCCCC), ), Text('${_dataArray[index]['arriveInfo']['display']}',style: TextStyle(fontSize: zsp(40),color: Colors.black,fontWeight: FontWeight.bold),) ], ), Text('${_dataArray[index]['dtFlightInformation']['partnerName']}',style: TextStyle(fontSize: zsp(24),color: Color(0xFF9A9A9A)),), Row( mainAxisAlignment: MainAxisAlignment.spaceBetween, children: [ Text('${_dataArray[index]['dtFlightInformation']['model']}',style: TextStyle(fontSize: zsp(24),color: Color(0xFF9A9A9A)),), RichText( text: TextSpan( text: '¥', style: TextStyle(fontSize: zsp(24),color: Color(0xFFEB423B)), children: [ TextSpan( text: '${_dataArray[index]['discountPrice']}', style: TextStyle(fontSize: zsp(42),fontWeight: FontWeight.bold), ), TextSpan( text: '元起', style: TextStyle(fontSize: zsp(20)), ) ] ), ) ], ) ], ), ) ], ):_typeIndex==2?Column( children: [ Container( padding: EdgeInsets.only(bottom: hsp(30)), child: Column( children: [ Row( children: [ Text('${_dataArray[index]['setoutInfo']['display']}',style: TextStyle(fontSize: zsp(40),fontWeight: FontWeight.bold,color: Colors.black),), Image(height: hsp(60),width: hsp(60),image: AssetImage('lib/images/plane.png'),), Text('${_dataArray[index]['arriveInfo']['display']}',style: TextStyle(fontSize: zsp(40),fontWeight: FontWeight.bold,color: Colors.black),), ], mainAxisAlignment: MainAxisAlignment.spaceBetween, ), Row( mainAxisAlignment: MainAxisAlignment.spaceBetween, children: [ Text('${_dataArray[index]['setoutInfo']['airplanename']}',style: TextStyle(fontSize: zsp(24),color: Color(0xFF999999)),), Text('${_dataArray[index]['hour']}',style: TextStyle(fontSize: zsp(20),color: Color(0xFF343434)),), Text('${_dataArray[index]['arriveInfo']['airplanename']}',style: TextStyle(fontSize: zsp(24),color: Color(0xFF999999)),), ], ) ], ), ), Divider(height: 0.5,thickness: 0.5,color: Color(0xFFEAEAEA),), Container( height: hsp(70), child: Row( children: [ Text('${_dataArray[index]['flightTime']}',style: TextStyle(fontSize: zsp(28),color: Color(0xFF333333)),), Text('机型: ${_dataArray[index]['dtFlightInformation']['model']}',style: TextStyle(fontSize: zsp(28),color: Color(0xFF333333)),), ], mainAxisAlignment: MainAxisAlignment.spaceBetween, ), ), Divider(height: 0.5,thickness: 0.5,color: Color(0xFFEAEAEA),), Container( height: hsp(70), child: Row( children: [ RichText( text: TextSpan( style: TextStyle(fontSize: zsp(24),color: Color(0xFF999999)), children: [ TextSpan( text: '类型: ' ), TextSpan( text: '${_dataArray[index]['type']==1?'整机':'拼机'}', style: TextStyle(color: Color(0xFF333333)) ), TextSpan( text: '体积: ' ), TextSpan( text: '${_dataArray[index]['totalVolume']}立方米', style: TextStyle(color: Color(0xFF333333)) ), TextSpan( text: '重量: ' ), TextSpan( text: '${_dataArray[index]['totalWeight']}吨', style: TextStyle(color: Color(0xFF333333)) ) ] ), ), Text('¥${_dataArray[index]['discountPrice']}',style: TextStyle(fontSize: zsp(40),color: Color(0xFFEA413A),fontWeight: FontWeight.bold),), ], mainAxisAlignment: MainAxisAlignment.spaceBetween, ), margin: EdgeInsets.only(top: hsp(20)), ), ], ):Row( children: [ Container( height: hsp(200), width: hsp(250), child: CachedNetworkImage( imageUrl: '${_dataArray[index]['cover']}', fit: BoxFit.fill, ), margin: EdgeInsets.only(right: hsp(30)), ), Container( width: MediaQuery.of(context).size.width-hsp(340), height: hsp(200), child: Column( mainAxisAlignment: MainAxisAlignment.spaceBetween, crossAxisAlignment: CrossAxisAlignment.start, children: [ Text('${_dataArray[index]['title']}',style: TextStyle(fontSize: zsp(30),color: Color(0xFF343434)),maxLines: 2,), Text('${_dataArray[index]['dtFlightInformation']['partnerName']}',style: TextStyle(fontSize: zsp(24),color: Color(0xFF9A9A9A)),), Row( mainAxisAlignment: MainAxisAlignment.spaceBetween, children: [ Text('${_dataArray[index]['dtFlightInformation']['model']}',style: TextStyle(fontSize: zsp(24),color: Color(0xFF9A9A9A)),), RichText( text: TextSpan( text: '¥', style: TextStyle(fontSize: zsp(24),color: Color(0xFFEB423B)), children: [ TextSpan( text: '${_dataArray[index]['discountPrice']}', style: TextStyle(fontSize: zsp(42),fontWeight: FontWeight.bold), ), TextSpan( text: '元起', style: TextStyle(fontSize: zsp(20)), ) ] ), ) ], ) ], ), ) ], ), ), ); }, separatorBuilder: (context,index){ return Divider(height: 0.5,thickness: 0.5,color: Color(0xFFEEEEEE),); }, itemCount: _dataArray.length, padding: EdgeInsets.all(0), ), ), ) ], ), ) ], ), ), if(_isOrder==true)GestureDetector( onTap: (){ setState(() { _isOrder = false; }); }, child: Container( height: MediaQuery.of(context).size.height, width: MediaQuery.of(context).size.width, color: Colors.black54, child: GestureDetector( onTap: (){}, child: Column( children: [ Container( height: MediaQuery.of(context).size.height*0.8-hsp(120), width: MediaQuery.of(context).size.width, margin: EdgeInsets.only(top: MediaQuery.of(context).size.height*0.2), decoration: BoxDecoration( color: Color(0xFFF1F2F3), borderRadius: BorderRadius.only(topLeft: Radius.circular(10),topRight: Radius.circular(10)) ), child: Column( crossAxisAlignment: CrossAxisAlignment.start, children: [ Container( height: hsp(100), decoration: BoxDecoration( color: Colors.white, borderRadius: BorderRadius.only(topLeft: Radius.circular(10),topRight: Radius.circular(10)) ), padding: EdgeInsets.only(left: 15,right: 15), child: Row( mainAxisAlignment: MainAxisAlignment.spaceBetween, children: [ Container(width: wsp(50),), Text('订单确认',style: TextStyle(fontSize: 15,color: Color(0xFF000000),decoration: TextDecoration.none,fontWeight: FontWeight.bold),), GestureDetector( child: Text('关闭',style: TextStyle(fontSize: 15,color: Color(0xFF007EFF),decoration: TextDecoration.none,fontWeight: FontWeight.bold),), onTap: (){ setState(() { _isOrder = false; }); }, ), ], ), ), Divider(height: 0.5,thickness: 0.5,color: Color(0xFFE5E5E5),), Container( height: MediaQuery.of(context).size.height*0.8-hsp(220)-0.5, child: SingleChildScrollView( padding: EdgeInsets.all(0), child: Column( children: [ Container( padding: EdgeInsets.all(hsp(30)), color: Colors.white, width: MediaQuery.of(context).size.width, child: Column( crossAxisAlignment: CrossAxisAlignment.start, children: [ Text('使用日期',style: TextStyle(fontSize: zsp(30),color: Color(0xFF9A9A9A)),), Container( margin: EdgeInsets.only(top: hsp(20)), child: Row( children: [ Container( height: hsp(120), width: MediaQuery.of(context).size.width-hsp(200), child: ListView.separated( itemBuilder: (context,index){ return GestureDetector( behavior: HitTestBehavior.opaque, onTap: (){ setState(() { _selected = index; }); }, child: Stack( children: [ Container( height: hsp(120), width: (MediaQuery.of(context).size.width-hsp(230))/3, decoration: BoxDecoration( color: index==_selected?Color(0xFF007EFF):Color(0xFFF0EEEE), borderRadius: BorderRadius.all(Radius.circular(5)) ), alignment: Alignment.center, child: Text('${_priceList[index]['time']} \n¥${_priceList[index]['price']}', style: TextStyle(fontSize: zsp(20),color: index==_selected?Colors.white:Color(0xFF8B8B8B)),textAlign: TextAlign.center,), ), if(_selected==index)Container( child: Text(timeTag('${_priceList[index]['time']}'),style: TextStyle(fontSize: zsp(16),color: Color(0xFF007EFF)),), height: hsp(30), padding: EdgeInsets.only(left: wsp(3),right: wsp(3)), decoration: BoxDecoration( color: Color(0xFFF7F7F7), borderRadius: BorderRadius.only(topLeft: Radius.circular(3),bottomRight: Radius.circular(5)) ), alignment: Alignment.center, ), ], ), ); }, separatorBuilder: (context,index){ return Container(width: hsp(15),color: Colors.white,); }, itemCount: _priceList.length, padding: EdgeInsets.all(0), scrollDirection: Axis.horizontal, ), ), GestureDetector( onTap: (){ showModalBottomSheet( context: context, builder: (context){ return YSDatePicker( choose: (value){ Map time = {'time':value.split(' ')[0],'price':_priceList[0]['price']}; int index; for(int i=0;i<_priceList.length;i++){ if(_priceList[i]['time']==time['time']){ index = i; } } if(index!=null){ _priceList.removeAt(index); } setState(() { _priceList.insert(0, time); }); }, ); } ); }, behavior: HitTestBehavior.opaque, child: Container( height: hsp(120), width: hsp(140), alignment: Alignment.center, child: Text('更多\n日期',style: TextStyle(fontSize: zsp(26),color: Color(0xFF007EFF)),), ), ) ], ), ), ], ), ), if(_dataArray[_index]['type']==2)Container( padding: EdgeInsets.all(hsp(30)), margin: EdgeInsets.only(top: hsp(10)), width: MediaQuery.of(context).size.width, color: Colors.white, child: Column( crossAxisAlignment: CrossAxisAlignment.start, children: [ Text('本次拼机截止时间:${_dataArray[_index]['deadlineTime']}',style: TextStyle(fontSize: zsp(26),color: Color(0xFF999999)),), Row( mainAxisAlignment: MainAxisAlignment.spaceBetween, children: [ Text('0吨',style: TextStyle(fontSize: zsp(22),color: Color(0xFF656565)),), Container( height: hsp(100), width: MediaQuery.of(context).size.width-hsp(200), child: Slider( value: double.parse('${_dataArray[_index]['nowWeight']}'), onChanged: (value){ }, activeColor: Color(0xFF0079FF), min: 0, max: 10, divisions: 4, ), ), Text('${_dataArray[_index]['totalWeight']}吨',style: TextStyle(fontSize: zsp(22),color: Color(0xFF656565)),), ], ), Container( width: MediaQuery.of(context).size.width, child: Text('目标${_dataArray[_index]['nowWeight']}吨',style: TextStyle(fontSize: zsp(24),color: Color(0xFF999999)),), alignment: Alignment.center, ), ], ), ), Container( padding: EdgeInsets.all(hsp(30)), margin: EdgeInsets.only(top: hsp(10)), color: Colors.white, child: Column( children: [ Container( padding: EdgeInsets.only(bottom: hsp(30)), child: Column( children: [ Row( children: [ Text('${_dataArray[_index]['setoutInfo']['display']}',style: TextStyle(fontSize: zsp(40),fontWeight: FontWeight.bold,color: Colors.black),), Image(height: hsp(60),width: hsp(60),image: AssetImage('lib/images/plane.png'),), Text('${_dataArray[_index]['arriveInfo']['display']}',style: TextStyle(fontSize: zsp(40),fontWeight: FontWeight.bold,color: Colors.black),), ], mainAxisAlignment: MainAxisAlignment.spaceBetween, ), Row( mainAxisAlignment: MainAxisAlignment.spaceBetween, children: [ Text('${_dataArray[_index]['setoutInfo']['airplanename']}',style: TextStyle(fontSize: zsp(24),color: Color(0xFF999999)),), Text('${_dataArray[_index]['hour']}',style: TextStyle(fontSize: zsp(20),color: Color(0xFF343434)),), Text('${_dataArray[_index]['arriveInfo']['airplanename']}',style: TextStyle(fontSize: zsp(24),color: Color(0xFF999999)),), ], ) ], ), ), Divider(height: 0.5,thickness: 0.5,color: Color(0xFFEAEAEA),), Container( height: hsp(70), child: Row( children: [ Text('${_dataArray[_index]['flightTime']}',style: TextStyle(fontSize: zsp(28),color: Color(0xFF333333)),), Text('机型: ${_dataArray[_index]['dtFlightInformation']['model']}',style: TextStyle(fontSize: zsp(28),color: Color(0xFF333333)),), ], mainAxisAlignment: MainAxisAlignment.spaceBetween, ), ), Divider(height: 0.5,thickness: 0.5,color: Color(0xFFEAEAEA),), Container( height: hsp(90), alignment: Alignment.centerLeft, child: Row( children: [ RichText( text: TextSpan( style: TextStyle(fontSize: zsp(24),color: Color(0xFF999999)), children: [ TextSpan( text: '类型: ' ), TextSpan( text: '${_dataArray[_index]['type']==1?'整机':'拼机'}', style: TextStyle(color: Color(0xFF333333)) ), TextSpan( text: '体积: ' ), TextSpan( text: '${_dataArray[_index]['totalVolume']}立方米', style: TextStyle(color: Color(0xFF333333)) ), TextSpan( text: '重量: ' ), TextSpan( text: '${_dataArray[_index]['totalWeight']}吨', style: TextStyle(color: Color(0xFF333333)) ) ] ), ), Text('¥${_dataArray[_index]['discountPrice']}',style: TextStyle(fontSize: zsp(40),color: Color(0xFFEA413A),fontWeight: FontWeight.bold),), ], mainAxisAlignment: MainAxisAlignment.spaceBetween, ), ), Divider(height: 0.5,thickness: 0.5,color: Color(0xFFEAEAEA),), Container( height: hsp(90), alignment: Alignment.centerLeft, child: RichText( text: TextSpan( style: TextStyle(fontSize: zsp(24),color: Color(0xFF999999)), children: [ TextSpan( text: '说明: ' ), TextSpan( text: '${_dataArray[_index]['explain']}',style: TextStyle(color: Color(0xFF333333)) ), ] ), ), ) ], ), ), ListView.separated( itemBuilder: (context,index){ return Container( height: hsp(90), color: Colors.white, width: MediaQuery.of(context).size.width, padding: EdgeInsets.only(left: hsp(30),right: hsp(30)), alignment: Alignment.centerLeft, child: index==0?Text( '货物信息',style: TextStyle(fontSize: zsp(30),color: Color(0xFF333333),fontWeight: FontWeight.bold), ):Row( mainAxisAlignment: MainAxisAlignment.spaceBetween, children: [ Text(index==1?'名称':index==2?'类型':index==3?'体积':'重量',style: TextStyle(fontSize: zsp(30),color: Color(0xFF999999)),), Container( height: hsp(90), width: MediaQuery.of(context).size.width*0.7, alignment: Alignment.centerRight, child: index==2?GestureDetector( onTap: (){ FocusScope.of(context).unfocus(); showModalBottomSheet( context: context, builder: (context){ return YSPicker( dataArray: _kinds, title: 'name', choose: (value){ setState(() { _kind = value; }); }, ); } ); }, child: Row( mainAxisSize: MainAxisSize.min, children: [ Text(_kind==null?'请选择类型':'${_kind['name']}',style: TextStyle(fontSize: zsp(30),color: Color(0xFF9A9A9A)),), Icon(Icons.keyboard_arrow_down,size: hsp(40),color: Color(0xFF9A9A9A)) ], ), ):CupertinoTextField( placeholder: index==1?'请输入名称':index==3?'请输入体积':'请输入重量', placeholderStyle: TextStyle(fontSize: zsp(30),color: Color(0xFF9A9A9A)), style: TextStyle(fontSize: zsp(30),color: Color(0xFF9A9A9A)), decoration: BoxDecoration(), textAlign: TextAlign.right, suffix: Text(index==1?'':index==3?'立方米':'吨',style: TextStyle(fontSize: zsp(30),color: Colors.black)), controller: index==1?_name:index==3?_volume:_weight, keyboardType: index==1?TextInputType.text:TextInputType.numberWithOptions(), ), ), ], ), ); }, separatorBuilder: (context,index){ return Divider(height: 0.5,thickness: 0.5,color: Color(0xFFEAEAEA),); }, itemCount: 5, padding: EdgeInsets.only(top: hsp(10)), shrinkWrap: true, physics: NeverScrollableScrollPhysics(), ), if(_dataArray[_index]['type']==2)Container( padding: EdgeInsets.all(hsp(30)), margin: EdgeInsets.only(top: hsp(10),bottom: hsp(30)), color: Colors.white, child: Row( mainAxisAlignment: MainAxisAlignment.spaceBetween, children: [ Container( width: (MediaQuery.of(context).size.width-hsp(60))*0.6, child: SingleChildScrollView( child: Stack( children: [ for(int i = 0;i<(_dataArray[_index]['dtAirplaneGoods']).length;i++)Container( height: hsp(70), width: hsp(70), margin: EdgeInsets.only(left: hsp(60)*i), decoration: BoxDecoration( color: Color(0xFFED5D57), borderRadius: BorderRadius.all(Radius.circular(50)), border: Border.all(color: Colors.white,width: 1), image: DecorationImage( image: NetworkImage('${_dataArray[_index]['dtAirplaneGoods'][i]['dtUsers']['avatar']}'), fit: BoxFit.fill, ) ), ) ], ), scrollDirection: Axis.horizontal, ), ), RichText( text: TextSpan( text: '已有', style: TextStyle(fontSize: zsp(30),color: Color(0xFF999999)), children: [ TextSpan( text: '4', style: TextStyle(color: Color(0xFF007DFF)) ), TextSpan( text: '个人在拼该机' ) ] ), ) ], ), ) ], ), ), ), ], ), ), Container( height: hsp(120), width: MediaQuery.of(context).size.width, color: Colors.white, padding: EdgeInsets.only(left: wsp(30),right: wsp(30)), child: Row( mainAxisAlignment: MainAxisAlignment.spaceBetween, children: [ RichText( text: TextSpan( text: '参考价(¥)', style: TextStyle(fontSize: zsp(22),color: Color(0xFF181818)), children: [ TextSpan( text: ' ${_dataArray[_index]['discountPrice']}', style: TextStyle(fontSize: zsp(40),color: Color(0xFFFF6600)), ), TextSpan( text: ' 元', ) ] ), ), // GestureDetector( // child: Row( // children: [ // Text('明细',style: TextStyle(fontSize: zsp(22),color: Color(0xFF181818)),), // Icon(Icons.keyboard_arrow_up,size: hsp(30),color: Color(0xFF007EFF),), // ], // ), // onTap: (){ // setState(() { // _isDetail = !_isDetail; // }); // }, // ), GestureDetector( onTap: (){ FocusScope.of(context).unfocus(); _postOrderData(); }, child: Container( height: hsp(70), padding: EdgeInsets.only(left: wsp(50),right: wsp(50)), decoration: BoxDecoration( color: Color(0xFF007EFF), borderRadius: BorderRadius.all(Radius.circular(50)) ), alignment: Alignment.center, child: Text('立即预约',style: TextStyle(fontSize: zsp(30),color: Colors.white,fontWeight: FontWeight.bold),), ), ) ], ), ) ], ), ), ), ) ], ), ), ); } Future _refreshData() async{ _page = 1; Map request = {}; request['category'] = _tabValues[_typeIndex]['type']; request['pageNo'] = _page; request['pageSize'] = 10; String url = '/app/applets/AirTour/list'; if(_searchStr.text.isNotEmpty){ request['name'] = _searchStr.text; url = '/app/applets/AirTour/search'; } Map dict = await ysRequestHttp(context,type: requestType.get,api: url,parameter: request,isLoading: false,isToken: false); if(dict!=null){ setState(() { _dataArray = dict['data']['resultList']; }); } } Future _loadMoreData() async{ _page++; Map request = {}; request['category'] = _tabValues[_typeIndex]['type']; request['pageNo'] = _page; request['pageSize'] = 10; String url = '/app/applets/AirTour/list'; if(_searchStr.text.isNotEmpty){ request['name'] = _searchStr.text; url = '/app/applets/AirTour/search'; } Map dict = await ysRequestHttp(context,type: requestType.get,api: url,parameter: request,isLoading: false,isToken: false); if(dict!=null){ setState(() { _dataArray.addAll(dict['data']['resultList']); }); } } _getPriceData() async{ Map dict = await ysRequestHttp(context,type: requestType.get,api: '/app/applets/airplaneorder/getDateAndTime', parameter: {'time':_timeStr,'type':3,'id':_dataArray[_index]['id']},isLoading: true,isToken: true); if(dict!=null){ _isOrder = true; _priceList = dict['data']; _getTypeData(); } } _getTypeData() async{ Map dict = await ysRequestHttp(context,type: requestType.get,api: '/app/applets/airplanegoods/type/get',parameter: {},isLoading: true,isToken: false); if(dict!=null){ setState(() { _kinds = dict['data']; _kind = _kinds[0]; }); } } _postOrderData() async{ if(_name.text.isEmpty){ ysFlutterToast(context, '货物名称不能为空'); return; } if(_volume.text.isEmpty){ ysFlutterToast(context, '货物体积不能为空'); return; } if(_weight.text.isEmpty){ ysFlutterToast(context, '货物重量不能为空'); return; } Map request = {}; request['flightTime'] = '2020-10-07 17:59:27'; request['type'] = 3; request['airplaneid'] = _dataArray[_index]['id']; request['airportidSetout'] = _dataArray[_index]['airportidSetout']; request['airportidArrive'] = _dataArray[_index]['airportidArrive']; request['airportidArrive'] = _dataArray[_index]['airportidArrive']; Map value = {}; value['goodsName'] = _name.text; value['goodsNatureId'] = _kind['id']; value['goodsVolume'] = _volume.text; value['goodsWeight'] = _weight.text; value['contactPerson'] = '111'; value['phone'] = '15829646496'; value['goodsPlace'] = '西安小寨A座国际商务酒店'; value['goodsLocation'] = '108.985463,34.30501'; value['goodsUnloadingPlace'] = '上海酒店'; value['goodsUnloadingLocation'] = '108.985463,34.30501'; request['dtAirplaneGoods'] = value; request['sourceType'] = _dataArray[_index]['type']; Map dict = await ysRequestHttp(context,type: requestType.post,api: '/app/applets/airplaneorder/createOrder',parameter: request,isLoading: true,isToken: true); if(dict!=null){ Navigator.of(context).push( CupertinoPageRoute( builder: (context){ return YSPay(orderDict: dict['data'],type: payType.goods,); } ) ); } } }