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

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;
}