Io Astrology Software For Mac Link
import Foundation class PlanetCalculator
var zodiacSign: String let signs = ["Aries", "Taurus", "Gemini", "Cancer", "Leo", "Virgo", "Libra", "Scorpio", "Sagittarius", "Capricorn", "Aquarius", "Pisces"] let index = Int((longitude / 30).rounded(.down)) % 12 return signs[index]
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)") io astrology software for mac
func updateMenubarText() let now = Date() let moonPhase = getMoonPhase(date: now) statusItem?.button?.title = "🌙 \(moonPhase) ☉ Io"
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" 0.125: return "🌑 New" case 0.125..<
import CoreSpotlight import MobileCoreServices class SpotlightIndexer static func indexChart(_ birthData: BirthData, positions: [PlanetaryPosition]) let attributeSet = CSSearchableItemAttributeSet(contentType: .text) attributeSet.title = "(birthData.name)'s Natal Chart" attributeSet.contentDescription = positions.map "($0.planet.symbol) in ($0.zodiacSign)" .joined(separator: ", ")
.padding() .frame(width: 200)
struct QuickWidgetView: View var body: some View VStack(alignment: .leading) Text("Planetary Hour: Mars ☿") Text("Moon in Scorpio ♏") Text("Next transit: Moon trine Sun in 2h") Divider() Button("Open Full App") NSApp.activate(ignoringOtherApps: true)
func makeNSView(context: Context) -> MTKView let mtkView = MTKView() mtkView.device = MTLCreateSystemDefaultDevice() mtkView.clearColor = MTLClearColor(red: 0.05, green: 0.05, blue: 0.1, alpha: 1) mtkView.delegate = context.coordinator return mtkView 0.25: return "🌒 Waxing" case 0.25..<
@objc func togglePopover() if popover == nil popover = NSPopover() popover?.contentViewController = NSHostingController(rootView: QuickWidgetView()) if let popover = popover, let button = statusItem?.button if popover.isShown popover.performClose(nil) else popover.show(relativeTo: button.bounds, of: button, preferredEdge: .minY)