Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

MOB-1905 - UI for token amount input #453

Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
35 commits
Select commit Hold shift + click to select a range
0ae2847
Updated receive button place. Removed current profile switcher.
Oleg-Pecheneg Mar 20, 2024
5620fba
Updated home screen title view
Oleg-Pecheneg Mar 20, 2024
58ed3b0
Added send crypto view.
Oleg-Pecheneg Mar 20, 2024
6dae04d
Added section with user's wallets
Oleg-Pecheneg Mar 20, 2024
0505a33
Added send crypto view model
Oleg-Pecheneg Mar 20, 2024
9d55bee
Refactoring
Oleg-Pecheneg Mar 20, 2024
cb79a3f
Updated nav bar customisation
Oleg-Pecheneg Mar 20, 2024
6e30f15
Disable interactive dismiss when navigate
Oleg-Pecheneg Mar 20, 2024
ec8e5ac
Extracted tab selection view from explore module
Oleg-Pecheneg Mar 20, 2024
11b9490
Refactoring
Oleg-Pecheneg Mar 20, 2024
2ab2e5d
Created UI for token balance
Oleg-Pecheneg Mar 20, 2024
c7d48e6
Make tokens selectable
Oleg-Pecheneg Mar 20, 2024
6502182
Added UI for domains list in assets selection
Oleg-Pecheneg Mar 20, 2024
3853c47
Created senc crypto flow actions
Oleg-Pecheneg Mar 20, 2024
b0c4621
Pass actions from select receiver and asset type views
Oleg-Pecheneg Mar 20, 2024
bef3953
Refactoring
Oleg-Pecheneg Mar 20, 2024
8342291
Fixed initial onAppear call in token icons view
Oleg-Pecheneg Mar 20, 2024
5ba0893
Created UDNumberButtonView
Oleg-Pecheneg Mar 20, 2024
eed79a7
Created number pad view and input interpreter.
Oleg-Pecheneg Mar 20, 2024
f0d83eb
Improved number pad logic
Oleg-Pecheneg Mar 20, 2024
1737f29
Added UI for input and token info
Oleg-Pecheneg Mar 20, 2024
10d900f
Added converted value label and toggle
Oleg-Pecheneg Mar 20, 2024
98e573a
Merge branch 'dev/feat/send_crypto/MOB-1898-send-crypto' into dev/fea…
Oleg-Pecheneg Mar 20, 2024
4e300d4
Merge branch 'dev/feat/send_crypto/MOB-1903-receiver-selection' into …
Oleg-Pecheneg Mar 20, 2024
492f4d6
Merge branch 'dev/feat/send_crypto/MOB-1904-select-asset' into dev/fe…
Oleg-Pecheneg Mar 20, 2024
00001eb
Added confirmation button
Oleg-Pecheneg Mar 20, 2024
0d418fa
Refactoring
Oleg-Pecheneg Mar 20, 2024
780fa09
Merge branch 'dev/feat/send_crypto/MOB-1898-send-crypto' into dev/fea…
Oleg-Pecheneg Mar 20, 2024
cc04daf
Merge branch 'dev/feat/send_crypto/MOB-1904-select-asset' into dev/fe…
Oleg-Pecheneg Mar 20, 2024
124c2dc
Merge branch 'dev/feat/send_crypto/MOB-1898-send-crypto' into dev/fea…
Oleg-Pecheneg Mar 20, 2024
dcf1b17
Disable animation for primary input view
Oleg-Pecheneg Mar 21, 2024
6c0b7d1
Swap buy and send actions on home screen
Oleg-Pecheneg Mar 21, 2024
b3ccec2
Fixed copy on select receiver screen
Oleg-Pecheneg Mar 21, 2024
cfc6efd
Added token icon near primary input value
Oleg-Pecheneg Mar 21, 2024
4562e1b
Adjusted UI for nav bar and in the IP SE
Oleg-Pecheneg Mar 21, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Extracted tab selection view from explore module
  • Loading branch information
Oleg-Pecheneg committed Mar 20, 2024
commit ec8e5aca1d98953ba45410c97275e6b48e172cb0
Original file line number Diff line number Diff line change
Expand Up @@ -590,6 +590,8 @@
C628E37227FDE1D60044E408 /* UDSubtitleLabel.swift in Sources */ = {isa = PBXBuildFile; fileRef = C628E37127FDE1D60044E408 /* UDSubtitleLabel.swift */; };
C628E37D27FEE2D40044E408 /* NSLayoutHelper.swift in Sources */ = {isa = PBXBuildFile; fileRef = C628E37C27FEE2D40044E408 /* NSLayoutHelper.swift */; };
C628E38227FEE31D0044E408 /* DeviceHelper.swift in Sources */ = {isa = PBXBuildFile; fileRef = C628E38127FEE31D0044E408 /* DeviceHelper.swift */; };
C62900DF2BAAB1A8008B35A2 /* UDTabsPickerView.swift in Sources */ = {isa = PBXBuildFile; fileRef = C62900DE2BAAB1A8008B35A2 /* UDTabsPickerView.swift */; };
C62900E02BAAB1A8008B35A2 /* UDTabsPickerView.swift in Sources */ = {isa = PBXBuildFile; fileRef = C62900DE2BAAB1A8008B35A2 /* UDTabsPickerView.swift */; };
C629A4602A3FF13600A528A1 /* MessagingChatMessageImageBase64TypeDisplayInfo.swift in Sources */ = {isa = PBXBuildFile; fileRef = C629A45F2A3FF13600A528A1 /* MessagingChatMessageImageBase64TypeDisplayInfo.swift */; };
C629A4802A403C1C00A528A1 /* MessagingChatConversationState.swift in Sources */ = {isa = PBXBuildFile; fileRef = C629A47F2A403C1C00A528A1 /* MessagingChatConversationState.swift */; };
C62BDA412B5E4104008E21AD /* MessagingBlockUserInChatType.swift in Sources */ = {isa = PBXBuildFile; fileRef = C62BDA402B5E4104008E21AD /* MessagingBlockUserInChatType.swift */; };
Expand Down Expand Up @@ -2906,6 +2908,7 @@
C628E37127FDE1D60044E408 /* UDSubtitleLabel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = UDSubtitleLabel.swift; sourceTree = "<group>"; };
C628E37C27FEE2D40044E408 /* NSLayoutHelper.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = NSLayoutHelper.swift; sourceTree = "<group>"; };
C628E38127FEE31D0044E408 /* DeviceHelper.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = DeviceHelper.swift; sourceTree = "<group>"; };
C62900DE2BAAB1A8008B35A2 /* UDTabsPickerView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = UDTabsPickerView.swift; sourceTree = "<group>"; };
C629A45F2A3FF13600A528A1 /* MessagingChatMessageImageBase64TypeDisplayInfo.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MessagingChatMessageImageBase64TypeDisplayInfo.swift; sourceTree = "<group>"; };
C629A47F2A403C1C00A528A1 /* MessagingChatConversationState.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MessagingChatConversationState.swift; sourceTree = "<group>"; };
C62BDA402B5E4104008E21AD /* MessagingBlockUserInChatType.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MessagingBlockUserInChatType.swift; sourceTree = "<group>"; };
Expand Down Expand Up @@ -6826,6 +6829,7 @@
C61C33292B90527200BD11F5 /* UDSegmentedControlView.swift */,
C6DDF24C2B147F1A006D1F0B /* UDTextFieldView.swift */,
C655CA9B2B16E5BE00FDA063 /* UDToggleStyle.swift */,
C62900DE2BAAB1A8008B35A2 /* UDTabsPickerView.swift */,
C607A5D62B32A1030088ECF3 /* NavigationContentView.swift */,
C6B65FAC2B57A5BB006D1812 /* DismissIndicatorView.swift */,
C6DDF2432B147F1A006D1F0B /* Buttons */,
Expand Down Expand Up @@ -9019,6 +9023,7 @@
C66FCCF32844863E009B9525 /* UDGradientCoverView.swift in Sources */,
29BECD132979BDF800662FC1 /* BackedUpWallet.swift in Sources */,
C62BDA412B5E4104008E21AD /* MessagingBlockUserInChatType.swift in Sources */,
C62900DF2BAAB1A8008B35A2 /* UDTabsPickerView.swift in Sources */,
C61B3E72283E43D000500B6D /* EnterEmailViewPresenter.swift in Sources */,
C6ED320D295E8EDE00BC6919 /* NonEmptyArray.swift in Sources */,
C63F1CFF28AD099C000A5C12 /* EmptyRootCNavigationController.swift in Sources */,
Expand Down Expand Up @@ -10165,6 +10170,7 @@
C6D646372B1DC45100D724AC /* ApplePayButton.swift in Sources */,
C61808122B19AA670032E543 /* PreviewWCRequestsHandlingService.swift in Sources */,
C6960C522B19993700B79E28 /* PreviewString.swift in Sources */,
C62900E02BAAB1A8008B35A2 /* UDTabsPickerView.swift in Sources */,
C6D647062B1ED7CA00D724AC /* MessagingImageLoader.swift in Sources */,
C6D647832B1EE23000D724AC /* UITableViewCell.swift in Sources */,
C6D1E74D2BA17E2700738365 /* WalletsDataNetworkServiceProtocol.swift in Sources */,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,44 +13,27 @@ struct HomeExploreFollowerRelationshipTypePickerView: View {
@Binding var relationshipType: DomainProfileFollowerRelationshipType

var body: some View {
HStack(spacing: 16) {
ForEach(orderedRelationshipTypes, id: \.self) { relationshipType in
viewFor(relationshipType: relationshipType)
UDTabsPickerView(selectedTab: $relationshipType,
tabs: orderedRelationshipTypes) { relationshipType in
let numberOfFollowers = profile.numberOfFollowersFor(relationshipType: relationshipType)
if numberOfFollowers > 0 {
return String(numberOfFollowers)
}
return nil
}
}
}

// MARK: - Private methods
private extension HomeExploreFollowerRelationshipTypePickerView {
var orderedRelationshipTypes: [DomainProfileFollowerRelationshipType] { [.following, .followers] }
}

extension DomainProfileFollowerRelationshipType: UDTabPickable {
var id: String { rawValue }

@ViewBuilder
func viewFor(relationshipType: DomainProfileFollowerRelationshipType) -> some View {
Button {
UDVibration.buttonTap.vibrate()
self.relationshipType = relationshipType
} label: {
HStack(alignment: .top, spacing: 4) {
Text(titleFor(relationshipType: relationshipType))
.font(.currentFont(size: 16, weight: .medium))
let numberOfFollowers = profile.numberOfFollowersFor(relationshipType: relationshipType)
if numberOfFollowers > 0 {
Text(String(numberOfFollowers))
.font(.currentFont(size: 11, weight: .medium))
}
}
.foregroundStyle(foregroundStyleFor(relationshipType: relationshipType))
}
.buttonStyle(.plain)
}

func foregroundStyleFor(relationshipType: DomainProfileFollowerRelationshipType) -> Color {
relationshipType == self.relationshipType ? Color.foregroundDefault : Color.foregroundSecondary
}

func titleFor(relationshipType: DomainProfileFollowerRelationshipType) -> String {
switch relationshipType {
var title: String {
switch self {
case .followers:
String.Constants.followers.localized()
case .following:
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
//
// UDTabsPickerView.swift
// domains-manager-ios
//
// Created by Oleg Kuplin on 20.03.2024.
//

import SwiftUI


protocol UDTabPickable: Identifiable {
var title: String { get }
}

struct UDTabsPickerView<Tab: UDTabPickable>: View {

@Binding var selectedTab: Tab
let tabs: [Tab]
var suffixProvider: ((Tab) -> String?)? = nil

var body: some View {
HStack(spacing: 16) {
ForEach(tabs) { tab in
viewFor(tab: tab)
}
}
}

@ViewBuilder
func viewFor(tab: Tab) -> some View {
Button {
UDVibration.buttonTap.vibrate()
self.selectedTab = tab
} label: {
HStack(alignment: .top, spacing: 4) {
Text(tab.title)
.font(.currentFont(size: 16, weight: .medium))

if let suffix = suffixProvider?(tab) {
Text(suffix)
.font(.currentFont(size: 11, weight: .medium))
}
}
.foregroundStyle(foregroundStyleFor(tab: tab))
}
.buttonStyle(.plain)
}

func foregroundStyleFor(tab: Tab) -> Color {
tab.id == selectedTab.id ? Color.foregroundDefault : Color.foregroundSecondary
}
}


#Preview {
UDTabsPickerView(selectedTab: .constant(.followers),
tabs: DomainProfileFollowerRelationshipType.allCases)
}