@roxyapi/ui 0.11.0 → 0.12.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (142) hide show
  1. package/AGENTS.md +6 -0
  2. package/README.md +7 -1
  3. package/components-catalog.json +111 -1
  4. package/dist/cdn/components/astrocartography-map.js +58 -0
  5. package/dist/cdn/components/astrocartography-map.js.map +7 -0
  6. package/dist/cdn/components/divisional-chart.js +7 -7
  7. package/dist/cdn/components/divisional-chart.js.map +1 -1
  8. package/dist/cdn/components/dosha-card.js +2 -2
  9. package/dist/cdn/components/dosha-card.js.map +3 -3
  10. package/dist/cdn/components/fixed-stars.js +52 -0
  11. package/dist/cdn/components/fixed-stars.js.map +7 -0
  12. package/dist/cdn/components/hd-variables.js +2 -2
  13. package/dist/cdn/components/hd-variables.js.map +3 -3
  14. package/dist/cdn/components/hexagram.js +3 -3
  15. package/dist/cdn/components/hexagram.js.map +3 -3
  16. package/dist/cdn/components/local-space-compass.js +58 -0
  17. package/dist/cdn/components/local-space-compass.js.map +7 -0
  18. package/dist/cdn/components/moon-phase.js +3 -3
  19. package/dist/cdn/components/moon-phase.js.map +3 -3
  20. package/dist/cdn/components/natal-chart.js +8 -8
  21. package/dist/cdn/components/natal-chart.js.map +2 -2
  22. package/dist/cdn/components/positions-table.js +52 -0
  23. package/dist/cdn/components/positions-table.js.map +7 -0
  24. package/dist/cdn/components/profection-card.js +52 -0
  25. package/dist/cdn/components/profection-card.js.map +7 -0
  26. package/dist/cdn/components/reference-card.js +3 -3
  27. package/dist/cdn/components/reference-card.js.map +3 -3
  28. package/dist/cdn/components/relocation-wheel.js +61 -0
  29. package/dist/cdn/components/relocation-wheel.js.map +7 -0
  30. package/dist/cdn/components/synastry-chart.js +4 -4
  31. package/dist/cdn/components/synastry-chart.js.map +2 -2
  32. package/dist/cdn/components/vedic-kundli.js +5 -5
  33. package/dist/cdn/components/vedic-kundli.js.map +1 -1
  34. package/dist/cdn/components/vedic-planets-table.js +2 -2
  35. package/dist/cdn/components/vedic-planets-table.js.map +1 -1
  36. package/dist/cdn/components/western-planets-table.js +2 -2
  37. package/dist/cdn/components/western-planets-table.js.map +1 -1
  38. package/dist/cdn/components/yoga-list.js +3 -3
  39. package/dist/cdn/components/yoga-list.js.map +3 -3
  40. package/dist/cdn/roxy-ui.js +84 -72
  41. package/dist/cdn/roxy-ui.js.map +4 -4
  42. package/dist/components/astrocartography-map.d.ts +27 -0
  43. package/dist/components/astrocartography-map.d.ts.map +1 -0
  44. package/dist/components/astrocartography-map.js +8 -0
  45. package/dist/components/astrocartography-map.js.map +7 -0
  46. package/dist/components/divisional-chart.js +22 -22
  47. package/dist/components/divisional-chart.js.map +1 -1
  48. package/dist/components/dosha-card.d.ts.map +1 -1
  49. package/dist/components/dosha-card.js +1 -1
  50. package/dist/components/dosha-card.js.map +3 -3
  51. package/dist/components/fixed-stars.d.ts +21 -0
  52. package/dist/components/fixed-stars.d.ts.map +1 -0
  53. package/dist/components/fixed-stars.js +2 -0
  54. package/dist/components/fixed-stars.js.map +7 -0
  55. package/dist/components/hd-variables.d.ts.map +1 -1
  56. package/dist/components/hd-variables.js +1 -1
  57. package/dist/components/hd-variables.js.map +3 -3
  58. package/dist/components/hexagram.d.ts +3 -1
  59. package/dist/components/hexagram.d.ts.map +1 -1
  60. package/dist/components/hexagram.js +1 -1
  61. package/dist/components/hexagram.js.map +3 -3
  62. package/dist/components/local-space-compass.d.ts +23 -0
  63. package/dist/components/local-space-compass.d.ts.map +1 -0
  64. package/dist/components/local-space-compass.js +8 -0
  65. package/dist/components/local-space-compass.js.map +7 -0
  66. package/dist/components/moon-phase.d.ts.map +1 -1
  67. package/dist/components/moon-phase.js +1 -1
  68. package/dist/components/moon-phase.js.map +3 -3
  69. package/dist/components/natal-chart.d.ts +2 -0
  70. package/dist/components/natal-chart.d.ts.map +1 -1
  71. package/dist/components/natal-chart.js +6 -6
  72. package/dist/components/natal-chart.js.map +2 -2
  73. package/dist/components/positions-table.d.ts +34 -0
  74. package/dist/components/positions-table.d.ts.map +1 -0
  75. package/dist/components/positions-table.js +2 -0
  76. package/dist/components/positions-table.js.map +7 -0
  77. package/dist/components/profection-card.d.ts +18 -0
  78. package/dist/components/profection-card.d.ts.map +1 -0
  79. package/dist/components/profection-card.js +2 -0
  80. package/dist/components/profection-card.js.map +7 -0
  81. package/dist/components/reference-card.d.ts.map +1 -1
  82. package/dist/components/reference-card.js +1 -1
  83. package/dist/components/reference-card.js.map +3 -3
  84. package/dist/components/relocation-wheel.d.ts +21 -0
  85. package/dist/components/relocation-wheel.d.ts.map +1 -0
  86. package/dist/components/relocation-wheel.js +11 -0
  87. package/dist/components/relocation-wheel.js.map +7 -0
  88. package/dist/components/synastry-chart.js +3 -3
  89. package/dist/components/synastry-chart.js.map +2 -2
  90. package/dist/components/vedic-kundli.js +14 -14
  91. package/dist/components/vedic-kundli.js.map +1 -1
  92. package/dist/components/vedic-planets-table.js +1 -1
  93. package/dist/components/vedic-planets-table.js.map +1 -1
  94. package/dist/components/western-planets-table.js +1 -1
  95. package/dist/components/western-planets-table.js.map +1 -1
  96. package/dist/components/yoga-list.d.ts +5 -2
  97. package/dist/components/yoga-list.d.ts.map +1 -1
  98. package/dist/components/yoga-list.js +1 -1
  99. package/dist/components/yoga-list.js.map +3 -3
  100. package/dist/generated/endpoint-bindings.d.ts.map +1 -1
  101. package/dist/index.cjs +55 -43
  102. package/dist/index.cjs.map +4 -4
  103. package/dist/index.d.ts +6 -0
  104. package/dist/index.d.ts.map +1 -1
  105. package/dist/index.js +63 -51
  106. package/dist/index.js.map +4 -4
  107. package/dist/manifest.d.ts.map +1 -1
  108. package/dist/manifest.json +6 -0
  109. package/dist/types/index.d.ts +1 -1
  110. package/dist/types/index.d.ts.map +1 -1
  111. package/dist/types/types.gen.d.ts +7864 -5381
  112. package/dist/types/types.gen.d.ts.map +1 -1
  113. package/dist/utils/degree.d.ts +2 -0
  114. package/dist/utils/degree.d.ts.map +1 -1
  115. package/dist/utils/planet-color.d.ts +3 -0
  116. package/dist/utils/planet-color.d.ts.map +1 -0
  117. package/dist/utils/world-map.d.ts +8 -0
  118. package/dist/utils/world-map.d.ts.map +1 -0
  119. package/dist/version.d.ts +1 -1
  120. package/package.json +2 -1
  121. package/src/components/astrocartography-map.ts +442 -0
  122. package/src/components/dosha-card.ts +48 -16
  123. package/src/components/fixed-stars.ts +254 -0
  124. package/src/components/hd-variables.ts +30 -2
  125. package/src/components/hexagram.ts +11 -11
  126. package/src/components/local-space-compass.ts +299 -0
  127. package/src/components/moon-phase.ts +21 -2
  128. package/src/components/natal-chart.ts +36 -24
  129. package/src/components/positions-table.ts +442 -0
  130. package/src/components/profection-card.ts +173 -0
  131. package/src/components/reference-card.ts +40 -8
  132. package/src/components/relocation-wheel.ts +170 -0
  133. package/src/components/yoga-list.ts +95 -2
  134. package/src/generated/endpoint-bindings.ts +62 -0
  135. package/src/index.ts +6 -0
  136. package/src/manifest.ts +79 -0
  137. package/src/types/index.ts +1 -1
  138. package/src/types/types.gen.ts +7814 -5263
  139. package/src/utils/degree.ts +11 -0
  140. package/src/utils/planet-color.ts +45 -0
  141. package/src/utils/world-map.ts +8 -0
  142. package/src/version.ts +1 -1
@@ -0,0 +1,61 @@
1
+ "use strict";var RoxyUI_relocation_wheel=(()=>{var X=Object.defineProperty;var Re=Object.getOwnPropertyDescriptor;var it=Object.getOwnPropertyNames;var at=Object.prototype.hasOwnProperty;var lt=(i,e)=>{for(var t in e)X(i,t,{get:e[t],enumerable:!0})},ct=(i,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of it(e))!at.call(i,s)&&s!==t&&X(i,s,{get:()=>e[s],enumerable:!(r=Re(e,s))||r.enumerable});return i};var dt=i=>ct(X({},"__esModule",{value:!0}),i),y=(i,e,t,r)=>{for(var s=r>1?void 0:r?Re(e,t):e,o=i.length-1,n;o>=0;o--)(n=i[o])&&(s=(r?n(e,t,s):n(s))||s);return r&&s&&X(e,t,s),s};var Rt={};lt(Rt,{RoxyRelocationWheel:()=>D});var Q=globalThis,ee=Q.ShadowRoot&&(Q.ShadyCSS===void 0||Q.ShadyCSS.nativeShadow)&&"adoptedStyleSheets"in Document.prototype&&"replace"in CSSStyleSheet.prototype,ce=Symbol(),Me=new WeakMap,q=class{constructor(e,t,r){if(this._$cssResult$=!0,r!==ce)throw Error("CSSResult is not constructable. Use `unsafeCSS` or `css` instead.");this.cssText=e,this.t=t}get styleSheet(){let e=this.o,t=this.t;if(ee&&e===void 0){let r=t!==void 0&&t.length===1;r&&(e=Me.get(t)),e===void 0&&((this.o=e=new CSSStyleSheet).replaceSync(this.cssText),r&&Me.set(t,e))}return e}toString(){return this.cssText}},Ne=i=>new q(typeof i=="string"?i:i+"",void 0,ce),w=(i,...e)=>{let t=i.length===1?i[0]:e.reduce((r,s,o)=>r+(n=>{if(n._$cssResult$===!0)return n.cssText;if(typeof n=="number")return n;throw Error("Value passed to 'css' function must be a 'css' function result: "+n+". Use 'unsafeCSS' to pass non-literal values, but take care to ensure page security.")})(s)+i[o+1],i[0]);return new q(t,i,ce)},Le=(i,e)=>{if(ee)i.adoptedStyleSheets=e.map(t=>t instanceof CSSStyleSheet?t:t.styleSheet);else for(let t of e){let r=document.createElement("style"),s=Q.litNonce;s!==void 0&&r.setAttribute("nonce",s),r.textContent=t.cssText,i.appendChild(r)}},de=ee?i=>i:i=>i instanceof CSSStyleSheet?(e=>{let t="";for(let r of e.cssRules)t+=r.cssText;return Ne(t)})(i):i;var{is:pt,defineProperty:ht,getOwnPropertyDescriptor:ut,getOwnPropertyNames:mt,getOwnPropertySymbols:gt,getPrototypeOf:yt}=Object,te=globalThis,Ue=te.trustedTypes,ft=Ue?Ue.emptyScript:"",xt=te.reactiveElementPolyfillSupport,G=(i,e)=>i,B={toAttribute(i,e){switch(e){case Boolean:i=i?ft:null;break;case Object:case Array:i=i==null?i:JSON.stringify(i)}return i},fromAttribute(i,e){let t=i;switch(e){case Boolean:t=i!==null;break;case Number:t=i===null?null:Number(i);break;case Object:case Array:try{t=JSON.parse(i)}catch{t=null}}return t}},re=(i,e)=>!pt(i,e),Oe={attribute:!0,type:String,converter:B,reflect:!1,useDefault:!1,hasChanged:re};Symbol.metadata??=Symbol("metadata"),te.litPropertyMetadata??=new WeakMap;var k=class extends HTMLElement{static addInitializer(e){this._$Ei(),(this.l??=[]).push(e)}static get observedAttributes(){return this.finalize(),this._$Eh&&[...this._$Eh.keys()]}static createProperty(e,t=Oe){if(t.state&&(t.attribute=!1),this._$Ei(),this.prototype.hasOwnProperty(e)&&((t=Object.create(t)).wrapped=!0),this.elementProperties.set(e,t),!t.noAccessor){let r=Symbol(),s=this.getPropertyDescriptor(e,r,t);s!==void 0&&ht(this.prototype,e,s)}}static getPropertyDescriptor(e,t,r){let{get:s,set:o}=ut(this.prototype,e)??{get(){return this[t]},set(n){this[t]=n}};return{get:s,set(n){let l=s?.call(this);o?.call(this,n),this.requestUpdate(e,l,r)},configurable:!0,enumerable:!0}}static getPropertyOptions(e){return this.elementProperties.get(e)??Oe}static _$Ei(){if(this.hasOwnProperty(G("elementProperties")))return;let e=yt(this);e.finalize(),e.l!==void 0&&(this.l=[...e.l]),this.elementProperties=new Map(e.elementProperties)}static finalize(){if(this.hasOwnProperty(G("finalized")))return;if(this.finalized=!0,this._$Ei(),this.hasOwnProperty(G("properties"))){let t=this.properties,r=[...mt(t),...gt(t)];for(let s of r)this.createProperty(s,t[s])}let e=this[Symbol.metadata];if(e!==null){let t=litPropertyMetadata.get(e);if(t!==void 0)for(let[r,s]of t)this.elementProperties.set(r,s)}this._$Eh=new Map;for(let[t,r]of this.elementProperties){let s=this._$Eu(t,r);s!==void 0&&this._$Eh.set(s,t)}this.elementStyles=this.finalizeStyles(this.styles)}static finalizeStyles(e){let t=[];if(Array.isArray(e)){let r=new Set(e.flat(1/0).reverse());for(let s of r)t.unshift(de(s))}else e!==void 0&&t.push(de(e));return t}static _$Eu(e,t){let r=t.attribute;return r===!1?void 0:typeof r=="string"?r:typeof e=="string"?e.toLowerCase():void 0}constructor(){super(),this._$Ep=void 0,this.isUpdatePending=!1,this.hasUpdated=!1,this._$Em=null,this._$Ev()}_$Ev(){this._$ES=new Promise(e=>this.enableUpdating=e),this._$AL=new Map,this._$E_(),this.requestUpdate(),this.constructor.l?.forEach(e=>e(this))}addController(e){(this._$EO??=new Set).add(e),this.renderRoot!==void 0&&this.isConnected&&e.hostConnected?.()}removeController(e){this._$EO?.delete(e)}_$E_(){let e=new Map,t=this.constructor.elementProperties;for(let r of t.keys())this.hasOwnProperty(r)&&(e.set(r,this[r]),delete this[r]);e.size>0&&(this._$Ep=e)}createRenderRoot(){let e=this.shadowRoot??this.attachShadow(this.constructor.shadowRootOptions);return Le(e,this.constructor.elementStyles),e}connectedCallback(){this.renderRoot??=this.createRenderRoot(),this.enableUpdating(!0),this._$EO?.forEach(e=>e.hostConnected?.())}enableUpdating(e){}disconnectedCallback(){this._$EO?.forEach(e=>e.hostDisconnected?.())}attributeChangedCallback(e,t,r){this._$AK(e,r)}_$ET(e,t){let r=this.constructor.elementProperties.get(e),s=this.constructor._$Eu(e,r);if(s!==void 0&&r.reflect===!0){let o=(r.converter?.toAttribute!==void 0?r.converter:B).toAttribute(t,r.type);this._$Em=e,o==null?this.removeAttribute(s):this.setAttribute(s,o),this._$Em=null}}_$AK(e,t){let r=this.constructor,s=r._$Eh.get(e);if(s!==void 0&&this._$Em!==s){let o=r.getPropertyOptions(s),n=typeof o.converter=="function"?{fromAttribute:o.converter}:o.converter?.fromAttribute!==void 0?o.converter:B;this._$Em=s;let l=n.fromAttribute(t,o.type);this[s]=l??this._$Ej?.get(s)??l,this._$Em=null}}requestUpdate(e,t,r,s=!1,o){if(e!==void 0){let n=this.constructor;if(s===!1&&(o=this[e]),r??=n.getPropertyOptions(e),!((r.hasChanged??re)(o,t)||r.useDefault&&r.reflect&&o===this._$Ej?.get(e)&&!this.hasAttribute(n._$Eu(e,r))))return;this.C(e,t,r)}this.isUpdatePending===!1&&(this._$ES=this._$EP())}C(e,t,{useDefault:r,reflect:s,wrapped:o},n){r&&!(this._$Ej??=new Map).has(e)&&(this._$Ej.set(e,n??t??this[e]),o!==!0||n!==void 0)||(this._$AL.has(e)||(this.hasUpdated||r||(t=void 0),this._$AL.set(e,t)),s===!0&&this._$Em!==e&&(this._$Eq??=new Set).add(e))}async _$EP(){this.isUpdatePending=!0;try{await this._$ES}catch(t){Promise.reject(t)}let e=this.scheduleUpdate();return e!=null&&await e,!this.isUpdatePending}scheduleUpdate(){return this.performUpdate()}performUpdate(){if(!this.isUpdatePending)return;if(!this.hasUpdated){if(this.renderRoot??=this.createRenderRoot(),this._$Ep){for(let[s,o]of this._$Ep)this[s]=o;this._$Ep=void 0}let r=this.constructor.elementProperties;if(r.size>0)for(let[s,o]of r){let{wrapped:n}=o,l=this[s];n!==!0||this._$AL.has(s)||l===void 0||this.C(s,void 0,o,l)}}let e=!1,t=this._$AL;try{e=this.shouldUpdate(t),e?(this.willUpdate(t),this._$EO?.forEach(r=>r.hostUpdate?.()),this.update(t)):this._$EM()}catch(r){throw e=!1,this._$EM(),r}e&&this._$AE(t)}willUpdate(e){}_$AE(e){this._$EO?.forEach(t=>t.hostUpdated?.()),this.hasUpdated||(this.hasUpdated=!0,this.firstUpdated(e)),this.updated(e)}_$EM(){this._$AL=new Map,this.isUpdatePending=!1}get updateComplete(){return this.getUpdateComplete()}getUpdateComplete(){return this._$ES}shouldUpdate(e){return!0}update(e){this._$Eq&&=this._$Eq.forEach(t=>this._$ET(t,this[t])),this._$EM()}updated(e){}firstUpdated(e){}};k.elementStyles=[],k.shadowRootOptions={mode:"open"},k[G("elementProperties")]=new Map,k[G("finalized")]=new Map,xt?.({ReactiveElement:k}),(te.reactiveElementVersions??=[]).push("2.1.2");var fe=globalThis,He=i=>i,se=fe.trustedTypes,ze=se?se.createPolicy("lit-html",{createHTML:i=>i}):void 0,Be="$lit$",C=`lit$${Math.random().toFixed(9).slice(2)}$`,Ke="?"+C,bt=`<${Ke}>`,N=document,F=()=>N.createComment(""),V=i=>i===null||typeof i!="object"&&typeof i!="function",xe=Array.isArray,$t=i=>xe(i)||typeof i?.[Symbol.iterator]=="function",pe=`[
2
+ \f\r]`,K=/<(?:(!--|\/[^a-zA-Z])|(\/?[a-zA-Z][^>\s]*)|(\/?$))/g,Ie=/-->/g,je=/>/g,R=RegExp(`>|${pe}(?:([^\\s"'>=/]+)(${pe}*=${pe}*(?:[^
3
+ \f\r"'\`<>=]|("|')|))|$)`,"g"),De=/'/g,qe=/"/g,Fe=/^(?:script|style|textarea|title)$/i,be=i=>(e,...t)=>({_$litType$:i,strings:e,values:t}),c=be(1),A=be(2),Ht=be(3),L=Symbol.for("lit-noChange"),d=Symbol.for("lit-nothing"),Ge=new WeakMap,M=N.createTreeWalker(N,129);function Ve(i,e){if(!xe(i)||!i.hasOwnProperty("raw"))throw Error("invalid template strings array");return ze!==void 0?ze.createHTML(e):e}var vt=(i,e)=>{let t=i.length-1,r=[],s,o=e===2?"<svg>":e===3?"<math>":"",n=K;for(let l=0;l<t;l++){let a=i[l],p,m,u=-1,g=0;for(;g<a.length&&(n.lastIndex=g,m=n.exec(a),m!==null);)g=n.lastIndex,n===K?m[1]==="!--"?n=Ie:m[1]!==void 0?n=je:m[2]!==void 0?(Fe.test(m[2])&&(s=RegExp("</"+m[2],"g")),n=R):m[3]!==void 0&&(n=R):n===R?m[0]===">"?(n=s??K,u=-1):m[1]===void 0?u=-2:(u=n.lastIndex-m[2].length,p=m[1],n=m[3]===void 0?R:m[3]==='"'?qe:De):n===qe||n===De?n=R:n===Ie||n===je?n=K:(n=R,s=void 0);let b=n===R&&i[l+1].startsWith("/>")?" ":"";o+=n===K?a+bt:u>=0?(r.push(p),a.slice(0,u)+Be+a.slice(u)+C+b):a+C+(u===-2?l:b)}return[Ve(i,o+(i[t]||"<?>")+(e===2?"</svg>":e===3?"</math>":"")),r]},W=class i{constructor({strings:e,_$litType$:t},r){let s;this.parts=[];let o=0,n=0,l=e.length-1,a=this.parts,[p,m]=vt(e,t);if(this.el=i.createElement(p,r),M.currentNode=this.el.content,t===2||t===3){let u=this.el.content.firstChild;u.replaceWith(...u.childNodes)}for(;(s=M.nextNode())!==null&&a.length<l;){if(s.nodeType===1){if(s.hasAttributes())for(let u of s.getAttributeNames())if(u.endsWith(Be)){let g=m[n++],b=s.getAttribute(u).split(C),S=/([.?@])?(.*)/.exec(g);a.push({type:1,index:o,name:S[2],strings:b,ctor:S[1]==="."?ue:S[1]==="?"?me:S[1]==="@"?ge:O}),s.removeAttribute(u)}else u.startsWith(C)&&(a.push({type:6,index:o}),s.removeAttribute(u));if(Fe.test(s.tagName)){let u=s.textContent.split(C),g=u.length-1;if(g>0){s.textContent=se?se.emptyScript:"";for(let b=0;b<g;b++)s.append(u[b],F()),M.nextNode(),a.push({type:2,index:++o});s.append(u[g],F())}}}else if(s.nodeType===8)if(s.data===Ke)a.push({type:2,index:o});else{let u=-1;for(;(u=s.data.indexOf(C,u+1))!==-1;)a.push({type:7,index:o}),u+=C.length-1}o++}}static createElement(e,t){let r=N.createElement("template");return r.innerHTML=e,r}};function U(i,e,t=i,r){if(e===L)return e;let s=r!==void 0?t._$Co?.[r]:t._$Cl,o=V(e)?void 0:e._$litDirective$;return s?.constructor!==o&&(s?._$AO?.(!1),o===void 0?s=void 0:(s=new o(i),s._$AT(i,t,r)),r!==void 0?(t._$Co??=[])[r]=s:t._$Cl=s),s!==void 0&&(e=U(i,s._$AS(i,e.values),s,r)),e}var he=class{constructor(e,t){this._$AV=[],this._$AN=void 0,this._$AD=e,this._$AM=t}get parentNode(){return this._$AM.parentNode}get _$AU(){return this._$AM._$AU}u(e){let{el:{content:t},parts:r}=this._$AD,s=(e?.creationScope??N).importNode(t,!0);M.currentNode=s;let o=M.nextNode(),n=0,l=0,a=r[0];for(;a!==void 0;){if(n===a.index){let p;a.type===2?p=new J(o,o.nextSibling,this,e):a.type===1?p=new a.ctor(o,a.name,a.strings,this,e):a.type===6&&(p=new ye(o,this,e)),this._$AV.push(p),a=r[++l]}n!==a?.index&&(o=M.nextNode(),n++)}return M.currentNode=N,s}p(e){let t=0;for(let r of this._$AV)r!==void 0&&(r.strings!==void 0?(r._$AI(e,r,t),t+=r.strings.length-2):r._$AI(e[t])),t++}},J=class i{get _$AU(){return this._$AM?._$AU??this._$Cv}constructor(e,t,r,s){this.type=2,this._$AH=d,this._$AN=void 0,this._$AA=e,this._$AB=t,this._$AM=r,this.options=s,this._$Cv=s?.isConnected??!0}get parentNode(){let e=this._$AA.parentNode,t=this._$AM;return t!==void 0&&e?.nodeType===11&&(e=t.parentNode),e}get startNode(){return this._$AA}get endNode(){return this._$AB}_$AI(e,t=this){e=U(this,e,t),V(e)?e===d||e==null||e===""?(this._$AH!==d&&this._$AR(),this._$AH=d):e!==this._$AH&&e!==L&&this._(e):e._$litType$!==void 0?this.$(e):e.nodeType!==void 0?this.T(e):$t(e)?this.k(e):this._(e)}O(e){return this._$AA.parentNode.insertBefore(e,this._$AB)}T(e){this._$AH!==e&&(this._$AR(),this._$AH=this.O(e))}_(e){this._$AH!==d&&V(this._$AH)?this._$AA.nextSibling.data=e:this.T(N.createTextNode(e)),this._$AH=e}$(e){let{values:t,_$litType$:r}=e,s=typeof r=="number"?this._$AC(e):(r.el===void 0&&(r.el=W.createElement(Ve(r.h,r.h[0]),this.options)),r);if(this._$AH?._$AD===s)this._$AH.p(t);else{let o=new he(s,this),n=o.u(this.options);o.p(t),this.T(n),this._$AH=o}}_$AC(e){let t=Ge.get(e.strings);return t===void 0&&Ge.set(e.strings,t=new W(e)),t}k(e){xe(this._$AH)||(this._$AH=[],this._$AR());let t=this._$AH,r,s=0;for(let o of e)s===t.length?t.push(r=new i(this.O(F()),this.O(F()),this,this.options)):r=t[s],r._$AI(o),s++;s<t.length&&(this._$AR(r&&r._$AB.nextSibling,s),t.length=s)}_$AR(e=this._$AA.nextSibling,t){for(this._$AP?.(!1,!0,t);e!==this._$AB;){let r=He(e).nextSibling;He(e).remove(),e=r}}setConnected(e){this._$AM===void 0&&(this._$Cv=e,this._$AP?.(e))}},O=class{get tagName(){return this.element.tagName}get _$AU(){return this._$AM._$AU}constructor(e,t,r,s,o){this.type=1,this._$AH=d,this._$AN=void 0,this.element=e,this.name=t,this._$AM=s,this.options=o,r.length>2||r[0]!==""||r[1]!==""?(this._$AH=Array(r.length-1).fill(new String),this.strings=r):this._$AH=d}_$AI(e,t=this,r,s){let o=this.strings,n=!1;if(o===void 0)e=U(this,e,t,0),n=!V(e)||e!==this._$AH&&e!==L,n&&(this._$AH=e);else{let l=e,a,p;for(e=o[0],a=0;a<o.length-1;a++)p=U(this,l[r+a],t,a),p===L&&(p=this._$AH[a]),n||=!V(p)||p!==this._$AH[a],p===d?e=d:e!==d&&(e+=(p??"")+o[a+1]),this._$AH[a]=p}n&&!s&&this.j(e)}j(e){e===d?this.element.removeAttribute(this.name):this.element.setAttribute(this.name,e??"")}},ue=class extends O{constructor(){super(...arguments),this.type=3}j(e){this.element[this.name]=e===d?void 0:e}},me=class extends O{constructor(){super(...arguments),this.type=4}j(e){this.element.toggleAttribute(this.name,!!e&&e!==d)}},ge=class extends O{constructor(e,t,r,s,o){super(e,t,r,s,o),this.type=5}_$AI(e,t=this){if((e=U(this,e,t,0)??d)===L)return;let r=this._$AH,s=e===d&&r!==d||e.capture!==r.capture||e.once!==r.once||e.passive!==r.passive,o=e!==d&&(r===d||s);s&&this.element.removeEventListener(this.name,this,r),o&&this.element.addEventListener(this.name,this,e),this._$AH=e}handleEvent(e){typeof this._$AH=="function"?this._$AH.call(this.options?.host??this.element,e):this._$AH.handleEvent(e)}},ye=class{constructor(e,t,r){this.element=e,this.type=6,this._$AN=void 0,this._$AM=t,this.options=r}get _$AU(){return this._$AM._$AU}_$AI(e){U(this,e)}};var At=fe.litHtmlPolyfillSupport;At?.(W,J),(fe.litHtmlVersions??=[]).push("3.3.2");var We=(i,e,t)=>{let r=t?.renderBefore??e,s=r._$litPart$;if(s===void 0){let o=t?.renderBefore??null;r._$litPart$=s=new J(e.insertBefore(F(),o),o,void 0,t??{})}return s._$AI(i),s};var $e=globalThis,P=class extends k{constructor(){super(...arguments),this.renderOptions={host:this},this._$Do=void 0}createRenderRoot(){let e=super.createRenderRoot();return this.renderOptions.renderBefore??=e.firstChild,e}update(e){let t=this.render();this.hasUpdated||(this.renderOptions.isConnected=this.isConnected),super.update(e),this._$Do=We(t,this.renderRoot,this.renderOptions)}connectedCallback(){super.connectedCallback(),this._$Do?.setConnected(!0)}disconnectedCallback(){super.disconnectedCallback(),this._$Do?.setConnected(!1)}render(){return L}};P._$litElement$=!0,P.finalized=!0,$e.litElementHydrateSupport?.({LitElement:P});var wt=$e.litElementPolyfillSupport;wt?.({LitElement:P});($e.litElementVersions??=[]).push("4.2.2");var ne=i=>(e,t)=>{t!==void 0?t.addInitializer(()=>{customElements.define(i,e)}):customElements.define(i,e)};var St={attribute:!0,type:String,converter:B,reflect:!1,hasChanged:re},_t=(i=St,e,t)=>{let{kind:r,metadata:s}=t,o=globalThis.litPropertyMetadata.get(s);if(o===void 0&&globalThis.litPropertyMetadata.set(s,o=new Map),r==="setter"&&((i=Object.create(i)).wrapped=!0),o.set(t.name,i),r==="accessor"){let{name:n}=t;return{set(l){let a=e.get.call(this);e.set.call(this,l),this.requestUpdate(n,a,i,!0,l)},init(l){return l!==void 0&&this.C(n,void 0,i,l),l}}}if(r==="setter"){let{name:n}=t;return function(l){let a=this[n];e.call(this,l),this.requestUpdate(n,a,i,!0,l)}}throw Error("Unsupported decorator location: "+r)};function $(i){return(e,t)=>typeof t=="object"?_t(i,e,t):((r,s,o)=>{let n=s.hasOwnProperty(o);return s.constructor.createProperty(o,r),n?Object.getOwnPropertyDescriptor(s,o):void 0})(i,e,t)}function Y(i){return $({...i,state:!0,attribute:!1})}var _={Sun:"\u2609",Moon:"\u263D",Mercury:"\u263F",Venus:"\u2640",Earth:"\u2641",Mars:"\u2642",Jupiter:"\u2643",Saturn:"\u2644",Uranus:"\u2645",Neptune:"\u2646",Pluto:"\u2647",Rahu:"\u260A",Ketu:"\u260B",Ascendant:"Asc",Lagna:"La",NorthNode:"\u260A",SouthNode:"\u260B","North node":"\u260A","South node":"\u260B",Chiron:"\u26B7",Lilith:"\u26B8","Black moon lilith":"\u26B8"};var Je={Aries:"\u2648",Taurus:"\u2649",Gemini:"\u264A",Cancer:"\u264B",Leo:"\u264C",Virgo:"\u264D",Libra:"\u264E",Scorpio:"\u264F",Sagittarius:"\u2650",Capricorn:"\u2651",Aquarius:"\u2652",Pisces:"\u2653"};var H=["Aries","Taurus","Gemini","Cancer","Leo","Virgo","Libra","Scorpio","Sagittarius","Capricorn","Aquarius","Pisces"],wr=H.map(i=>i.toLowerCase()),ve={conjunction:"\u260C",opposition:"\u260D",trine:"\u25B3",square:"\u25A1",sextile:"\u2731",quincunx:"\u22BB",semisextile:"\u22BC"};var Ye=i=>i??d;var z=w`:host{font-family:var(--roxy-font-sans,system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);color:var(--roxy-fg,#0a0a0a);font-size:var(--roxy-text-base,1rem);line-height:var(--roxy-leading-normal,1.5);animation:roxy-fade-in var(--roxy-motion-duration,.2s) var(--roxy-motion-easing,cubic-bezier(.4, 0, .2, 1)) both;background:0 0;display:block;container-type:inline-size}:host([bare]){--roxy-surface:transparent;--roxy-shadow-sm:none;--roxy-shadow-md:none}*,:before,:after{box-sizing:border-box}@keyframes roxy-fade-in{0%{opacity:0;transform:translateY(2px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion:reduce){:host{animation:none}}.roxy-skeleton{background:linear-gradient(90deg, var(--roxy-border,#e4e4e7) 0%, color-mix(in srgb, var(--roxy-border,#e4e4e7) 60%, transparent) 50%, var(--roxy-border,#e4e4e7) 100%);border-radius:var(--roxy-radius-md,8px);background-size:200% 100%;animation:1.4s ease-in-out infinite roxy-shimmer}@keyframes roxy-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (prefers-reduced-motion:reduce){.roxy-skeleton{animation:none}}.roxy-empty{padding:var(--roxy-space-lg,1.5rem);color:var(--roxy-muted,#71717a);text-align:center;font-size:var(--roxy-text-sm,.875rem)}.roxy-error{gap:var(--roxy-space-sm,.5rem);padding:var(--roxy-space-lg,1.5rem);background:var(--roxy-surface,#fff);border:1px solid var(--roxy-danger,#dc2626);border-radius:var(--roxy-radius-md,8px);color:var(--roxy-danger-fg,#991b1b);font-size:var(--roxy-text-sm,.875rem);justify-items:start;display:grid}.roxy-surface{background:var(--roxy-surface,#fff);color:var(--roxy-fg,#0a0a0a)}:host(:focus-within) .roxy-card{outline:2px solid var(--roxy-ring,#f59e0b66);outline-offset:2px}:host{font-variant-emoji:text}`;var Et="https://roxyapi.com/api/v2",ie=class{constructor(e){this.baseUrl=Et;this.host=e,e.addController(this)}hostDisconnected(){this.abort?.abort(),this.abort=void 0}async run(e){if(!this.submitUrl&&this.secretKeyRefused())return;this.abort?.abort();let t=new AbortController;this.abort=t,this.host.loading=!0,this.host.error=null;try{let r=this.submitUrl?await fetch(this.submitUrl,{method:"POST",headers:{Accept:"application/json","Content-Type":"application/json"},body:JSON.stringify(e),signal:t.signal}):await this.callApi(e,t.signal);if(!r.ok)throw new Error(await this.readError(r));let s=await r.json();if(t.signal.aborted)return;this.host.data=s}catch(r){if(r?.name==="AbortError")return;this.host.error=r instanceof Error?r.message:String(r)}finally{this.abort===t&&(this.abort=void 0),t.signal.aborted||(this.host.loading=!1)}}callApi(e,t){let r=new URL(`${this.baseUrl}${e.path}`);for(let[o,n]of Object.entries(e.query??{}))n!=null&&r.searchParams.set(o,String(n));let s={Accept:"application/json"};return this.publishableKey&&(s["X-API-Key"]=this.publishableKey),e.body!=null&&(s["Content-Type"]="application/json"),fetch(r,{method:e.method??"GET",headers:s,body:e.body!=null?JSON.stringify(e.body):void 0,signal:t})}secretKeyRefused(){let e=this.publishableKey;return!e||e.startsWith("pk_")?!1:(this.host.error="Client-side components accept a pk_ publishable key only. Use a publishable key with an origin allowlist, or render server-side.",this.host.dispatchEvent(new CustomEvent("roxy-validation-error",{detail:{reason:"possible-secret-key"},bubbles:!0,composed:!0})),!0)}async readError(e){try{let t=await e.json();if(t?.error)return t.error}catch{}return`Request failed (${e.status})`}};function Ze(i,e,t){let r={...t},s=`/${i.replace(/^\//,"")}`.replace(/\{([^}]+)\}/g,(l,a)=>{let p=r[a];return delete r[a],encodeURIComponent(String(p??""))}),o={},n={};for(let[l,a]of Object.entries(r))a===void 0||a===""||(e==="GET"?o[l]=a:n[l]=a);return{path:s,method:e,query:o,body:e==="POST"?n:void 0}}var kt="roxy-data";function Ct(i){return i.nodeName==="SCRIPT"&&i.getAttribute("type")==="application/json"}var ae=class{constructor(e){this.host=e,e.addController(this)}hostConnected(){if(this.host.data!=null)return;let e=this.read();e!==void 0&&(this.host.data=e,this.host.requestUpdate())}read(){let e=this.findInlineScript();return e?this.parse(e.textContent):void 0}findInlineScript(){for(let e of Array.from(this.host.children))if(Ct(e)&&e.classList.contains(kt))return e;return null}parse(e){if(e?.trim())try{return JSON.parse(e)}catch{return}}};var x=class extends P{constructor(){super();this.data=null;this.endpoint="";this.method="POST";this.remember=!1;this.loading=!1;this.error=null;this.onFormSubmit=t=>{let r=t.detail;this.remember&&this.writeRemembered(r.values),this.fetcher.run(Ze(this.endpoint,this.method,r.values))};new ae(this),this.fetcher=new ie(this)}static{this.styles=[z]}willUpdate(t){t.has("publishableKey")&&(this.fetcher.publishableKey=this.publishableKey),t.has("baseUrl")&&this.baseUrl&&(this.fetcher.baseUrl=this.baseUrl),t.has("submitUrl")&&(this.fetcher.submitUrl=this.submitUrl)}render(){return this.loading?this.renderLoading():this.error!=null?this.renderError(this.error):this.data!=null?this.renderData(this.data):this.renderNoData()}renderNoData(){return this.endpoint?this.renderForm():this.renderEmpty()}renderForm(){return c`<roxy-endpoint-form data-endpoint="${this.endpoint}" method="${this.method}" spec-url="${Ye(this.specUrl)}" .initialValues="${this.remember?this.readRemembered():void 0}" @roxy-submit="${this.onFormSubmit}"></roxy-endpoint-form>`}rememberKey(){return`roxy-ui:form:${this.endpoint}`}readRemembered(){try{let t=sessionStorage.getItem(this.rememberKey());return t?JSON.parse(t):void 0}catch{return}}writeRemembered(t){try{sessionStorage.setItem(this.rememberKey(),JSON.stringify(t))}catch{}}renderEmpty(){return c`<div class="roxy-empty" role="status">No data</div>`}renderLoading(){return c`<div class="roxy-skeleton" style="height:8rem" role="status" aria-label="Loading"></div>`}renderError(t){let r=c`<div class="roxy-error" role="alert">${t}</div>`;return this.endpoint?c`${r}${this.renderForm()}`:r}};y([$({attribute:!1})],x.prototype,"data",2),y([$({type:String,attribute:"data-endpoint"})],x.prototype,"endpoint",2),y([$({type:String})],x.prototype,"method",2),y([$({type:String,attribute:"publishable-key"})],x.prototype,"publishableKey",2),y([$({type:String,attribute:"base-url"})],x.prototype,"baseUrl",2),y([$({type:String,attribute:"spec-url"})],x.prototype,"specUrl",2),y([$({type:String,attribute:"submit-url"})],x.prototype,"submitUrl",2),y([$({type:Boolean})],x.prototype,"remember",2),y([Y()],x.prototype,"loading",2),y([Y()],x.prototype,"error",2);function E(i){let e=i%360;return e<0?e+360:e}function Ae(i){let e=E(i),t=Math.floor(e/30)%12,r=e%30,s=Math.floor(r),o=(r-s)*60,n=Math.floor(o),l=Math.round((o-n)*60);return{sign:H[t]??"Aries",signIndex:t,degree:s,minute:n,second:l}}function we(i){return E(i+180)}function Xe(i,e){let t=E(i),r=E(e)-t;return r<0&&(r+=360),E(t+r/2)}function f(i,e,t,r){let s=r*Math.PI/180;return{x:i+t*Math.cos(s),y:e+t*Math.sin(s)}}function Qe(){return c`<svg class="roxy-chevron" viewBox="0 0 16 16" width="14" height="14" aria-hidden="true"><path d="M4 6l4 4 4-4" fill="none" stroke="currentColor" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/></svg>`}var et=w`summary{list-style:none}summary::-webkit-details-marker{display:none}.roxy-chevron{aspect-ratio:auto;width:14px;height:14px;color:var(--roxy-muted,#71717a);transition:transform var(--roxy-motion-duration,.2s) var(--roxy-motion-easing,ease);flex-shrink:0}details[open]>summary .roxy-chevron{transform:rotate(180deg)}@media (prefers-reduced-motion:reduce){.roxy-chevron{transition:none}}`;function le(i,e=1){return typeof i!="number"||!Number.isFinite(i)?"":i.toFixed(e).replace(/\.?0+$/,"")}var Se={conjunction:"aspect-conjunction",sextile:"aspect-sextile",square:"aspect-square",trine:"aspect-trine",opposition:"aspect-opposition"};function _e(i){return(i.type??"").toLowerCase().replace(/_/g,"-")}function v(i){return i?i.charAt(0).toUpperCase()+i.slice(1).toLowerCase():""}var tt=w`.roxy-tablist{border-bottom:2px solid var(--roxy-border,#e4e4e7);gap:2px;display:flex}.roxy-tab{padding:var(--roxy-space-xs,.25rem) var(--roxy-space-md,1rem);font-size:var(--roxy-text-sm,.875rem);cursor:pointer;color:var(--roxy-muted,#71717a);transition:color var(--roxy-motion-duration,.2s) var(--roxy-motion-easing,ease);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;font-family:inherit}.roxy-tab[aria-selected=true]{color:var(--roxy-accent-ink,#b45309);border-bottom-color:var(--roxy-accent,#f59e0b);font-weight:var(--roxy-weight-bold,600)}.roxy-tab:hover:not([aria-selected=true]){color:var(--roxy-fg,#0a0a0a)}.roxy-tab:focus-visible{outline:2px solid var(--roxy-ring,#f59e0b66);outline-offset:2px;border-radius:4px}`;function rt(i){let{items:e,active:t,onSelect:r,label:s,idPrefix:o,controls:n=!1}=i;return c`<div class="roxy-tablist" role="tablist" aria-label="${s}" @keydown="${a=>{if(a.key!=="ArrowRight"&&a.key!=="ArrowLeft")return;a.preventDefault();let p=e.findIndex(b=>b.id===t);if(p===-1)return;let m=a.key==="ArrowRight"?1:-1,u=e[(p+m+e.length)%e.length];if(!u)return;r(u.id);let g=a.currentTarget.getRootNode();requestAnimationFrame(()=>{g.querySelector(`#${o}-tab-${u.id}`)?.focus()})}}">${e.map(a=>c`<button type="button" class="roxy-tab" role="tab" id="${o}-tab-${a.id}" aria-selected="${t===a.id?"true":"false"}" aria-controls="${n&&t===a.id?`${o}-panel-${a.id}`:d}" tabindex="${t===a.id?"0":"-1"}" @click="${()=>r(a.id)}">${a.label}</button>`)}</div>`}var ke=420,h=ke/2,I=164,Ee=146,Z=120,j=96,Pt=178,Tt=196,T=class extends x{constructor(){super(...arguments);this.houseSystem="placidus";this.heading="Natal chart";this.view="wheel"}getPlanets(){return this.data?.planets??[]}getAscendant(){return this.data?.ascendant?.longitude??0}getMidheaven(){let t=this.data?.midheaven?.longitude;return typeof t=="number"?t:null}toAngle(t){return 180+this.getAscendant()-t}renderEmpty(){return c`<div class="roxy-empty" role="status">No chart data</div>`}renderData(t){let r=this.getPlanets(),s=t.aspects??[],o=this.view;return c`<div class="wrap"><header><h2 class="title">${this.heading}</h2>${t.birthDetails?c`<div class="meta">${[t.birthDetails.date,t.birthDetails.time].filter(Boolean).join(" \xB7 ")}</div>`:d}</header>${s.length>0?c`${rt({items:[{id:"wheel",label:"Wheel"},{id:"grid",label:"Aspect grid"}],active:o,onSelect:n=>{this.view=n},label:"Natal chart views",idPrefix:"natal",controls:!0})}<div id="natal-panel-${o}" role="tabpanel" aria-labelledby="natal-tab-${o}">${o==="wheel"?this.renderWheel(r,s):this.renderAspectGrid(r,s)}</div>`:this.renderWheel(r,s)}<div class="legend"><span>${r.length} planets</span> ${s.length>0?c`<span>${s.length} aspects</span>`:d} ${t.houseSystem?c`<span>${t.houseSystem} houses</span>`:d} ${s.length>0?c`<span><span class="legend-swatch" style="background:var(--roxy-success)"></span>harmonious</span> <span><span class="legend-swatch" style="background:var(--roxy-danger)"></span>challenging</span>`:d}</div>${this.renderDetails()} ${this.renderInterpretations()}</div>`}renderWheel(t,r){return c`<svg viewBox="0 0 ${ke} ${ke}" role="img" aria-label="Natal chart wheel with twelve houses, planets, and aspects"><title>Natal chart wheel</title><desc>Twelve zodiac sign segments around a circular wheel. Planet glyphs are placed at their ecliptic longitudes. Aspect lines connect related planets.</desc><circle class="wheel-line" cx="${h}" cy="${h}" r="${I}" stroke-width="1.5"/><circle class="wheel-line" cx="${h}" cy="${h}" r="${Ee-14}" stroke-width="0.8"/><circle class="wheel-line" cx="${h}" cy="${h}" r="${Z}" stroke-width="1"/><circle class="wheel-line" cx="${h}" cy="${h}" r="${j-16}" stroke-width="0.5"/>${this.renderTicks()} ${this.renderSpokes()} ${this.renderSigns()} ${this.renderHouseNumbers()} ${this.renderCuspDegrees()} ${this.renderAspects(t,r)} ${this.renderPlanets(t)} ${this.renderAngles()}</svg>`}renderAspectGrid(t,r){let s=t.map(n=>v(n.name)),o=new Map;for(let n of r){let l=[v(n.planet1),v(n.planet2)].sort().join("|");o.set(l,n)}return s.length===0?c`<p class="roxy-empty" role="status">No planets to grid</p>`:c`<div class="grid-scroll"><table class="aspect-grid" aria-label="Planet by planet aspect grid"><thead><tr><th></th>${s.slice(0,-1).map(n=>{let l=_[n]??n.slice(0,2);return c`<th scope="col" title="${n}">${l}</th>`})}</tr></thead><tbody>${s.slice(1).map((n,l)=>{let a=_[n]??n.slice(0,2);return c`<tr><th scope="row" title="${n}">${a}</th>${s.slice(0,l+1).map(p=>{let m=o.get([n,p].sort().join("|"));if(!m)return c`<td class="empty"></td>`;let u=_e(m),g=ve[u]??ve[u.replace(/-/g,"")]??u.slice(0,3),b=Se[u]??"aspect-other",S=le(m.orb,1);return c`<td class="${`cell ${b}`}" title="${`${n} ${u} ${p}${S?` (orb ${S}\xB0)`:""}`}"><span class="asp">${g}</span></td>`})} ${s.slice(l+1,-1).map(()=>c`<td class="empty"></td>`)}</tr>`})}</tbody></table></div>`}renderAngles(){let t=this.getAscendant(),r=this.getMidheaven(),s=[this.renderAngleMark(t,"ASC"),this.renderAngleMark(we(t),"DSC")];r!==null&&(s.push(this.renderAngleMark(r,"MC")),s.push(this.renderAngleMark(we(r),"IC")));let o=this.data?.partOfFortune?.longitude;typeof o=="number"&&s.push(this.renderAngleMark(E(o),"PoF"));let n=this.data?.vertex?.longitude;return typeof n=="number"&&s.push(this.renderAngleMark(E(n),"Vtx")),s}renderAngleMark(t,r){let s=this.toAngle(t),o=f(h,h,I,s),n=f(h,h,Pt,s),l=f(h,h,Tt,s);return A`
4
+ <g>
5
+ <line class="angle-tick" x1=${o.x} y1=${o.y} x2=${n.x} y2=${n.y} />
6
+ <text class="angle-marker" x=${l.x} y=${l.y} text-anchor="middle" dominant-baseline="central">${r}</text>
7
+ </g>
8
+ `}renderSpokes(){let t=this.data?.houses??[];return(t.length===12?t.map(s=>s.longitude):Array.from({length:12},(s,o)=>this.getAscendant()+o*30)).map(s=>{let o=this.toAngle(s),n=f(h,h,Z,o),l=f(h,h,I,o);return A`<line class="wheel-line" x1=${n.x} y1=${n.y} x2=${l.x} y2=${l.y} stroke-width="0.8" />`})}renderSigns(){return H.map((t,r)=>{let s=this.toAngle(r*30+15),o=f(h,h,Ee,s);return A`<text class="sign-glyph" x=${o.x} y=${o.y} text-anchor="middle" dominant-baseline="central">${Je[t]}</text>`})}renderHouseNumbers(){let t=this.data?.houses??[];if(t.length===12)return t.map((s,o)=>{let n=t[(o+1)%12],l=Xe(s.longitude,n?n.longitude:s.longitude+30),a=f(h,h,Z-12,this.toAngle(l));return A`<text class="house-num" x=${a.x} y=${a.y} text-anchor="middle" dominant-baseline="central">${s.number}</text>`});let r=Math.floor(this.getAscendant()/30);return Array.from({length:12},(s,o)=>{let n=this.toAngle(o*30+15),l=f(h,h,Z-12,n),a=(o-r+12)%12+1;return A`<text class="house-num" x=${l.x} y=${l.y} text-anchor="middle" dominant-baseline="central">${a}</text>`})}renderTicks(){let t=[];for(let r=0;r<360;r+=5){let s=this.toAngle(r),o=r%30===0,n=o?Ee-14:I-5,l=f(h,h,n,s),a=f(h,h,I,s);t.push(A`<line class=${o?"tick tick-major":"tick"} x1=${l.x} y1=${l.y} x2=${a.x} y2=${a.y} stroke-width=${o?1:.5} />`)}return t}renderCuspDegrees(){let t=this.data?.houses??[];return t.length!==12?d:t.map(r=>{let s=this.toAngle(r.longitude),o=f(h,h,Z+9,s),n=Ae(r.longitude);return A`<text class="cusp-deg" x=${o.x} y=${o.y} text-anchor="middle" dominant-baseline="central">${n.degree}°${String(n.minute).padStart(2,"0")}'</text>`})}renderPlanets(t){let s=t.filter(n=>Number.isFinite(n.longitude)).map(n=>({p:n,trueLon:E(n.longitude),displayLon:E(n.longitude)})).sort((n,l)=>n.trueLon-l.trueLon);for(let n=1;n<s.length;n++){let l=s[n-1],a=s[n];if(!l||!a)continue;let p=l.displayLon+7;a.displayLon<p&&(a.displayLon=p)}let o=s[s.length-1];if(o&&o.displayLon>360){let n=o.displayLon-360;for(let l of s)l.displayLon-=n}return s.map(({p:n,trueLon:l,displayLon:a})=>{let p=this.toAngle(l),m=this.toAngle(a),u=f(h,h,j,m),g=f(h,h,j-13,m),b=f(h,h,I-4,p),S=f(h,h,j+8,m),nt=_[v(n.name)]??n.name.slice(0,2),Ce=Ae(n.longitude),Pe=n.isRetrograde===!0,Te=`${Ce.degree}\xB0${String(Ce.minute).padStart(2,"0")}'`,ot=Math.abs(a-l)>.5;return A`<g>
9
+ ${ot?A`<line class="planet-leader" x1=${b.x} y1=${b.y} x2=${S.x} y2=${S.y} />`:d}
10
+ <text class="planet-glyph" x=${u.x} y=${u.y} text-anchor="middle" dominant-baseline="central"><title>${n.name}${Pe?" retrograde":""} - ${Te} ${n.sign??""}</title>${nt}</text>
11
+ <text class="planet-deg" x=${g.x} y=${g.y} text-anchor="middle" dominant-baseline="central">${Te}${Pe?A`<tspan class="retro"> ℞</tspan>`:d}</text>
12
+ </g>`})}renderDetails(){let t=this.data?.summary,r=this.data?.aspectsInterpretation;if(!t&&!r)return d;let s=t?.retrogradePlanets??[];return c`<div class="details">${t?.dominantElement||t?.dominantModality?c`<div class="pill-row">${t.dominantElement?c`<span class="pill">Dominant element: ${t.dominantElement}</span>`:d} ${t.dominantModality?c`<span class="pill">Dominant modality: ${t.dominantModality}</span>`:d}</div>`:d} ${r?c`<div class="pill-row"><span class="pill pill--success">Harmonious ${r.harmonious}</span> <span class="pill pill--danger">Challenging ${r.challenging}</span> <span class="pill pill--muted">Neutral ${r.neutral}</span></div>`:d} ${s.length>0?c`<div class="pill-row">${s.map(o=>{let n=_[o]??o.slice(0,2);return c`<span class="pill pill--muted">${n} ${o} R</span>`})}</div>`:d} ${r?.summary?c`<p class="summary">${r.summary}</p>`:d} ${this.renderElementModalityGrid()}</div>`}renderElementModalityGrid(){let t=this.getPlanets();if(t.length===0)return d;let r=["Fire","Earth","Air","Water"],s=["Cardinal","Fixed","Mutable"],o=H,n={};for(let l of r)n[l]={Cardinal:[],Fixed:[],Mutable:[]};for(let l of t){let a=o.indexOf(v(l.sign??""));if(a<0)continue;let p=r[a%4],m=s[a%3],u=_[v(l.name)]??v(l.name).slice(0,2);n[p]?.[m]?.push(u)}return c`<table class="em-grid" aria-label="Element and modality distribution"><thead><tr><th></th>${s.map(l=>c`<th scope="col">${l.slice(0,3)}</th>`)}<th scope="col">Total</th></tr></thead><tbody>${r.map(l=>{let a=s.reduce((p,m)=>p+(n[l]?.[m]?.length??0),0);return c`<tr><th scope="row">${l}</th>${s.map(p=>c`<td>${(n[l]?.[p]??[]).join(" ")}</td>`)}<td class="em-total">${a}</td></tr>`})}<tr><th scope="row">Total</th>${s.map(l=>c`<td class="em-total">${r.reduce((a,p)=>a+(n[p]?.[l]?.length??0),0)}</td>`)}<td class="em-total">${t.length}</td></tr></tbody></table>`}renderInterpretations(){let t=this.getPlanets().filter(r=>r.interpretation);return t.length===0?d:c`<section class="interpretations"><h3>Planet readings</h3>${t.map((r,s)=>{let o=r.interpretation,n=_[v(r.name)]??"",l=le(r.degree??0,1);return c`<details class="interp-card" name="natal-planet-readings" ?open="${s===0}"><summary><span>${n} ${r.name}</span> <span class="interp-aside"><small>${r.sign??""} ${l}</small> ${Qe()}</span></summary><div class="interp-body">${o.summary?c`<p class="interp-summary">${o.summary}</p>`:d} ${o.detailed?c`<p class="interp-detail">${o.detailed}</p>`:d} ${o.keywords?.length?c`<div class="interp-keywords">${o.keywords.map(a=>c`<span class="kw">${a}</span>`)}</div>`:d}</div></details>`})}</section>`}renderAspects(t,r){let s=new Map;for(let o of t){if(typeof o.longitude!="number")continue;let n=v(o.name);n&&s.set(n,o.longitude)}return r.map(o=>{let n=s.get(v(o.planet1)),l=s.get(v(o.planet2));if(n===void 0||l===void 0)return d;let a=f(h,h,j-18,this.toAngle(n)),p=f(h,h,j-18,this.toAngle(l)),m=_e(o),u=Se[m]??"aspect-other",g=le(o.orb,1);return A`<line class=${`aspect ${u}`} x1=${a.x} y1=${a.y} x2=${p.x} y2=${p.y}><title>${o.planet1} ${m||""} ${o.planet2}${g?` (orb ${g}\xB0)`:""}</title></line>`})}};T.styles=[z,tt,et,w`.wrap{background:var(--roxy-surface,#fff);width:100%;color:var(--roxy-fg,#0a0a0a);border:1px solid var(--roxy-border,#e4e4e7);border-radius:var(--roxy-radius-md,8px);padding:var(--roxy-space-lg,1.5rem);box-shadow:var(--roxy-shadow-sm);gap:var(--roxy-space-md,1rem);display:grid}.title{font-size:var(--roxy-text-lg,1.125rem);font-weight:var(--roxy-weight-bold,600);color:var(--roxy-primary,#0f172a);margin:0}.meta{color:var(--roxy-muted,#71717a);font-size:var(--roxy-text-sm,.875rem)}svg{width:100%;max-width:var(--roxy-chart-max-width,560px);aspect-ratio:1;height:auto;margin:0 auto;display:block}.wheel-line{fill:none;stroke:var(--roxy-border,#e4e4e7)}.sign-glyph{fill:var(--roxy-secondary,#475569);font-size:14px;font-family:var(--roxy-font-sans)}.planet-glyph{fill:var(--roxy-accent,#f59e0b);font-size:14px;font-weight:600;font-family:var(--roxy-font-sans)}.planet-deg{fill:var(--roxy-fg,#0a0a0a);font-size:7px;font-family:var(--roxy-font-sans)}@container (width<=480px){.sign-glyph,.planet-glyph{font-size:18px}.planet-deg{font-size:10px}.house-num{font-size:12px}}.planet-deg .retro{fill:var(--roxy-danger,#dc2626)}.planet-leader{stroke:var(--roxy-accent,#f59e0b);stroke-width:.5px;opacity:.55}.house-num{fill:var(--roxy-muted,#71717a);font-size:9px;font-family:var(--roxy-font-sans)}.cusp-deg{fill:var(--roxy-muted,#71717a);font-size:6px;font-family:var(--roxy-font-sans)}.tick{stroke:var(--roxy-border,#e4e4e7)}.tick-major{stroke:var(--roxy-secondary,#475569)}.aspect{stroke-width:.8px;fill:none;opacity:.55}.aspect-trine,.aspect-sextile{stroke:var(--roxy-success,#16a34a)}.aspect-square,.aspect-opposition{stroke:var(--roxy-danger,#dc2626)}.aspect-conjunction{stroke:var(--roxy-accent-ink,#b45309)}.aspect-other{stroke:var(--roxy-muted,#71717a);opacity:.4}.angle-marker{fill:var(--roxy-accent-ink,#b45309);font-size:10px;font-weight:700;font-family:var(--roxy-font-sans);letter-spacing:.04em}.angle-tick{stroke:var(--roxy-accent-ink,#b45309);stroke-width:1.5px}.legend{font-size:var(--roxy-text-xs,.75rem);color:var(--roxy-muted,#71717a);gap:var(--roxy-space-md,1rem);flex-wrap:wrap;display:flex}.legend-swatch{vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:4px;display:inline-block}.grid-scroll{-webkit-overflow-scrolling:touch;overflow-x:auto}table.aspect-grid{border-collapse:collapse;font-size:var(--roxy-text-xs,.75rem);margin:0 auto}table.aspect-grid th,table.aspect-grid td{text-align:center;border:1px solid var(--roxy-border,#e4e4e7);width:1.6rem;height:1.6rem;padding:0}table.aspect-grid th{color:var(--roxy-secondary,#475569);font-weight:var(--roxy-weight-bold,600)}table.aspect-grid td.cell{cursor:default}table.aspect-grid td.empty{background:color-mix(in srgb, var(--roxy-border,#e4e4e7) 18%, transparent)}table.aspect-grid td .asp{font-size:.95em;line-height:1}table.aspect-grid td.aspect-trine .asp,table.aspect-grid td.aspect-sextile .asp{color:var(--roxy-success,#16a34a)}table.aspect-grid td.aspect-square .asp,table.aspect-grid td.aspect-opposition .asp{color:var(--roxy-danger,#dc2626)}table.aspect-grid td.aspect-conjunction .asp{color:var(--roxy-accent-ink,#b45309)}table.aspect-grid td.aspect-other .asp{color:var(--roxy-muted,#71717a)}.details{margin-top:var(--roxy-space-md,1rem)}.pill-row{gap:var(--roxy-space-xs,.25rem);margin-bottom:var(--roxy-space-xs,.25rem);flex-wrap:wrap;display:flex}.pill{border-radius:var(--roxy-radius-sm,4px);font-size:var(--roxy-text-xs,.75rem);background:color-mix(in srgb, var(--roxy-fg,#0f172a) 8%, transparent);color:var(--roxy-fg,#0f172a);padding:2px 8px}.pill--success{background:color-mix(in srgb, var(--roxy-success,#16a34a) 15%, transparent);color:var(--roxy-success,#16a34a)}.pill--danger{background:color-mix(in srgb, var(--roxy-danger,#dc2626) 15%, transparent);color:var(--roxy-danger,#dc2626)}.pill--muted{background:color-mix(in srgb, var(--roxy-border,#e4e4e7) 60%, transparent);color:var(--roxy-fg,#0a0a0a)}.summary{color:var(--roxy-fg,#0f172a);font-size:var(--roxy-text-sm,.875rem);margin:var(--roxy-space-md,1rem) 0}.em-grid{border-collapse:collapse;font-size:var(--roxy-text-xs,.75rem);width:100%}.em-grid th,.em-grid td{border:1px solid var(--roxy-border,#e4e4e7);text-align:center;vertical-align:middle;padding:3px 5px}.em-grid th{color:var(--roxy-muted,#71717a);font-weight:var(--roxy-weight-bold,600);text-transform:uppercase;letter-spacing:.04em}.em-grid th[scope=row]{text-align:left}.em-grid td{color:var(--roxy-accent,#f59e0b);min-width:1.4rem;font-size:.95em;line-height:1.4}.em-grid .em-total{color:var(--roxy-fg,#0a0a0a);font-weight:var(--roxy-weight-bold,600);background:color-mix(in srgb, var(--roxy-border,#e4e4e7) 25%, transparent)}.interpretations{margin-top:var(--roxy-space-md,1rem)}.interpretations h3{font-size:var(--roxy-text-sm,.875rem);color:var(--roxy-muted,#71717a);text-transform:uppercase;letter-spacing:.06em;margin:0 0 var(--roxy-space-sm,.5rem);font-weight:600}.interp-card{border:1px solid var(--roxy-border,#e4e4e7);border-radius:var(--roxy-radius-md,8px);padding:var(--roxy-space-sm,.5rem) var(--roxy-space-md,1rem);margin-bottom:var(--roxy-space-xs,.25rem)}.interp-card summary{cursor:pointer;color:var(--roxy-fg,#0f172a);justify-content:space-between;align-items:center;gap:var(--roxy-space-md,1rem);font-weight:500;display:flex}.interp-aside{align-items:center;gap:.6em;display:inline-flex}.interp-aside small{color:var(--roxy-muted,#71717a);font-weight:400}.interp-body{margin-top:var(--roxy-space-xs,.25rem);color:var(--roxy-fg,#0f172a);font-size:var(--roxy-text-sm,.875rem)}.interp-keywords{flex-wrap:wrap;gap:.25rem;margin-top:.5rem;display:flex}.interp-keywords .kw{background:color-mix(in srgb, var(--roxy-accent,#f59e0b) 14%, transparent);color:var(--roxy-accent-ink,#b45309);font-size:var(--roxy-text-xs,.75rem);border-radius:9999px;padding:1px 8px}`],y([$({type:String,attribute:"house-system",reflect:!0})],T.prototype,"houseSystem",2),y([$({type:String})],T.prototype,"heading",2),y([Y()],T.prototype,"view",2),T=y([ne("roxy-natal-chart")],T);var st=i=>_[v(i)]??_[i]??"",D=class extends x{renderEmpty(){return c`<div class="roxy-empty" role="status">No relocation data</div>`}renderData(e){let t=e.changes;return c`<div class="stack"><roxy-natal-chart heading="Relocation chart" .data="${e}"></roxy-natal-chart><section class="changes"><h3 class="title">What changes at this location</h3><div class="move">${typeof t?.distanceKm=="number"?c`<span>${Math.round(t.distanceKm).toLocaleString()} km ${t.direction??""} of birthplace</span>`:d} ${t?c`<span>Ascendant ${t.ascendantSignChanged?"changes sign":"keeps its sign"}</span>`:d}</div>${e.interpretation?.summary?c`<p class="summary">${e.interpretation.summary}</p>`:d} ${t?.angularPlanets?.length?c`<div><p class="block-label">Angular planets here</p><div class="chips">${t.angularPlanets.map(r=>c`<span class="chip">${st(r)} ${r}</span>`)}</div></div>`:d}<div><p class="block-label">Planets that change house</p>${t?.planetsChangedHouse?.length?c`<ul class="moves-list">${t.planetsChangedHouse.map(r=>c`<li>${st(r.planet)} ${r.planet}: house ${r.natalHouse} <span class="arrow">to</span> ${r.relocatedHouse}</li>`)}</ul>`:c`<p class="empty-note">No planet changes house at this location.</p>`}</div></section></div>`}};D.styles=[z,w`.stack{gap:var(--roxy-space-md,1rem);display:grid}.changes{background:var(--roxy-surface,#fff);color:var(--roxy-fg,#0a0a0a);border:1px solid var(--roxy-border,#e4e4e7);border-radius:var(--roxy-radius-md,8px);padding:var(--roxy-space-lg,1.5rem);box-shadow:var(--roxy-shadow-sm);gap:var(--roxy-space-md,1rem);display:grid}.title{font-size:var(--roxy-text-lg,1.125rem);font-weight:var(--roxy-weight-bold,600);color:var(--roxy-primary,#0f172a);margin:0}.move{gap:var(--roxy-space-xs,.25rem) var(--roxy-space-md,1rem);font-size:var(--roxy-text-sm,.875rem);color:var(--roxy-muted,#71717a);flex-wrap:wrap;display:flex}.summary{font-size:var(--roxy-text-sm,.875rem);color:var(--roxy-fg,#0a0a0a);margin:0}.block-label{font-size:var(--roxy-text-xs,.75rem);text-transform:uppercase;letter-spacing:.06em;color:var(--roxy-muted,#71717a);margin:0 0 var(--roxy-space-xs,.25rem);font-weight:600}.chips{gap:var(--roxy-space-xs,.25rem);flex-wrap:wrap;display:flex}.chip{border-radius:var(--roxy-radius-full,9999px);font-size:var(--roxy-text-xs,.75rem);background:color-mix(in srgb, var(--roxy-accent,#f59e0b) 16%, transparent);color:var(--roxy-fg,#0a0a0a);padding:2px 10px}.moves-list{gap:2px;margin:0;padding:0;list-style:none;display:grid}.moves-list li{font-size:var(--roxy-text-sm,.875rem);color:var(--roxy-fg,#0a0a0a)}.moves-list .arrow{color:var(--roxy-muted,#71717a)}.empty-note{font-size:var(--roxy-text-sm,.875rem);color:var(--roxy-muted,#71717a);margin:0}`],D=y([ne("roxy-relocation-wheel")],D);return dt(Rt);})();
13
+ /*! Bundled license information:
14
+
15
+ @lit/reactive-element/css-tag.js:
16
+ (**
17
+ * @license
18
+ * Copyright 2019 Google LLC
19
+ * SPDX-License-Identifier: BSD-3-Clause
20
+ *)
21
+
22
+ @lit/reactive-element/reactive-element.js:
23
+ lit-html/lit-html.js:
24
+ lit-element/lit-element.js:
25
+ @lit/reactive-element/decorators/custom-element.js:
26
+ @lit/reactive-element/decorators/property.js:
27
+ @lit/reactive-element/decorators/state.js:
28
+ @lit/reactive-element/decorators/event-options.js:
29
+ @lit/reactive-element/decorators/base.js:
30
+ @lit/reactive-element/decorators/query.js:
31
+ @lit/reactive-element/decorators/query-all.js:
32
+ @lit/reactive-element/decorators/query-async.js:
33
+ @lit/reactive-element/decorators/query-assigned-nodes.js:
34
+ (**
35
+ * @license
36
+ * Copyright 2017 Google LLC
37
+ * SPDX-License-Identifier: BSD-3-Clause
38
+ *)
39
+
40
+ lit-html/is-server.js:
41
+ (**
42
+ * @license
43
+ * Copyright 2022 Google LLC
44
+ * SPDX-License-Identifier: BSD-3-Clause
45
+ *)
46
+
47
+ @lit/reactive-element/decorators/query-assigned-elements.js:
48
+ (**
49
+ * @license
50
+ * Copyright 2021 Google LLC
51
+ * SPDX-License-Identifier: BSD-3-Clause
52
+ *)
53
+
54
+ lit-html/directives/if-defined.js:
55
+ (**
56
+ * @license
57
+ * Copyright 2018 Google LLC
58
+ * SPDX-License-Identifier: BSD-3-Clause
59
+ *)
60
+ */
61
+ //# sourceMappingURL=relocation-wheel.js.map