import 'dart:math';

import 'package:matrix/matrix.dart';
import 'package:fluffychat/config/themes.dart';
import 'package:fluffychat/utils/fluffy_share.dart';
import 'package:flutter/material.dart';
import '../../widgets/content_banner.dart';
import '../user_bottom_sheet.dart';
import '../../utils/matrix_sdk_extensions.dart/presence_extension.dart';
import 'package:flutter_gen/gen_l10n/l10n.dart';

class UserBottomSheetView extends StatelessWidget {
  final UserBottomSheetController controller;

  const UserBottomSheetView(this.controller, {Key key}) : super(key: key);

  @override
  Widget build(BuildContext context) {
    final user = controller.widget.user;
    final client = user.room.client;
    final presence = client.presences[user.id];
    return Center(
      child: Container(
        width: min(
            MediaQuery.of(context).size.width, FluffyThemes.columnWidth * 1.5),
        child: Material(
          elevation: 4,
          child: SafeArea(
            child: Scaffold(
              extendBodyBehindAppBar: true,
              appBar: AppBar(
                elevation: 0,
                backgroundColor:
                    Theme.of(context).scaffoldBackgroundColor.withOpacity(0.5),
                leading: IconButton(
                  icon: Icon(Icons.arrow_downward_outlined),
                  onPressed: Navigator.of(context, rootNavigator: false).pop,
                  tooltip: L10n.of(context).close,
                ),
                title: Text(user.calcDisplayname()),
                actions: [
                  if (user.id != user.room.client.userID)
                    PopupMenuButton(
                      itemBuilder: (_) => [
                        if (controller.widget.onMention != null)
                          PopupMenuItem(
                            value: 'mention',
                            child: _TextWithIcon(
                              L10n.of(context).mention,
                              Icons.alternate_email_outlined,
                            ),
                          ),
                        if (user.id != user.room.client.userID &&
                            !user.room.isDirectChat)
                          PopupMenuItem(
                            value: 'message',
                            child: _TextWithIcon(
                              L10n.of(context).sendAMessage,
                              Icons.send_outlined,
                            ),
                          ),
                        if (user.canChangePowerLevel)
                          PopupMenuItem(
                            value: 'permission',
                            child: _TextWithIcon(
                              L10n.of(context).setPermissionsLevel,
                              Icons.edit_attributes_outlined,
                            ),
                          ),
                        if (user.canKick)
                          PopupMenuItem(
                            value: 'kick',
                            child: _TextWithIcon(
                              L10n.of(context).kickFromChat,
                              Icons.exit_to_app_outlined,
                            ),
                          ),
                        if (user.canBan && user.membership != Membership.ban)
                          PopupMenuItem(
                            value: 'ban',
                            child: _TextWithIcon(
                              L10n.of(context).banFromChat,
                              Icons.warning_sharp,
                            ),
                          )
                        else if (user.canBan &&
                            user.membership == Membership.ban)
                          PopupMenuItem(
                            value: 'unban',
                            child: _TextWithIcon(
                              L10n.of(context).removeExile,
                              Icons.warning_outlined,
                            ),
                          ),
                      ],
                      onSelected: controller.participantAction,
                    ),
                ],
              ),
              body: Column(
                children: [
                  Expanded(
                    child: ContentBanner(
                      user.avatarUrl,
                      defaultIcon: Icons.person_outline,
                      client: user.room.client,
                    ),
                  ),
                  ListTile(
                    title: Text(L10n.of(context).username),
                    subtitle: Text(user.id),
                    trailing: Icon(Icons.share_outlined),
                    onTap: () => FluffyShare.share(
                        user.id, controller.widget.outerContext),
                  ),
                  if (presence != null)
                    ListTile(
                      title: Text(presence.getLocalizedStatusMessage(context)),
                      subtitle:
                          Text(presence.getLocalizedLastActiveAgo(context)),
                      trailing: Icon(Icons.circle,
                          color: presence.presence.currentlyActive ?? false
                              ? Colors.green
                              : Colors.grey),
                    ),
                ],
              ),
            ),
          ),
        ),
      ),
    );
  }
}

class _TextWithIcon extends StatelessWidget {
  final String text;
  final IconData iconData;

  const _TextWithIcon(
    this.text,
    this.iconData, {
    Key key,
  }) : super(key: key);

  @override
  Widget build(BuildContext context) {
    return Row(
      mainAxisSize: MainAxisSize.min,
      children: [
        Icon(iconData),
        SizedBox(width: 16),
        Text(text),
      ],
    );
  }
}