| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798 |
- import 'package:electronic_assistant/base/base_controller.dart';
- import 'package:electronic_assistant/data/bean/talks.dart';
- import 'package:electronic_assistant/data/repositories/agenda_repository.dart';
- import 'package:electronic_assistant/data/repositories/talk_repository.dart';
- import 'package:electronic_assistant/module/main/controller.dart';
- import 'package:electronic_assistant/resource/string.gen.dart';
- import 'package:electronic_assistant/utils/event_bus.dart';
- import 'package:electronic_assistant/widget/pull_to_refresh.dart';
- import 'package:flutter/cupertino.dart';
- import 'package:get/get.dart';
- import '../../data/bean/agenda.dart';
- import '../../data/repositories/account_repository.dart';
- import '../../utils/error_handler.dart';
- import '../../utils/toast_util.dart';
- class HomePageController extends BaseController {
- get isLogin => accountRepository.isLogin.value;
- get loginTxt => accountRepository.isLogin.value
- ? accountRepository.getUserSubName(accountRepository.phone)
- : StringName.homeGoLogin.tr;
- final refreshController = PullToRefreshController();
- BuildContext? todoTargetContext;
- RxList<TalkBean> get talkList => talkRepository.talkList;
- RxList<Agenda> get agendaList => agendaRepository.agendaList;
- @override
- void onReady() {
- super.onReady();
- refreshController.requestRefresh();
- eventBus.on(EventUserLogin, (arg) {
- requestHomeData();
- });
- eventBus.on(EventUserLogout, (arg) {
- requestHomeData();
- });
- }
- @override
- void dispose() {
- // TODO: implement dispose
- super.dispose();
- eventBus.off(EventUserLogin);
- eventBus.off(EventUserLogout);
- }
- void requestHomeData() async {
- try {
- await Future.wait([
- talkRepository.requestHomeTalkData(),
- agendaRepository.requestHomeAgendaData(),
- ]);
- } catch (e) {
- // Handle errors if necessary
- } finally {
- refreshController.refreshCompleted();
- }
- }
- void requestName(String? newName, TalkBean bean) {
- talkRepository.talkRename(bean.id, newName).then((data) {
- bean.title.value = newName;
- ToastUtil.showToast(StringName.talkRenameSuccess.tr);
- }).catchError((error) {
- ErrorHandler.toastError(error, message: StringName.talkRenameFail.tr);
- });
- }
- void goTalkRecordPage() {
- Get.find<MainController>().updateIndexByPageName(StringName.mainTabFile);
- }
- void showLoginDrawer() {
- Get.find<MainController>().openDrawer();
- }
- void requestDelete(TalkBean item) {
- talkRepository.talkDelete(item.id).then((data) {
- requestHomeData();
- }).catchError((error) {
- ErrorHandler.toastError(error, message: StringName.talkDeleteFail.tr);
- });
- }
- void agendaComplete(Agenda item) {
- agendaRepository.agendaFinish(item.id, true).then((data) {
- agendaRepository.removeItem(item);
- }).catchError((error) {
- ErrorHandler.toastError(error);
- });
- }
- }
|