fixing tag loading on full refresh, smart skipping
This commit is contained in:
parent
d25a9d8b88
commit
509aea0b42
@ -47,9 +47,9 @@ class LiveUser: ObservableObject {
|
|||||||
Logger.sys.debug("failed to get APNS token")
|
Logger.sys.debug("failed to get APNS token")
|
||||||
}
|
}
|
||||||
|
|
||||||
@Published var isInitiallyRefreshingUser = true
|
@Published var isFullRefreshingUser = true
|
||||||
@Published var isInitiallyRefreshingPlaylists = true
|
@Published var isFullRefreshingPlaylists = true
|
||||||
@Published var isInitiallyRefreshingTags = true
|
@Published var isFullRefreshingTags = true
|
||||||
|
|
||||||
@Published var isRefreshingUser = false
|
@Published var isRefreshingUser = false
|
||||||
@Published var isRefreshingPlaylists = false
|
@Published var isRefreshingPlaylists = false
|
||||||
@ -71,8 +71,10 @@ class LiveUser: ObservableObject {
|
|||||||
self.user = user
|
self.user = user
|
||||||
}
|
}
|
||||||
|
|
||||||
func lastfm_connected() -> Bool {
|
var lastfm_connected: Bool {
|
||||||
return username.count > 0
|
get {
|
||||||
|
return user.lastfm_username.count > 0
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func logout() {
|
func logout() {
|
||||||
@ -109,154 +111,188 @@ class LiveUser: ObservableObject {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func refresh_user(onSuccess: (() -> Void)? = nil, onFailure: (() -> Void)? = nil) {
|
func refresh_user(onSuccess: (() -> Void)? = nil, onFailure: (() -> Void)? = nil) {
|
||||||
self.isRefreshingUser = true
|
|
||||||
|
|
||||||
Logger.sys.info("refreshing user")
|
if !isRefreshingUser {
|
||||||
|
self.isRefreshingUser = true
|
||||||
|
|
||||||
let api = UserApi.getUser
|
Logger.sys.info("refreshing user")
|
||||||
RequestBuilder.buildRequest(apiRequest: api).responseJSON{ response in
|
|
||||||
|
|
||||||
if self.check_network_response(response: response) {
|
let api = UserApi.getUser
|
||||||
|
RequestBuilder.buildRequest(apiRequest: api).responseJSON{ response in
|
||||||
|
|
||||||
guard let data = response.data else {
|
if self.check_network_response(response: response) {
|
||||||
Logger.net.error("error getting user")
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
guard let json = try? JSON(data: data) else {
|
guard let data = response.data else {
|
||||||
Logger.parse.error("error parsing user")
|
Logger.net.error("error getting user")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
// update state
|
guard let json = try? JSON(data: data) else {
|
||||||
self.user = UserApi.fromJSON(user: json)
|
Logger.parse.error("error parsing user")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
self.isRefreshingUser = false
|
// update state
|
||||||
self.isInitiallyRefreshingUser = false
|
self.user = UserApi.fromJSON(user: json)
|
||||||
|
|
||||||
if let success = onSuccess {
|
self.isRefreshingUser = false
|
||||||
Logger.sys.debug("successfully refreshed user")
|
self.isFullRefreshingUser = false
|
||||||
success()
|
|
||||||
}
|
|
||||||
|
|
||||||
} else {
|
if let success = onSuccess {
|
||||||
|
Logger.sys.debug("successfully refreshed user")
|
||||||
|
success()
|
||||||
|
}
|
||||||
|
|
||||||
if let failure = onFailure {
|
} else {
|
||||||
Logger.net.error("failed to refresh user")
|
|
||||||
failure()
|
if let failure = onFailure {
|
||||||
|
Logger.net.error("failed to refresh user")
|
||||||
|
failure()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Logger.sys.info("skipping refreshing user, already refreshing")
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func refresh_playlists(onSuccess: (() -> Void)? = nil, onFailure: (() -> Void)? = nil) {
|
func refresh_playlists(onSuccess: (() -> Void)? = nil, onFailure: (() -> Void)? = nil) {
|
||||||
self.isRefreshingPlaylists = true
|
|
||||||
|
|
||||||
Logger.sys.info("refreshing playlists")
|
if !isRefreshingPlaylists {
|
||||||
|
self.isRefreshingPlaylists = true
|
||||||
|
|
||||||
let api = PlaylistApi.getPlaylists
|
Logger.sys.info("refreshing playlists")
|
||||||
RequestBuilder.buildRequest(apiRequest: api).responseJSON{ response in
|
|
||||||
|
|
||||||
if self.check_network_response(response: response) {
|
let api = PlaylistApi.getPlaylists
|
||||||
|
RequestBuilder.buildRequest(apiRequest: api).responseJSON{ response in
|
||||||
|
|
||||||
guard let data = response.data else {
|
if self.check_network_response(response: response) {
|
||||||
Logger.net.error("error getting playlists from net request")
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
guard let json = try? JSON(data: data) else {
|
guard let data = response.data else {
|
||||||
Logger.parse.error("error parsing playlists reponse")
|
Logger.net.error("error getting playlists from net request")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
let playlists = json["playlists"].arrayValue
|
guard let json = try? JSON(data: data) else {
|
||||||
|
Logger.parse.error("error parsing playlists reponse")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
// update state
|
let playlists = json["playlists"].arrayValue
|
||||||
self.playlists = PlaylistApi.fromJSON(playlist: playlists).sorted(by: { $0.name.lowercased() < $1.name.lowercased() })
|
|
||||||
|
|
||||||
self.isRefreshingPlaylists = false
|
// update state
|
||||||
self.isInitiallyRefreshingPlaylists = false
|
self.playlists = PlaylistApi.fromJSON(playlist: playlists).sorted(by: { $0.name.lowercased() < $1.name.lowercased() })
|
||||||
|
|
||||||
if let success = onSuccess {
|
self.isRefreshingPlaylists = false
|
||||||
Logger.sys.debug("successfully refreshed playlists")
|
self.isFullRefreshingPlaylists = false
|
||||||
success()
|
|
||||||
}
|
|
||||||
|
|
||||||
let encoder = JSONEncoder()
|
if let success = onSuccess {
|
||||||
do {
|
Logger.sys.debug("successfully refreshed playlists")
|
||||||
UserDefaults.standard.set(String(data: try encoder.encode(playlists), encoding: .utf8), forKey: "playlists")
|
success()
|
||||||
} catch {
|
}
|
||||||
Logger.parse.error("error encoding playlists: \(error)")
|
|
||||||
}
|
|
||||||
|
|
||||||
} else {
|
let encoder = JSONEncoder()
|
||||||
|
do {
|
||||||
|
UserDefaults.standard.set(String(data: try encoder.encode(playlists), encoding: .utf8), forKey: "playlists")
|
||||||
|
} catch {
|
||||||
|
Logger.parse.error("error encoding playlists: \(error)")
|
||||||
|
}
|
||||||
|
|
||||||
if let failure = onFailure {
|
} else {
|
||||||
Logger.net.error("failed to refresh playlists")
|
|
||||||
failure()
|
if let failure = onFailure {
|
||||||
|
Logger.net.error("failed to refresh playlists")
|
||||||
|
failure()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Logger.sys.info("skipping refreshing playlists, already refreshing")
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func refresh_tags(onSuccess: (() -> Void)? = nil, onFailure: (() -> Void)? = nil) {
|
func refresh_tags(onSuccess: (() -> Void)? = nil, onFailure: (() -> Void)? = nil) {
|
||||||
self.isRefreshingTags = true
|
|
||||||
|
|
||||||
Logger.sys.info("refreshing tags")
|
if !isRefreshingTags {
|
||||||
|
self.isRefreshingTags = true
|
||||||
|
|
||||||
let api = TagApi.getTags
|
Logger.sys.info("refreshing tags")
|
||||||
RequestBuilder.buildRequest(apiRequest: api).responseJSON{ response in
|
|
||||||
|
|
||||||
if self.check_network_response(response: response) {
|
let api = TagApi.getTags
|
||||||
|
RequestBuilder.buildRequest(apiRequest: api).responseJSON{ response in
|
||||||
|
|
||||||
guard let data = response.data else {
|
if self.check_network_response(response: response) {
|
||||||
Logger.net.error("error getting tags")
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
guard let json = try? JSON(data: data) else {
|
guard let data = response.data else {
|
||||||
Logger.parse.error("error parsing tags response")
|
Logger.net.error("error getting tags")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
let tags = json["tags"].arrayValue
|
guard let json = try? JSON(data: data) else {
|
||||||
|
Logger.parse.error("error parsing tags response")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
// update state
|
let tags = json["tags"].arrayValue
|
||||||
self.tags = TagApi.fromJSON(tag: tags).sorted(by: { $0.name.lowercased() < $1.name.lowercased() })
|
|
||||||
|
|
||||||
self.isRefreshingTags = false
|
// update state
|
||||||
self.isInitiallyRefreshingTags = false
|
self.tags = TagApi.fromJSON(tag: tags).sorted(by: { $0.name.lowercased() < $1.name.lowercased() })
|
||||||
|
|
||||||
if let success = onSuccess {
|
self.isRefreshingTags = false
|
||||||
Logger.sys.debug("successfully refreshed tags")
|
self.isFullRefreshingTags = false
|
||||||
success()
|
|
||||||
}
|
|
||||||
|
|
||||||
let encoder = JSONEncoder()
|
if let success = onSuccess {
|
||||||
do {
|
Logger.sys.debug("successfully refreshed tags")
|
||||||
UserDefaults.standard.set(String(data: try encoder.encode(tags), encoding: .utf8), forKey: "tags")
|
success()
|
||||||
} catch {
|
}
|
||||||
Logger.parse.error("error encoding tags: \(error)")
|
|
||||||
}
|
|
||||||
|
|
||||||
} else {
|
let encoder = JSONEncoder()
|
||||||
|
do {
|
||||||
|
UserDefaults.standard.set(String(data: try encoder.encode(tags), encoding: .utf8), forKey: "tags")
|
||||||
|
} catch {
|
||||||
|
Logger.parse.error("error encoding tags: \(error)")
|
||||||
|
}
|
||||||
|
|
||||||
if let failure = onFailure {
|
} else {
|
||||||
Logger.net.error("failed to refresh tags")
|
|
||||||
failure()
|
if let failure = onFailure {
|
||||||
|
Logger.net.error("failed to refresh tags")
|
||||||
|
failure()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Logger.sys.info("skipping refreshing tags, already refreshing")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var isFullRefreshing: Bool {
|
||||||
|
get {
|
||||||
|
return isFullRefreshingTags || isFullRefreshingPlaylists || isFullRefreshingUser
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func full_refresh() {
|
func full_refresh() {
|
||||||
self.isInitiallyRefreshingUser = true
|
|
||||||
self.isInitiallyRefreshingPlaylists = true
|
|
||||||
self.isInitiallyRefreshingTags = true
|
|
||||||
|
|
||||||
self.refresh_user()
|
if !isFullRefreshing {
|
||||||
self.refresh_playlists()
|
self.isFullRefreshingUser = true
|
||||||
self.refresh_tags()
|
self.isFullRefreshingPlaylists = true
|
||||||
|
self.isFullRefreshingTags = true
|
||||||
|
|
||||||
|
self.refresh_user()
|
||||||
|
self.refresh_playlists()
|
||||||
|
self.refresh_tags()
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Logger.sys.info("skipping full refresh, already refreshing")
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func check_network_response(response: AFDataResponse<Any>) -> Bool {
|
func check_network_response(response: AFDataResponse<Any>) -> Bool {
|
||||||
|
@ -18,9 +18,9 @@ struct AppSkeleton: View {
|
|||||||
|
|
||||||
var body: some View {
|
var body: some View {
|
||||||
|
|
||||||
if self.liveUser.isInitiallyRefreshingUser
|
if self.liveUser.isFullRefreshingUser
|
||||||
|| self.liveUser.isInitiallyRefreshingPlaylists
|
|| self.liveUser.isFullRefreshingPlaylists
|
||||||
|| self.liveUser.isInitiallyRefreshingTags
|
|| self.liveUser.isFullRefreshingTags
|
||||||
{
|
{
|
||||||
LoadingScreen()
|
LoadingScreen()
|
||||||
.onAppear {
|
.onAppear {
|
||||||
@ -39,7 +39,7 @@ struct AppSkeleton: View {
|
|||||||
}
|
}
|
||||||
.tag(0)
|
.tag(0)
|
||||||
|
|
||||||
if liveUser.lastfm_connected() {
|
if liveUser.lastfm_connected {
|
||||||
|
|
||||||
TagList()
|
TagList()
|
||||||
.tabItem {
|
.tabItem {
|
||||||
|
@ -27,7 +27,7 @@ struct PlaylistView: View {
|
|||||||
var body: some View {
|
var body: some View {
|
||||||
Form {
|
Form {
|
||||||
|
|
||||||
if liveUser.lastfm_connected() {
|
if liveUser.lastfm_connected {
|
||||||
PlaylistStatsSection(playlist: $playlist, showingToast: $showingToast, toastText: $toastText, toastSuccess: $toastSuccess)
|
PlaylistStatsSection(playlist: $playlist, showingToast: $showingToast, toastText: $toastText, toastSuccess: $toastSuccess)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user