vip.dart 12 KB

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