diff --git a/lib/ui/widgets/first_screen/contact_search_page.dart b/lib/ui/widgets/first_screen/contact_search_page.dart
index 39a7f395a58aa7be88b9aaabea47b20d724e8072..cd5dbd8a9e54096ed5335a345d2d5c78fab78f1e 100644
--- a/lib/ui/widgets/first_screen/contact_search_page.dart
+++ b/lib/ui/widgets/first_screen/contact_search_page.dart
@@ -21,6 +21,8 @@ import '../../nfc_helper.dart';
 import '../../qr_manager.dart';
 import '../../ui_helpers.dart';
 import '../connectivity_widget_wrapper_wrapper.dart';
+import '../contact_menu.dart';
+import '../contacts_actions.dart';
 import '../custom_error_widget.dart';
 import '../loading_box.dart';
 import '../third_screen/contacts_page.dart';
@@ -88,8 +90,9 @@ class _ContactSearchPageState extends State<ContactSearchPage> {
                 .convert(cPlusResponse.body) as Map<String, dynamic>)['hits']
             as Map<String, dynamic>)['hits'] as List<dynamic>;
         for (final dynamic hit in hits) {
-          final Contact c =
-              await contactFromResultSearch(hit as Map<String, dynamic>);
+          final Contact c = await contactFromResultSearch(
+            hit as Map<String, dynamic>,
+          );
           logger('Contact retrieved in c+ search $c');
           ContactsCache().addContact(c);
           setState(() {
@@ -103,7 +106,7 @@ class _ContactSearchPageState extends State<ContactSearchPage> {
     if (isConnected) {
       if (_searchTerm.length >= 8) {
         // Only search wot if it's a long key
-        final List<Contact> wotResults = await searchWotV2(_searchTerm);
+        final List<Contact> wotResults = await searchWotV1(_searchTerm);
         // ignore: prefer_foreach
         for (final Contact c in wotResults) {
           ContactsCache().addContact(c);
@@ -114,8 +117,9 @@ class _ContactSearchPageState extends State<ContactSearchPage> {
                 await ContactsCache().getContact(wotC.pubKey);
             if (cachedWotProfile.name == null) {
               // Users without c+ profile
-              final Contact cPlusProfile =
-                  await getProfile(cachedWotProfile.pubKey, true);
+              final Contact cPlusProfile = await getProfile(
+                  cachedWotProfile.pubKey,
+                  onlyCPlusProfile: true);
               ContactsCache().addContact(cPlusProfile);
             }
           }
@@ -154,9 +158,10 @@ class _ContactSearchPageState extends State<ContactSearchPage> {
           final bool nft = hasNft(snapshot);
 
           final PaymentCubit paymentCubit = context.read<PaymentCubit>();
+          final bool forPayment = widget.forPayment;
           return Scaffold(
             appBar: AppBar(
-              title: Text(widget.forPayment
+              title: Text(forPayment
                   ? tr('search_user_title')
                   : tr('search_user_title_in_contacts')),
               backgroundColor: Theme.of(context).colorScheme.primary,
@@ -205,102 +210,104 @@ class _ContactSearchPageState extends State<ContactSearchPage> {
                 )
               ],
             ),
-            body: Padding(
-              padding: const EdgeInsets.all(16.0),
-              child: Column(
-                crossAxisAlignment: CrossAxisAlignment.stretch,
-                children: <Widget>[
-                  TextField(
-                    controller: _searchController,
-                    focusNode: _searchFocusNode,
-                    decoration: InputDecoration(
-                      filled: true,
-                      labelText: tr('search_user'),
-                      helperText: _searchTerm.isEmpty
-                          ? tr('search_user_hint')
-                          : !_isMultiSelect && !_isLoading
-                              ? tr('search_multiuser_hint')
-                              : null,
-                      suffixIcon: Row(
-                        mainAxisAlignment: MainAxisAlignment.end,
-                        mainAxisSize: MainAxisSize.min,
-                        children: <Widget>[
-                          IconButton(
-                            icon: const Icon(Icons.clear),
-                            onPressed: () {
-                              _searchController.clear();
-                              _searchTerm = '';
-                              _previousSearchTerm = '';
-                              setState(() {
-                                _isLoading = false;
-                                _results.clear();
-                              });
-                            },
-                          ),
-                          IconButton(
-                            icon: const Icon(Icons.search),
-                            onPressed: () =>
-                                _searchTerm.length < 3 ? null : _search(),
-                          ),
-                        ],
+            body: Column(
+              crossAxisAlignment: CrossAxisAlignment.stretch,
+              children: <Widget>[
+                Padding(
+                    padding: const EdgeInsets.all(16.0),
+                    child: TextField(
+                      controller: _searchController,
+                      focusNode: _searchFocusNode,
+                      decoration: InputDecoration(
+                        filled: true,
+                        labelText: tr('search_user'),
+                        helperText: _searchTerm.isEmpty
+                            ? forPayment
+                                ? tr('search_user_hint')
+                                : tr('search_user_hint_basic')
+                            : !_isMultiSelect && !_isLoading && forPayment
+                                ? tr('search_multiuser_hint')
+                                : null,
+                        suffixIcon: Row(
+                          mainAxisAlignment: MainAxisAlignment.end,
+                          mainAxisSize: MainAxisSize.min,
+                          children: <Widget>[
+                            IconButton(
+                              icon: const Icon(Icons.clear),
+                              onPressed: () {
+                                _searchController.clear();
+                                _searchTerm = '';
+                                _previousSearchTerm = '';
+                                setState(() {
+                                  _isLoading = false;
+                                  _results.clear();
+                                });
+                              },
+                            ),
+                            IconButton(
+                              icon: const Icon(Icons.search),
+                              onPressed: () =>
+                                  _searchTerm.length < 3 ? null : _search(),
+                            ),
+                          ],
+                        ),
                       ),
-                    ),
-                    onSubmitted: (_) {
-                      _search();
-                    },
-                    onChanged: (String value) {
-                      if (value.length < _previousSearchTerm.length &&
-                          value.length < 3) {
+                      onSubmitted: (_) {
+                        _search();
+                      },
+                      onChanged: (String value) {
+                        if (value.length < _previousSearchTerm.length &&
+                            value.length < 3) {
+                          _previousSearchTerm = value;
+                          setState(() {
+                            _isLoading = false;
+                          });
+                          return;
+                        }
+                        _searchTerm = value;
                         _previousSearchTerm = value;
-                        setState(() {
-                          _isLoading = false;
-                        });
-                        return;
-                      }
-                      _searchTerm = value;
-                      _previousSearchTerm = value;
-                      if (_searchTerm.length >= 3) {
-                        setState(() {
-                          _isLoading = true;
-                        });
-                        EasyDebounce.debounce('profile_search_debouncer',
-                            const Duration(milliseconds: 500), () => _search());
-                      }
-                    },
-                  ),
-                  if (_isLoading)
-                    const LoadingBox(simple: false)
-                  else if (_searchTerm.isNotEmpty &&
-                      _results.isEmpty &&
-                      _isLoading)
-                    const NoElements(text: 'nothing_found')
-                  else
-                    Expanded(
-                      child: ListView.builder(
-                          itemCount: _results.length,
-                          itemBuilder: (BuildContext context, int index) {
-                            final Contact contact = _results[index];
-                            return FutureBuilder<Contact>(
-                                future: _getAndReplaceContact(contact),
-                                builder: (BuildContext context,
-                                    AsyncSnapshot<Contact> snapshot) {
-                                  Widget widget;
-                                  if (snapshot.hasData) {
-                                    widget = _buildItem(
-                                        snapshot.data!, index, context);
-                                  } else if (snapshot.hasError) {
-                                    widget = CustomErrorWidget(snapshot.error);
-                                  } else {
-                                    // Contact without wot
-                                    widget =
-                                        _buildItem(contact, index, context);
-                                  }
-                                  return widget;
-                                });
-                          }),
-                    )
-                ],
-              ),
+                        if (_searchTerm.length >= 3) {
+                          setState(() {
+                            _isLoading = true;
+                          });
+                          EasyDebounce.debounce(
+                              'profile_search_debouncer',
+                              const Duration(milliseconds: 500),
+                              () => _search());
+                        }
+                      },
+                    )),
+                if (_isLoading)
+                  const LoadingBox(simple: false)
+                else if (_searchTerm.isNotEmpty &&
+                    _results.isEmpty &&
+                    _isLoading)
+                  const NoElements(text: 'nothing_found')
+                else
+                  Expanded(
+                    child: ListView.builder(
+                        itemCount: _results.length,
+                        itemBuilder: (BuildContext context, int index) {
+                          final Contact contact = _results[index];
+                          return FutureBuilder<Contact>(
+                              future: _getAndReplaceContact(contact),
+                              builder: (BuildContext context,
+                                  AsyncSnapshot<Contact> snapshot) {
+                                Widget widget;
+                                if (snapshot.hasData) {
+                                  widget = _buildItem(
+                                      snapshot.data!, index, context);
+                                } else if (snapshot.hasError) {
+                                  widget = CustomErrorWidget(snapshot.error);
+                                } else {
+                                  // Contact without wot
+                                  widget = _buildItem(contact, index, context);
+                                }
+                                return widget;
+                              });
+                        }),
+                  )
+              ],
             ),
             floatingActionButton:
                 _isMultiSelect ? _buildFloatingActionButtons() : null,
@@ -494,9 +501,16 @@ class _ContactSearchPageState extends State<ContactSearchPage> {
             },
             trailing: BlocBuilder<ContactsCubit, ContactsState>(
                 builder: (BuildContext context, ContactsState state) {
-              return ContactFavIcon(
-                  contact: contact,
-                  contactsCubit: context.read<ContactsCubit>());
+              return widget.forPayment
+                  ? ContactFavIcon(
+                      contact: contact,
+                      contactsCubit: context.read<ContactsCubit>())
+                  : ContactMenu(
+                      contact: contact,
+                      onEdit: () => onEditContact(context, contact),
+                      onSent: () => onSentContact(context, contact),
+                      onCopy: () => onShowContactQr(context, contact),
+                      onDelete: () => onDeleteContact(context, contact));
             }),
           );
   }