You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
492 lines
15 KiB
492 lines
15 KiB
import 'dart:io'; |
|
import 'package:dio/dio.dart'; |
|
import 'package:flutter/cupertino.dart'; |
|
import 'package:flutter/material.dart'; |
|
import 'package:flutter_smart_dialog/flutter_smart_dialog.dart'; |
|
import 'package:flutter_svg/flutter_svg.dart'; |
|
import 'package:huixiang/generated/l10n.dart'; |
|
import 'package:huixiang/data/address.dart'; |
|
import 'package:huixiang/retrofit/retrofit_api.dart'; |
|
import 'package:huixiang/utils/font_weight.dart'; |
|
import 'package:huixiang/utils/shared_preference.dart'; |
|
import 'package:huixiang/view_widget/my_appbar.dart'; |
|
import 'package:flutter_screenutil/flutter_screenutil.dart'; |
|
import 'package:image_pickers/image_pickers.dart'; |
|
import 'package:shared_preferences/shared_preferences.dart'; |
|
import '../utils/upload_async.dart'; |
|
|
|
class ReleaseDynamic extends StatefulWidget { |
|
@override |
|
State<StatefulWidget> createState() { |
|
return _ReleaseDynamic(); |
|
} |
|
} |
|
|
|
class _ReleaseDynamic extends State<ReleaseDynamic> { |
|
int selectCount = 9; |
|
List<Medias> mediaPaths = []; |
|
bool isRelease = false; |
|
int dynamicType = 0; |
|
TextEditingController textController = TextEditingController(); |
|
TextEditingController addressController = TextEditingController(); |
|
|
|
// TextEditingController houseNumberController = TextEditingController(); |
|
ApiService? apiService; |
|
Map? addressMap; |
|
Address? preAddress; |
|
|
|
@override |
|
void initState() { |
|
super.initState(); |
|
|
|
apiService = ApiService( |
|
Dio(), |
|
context: context, |
|
token: SharedInstance.instance.token, |
|
showLoading: false, |
|
); |
|
} |
|
|
|
@override |
|
Widget build(BuildContext context) { |
|
return Scaffold( |
|
appBar: MyAppBar( |
|
title: S.of(context).xiedongtai, |
|
titleColor: Colors.black, |
|
leadingColor: Colors.black, |
|
background: Colors.white, |
|
action: Container( |
|
alignment: Alignment.center, |
|
child: Container( |
|
width: 46.w, |
|
height: 24.h, |
|
alignment: Alignment.center, |
|
decoration: BoxDecoration( |
|
color: isRelease ? Color(0xFF32A060) : Color(0xFFD8D8D8), |
|
borderRadius: BorderRadius.circular(12), |
|
), |
|
child: Text( |
|
S.of(context).fabu, |
|
style: TextStyle( |
|
color: isRelease ? Colors.white : Color(0xFFA0A0A0), |
|
fontSize: 14.sp, |
|
fontWeight: MyFontWeight.semi_bold, |
|
), |
|
), |
|
), |
|
), |
|
onTap: () { |
|
if (!isRelease) { |
|
SmartDialog.showToast("请输入您此刻的想法!~"); |
|
return; |
|
} |
|
releaseDynamic(); |
|
}, |
|
), |
|
body: GestureDetector( |
|
behavior: HitTestBehavior.translucent, |
|
onTap: () { |
|
FocusScope.of(context).requestFocus(FocusNode()); |
|
}, |
|
child: Container( |
|
child: Column( |
|
children: [ |
|
buildEdit(), |
|
Container( |
|
width: double.infinity, |
|
margin: EdgeInsets.all(16), |
|
padding: EdgeInsets.only(left: 16, right: 16), |
|
child: Row( |
|
crossAxisAlignment: CrossAxisAlignment.start, |
|
mainAxisAlignment: MainAxisAlignment.start, |
|
children: [ |
|
Text( |
|
"!", |
|
overflow: TextOverflow.ellipsis, |
|
style: TextStyle( |
|
fontWeight: MyFontWeight.semi_bold, |
|
fontSize: 14.sp, |
|
color: Colors.red, |
|
), |
|
), |
|
SizedBox( |
|
width: 10, |
|
), |
|
Expanded( |
|
child: Text( |
|
S.of(context).dongtaitishi, |
|
maxLines: 2, |
|
overflow: TextOverflow.ellipsis, |
|
style: TextStyle( |
|
fontWeight: MyFontWeight.medium, |
|
fontSize: 12.sp, |
|
color: Color(0xFFB3B2B2), |
|
), |
|
), |
|
) |
|
], |
|
), |
|
), |
|
Expanded( |
|
child: GridView.builder( |
|
gridDelegate: SliverGridDelegateWithFixedCrossAxisCount( |
|
crossAxisCount: 3, |
|
crossAxisSpacing: 12.w, |
|
mainAxisSpacing: 12.w, |
|
childAspectRatio: 1, |
|
), |
|
padding: EdgeInsets.all(16), |
|
shrinkWrap: true, |
|
physics: NeverScrollableScrollPhysics(), |
|
itemBuilder: (context, position) { |
|
if (mediaPaths.length > position) { |
|
return imageItem(mediaPaths[position]); |
|
} else { |
|
return addImageItem(); |
|
} |
|
}, |
|
itemCount: (mediaPaths.length == 0) |
|
? 1 |
|
: ((dynamicType == 2) |
|
? 1 |
|
: mediaPaths.length >= 9 |
|
? 9 |
|
: (mediaPaths.length + 1)), |
|
), |
|
), |
|
], |
|
), |
|
)), |
|
); |
|
} |
|
|
|
releaseDynamic() async { |
|
String dynamicText = textController.text; |
|
if (dynamicText == "") { |
|
SmartDialog.showToast("请输入您此刻的想法!"); |
|
return; |
|
} |
|
|
|
UploadAsync.upload(dynamicType, mediaPaths, addressController.text, dynamicText); |
|
Navigator.of(context).pop(); |
|
} |
|
|
|
Widget imageItem(Medias media) { |
|
return InkWell( |
|
onTap: () { |
|
showDeletePicker(media); |
|
}, |
|
child: Container( |
|
decoration: BoxDecoration( |
|
borderRadius: BorderRadius.circular(4), |
|
), |
|
alignment: Alignment.center, |
|
child: ClipRRect( |
|
borderRadius: BorderRadius.circular(4), |
|
child: Image.file( |
|
File(media.galleryMode == GalleryMode.video |
|
? "${media.thumbPath}" |
|
: "${media.path}"), |
|
fit: BoxFit.cover, |
|
width: double.infinity, |
|
height: double.infinity, |
|
), |
|
), |
|
), |
|
); |
|
} |
|
|
|
///显示图片选择方式 |
|
showImagePicker() { |
|
FocusScope.of(context).requestFocus(FocusNode()); |
|
|
|
if (dynamicType == 1) { |
|
getImageOrVideo(GalleryMode.image); |
|
return; |
|
} |
|
showCupertinoModalPopup( |
|
context: context, |
|
builder: (context) { |
|
return CupertinoActionSheet( |
|
title: Text("选择媒体文件"), |
|
actions: [ |
|
CupertinoActionSheetAction( |
|
child: Text("照片"), |
|
onPressed: () { |
|
getImageOrVideo(GalleryMode.image); |
|
Navigator.of(context).pop(); |
|
}, |
|
isDefaultAction: true, |
|
isDestructiveAction: false, |
|
), |
|
CupertinoActionSheetAction( |
|
child: Text("视频"), |
|
onPressed: () { |
|
getImageOrVideo(GalleryMode.video); |
|
Navigator.of(context).pop(); |
|
}, |
|
isDefaultAction: true, |
|
isDestructiveAction: false, |
|
), |
|
], |
|
cancelButton: CupertinoActionSheetAction( |
|
onPressed: () { |
|
Navigator.of(context).pop(); |
|
}, |
|
child: Text(S.of(context).quxiao), |
|
isDestructiveAction: true, |
|
), |
|
); |
|
}, |
|
); |
|
} |
|
|
|
///显示图片选择方式 |
|
showDeletePicker(Medias media) { |
|
showCupertinoModalPopup( |
|
context: context, |
|
builder: (context) { |
|
return CupertinoActionSheet( |
|
title: Text("动态"), |
|
actions: [ |
|
CupertinoActionSheetAction( |
|
child: Text("删除"), |
|
onPressed: () { |
|
mediaPaths.remove(media); |
|
if (mediaPaths.length == 0) { |
|
dynamicType = 0; |
|
} |
|
selectCount = 9 - mediaPaths.length; |
|
Navigator.of(context).pop(); |
|
setState(() {}); |
|
}, |
|
isDefaultAction: true, |
|
isDestructiveAction: false, |
|
), |
|
], |
|
cancelButton: CupertinoActionSheetAction( |
|
onPressed: () { |
|
Navigator.of(context).pop(); |
|
}, |
|
child: Text(S.of(context).quxiao), |
|
isDestructiveAction: true, |
|
), |
|
); |
|
}, |
|
); |
|
} |
|
|
|
Widget addImageItem() { |
|
return InkWell( |
|
onTap: () { |
|
showImagePicker(); |
|
}, |
|
child: Container( |
|
decoration: BoxDecoration( |
|
color: Color(0xFFF2F2F2), |
|
borderRadius: BorderRadius.circular(4), |
|
), |
|
alignment: Alignment.center, |
|
child: Column( |
|
mainAxisAlignment: MainAxisAlignment.center, |
|
crossAxisAlignment: CrossAxisAlignment.center, |
|
children: [ |
|
SvgPicture.asset( |
|
"assets/svg/zhaopianshipin.svg", |
|
width: 48, |
|
height: 48, |
|
fit: BoxFit.contain, |
|
), |
|
Text( |
|
"照片/视频", |
|
style: TextStyle( |
|
fontWeight: MyFontWeight.semi_bold, |
|
fontSize: 15.sp, |
|
color: Color(0xFFCDCCCC), |
|
), |
|
), |
|
], |
|
), |
|
), |
|
); |
|
} |
|
|
|
Future getImageOrVideo(GalleryMode galleryMode) async { |
|
if (selectCount == 0) return; |
|
List<Media> medias = await ImagePickers.pickerPaths( |
|
galleryMode: galleryMode, |
|
selectCount: (galleryMode == GalleryMode.video) ? 1 : selectCount, |
|
showGif: true, |
|
showCamera: false, |
|
compressSize: 500, |
|
uiConfig: UIConfig( |
|
uiThemeColor: Color(0xFFFFFFFF), |
|
), |
|
cropConfig: CropConfig( |
|
enableCrop: false, |
|
width: 200, |
|
height: 200, |
|
), |
|
); |
|
|
|
mediaPaths.addAll(medias.map((e) => Medias(e)).toList()); |
|
selectCount = 9 - mediaPaths.length; |
|
|
|
if (mediaPaths.length > 0) { |
|
if (galleryMode == GalleryMode.image) { |
|
dynamicType = 1; |
|
} else { |
|
dynamicType = 2; |
|
} |
|
} |
|
|
|
setState(() {}); |
|
} |
|
|
|
toMap() async { |
|
Navigator.of(context).pushNamed('/router/address_map_page').then( |
|
(value) => { |
|
setState(() { |
|
if (value != null) { |
|
addressMap = value as Map; |
|
addressController.text = "${(value as Map)['cityInfo']}"; |
|
preAddress?.cityInfo = addressMap?['cityInfo']; |
|
// houseNumberController.text = "${(value as Map)['address']}"; |
|
} |
|
}) |
|
}, |
|
); |
|
} |
|
|
|
///动态输入框 |
|
Widget buildEdit() { |
|
return Container( |
|
// height: 174.h, |
|
margin: EdgeInsets.symmetric(horizontal: 16.w), |
|
decoration: BoxDecoration( |
|
border: Border( |
|
bottom: BorderSide( |
|
width: 1.w, |
|
color: Color(0xFFD8D8D8), |
|
style: BorderStyle.solid, |
|
), |
|
), |
|
), |
|
child: Column( |
|
children: [ |
|
TextField( |
|
controller: textController, |
|
maxLines: 5, |
|
style: TextStyle( |
|
fontSize: 14.sp, |
|
height: 1.3, |
|
letterSpacing:1, |
|
fontWeight: MyFontWeight.medium, |
|
color: Color(0xFF4C4C4C), |
|
), |
|
onChanged: (text) { |
|
bool release = text != ""; |
|
if (release != isRelease) { |
|
isRelease = release; |
|
setState(() {}); |
|
} |
|
}, |
|
decoration: InputDecoration( |
|
contentPadding: EdgeInsets.symmetric( |
|
vertical: 18.h, |
|
), |
|
errorBorder: InputBorder.none, |
|
focusedBorder: InputBorder.none, |
|
enabledBorder: InputBorder.none, |
|
hintText: "此时此刻的想法~", |
|
hintStyle: TextStyle( |
|
fontSize: 14.sp, |
|
color: Color(0xFFA29E9E), |
|
), |
|
), |
|
), |
|
Container( |
|
width: double.infinity, |
|
child: Row( |
|
mainAxisAlignment: MainAxisAlignment.start, |
|
crossAxisAlignment: CrossAxisAlignment.center, |
|
children: [ |
|
Expanded( |
|
child: GestureDetector( |
|
onTap: () { |
|
toMap(); |
|
}, |
|
child: Row( |
|
crossAxisAlignment: CrossAxisAlignment.start, |
|
mainAxisAlignment: MainAxisAlignment.start, |
|
children: [ |
|
Icon( |
|
Icons.place, |
|
size: 16, |
|
color: Color(0xFFB3B2B2), |
|
), |
|
SizedBox( |
|
width: 2, |
|
), |
|
Text( |
|
addressController.text == "" |
|
? "你在哪里呢?" |
|
: addressController.text, |
|
overflow: TextOverflow.ellipsis, |
|
style: TextStyle( |
|
fontSize: 11.sp, |
|
fontWeight: MyFontWeight.medium, |
|
color: Color(0xFFB3B2B2), |
|
), |
|
), |
|
], |
|
), |
|
), |
|
), |
|
addressController.text == "" |
|
? Container() |
|
: GestureDetector( |
|
behavior: HitTestBehavior.opaque, |
|
onTap: () { |
|
setState(() { |
|
addressController.text = ""; |
|
}); |
|
}, |
|
child: Container( |
|
// color: Colors.red, |
|
height: 21.h, |
|
padding: EdgeInsets.only(left: 10, right: 10), |
|
alignment: Alignment.centerRight, |
|
child: Icon( |
|
Icons.close, |
|
color: Colors.black, |
|
size: 16, |
|
), |
|
), |
|
), |
|
], |
|
), |
|
), |
|
SizedBox( |
|
height: 5, |
|
) |
|
], |
|
), |
|
); |
|
} |
|
} |
|
|
|
class Medias { |
|
// Media media; |
|
|
|
Medias(Media media) { |
|
this.thumbPath = media.thumbPath; |
|
this.path = media.path; |
|
this.galleryMode = media.galleryMode; |
|
} |
|
|
|
String? thumbPath; |
|
String? path; |
|
GalleryMode? galleryMode; |
|
String? remotePath; |
|
}
|
|
|