mirror of https://github.com/oxen-io/session-ios
				
				
				
			
			You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
	
	
		
			83 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Swift
		
	
			
		
		
	
	
			83 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Swift
		
	
// Copyright © 2022 Rangeproof Pty Ltd. All rights reserved.
 | 
						|
 | 
						|
import Foundation
 | 
						|
import GRDB
 | 
						|
import DifferenceKit
 | 
						|
import SessionUIKit
 | 
						|
import SessionMessagingKit
 | 
						|
import SessionUtilitiesKit
 | 
						|
 | 
						|
class NotificationContentViewModel: SessionTableViewModel<NoNav, NotificationSettingsViewModel.Section, Preferences.NotificationPreviewType> {
 | 
						|
    private let storage: Storage
 | 
						|
    private let scheduler: ValueObservationScheduler
 | 
						|
    
 | 
						|
    // MARK: - Initialization
 | 
						|
    
 | 
						|
    init(
 | 
						|
        storage: Storage = Storage.shared,
 | 
						|
        scheduling scheduler: ValueObservationScheduler = Storage.defaultPublisherScheduler
 | 
						|
    ) {
 | 
						|
        self.storage = storage
 | 
						|
        self.scheduler = scheduler
 | 
						|
    }
 | 
						|
    
 | 
						|
    // MARK: - Section
 | 
						|
    
 | 
						|
    public enum Section: SessionTableSection {
 | 
						|
        case content
 | 
						|
    }
 | 
						|
    
 | 
						|
    // MARK: - Content
 | 
						|
    
 | 
						|
    override var title: String { "NOTIFICATIONS_STYLE_CONTENT_TITLE".localized() }
 | 
						|
    
 | 
						|
    private var _settingsData: [SectionModel] = []
 | 
						|
    public override var settingsData: [SectionModel] { _settingsData }
 | 
						|
    
 | 
						|
    public override var observableSettingsData: ObservableData { _observableSettingsData }
 | 
						|
    
 | 
						|
    /// This is all the data the screen needs to populate itself, please see the following link for tips to help optimise
 | 
						|
    /// performance https://github.com/groue/GRDB.swift#valueobservation-performance
 | 
						|
    ///
 | 
						|
    /// **Note:** This observation will be triggered twice immediately (and be de-duped by the `removeDuplicates`)
 | 
						|
    /// this is due to the behaviour of `ValueConcurrentObserver.asyncStartObservation` which triggers it's own
 | 
						|
    /// fetch (after the ones in `ValueConcurrentObserver.asyncStart`/`ValueConcurrentObserver.syncStart`)
 | 
						|
    /// just in case the database has changed between the two reads - unfortunately it doesn't look like there is a way to prevent this
 | 
						|
    private lazy var _observableSettingsData: ObservableData = ValueObservation
 | 
						|
        .trackingConstantRegion { [storage] db -> [SectionModel] in
 | 
						|
            let currentSelection: Preferences.NotificationPreviewType? = db[.preferencesNotificationPreviewType]
 | 
						|
                .defaulting(to: .defaultPreviewType)
 | 
						|
            
 | 
						|
            return [
 | 
						|
                SectionModel(
 | 
						|
                    model: .content,
 | 
						|
                    elements: Preferences.NotificationPreviewType.allCases
 | 
						|
                        .map { previewType in
 | 
						|
                            SessionCell.Info(
 | 
						|
                                id: previewType,
 | 
						|
                                title: previewType.name,
 | 
						|
                                rightAccessory: .radio(
 | 
						|
                                    isSelected: { (currentSelection == previewType) }
 | 
						|
                                ),
 | 
						|
                                onTap: { [weak self] in
 | 
						|
                                    storage.writeAsync { db in
 | 
						|
                                        db[.preferencesNotificationPreviewType] = previewType
 | 
						|
                                    }
 | 
						|
                                    
 | 
						|
                                    self?.dismissScreen()
 | 
						|
                                }
 | 
						|
                            )
 | 
						|
                        }
 | 
						|
                )
 | 
						|
            ]
 | 
						|
        }
 | 
						|
        .removeDuplicates()
 | 
						|
        .publisher(in: storage, scheduling: scheduler)
 | 
						|
    
 | 
						|
    // MARK: - Functions
 | 
						|
 | 
						|
    public override func updateSettings(_ updatedSettings: [SectionModel]) {
 | 
						|
        self._settingsData = updatedSettings
 | 
						|
    }
 | 
						|
}
 |