Io Astrology Software For Mac May 2026

class AppDelegate: NSObject, NSApplicationDelegate var statusItem: NSStatusItem? var popover: NSPopover?

static func calculatePositions(for date: Date, birthData: BirthData? = nil) -> [PlanetaryPosition] return Planet.allCases.map planet in let lon = approximatePosition(planet: planet, date: date) return PlanetaryPosition( planet: planet, longitude: lon, latitude: 0, speed: 1.0, isRetrograde: false ) io astrology software for mac

let item = CSSearchableItem(uniqueIdentifier: birthData.id.uuidString, domainIdentifier: "io.astrology.charts", attributeSet: attributeSet) CSSearchableIndex.default().indexSearchableItems([item]) error in if let error = error print("Index error: \(error)") = nil) -> [PlanetaryPosition] return Planet

import SwiftUI import MetalKit struct ChartWheelView: NSViewRepresentable { let positions: [PlanetaryPosition] = nil) -&gt

import SwiftUI @main struct IoAstrologyApp: App @NSApplicationDelegateAdaptor(AppDelegate.self) var appDelegate

func getMoonPhase(date: Date) -> String // Simplified lunar cycle let lunarMonth: Double = 29.53058867 let referenceNewMoon = Date(timeIntervalSince1970: 946684800) // Jan 1 2000 let daysSince = date.timeIntervalSince(referenceNewMoon) / 86400 let phase = daysSince.truncatingRemainder(dividingBy: lunarMonth) / lunarMonth switch phase case 0..<0.125: return "🌑 New" case 0.125..<0.25: return "🌒 Waxing" case 0.25..<0.375: return "🌓 First Q" case 0.375..<0.5: return "🌔 Gibbous" case 0.5..<0.625: return "🌕 Full" case 0.625..<0.75: return "🌖 Waning" case 0.75..<0.875: return "🌗 Last Q" default: return "🌘 Balsamic"