@roxyapi/ui 0.0.1 → 0.1.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 (166) hide show
  1. package/AGENTS.md +169 -0
  2. package/THEMING.md +129 -0
  3. package/dist/cdn/components/biorhythm-chart.js +261 -0
  4. package/dist/cdn/components/biorhythm-chart.js.map +7 -0
  5. package/dist/cdn/components/compatibility-card.js +257 -0
  6. package/dist/cdn/components/compatibility-card.js.map +7 -0
  7. package/dist/cdn/components/dasha-timeline.js +244 -0
  8. package/dist/cdn/components/dasha-timeline.js.map +7 -0
  9. package/dist/cdn/components/data.js +258 -0
  10. package/dist/cdn/components/data.js.map +7 -0
  11. package/dist/cdn/components/dosha-card.js +254 -0
  12. package/dist/cdn/components/dosha-card.js.map +7 -0
  13. package/dist/cdn/components/endpoint-form.js +253 -0
  14. package/dist/cdn/components/endpoint-form.js.map +7 -0
  15. package/dist/cdn/components/guna-milan.js +256 -0
  16. package/dist/cdn/components/guna-milan.js.map +7 -0
  17. package/dist/cdn/components/hexagram.js +275 -0
  18. package/dist/cdn/components/hexagram.js.map +7 -0
  19. package/dist/cdn/components/horoscope-card.js +302 -0
  20. package/dist/cdn/components/horoscope-card.js.map +7 -0
  21. package/dist/cdn/components/kp-planets-table.js +224 -0
  22. package/dist/cdn/components/kp-planets-table.js.map +7 -0
  23. package/dist/cdn/components/location-search.js +267 -0
  24. package/dist/cdn/components/location-search.js.map +7 -0
  25. package/dist/cdn/components/moon-phase.js +251 -0
  26. package/dist/cdn/components/moon-phase.js.map +7 -0
  27. package/dist/cdn/components/natal-chart.js +237 -0
  28. package/dist/cdn/components/natal-chart.js.map +7 -0
  29. package/dist/cdn/components/numerology-card.js +252 -0
  30. package/dist/cdn/components/numerology-card.js.map +7 -0
  31. package/dist/cdn/components/panchang-table.js +234 -0
  32. package/dist/cdn/components/panchang-table.js.map +7 -0
  33. package/dist/cdn/components/synastry-chart.js +303 -0
  34. package/dist/cdn/components/synastry-chart.js.map +7 -0
  35. package/dist/cdn/components/tarot-card.js +260 -0
  36. package/dist/cdn/components/tarot-card.js.map +7 -0
  37. package/dist/cdn/components/tarot-spread.js +261 -0
  38. package/dist/cdn/components/tarot-spread.js.map +7 -0
  39. package/dist/cdn/components/vedic-kundli.js +189 -0
  40. package/dist/cdn/components/vedic-kundli.js.map +7 -0
  41. package/dist/cdn/roxy-ui.js +2552 -0
  42. package/dist/cdn/roxy-ui.js.map +7 -0
  43. package/dist/cdn/widgets.js +114 -0
  44. package/dist/components/biorhythm-chart.d.ts +66 -0
  45. package/dist/components/biorhythm-chart.d.ts.map +1 -0
  46. package/dist/components/biorhythm-chart.js +318 -0
  47. package/dist/components/biorhythm-chart.js.map +7 -0
  48. package/dist/components/compatibility-card.d.ts +46 -0
  49. package/dist/components/compatibility-card.d.ts.map +1 -0
  50. package/dist/components/compatibility-card.js +279 -0
  51. package/dist/components/compatibility-card.js.map +7 -0
  52. package/dist/components/dasha-timeline.d.ts +53 -0
  53. package/dist/components/dasha-timeline.d.ts.map +1 -0
  54. package/dist/components/dasha-timeline.js +269 -0
  55. package/dist/components/dasha-timeline.js.map +7 -0
  56. package/dist/components/data.d.ts +40 -0
  57. package/dist/components/data.d.ts.map +1 -0
  58. package/dist/components/data.js +339 -0
  59. package/dist/components/data.js.map +7 -0
  60. package/dist/components/dosha-card.d.ts +35 -0
  61. package/dist/components/dosha-card.d.ts.map +1 -0
  62. package/dist/components/dosha-card.js +278 -0
  63. package/dist/components/dosha-card.js.map +7 -0
  64. package/dist/components/endpoint-form.d.ts +39 -0
  65. package/dist/components/endpoint-form.d.ts.map +1 -0
  66. package/dist/components/endpoint-form.js +432 -0
  67. package/dist/components/endpoint-form.js.map +7 -0
  68. package/dist/components/guna-milan.d.ts +35 -0
  69. package/dist/components/guna-milan.d.ts.map +1 -0
  70. package/dist/components/guna-milan.js +302 -0
  71. package/dist/components/guna-milan.js.map +7 -0
  72. package/dist/components/hexagram.d.ts +47 -0
  73. package/dist/components/hexagram.d.ts.map +1 -0
  74. package/dist/components/hexagram.js +334 -0
  75. package/dist/components/hexagram.js.map +7 -0
  76. package/dist/components/horoscope-card.d.ts +38 -0
  77. package/dist/components/horoscope-card.d.ts.map +1 -0
  78. package/dist/components/horoscope-card.js +332 -0
  79. package/dist/components/horoscope-card.js.map +7 -0
  80. package/dist/components/kp-planets-table.d.ts +36 -0
  81. package/dist/components/kp-planets-table.d.ts.map +1 -0
  82. package/dist/components/kp-planets-table.js +227 -0
  83. package/dist/components/kp-planets-table.js.map +7 -0
  84. package/dist/components/location-search.d.ts +56 -0
  85. package/dist/components/location-search.d.ts.map +1 -0
  86. package/dist/components/location-search.js +401 -0
  87. package/dist/components/location-search.js.map +7 -0
  88. package/dist/components/moon-phase.d.ts +38 -0
  89. package/dist/components/moon-phase.d.ts.map +1 -0
  90. package/dist/components/moon-phase.js +284 -0
  91. package/dist/components/moon-phase.js.map +7 -0
  92. package/dist/components/natal-chart.d.ts +65 -0
  93. package/dist/components/natal-chart.d.ts.map +1 -0
  94. package/dist/components/natal-chart.js +407 -0
  95. package/dist/components/natal-chart.js.map +7 -0
  96. package/dist/components/numerology-card.d.ts +55 -0
  97. package/dist/components/numerology-card.d.ts.map +1 -0
  98. package/dist/components/numerology-card.js +274 -0
  99. package/dist/components/numerology-card.js.map +7 -0
  100. package/dist/components/panchang-table.d.ts +77 -0
  101. package/dist/components/panchang-table.d.ts.map +1 -0
  102. package/dist/components/panchang-table.js +285 -0
  103. package/dist/components/panchang-table.js.map +7 -0
  104. package/dist/components/synastry-chart.d.ts +52 -0
  105. package/dist/components/synastry-chart.d.ts.map +1 -0
  106. package/dist/components/synastry-chart.js +415 -0
  107. package/dist/components/synastry-chart.js.map +7 -0
  108. package/dist/components/tarot-card.d.ts +47 -0
  109. package/dist/components/tarot-card.d.ts.map +1 -0
  110. package/dist/components/tarot-card.js +281 -0
  111. package/dist/components/tarot-card.js.map +7 -0
  112. package/dist/components/tarot-spread.d.ts +42 -0
  113. package/dist/components/tarot-spread.d.ts.map +1 -0
  114. package/dist/components/tarot-spread.js +271 -0
  115. package/dist/components/tarot-spread.js.map +7 -0
  116. package/dist/components/vedic-kundli.d.ts +45 -0
  117. package/dist/components/vedic-kundli.d.ts.map +1 -0
  118. package/dist/components/vedic-kundli.js +325 -0
  119. package/dist/components/vedic-kundli.js.map +7 -0
  120. package/dist/index.cjs +4174 -0
  121. package/dist/index.cjs.map +7 -0
  122. package/dist/index.d.ts +30 -0
  123. package/dist/index.d.ts.map +1 -0
  124. package/dist/index.js +4154 -0
  125. package/dist/index.js.map +7 -0
  126. package/dist/manifest.json +24 -0
  127. package/dist/styles/tokens.css +147 -0
  128. package/dist/tokens/index.d.ts +17 -0
  129. package/dist/tokens/index.d.ts.map +1 -0
  130. package/dist/utils/base-styles.d.ts +6 -0
  131. package/dist/utils/base-styles.d.ts.map +1 -0
  132. package/dist/utils/debounce.d.ts +5 -0
  133. package/dist/utils/debounce.d.ts.map +1 -0
  134. package/dist/utils/degree.d.ts +29 -0
  135. package/dist/utils/degree.d.ts.map +1 -0
  136. package/dist/utils/motion.d.ts +13 -0
  137. package/dist/utils/motion.d.ts.map +1 -0
  138. package/package.json +69 -3
  139. package/src/components/biorhythm-chart.ts +290 -0
  140. package/src/components/compatibility-card.ts +231 -0
  141. package/src/components/dasha-timeline.ts +251 -0
  142. package/src/components/data.ts +287 -0
  143. package/src/components/dosha-card.ts +215 -0
  144. package/src/components/endpoint-form.ts +433 -0
  145. package/src/components/guna-milan.ts +245 -0
  146. package/src/components/hexagram.ts +279 -0
  147. package/src/components/horoscope-card.ts +291 -0
  148. package/src/components/kp-planets-table.ts +156 -0
  149. package/src/components/location-search.ts +335 -0
  150. package/src/components/moon-phase.ts +221 -0
  151. package/src/components/natal-chart.ts +298 -0
  152. package/src/components/numerology-card.ts +243 -0
  153. package/src/components/panchang-table.ts +265 -0
  154. package/src/components/synastry-chart.ts +341 -0
  155. package/src/components/tarot-card.ts +235 -0
  156. package/src/components/tarot-spread.ts +224 -0
  157. package/src/components/vedic-kundli.ts +257 -0
  158. package/src/index.ts +61 -0
  159. package/src/styles/tokens.css +147 -0
  160. package/src/tokens/index.ts +130 -0
  161. package/src/types/index.ts +3 -0
  162. package/src/types/types.gen.ts +28526 -0
  163. package/src/utils/base-styles.ts +89 -0
  164. package/src/utils/debounce.ts +13 -0
  165. package/src/utils/degree.ts +64 -0
  166. package/src/utils/motion.ts +18 -0
@@ -0,0 +1,253 @@
1
+ "use strict";var RoxyUI_endpoint_form=(()=>{var L=Object.defineProperty;var ie=Object.getOwnPropertyDescriptor;var Ee=Object.getOwnPropertyNames;var we=Object.prototype.hasOwnProperty;var Ce=(i,e)=>{for(var t in e)L(i,t,{get:e[t],enumerable:!0})},Oe=(i,e,t,s)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of Ee(e))!we.call(i,r)&&r!==t&&L(i,r,{get:()=>e[r],enumerable:!(s=ie(e,r))||s.enumerable});return i};var Pe=i=>Oe(L({},"__esModule",{value:!0}),i),y=(i,e,t,s)=>{for(var r=s>1?void 0:s?ie(e,t):e,o=i.length-1,n;o>=0;o--)(n=i[o])&&(r=(s?n(e,t,r):n(r))||r);return s&&r&&L(e,t,r),r};var We={};Ce(We,{RoxyEndpointForm:()=>m});var j=globalThis,D=j.ShadowRoot&&(j.ShadyCSS===void 0||j.ShadyCSS.nativeShadow)&&"adoptedStyleSheets"in Document.prototype&&"replace"in CSSStyleSheet.prototype,K=Symbol(),oe=new WeakMap,O=class{constructor(e,t,s){if(this._$cssResult$=!0,s!==K)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(D&&e===void 0){let s=t!==void 0&&t.length===1;s&&(e=oe.get(t)),e===void 0&&((this.o=e=new CSSStyleSheet).replaceSync(this.cssText),s&&oe.set(t,e))}return e}toString(){return this.cssText}},ne=i=>new O(typeof i=="string"?i:i+"",void 0,K),P=(i,...e)=>{let t=i.length===1?i[0]:e.reduce((s,r,o)=>s+(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.")})(r)+i[o+1],i[0]);return new O(t,i,K)},ae=(i,e)=>{if(D)i.adoptedStyleSheets=e.map(t=>t instanceof CSSStyleSheet?t:t.styleSheet);else for(let t of e){let s=document.createElement("style"),r=j.litNonce;r!==void 0&&s.setAttribute("nonce",r),s.textContent=t.cssText,i.appendChild(s)}},J=D?i=>i:i=>i instanceof CSSStyleSheet?(e=>{let t="";for(let s of e.cssRules)t+=s.cssText;return ne(t)})(i):i;var{is:Ue,defineProperty:Te,getOwnPropertyDescriptor:ke,getOwnPropertyNames:Me,getOwnPropertySymbols:Re,getPrototypeOf:qe}=Object,B=globalThis,le=B.trustedTypes,He=le?le.emptyScript:"",Ne=B.reactiveElementPolyfillSupport,U=(i,e)=>i,T={toAttribute(i,e){switch(e){case Boolean:i=i?He: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}},I=(i,e)=>!Ue(i,e),ce={attribute:!0,type:String,converter:T,reflect:!1,useDefault:!1,hasChanged:I};Symbol.metadata??=Symbol("metadata"),B.litPropertyMetadata??=new WeakMap;var $=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=ce){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 s=Symbol(),r=this.getPropertyDescriptor(e,s,t);r!==void 0&&Te(this.prototype,e,r)}}static getPropertyDescriptor(e,t,s){let{get:r,set:o}=ke(this.prototype,e)??{get(){return this[t]},set(n){this[t]=n}};return{get:r,set(n){let l=r?.call(this);o?.call(this,n),this.requestUpdate(e,l,s)},configurable:!0,enumerable:!0}}static getPropertyOptions(e){return this.elementProperties.get(e)??ce}static _$Ei(){if(this.hasOwnProperty(U("elementProperties")))return;let e=qe(this);e.finalize(),e.l!==void 0&&(this.l=[...e.l]),this.elementProperties=new Map(e.elementProperties)}static finalize(){if(this.hasOwnProperty(U("finalized")))return;if(this.finalized=!0,this._$Ei(),this.hasOwnProperty(U("properties"))){let t=this.properties,s=[...Me(t),...Re(t)];for(let r of s)this.createProperty(r,t[r])}let e=this[Symbol.metadata];if(e!==null){let t=litPropertyMetadata.get(e);if(t!==void 0)for(let[s,r]of t)this.elementProperties.set(s,r)}this._$Eh=new Map;for(let[t,s]of this.elementProperties){let r=this._$Eu(t,s);r!==void 0&&this._$Eh.set(r,t)}this.elementStyles=this.finalizeStyles(this.styles)}static finalizeStyles(e){let t=[];if(Array.isArray(e)){let s=new Set(e.flat(1/0).reverse());for(let r of s)t.unshift(J(r))}else e!==void 0&&t.push(J(e));return t}static _$Eu(e,t){let s=t.attribute;return s===!1?void 0:typeof s=="string"?s: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 s of t.keys())this.hasOwnProperty(s)&&(e.set(s,this[s]),delete this[s]);e.size>0&&(this._$Ep=e)}createRenderRoot(){let e=this.shadowRoot??this.attachShadow(this.constructor.shadowRootOptions);return ae(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,s){this._$AK(e,s)}_$ET(e,t){let s=this.constructor.elementProperties.get(e),r=this.constructor._$Eu(e,s);if(r!==void 0&&s.reflect===!0){let o=(s.converter?.toAttribute!==void 0?s.converter:T).toAttribute(t,s.type);this._$Em=e,o==null?this.removeAttribute(r):this.setAttribute(r,o),this._$Em=null}}_$AK(e,t){let s=this.constructor,r=s._$Eh.get(e);if(r!==void 0&&this._$Em!==r){let o=s.getPropertyOptions(r),n=typeof o.converter=="function"?{fromAttribute:o.converter}:o.converter?.fromAttribute!==void 0?o.converter:T;this._$Em=r;let l=n.fromAttribute(t,o.type);this[r]=l??this._$Ej?.get(r)??l,this._$Em=null}}requestUpdate(e,t,s,r=!1,o){if(e!==void 0){let n=this.constructor;if(r===!1&&(o=this[e]),s??=n.getPropertyOptions(e),!((s.hasChanged??I)(o,t)||s.useDefault&&s.reflect&&o===this._$Ej?.get(e)&&!this.hasAttribute(n._$Eu(e,s))))return;this.C(e,t,s)}this.isUpdatePending===!1&&(this._$ES=this._$EP())}C(e,t,{useDefault:s,reflect:r,wrapped:o},n){s&&!(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||s||(t=void 0),this._$AL.set(e,t)),r===!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[r,o]of this._$Ep)this[r]=o;this._$Ep=void 0}let s=this.constructor.elementProperties;if(s.size>0)for(let[r,o]of s){let{wrapped:n}=o,l=this[r];n!==!0||this._$AL.has(r)||l===void 0||this.C(r,void 0,o,l)}}let e=!1,t=this._$AL;try{e=this.shouldUpdate(t),e?(this.willUpdate(t),this._$EO?.forEach(s=>s.hostUpdate?.()),this.update(t)):this._$EM()}catch(s){throw e=!1,this._$EM(),s}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){}};$.elementStyles=[],$.shadowRootOptions={mode:"open"},$[U("elementProperties")]=new Map,$[U("finalized")]=new Map,Ne?.({ReactiveElement:$}),(B.reactiveElementVersions??=[]).push("2.1.2");var ee=globalThis,he=i=>i,V=ee.trustedTypes,de=V?V.createPolicy("lit-html",{createHTML:i=>i}):void 0,ge="$lit$",v=`lit$${Math.random().toFixed(9).slice(2)}$`,$e="?"+v,ze=`<${$e}>`,A=document,M=()=>A.createComment(""),R=i=>i===null||typeof i!="object"&&typeof i!="function",te=Array.isArray,Le=i=>te(i)||typeof i?.[Symbol.iterator]=="function",Y=`[
2
+ \f\r]`,k=/<(?:(!--|\/[^a-zA-Z])|(\/?[a-zA-Z][^>\s]*)|(\/?$))/g,pe=/-->/g,ue=/>/g,_=RegExp(`>|${Y}(?:([^\\s"'>=/]+)(${Y}*=${Y}*(?:[^
3
+ \f\r"'\`<>=]|("|')|))|$)`,"g"),me=/'/g,fe=/"/g,ve=/^(?:script|style|textarea|title)$/i,se=i=>(e,...t)=>({_$litType$:i,strings:e,values:t}),g=se(1),Qe=se(2),Xe=se(3),S=Symbol.for("lit-noChange"),d=Symbol.for("lit-nothing"),ye=new WeakMap,x=A.createTreeWalker(A,129);function be(i,e){if(!te(i)||!i.hasOwnProperty("raw"))throw Error("invalid template strings array");return de!==void 0?de.createHTML(e):e}var je=(i,e)=>{let t=i.length-1,s=[],r,o=e===2?"<svg>":e===3?"<math>":"",n=k;for(let l=0;l<t;l++){let a=i[l],p,c,h=-1,f=0;for(;f<a.length&&(n.lastIndex=f,c=n.exec(a),c!==null);)f=n.lastIndex,n===k?c[1]==="!--"?n=pe:c[1]!==void 0?n=ue:c[2]!==void 0?(ve.test(c[2])&&(r=RegExp("</"+c[2],"g")),n=_):c[3]!==void 0&&(n=_):n===_?c[0]===">"?(n=r??k,h=-1):c[1]===void 0?h=-2:(h=n.lastIndex-c[2].length,p=c[1],n=c[3]===void 0?_:c[3]==='"'?fe:me):n===fe||n===me?n=_:n===pe||n===ue?n=k:(n=_,r=void 0);let u=n===_&&i[l+1].startsWith("/>")?" ":"";o+=n===k?a+ze:h>=0?(s.push(p),a.slice(0,h)+ge+a.slice(h)+v+u):a+v+(h===-2?l:u)}return[be(i,o+(i[t]||"<?>")+(e===2?"</svg>":e===3?"</math>":"")),s]},q=class i{constructor({strings:e,_$litType$:t},s){let r;this.parts=[];let o=0,n=0,l=e.length-1,a=this.parts,[p,c]=je(e,t);if(this.el=i.createElement(p,s),x.currentNode=this.el.content,t===2||t===3){let h=this.el.content.firstChild;h.replaceWith(...h.childNodes)}for(;(r=x.nextNode())!==null&&a.length<l;){if(r.nodeType===1){if(r.hasAttributes())for(let h of r.getAttributeNames())if(h.endsWith(ge)){let f=c[n++],u=r.getAttribute(h).split(v),z=/([.?@])?(.*)/.exec(f);a.push({type:1,index:o,name:z[2],strings:u,ctor:z[1]==="."?G:z[1]==="?"?Q:z[1]==="@"?X:C}),r.removeAttribute(h)}else h.startsWith(v)&&(a.push({type:6,index:o}),r.removeAttribute(h));if(ve.test(r.tagName)){let h=r.textContent.split(v),f=h.length-1;if(f>0){r.textContent=V?V.emptyScript:"";for(let u=0;u<f;u++)r.append(h[u],M()),x.nextNode(),a.push({type:2,index:++o});r.append(h[f],M())}}}else if(r.nodeType===8)if(r.data===$e)a.push({type:2,index:o});else{let h=-1;for(;(h=r.data.indexOf(v,h+1))!==-1;)a.push({type:7,index:o}),h+=v.length-1}o++}}static createElement(e,t){let s=A.createElement("template");return s.innerHTML=e,s}};function w(i,e,t=i,s){if(e===S)return e;let r=s!==void 0?t._$Co?.[s]:t._$Cl,o=R(e)?void 0:e._$litDirective$;return r?.constructor!==o&&(r?._$AO?.(!1),o===void 0?r=void 0:(r=new o(i),r._$AT(i,t,s)),s!==void 0?(t._$Co??=[])[s]=r:t._$Cl=r),r!==void 0&&(e=w(i,r._$AS(i,e.values),r,s)),e}var Z=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:s}=this._$AD,r=(e?.creationScope??A).importNode(t,!0);x.currentNode=r;let o=x.nextNode(),n=0,l=0,a=s[0];for(;a!==void 0;){if(n===a.index){let p;a.type===2?p=new H(o,o.nextSibling,this,e):a.type===1?p=new a.ctor(o,a.name,a.strings,this,e):a.type===6&&(p=new F(o,this,e)),this._$AV.push(p),a=s[++l]}n!==a?.index&&(o=x.nextNode(),n++)}return x.currentNode=A,r}p(e){let t=0;for(let s of this._$AV)s!==void 0&&(s.strings!==void 0?(s._$AI(e,s,t),t+=s.strings.length-2):s._$AI(e[t])),t++}},H=class i{get _$AU(){return this._$AM?._$AU??this._$Cv}constructor(e,t,s,r){this.type=2,this._$AH=d,this._$AN=void 0,this._$AA=e,this._$AB=t,this._$AM=s,this.options=r,this._$Cv=r?.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=w(this,e,t),R(e)?e===d||e==null||e===""?(this._$AH!==d&&this._$AR(),this._$AH=d):e!==this._$AH&&e!==S&&this._(e):e._$litType$!==void 0?this.$(e):e.nodeType!==void 0?this.T(e):Le(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&&R(this._$AH)?this._$AA.nextSibling.data=e:this.T(A.createTextNode(e)),this._$AH=e}$(e){let{values:t,_$litType$:s}=e,r=typeof s=="number"?this._$AC(e):(s.el===void 0&&(s.el=q.createElement(be(s.h,s.h[0]),this.options)),s);if(this._$AH?._$AD===r)this._$AH.p(t);else{let o=new Z(r,this),n=o.u(this.options);o.p(t),this.T(n),this._$AH=o}}_$AC(e){let t=ye.get(e.strings);return t===void 0&&ye.set(e.strings,t=new q(e)),t}k(e){te(this._$AH)||(this._$AH=[],this._$AR());let t=this._$AH,s,r=0;for(let o of e)r===t.length?t.push(s=new i(this.O(M()),this.O(M()),this,this.options)):s=t[r],s._$AI(o),r++;r<t.length&&(this._$AR(s&&s._$AB.nextSibling,r),t.length=r)}_$AR(e=this._$AA.nextSibling,t){for(this._$AP?.(!1,!0,t);e!==this._$AB;){let s=he(e).nextSibling;he(e).remove(),e=s}}setConnected(e){this._$AM===void 0&&(this._$Cv=e,this._$AP?.(e))}},C=class{get tagName(){return this.element.tagName}get _$AU(){return this._$AM._$AU}constructor(e,t,s,r,o){this.type=1,this._$AH=d,this._$AN=void 0,this.element=e,this.name=t,this._$AM=r,this.options=o,s.length>2||s[0]!==""||s[1]!==""?(this._$AH=Array(s.length-1).fill(new String),this.strings=s):this._$AH=d}_$AI(e,t=this,s,r){let o=this.strings,n=!1;if(o===void 0)e=w(this,e,t,0),n=!R(e)||e!==this._$AH&&e!==S,n&&(this._$AH=e);else{let l=e,a,p;for(e=o[0],a=0;a<o.length-1;a++)p=w(this,l[s+a],t,a),p===S&&(p=this._$AH[a]),n||=!R(p)||p!==this._$AH[a],p===d?e=d:e!==d&&(e+=(p??"")+o[a+1]),this._$AH[a]=p}n&&!r&&this.j(e)}j(e){e===d?this.element.removeAttribute(this.name):this.element.setAttribute(this.name,e??"")}},G=class extends C{constructor(){super(...arguments),this.type=3}j(e){this.element[this.name]=e===d?void 0:e}},Q=class extends C{constructor(){super(...arguments),this.type=4}j(e){this.element.toggleAttribute(this.name,!!e&&e!==d)}},X=class extends C{constructor(e,t,s,r,o){super(e,t,s,r,o),this.type=5}_$AI(e,t=this){if((e=w(this,e,t,0)??d)===S)return;let s=this._$AH,r=e===d&&s!==d||e.capture!==s.capture||e.once!==s.once||e.passive!==s.passive,o=e!==d&&(s===d||r);r&&this.element.removeEventListener(this.name,this,s),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)}},F=class{constructor(e,t,s){this.element=e,this.type=6,this._$AN=void 0,this._$AM=t,this.options=s}get _$AU(){return this._$AM._$AU}_$AI(e){w(this,e)}};var De=ee.litHtmlPolyfillSupport;De?.(q,H),(ee.litHtmlVersions??=[]).push("3.3.2");var _e=(i,e,t)=>{let s=t?.renderBefore??e,r=s._$litPart$;if(r===void 0){let o=t?.renderBefore??null;s._$litPart$=r=new H(e.insertBefore(M(),o),o,void 0,t??{})}return r._$AI(i),r};var re=globalThis,b=class extends ${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=_e(t,this.renderRoot,this.renderOptions)}connectedCallback(){super.connectedCallback(),this._$Do?.setConnected(!0)}disconnectedCallback(){super.disconnectedCallback(),this._$Do?.setConnected(!1)}render(){return S}};b._$litElement$=!0,b.finalized=!0,re.litElementHydrateSupport?.({LitElement:b});var Be=re.litElementPolyfillSupport;Be?.({LitElement:b});(re.litElementVersions??=[]).push("4.2.2");var xe=i=>(e,t)=>{t!==void 0?t.addInitializer(()=>{customElements.define(i,e)}):customElements.define(i,e)};var Ie={attribute:!0,type:String,converter:T,reflect:!1,hasChanged:I},Ve=(i=Ie,e,t)=>{let{kind:s,metadata:r}=t,o=globalThis.litPropertyMetadata.get(r);if(o===void 0&&globalThis.litPropertyMetadata.set(r,o=new Map),s==="setter"&&((i=Object.create(i)).wrapped=!0),o.set(t.name,i),s==="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(s==="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: "+s)};function E(i){return(e,t)=>typeof t=="object"?Ve(i,e,t):((s,r,o)=>{let n=r.hasOwnProperty(o);return r.constructor.createProperty(o,s),n?Object.getOwnPropertyDescriptor(r,o):void 0})(i,e,t)}function N(i){return E({...i,state:!0,attribute:!1})}var Ae=P`
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
+ `;var m=class extends b{constructor(){super(...arguments);this.endpoint="vedic-astrology/birth-chart";this.method="POST";this.specUrl="https://roxyapi.com/api/v2/openapi.json";this.submitLabel="Submit";this.fields=[];this.values={};this.hasLocation=!1;this.loaded=!1;this.onLocation=t=>{let s=t.detail;s&&(this.values={...this.values,latitude:s.latitude,longitude:s.longitude,timezone:s.timezone??s.utcOffset})};this.onSubmit=t=>{t.preventDefault();let s=this.fields.filter(r=>r.required).filter(r=>this.values[r.name]===void 0||this.values[r.name]==="");if(s.length>0){this.dispatchEvent(new CustomEvent("roxy-validation-error",{detail:{missing:s.map(r=>r.name)},bubbles:!0,composed:!0}));return}this.dispatchEvent(new CustomEvent("roxy-submit",{detail:{endpoint:this.endpoint,values:this.values},bubbles:!0,composed:!0}))}}connectedCallback(){super.connectedCallback(),this.loadSchema()}async loadSchema(){try{let t=await fetch(this.specUrl);if(!t.ok)throw new Error(`HTTP ${t.status}`);let s=await t.json(),r=`/${this.endpoint.replace(/^\//,"")}`,o=s.paths?.[r]?.[this.method.toLowerCase()];if(!o)return;let n=s.components?.schemas??{},l=[],a;if(o.requestBody){let c=o.requestBody.content?.["application/json"]?.schema;a=this.resolve(c,n)}if(a?.properties){let c=new Set(a.required??[]);for(let[h,f]of Object.entries(a.properties)){let u=this.resolve(f,n)??{};l.push({name:h,type:this.fieldType(u),required:c.has(h),description:u.description,enum:u.enum,min:u.minimum,max:u.maximum,default:u.default})}}for(let c of o.parameters??[])if(c.in==="path"||c.in==="query"){let h=this.resolve(c.schema,n)??{};l.push({name:c.name,type:this.fieldType(h),required:!!c.required,description:h.description,enum:h.enum,default:h.default})}this.fields=l,this.hasLocation=l.some(c=>c.name==="latitude")&&l.some(c=>c.name==="longitude")&&l.some(c=>c.name==="timezone");let p={};for(let c of l)c.default!==void 0&&(p[c.name]=c.default);this.values=p,this.loaded=!0}catch{this.loaded=!0}}resolve(t,s){if(t){if("$ref"in t&&t.$ref){let r=t.$ref.split("/").pop();return r?s[r]:void 0}return t}}fieldType(t){return t.enum?"enum":t.format==="date"?"date":t.format==="time"?"time":t.format==="date-time"?"datetime":t.type==="integer"||t.type==="number"?"number":"text"}setValue(t,s){this.values={...this.values,[t]:s}}render(){if(!this.loaded)return g`<form><div class="roxy-skeleton" style="height: 8rem"></div></form>`;let t=s=>{if(this.hasLocation&&(s.name==="latitude"||s.name==="longitude"||s.name==="timezone"))return d;let r=`roxy-form-${s.name}`;return g`<div class="field">
86
+ <label for=${r}>
87
+ ${Se(s.name)}${s.required?g`<span class="req" aria-hidden="true">*</span>`:d}
88
+ </label>
89
+ ${s.enum?g`<select
90
+ id=${r}
91
+ ?required=${s.required}
92
+ @change=${o=>this.setValue(s.name,o.target.value)}
93
+ >
94
+ <option value="">Choose</option>
95
+ ${s.enum.map(o=>g`<option value=${o} ?selected=${this.values[s.name]===o}>
96
+ ${o}
97
+ </option>`)}
98
+ </select>`:g`<input
99
+ id=${r}
100
+ type=${this.htmlType(s.type)}
101
+ ?required=${s.required}
102
+ min=${s.min??""}
103
+ max=${s.max??""}
104
+ step=${s.type==="number"?"any":""}
105
+ .value=${this.values[s.name]??""}
106
+ @input=${o=>this.setValue(s.name,this.coerce(s.type,o.target.value))}
107
+ />`}
108
+ ${s.description?g`<small class="help">${s.description}</small>`:d}
109
+ </div>`};return g`<form @submit=${this.onSubmit}>
110
+ <h2 class="title">${Se(this.endpoint.split("/").pop()??"")}</h2>
111
+ ${this.hasLocation?g`<div class="location-block">
112
+ <label>Birth location</label>
113
+ <roxy-location-search
114
+ @roxy-location-select=${this.onLocation}
115
+ placeholder="City of birth"
116
+ ></roxy-location-search>
117
+ <small class="help">
118
+ Required: latitude, longitude, timezone. Pick a city to autofill.
119
+ </small>
120
+ </div>`:d}
121
+ <div class="fields">
122
+ ${this.fields.map(s=>t(s))}
123
+ </div>
124
+ <button class="submit" type="submit">${this.submitLabel}</button>
125
+ </form>`}htmlType(t){switch(t){case"date":return"date";case"time":return"time";case"datetime":return"datetime-local";case"number":return"number";default:return"text"}}coerce(t,s){if(s!==""){if(t==="number"){let r=Number(s);return Number.isFinite(r)?r:void 0}return s}}};m.styles=[Ae,P`
126
+ form {
127
+ display: grid;
128
+ gap: var(--roxy-space-md, 1rem);
129
+ background: var(--roxy-bg, #fff);
130
+ border: 1px solid var(--roxy-border, #e4e4e7);
131
+ border-radius: var(--roxy-radius-md, 8px);
132
+ padding: var(--roxy-space-lg, 1.5rem);
133
+ box-shadow: var(--roxy-shadow-sm);
134
+ }
135
+ .title {
136
+ margin: 0;
137
+ font-size: var(--roxy-text-lg, 1.125rem);
138
+ font-weight: var(--roxy-weight-bold, 600);
139
+ }
140
+ .fields {
141
+ display: grid;
142
+ grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr));
143
+ gap: var(--roxy-space-md, 1rem);
144
+ }
145
+ .field {
146
+ display: grid;
147
+ gap: var(--roxy-space-xs, 0.25rem);
148
+ }
149
+ label {
150
+ font-size: var(--roxy-text-sm, 0.875rem);
151
+ color: var(--roxy-secondary, #475569);
152
+ }
153
+ label .req {
154
+ color: var(--roxy-danger, #dc2626);
155
+ margin-left: 4px;
156
+ }
157
+ input,
158
+ select {
159
+ padding: var(--roxy-space-sm, 0.5rem) var(--roxy-space-md, 1rem);
160
+ font-size: var(--roxy-text-base, 1rem);
161
+ font-family: inherit;
162
+ color: var(--roxy-fg, #0a0a0a);
163
+ background: var(--roxy-bg, #fff);
164
+ border: 1px solid var(--roxy-border, #e4e4e7);
165
+ border-radius: var(--roxy-radius-md, 8px);
166
+ }
167
+ input:focus,
168
+ select:focus {
169
+ outline: 2px solid var(--roxy-ring, rgba(245, 158, 11, 0.4));
170
+ outline-offset: 2px;
171
+ border-color: var(--roxy-accent-fg, #b45309);
172
+ }
173
+ .help {
174
+ color: var(--roxy-muted, #71717a);
175
+ font-size: var(--roxy-text-xs, 0.75rem);
176
+ }
177
+ .location-block {
178
+ display: grid;
179
+ gap: var(--roxy-space-xs, 0.25rem);
180
+ grid-column: 1 / -1;
181
+ }
182
+ .coords {
183
+ display: grid;
184
+ grid-template-columns: repeat(3, 1fr);
185
+ gap: var(--roxy-space-sm, 0.5rem);
186
+ }
187
+ .coords input {
188
+ font-size: var(--roxy-text-sm, 0.875rem);
189
+ }
190
+ button.submit {
191
+ justify-self: start;
192
+ background: var(--roxy-accent-fg, #b45309);
193
+ color: #fff;
194
+ border: 0;
195
+ border-radius: var(--roxy-radius-md, 8px);
196
+ padding: var(--roxy-space-sm, 0.5rem) var(--roxy-space-lg, 1.5rem);
197
+ font-size: var(--roxy-text-base, 1rem);
198
+ font-weight: var(--roxy-weight-bold, 600);
199
+ cursor: pointer;
200
+ transition:
201
+ transform var(--roxy-motion-duration, 200ms)
202
+ var(--roxy-motion-easing, cubic-bezier(0.4, 0, 0.2, 1));
203
+ }
204
+ button.submit:hover {
205
+ transform: scale(1.02);
206
+ }
207
+ button.submit:focus-visible {
208
+ outline: 2px solid var(--roxy-ring, rgba(245, 158, 11, 0.4));
209
+ outline-offset: 2px;
210
+ }
211
+ `],y([E({type:String,attribute:"data-endpoint"})],m.prototype,"endpoint",2),y([E({type:String})],m.prototype,"method",2),y([E({type:String,attribute:"spec-url"})],m.prototype,"specUrl",2),y([E({type:String,attribute:"submit-label"})],m.prototype,"submitLabel",2),y([N()],m.prototype,"fields",2),y([N()],m.prototype,"values",2),y([N()],m.prototype,"hasLocation",2),y([N()],m.prototype,"loaded",2),m=y([xe("roxy-endpoint-form")],m);function Se(i){return i.replace(/[_-]+/g," ").replace(/([a-z])([A-Z])/g,"$1 $2").replace(/^\w/,e=>e.toUpperCase())}return Pe(We);})();
212
+ /*! Bundled license information:
213
+
214
+ @lit/reactive-element/css-tag.js:
215
+ (**
216
+ * @license
217
+ * Copyright 2019 Google LLC
218
+ * SPDX-License-Identifier: BSD-3-Clause
219
+ *)
220
+
221
+ @lit/reactive-element/reactive-element.js:
222
+ lit-html/lit-html.js:
223
+ lit-element/lit-element.js:
224
+ @lit/reactive-element/decorators/custom-element.js:
225
+ @lit/reactive-element/decorators/property.js:
226
+ @lit/reactive-element/decorators/state.js:
227
+ @lit/reactive-element/decorators/event-options.js:
228
+ @lit/reactive-element/decorators/base.js:
229
+ @lit/reactive-element/decorators/query.js:
230
+ @lit/reactive-element/decorators/query-all.js:
231
+ @lit/reactive-element/decorators/query-async.js:
232
+ @lit/reactive-element/decorators/query-assigned-nodes.js:
233
+ (**
234
+ * @license
235
+ * Copyright 2017 Google LLC
236
+ * SPDX-License-Identifier: BSD-3-Clause
237
+ *)
238
+
239
+ lit-html/is-server.js:
240
+ (**
241
+ * @license
242
+ * Copyright 2022 Google LLC
243
+ * SPDX-License-Identifier: BSD-3-Clause
244
+ *)
245
+
246
+ @lit/reactive-element/decorators/query-assigned-elements.js:
247
+ (**
248
+ * @license
249
+ * Copyright 2021 Google LLC
250
+ * SPDX-License-Identifier: BSD-3-Clause
251
+ *)
252
+ */
253
+ //# sourceMappingURL=endpoint-form.js.map