Skip to content

Commit

Permalink
Update Followers example
Browse files Browse the repository at this point in the history
  • Loading branch information
sbertix committed Jan 7, 2021
1 parent 8c63ba9 commit 7454e2a
Show file tree
Hide file tree
Showing 4 changed files with 89 additions and 7 deletions.
6 changes: 3 additions & 3 deletions Examples/Followers/Followers.xcodeproj/project.pbxproj
Original file line number Diff line number Diff line change
Expand Up @@ -341,7 +341,7 @@
buildSettings = {
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
CODE_SIGN_IDENTITY = "Apple Development";
CODE_SIGN_STYLE = Automatic;
CODE_SIGN_STYLE = Manual;
DEVELOPMENT_ASSET_PATHS = "\"Followers/Preview Content\"";
DEVELOPMENT_TEAM = "";
ENABLE_PREVIEWS = YES;
Expand All @@ -363,7 +363,7 @@
buildSettings = {
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
CODE_SIGN_IDENTITY = "Apple Development";
CODE_SIGN_STYLE = Automatic;
CODE_SIGN_STYLE = Manual;
DEVELOPMENT_ASSET_PATHS = "\"Followers/Preview Content\"";
DEVELOPMENT_TEAM = "";
ENABLE_PREVIEWS = YES;
Expand Down Expand Up @@ -417,7 +417,7 @@
repositoryURL = "[email protected]:sbertix/Swiftagram.git";
requirement = {
kind = upToNextMinorVersion;
minimumVersion = 4.1.0;
minimumVersion = 4.2.0;
};
};
/* End XCRemoteSwiftPackageReference section */
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,78 @@
<?xml version="1.0" encoding="UTF-8"?>
<Scheme
LastUpgradeVersion = "1230"
version = "1.3">
<BuildAction
parallelizeBuildables = "YES"
buildImplicitDependencies = "YES">
<BuildActionEntries>
<BuildActionEntry
buildForTesting = "YES"
buildForRunning = "YES"
buildForProfiling = "YES"
buildForArchiving = "YES"
buildForAnalyzing = "YES">
<BuildableReference
BuildableIdentifier = "primary"
BlueprintIdentifier = "E028F0072418DFAD00F9C7F8"
BuildableName = "Followers.app"
BlueprintName = "Followers"
ReferencedContainer = "container:Followers.xcodeproj">
</BuildableReference>
</BuildActionEntry>
</BuildActionEntries>
</BuildAction>
<TestAction
buildConfiguration = "Debug"
selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
shouldUseLaunchSchemeArgsEnv = "YES">
<Testables>
</Testables>
</TestAction>
<LaunchAction
buildConfiguration = "Debug"
selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
launchStyle = "0"
useCustomWorkingDirectory = "NO"
ignoresPersistentStateOnLaunch = "NO"
debugDocumentVersioning = "YES"
debugServiceExtension = "internal"
allowLocationSimulation = "YES">
<BuildableProductRunnable
runnableDebuggingMode = "0">
<BuildableReference
BuildableIdentifier = "primary"
BlueprintIdentifier = "E028F0072418DFAD00F9C7F8"
BuildableName = "Followers.app"
BlueprintName = "Followers"
ReferencedContainer = "container:Followers.xcodeproj">
</BuildableReference>
</BuildableProductRunnable>
</LaunchAction>
<ProfileAction
buildConfiguration = "Release"
shouldUseLaunchSchemeArgsEnv = "YES"
savedToolIdentifier = ""
useCustomWorkingDirectory = "NO"
debugDocumentVersioning = "YES">
<BuildableProductRunnable
runnableDebuggingMode = "0">
<BuildableReference
BuildableIdentifier = "primary"
BlueprintIdentifier = "E028F0072418DFAD00F9C7F8"
BuildableName = "Followers.app"
BlueprintName = "Followers"
ReferencedContainer = "container:Followers.xcodeproj">
</BuildableReference>
</BuildableProductRunnable>
</ProfileAction>
<AnalyzeAction
buildConfiguration = "Debug">
</AnalyzeAction>
<ArchiveAction
buildConfiguration = "Release"
revealArchiveInOrganizer = "YES">
</ArchiveAction>
</Scheme>
8 changes: 4 additions & 4 deletions Examples/Followers/Followers/Followers/FollowersModel.swift
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ final class FollowersModel: ObservableObject {
/// The logged in secret.
var secret: Secret? {
didSet {
guard let secret = secret, secret.id != oldValue?.id else { return }
guard let secret = secret, secret.identifier != oldValue?.identifier else { return }
fetch(secret: secret)
}
}
Expand All @@ -42,7 +42,7 @@ final class FollowersModel: ObservableObject {
if let secret = KeychainStorage<Secret>().all().first {
self.secret = secret
self.current = UserDefaults.standard
.data(forKey: secret.id)
.data(forKey: secret.identifier)
.flatMap { try? JSONDecoder().decode(User.self, from: $0) }
// Fetch the data.
self.fetch(secret: secret)
Expand All @@ -59,7 +59,7 @@ final class FollowersModel: ObservableObject {
/// Fetch values.
func fetch(secret: Secret) {
// Load info for the logged in user.
Endpoint.User.summary(for: secret.id)
Endpoint.User.summary(for: secret.identifier)
.unlocking(with: secret)
.publish()
.map(\.user)
Expand All @@ -69,7 +69,7 @@ final class FollowersModel: ObservableObject {
// Load the first 3 pages of the current user's followers.
// In a real app you might want to fetch all of them.
followers = []
Endpoint.Friendship.following(secret.id)
Endpoint.Friendship.following(secret.identifier)
.unlocking(with: secret)
.publish()
.prefix(3)
Expand Down
4 changes: 4 additions & 0 deletions Examples/Followers/Followers/Followers/FollowersView.swift
Original file line number Diff line number Diff line change
Expand Up @@ -22,8 +22,10 @@ struct FollowersView: View {
Text("Loading…")
.font(.headline)
.foregroundColor(.secondary)
.padding(.vertical)
} else if model.followers?.isEmpty == true {
Text("No followers.")
.padding(.vertical)
} else {
ForEach(model.followers ?? [], id: \.username.hashValue) { user in
/// Visit **Instagram** on tap.
Expand All @@ -37,10 +39,12 @@ struct FollowersView: View {
Spacer()
Image(systemName: "chevron.right").imageScale(.small).foregroundColor(.secondary)
}
.padding(.vertical)
}
}
}
}
.listStyle(PlainListStyle())
.onAppear {
guard self.model.secret == nil else { return }
self.shouldDisplayLogin = true
Expand Down

0 comments on commit 7454e2a

Please sign in to comment.