2018-01-11 00:51:25 -08:00
|
|
|
//
|
|
|
|
// Account+Scriptability.swift
|
2018-08-28 22:18:24 -07:00
|
|
|
// NetNewsWire
|
2018-01-11 00:51:25 -08:00
|
|
|
//
|
|
|
|
// Created by Olof Hellman on 1/9/18.
|
|
|
|
// Copyright © 2018 Olof Hellman. All rights reserved.
|
|
|
|
//
|
|
|
|
|
2018-02-02 22:51:32 -08:00
|
|
|
import AppKit
|
2018-01-11 00:51:25 -08:00
|
|
|
import Account
|
2018-07-23 18:29:08 -07:00
|
|
|
import Articles
|
2018-03-04 18:43:29 -08:00
|
|
|
import RSCore
|
2018-01-11 00:51:25 -08:00
|
|
|
|
|
|
|
@objc(ScriptableAccount)
|
|
|
|
class ScriptableAccount: NSObject, UniqueIdScriptingObject, ScriptingObjectContainer {
|
|
|
|
|
|
|
|
let account:Account
|
|
|
|
init (_ account:Account) {
|
|
|
|
self.account = account
|
|
|
|
}
|
|
|
|
|
|
|
|
@objc(objectSpecifier)
|
|
|
|
override var objectSpecifier: NSScriptObjectSpecifier? {
|
|
|
|
let myContainer = NSApplication.shared
|
|
|
|
let scriptObjectSpecifier = myContainer.makeFormUniqueIDScriptObjectSpecifier(forObject:self)
|
|
|
|
return (scriptObjectSpecifier)
|
|
|
|
}
|
|
|
|
|
|
|
|
// MARK: --- ScriptingObject protocol ---
|
|
|
|
|
|
|
|
var scriptingKey: String {
|
|
|
|
return "accounts"
|
|
|
|
}
|
|
|
|
|
|
|
|
// MARK: --- UniqueIdScriptingObject protocol ---
|
|
|
|
|
|
|
|
// I am not sure if account should prefer to be specified by name or by ID
|
|
|
|
// but in either case it seems like the accountID would be used as the keydata, so I chose ID
|
2018-04-25 21:40:50 -07:00
|
|
|
@objc(uniqueId)
|
2018-01-11 00:51:25 -08:00
|
|
|
var scriptingUniqueId:Any {
|
|
|
|
return account.accountID
|
|
|
|
}
|
|
|
|
|
|
|
|
// MARK: --- ScriptingObjectContainer protocol ---
|
|
|
|
|
|
|
|
var scriptingClassDescription: NSScriptClassDescription {
|
|
|
|
return self.classDescription as! NSScriptClassDescription
|
|
|
|
}
|
2018-02-20 00:26:46 -08:00
|
|
|
|
2018-03-04 18:43:29 -08:00
|
|
|
func deleteElement(_ element:ScriptingObject) {
|
|
|
|
if let scriptableFolder = element as? ScriptableFolder {
|
|
|
|
BatchUpdate.shared.perform {
|
|
|
|
account.deleteFolder(scriptableFolder.folder)
|
|
|
|
}
|
|
|
|
} else if let scriptableFeed = element as? ScriptableFeed {
|
|
|
|
BatchUpdate.shared.perform {
|
|
|
|
account.deleteFeed(scriptableFeed.feed)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-02-20 00:26:46 -08:00
|
|
|
@objc(isLocationRequiredToCreateForKey:)
|
|
|
|
func isLocationRequiredToCreate(forKey key:String) -> Bool {
|
|
|
|
return false;
|
|
|
|
}
|
2018-01-11 00:51:25 -08:00
|
|
|
|
|
|
|
// MARK: --- Scriptable elements ---
|
|
|
|
|
|
|
|
@objc(feeds)
|
|
|
|
var feeds:NSArray {
|
2018-09-16 17:54:42 -07:00
|
|
|
return account.topLevelFeeds.map { ScriptableFeed($0, container:self) } as NSArray
|
2018-01-11 00:51:25 -08:00
|
|
|
}
|
|
|
|
|
2018-02-08 00:11:52 -08:00
|
|
|
@objc(valueInFeedsWithUniqueID:)
|
|
|
|
func valueInFeeds(withUniqueID id:String) -> ScriptableFeed? {
|
2018-09-16 17:54:42 -07:00
|
|
|
let feeds = Array(account.topLevelFeeds)
|
2018-02-08 00:11:52 -08:00
|
|
|
guard let feed = feeds.first(where:{$0.feedID == id}) else { return nil }
|
|
|
|
return ScriptableFeed(feed, container:self)
|
|
|
|
}
|
|
|
|
|
2018-03-04 18:43:29 -08:00
|
|
|
@objc(valueInFeedsWithName:)
|
|
|
|
func valueInFeeds(withName name:String) -> ScriptableFeed? {
|
2018-09-16 17:54:42 -07:00
|
|
|
let feeds = Array(account.topLevelFeeds)
|
2018-03-04 18:43:29 -08:00
|
|
|
guard let feed = feeds.first(where:{$0.name == name}) else { return nil }
|
|
|
|
return ScriptableFeed(feed, container:self)
|
|
|
|
}
|
|
|
|
|
2018-01-11 00:51:25 -08:00
|
|
|
@objc(folders)
|
|
|
|
var folders:NSArray {
|
2018-09-16 17:54:42 -07:00
|
|
|
let foldersSet = account.folders ?? Set<Folder>()
|
|
|
|
let folders = Array(foldersSet)
|
|
|
|
return folders.map { ScriptableFolder($0, container:self) } as NSArray
|
2018-01-11 00:51:25 -08:00
|
|
|
}
|
|
|
|
|
2018-02-08 00:11:52 -08:00
|
|
|
@objc(valueInFoldersWithUniqueID:)
|
|
|
|
func valueInFolders(withUniqueID id:NSNumber) -> ScriptableFolder? {
|
|
|
|
let folderId = id.intValue
|
2018-09-16 17:54:42 -07:00
|
|
|
let foldersSet = account.folders ?? Set<Folder>()
|
|
|
|
let folders = Array(foldersSet)
|
2018-02-08 00:11:52 -08:00
|
|
|
guard let folder = folders.first(where:{$0.folderID == folderId}) else { return nil }
|
|
|
|
return ScriptableFolder(folder, container:self)
|
2018-02-20 00:26:46 -08:00
|
|
|
}
|
2018-02-08 00:11:52 -08:00
|
|
|
|
2018-01-11 00:51:25 -08:00
|
|
|
// MARK: --- Scriptable properties ---
|
|
|
|
|
|
|
|
@objc(contents)
|
|
|
|
var contents:NSArray {
|
|
|
|
var contentsArray:[AnyObject] = []
|
2018-09-16 17:54:42 -07:00
|
|
|
for feed in account.topLevelFeeds {
|
|
|
|
contentsArray.append(ScriptableFeed(feed, container: self))
|
|
|
|
}
|
|
|
|
if let folders = account.folders {
|
|
|
|
for folder in folders {
|
|
|
|
contentsArray.append(ScriptableFolder(folder, container:self))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return contentsArray as NSArray
|
2018-01-11 00:51:25 -08:00
|
|
|
}
|
2018-01-19 22:49:01 -08:00
|
|
|
|
|
|
|
@objc(opmlRepresentation)
|
|
|
|
var opmlRepresentation:String {
|
|
|
|
return self.account.OPMLString(indentLevel:0)
|
|
|
|
}
|
|
|
|
|
2018-01-11 00:51:25 -08:00
|
|
|
@objc(accountType)
|
|
|
|
var accountType:OSType {
|
|
|
|
var osType:String = ""
|
|
|
|
switch self.account.type {
|
|
|
|
case .onMyMac:
|
|
|
|
osType = "Locl"
|
|
|
|
case .feedly:
|
|
|
|
osType = "Fdly"
|
|
|
|
case .feedbin:
|
|
|
|
osType = "Fdbn"
|
|
|
|
case .feedWrangler:
|
|
|
|
osType = "FWrg"
|
|
|
|
case .newsBlur:
|
|
|
|
osType = "NBlr"
|
|
|
|
}
|
2019-04-13 12:58:43 -07:00
|
|
|
return osType.fourCharCode()
|
2018-01-11 00:51:25 -08:00
|
|
|
}
|
|
|
|
}
|