vip.dart 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354
  1. import 'package:flutter/material.dart';
  2. import 'package:fake_push/fake_push.dart';
  3. import 'package:liftmanager/net/api_service.dart';
  4. import 'package:liftmanager/utils/toast.dart';
  5. import 'package:liftmanager/widgets/app_bar.dart';
  6. import 'package:provider/provider.dart';
  7. import 'package:liftmanager/internal/account/provider/user_provider.dart';
  8. import 'package:flutter_screenutil/flutter_screenutil.dart';
  9. import 'package:flutter_swiper/flutter_swiper.dart';
  10. import 'package:liftmanager/widgets/load_image.dart';
  11. import 'package:liftmanager/widgets/bbs_content.dart';
  12. import 'package:liftmanager/routers/fluro_navigator.dart';
  13. import 'package:liftmanager/common/user_db.dart';
  14. import 'package:liftmanager/internal/bbs/provide/websocket.dart';
  15. import 'package:liftmanager/common/common.dart';
  16. import 'package:liftmanager/internal/account/account_router.dart';
  17. import 'package:liftmanager/internal/wode/wode_router.dart';
  18. import 'package:flustars/flustars.dart' as flustars;
  19. import 'package:liftmanager/internal/wode/model/privilege_model.dart';
  20. import 'package:liftmanager/utils/theme_utils.dart';
  21. class Vip extends StatefulWidget {
  22. Vip(this.id);
  23. final String id;
  24. @override
  25. State<StatefulWidget> createState() {
  26. return VipState();
  27. }
  28. }
  29. class VipState extends State<Vip> with AutomaticKeepAliveClientMixin {
  30. UserProvider provider = UserProvider();
  31. Push _push = Push();
  32. int currentIndex = -1;
  33. List<PrivilegeModel> vipList = [];
  34. void getMemberAllMenu() {
  35. NewApiService().getMemberAllMenu(onSuccess: (res) {
  36. vipList = res;
  37. currentIndex = res.length > 0 ? 0 : -1;
  38. setState(() {});
  39. }, onError: (code, msg) {
  40. vipList = [];
  41. toasts(msg);
  42. });
  43. }
  44. bool vip = false;
  45. Future isVipOrExpert() async{
  46. await NewApiService().getIsVipOrExpert(onSuccess: (res) {
  47. if(res != null){
  48. vip = true;
  49. }
  50. }, onError: (code, msg) {
  51. toasts(msg);
  52. });
  53. }
  54. Future becomeLowerMember() async{
  55. await NewApiService().getUserRebates(widget.id,
  56. onSuccess: (res) {
  57. toasts("您已成为${res!=null?res.toString():''}的下级用户");
  58. }, onError: (code, msg) {
  59. toasts(msg);
  60. });
  61. }
  62. void updateVip(userLevel) {
  63. NewApiService().updateVip(userLevel, onSuccess: (res) {
  64. toasts("充值成功,请重新登录");
  65. setState(() {});
  66. User().clearUser();
  67. Provider.of<WebSocketProvide>(context, listen: false).closeWebSocket();
  68. // removeSocket();
  69. _push.unbindAccount(account: flustars.SpUtil.getString(Constant.phone));
  70. NavigatorUtils.push(context, AccountRouter.loginPage, clearStack: true);
  71. }, onError: (code, msg) {
  72. toasts(msg);
  73. });
  74. }
  75. @override
  76. void initState() {
  77. getMemberAllMenu();
  78. super.initState();
  79. print(widget.id);
  80. print(66666);
  81. if(widget.id != null && widget.id != ""){
  82. print("触发绑定");
  83. becomeLowerMember();
  84. }
  85. }
  86. @override
  87. void dispose() {
  88. super.dispose();
  89. }
  90. @override
  91. Widget build(BuildContext context) {
  92. double width = MediaQuery.of(context).size.width;
  93. double height = MediaQuery.of(context).size.height;
  94. return ChangeNotifierProvider<UserProvider>(
  95. create: (_) => provider,
  96. child: Container(
  97. child: Scaffold(
  98. resizeToAvoidBottomPadding: false,
  99. appBar: MyAppBar(
  100. centerTitle: "会员中心",
  101. ),
  102. body: Consumer<UserProvider>(
  103. builder: (_, provider, __) {
  104. return ListView(
  105. padding: EdgeInsets.all(0.0),
  106. children: <Widget>[
  107. Container(
  108. padding:
  109. EdgeInsets.only(left: 20.0, right: 20.0, top: 10.0),
  110. // height: ScreenUtil().setWidth(345),
  111. child: Column(
  112. children: <Widget>[
  113. vipList.length > 0
  114. ? SwipeWidget(
  115. banners: vipList,
  116. onClickItem: (index, item) {
  117. // showAlert(
  118. // context,
  119. // "提示",
  120. // "您确定需要充值升级为Vip吗?",
  121. // "确认",
  122. // () {
  123. // // updateVip(item.id);
  124. // // NavigatorUtils.goBack(context);
  125. // },
  126. // txt2: "取消",
  127. // onPre2: () {
  128. // NavigatorUtils.goBack(context);
  129. // },
  130. // );
  131. // print(333);
  132. // print(provider);
  133. NavigatorUtils.push(context,
  134. "${WodeRouter.vipService}?id=${item.id.toString()}");
  135. },
  136. onChangItem: (index, item) {
  137. currentIndex = index;
  138. setState(() {});
  139. },
  140. )
  141. : Container()
  142. ],
  143. ),
  144. ),
  145. LableTitle(
  146. title: "会员特权",
  147. isMore: true,
  148. userTap: () {
  149. if (currentIndex != -1) {
  150. NavigatorUtils.push(context,
  151. "${WodeRouter.privilege}?id=${vipList[currentIndex].id.toString()}");
  152. }
  153. },
  154. ),
  155. Container(
  156. color: ThemeUtils.getTabsBg(context),
  157. height: ScreenUtil().setWidth(150),
  158. padding: EdgeInsets.only(
  159. top: ScreenUtil().setWidth(5),
  160. left: ScreenUtil().setWidth(10),
  161. right: ScreenUtil().setWidth(10),
  162. ),
  163. child: Privilege(
  164. initList: currentIndex != -1
  165. ? vipList[currentIndex].menuList
  166. : []),
  167. ),
  168. LableTitle(
  169. title: "邀请好友",
  170. isMore: false,
  171. userTap: () {},
  172. ),
  173. GestureDetector(
  174. onTap: () async{
  175. await isVipOrExpert();
  176. if (vip) {
  177. NavigatorUtils.push(context, "${WodeRouter.qrshare}");
  178. vip = false;
  179. } else {
  180. print(999);
  181. toasts("请开通会员或成为专家");
  182. }
  183. },
  184. child: Container(
  185. color: ThemeUtils.getTabsBg(context),
  186. height: ScreenUtil().setWidth(110),
  187. padding: EdgeInsets.only(
  188. top: ScreenUtil().setWidth(10),
  189. left: ScreenUtil().setWidth(10),
  190. right: ScreenUtil().setWidth(10),
  191. ),
  192. child: LoadAssetImage(
  193. "wode/invite_friends",
  194. width: ScreenUtil().setWidth(724),
  195. height: ScreenUtil().setWidth(183),
  196. ),
  197. ),
  198. )
  199. ],
  200. );
  201. },
  202. ),
  203. ),
  204. ),
  205. );
  206. }
  207. @override
  208. bool get wantKeepAlive => true;
  209. }
  210. class SwipeWidget extends StatelessWidget {
  211. const SwipeWidget({Key key, this.banners, this.onClickItem, this.onChangItem})
  212. : super(key: key);
  213. final List<dynamic> banners;
  214. final Function onClickItem;
  215. final Function onChangItem;
  216. @override
  217. Widget build(BuildContext context) {
  218. double width = MediaQuery.of(context).size.width;
  219. double height = ScreenUtil().setWidth(180);
  220. return Container(
  221. width: width,
  222. height: height,
  223. child: Swiper(
  224. itemBuilder: (BuildContext context, index) {
  225. return Container(
  226. width: width,
  227. height: height,
  228. child: LoadNetworkImage(
  229. banners[index].image,
  230. width: width,
  231. height: height,
  232. // fit: BoxFit.none
  233. ),
  234. );
  235. },
  236. pagination: SwiperPagination(
  237. builder: DotSwiperPaginationBuilder(
  238. color: Colors.grey,
  239. activeColor: Colors.white,
  240. size: 6,
  241. activeSize: 6,
  242. ),
  243. ),
  244. itemCount: banners.length,
  245. scrollDirection: Axis.horizontal,
  246. autoplay: false,
  247. onTap: (index) {
  248. onClickItem(index, banners[index]);
  249. },
  250. onIndexChanged: (index) {
  251. onChangItem(index, banners[index]);
  252. },
  253. ),
  254. );
  255. }
  256. }
  257. class Privilege extends StatelessWidget {
  258. const Privilege({Key key, this.initList}) : super(key: key);
  259. final List<dynamic> initList;
  260. List<Widget> listWidget(context) => initList.asMap().keys.map((i) {
  261. double width = MediaQuery.of(context).size.width;
  262. return GestureDetector(
  263. child: Container(
  264. margin: EdgeInsets.only(right: 10),
  265. padding: EdgeInsets.only(top: 10, bottom: 10),
  266. child: Row(
  267. children: <Widget>[
  268. SizedBox(width: ScreenUtil().setWidth(i == 0 ? 10 : 10)),
  269. Container(
  270. width: ScreenUtil().setWidth(120),
  271. padding: EdgeInsets.only(top: 20, bottom: 20),
  272. decoration: BoxDecoration(
  273. color: ThemeUtils.getTabsBg(context),
  274. borderRadius: BorderRadius.circular(5),
  275. boxShadow: [
  276. BoxShadow(
  277. offset: Offset(0, 0), //x,y轴
  278. color: Colors.grey[300], //投影颜色
  279. blurRadius: 5, //投影距离
  280. )
  281. ],
  282. ),
  283. child: Column(
  284. crossAxisAlignment: CrossAxisAlignment.center,
  285. children: <Widget>[
  286. // Icon(
  287. // IconData(initList[i]['icon'], fontFamily: "myfont"),
  288. // size: 24.0,
  289. // color: Color.fromRGBO(51, 51, 51, 1),
  290. // ),
  291. Container(
  292. margin: EdgeInsets.only(bottom: 8),
  293. child: LoadNetworkImage(
  294. initList[i].image,
  295. width: 30,
  296. height: 30,
  297. ),
  298. ),
  299. Text(
  300. initList[i].name ?? '',
  301. textAlign: TextAlign.start,
  302. style: TextStyle(
  303. fontSize: ScreenUtil().setSp(14),
  304. ),
  305. ),
  306. Text(
  307. initList[i].descr ?? '',
  308. textAlign: TextAlign.start,
  309. style: TextStyle(
  310. fontSize: ScreenUtil().setSp(14),
  311. color: Color(0xff999999),
  312. ),
  313. overflow: TextOverflow.ellipsis,
  314. ),
  315. ],
  316. ),
  317. ),
  318. ],
  319. ),
  320. ),
  321. onTap: () {
  322. // print(i);
  323. },
  324. );
  325. }).toList();
  326. @override
  327. Widget build(BuildContext context) {
  328. return ListView(
  329. scrollDirection: Axis.horizontal,
  330. padding: EdgeInsets.all(0),
  331. children: listWidget(context),
  332. );
  333. }
  334. }