working more
parent
a0b5ece5ab
commit
3820bdff16
|
@ -0,0 +1,44 @@
|
|||
import GRDB
|
||||
/// The Seg struct.
|
||||
///
|
||||
/// Identifiable conformance supports SwiftUI list animations, and type-safe
|
||||
/// GRDB primary key methods.
|
||||
/// Equatable conformance supports tests.
|
||||
struct ScrollState: Identifiable, Equatable {
|
||||
/// Int64 is the recommended type for auto-incremented database ids.
|
||||
/// Use nil for players that are not inserted yet in the database.
|
||||
var id: Int64?
|
||||
var scrollId: String
|
||||
var scrollOffset: Int64
|
||||
}
|
||||
|
||||
extension ScrollState {
|
||||
}
|
||||
|
||||
// MARK: - Persistence
|
||||
|
||||
/// Make ScrollState a Codable Record.
|
||||
///
|
||||
/// See <https://github.com/groue/GRDB.swift/blob/master/README.md#records>
|
||||
extension ScrollState: Codable, FetchableRecord, MutablePersistableRecord {
|
||||
// Define database columns from CodingKeys
|
||||
fileprivate enum Columns {
|
||||
static let id = Column(CodingKeys.id)
|
||||
static let scrollId = Column(CodingKeys.scrollId)
|
||||
static let scrollOffset = Column(CodingKeys.scrollOffset)
|
||||
}
|
||||
|
||||
/// Updates a player id after it has been inserted in the database.
|
||||
mutating func didInsert(_ inserted: InsertionSuccess) {
|
||||
id = inserted.rowID
|
||||
}
|
||||
}
|
||||
|
||||
// MARK: - ScrollState Database Requests
|
||||
|
||||
/// Define some player requests used by the application.
|
||||
///
|
||||
/// See <https://github.com/groue/GRDB.swift/blob/master/README.md#requests>
|
||||
/// See <https://github.com/groue/GRDB.swift/blob/master/Documentation/GoodPracticesForDesigningRecordTypes.md>
|
||||
extension DerivableRequest<ScrollState> {
|
||||
}
|
|
@ -0,0 +1,36 @@
|
|||
import Combine
|
||||
import GRDB
|
||||
import GRDBQuery
|
||||
|
||||
struct ScrollStateRequest: Queryable {
|
||||
// enum Ordering {
|
||||
// case byScore
|
||||
// case byName
|
||||
// }
|
||||
|
||||
/// The ordering used by the player request.
|
||||
// var ordering: Ordering
|
||||
static var defaultValue: [Ribbon] { [] }
|
||||
|
||||
func publisher(in appDatabase: AppDatabase) -> AnyPublisher<[Ribbon], Error> {
|
||||
// Build the publisher from the general-purpose read-only access
|
||||
// granted by `appDatabase.reader`.
|
||||
// Some apps will prefer to call a dedicated method of `appDatabase`.
|
||||
ValueObservation
|
||||
.tracking(fetchValue(_:))
|
||||
.publisher(
|
||||
in: appDatabase.reader,
|
||||
// The `.immediate` scheduling feeds the view right on
|
||||
// subscription, and avoids an undesired animation when the
|
||||
// application starts.
|
||||
scheduling: .immediate)
|
||||
.eraseToAnyPublisher()
|
||||
}
|
||||
|
||||
// This method is not required by Queryable, but it makes it easier
|
||||
func fetchValue(_ db: Database) throws -> [Ribbon] {
|
||||
var ret = try Ribbon.fetchAll(db, sql: "SELECT * FROM ScrollState LIMIT 1") // [Player]
|
||||
// print(ret)
|
||||
return ret
|
||||
}
|
||||
}
|
|
@ -44,7 +44,7 @@ public class VisibilityTracker<ID: Hashable>: ObservableObject {
|
|||
containerBounds = bounds
|
||||
}
|
||||
|
||||
public func reportContentBounds(_ bounds: CGRect, id: ID) {
|
||||
public func reportContentBounds(_ bounds: CGRect, id: ID) {
|
||||
let topLeft = bounds.origin
|
||||
let size = bounds.size
|
||||
let bottomRight = CGPoint(x: topLeft.x + size.width, y: topLeft.y + size.height)
|
||||
|
@ -53,6 +53,9 @@ public class VisibilityTracker<ID: Hashable>: ObservableObject {
|
|||
|
||||
|
||||
visibleViews[id] = -1 * (bounds.origin.y - containerBounds.origin.y)
|
||||
if (abs(visibleViews[id]! ) > 1000) {
|
||||
visibleViews.removeValue(forKey: id)
|
||||
}
|
||||
sortViews()
|
||||
action(id, .shown, self)
|
||||
|
||||
|
|
|
@ -36,6 +36,8 @@
|
|||
85942EF929B1150B00307621 /* SegDenorm.swift in Sources */ = {isa = PBXBuildFile; fileRef = 85942EF829B1150B00307621 /* SegDenorm.swift */; };
|
||||
85942EFE29B11C0B00307621 /* john_export.json in Resources */ = {isa = PBXBuildFile; fileRef = 85942EFC29B11C0A00307621 /* john_export.json */; };
|
||||
85942EFF29B11C0B00307621 /* mark_export.json in Resources */ = {isa = PBXBuildFile; fileRef = 85942EFD29B11C0B00307621 /* mark_export.json */; };
|
||||
85E00E7C29F34D2D00FF9E78 /* ScrollState.swift in Sources */ = {isa = PBXBuildFile; fileRef = 85E00E7B29F34D2D00FF9E78 /* ScrollState.swift */; };
|
||||
85E00E7E29F34D3700FF9E78 /* ScrollStateRequest.swift in Sources */ = {isa = PBXBuildFile; fileRef = 85E00E7D29F34D3700FF9E78 /* ScrollStateRequest.swift */; };
|
||||
85F01DF82978787800F317B4 /* AveriaSerifLibre-Regular.ttf in Resources */ = {isa = PBXBuildFile; fileRef = 85F01DF72978787800F317B4 /* AveriaSerifLibre-Regular.ttf */; };
|
||||
85F01DFB2978790400F317B4 /* xe-Dogma-Bold.ttf in Resources */ = {isa = PBXBuildFile; fileRef = 85F01DFA2978790400F317B4 /* xe-Dogma-Bold.ttf */; };
|
||||
/* End PBXBuildFile section */
|
||||
|
@ -68,6 +70,8 @@
|
|||
85942EF829B1150B00307621 /* SegDenorm.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SegDenorm.swift; sourceTree = "<group>"; };
|
||||
85942EFC29B11C0A00307621 /* john_export.json */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.json; path = john_export.json; sourceTree = "<group>"; };
|
||||
85942EFD29B11C0B00307621 /* mark_export.json */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.json; path = mark_export.json; sourceTree = "<group>"; };
|
||||
85E00E7B29F34D2D00FF9E78 /* ScrollState.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ScrollState.swift; sourceTree = "<group>"; };
|
||||
85E00E7D29F34D3700FF9E78 /* ScrollStateRequest.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ScrollStateRequest.swift; sourceTree = "<group>"; };
|
||||
85F01DF72978787800F317B4 /* AveriaSerifLibre-Regular.ttf */ = {isa = PBXFileReference; lastKnownFileType = file; path = "AveriaSerifLibre-Regular.ttf"; sourceTree = "<group>"; };
|
||||
85F01DFA2978790400F317B4 /* xe-Dogma-Bold.ttf */ = {isa = PBXFileReference; lastKnownFileType = file; path = "xe-Dogma-Bold.ttf"; sourceTree = "<group>"; };
|
||||
85F01DFC29787B3500F317B4 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist; path = Info.plist; sourceTree = "<group>"; };
|
||||
|
@ -101,6 +105,8 @@
|
|||
85431A7C2905F4F500EE0760 = {
|
||||
isa = PBXGroup;
|
||||
children = (
|
||||
85E00E7B29F34D2D00FF9E78 /* ScrollState.swift */,
|
||||
85E00E7D29F34D3700FF9E78 /* ScrollStateRequest.swift */,
|
||||
8528897429B2B86B003F2E16 /* CrownOfThorns.swift */,
|
||||
85942EEC29AEA04200307621 /* SelectedRibbon.swift */,
|
||||
85942EEE29AEA18300307621 /* SelectedRibbonRequest.swift */,
|
||||
|
@ -274,8 +280,10 @@
|
|||
85942EEB29AD55A400307621 /* RibbonRequest.swift in Sources */,
|
||||
85431A8B2905F4F500EE0760 /* ContentView.swift in Sources */,
|
||||
85942EF529B108C600307621 /* Seg.swift in Sources */,
|
||||
85E00E7C29F34D2D00FF9E78 /* ScrollState.swift in Sources */,
|
||||
8528897529B2B86B003F2E16 /* CrownOfThorns.swift in Sources */,
|
||||
85431A952905F4F600EE0760 /* gloss.xcdatamodeld in Sources */,
|
||||
85E00E7E29F34D3700FF9E78 /* ScrollStateRequest.swift in Sources */,
|
||||
85942EE929AD51A100307621 /* Ribbon.swift in Sources */,
|
||||
8590D96729A183EE001EF84F /* AppDatabase.swift in Sources */,
|
||||
8590D96929A18A6D001EF84F /* LineRequest.swift in Sources */,
|
||||
|
|
Binary file not shown.
|
@ -54,6 +54,7 @@ struct AppDatabase {
|
|||
t.autoIncrementedPrimaryKey("id")
|
||||
t.column("book", .text).notNull()
|
||||
t.column("scrollOffset", .integer).notNull()
|
||||
t.column("scrollId", .text)
|
||||
}
|
||||
|
||||
try db.create(table: "SelectedRibbon") { t in
|
||||
|
@ -61,6 +62,12 @@ struct AppDatabase {
|
|||
t.column("ribbonId", .integer).notNull()
|
||||
}
|
||||
|
||||
try db.create(table: "ScrollState") { t in
|
||||
t.autoIncrementedPrimaryKey("id")
|
||||
t.column("scrollId", .text).notNull()
|
||||
t.column("scrollOffset", .integer).notNull()
|
||||
}
|
||||
|
||||
try db.create(table: "foo2") { t in
|
||||
t.autoIncrementedPrimaryKey("id")
|
||||
t.column("ribbonId", .integer).notNull()
|
||||
|
@ -123,6 +130,16 @@ extension AppDatabase {
|
|||
}
|
||||
}
|
||||
|
||||
func saveScrollState(_ scrollState: inout ScrollState) async throws {
|
||||
// if ribbon.name.isEmpty {
|
||||
// throw ValidationError.missingName
|
||||
// }
|
||||
try await dbWriter.write { [scrollState] db in
|
||||
try scrollState.update(db)
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
/// Create random Lines if the database is empty.
|
||||
func createRandomLinesIfEmpty() throws {
|
||||
|
@ -156,6 +173,7 @@ extension AppDatabase {
|
|||
_ = try Ribbon(id: 1, book: "bible.john", scrollOffset: 0).inserted(db)
|
||||
_ = try Ribbon(id: 2, book: "bible.john", scrollOffset: 2000).inserted(db)
|
||||
_ = try SelectedRibbon(id: 1, ribbonId: 1).inserted(db)
|
||||
_ = try ScrollState(id: 1, scrollId: "1", scrollOffset: 1).inserted(db)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -50,7 +50,7 @@ struct SwitchButton : View {
|
|||
// var selectedRibbon: SelectedRibbon
|
||||
|
||||
// @Binding var book : String
|
||||
@Binding var scrollDelegate : ScrollViewHandler
|
||||
// @Binding var scrollDelegate : ScrollViewHandler
|
||||
@Binding var scrollView : UIScrollView?
|
||||
@Binding var scrollUpdate : Bool
|
||||
|
||||
|
@ -68,7 +68,7 @@ struct SwitchButton : View {
|
|||
var selectedRibbon = sr[0]
|
||||
Print("SELECTED RIBBON", selectedRibbon)
|
||||
|
||||
var saveScrollOffset = scrollDelegate.scrollOffset
|
||||
// var saveScrollOffset = scrollDelegate.scrollOffset
|
||||
|
||||
var editedRibbon = selectedRibbon
|
||||
|
||||
|
@ -79,10 +79,10 @@ struct SwitchButton : View {
|
|||
if (selectedRibbon.id != ribbon.id!) {
|
||||
Print("switching")
|
||||
// book = ribbon.book
|
||||
Print("applying offset", CGFloat(ribbon.scrollOffset))
|
||||
// Print("applying offset", CGFloat(ribbon.scrollOffset))
|
||||
// scrollOffset = CGFloat(ribbon.scrollOffset)
|
||||
// scrollDelegate.scrollOffset = CGFloat(ribbon.scrollOffset)
|
||||
scrollDelegate.scrollOffset = CGFloat(ribbon.scrollOffset)
|
||||
// scrollDelegate.scrollOffset = CGFloat(ribbon.scrollOffset)
|
||||
// scrollView!.contentOffset.y = CGFloat(ribbon.scrollOffset)
|
||||
// scrollOffset = CGFloat(1500)
|
||||
var updateSelectRibbon = SelectedRibbon(id: Int64(1), ribbonId: ribbon.id!)
|
||||
|
@ -95,7 +95,7 @@ struct SwitchButton : View {
|
|||
}
|
||||
}
|
||||
|
||||
editedRibbon.scrollOffset = Int(saveScrollOffset)
|
||||
// editedRibbon.scrollOffset = Int(saveScrollOffset)
|
||||
|
||||
_ = try await appDatabase.saveRibbon(&editedRibbon)
|
||||
_ = Print("editedRibbon", editedRibbon)
|
||||
|
@ -112,17 +112,17 @@ struct SwitchButton : View {
|
|||
}
|
||||
|
||||
|
||||
class ScrollViewHandler: NSObject {
|
||||
public var scrollOffset = CGFloat(10)
|
||||
}
|
||||
// class ScrollViewHandler: NSObject {
|
||||
// public var scrollOffset = CGFloat(10)
|
||||
// }
|
||||
|
||||
extension ScrollViewHandler: UIScrollViewDelegate {
|
||||
func scrollViewDidScroll(_ scrollView: UIScrollView) {
|
||||
scrollOffset = CGFloat(scrollView.contentOffset.y)
|
||||
// print("delegate", scrollView.contentOffset.y)
|
||||
// print("delegate prop", self.scrollOffset)
|
||||
}
|
||||
}
|
||||
// extension ScrollViewHandler: UIScrollViewDelegate {
|
||||
// func scrollViewDidScroll(_ scrollView: UIScrollView) {
|
||||
// scrollOffset = CGFloat(scrollView.contentOffset.y)
|
||||
// // print("delegate", scrollView.contentOffset.y)
|
||||
// // print("delegate prop", self.scrollOffset)
|
||||
// }
|
||||
// }
|
||||
|
||||
|
||||
class Verse: NSObject, Codable {
|
||||
|
@ -133,49 +133,19 @@ class Verse: NSObject, Codable {
|
|||
func makeVerseView(seg: SegDenorm) -> some View {
|
||||
var retView = Text("")
|
||||
var segSplit = seg.body.components(separatedBy: ";;")
|
||||
// Text(segSplit[0].body)
|
||||
// .id(seg.id)
|
||||
// VStack {
|
||||
// ForEach(segSplit.indices) { i in
|
||||
let decoder = JSONDecoder()
|
||||
segSplit.enumerated().forEach({ (index, item) in
|
||||
let verse = try! decoder.decode(Verse.self, from: item.data(using: .utf8)!)
|
||||
|
||||
retView = retView + Text(String(verse.verse))
|
||||
// Text(seg.body)
|
||||
// .contentShape(Rectangle())
|
||||
.font(Font.custom("AveriaSerifLibre-Regular", size: 20))
|
||||
.baselineOffset(6.0)
|
||||
.foregroundColor(Color.white)
|
||||
|
||||
retView = retView + Text(verse.body)
|
||||
// .frame(maxWidth: .infinity, alignment: .leading)
|
||||
// .contentShape(Rectangle())
|
||||
.foregroundColor(Color.white)
|
||||
.font(Font.custom("AveriaSerifLibre-Regular", size: 30))
|
||||
// .listRowBackground(Color(red: 0.2, green: 0.8, blue: 0.2))
|
||||
// .listRowInsets(EdgeInsets())
|
||||
// .padding(EdgeInsets(top: 10, leading: 20, bottom: 40, trailing: 20))
|
||||
// .listRowSeparator(.hidden)
|
||||
// .id(String(seg.id) + "body" + String(i))
|
||||
// .id(seg.id)
|
||||
//.onTapGesture {
|
||||
// selectedLine = seg.id
|
||||
// //Print(selectedLine)
|
||||
//}
|
||||
|
||||
// .listRowBackground(Color(red: 0.2, green: 0.8, blue: 0.2))
|
||||
// .listRowInsets(EdgeInsets())
|
||||
// .padding(EdgeInsets(top: 10, leading: 20, bottom: 40, trailing: 20))
|
||||
// .listRowSeparator(.hidden)
|
||||
// .id(String(seg.id) + "verse" + String(i))
|
||||
// .id(seg.id)
|
||||
//.onTapGesture {
|
||||
// selectedLine = seg.id
|
||||
// //Print(selectedLine)
|
||||
//}
|
||||
})
|
||||
// }
|
||||
return retView
|
||||
}
|
||||
|
||||
|
@ -241,22 +211,25 @@ struct ContentView: View {
|
|||
@State var pulledOut = CGSize.zero
|
||||
@State var taskTitle : String = "FIRST DOGGG"
|
||||
@State var curBook : String = "Matthew"
|
||||
// @State var scrollTo1 : Int64?
|
||||
@State var selectedLine : Int64?
|
||||
@State var scrollOffset = CGFloat()
|
||||
|
||||
@State var thisScrollView : UIScrollView?
|
||||
@State var scrollUpdate = false
|
||||
@State var initLoad = false
|
||||
|
||||
@State var currentId : String?
|
||||
@State var currentOffset = CGFloat()
|
||||
|
||||
// set this to scroll to area
|
||||
@State var scrollId : String?
|
||||
@State var scrollOffset: CGFloat?
|
||||
|
||||
|
||||
@Query(SegDenormRequest(book: "bible.mark")) private var segs: [SegDenorm]
|
||||
|
||||
@State var scrollDelegate: ScrollViewHandler
|
||||
// @State var scrollDelegate: ScrollViewHandler
|
||||
// @State var scrollDelegate = ScrollViewHandler()
|
||||
|
||||
// @State var selectedRibbon: Ribbon!,
|
||||
// @State var selectedRibbon: Ribbon!
|
||||
|
||||
// @State var selectedRibbonId = Int64(UserDefaults.standard.optionalInt(forKey: "selectedRibbonId") ?? 1)
|
||||
|
||||
// ribbon
|
||||
|
@ -276,8 +249,7 @@ struct ContentView: View {
|
|||
init() {
|
||||
UITableView.appearance().backgroundColor = UIColor(Color(red: 0.2, green: 0.2, blue: 0.2))
|
||||
// _selectedRibbon = Query(RibbonRequest(id: Int64(UserDefaults.standard.optionalInt(forKey: "lastRibbonId") ?? 1)))
|
||||
self._scrollDelegate = State(initialValue: ScrollViewHandler())
|
||||
Print("initalizing")
|
||||
// self._scrollDelegate = State(initialValue: ScrollViewHandler())
|
||||
}
|
||||
|
||||
var body: some View {
|
||||
|
@ -287,24 +259,6 @@ struct ContentView: View {
|
|||
ZStack{
|
||||
VStack{
|
||||
|
||||
VStack{
|
||||
|
||||
// // Star(corners: 6, smoothness: 0.85, initAngle:-CGFloat.pi / 4)
|
||||
// .fill(.blue)
|
||||
// .frame(width: 200, height: 200)
|
||||
// .background(Color.gray.opacity(0.0))
|
||||
|
||||
// Star(corners: 6, smoothness: 0.85, initAngle:-CGFloat.pi / 2)
|
||||
// .fill(.blue)
|
||||
// .frame(width: 200, height: 200)
|
||||
// .background(Color.gray.opacity(0.0))
|
||||
|
||||
// MyCustomShape().frame(width: 10, height: 10)
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
Text("MRK")
|
||||
.font(Font.custom("AveriaSerifLibre-Regular", size: 20))
|
||||
.foregroundColor(Color.white)
|
||||
|
@ -320,12 +274,10 @@ struct ContentView: View {
|
|||
.frame(width: 120, height: 120)
|
||||
|
||||
|
||||
|
||||
// Text("cat" + String(selectedRibbon[0].id!))
|
||||
ForEach(ribbons) { ribbon in
|
||||
//ForEach(selectedRibbon) { sr in
|
||||
SwitchButton(ribbon: ribbon,
|
||||
scrollDelegate: $scrollDelegate,
|
||||
// scrollDelegate: $scrollDelegate,
|
||||
scrollView:$thisScrollView,
|
||||
scrollUpdate:$scrollUpdate
|
||||
)
|
||||
|
@ -337,20 +289,14 @@ struct ContentView: View {
|
|||
.background(Color(red: 0.1, green: 0.1, blue: 0.1))
|
||||
|
||||
ScrollViewReader { proxy in
|
||||
|
||||
VisibilityTrackingScrollView(action: handleVisibilityChanged) {
|
||||
// ScrollView {
|
||||
|
||||
LazyVStack {
|
||||
Text(refresh ? "Selected" : "not Selected")
|
||||
Button("Jump to #8") {
|
||||
scrollId = "20"
|
||||
|
||||
proxy.scrollTo("5", anchor: .top)
|
||||
|
||||
DispatchQueue.main.async {
|
||||
scrollOffset = 340
|
||||
refresh.toggle()
|
||||
}
|
||||
}
|
||||
ForEach(segs) { seg in
|
||||
SegRow(seg: seg)
|
||||
|
@ -371,27 +317,37 @@ struct ContentView: View {
|
|||
}
|
||||
}
|
||||
.background(Color(red: 0.2, green: 0.2, blue: 0.2))
|
||||
}
|
||||
.onChange(of: scrollId) { target in
|
||||
if let target = target {
|
||||
proxy.scrollTo(scrollId! , anchor: .top)
|
||||
//scrollId = nil
|
||||
|
||||
DispatchQueue.main.async {
|
||||
scrollOffset = -299
|
||||
refresh.toggle()
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
}
|
||||
.introspectScrollView { scrollView in
|
||||
|
||||
|
||||
// Print("introspect")
|
||||
scrollView.delegate = scrollDelegate
|
||||
Print("Scroll delegate offset", scrollDelegate.scrollOffset)
|
||||
// scrollView.delegate = scrollDelegate
|
||||
// Print("Scroll delegate offset", scrollDelegate.scrollOffset)
|
||||
|
||||
if (scrollOffset != 0) {
|
||||
Print("GOT THEHREHREH")
|
||||
|
||||
scrollView.contentOffset.y = scrollView.contentOffset.y + scrollOffset
|
||||
|
||||
DispatchQueue.main.async { scrollOffset = 0 }
|
||||
if (scrollOffset != nil) {
|
||||
Print("Setting scroll offset")
|
||||
scrollView.contentOffset.y = scrollView.contentOffset.y + scrollOffset!
|
||||
DispatchQueue.main.async { scrollOffset = nil }
|
||||
}
|
||||
|
||||
if (thisScrollView == nil) {
|
||||
Print("init scroll")
|
||||
thisScrollView = scrollView
|
||||
scrollView.contentOffset.y = CGFloat(selectedRibbon[0].scrollOffset)
|
||||
}
|
||||
// if (thisScrollView == nil) {
|
||||
// Print("init scroll")
|
||||
// thisScrollView = scrollView
|
||||
// scrollView.contentOffset.y = CGFloat(selectedRibbon[0].scrollOffset)
|
||||
// }
|
||||
}
|
||||
.listStyle(PlainListStyle())
|
||||
}
|
||||
|
@ -439,11 +395,44 @@ struct ContentView: View {
|
|||
}
|
||||
|
||||
func handleVisibilityChanged(_ id: String, change: VisibilityChange, tracker: VisibilityTracker<String>) {
|
||||
|
||||
// @Environment(\.appDatabase) var appDatabase
|
||||
switch change {
|
||||
case .shown: print("\(id) shown")
|
||||
case .hidden: print("\(id) hidden")
|
||||
}
|
||||
print(tracker.visibleViews)
|
||||
// if (currentId != nil) {
|
||||
// currentOffset = tracker.visibleViews[currentId!]!
|
||||
// }
|
||||
|
||||
let currentId = Array(tracker.visibleViews.keys)[0]
|
||||
if (currentId != nil) {
|
||||
|
||||
// Access Shared Defaults Object
|
||||
let userDefaults = UserDefaults.standard
|
||||
|
||||
// Write/Set Value
|
||||
Print(currentId)
|
||||
Print(tracker.visibleViews[currentId]!)
|
||||
userDefaults.set(currentId, forKey: "currentId")
|
||||
userDefaults.set(tracker.visibleViews[currentId]!, forKey: "currentOffset")
|
||||
// userDefaults.set(tracker.visibleViews[currentId!]!, forKey: "currentOffset")
|
||||
// var updateScrollState = ScrollState(id: Int64(1),
|
||||
// scrollId: currentId!,
|
||||
// scrollOffset: Int64(tracker.visibleViews[currentId!]!))
|
||||
// Print("Savingg")
|
||||
// Print(updateScrollState)
|
||||
// Task(priority: .default) {
|
||||
|
||||
// do {
|
||||
// _ = try await appDatabase.saveScrollState(&updateScrollState)
|
||||
|
||||
// } catch {
|
||||
// Print("something wrong")
|
||||
// }
|
||||
// }
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
|
Loading…
Reference in New Issue