@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)
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: ", ")
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" io astrology software for mac
static let example = BirthData( name: "Example", date: Date(), latitude: 40.7128, longitude: -74.0060, timezone: .current ) enum Planet: String, CaseIterable case sun, moon, mercury, venus, mars, jupiter, saturn, uranus, neptune, pluto case chiron, northNode, trueLilith var symbol: String switch self case .sun: return "☉" case .moon: return "☽" case .mercury: return "☿" case .venus: return "♀" case .mars: return "♂" case .jupiter: return "♃" case .saturn: return "♄" case .uranus: return "♅" case .neptune: return "♆" case .pluto: return "♇" case .chiron: return "⚷" case .northNode: return "☊" case .trueLilith: return "⚸"
func updateNSView(_ nsView: MTKView, context: Context) context.coordinator.positions = positions @objc func togglePopover() if popover == nil popover
enum HouseSystem: String, CaseIterable case placidus = "Placidus" case koch = "Koch" case wholeSign = "Whole Sign"
func applicationDidFinishLaunching(_ notification: Notification) statusItem = NSStatusBar.system.statusItem(withLength: NSStatusItem.variableLength) if let button = statusItem?.button button.title = "☉ Io" button.action = #selector(togglePopover) // Update planetary hour every minute Timer.scheduledTimer(withTimeInterval: 60, repeats: true) _ in self.updateMenubarText() updateMenubarText() ") func getMoonPhase(date: Date) ->
class Coordinator: NSObject, MTKViewDelegate { var positions: [PlanetaryPosition] init(positions: [PlanetaryPosition]) self.positions = positions func mtkView(_ view: MTKView, drawableSizeWillChange size: CGSize) {} func draw(in view: MTKView) guard let drawable = view.currentDrawable, let device = view.device, let commandBuffer = device.makeCommandQueue()?.makeCommandBuffer() else return // Clear background let renderPassDescriptor = MTLRenderPassDescriptor() renderPassDescriptor.colorAttachments[0].texture = drawable.texture renderPassDescriptor.colorAttachments[0].loadAction = .clear renderPassDescriptor.colorAttachments[0].clearColor = MTLClearColor(red: 0.05, green: 0.05, blue: 0.1, alpha: 1) guard let encoder = commandBuffer.makeRenderCommandEncoder(descriptor: renderPassDescriptor) else return // Draw zodiac circle and aspect lines here // (Simplified: In real implementation, use Metal shaders to draw lines/arcs) encoder.endEncoding() commandBuffer.present(drawable) commandBuffer.commit() } } import SwiftUI struct InputFormView: View @State private var name = "" @State private var birthDate = Date() @State private var latitude = 0.0 @State private var longitude = 0.0 @State private var selectedHouseSystem = HouseSystem.placidus @AppStorage("savedBirthData") private var savedData: Data?