veilidchat/lib/chat/models/chat_component_state.dart

42 lines
1.5 KiB
Dart
Raw Normal View History

2024-06-06 00:19:07 -04:00
import 'package:async_tools/async_tools.dart';
import 'package:fast_immutable_collections/fast_immutable_collections.dart';
import 'package:flutter/material.dart';
import 'package:flutter_chat_types/flutter_chat_types.dart' show Message, User;
2024-07-04 23:09:37 -04:00
import 'package:flutter_chat_ui/flutter_chat_ui.dart'
show ChatState, InputTextFieldController;
2024-06-06 00:19:07 -04:00
import 'package:freezed_annotation/freezed_annotation.dart';
import 'package:scroll_to_index/scroll_to_index.dart';
import 'package:veilid_support/veilid_support.dart';
import 'window_state.dart';
part 'chat_component_state.freezed.dart';
@freezed
class ChatComponentState with _$ChatComponentState {
const factory ChatComponentState(
{
// GlobalKey for the chat
required GlobalKey<ChatState> chatKey,
// ScrollController for the chat
required AutoScrollController scrollController,
2024-07-04 23:09:37 -04:00
// TextEditingController for the chat
required InputTextFieldController textEditingController,
2024-06-06 00:19:07 -04:00
// Local user
2024-06-16 22:12:24 -04:00
required User? localUser,
// Active remote users
2024-06-06 00:19:07 -04:00
required IMap<TypedKey, User> remoteUsers,
2024-06-16 22:12:24 -04:00
// Historical remote users
required IMap<TypedKey, User> historicalRemoteUsers,
// Unknown users
required IMap<TypedKey, User> unknownUsers,
2024-06-06 00:19:07 -04:00
// Messages state
required AsyncValue<WindowState<Message>> messageWindow,
// Title of the chat
required String title}) = _ChatComponentState;
}
extension ChatComponentStateExt on ChatComponentState {
//
}