@roxyapi/ui 0.5.0 → 0.6.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.
- package/README.md +1 -1
- package/dist/cdn/components/ashtakavarga-grid.js +3 -362
- package/dist/cdn/components/ashtakavarga-grid.js.map +2 -2
- package/dist/cdn/components/biorhythm-chart.js +2 -225
- package/dist/cdn/components/biorhythm-chart.js.map +2 -2
- package/dist/cdn/components/choghadiya-grid.js +2 -231
- package/dist/cdn/components/choghadiya-grid.js.map +2 -2
- package/dist/cdn/components/compatibility-card.js +2 -230
- package/dist/cdn/components/compatibility-card.js.map +2 -2
- package/dist/cdn/components/dasha-timeline.js +2 -282
- package/dist/cdn/components/dasha-timeline.js.map +2 -2
- package/dist/cdn/components/data.js +3 -230
- package/dist/cdn/components/data.js.map +2 -2
- package/dist/cdn/components/divisional-chart.js +34 -321
- package/dist/cdn/components/divisional-chart.js.map +4 -4
- package/dist/cdn/components/dosha-card.js +2 -225
- package/dist/cdn/components/dosha-card.js.map +2 -2
- package/dist/cdn/components/endpoint-form.js +2 -243
- package/dist/cdn/components/endpoint-form.js.map +2 -2
- package/dist/cdn/components/guna-milan.js +2 -269
- package/dist/cdn/components/guna-milan.js.map +2 -2
- package/dist/cdn/components/hexagram.js +3 -247
- package/dist/cdn/components/hexagram.js.map +2 -2
- package/dist/cdn/components/horoscope-card.js +3 -281
- package/dist/cdn/components/horoscope-card.js.map +2 -2
- package/dist/cdn/components/kp-chart.js +2 -277
- package/dist/cdn/components/kp-chart.js.map +2 -2
- package/dist/cdn/components/kp-planets-table.js +2 -195
- package/dist/cdn/components/kp-planets-table.js.map +2 -2
- package/dist/cdn/components/kp-ruling-planets.js +2 -240
- package/dist/cdn/components/kp-ruling-planets.js.map +2 -2
- package/dist/cdn/components/location-search.js +2 -240
- package/dist/cdn/components/location-search.js.map +2 -2
- package/dist/cdn/components/moon-phase.js +3 -223
- package/dist/cdn/components/moon-phase.js.map +2 -2
- package/dist/cdn/components/nakshatra-card.js +2 -200
- package/dist/cdn/components/nakshatra-card.js.map +2 -2
- package/dist/cdn/components/natal-chart.js +9 -560
- package/dist/cdn/components/natal-chart.js.map +4 -4
- package/dist/cdn/components/numerology-card.js +2 -232
- package/dist/cdn/components/numerology-card.js.map +2 -2
- package/dist/cdn/components/panchang-table.js +3 -220
- package/dist/cdn/components/panchang-table.js.map +2 -2
- package/dist/cdn/components/shadbala-table.js +3 -284
- package/dist/cdn/components/shadbala-table.js.map +2 -2
- package/dist/cdn/components/synastry-chart.js +5 -395
- package/dist/cdn/components/synastry-chart.js.map +2 -2
- package/dist/cdn/components/tarot-card.js +3 -261
- package/dist/cdn/components/tarot-card.js.map +2 -2
- package/dist/cdn/components/tarot-spread.js +2 -248
- package/dist/cdn/components/tarot-spread.js.map +2 -2
- package/dist/cdn/components/transits-table.js +3 -382
- package/dist/cdn/components/transits-table.js.map +4 -4
- package/dist/cdn/components/vedic-kundli.js +35 -271
- package/dist/cdn/components/vedic-kundli.js.map +4 -4
- package/dist/cdn/components/vedic-planets-table.js +2 -202
- package/dist/cdn/components/vedic-planets-table.js.map +2 -2
- package/dist/cdn/components/western-planets-table.js +3 -192
- package/dist/cdn/components/western-planets-table.js.map +2 -2
- package/dist/cdn/components/yoga-list.js +2 -305
- package/dist/cdn/components/yoga-list.js.map +2 -2
- package/dist/cdn/roxy-ui.js +41 -5059
- package/dist/cdn/roxy-ui.js.map +4 -4
- package/dist/cdn/widgets.js +1 -114
- package/dist/components/ashtakavarga-grid.js +1 -577
- package/dist/components/ashtakavarga-grid.js.map +3 -3
- package/dist/components/biorhythm-chart.js +1 -378
- package/dist/components/biorhythm-chart.js.map +3 -3
- package/dist/components/choghadiya-grid.js +1 -397
- package/dist/components/choghadiya-grid.js.map +3 -3
- package/dist/components/compatibility-card.js +1 -359
- package/dist/components/compatibility-card.js.map +3 -3
- package/dist/components/dasha-timeline.js +1 -447
- package/dist/components/dasha-timeline.js.map +3 -3
- package/dist/components/data.js +1 -408
- package/dist/components/data.js.map +3 -3
- package/dist/components/divisional-chart.d.ts.map +1 -1
- package/dist/components/divisional-chart.js +64 -929
- package/dist/components/divisional-chart.js.map +4 -4
- package/dist/components/dosha-card.js +1 -339
- package/dist/components/dosha-card.js.map +3 -3
- package/dist/components/endpoint-form.js +1 -505
- package/dist/components/endpoint-form.js.map +3 -3
- package/dist/components/guna-milan.js +1 -420
- package/dist/components/guna-milan.js.map +3 -3
- package/dist/components/hexagram.js +1 -426
- package/dist/components/hexagram.js.map +3 -3
- package/dist/components/horoscope-card.js +1 -427
- package/dist/components/horoscope-card.js.map +3 -3
- package/dist/components/kp-chart.js +1 -441
- package/dist/components/kp-chart.js.map +3 -3
- package/dist/components/kp-planets-table.js +1 -292
- package/dist/components/kp-planets-table.js.map +3 -3
- package/dist/components/kp-ruling-planets.js +1 -334
- package/dist/components/kp-ruling-planets.js.map +3 -3
- package/dist/components/location-search.js +1 -461
- package/dist/components/location-search.js.map +3 -3
- package/dist/components/moon-phase.js +1 -373
- package/dist/components/moon-phase.js.map +3 -3
- package/dist/components/nakshatra-card.js +1 -290
- package/dist/components/nakshatra-card.js.map +3 -3
- package/dist/components/natal-chart.d.ts +0 -1
- package/dist/components/natal-chart.d.ts.map +1 -1
- package/dist/components/natal-chart.js +8 -1084
- package/dist/components/natal-chart.js.map +4 -4
- package/dist/components/numerology-card.js +1 -361
- package/dist/components/numerology-card.js.map +3 -3
- package/dist/components/panchang-table.js +1 -396
- package/dist/components/panchang-table.js.map +3 -3
- package/dist/components/shadbala-table.js +1 -459
- package/dist/components/shadbala-table.js.map +3 -3
- package/dist/components/synastry-chart.js +7 -704
- package/dist/components/synastry-chart.js.map +3 -3
- package/dist/components/tarot-card.js +1 -379
- package/dist/components/tarot-card.js.map +3 -3
- package/dist/components/tarot-spread.js +1 -356
- package/dist/components/tarot-spread.js.map +3 -3
- package/dist/components/transits-table.d.ts +2 -0
- package/dist/components/transits-table.d.ts.map +1 -1
- package/dist/components/transits-table.js +1 -594
- package/dist/components/transits-table.js.map +4 -4
- package/dist/components/vedic-kundli.d.ts.map +1 -1
- package/dist/components/vedic-kundli.js +64 -845
- package/dist/components/vedic-kundli.js.map +4 -4
- package/dist/components/vedic-planets-table.js +1 -414
- package/dist/components/vedic-planets-table.js.map +3 -3
- package/dist/components/western-planets-table.js +1 -409
- package/dist/components/western-planets-table.js.map +3 -3
- package/dist/components/yoga-list.js +1 -429
- package/dist/components/yoga-list.js.map +3 -3
- package/dist/index.cjs +77 -8721
- package/dist/index.cjs.map +4 -4
- package/dist/index.js +77 -8701
- package/dist/index.js.map +4 -4
- package/dist/utils/disclosure.d.ts +16 -0
- package/dist/utils/disclosure.d.ts.map +1 -0
- package/dist/utils/kundli-render.d.ts.map +1 -1
- package/dist/utils/kundli-styles.d.ts.map +1 -1
- package/dist/utils/tablist.d.ts +44 -0
- package/dist/utils/tablist.d.ts.map +1 -0
- package/dist/version.d.ts +1 -1
- package/package.json +3 -1
- package/src/components/dasha-timeline.ts +7 -7
- package/src/components/divisional-chart.ts +2 -0
- package/src/components/natal-chart.ts +37 -62
- package/src/components/transits-table.ts +45 -18
- package/src/components/vedic-kundli.ts +2 -1
- package/src/utils/disclosure.ts +62 -0
- package/src/utils/kundli-render.ts +21 -35
- package/src/utils/kundli-styles.ts +0 -31
- package/src/utils/tablist.ts +124 -0
- package/src/version.ts +1 -1
|
@@ -1,385 +1,6 @@
|
|
|
1
|
-
"use strict";var RoxyUI_transits_table=(()=>{var z=Object.defineProperty;var at=Object.getOwnPropertyDescriptor;var
|
|
2
|
-
\f\r]`,
|
|
3
|
-
\f\r"'\`<>=]|("|')|))|$)`,"g"),yt=/'/g,$t=/"/g,_t=/^(?:script|style|textarea|title)$/i,ot=s=>(t,...e)=>({_$litType$:s,strings:t,values:e}),u=ot(1),ne=ot(2),ie=ot(3),_=Symbol.for("lit-noChange"),c=Symbol.for("lit-nothing"),xt=new WeakMap,v=b.createTreeWalker(b,129);function At(s,t){if(!st(s)||!s.hasOwnProperty("raw"))throw Error("invalid template strings array");return mt!==void 0?mt.createHTML(t):t}var Vt=(s,t)=>{let e=s.length-1,r=[],o,n=t===2?"<svg>":t===3?"<math>":"",i=N;for(let l=0;l<e;l++){let a=s[l],d,h,p=-1,m=0;for(;m<a.length&&(i.lastIndex=m,h=i.exec(a),h!==null);)m=i.lastIndex,i===N?h[1]==="!--"?i=gt:h[1]!==void 0?i=ft:h[2]!==void 0?(_t.test(h[2])&&(o=RegExp("</"+h[2],"g")),i=x):h[3]!==void 0&&(i=x):i===x?h[0]===">"?(i=o??N,p=-1):h[1]===void 0?p=-2:(p=i.lastIndex-h[2].length,d=h[1],i=h[3]===void 0?x:h[3]==='"'?$t:yt):i===$t||i===yt?i=x:i===gt||i===ft?i=N:(i=x,o=void 0);let f=i===x&&s[l+1].startsWith("/>")?" ":"";n+=i===N?a+Bt:p>=0?(r.push(d),a.slice(0,p)+vt+a.slice(p)+y+f):a+y+(p===-2?l:f)}return[At(s,n+(s[e]||"<?>")+(t===2?"</svg>":t===3?"</math>":"")),r]},M=class s{constructor({strings:t,_$litType$:e},r){let o;this.parts=[];let n=0,i=0,l=t.length-1,a=this.parts,[d,h]=Vt(t,e);if(this.el=s.createElement(d,r),v.currentNode=this.el.content,e===2||e===3){let p=this.el.content.firstChild;p.replaceWith(...p.childNodes)}for(;(o=v.nextNode())!==null&&a.length<l;){if(o.nodeType===1){if(o.hasAttributes())for(let p of o.getAttributeNames())if(p.endsWith(vt)){let m=h[i++],f=o.getAttribute(p).split(y),H=/([.?@])?(.*)/.exec(m);a.push({type:1,index:n,name:H[2],strings:f,ctor:H[1]==="."?X:H[1]==="?"?Q:H[1]==="@"?tt:w}),o.removeAttribute(p)}else p.startsWith(y)&&(a.push({type:6,index:n}),o.removeAttribute(p));if(_t.test(o.tagName)){let p=o.textContent.split(y),m=p.length-1;if(m>0){o.textContent=B?B.emptyScript:"";for(let f=0;f<m;f++)o.append(p[f],R()),v.nextNode(),a.push({type:2,index:++n});o.append(p[m],R())}}}else if(o.nodeType===8)if(o.data===bt)a.push({type:2,index:n});else{let p=-1;for(;(p=o.data.indexOf(y,p+1))!==-1;)a.push({type:7,index:n}),p+=y.length-1}n++}}static createElement(t,e){let r=b.createElement("template");return r.innerHTML=t,r}};function S(s,t,e=s,r){if(t===_)return t;let o=r!==void 0?e._$Co?.[r]:e._$Cl,n=L(t)?void 0:t._$litDirective$;return o?.constructor!==n&&(o?._$AO?.(!1),n===void 0?o=void 0:(o=new n(s),o._$AT(s,e,r)),r!==void 0?(e._$Co??=[])[r]=o:e._$Cl=o),o!==void 0&&(t=S(s,o._$AS(s,t.values),o,r)),t}var Z=class{constructor(t,e){this._$AV=[],this._$AN=void 0,this._$AD=t,this._$AM=e}get parentNode(){return this._$AM.parentNode}get _$AU(){return this._$AM._$AU}u(t){let{el:{content:e},parts:r}=this._$AD,o=(t?.creationScope??b).importNode(e,!0);v.currentNode=o;let n=v.nextNode(),i=0,l=0,a=r[0];for(;a!==void 0;){if(i===a.index){let d;a.type===2?d=new k(n,n.nextSibling,this,t):a.type===1?d=new a.ctor(n,a.name,a.strings,this,t):a.type===6&&(d=new et(n,this,t)),this._$AV.push(d),a=r[++l]}i!==a?.index&&(n=v.nextNode(),i++)}return v.currentNode=b,o}p(t){let e=0;for(let r of this._$AV)r!==void 0&&(r.strings!==void 0?(r._$AI(t,r,e),e+=r.strings.length-2):r._$AI(t[e])),e++}},k=class s{get _$AU(){return this._$AM?._$AU??this._$Cv}constructor(t,e,r,o){this.type=2,this._$AH=c,this._$AN=void 0,this._$AA=t,this._$AB=e,this._$AM=r,this.options=o,this._$Cv=o?.isConnected??!0}get parentNode(){let t=this._$AA.parentNode,e=this._$AM;return e!==void 0&&t?.nodeType===11&&(t=e.parentNode),t}get startNode(){return this._$AA}get endNode(){return this._$AB}_$AI(t,e=this){t=S(this,t,e),L(t)?t===c||t==null||t===""?(this._$AH!==c&&this._$AR(),this._$AH=c):t!==this._$AH&&t!==_&&this._(t):t._$litType$!==void 0?this.$(t):t.nodeType!==void 0?this.T(t):Gt(t)?this.k(t):this._(t)}O(t){return this._$AA.parentNode.insertBefore(t,this._$AB)}T(t){this._$AH!==t&&(this._$AR(),this._$AH=this.O(t))}_(t){this._$AH!==c&&L(this._$AH)?this._$AA.nextSibling.data=t:this.T(b.createTextNode(t)),this._$AH=t}$(t){let{values:e,_$litType$:r}=t,o=typeof r=="number"?this._$AC(t):(r.el===void 0&&(r.el=M.createElement(At(r.h,r.h[0]),this.options)),r);if(this._$AH?._$AD===o)this._$AH.p(e);else{let n=new Z(o,this),i=n.u(this.options);n.p(e),this.T(i),this._$AH=n}}_$AC(t){let e=xt.get(t.strings);return e===void 0&&xt.set(t.strings,e=new M(t)),e}k(t){st(this._$AH)||(this._$AH=[],this._$AR());let e=this._$AH,r,o=0;for(let n of t)o===e.length?e.push(r=new s(this.O(R()),this.O(R()),this,this.options)):r=e[o],r._$AI(n),o++;o<e.length&&(this._$AR(r&&r._$AB.nextSibling,o),e.length=o)}_$AR(t=this._$AA.nextSibling,e){for(this._$AP?.(!1,!0,e);t!==this._$AB;){let r=ut(t).nextSibling;ut(t).remove(),t=r}}setConnected(t){this._$AM===void 0&&(this._$Cv=t,this._$AP?.(t))}},w=class{get tagName(){return this.element.tagName}get _$AU(){return this._$AM._$AU}constructor(t,e,r,o,n){this.type=1,this._$AH=c,this._$AN=void 0,this.element=t,this.name=e,this._$AM=o,this.options=n,r.length>2||r[0]!==""||r[1]!==""?(this._$AH=Array(r.length-1).fill(new String),this.strings=r):this._$AH=c}_$AI(t,e=this,r,o){let n=this.strings,i=!1;if(n===void 0)t=S(this,t,e,0),i=!L(t)||t!==this._$AH&&t!==_,i&&(this._$AH=t);else{let l=t,a,d;for(t=n[0],a=0;a<n.length-1;a++)d=S(this,l[r+a],e,a),d===_&&(d=this._$AH[a]),i||=!L(d)||d!==this._$AH[a],d===c?t=c:t!==c&&(t+=(d??"")+n[a+1]),this._$AH[a]=d}i&&!o&&this.j(t)}j(t){t===c?this.element.removeAttribute(this.name):this.element.setAttribute(this.name,t??"")}},X=class extends w{constructor(){super(...arguments),this.type=3}j(t){this.element[this.name]=t===c?void 0:t}},Q=class extends w{constructor(){super(...arguments),this.type=4}j(t){this.element.toggleAttribute(this.name,!!t&&t!==c)}},tt=class extends w{constructor(t,e,r,o,n){super(t,e,r,o,n),this.type=5}_$AI(t,e=this){if((t=S(this,t,e,0)??c)===_)return;let r=this._$AH,o=t===c&&r!==c||t.capture!==r.capture||t.once!==r.once||t.passive!==r.passive,n=t!==c&&(r===c||o);o&&this.element.removeEventListener(this.name,this,r),n&&this.element.addEventListener(this.name,this,t),this._$AH=t}handleEvent(t){typeof this._$AH=="function"?this._$AH.call(this.options?.host??this.element,t):this._$AH.handleEvent(t)}},et=class{constructor(t,e,r){this.element=t,this.type=6,this._$AN=void 0,this._$AM=e,this.options=r}get _$AU(){return this._$AM._$AU}_$AI(t){S(this,t)}};var Ft=rt.litHtmlPolyfillSupport;Ft?.(M,k),(rt.litHtmlVersions??=[]).push("3.3.2");var St=(s,t,e)=>{let r=e?.renderBefore??t,o=r._$litPart$;if(o===void 0){let n=e?.renderBefore??null;r._$litPart$=o=new k(t.insertBefore(R(),n),n,void 0,e??{})}return o._$AI(s),o};var nt=globalThis,$=class extends g{constructor(){super(...arguments),this.renderOptions={host:this},this._$Do=void 0}createRenderRoot(){let t=super.createRenderRoot();return this.renderOptions.renderBefore??=t.firstChild,t}update(t){let e=this.render();this.hasUpdated||(this.renderOptions.isConnected=this.isConnected),super.update(t),this._$Do=St(e,this.renderRoot,this.renderOptions)}connectedCallback(){super.connectedCallback(),this._$Do?.setConnected(!0)}disconnectedCallback(){super.disconnectedCallback(),this._$Do?.setConnected(!1)}render(){return _}};$._$litElement$=!0,$.finalized=!0,nt.litElementHydrateSupport?.({LitElement:$});var Wt=nt.litElementPolyfillSupport;Wt?.({LitElement:$});(nt.litElementVersions??=[]).push("4.2.2");var wt=s=>(t,e)=>{e!==void 0?e.addInitializer(()=>{customElements.define(s,t)}):customElements.define(s,t)};var Yt={attribute:!0,type:String,converter:T,reflect:!1,hasChanged:I},Jt=(s=Yt,t,e)=>{let{kind:r,metadata:o}=e,n=globalThis.litPropertyMetadata.get(o);if(n===void 0&&globalThis.litPropertyMetadata.set(o,n=new Map),r==="setter"&&((s=Object.create(s)).wrapped=!0),n.set(e.name,s),r==="accessor"){let{name:i}=e;return{set(l){let a=t.get.call(this);t.set.call(this,l),this.requestUpdate(i,a,s,!0,l)},init(l){return l!==void 0&&this.C(i,void 0,s,l),l}}}if(r==="setter"){let{name:i}=e;return function(l){let a=this[i];t.call(this,l),this.requestUpdate(i,a,s,!0,l)}}throw Error("Unsupported decorator location: "+r)};function it(s){return(t,e)=>typeof e=="object"?Jt(s,t,e):((r,o,n)=>{let i=o.hasOwnProperty(n);return o.constructor.createProperty(n,r),i?Object.getOwnPropertyDescriptor(o,n):void 0})(s,t,e)}var V={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 Et={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 Kt=["Aries","Taurus","Gemini","Cancer","Leo","Virgo","Libra","Scorpio","Sagittarius","Capricorn","Aquarius","Pisces"],Fe=Kt.map(s=>s.toLowerCase());var Ct=C`
|
|
4
|
-
:host {
|
|
5
|
-
display: block;
|
|
6
|
-
container-type: inline-size;
|
|
7
|
-
font-family: var(
|
|
8
|
-
--roxy-font-sans,
|
|
9
|
-
system-ui,
|
|
10
|
-
-apple-system,
|
|
11
|
-
BlinkMacSystemFont,
|
|
12
|
-
'Segoe UI',
|
|
13
|
-
Roboto,
|
|
14
|
-
sans-serif
|
|
15
|
-
);
|
|
16
|
-
color: var(--roxy-fg, #0a0a0a);
|
|
17
|
-
background: transparent;
|
|
18
|
-
font-size: var(--roxy-text-base, 1rem);
|
|
19
|
-
line-height: var(--roxy-leading-normal, 1.5);
|
|
20
|
-
animation: roxy-fade-in var(--roxy-motion-duration, 200ms)
|
|
21
|
-
var(--roxy-motion-easing, cubic-bezier(0.4, 0, 0.2, 1)) both;
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
*,
|
|
25
|
-
*::before,
|
|
26
|
-
*::after {
|
|
27
|
-
box-sizing: border-box;
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
@keyframes roxy-fade-in {
|
|
31
|
-
from {
|
|
32
|
-
opacity: 0;
|
|
33
|
-
transform: translateY(2px);
|
|
34
|
-
}
|
|
35
|
-
to {
|
|
36
|
-
opacity: 1;
|
|
37
|
-
transform: translateY(0);
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
@media (prefers-reduced-motion: reduce) {
|
|
42
|
-
:host {
|
|
43
|
-
animation: none;
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
.roxy-skeleton {
|
|
48
|
-
background: linear-gradient(
|
|
49
|
-
90deg,
|
|
50
|
-
var(--roxy-border, #e4e4e7) 0%,
|
|
51
|
-
color-mix(in srgb, var(--roxy-border, #e4e4e7) 60%, transparent) 50%,
|
|
52
|
-
var(--roxy-border, #e4e4e7) 100%
|
|
53
|
-
);
|
|
54
|
-
background-size: 200% 100%;
|
|
55
|
-
animation: roxy-shimmer 1.4s ease-in-out infinite;
|
|
56
|
-
border-radius: var(--roxy-radius-md, 8px);
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
@keyframes roxy-shimmer {
|
|
60
|
-
0% {
|
|
61
|
-
background-position: 200% 0;
|
|
62
|
-
}
|
|
63
|
-
100% {
|
|
64
|
-
background-position: -200% 0;
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
@media (prefers-reduced-motion: reduce) {
|
|
69
|
-
.roxy-skeleton {
|
|
70
|
-
animation: none;
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
.roxy-empty {
|
|
75
|
-
padding: var(--roxy-space-lg, 1.5rem);
|
|
76
|
-
color: var(--roxy-muted, #71717a);
|
|
77
|
-
text-align: center;
|
|
78
|
-
font-size: var(--roxy-text-sm, 0.875rem);
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
:host(:focus-within) .roxy-card {
|
|
82
|
-
outline: 2px solid var(--roxy-ring, rgba(245, 158, 11, 0.4));
|
|
83
|
-
outline-offset: 2px;
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
/* Force the text-style variant on every Unicode glyph in the component.
|
|
87
|
-
* macOS and iOS substitute coloured emoji glyphs for the planetary and
|
|
88
|
-
* gender Unicode code points (Mars, Venus, Mercury, etc.) when the
|
|
89
|
-
* system colour-emoji font wins font selection. The text-style variant
|
|
90
|
-
* keeps glyphs monochrome so they inherit the surrounding fill colour
|
|
91
|
-
* and match the brand palette consistently across platforms.
|
|
92
|
-
*
|
|
93
|
-
* font-variant-emoji is part of CSS Fonts 4 (Safari 17+, Chrome 134+,
|
|
94
|
-
* Firefox 139+). On older browsers the rule is silently ignored.
|
|
95
|
-
*/
|
|
96
|
-
:host {
|
|
97
|
-
font-variant-emoji: text;
|
|
98
|
-
}
|
|
99
|
-
`;function Pt(s){if(typeof s!="string"||s.length===0||/^\d{4}-\d{2}-\d{2}$/.test(s))return"";let e=/^\d{2}:\d{2}(:\d{2})?$/.test(s)?`1970-01-01T${s}`:s,r=new Date(e);return Number.isNaN(r.getTime())?s:r.toLocaleTimeString(void 0,{hour:"numeric",minute:"2-digit",hour12:!0})}function Tt(s){if(typeof s!="string"||s.length===0)return"";let t=new Date(/^\d{4}-\d{2}-\d{2}$/.test(s)?`${s}T00:00:00`:s);return Number.isNaN(t.getTime())?s:t.toLocaleDateString(void 0,{month:"short",day:"numeric",year:"numeric"})}function U(s,t=1){return typeof s!="number"||!Number.isFinite(s)?"":s.toFixed(t).replace(/\.?0+$/,"")}var Zt="roxy-data";function Xt(s){return s.nodeName==="SCRIPT"&&s.getAttribute("type")==="application/json"}var F=class{constructor(t){this.host=t,t.addController(this)}hostConnected(){if(this.host.data!=null)return;let t=this.read();t!==void 0&&(this.host.data=t,this.host.requestUpdate())}read(){let t=this.findInlineScript();return t?this.parse(t.textContent):void 0}findInlineScript(){for(let t of Array.from(this.host.children))if(Xt(t)&&t.classList.contains(Zt))return t;return null}parse(t){if(t?.trim())try{return JSON.parse(t)}catch{return}}};function O(s){return s?s.charAt(0).toUpperCase()+s.slice(1).toLowerCase():""}var A=class extends ${constructor(){super();this.data=null;new F(this)}render(){if(!this.data?.transitPlanets?.length)return u`<div class="roxy-empty" role="status">No transits data</div>`;let{transitDate:e,transitTime:r,transitPlanets:o,transitAspects:n,summary:i}=this.data,l=[Tt(e),Pt(r)].filter(Boolean).join(" ");return u`<div class="wrap" aria-label="Transit positions table">
|
|
100
|
-
<div class="head">
|
|
101
|
-
<h2 class="title">Transits</h2>
|
|
102
|
-
${l?u`<p class="subtitle">${l}</p>`:c}
|
|
103
|
-
</div>
|
|
104
|
-
|
|
105
|
-
${i?this.renderSummaryPills(i):c}
|
|
106
|
-
|
|
107
|
-
<div>
|
|
108
|
-
<p class="section-label">Planet positions</p>
|
|
109
|
-
<div class="overflow-scroll">
|
|
110
|
-
${this.renderPlanetsTable(o)}
|
|
111
|
-
</div>
|
|
112
|
-
</div>
|
|
113
|
-
|
|
114
|
-
${n?.length?u`<div>
|
|
115
|
-
<p class="section-label">Transit aspects</p>
|
|
116
|
-
<div class="overflow-scroll">
|
|
117
|
-
${this.renderAspectsList(n)}
|
|
118
|
-
</div>
|
|
119
|
-
</div>`:c}
|
|
120
|
-
</div>`}renderSummaryPills(e){return u`<div class="summary-pills" role="region" aria-label="Aspect summary">
|
|
121
|
-
<span class="pill pill--muted">
|
|
122
|
-
Total: ${e.totalAspects}
|
|
123
|
-
</span>
|
|
124
|
-
<span class="pill pill--success">
|
|
125
|
-
Harmonious: ${e.harmonious}
|
|
126
|
-
</span>
|
|
127
|
-
<span class="pill pill--danger">
|
|
128
|
-
Challenging: ${e.challenging}
|
|
129
|
-
</span>
|
|
130
|
-
<span class="pill pill--muted">
|
|
131
|
-
Neutral: ${e.neutral}
|
|
132
|
-
</span>
|
|
133
|
-
</div>`}renderPlanetsTable(e){return u`<table class="planets-table">
|
|
134
|
-
<thead>
|
|
135
|
-
<tr>
|
|
136
|
-
<th scope="col">Planet</th>
|
|
137
|
-
<th scope="col">Sign</th>
|
|
138
|
-
<th scope="col">Degree</th>
|
|
139
|
-
<th scope="col">Speed</th>
|
|
140
|
-
</tr>
|
|
141
|
-
</thead>
|
|
142
|
-
<tbody>
|
|
143
|
-
${e.map(r=>{let o=V[O(r.name)]??"",n=Et[O(r.sign)]??"",i=r.speed>=0?"\u2191":"\u2193";return u`<tr>
|
|
144
|
-
<td>
|
|
145
|
-
<div class="planet-cell">
|
|
146
|
-
<span class="glyph" aria-hidden="true">${o}</span>
|
|
147
|
-
${r.name}
|
|
148
|
-
${r.isRetrograde?u`<span class="retro-badge" aria-label="retrograde">R</span>`:c}
|
|
149
|
-
</div>
|
|
150
|
-
</td>
|
|
151
|
-
<td>
|
|
152
|
-
<div class="planet-cell">
|
|
153
|
-
<span class="glyph" aria-hidden="true">${n}</span>
|
|
154
|
-
${r.sign}
|
|
155
|
-
</div>
|
|
156
|
-
</td>
|
|
157
|
-
<td class="num">${U(r.degree,2)}</td>
|
|
158
|
-
<td class="speed">
|
|
159
|
-
<span class="speed-arrow" aria-hidden="true">${i}</span>
|
|
160
|
-
${U(Math.abs(r.speed),4)}
|
|
161
|
-
</td>
|
|
162
|
-
</tr>`})}
|
|
163
|
-
</tbody>
|
|
164
|
-
</table>`}renderAspectsList(e){return u`<div role="list" aria-label="Transit aspects">
|
|
165
|
-
${e.map((r,o)=>{let n=V[O(r.transitPlanet)]??"",i=V[O(r.natalPlanet)]??"",l=(r.nature??"neutral").toLowerCase(),a=r.interpretation,d=(r.type??"").toLowerCase(),h=r.isApplying?"Applying":"Separating";return u`<details class="aspect-card" role="listitem" name="transit-aspects" ?open=${o===0}>
|
|
166
|
-
<summary>
|
|
167
|
-
<span aria-hidden="true">${n}</span>
|
|
168
|
-
${r.transitPlanet}
|
|
169
|
-
<span class="nature-badge ${l}">${d}</span>
|
|
170
|
-
<span aria-hidden="true">${i}</span>
|
|
171
|
-
${r.natalPlanet}
|
|
172
|
-
<span class="meta">
|
|
173
|
-
${h} · orb ${U(r.orb,2)}° · strength ${U(r.strength,1)}
|
|
174
|
-
</span>
|
|
175
|
-
</summary>
|
|
176
|
-
<div class="interp-body">
|
|
177
|
-
${a?.summary?u`<p>${a.summary}</p>`:c}
|
|
178
|
-
${a?.impact?u`<p><strong>Impact:</strong> ${a.impact}</p>`:c}
|
|
179
|
-
${a?.timing?u`<p><strong>Timing:</strong> ${a.timing}</p>`:c}
|
|
180
|
-
${a?.guidance?u`<p><strong>Guidance:</strong> ${a.guidance}</p>`:c}
|
|
181
|
-
${a?.keywords?.length?u`<div class="interp-keywords">
|
|
182
|
-
${a.keywords.map(p=>u`<span class="kw">${p}</span>`)}
|
|
183
|
-
</div>`:c}
|
|
184
|
-
</div>
|
|
185
|
-
</details>`})}
|
|
186
|
-
</div>`}};A.styles=[Ct,C`
|
|
187
|
-
.wrap {
|
|
188
|
-
display: grid;
|
|
189
|
-
gap: var(--roxy-space-md, 1rem);
|
|
190
|
-
}
|
|
191
|
-
|
|
192
|
-
.head {
|
|
193
|
-
display: flex;
|
|
194
|
-
justify-content: space-between;
|
|
195
|
-
align-items: baseline;
|
|
196
|
-
gap: var(--roxy-space-md, 1rem);
|
|
197
|
-
flex-wrap: wrap;
|
|
198
|
-
}
|
|
199
|
-
|
|
200
|
-
.title {
|
|
201
|
-
font-size: var(--roxy-text-lg, 1.125rem);
|
|
202
|
-
font-weight: var(--roxy-weight-bold, 600);
|
|
203
|
-
margin: 0;
|
|
204
|
-
}
|
|
205
|
-
|
|
206
|
-
.subtitle {
|
|
207
|
-
color: var(--roxy-muted, #71717a);
|
|
208
|
-
font-size: var(--roxy-text-sm, 0.875rem);
|
|
209
|
-
margin: 0;
|
|
210
|
-
}
|
|
211
|
-
|
|
212
|
-
.summary-pills {
|
|
213
|
-
display: flex;
|
|
214
|
-
flex-wrap: wrap;
|
|
215
|
-
gap: var(--roxy-space-sm, 0.5rem);
|
|
216
|
-
}
|
|
217
|
-
|
|
218
|
-
.pill {
|
|
219
|
-
display: inline-flex;
|
|
220
|
-
align-items: center;
|
|
221
|
-
gap: 4px;
|
|
222
|
-
padding: 2px var(--roxy-space-sm, 0.5rem);
|
|
223
|
-
border-radius: var(--roxy-radius-full, 9999px);
|
|
224
|
-
font-size: var(--roxy-text-xs, 0.75rem);
|
|
225
|
-
font-weight: var(--roxy-weight-bold, 600);
|
|
226
|
-
border: 1px solid currentColor;
|
|
227
|
-
}
|
|
228
|
-
|
|
229
|
-
.pill--muted {
|
|
230
|
-
color: var(--roxy-fg, #0a0a0a);
|
|
231
|
-
background: color-mix(in srgb, var(--roxy-border, #e4e4e7) 60%, transparent);
|
|
232
|
-
}
|
|
233
|
-
|
|
234
|
-
.pill--success {
|
|
235
|
-
color: var(--roxy-success-fg, #166534);
|
|
236
|
-
background: color-mix(in srgb, var(--roxy-success, #16a34a) 10%, transparent);
|
|
237
|
-
}
|
|
238
|
-
|
|
239
|
-
.pill--danger {
|
|
240
|
-
color: var(--roxy-danger-fg, #991b1b);
|
|
241
|
-
background: color-mix(in srgb, var(--roxy-danger, #dc2626) 10%, transparent);
|
|
242
|
-
}
|
|
243
|
-
|
|
244
|
-
table {
|
|
245
|
-
width: 100%;
|
|
246
|
-
border-collapse: collapse;
|
|
247
|
-
font-size: var(--roxy-text-sm, 0.875rem);
|
|
248
|
-
}
|
|
249
|
-
|
|
250
|
-
th,
|
|
251
|
-
td {
|
|
252
|
-
padding: var(--roxy-space-sm, 0.5rem);
|
|
253
|
-
border-bottom: 1px solid var(--roxy-border, #e4e4e7);
|
|
254
|
-
text-align: left;
|
|
255
|
-
}
|
|
256
|
-
|
|
257
|
-
th {
|
|
258
|
-
color: var(--roxy-muted, #71717a);
|
|
259
|
-
font-weight: var(--roxy-weight-bold, 600);
|
|
260
|
-
text-transform: uppercase;
|
|
261
|
-
font-size: var(--roxy-text-xs, 0.75rem);
|
|
262
|
-
letter-spacing: 0.06em;
|
|
263
|
-
}
|
|
264
|
-
|
|
265
|
-
.section-label {
|
|
266
|
-
font-size: var(--roxy-text-xs, 0.75rem);
|
|
267
|
-
color: var(--roxy-muted, #71717a);
|
|
268
|
-
text-transform: uppercase;
|
|
269
|
-
letter-spacing: 0.06em;
|
|
270
|
-
font-weight: var(--roxy-weight-bold, 600);
|
|
271
|
-
margin: 0 0 var(--roxy-space-xs, 0.25rem) 0;
|
|
272
|
-
}
|
|
273
|
-
|
|
274
|
-
.glyph {
|
|
275
|
-
font-size: 1.1em;
|
|
276
|
-
margin-right: 2px;
|
|
277
|
-
line-height: 1;
|
|
278
|
-
}
|
|
279
|
-
|
|
280
|
-
.planet-cell {
|
|
281
|
-
display: flex;
|
|
282
|
-
align-items: center;
|
|
283
|
-
gap: 4px;
|
|
284
|
-
white-space: nowrap;
|
|
285
|
-
}
|
|
286
|
-
|
|
287
|
-
.retro-badge {
|
|
288
|
-
display: inline-block;
|
|
289
|
-
font-size: 0.7em;
|
|
290
|
-
padding: 1px 4px;
|
|
291
|
-
border-radius: var(--roxy-radius-sm, 4px);
|
|
292
|
-
background: color-mix(in srgb, var(--roxy-warning, #ea580c) 12%, transparent);
|
|
293
|
-
color: var(--roxy-warning-fg, #9a3412);
|
|
294
|
-
font-weight: var(--roxy-weight-bold, 600);
|
|
295
|
-
margin-left: 2px;
|
|
296
|
-
vertical-align: middle;
|
|
297
|
-
}
|
|
298
|
-
|
|
299
|
-
.speed {
|
|
300
|
-
font-variant-numeric: tabular-nums;
|
|
301
|
-
color: var(--roxy-muted, #71717a);
|
|
302
|
-
white-space: nowrap;
|
|
303
|
-
}
|
|
304
|
-
|
|
305
|
-
.speed-arrow {
|
|
306
|
-
font-size: 0.85em;
|
|
307
|
-
}
|
|
308
|
-
|
|
309
|
-
td.num {
|
|
310
|
-
font-variant-numeric: tabular-nums;
|
|
311
|
-
color: var(--roxy-muted, #71717a);
|
|
312
|
-
}
|
|
313
|
-
|
|
314
|
-
.overflow-scroll {
|
|
315
|
-
overflow-x: auto;
|
|
316
|
-
-webkit-overflow-scrolling: touch;
|
|
317
|
-
}
|
|
318
|
-
|
|
319
|
-
.aspect-card {
|
|
320
|
-
border: 1px solid var(--roxy-border, #e4e4e7);
|
|
321
|
-
border-radius: var(--roxy-radius-md, 8px);
|
|
322
|
-
padding: var(--roxy-space-sm, 0.5rem) var(--roxy-space-md, 1rem);
|
|
323
|
-
margin-bottom: var(--roxy-space-xs, 0.25rem);
|
|
324
|
-
}
|
|
325
|
-
.aspect-card summary {
|
|
326
|
-
cursor: pointer;
|
|
327
|
-
font-weight: 500;
|
|
328
|
-
color: var(--roxy-fg, #0a0a0a);
|
|
329
|
-
display: flex;
|
|
330
|
-
flex-wrap: wrap;
|
|
331
|
-
align-items: center;
|
|
332
|
-
gap: 0.5em;
|
|
333
|
-
}
|
|
334
|
-
.aspect-card summary .meta {
|
|
335
|
-
color: var(--roxy-muted, #71717a);
|
|
336
|
-
font-weight: 400;
|
|
337
|
-
font-size: var(--roxy-text-xs, 0.75rem);
|
|
338
|
-
margin-left: auto;
|
|
339
|
-
font-variant-numeric: tabular-nums;
|
|
340
|
-
}
|
|
341
|
-
.aspect-card .interp-body {
|
|
342
|
-
margin-top: var(--roxy-space-xs, 0.25rem);
|
|
343
|
-
color: var(--roxy-fg, #0a0a0a);
|
|
344
|
-
font-size: var(--roxy-text-sm, 0.875rem);
|
|
345
|
-
line-height: 1.45;
|
|
346
|
-
}
|
|
347
|
-
.aspect-card .interp-body p {
|
|
348
|
-
margin: 0 0 var(--roxy-space-xs, 0.25rem);
|
|
349
|
-
}
|
|
350
|
-
.interp-keywords {
|
|
351
|
-
display: flex;
|
|
352
|
-
flex-wrap: wrap;
|
|
353
|
-
gap: 0.25rem;
|
|
354
|
-
margin-top: 0.5rem;
|
|
355
|
-
}
|
|
356
|
-
.interp-keywords .kw {
|
|
357
|
-
padding: 1px 8px;
|
|
358
|
-
border-radius: 9999px;
|
|
359
|
-
background: color-mix(in srgb, var(--roxy-accent, #f59e0b) 14%, transparent);
|
|
360
|
-
color: var(--roxy-accent-fg, #b45309);
|
|
361
|
-
font-size: var(--roxy-text-xs, 0.75rem);
|
|
362
|
-
}
|
|
363
|
-
.nature-badge {
|
|
364
|
-
display: inline-block;
|
|
365
|
-
padding: 1px 8px;
|
|
366
|
-
border-radius: 9999px;
|
|
367
|
-
font-size: var(--roxy-text-xs, 0.75rem);
|
|
368
|
-
font-weight: 600;
|
|
369
|
-
}
|
|
370
|
-
.nature-badge.harmonious {
|
|
371
|
-
background: color-mix(in srgb, var(--roxy-success, #16a34a) 12%, transparent);
|
|
372
|
-
color: var(--roxy-success-fg, #166534);
|
|
373
|
-
}
|
|
374
|
-
.nature-badge.challenging {
|
|
375
|
-
background: color-mix(in srgb, var(--roxy-danger, #dc2626) 12%, transparent);
|
|
376
|
-
color: var(--roxy-danger-fg, #991b1b);
|
|
377
|
-
}
|
|
378
|
-
.nature-badge.neutral {
|
|
379
|
-
background: color-mix(in srgb, var(--roxy-border, #e4e4e7) 60%, transparent);
|
|
380
|
-
color: var(--roxy-fg, #0a0a0a);
|
|
381
|
-
}
|
|
382
|
-
`],W([it({attribute:!1})],A.prototype,"data",2),A=W([wt("roxy-transits-table")],A);return kt(Qt);})();
|
|
1
|
+
"use strict";var RoxyUI_transits_table=(()=>{var z=Object.defineProperty;var at=Object.getOwnPropertyDescriptor;var Ut=Object.getOwnPropertyNames;var Ht=Object.prototype.hasOwnProperty;var Ot=(s,t)=>{for(var e in t)z(s,e,{get:t[e],enumerable:!0})},zt=(s,t,e,r)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Ut(t))!Ht.call(s,o)&&o!==e&&z(s,o,{get:()=>t[o],enumerable:!(r=at(t,o))||r.enumerable});return s};var Dt=s=>zt(z({},"__esModule",{value:!0}),s),D=(s,t,e,r)=>{for(var o=r>1?void 0:r?at(t,e):t,n=s.length-1,i;n>=0;n--)(i=s[n])&&(o=(r?i(t,e,o):i(o))||o);return r&&o&&z(t,e,o),o};var oe={};Ot(oe,{RoxyTransitsTable:()=>b});var q=globalThis,j=q.ShadowRoot&&(q.ShadyCSS===void 0||q.ShadyCSS.nativeShadow)&&"adoptedStyleSheets"in Document.prototype&&"replace"in CSSStyleSheet.prototype,F=Symbol(),lt=new WeakMap,C=class{constructor(t,e,r){if(this._$cssResult$=!0,r!==F)throw Error("CSSResult is not constructable. Use `unsafeCSS` or `css` instead.");this.cssText=t,this.t=e}get styleSheet(){let t=this.o,e=this.t;if(j&&t===void 0){let r=e!==void 0&&e.length===1;r&&(t=lt.get(e)),t===void 0&&((this.o=t=new CSSStyleSheet).replaceSync(this.cssText),r&<.set(e,t))}return t}toString(){return this.cssText}},ct=s=>new C(typeof s=="string"?s:s+"",void 0,F),g=(s,...t)=>{let e=s.length===1?s[0]:t.reduce((r,o,n)=>r+(i=>{if(i._$cssResult$===!0)return i.cssText;if(typeof i=="number")return i;throw Error("Value passed to 'css' function must be a 'css' function result: "+i+". Use 'unsafeCSS' to pass non-literal values, but take care to ensure page security.")})(o)+s[n+1],s[0]);return new C(e,s,F)},dt=(s,t)=>{if(j)s.adoptedStyleSheets=t.map(e=>e instanceof CSSStyleSheet?e:e.styleSheet);else for(let e of t){let r=document.createElement("style"),o=q.litNonce;o!==void 0&&r.setAttribute("nonce",o),r.textContent=e.cssText,s.appendChild(r)}},J=j?s=>s:s=>s instanceof CSSStyleSheet?(t=>{let e="";for(let r of t.cssRules)e+=r.cssText;return ct(e)})(s):s;var{is:qt,defineProperty:jt,getOwnPropertyDescriptor:It,getOwnPropertyNames:Bt,getOwnPropertySymbols:Gt,getPrototypeOf:Vt}=Object,I=globalThis,pt=I.trustedTypes,Kt=pt?pt.emptyScript:"",Wt=I.reactiveElementPolyfillSupport,P=(s,t)=>s,T={toAttribute(s,t){switch(t){case Boolean:s=s?Kt:null;break;case Object:case Array:s=s==null?s:JSON.stringify(s)}return s},fromAttribute(s,t){let e=s;switch(t){case Boolean:e=s!==null;break;case Number:e=s===null?null:Number(s);break;case Object:case Array:try{e=JSON.parse(s)}catch{e=null}}return e}},B=(s,t)=>!qt(s,t),ht={attribute:!0,type:String,converter:T,reflect:!1,useDefault:!1,hasChanged:B};Symbol.metadata??=Symbol("metadata"),I.litPropertyMetadata??=new WeakMap;var y=class extends HTMLElement{static addInitializer(t){this._$Ei(),(this.l??=[]).push(t)}static get observedAttributes(){return this.finalize(),this._$Eh&&[...this._$Eh.keys()]}static createProperty(t,e=ht){if(e.state&&(e.attribute=!1),this._$Ei(),this.prototype.hasOwnProperty(t)&&((e=Object.create(e)).wrapped=!0),this.elementProperties.set(t,e),!e.noAccessor){let r=Symbol(),o=this.getPropertyDescriptor(t,r,e);o!==void 0&&jt(this.prototype,t,o)}}static getPropertyDescriptor(t,e,r){let{get:o,set:n}=It(this.prototype,t)??{get(){return this[e]},set(i){this[e]=i}};return{get:o,set(i){let l=o?.call(this);n?.call(this,i),this.requestUpdate(t,l,r)},configurable:!0,enumerable:!0}}static getPropertyOptions(t){return this.elementProperties.get(t)??ht}static _$Ei(){if(this.hasOwnProperty(P("elementProperties")))return;let t=Vt(this);t.finalize(),t.l!==void 0&&(this.l=[...t.l]),this.elementProperties=new Map(t.elementProperties)}static finalize(){if(this.hasOwnProperty(P("finalized")))return;if(this.finalized=!0,this._$Ei(),this.hasOwnProperty(P("properties"))){let e=this.properties,r=[...Bt(e),...Gt(e)];for(let o of r)this.createProperty(o,e[o])}let t=this[Symbol.metadata];if(t!==null){let e=litPropertyMetadata.get(t);if(e!==void 0)for(let[r,o]of e)this.elementProperties.set(r,o)}this._$Eh=new Map;for(let[e,r]of this.elementProperties){let o=this._$Eu(e,r);o!==void 0&&this._$Eh.set(o,e)}this.elementStyles=this.finalizeStyles(this.styles)}static finalizeStyles(t){let e=[];if(Array.isArray(t)){let r=new Set(t.flat(1/0).reverse());for(let o of r)e.unshift(J(o))}else t!==void 0&&e.push(J(t));return e}static _$Eu(t,e){let r=e.attribute;return r===!1?void 0:typeof r=="string"?r:typeof t=="string"?t.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(t=>this.enableUpdating=t),this._$AL=new Map,this._$E_(),this.requestUpdate(),this.constructor.l?.forEach(t=>t(this))}addController(t){(this._$EO??=new Set).add(t),this.renderRoot!==void 0&&this.isConnected&&t.hostConnected?.()}removeController(t){this._$EO?.delete(t)}_$E_(){let t=new Map,e=this.constructor.elementProperties;for(let r of e.keys())this.hasOwnProperty(r)&&(t.set(r,this[r]),delete this[r]);t.size>0&&(this._$Ep=t)}createRenderRoot(){let t=this.shadowRoot??this.attachShadow(this.constructor.shadowRootOptions);return dt(t,this.constructor.elementStyles),t}connectedCallback(){this.renderRoot??=this.createRenderRoot(),this.enableUpdating(!0),this._$EO?.forEach(t=>t.hostConnected?.())}enableUpdating(t){}disconnectedCallback(){this._$EO?.forEach(t=>t.hostDisconnected?.())}attributeChangedCallback(t,e,r){this._$AK(t,r)}_$ET(t,e){let r=this.constructor.elementProperties.get(t),o=this.constructor._$Eu(t,r);if(o!==void 0&&r.reflect===!0){let n=(r.converter?.toAttribute!==void 0?r.converter:T).toAttribute(e,r.type);this._$Em=t,n==null?this.removeAttribute(o):this.setAttribute(o,n),this._$Em=null}}_$AK(t,e){let r=this.constructor,o=r._$Eh.get(t);if(o!==void 0&&this._$Em!==o){let n=r.getPropertyOptions(o),i=typeof n.converter=="function"?{fromAttribute:n.converter}:n.converter?.fromAttribute!==void 0?n.converter:T;this._$Em=o;let l=i.fromAttribute(e,n.type);this[o]=l??this._$Ej?.get(o)??l,this._$Em=null}}requestUpdate(t,e,r,o=!1,n){if(t!==void 0){let i=this.constructor;if(o===!1&&(n=this[t]),r??=i.getPropertyOptions(t),!((r.hasChanged??B)(n,e)||r.useDefault&&r.reflect&&n===this._$Ej?.get(t)&&!this.hasAttribute(i._$Eu(t,r))))return;this.C(t,e,r)}this.isUpdatePending===!1&&(this._$ES=this._$EP())}C(t,e,{useDefault:r,reflect:o,wrapped:n},i){r&&!(this._$Ej??=new Map).has(t)&&(this._$Ej.set(t,i??e??this[t]),n!==!0||i!==void 0)||(this._$AL.has(t)||(this.hasUpdated||r||(e=void 0),this._$AL.set(t,e)),o===!0&&this._$Em!==t&&(this._$Eq??=new Set).add(t))}async _$EP(){this.isUpdatePending=!0;try{await this._$ES}catch(e){Promise.reject(e)}let t=this.scheduleUpdate();return t!=null&&await t,!this.isUpdatePending}scheduleUpdate(){return this.performUpdate()}performUpdate(){if(!this.isUpdatePending)return;if(!this.hasUpdated){if(this.renderRoot??=this.createRenderRoot(),this._$Ep){for(let[o,n]of this._$Ep)this[o]=n;this._$Ep=void 0}let r=this.constructor.elementProperties;if(r.size>0)for(let[o,n]of r){let{wrapped:i}=n,l=this[o];i!==!0||this._$AL.has(o)||l===void 0||this.C(o,void 0,n,l)}}let t=!1,e=this._$AL;try{t=this.shouldUpdate(e),t?(this.willUpdate(e),this._$EO?.forEach(r=>r.hostUpdate?.()),this.update(e)):this._$EM()}catch(r){throw t=!1,this._$EM(),r}t&&this._$AE(e)}willUpdate(t){}_$AE(t){this._$EO?.forEach(e=>e.hostUpdated?.()),this.hasUpdated||(this.hasUpdated=!0,this.firstUpdated(t)),this.updated(t)}_$EM(){this._$AL=new Map,this.isUpdatePending=!1}get updateComplete(){return this.getUpdateComplete()}getUpdateComplete(){return this._$ES}shouldUpdate(t){return!0}update(t){this._$Eq&&=this._$Eq.forEach(e=>this._$ET(e,this[e])),this._$EM()}updated(t){}firstUpdated(t){}};y.elementStyles=[],y.shadowRootOptions={mode:"open"},y[P("elementProperties")]=new Map,y[P("finalized")]=new Map,Wt?.({ReactiveElement:y}),(I.reactiveElementVersions??=[]).push("2.1.2");var st=globalThis,ut=s=>s,G=st.trustedTypes,mt=G?G.createPolicy("lit-html",{createHTML:s=>s}):void 0,bt="$lit$",x=`lit$${Math.random().toFixed(9).slice(2)}$`,vt="?"+x,Yt=`<${vt}>`,A=document,N=()=>A.createComment(""),k=s=>s===null||typeof s!="object"&&typeof s!="function",ot=Array.isArray,Ft=s=>ot(s)||typeof s?.[Symbol.iterator]=="function",Z=`[
|
|
2
|
+
\f\r]`,R=/<(?:(!--|\/[^a-zA-Z])|(\/?[a-zA-Z][^>\s]*)|(\/?$))/g,ft=/-->/g,gt=/>/g,v=RegExp(`>|${Z}(?:([^\\s"'>=/]+)(${Z}*=${Z}*(?:[^
|
|
3
|
+
\f\r"'\`<>=]|("|')|))|$)`,"g"),yt=/'/g,xt=/"/g,_t=/^(?:script|style|textarea|title)$/i,nt=s=>(t,...e)=>({_$litType$:s,strings:t,values:e}),h=nt(1),de=nt(2),pe=nt(3),S=Symbol.for("lit-noChange"),d=Symbol.for("lit-nothing"),$t=new WeakMap,_=A.createTreeWalker(A,129);function At(s,t){if(!ot(s)||!s.hasOwnProperty("raw"))throw Error("invalid template strings array");return mt!==void 0?mt.createHTML(t):t}var Jt=(s,t)=>{let e=s.length-1,r=[],o,n=t===2?"<svg>":t===3?"<math>":"",i=R;for(let l=0;l<e;l++){let a=s[l],p,u,c=-1,m=0;for(;m<a.length&&(i.lastIndex=m,u=i.exec(a),u!==null);)m=i.lastIndex,i===R?u[1]==="!--"?i=ft:u[1]!==void 0?i=gt:u[2]!==void 0?(_t.test(u[2])&&(o=RegExp("</"+u[2],"g")),i=v):u[3]!==void 0&&(i=v):i===v?u[0]===">"?(i=o??R,c=-1):u[1]===void 0?c=-2:(c=i.lastIndex-u[2].length,p=u[1],i=u[3]===void 0?v:u[3]==='"'?xt:yt):i===xt||i===yt?i=v:i===ft||i===gt?i=R:(i=v,o=void 0);let f=i===v&&s[l+1].startsWith("/>")?" ":"";n+=i===R?a+Yt:c>=0?(r.push(p),a.slice(0,c)+bt+a.slice(c)+x+f):a+x+(c===-2?l:f)}return[At(s,n+(s[e]||"<?>")+(t===2?"</svg>":t===3?"</math>":"")),r]},L=class s{constructor({strings:t,_$litType$:e},r){let o;this.parts=[];let n=0,i=0,l=t.length-1,a=this.parts,[p,u]=Jt(t,e);if(this.el=s.createElement(p,r),_.currentNode=this.el.content,e===2||e===3){let c=this.el.content.firstChild;c.replaceWith(...c.childNodes)}for(;(o=_.nextNode())!==null&&a.length<l;){if(o.nodeType===1){if(o.hasAttributes())for(let c of o.getAttributeNames())if(c.endsWith(bt)){let m=u[i++],f=o.getAttribute(c).split(x),O=/([.?@])?(.*)/.exec(m);a.push({type:1,index:n,name:O[2],strings:f,ctor:O[1]==="."?Q:O[1]==="?"?tt:O[1]==="@"?et:E}),o.removeAttribute(c)}else c.startsWith(x)&&(a.push({type:6,index:n}),o.removeAttribute(c));if(_t.test(o.tagName)){let c=o.textContent.split(x),m=c.length-1;if(m>0){o.textContent=G?G.emptyScript:"";for(let f=0;f<m;f++)o.append(c[f],N()),_.nextNode(),a.push({type:2,index:++n});o.append(c[m],N())}}}else if(o.nodeType===8)if(o.data===vt)a.push({type:2,index:n});else{let c=-1;for(;(c=o.data.indexOf(x,c+1))!==-1;)a.push({type:7,index:n}),c+=x.length-1}n++}}static createElement(t,e){let r=A.createElement("template");return r.innerHTML=t,r}};function w(s,t,e=s,r){if(t===S)return t;let o=r!==void 0?e._$Co?.[r]:e._$Cl,n=k(t)?void 0:t._$litDirective$;return o?.constructor!==n&&(o?._$AO?.(!1),n===void 0?o=void 0:(o=new n(s),o._$AT(s,e,r)),r!==void 0?(e._$Co??=[])[r]=o:e._$Cl=o),o!==void 0&&(t=w(s,o._$AS(s,t.values),o,r)),t}var X=class{constructor(t,e){this._$AV=[],this._$AN=void 0,this._$AD=t,this._$AM=e}get parentNode(){return this._$AM.parentNode}get _$AU(){return this._$AM._$AU}u(t){let{el:{content:e},parts:r}=this._$AD,o=(t?.creationScope??A).importNode(e,!0);_.currentNode=o;let n=_.nextNode(),i=0,l=0,a=r[0];for(;a!==void 0;){if(i===a.index){let p;a.type===2?p=new M(n,n.nextSibling,this,t):a.type===1?p=new a.ctor(n,a.name,a.strings,this,t):a.type===6&&(p=new rt(n,this,t)),this._$AV.push(p),a=r[++l]}i!==a?.index&&(n=_.nextNode(),i++)}return _.currentNode=A,o}p(t){let e=0;for(let r of this._$AV)r!==void 0&&(r.strings!==void 0?(r._$AI(t,r,e),e+=r.strings.length-2):r._$AI(t[e])),e++}},M=class s{get _$AU(){return this._$AM?._$AU??this._$Cv}constructor(t,e,r,o){this.type=2,this._$AH=d,this._$AN=void 0,this._$AA=t,this._$AB=e,this._$AM=r,this.options=o,this._$Cv=o?.isConnected??!0}get parentNode(){let t=this._$AA.parentNode,e=this._$AM;return e!==void 0&&t?.nodeType===11&&(t=e.parentNode),t}get startNode(){return this._$AA}get endNode(){return this._$AB}_$AI(t,e=this){t=w(this,t,e),k(t)?t===d||t==null||t===""?(this._$AH!==d&&this._$AR(),this._$AH=d):t!==this._$AH&&t!==S&&this._(t):t._$litType$!==void 0?this.$(t):t.nodeType!==void 0?this.T(t):Ft(t)?this.k(t):this._(t)}O(t){return this._$AA.parentNode.insertBefore(t,this._$AB)}T(t){this._$AH!==t&&(this._$AR(),this._$AH=this.O(t))}_(t){this._$AH!==d&&k(this._$AH)?this._$AA.nextSibling.data=t:this.T(A.createTextNode(t)),this._$AH=t}$(t){let{values:e,_$litType$:r}=t,o=typeof r=="number"?this._$AC(t):(r.el===void 0&&(r.el=L.createElement(At(r.h,r.h[0]),this.options)),r);if(this._$AH?._$AD===o)this._$AH.p(e);else{let n=new X(o,this),i=n.u(this.options);n.p(e),this.T(i),this._$AH=n}}_$AC(t){let e=$t.get(t.strings);return e===void 0&&$t.set(t.strings,e=new L(t)),e}k(t){ot(this._$AH)||(this._$AH=[],this._$AR());let e=this._$AH,r,o=0;for(let n of t)o===e.length?e.push(r=new s(this.O(N()),this.O(N()),this,this.options)):r=e[o],r._$AI(n),o++;o<e.length&&(this._$AR(r&&r._$AB.nextSibling,o),e.length=o)}_$AR(t=this._$AA.nextSibling,e){for(this._$AP?.(!1,!0,e);t!==this._$AB;){let r=ut(t).nextSibling;ut(t).remove(),t=r}}setConnected(t){this._$AM===void 0&&(this._$Cv=t,this._$AP?.(t))}},E=class{get tagName(){return this.element.tagName}get _$AU(){return this._$AM._$AU}constructor(t,e,r,o,n){this.type=1,this._$AH=d,this._$AN=void 0,this.element=t,this.name=e,this._$AM=o,this.options=n,r.length>2||r[0]!==""||r[1]!==""?(this._$AH=Array(r.length-1).fill(new String),this.strings=r):this._$AH=d}_$AI(t,e=this,r,o){let n=this.strings,i=!1;if(n===void 0)t=w(this,t,e,0),i=!k(t)||t!==this._$AH&&t!==S,i&&(this._$AH=t);else{let l=t,a,p;for(t=n[0],a=0;a<n.length-1;a++)p=w(this,l[r+a],e,a),p===S&&(p=this._$AH[a]),i||=!k(p)||p!==this._$AH[a],p===d?t=d:t!==d&&(t+=(p??"")+n[a+1]),this._$AH[a]=p}i&&!o&&this.j(t)}j(t){t===d?this.element.removeAttribute(this.name):this.element.setAttribute(this.name,t??"")}},Q=class extends E{constructor(){super(...arguments),this.type=3}j(t){this.element[this.name]=t===d?void 0:t}},tt=class extends E{constructor(){super(...arguments),this.type=4}j(t){this.element.toggleAttribute(this.name,!!t&&t!==d)}},et=class extends E{constructor(t,e,r,o,n){super(t,e,r,o,n),this.type=5}_$AI(t,e=this){if((t=w(this,t,e,0)??d)===S)return;let r=this._$AH,o=t===d&&r!==d||t.capture!==r.capture||t.once!==r.once||t.passive!==r.passive,n=t!==d&&(r===d||o);o&&this.element.removeEventListener(this.name,this,r),n&&this.element.addEventListener(this.name,this,t),this._$AH=t}handleEvent(t){typeof this._$AH=="function"?this._$AH.call(this.options?.host??this.element,t):this._$AH.handleEvent(t)}},rt=class{constructor(t,e,r){this.element=t,this.type=6,this._$AN=void 0,this._$AM=e,this.options=r}get _$AU(){return this._$AM._$AU}_$AI(t){w(this,t)}};var Zt=st.litHtmlPolyfillSupport;Zt?.(L,M),(st.litHtmlVersions??=[]).push("3.3.2");var St=(s,t,e)=>{let r=e?.renderBefore??t,o=r._$litPart$;if(o===void 0){let n=e?.renderBefore??null;r._$litPart$=o=new M(t.insertBefore(N(),n),n,void 0,e??{})}return o._$AI(s),o};var it=globalThis,$=class extends y{constructor(){super(...arguments),this.renderOptions={host:this},this._$Do=void 0}createRenderRoot(){let t=super.createRenderRoot();return this.renderOptions.renderBefore??=t.firstChild,t}update(t){let e=this.render();this.hasUpdated||(this.renderOptions.isConnected=this.isConnected),super.update(t),this._$Do=St(e,this.renderRoot,this.renderOptions)}connectedCallback(){super.connectedCallback(),this._$Do?.setConnected(!0)}disconnectedCallback(){super.disconnectedCallback(),this._$Do?.setConnected(!1)}render(){return S}};$._$litElement$=!0,$.finalized=!0,it.litElementHydrateSupport?.({LitElement:$});var Xt=it.litElementPolyfillSupport;Xt?.({LitElement:$});(it.litElementVersions??=[]).push("4.2.2");var wt=s=>(t,e)=>{e!==void 0?e.addInitializer(()=>{customElements.define(s,t)}):customElements.define(s,t)};var Qt={attribute:!0,type:String,converter:T,reflect:!1,hasChanged:B},te=(s=Qt,t,e)=>{let{kind:r,metadata:o}=e,n=globalThis.litPropertyMetadata.get(o);if(n===void 0&&globalThis.litPropertyMetadata.set(o,n=new Map),r==="setter"&&((s=Object.create(s)).wrapped=!0),n.set(e.name,s),r==="accessor"){let{name:i}=e;return{set(l){let a=t.get.call(this);t.set.call(this,l),this.requestUpdate(i,a,s,!0,l)},init(l){return l!==void 0&&this.C(i,void 0,s,l),l}}}if(r==="setter"){let{name:i}=e;return function(l){let a=this[i];t.call(this,l),this.requestUpdate(i,a,s,!0,l)}}throw Error("Unsupported decorator location: "+r)};function V(s){return(t,e)=>typeof e=="object"?te(s,t,e):((r,o,n)=>{let i=o.hasOwnProperty(n);return o.constructor.createProperty(n,r),i?Object.getOwnPropertyDescriptor(o,n):void 0})(s,t,e)}function Et(s){return V({...s,state:!0,attribute:!1})}var W={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 Ct={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 ee=["Aries","Taurus","Gemini","Cancer","Leo","Virgo","Libra","Scorpio","Sagittarius","Capricorn","Aquarius","Pisces"],Ze=ee.map(s=>s.toLowerCase());var Pt=g`: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}*,: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)}:host(:focus-within) .roxy-card{outline:2px solid var(--roxy-ring,#f59e0b66);outline-offset:2px}:host{font-variant-emoji:text}`;function Tt(){return h`<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 Rt=g`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 Nt(s){if(typeof s!="string"||s.length===0||/^\d{4}-\d{2}-\d{2}$/.test(s))return"";let e=/^\d{2}:\d{2}(:\d{2})?$/.test(s)?`1970-01-01T${s}`:s,r=new Date(e);return Number.isNaN(r.getTime())?s:r.toLocaleTimeString(void 0,{hour:"numeric",minute:"2-digit",hour12:!0})}function kt(s){if(typeof s!="string"||s.length===0)return"";let t=new Date(/^\d{4}-\d{2}-\d{2}$/.test(s)?`${s}T00:00:00`:s);return Number.isNaN(t.getTime())?s:t.toLocaleDateString(void 0,{month:"short",day:"numeric",year:"numeric"})}function U(s,t=1){return typeof s!="number"||!Number.isFinite(s)?"":s.toFixed(t).replace(/\.?0+$/,"")}var re="roxy-data";function se(s){return s.nodeName==="SCRIPT"&&s.getAttribute("type")==="application/json"}var Y=class{constructor(t){this.host=t,t.addController(this)}hostConnected(){if(this.host.data!=null)return;let t=this.read();t!==void 0&&(this.host.data=t,this.host.requestUpdate())}read(){let t=this.findInlineScript();return t?this.parse(t.textContent):void 0}findInlineScript(){for(let t of Array.from(this.host.children))if(se(t)&&t.classList.contains(re))return t;return null}parse(t){if(t?.trim())try{return JSON.parse(t)}catch{return}}};function H(s){return s?s.charAt(0).toUpperCase()+s.slice(1).toLowerCase():""}var Lt=g`.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-fg,#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 Mt(s){let{items:t,active:e,onSelect:r,label:o,idPrefix:n,controls:i=!1}=s;return h`<div class="roxy-tablist" role="tablist" aria-label="${o}" @keydown="${a=>{if(a.key!=="ArrowRight"&&a.key!=="ArrowLeft")return;a.preventDefault();let p=t.findIndex(f=>f.id===e);if(p===-1)return;let u=a.key==="ArrowRight"?1:-1,c=t[(p+u+t.length)%t.length];if(!c)return;r(c.id);let m=a.currentTarget.getRootNode();requestAnimationFrame(()=>{m.querySelector(`#${n}-tab-${c.id}`)?.focus()})}}">${t.map(a=>h`<button type="button" class="roxy-tab" role="tab" id="${n}-tab-${a.id}" aria-selected="${e===a.id?"true":"false"}" aria-controls="${i&&e===a.id?`${n}-panel-${a.id}`:d}" tabindex="${e===a.id?"0":"-1"}" @click="${()=>r(a.id)}">${a.label}</button>`)}</div>`}var b=class extends ${constructor(){super();this.data=null;this.tab="positions";new Y(this)}render(){if(!this.data?.transitPlanets?.length)return h`<div class="roxy-empty" role="status">No transits data</div>`;let{transitDate:e,transitTime:r,transitPlanets:o,transitAspects:n,summary:i}=this.data,l=[kt(e),Nt(r)].filter(Boolean).join(" "),a=n?.length??0,p=this.tab;return h`<div class="wrap" aria-label="Transits"><div class="head"><h2 class="title">Transits</h2>${l?h`<p class="subtitle">${l}</p>`:d}</div>${a>0?h`${Mt({items:[{id:"positions",label:"Positions"},{id:"aspects",label:`Aspects (${a})`}],active:p,onSelect:u=>{this.tab=u},label:"Transit views",idPrefix:"transits",controls:!0})}<div id="transits-panel-${p}" role="tabpanel" aria-labelledby="transits-tab-${p}">${p==="positions"?h`<div class="overflow-scroll">${this.renderPlanetsTable(o)}</div>`:h`${i?this.renderSummaryPills(i):d}<div class="overflow-scroll">${this.renderAspectsList(n??[])}</div>`}</div>`:h`<div class="overflow-scroll">${this.renderPlanetsTable(o)}</div>`}</div>`}renderSummaryPills(e){return h`<div class="summary-pills" role="region" aria-label="Aspect summary"><span class="pill pill--muted">Total: ${e.totalAspects} </span><span class="pill pill--success">Harmonious: ${e.harmonious} </span><span class="pill pill--danger">Challenging: ${e.challenging} </span><span class="pill pill--muted">Neutral: ${e.neutral}</span></div>`}renderPlanetsTable(e){return h`<table class="planets-table"><thead><tr><th scope="col">Planet</th><th scope="col">Sign</th><th scope="col">Degree</th><th scope="col">Speed</th></tr></thead><tbody>${e.map(r=>{let o=W[H(r.name)]??"",n=Ct[H(r.sign)]??"",i=r.speed>=0?"\u2191":"\u2193";return h`<tr><td><div class="planet-cell"><span class="glyph" aria-hidden="true">${o}</span> ${r.name} ${r.isRetrograde?h`<span class="retro-badge" aria-label="retrograde">R</span>`:d}</div></td><td><div class="planet-cell"><span class="glyph" aria-hidden="true">${n}</span> ${r.sign}</div></td><td class="num">${U(r.degree,2)}</td><td class="speed"><span class="speed-arrow" aria-hidden="true">${i}</span> ${U(Math.abs(r.speed),4)}</td></tr>`})}</tbody></table>`}renderAspectsList(e){return h`<div role="list" aria-label="Transit aspects">${e.map((r,o)=>{let n=W[H(r.transitPlanet)]??"",i=W[H(r.natalPlanet)]??"",l=(r.nature??"neutral").toLowerCase(),a=r.interpretation,p=(r.type??"").toLowerCase(),u=r.isApplying?"Applying":"Separating";return h`<details class="aspect-card" role="listitem" name="transit-aspects" ?open="${o===0}"><summary><span aria-hidden="true">${n}</span> ${r.transitPlanet} <span class="nature-badge ${l}">${p}</span> <span aria-hidden="true">${i}</span> ${r.natalPlanet} <span class="meta">${u} · orb ${U(r.orb,2)}° · strength ${U(r.strength,1)} </span>${Tt()}</summary><div class="interp-body">${a?.summary?h`<p>${a.summary}</p>`:d} ${a?.impact?h`<p><strong>Impact:</strong> ${a.impact}</p>`:d} ${a?.timing?h`<p><strong>Timing:</strong> ${a.timing}</p>`:d} ${a?.guidance?h`<p><strong>Guidance:</strong> ${a.guidance}</p>`:d} ${a?.keywords?.length?h`<div class="interp-keywords">${a.keywords.map(c=>h`<span class="kw">${c}</span>`)}</div>`:d}</div></details>`})}</div>`}};b.styles=[Pt,Lt,Rt,g`.wrap{gap:var(--roxy-space-md,1rem);display:grid}.head{justify-content:space-between;align-items:baseline;gap:var(--roxy-space-md,1rem);flex-wrap:wrap;display:flex}.title{font-size:var(--roxy-text-lg,1.125rem);font-weight:var(--roxy-weight-bold,600);margin:0}.subtitle{color:var(--roxy-muted,#71717a);font-size:var(--roxy-text-sm,.875rem);margin:0}.summary-pills{gap:var(--roxy-space-sm,.5rem);flex-wrap:wrap;display:flex}.pill{padding:2px var(--roxy-space-sm,.5rem);border-radius:var(--roxy-radius-full,9999px);font-size:var(--roxy-text-xs,.75rem);font-weight:var(--roxy-weight-bold,600);border:1px solid;align-items:center;gap:4px;display:inline-flex}.pill--muted{color:var(--roxy-fg,#0a0a0a);background:color-mix(in srgb, var(--roxy-border,#e4e4e7) 60%, transparent)}.pill--success{color:var(--roxy-success-fg,#166534);background:color-mix(in srgb, var(--roxy-success,#16a34a) 10%, transparent)}.pill--danger{color:var(--roxy-danger-fg,#991b1b);background:color-mix(in srgb, var(--roxy-danger,#dc2626) 10%, transparent)}table{border-collapse:collapse;width:100%;font-size:var(--roxy-text-sm,.875rem)}th,td{padding:var(--roxy-space-sm,.5rem);border-bottom:1px solid var(--roxy-border,#e4e4e7);text-align:left}th{color:var(--roxy-muted,#71717a);font-weight:var(--roxy-weight-bold,600);text-transform:uppercase;font-size:var(--roxy-text-xs,.75rem);letter-spacing:.06em}.section-label{font-size:var(--roxy-text-xs,.75rem);color:var(--roxy-muted,#71717a);text-transform:uppercase;letter-spacing:.06em;font-weight:var(--roxy-weight-bold,600);margin:0 0 var(--roxy-space-xs,.25rem) 0}.glyph{margin-right:2px;font-size:1.1em;line-height:1}.planet-cell{white-space:nowrap;align-items:center;gap:4px;display:flex}.retro-badge{border-radius:var(--roxy-radius-sm,4px);background:color-mix(in srgb, var(--roxy-warning,#ea580c) 12%, transparent);color:var(--roxy-warning-fg,#9a3412);font-size:.7em;font-weight:var(--roxy-weight-bold,600);vertical-align:middle;margin-left:2px;padding:1px 4px;display:inline-block}.speed{font-variant-numeric:tabular-nums;color:var(--roxy-muted,#71717a);white-space:nowrap}.speed-arrow{font-size:.85em}td.num{font-variant-numeric:tabular-nums;color:var(--roxy-muted,#71717a)}.overflow-scroll{-webkit-overflow-scrolling:touch;overflow-x:auto}.aspect-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)}.aspect-card summary{cursor:pointer;color:var(--roxy-fg,#0a0a0a);flex-wrap:wrap;align-items:center;gap:.5em;font-weight:500;display:flex}.aspect-card summary .meta{color:var(--roxy-muted,#71717a);font-weight:400;font-size:var(--roxy-text-xs,.75rem);font-variant-numeric:tabular-nums;margin-left:auto}.aspect-card .interp-body{margin-top:var(--roxy-space-xs,.25rem);color:var(--roxy-fg,#0a0a0a);font-size:var(--roxy-text-sm,.875rem);line-height:1.45}.aspect-card .interp-body p{margin:0 0 var(--roxy-space-xs,.25rem)}.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-fg,#b45309);font-size:var(--roxy-text-xs,.75rem);border-radius:9999px;padding:1px 8px}.nature-badge{font-size:var(--roxy-text-xs,.75rem);border-radius:9999px;padding:1px 8px;font-weight:600;display:inline-block}.nature-badge.harmonious{background:color-mix(in srgb, var(--roxy-success,#16a34a) 12%, transparent);color:var(--roxy-success-fg,#166534)}.nature-badge.challenging{background:color-mix(in srgb, var(--roxy-danger,#dc2626) 12%, transparent);color:var(--roxy-danger-fg,#991b1b)}.nature-badge.neutral{background:color-mix(in srgb, var(--roxy-border,#e4e4e7) 60%, transparent);color:var(--roxy-fg,#0a0a0a)}`],D([V({attribute:!1})],b.prototype,"data",2),D([Et()],b.prototype,"tab",2),b=D([wt("roxy-transits-table")],b);return Dt(oe);})();
|
|
383
4
|
/*! Bundled license information:
|
|
384
5
|
|
|
385
6
|
@lit/reactive-element/css-tag.js:
|