wip basics for bloc based state management
This commit is contained in:
44
lib/view/pages/more/test.dart
Normal file
44
lib/view/pages/more/test.dart
Normal file
@ -0,0 +1,44 @@
|
||||
import 'package:flutter/material.dart';
|
||||
import '../../../state/app/application/marianumMessage/marianum_message_controller.dart';
|
||||
import '../../../state/app/application/marianumMessage/marianum_message_state.dart';
|
||||
import '../../../state/infrastructure/loadable_state.dart';
|
||||
import '../../../state/infrastructure/state_extensions.dart';
|
||||
import '../../../state/widgets/controller_consumer.dart';
|
||||
import '../../../state/widgets/loadable_controller_consumer.dart';
|
||||
import '../../../state/widgets/sub_selected_controller_consumer.dart';
|
||||
import '../../../state/widgets/controller_provider.dart';
|
||||
|
||||
class Test extends StatelessWidget {
|
||||
const Test({super.key});
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) => ControllerProvider<MarianumMessageController>(
|
||||
create: (context) => MarianumMessageController(),
|
||||
child: (context) => Scaffold(
|
||||
appBar: AppBar(title: const Text("TEST")),
|
||||
body: LoadableControllerConsumer<MarianumMessageController, LoadableState<MarianumMessageState>>(
|
||||
child: (context, data) => Column(
|
||||
children: [
|
||||
TextButton(
|
||||
onPressed: () => context.readController<MarianumMessageController>().loading(),
|
||||
child: Text(data.loadingState.toString())
|
||||
),
|
||||
TextButton(
|
||||
onPressed: () => context.readController<MarianumMessageController>().backgroundLoading(),
|
||||
child: Text(context.watchController<MarianumMessageController>().state.loadingState.toString())
|
||||
),
|
||||
TextButton(
|
||||
onPressed: () => context.readController<MarianumMessageController>().done(),
|
||||
child: Text(context.watchController<MarianumMessageController>().state.loadingState.toString())
|
||||
),
|
||||
ControllerConsumer<MarianumMessageController, LoadableState<MarianumMessageState>>(child: (context, state) => Text(state.data!.test.toString())),
|
||||
SubSelectedControllerConsumer<MarianumMessageController, LoadableState<MarianumMessageState>, LoadingState>(
|
||||
subselect: (state) => state.loadingState,
|
||||
child: (context, state) => Text(state.toString()),
|
||||
)
|
||||
],
|
||||
),
|
||||
),
|
||||
),
|
||||
);
|
||||
}
|
@ -16,6 +16,7 @@ import 'more/holidays/holidays.dart';
|
||||
import 'more/message/message.dart';
|
||||
import 'more/roomplan/roomplan.dart';
|
||||
import 'more/share/selectShareTypeDialog.dart';
|
||||
import 'more/test.dart';
|
||||
|
||||
class Overhang extends StatelessWidget {
|
||||
const Overhang({super.key});
|
||||
@ -74,6 +75,10 @@ class Overhang extends StatelessWidget {
|
||||
trailing: const Icon(Icons.arrow_right),
|
||||
onTap: () => pushScreen(context, withNavBar: false, screen: const FeedbackDialog()),
|
||||
),
|
||||
ListTile(
|
||||
leading: const Icon(Icons.science_outlined),
|
||||
onTap: () => pushScreen(context, withNavBar: false, screen: const Test()),
|
||||
)
|
||||
],
|
||||
),
|
||||
);
|
||||
|
@ -52,7 +52,7 @@ class ChatMessage {
|
||||
fadeInDuration: Duration.zero,
|
||||
fadeOutDuration: Duration.zero,
|
||||
errorListener: (value) {},
|
||||
imageUrl: 'https://${AccountData().buildHttpAuthString()}@${EndpointData().nextcloud().full()}/index.php/core/preview?fileId=${file!.id}&x=100&y=-1&a=1',
|
||||
imageUrl: 'https://${AccountData().buildHttpAuthString()}@${EndpointData().nextcloud().full()}/index.php/core/preview?fileId=${file!.id}&x=100&sub_selected_controller_consumer.dart=-1&a=1',
|
||||
);
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user