const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/FeaturedPlaylists-ac3ZVIp7.js","assets/ui-vendor-XTmw4zpA.js","assets/react-vendor-Bsm8qBAU.js","assets/FAQSection-B67sj2J0.js","assets/AdditionalInfoSection-Bsu7QzAv.js"])))=>i.map(i=>d[i]);
var Ps=Object.defineProperty;var Os=(t,e,a)=>e in t?Ps(t,e,{enumerable:!0,configurable:!0,writable:!0,value:a}):t[e]=a;var ae=(t,e,a)=>Os(t,typeof e!="symbol"?e+"":e,a);import{j as o}from"./ui-vendor-XTmw4zpA.js";import{a as Yr,g as zt,r as w,R as we,b as qa,L as R,u as Kt,c as Ce,d as Jr,e as Vt,f as Is,h as Y,N as Rs,B as Cs}from"./react-vendor-Bsm8qBAU.js";(function(){const e=document.createElement("link").relList;if(e&&e.supports&&e.supports("modulepreload"))return;for(const n of document.querySelectorAll('link[rel="modulepreload"]'))r(n);new MutationObserver(n=>{for(const s of n)if(s.type==="childList")for(const i of s.addedNodes)i.tagName==="LINK"&&i.rel==="modulepreload"&&r(i)}).observe(document,{childList:!0,subtree:!0});function a(n){const s={};return n.integrity&&(s.integrity=n.integrity),n.referrerPolicy&&(s.referrerPolicy=n.referrerPolicy),n.crossOrigin==="use-credentials"?s.credentials="include":n.crossOrigin==="anonymous"?s.credentials="omit":s.credentials="same-origin",s}function r(n){if(n.ep)return;n.ep=!0;const s=a(n);fetch(n.href,s)}})();var Zr,lr=Yr;Zr=lr.createRoot,lr.hydrateRoot;var $s=typeof Element<"u",Ds=typeof Map=="function",Ls=typeof Set=="function",Us=typeof ArrayBuffer=="function"&&!!ArrayBuffer.isView;function Rt(t,e){if(t===e)return!0;if(t&&e&&typeof t=="object"&&typeof e=="object"){if(t.constructor!==e.constructor)return!1;var a,r,n;if(Array.isArray(t)){if(a=t.length,a!=e.length)return!1;for(r=a;r--!==0;)if(!Rt(t[r],e[r]))return!1;return!0}var s;if(Ds&&t instanceof Map&&e instanceof Map){if(t.size!==e.size)return!1;for(s=t.entries();!(r=s.next()).done;)if(!e.has(r.value[0]))return!1;for(s=t.entries();!(r=s.next()).done;)if(!Rt(r.value[1],e.get(r.value[0])))return!1;return!0}if(Ls&&t instanceof Set&&e instanceof Set){if(t.size!==e.size)return!1;for(s=t.entries();!(r=s.next()).done;)if(!e.has(r.value[0]))return!1;return!0}if(Us&&ArrayBuffer.isView(t)&&ArrayBuffer.isView(e)){if(a=t.length,a!=e.length)return!1;for(r=a;r--!==0;)if(t[r]!==e[r])return!1;return!0}if(t.constructor===RegExp)return t.source===e.source&&t.flags===e.flags;if(t.valueOf!==Object.prototype.valueOf&&typeof t.valueOf=="function"&&typeof e.valueOf=="function")return t.valueOf()===e.valueOf();if(t.toString!==Object.prototype.toString&&typeof t.toString=="function"&&typeof e.toString=="function")return t.toString()===e.toString();if(n=Object.keys(t),a=n.length,a!==Object.keys(e).length)return!1;for(r=a;r--!==0;)if(!Object.prototype.hasOwnProperty.call(e,n[r]))return!1;if($s&&t instanceof Element)return!1;for(r=a;r--!==0;)if(!((n[r]==="_owner"||n[r]==="__v"||n[r]==="__o")&&t.$$typeof)&&!Rt(t[n[r]],e[n[r]]))return!1;return!0}return t!==t&&e!==e}var Ms=function(e,a){try{return Rt(e,a)}catch(r){if((r.message||"").match(/stack|recursion/i))return console.warn("react-fast-compare cannot handle circular refs"),!1;throw r}};const Bs=zt(Ms);var Fs=function(t,e,a,r,n,s,i,l){if(!t){var c;if(e===void 0)c=new Error("Minified exception occurred; use the non-minified dev environment for the full error message and additional helpful warnings.");else{var d=[a,r,n,s,i,l],u=0;c=new Error(e.replace(/%s/g,function(){return d[u++]})),c.name="Invariant Violation"}throw c.framesToPop=1,c}},Ws=Fs;const dr=zt(Ws);var Hs=function(e,a,r,n){var s=r?r.call(n,e,a):void 0;if(s!==void 0)return!!s;if(e===a)return!0;if(typeof e!="object"||!e||typeof a!="object"||!a)return!1;var i=Object.keys(e),l=Object.keys(a);if(i.length!==l.length)return!1;for(var c=Object.prototype.hasOwnProperty.bind(a),d=0;d<i.length;d++){var u=i[d];if(!c(u))return!1;var h=e[u],p=a[u];if(s=r?r.call(n,h,p,u):void 0,s===!1||s===void 0&&h!==p)return!1}return!0};const qs=zt(Hs);var Qr=(t=>(t.BASE="base",t.BODY="body",t.HEAD="head",t.HTML="html",t.LINK="link",t.META="meta",t.NOSCRIPT="noscript",t.SCRIPT="script",t.STYLE="style",t.TITLE="title",t.FRAGMENT="Symbol(react.fragment)",t))(Qr||{}),ta={link:{rel:["amphtml","canonical","alternate"]},script:{type:["application/ld+json"]},meta:{charset:"",name:["generator","robots","description"],property:["og:type","og:title","og:url","og:image","og:image:alt","og:description","twitter:url","twitter:title","twitter:description","twitter:image","twitter:image:alt","twitter:card","twitter:site"]}},cr=Object.values(Qr),Ga={accesskey:"accessKey",charset:"charSet",class:"className",contenteditable:"contentEditable",contextmenu:"contextMenu","http-equiv":"httpEquiv",itemprop:"itemProp",tabindex:"tabIndex"},Gs=Object.entries(Ga).reduce((t,[e,a])=>(t[a]=e,t),{}),oe="data-rh",ze={DEFAULT_TITLE:"defaultTitle",DEFER:"defer",ENCODE_SPECIAL_CHARACTERS:"encodeSpecialCharacters",ON_CHANGE_CLIENT_STATE:"onChangeClientState",TITLE_TEMPLATE:"titleTemplate",PRIORITIZE_SEO_TAGS:"prioritizeSeoTags"},Ke=(t,e)=>{for(let a=t.length-1;a>=0;a-=1){const r=t[a];if(Object.prototype.hasOwnProperty.call(r,e))return r[e]}return null},zs=t=>{let e=Ke(t,"title");const a=Ke(t,ze.TITLE_TEMPLATE);if(Array.isArray(e)&&(e=e.join("")),a&&e)return a.replace(/%s/g,()=>e);const r=Ke(t,ze.DEFAULT_TITLE);return e||r||void 0},Ks=t=>Ke(t,ze.ON_CHANGE_CLIENT_STATE)||(()=>{}),aa=(t,e)=>e.filter(a=>typeof a[t]<"u").map(a=>a[t]).reduce((a,r)=>({...a,...r}),{}),Vs=(t,e)=>e.filter(a=>typeof a.base<"u").map(a=>a.base).reverse().reduce((a,r)=>{if(!a.length){const n=Object.keys(r);for(let s=0;s<n.length;s+=1){const l=n[s].toLowerCase();if(t.indexOf(l)!==-1&&r[l])return a.concat(r)}}return a},[]),Ys=t=>console&&typeof console.warn=="function"&&console.warn(t),nt=(t,e,a)=>{const r={};return a.filter(n=>Array.isArray(n[t])?!0:(typeof n[t]<"u"&&Ys(`Helmet: ${t} should be of type "Array". Instead found type "${typeof n[t]}"`),!1)).map(n=>n[t]).reverse().reduce((n,s)=>{const i={};s.filter(c=>{let d;const u=Object.keys(c);for(let p=0;p<u.length;p+=1){const y=u[p],m=y.toLowerCase();e.indexOf(m)!==-1&&!(d==="rel"&&c[d].toLowerCase()==="canonical")&&!(m==="rel"&&c[m].toLowerCase()==="stylesheet")&&(d=m),e.indexOf(y)!==-1&&(y==="innerHTML"||y==="cssText"||y==="itemprop")&&(d=y)}if(!d||!c[d])return!1;const h=c[d].toLowerCase();return r[d]||(r[d]={}),i[d]||(i[d]={}),r[d][h]?!1:(i[d][h]=!0,!0)}).reverse().forEach(c=>n.push(c));const l=Object.keys(i);for(let c=0;c<l.length;c+=1){const d=l[c],u={...r[d],...i[d]};r[d]=u}return n},[]).reverse()},Js=(t,e)=>{if(Array.isArray(t)&&t.length){for(let a=0;a<t.length;a+=1)if(t[a][e])return!0}return!1},Zs=t=>({baseTag:Vs(["href"],t),bodyAttributes:aa("bodyAttributes",t),defer:Ke(t,ze.DEFER),encode:Ke(t,ze.ENCODE_SPECIAL_CHARACTERS),htmlAttributes:aa("htmlAttributes",t),linkTags:nt("link",["rel","href"],t),metaTags:nt("meta",["name","charset","http-equiv","property","itemprop"],t),noscriptTags:nt("noscript",["innerHTML"],t),onChangeClientState:Ks(t),scriptTags:nt("script",["src","innerHTML"],t),styleTags:nt("style",["cssText"],t),title:zs(t),titleAttributes:aa("titleAttributes",t),prioritizeSeoTags:Js(t,ze.PRIORITIZE_SEO_TAGS)}),Xr=t=>Array.isArray(t)?t.join(""):t,Qs=(t,e)=>{const a=Object.keys(t);for(let r=0;r<a.length;r+=1)if(e[a[r]]&&e[a[r]].includes(t[a[r]]))return!0;return!1},ra=(t,e)=>Array.isArray(t)?t.reduce((a,r)=>(Qs(r,e)?a.priority.push(r):a.default.push(r),a),{priority:[],default:[]}):{default:t,priority:[]},ur=(t,e)=>({...t,[e]:void 0}),Xs=["noscript","script","style"],ga=(t,e=!0)=>e===!1?String(t):String(t).replace(/&/g,"&").replace(/</g,"<").replace(/>/g,">").replace(/"/g,""").replace(/'/g,"'"),en=t=>Object.keys(t).reduce((e,a)=>{const r=typeof t[a]<"u"?`${a}="${t[a]}"`:`${a}`;return e?`${e} ${r}`:r},""),eo=(t,e,a,r)=>{const n=en(a),s=Xr(e);return n?`<${t} ${oe}="true" ${n}>${ga(s,r)}</${t}>`:`<${t} ${oe}="true">${ga(s,r)}</${t}>`},to=(t,e,a=!0)=>e.reduce((r,n)=>{const s=n,i=Object.keys(s).filter(d=>!(d==="innerHTML"||d==="cssText")).reduce((d,u)=>{const h=typeof s[u]>"u"?u:`${u}="${ga(s[u],a)}"`;return d?`${d} ${h}`:h},""),l=s.innerHTML||s.cssText||"",c=Xs.indexOf(t)===-1;return`${r}<${t} ${oe}="true" ${i}${c?"/>":`>${l}</${t}>`}`},""),tn=(t,e={})=>Object.keys(t).reduce((a,r)=>{const n=Ga[r];return a[n||r]=t[r],a},e),ao=(t,e,a)=>{const r={key:e,[oe]:!0},n=tn(a,r);return[we.createElement("title",n,e)]},Ct=(t,e)=>e.map((a,r)=>{const n={key:r,[oe]:!0};return Object.keys(a).forEach(s=>{const l=Ga[s]||s;if(l==="innerHTML"||l==="cssText"){const c=a.innerHTML||a.cssText;n.dangerouslySetInnerHTML={__html:c}}else n[l]=a[s]}),we.createElement(t,n)}),te=(t,e,a=!0)=>{switch(t){case"title":return{toComponent:()=>ao(t,e.title,e.titleAttributes),toString:()=>eo(t,e.title,e.titleAttributes,a)};case"bodyAttributes":case"htmlAttributes":return{toComponent:()=>tn(e),toString:()=>en(e)};default:return{toComponent:()=>Ct(t,e),toString:()=>to(t,e,a)}}},ro=({metaTags:t,linkTags:e,scriptTags:a,encode:r})=>{const n=ra(t,ta.meta),s=ra(e,ta.link),i=ra(a,ta.script);return{priorityMethods:{toComponent:()=>[...Ct("meta",n.priority),...Ct("link",s.priority),...Ct("script",i.priority)],toString:()=>`${te("meta",n.priority,r)} ${te("link",s.priority,r)} ${te("script",i.priority,r)}`},metaTags:n.default,linkTags:s.default,scriptTags:i.default}},no=t=>{const{baseTag:e,bodyAttributes:a,encode:r=!0,htmlAttributes:n,noscriptTags:s,styleTags:i,title:l="",titleAttributes:c,prioritizeSeoTags:d}=t;let{linkTags:u,metaTags:h,scriptTags:p}=t,y={toComponent:()=>{},toString:()=>""};return d&&({priorityMethods:y,linkTags:u,metaTags:h,scriptTags:p}=ro(t)),{priority:y,base:te("base",e,r),bodyAttributes:te("bodyAttributes",a,r),htmlAttributes:te("htmlAttributes",n,r),link:te("link",u,r),meta:te("meta",h,r),noscript:te("noscript",s,r),script:te("script",p,r),style:te("style",i,r),title:te("title",{title:l,titleAttributes:c},r)}},va=no,Tt=[],an=!!(typeof window<"u"&&window.document&&window.document.createElement),ba=class{constructor(t,e){ae(this,"instances",[]);ae(this,"canUseDOM",an);ae(this,"context");ae(this,"value",{setHelmet:t=>{this.context.helmet=t},helmetInstances:{get:()=>this.canUseDOM?Tt:this.instances,add:t=>{(this.canUseDOM?Tt:this.instances).push(t)},remove:t=>{const e=(this.canUseDOM?Tt:this.instances).indexOf(t);(this.canUseDOM?Tt:this.instances).splice(e,1)}}});this.context=t,this.canUseDOM=e||!1,e||(t.helmet=va({baseTag:[],bodyAttributes:{},htmlAttributes:{},linkTags:[],metaTags:[],noscriptTags:[],scriptTags:[],styleTags:[],title:"",titleAttributes:{}}))}},so={},rn=we.createContext(so),Ie,nn=(Ie=class extends w.Component{constructor(a){super(a);ae(this,"helmetData");this.helmetData=new ba(this.props.context||{},Ie.canUseDOM)}render(){return we.createElement(rn.Provider,{value:this.helmetData.value},this.props.children)}},ae(Ie,"canUseDOM",an),Ie),Le=(t,e)=>{const a=document.head||document.querySelector("head"),r=a.querySelectorAll(`${t}[${oe}]`),n=[].slice.call(r),s=[];let i;return e&&e.length&&e.forEach(l=>{const c=document.createElement(t);for(const d in l)if(Object.prototype.hasOwnProperty.call(l,d))if(d==="innerHTML")c.innerHTML=l.innerHTML;else if(d==="cssText")c.styleSheet?c.styleSheet.cssText=l.cssText:c.appendChild(document.createTextNode(l.cssText));else{const u=d,h=typeof l[u]>"u"?"":l[u];c.setAttribute(d,h)}c.setAttribute(oe,"true"),n.some((d,u)=>(i=u,c.isEqualNode(d)))?n.splice(i,1):s.push(c)}),n.forEach(l=>{var c;return(c=l.parentNode)==null?void 0:c.removeChild(l)}),s.forEach(l=>a.appendChild(l)),{oldTags:n,newTags:s}},wa=(t,e)=>{const a=document.getElementsByTagName(t)[0];if(!a)return;const r=a.getAttribute(oe),n=r?r.split(","):[],s=[...n],i=Object.keys(e);for(const l of i){const c=e[l]||"";a.getAttribute(l)!==c&&a.setAttribute(l,c),n.indexOf(l)===-1&&n.push(l);const d=s.indexOf(l);d!==-1&&s.splice(d,1)}for(let l=s.length-1;l>=0;l-=1)a.removeAttribute(s[l]);n.length===s.length?a.removeAttribute(oe):a.getAttribute(oe)!==i.join(",")&&a.setAttribute(oe,i.join(","))},oo=(t,e)=>{typeof t<"u"&&document.title!==t&&(document.title=Xr(t)),wa("title",e)},hr=(t,e)=>{const{baseTag:a,bodyAttributes:r,htmlAttributes:n,linkTags:s,metaTags:i,noscriptTags:l,onChangeClientState:c,scriptTags:d,styleTags:u,title:h,titleAttributes:p}=t;wa("body",r),wa("html",n),oo(h,p);const y={baseTag:Le("base",a),linkTags:Le("link",s),metaTags:Le("meta",i),noscriptTags:Le("noscript",l),scriptTags:Le("script",d),styleTags:Le("style",u)},m={},f={};Object.keys(y).forEach(g=>{const{newTags:v,oldTags:x}=y[g];v.length&&(m[g]=v),x.length&&(f[g]=y[g].oldTags)}),e&&e(),c(t,m,f)},st=null,io=t=>{st&&cancelAnimationFrame(st),t.defer?st=requestAnimationFrame(()=>{hr(t,()=>{st=null})}):(hr(t),st=null)},lo=io,pr=class extends w.Component{constructor(){super(...arguments);ae(this,"rendered",!1)}shouldComponentUpdate(e){return!qs(e,this.props)}componentDidUpdate(){this.emitChange()}componentWillUnmount(){const{helmetInstances:e}=this.props.context;e.remove(this),this.emitChange()}emitChange(){const{helmetInstances:e,setHelmet:a}=this.props.context;let r=null;const n=Zs(e.get().map(s=>{const i={...s.props};return delete i.context,i}));nn.canUseDOM?lo(n):va&&(r=va(n)),a(r)}init(){if(this.rendered)return;this.rendered=!0;const{helmetInstances:e}=this.props.context;e.add(this),this.emitChange()}render(){return this.init(),null}},fa,co=(fa=class extends w.Component{shouldComponentUpdate(t){return!Bs(ur(this.props,"helmetData"),ur(t,"helmetData"))}mapNestedChildrenToProps(t,e){if(!e)return null;switch(t.type){case"script":case"noscript":return{innerHTML:e};case"style":return{cssText:e};default:throw new Error(`<${t.type} /> elements are self-closing and can not contain children. Refer to our API for more information.`)}}flattenArrayTypeChildren(t,e,a,r){return{...e,[t.type]:[...e[t.type]||[],{...a,...this.mapNestedChildrenToProps(t,r)}]}}mapObjectTypeChildren(t,e,a,r){switch(t.type){case"title":return{...e,[t.type]:r,titleAttributes:{...a}};case"body":return{...e,bodyAttributes:{...a}};case"html":return{...e,htmlAttributes:{...a}};default:return{...e,[t.type]:{...a}}}}mapArrayTypeChildrenToProps(t,e){let a={...e};return Object.keys(t).forEach(r=>{a={...a,[r]:t[r]}}),a}warnOnInvalidChildren(t,e){return dr(cr.some(a=>t.type===a),typeof t.type=="function"?"You may be attempting to nest <Helmet> components within each other, which is not allowed. Refer to our API for more information.":`Only elements types ${cr.join(", ")} are allowed. Helmet does not support rendering <${t.type}> elements. Refer to our API for more information.`),dr(!e||typeof e=="string"||Array.isArray(e)&&!e.some(a=>typeof a!="string"),`Helmet expects a string as a child of <${t.type}>. Did you forget to wrap your children in braces? ( <${t.type}>{\`\`}</${t.type}> ) Refer to our API for more information.`),!0}mapChildrenToProps(t,e){let a={};return we.Children.forEach(t,r=>{if(!r||!r.props)return;const{children:n,...s}=r.props,i=Object.keys(s).reduce((c,d)=>(c[Gs[d]||d]=s[d],c),{});let{type:l}=r;switch(typeof l=="symbol"?l=l.toString():this.warnOnInvalidChildren(r,n),l){case"Symbol(react.fragment)":e=this.mapChildrenToProps(n,e);break;case"link":case"meta":case"noscript":case"script":case"style":a=this.flattenArrayTypeChildren(r,a,i,n);break;default:e=this.mapObjectTypeChildren(r,e,i,n);break}}),this.mapArrayTypeChildrenToProps(a,e)}render(){const{children:t,...e}=this.props;let a={...e},{helmetData:r}=e;if(t&&(a=this.mapChildrenToProps(t,a)),r&&!(r instanceof ba)){const n=r;r=new ba(n.context,!0),delete a.helmetData}return r?we.createElement(pr,{...a,context:r.value}):we.createElement(rn.Consumer,null,n=>we.createElement(pr,{...a,context:n}))}},ae(fa,"defaultProps",{defer:!0,encodeSpecialCharacters:!0,prioritizeSeoTags:!1}),fa),xa=function(t,e){return xa=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(a,r){a.__proto__=r}||function(a,r){for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(a[n]=r[n])},xa(t,e)};function sn(t,e){if(typeof e!="function"&&e!==null)throw new TypeError("Class extends value "+String(e)+" is not a constructor or null");xa(t,e);function a(){this.constructor=t}t.prototype=e===null?Object.create(e):(a.prototype=e.prototype,new a)}var Dt=function(){return Dt=Object.assign||function(e){for(var a,r=1,n=arguments.length;r<n;r++){a=arguments[r];for(var s in a)Object.prototype.hasOwnProperty.call(a,s)&&(e[s]=a[s])}return e},Dt.apply(this,arguments)};function Xe(t,e){var a={};for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&e.indexOf(r)<0&&(a[r]=t[r]);if(t!=null&&typeof Object.getOwnPropertySymbols=="function")for(var n=0,r=Object.getOwnPropertySymbols(t);n<r.length;n++)e.indexOf(r[n])<0&&Object.prototype.propertyIsEnumerable.call(t,r[n])&&(a[r[n]]=t[r[n]]);return a}function on(t,e,a,r){var n=arguments.length,s=n<3?e:r===null?r=Object.getOwnPropertyDescriptor(e,a):r,i;if(typeof Reflect=="object"&&typeof Reflect.decorate=="function")s=Reflect.decorate(t,e,a,r);else for(var l=t.length-1;l>=0;l--)(i=t[l])&&(s=(n<3?i(s):n>3?i(e,a,s):i(e,a))||s);return n>3&&s&&Object.defineProperty(e,a,s),s}function ln(t,e){return function(a,r){e(a,r,t)}}function dn(t,e,a,r,n,s){function i(v){if(v!==void 0&&typeof v!="function")throw new TypeError("Function expected");return v}for(var l=r.kind,c=l==="getter"?"get":l==="setter"?"set":"value",d=!e&&t?r.static?t:t.prototype:null,u=e||(d?Object.getOwnPropertyDescriptor(d,r.name):{}),h,p=!1,y=a.length-1;y>=0;y--){var m={};for(var f in r)m[f]=f==="access"?{}:r[f];for(var f in r.access)m.access[f]=r.access[f];m.addInitializer=function(v){if(p)throw new TypeError("Cannot add initializers after decoration has completed");s.push(i(v||null))};var g=(0,a[y])(l==="accessor"?{get:u.get,set:u.set}:u[c],m);if(l==="accessor"){if(g===void 0)continue;if(g===null||typeof g!="object")throw new TypeError("Object expected");(h=i(g.get))&&(u.get=h),(h=i(g.set))&&(u.set=h),(h=i(g.init))&&n.unshift(h)}else(h=i(g))&&(l==="field"?n.unshift(h):u[c]=h)}d&&Object.defineProperty(d,r.name,u),p=!0}function cn(t,e,a){for(var r=arguments.length>2,n=0;n<e.length;n++)a=r?e[n].call(t,a):e[n].call(t);return r?a:void 0}function un(t){return typeof t=="symbol"?t:"".concat(t)}function hn(t,e,a){return typeof e=="symbol"&&(e=e.description?"[".concat(e.description,"]"):""),Object.defineProperty(t,"name",{configurable:!0,value:a?"".concat(a," ",e):e})}function pn(t,e){if(typeof Reflect=="object"&&typeof Reflect.metadata=="function")return Reflect.metadata(t,e)}function N(t,e,a,r){function n(s){return s instanceof a?s:new a(function(i){i(s)})}return new(a||(a=Promise))(function(s,i){function l(u){try{d(r.next(u))}catch(h){i(h)}}function c(u){try{d(r.throw(u))}catch(h){i(h)}}function d(u){u.done?s(u.value):n(u.value).then(l,c)}d((r=r.apply(t,e||[])).next())})}function yn(t,e){var a={label:0,sent:function(){if(s[0]&1)throw s[1];return s[1]},trys:[],ops:[]},r,n,s,i=Object.create((typeof Iterator=="function"?Iterator:Object).prototype);return i.next=l(0),i.throw=l(1),i.return=l(2),typeof Symbol=="function"&&(i[Symbol.iterator]=function(){return this}),i;function l(d){return function(u){return c([d,u])}}function c(d){if(r)throw new TypeError("Generator is already executing.");for(;i&&(i=0,d[0]&&(a=0)),a;)try{if(r=1,n&&(s=d[0]&2?n.return:d[0]?n.throw||((s=n.return)&&s.call(n),0):n.next)&&!(s=s.call(n,d[1])).done)return s;switch(n=0,s&&(d=[d[0]&2,s.value]),d[0]){case 0:case 1:s=d;break;case 4:return a.label++,{value:d[1],done:!1};case 5:a.label++,n=d[1],d=[0];continue;case 7:d=a.ops.pop(),a.trys.pop();continue;default:if(s=a.trys,!(s=s.length>0&&s[s.length-1])&&(d[0]===6||d[0]===2)){a=0;continue}if(d[0]===3&&(!s||d[1]>s[0]&&d[1]<s[3])){a.label=d[1];break}if(d[0]===6&&a.label<s[1]){a.label=s[1],s=d;break}if(s&&a.label<s[2]){a.label=s[2],a.ops.push(d);break}s[2]&&a.ops.pop(),a.trys.pop();continue}d=e.call(t,a)}catch(u){d=[6,u],n=0}finally{r=s=0}if(d[0]&5)throw d[1];return{value:d[0]?d[1]:void 0,done:!0}}}var Yt=Object.create?function(t,e,a,r){r===void 0&&(r=a);var n=Object.getOwnPropertyDescriptor(e,a);(!n||("get"in n?!e.__esModule:n.writable||n.configurable))&&(n={enumerable:!0,get:function(){return e[a]}}),Object.defineProperty(t,r,n)}:function(t,e,a,r){r===void 0&&(r=a),t[r]=e[a]};function mn(t,e){for(var a in t)a!=="default"&&!Object.prototype.hasOwnProperty.call(e,a)&&Yt(e,t,a)}function Lt(t){var e=typeof Symbol=="function"&&Symbol.iterator,a=e&&t[e],r=0;if(a)return a.call(t);if(t&&typeof t.length=="number")return{next:function(){return t&&r>=t.length&&(t=void 0),{value:t&&t[r++],done:!t}}};throw new TypeError(e?"Object is not iterable.":"Symbol.iterator is not defined.")}function za(t,e){var a=typeof Symbol=="function"&&t[Symbol.iterator];if(!a)return t;var r=a.call(t),n,s=[],i;try{for(;(e===void 0||e-- >0)&&!(n=r.next()).done;)s.push(n.value)}catch(l){i={error:l}}finally{try{n&&!n.done&&(a=r.return)&&a.call(r)}finally{if(i)throw i.error}}return s}function fn(){for(var t=[],e=0;e<arguments.length;e++)t=t.concat(za(arguments[e]));return t}function gn(){for(var t=0,e=0,a=arguments.length;e<a;e++)t+=arguments[e].length;for(var r=Array(t),n=0,e=0;e<a;e++)for(var s=arguments[e],i=0,l=s.length;i<l;i++,n++)r[n]=s[i];return r}function vn(t,e,a){if(a||arguments.length===2)for(var r=0,n=e.length,s;r<n;r++)(s||!(r in e))&&(s||(s=Array.prototype.slice.call(e,0,r)),s[r]=e[r]);return t.concat(s||Array.prototype.slice.call(e))}function Je(t){return this instanceof Je?(this.v=t,this):new Je(t)}function bn(t,e,a){if(!Symbol.asyncIterator)throw new TypeError("Symbol.asyncIterator is not defined.");var r=a.apply(t,e||[]),n,s=[];return n=Object.create((typeof AsyncIterator=="function"?AsyncIterator:Object).prototype),l("next"),l("throw"),l("return",i),n[Symbol.asyncIterator]=function(){return this},n;function i(y){return function(m){return Promise.resolve(m).then(y,h)}}function l(y,m){r[y]&&(n[y]=function(f){return new Promise(function(g,v){s.push([y,f,g,v])>1||c(y,f)})},m&&(n[y]=m(n[y])))}function c(y,m){try{d(r[y](m))}catch(f){p(s[0][3],f)}}function d(y){y.value instanceof Je?Promise.resolve(y.value.v).then(u,h):p(s[0][2],y)}function u(y){c("next",y)}function h(y){c("throw",y)}function p(y,m){y(m),s.shift(),s.length&&c(s[0][0],s[0][1])}}function wn(t){var e,a;return e={},r("next"),r("throw",function(n){throw n}),r("return"),e[Symbol.iterator]=function(){return this},e;function r(n,s){e[n]=t[n]?function(i){return(a=!a)?{value:Je(t[n](i)),done:!1}:s?s(i):i}:s}}function xn(t){if(!Symbol.asyncIterator)throw new TypeError("Symbol.asyncIterator is not defined.");var e=t[Symbol.asyncIterator],a;return e?e.call(t):(t=typeof Lt=="function"?Lt(t):t[Symbol.iterator](),a={},r("next"),r("throw"),r("return"),a[Symbol.asyncIterator]=function(){return this},a);function r(s){a[s]=t[s]&&function(i){return new Promise(function(l,c){i=t[s](i),n(l,c,i.done,i.value)})}}function n(s,i,l,c){Promise.resolve(c).then(function(d){s({value:d,done:l})},i)}}function Tn(t,e){return Object.defineProperty?Object.defineProperty(t,"raw",{value:e}):t.raw=e,t}var uo=Object.create?function(t,e){Object.defineProperty(t,"default",{enumerable:!0,value:e})}:function(t,e){t.default=e},Ta=function(t){return Ta=Object.getOwnPropertyNames||function(e){var a=[];for(var r in e)Object.prototype.hasOwnProperty.call(e,r)&&(a[a.length]=r);return a},Ta(t)};function kn(t){if(t&&t.__esModule)return t;var e={};if(t!=null)for(var a=Ta(t),r=0;r<a.length;r++)a[r]!=="default"&&Yt(e,t,a[r]);return uo(e,t),e}function _n(t){return t&&t.__esModule?t:{default:t}}function jn(t,e,a,r){if(a==="a"&&!r)throw new TypeError("Private accessor was defined without a getter");if(typeof e=="function"?t!==e||!r:!e.has(t))throw new TypeError("Cannot read private member from an object whose class did not declare it");return a==="m"?r:a==="a"?r.call(t):r?r.value:e.get(t)}function Sn(t,e,a,r,n){if(r==="m")throw new TypeError("Private method is not writable");if(r==="a"&&!n)throw new TypeError("Private accessor was defined without a setter");if(typeof e=="function"?t!==e||!n:!e.has(t))throw new TypeError("Cannot write private member to an object whose class did not declare it");return r==="a"?n.call(t,a):n?n.value=a:e.set(t,a),a}function En(t,e){if(e===null||typeof e!="object"&&typeof e!="function")throw new TypeError("Cannot use 'in' operator on non-object");return typeof t=="function"?e===t:t.has(e)}function Nn(t,e,a){if(e!=null){if(typeof e!="object"&&typeof e!="function")throw new TypeError("Object expected.");var r,n;if(a){if(!Symbol.asyncDispose)throw new TypeError("Symbol.asyncDispose is not defined.");r=e[Symbol.asyncDispose]}if(r===void 0){if(!Symbol.dispose)throw new TypeError("Symbol.dispose is not defined.");r=e[Symbol.dispose],a&&(n=r)}if(typeof r!="function")throw new TypeError("Object not disposable.");n&&(r=function(){try{n.call(this)}catch(s){return Promise.reject(s)}}),t.stack.push({value:e,dispose:r,async:a})}else a&&t.stack.push({async:!0});return e}var ho=typeof SuppressedError=="function"?SuppressedError:function(t,e,a){var r=new Error(a);return r.name="SuppressedError",r.error=t,r.suppressed=e,r};function An(t){function e(s){t.error=t.hasError?new ho(s,t.error,"An error was suppressed during disposal."):s,t.hasError=!0}var a,r=0;function n(){for(;a=t.stack.pop();)try{if(!a.async&&r===1)return r=0,t.stack.push(a),Promise.resolve().then(n);if(a.dispose){var s=a.dispose.call(a.value);if(a.async)return r|=2,Promise.resolve(s).then(n,function(i){return e(i),n()})}else r|=1}catch(i){e(i)}if(r===1)return t.hasError?Promise.reject(t.error):Promise.resolve();if(t.hasError)throw t.error}return n()}function Pn(t,e){return typeof t=="string"&&/^\.\.?\//.test(t)?t.replace(/\.(tsx)$|((?:\.d)?)((?:\.[^./]+?)?)\.([cm]?)ts$/i,function(a,r,n,s,i){return r?e?".jsx":".js":n&&(!s||!i)?a:n+s+"."+i.toLowerCase()+"js"}):t}const po={__extends:sn,__assign:Dt,__rest:Xe,__decorate:on,__param:ln,__esDecorate:dn,__runInitializers:cn,__propKey:un,__setFunctionName:hn,__metadata:pn,__awaiter:N,__generator:yn,__createBinding:Yt,__exportStar:mn,__values:Lt,__read:za,__spread:fn,__spreadArrays:gn,__spreadArray:vn,__await:Je,__asyncGenerator:bn,__asyncDelegator:wn,__asyncValues:xn,__makeTemplateObject:Tn,__importStar:kn,__importDefault:_n,__classPrivateFieldGet:jn,__classPrivateFieldSet:Sn,__classPrivateFieldIn:En,__addDisposableResource:Nn,__disposeResources:An,__rewriteRelativeImportExtension:Pn},yo=Object.freeze(Object.defineProperty({__proto__:null,__addDisposableResource:Nn,get __assign(){return Dt},__asyncDelegator:wn,__asyncGenerator:bn,__asyncValues:xn,__await:Je,__awaiter:N,__classPrivateFieldGet:jn,__classPrivateFieldIn:En,__classPrivateFieldSet:Sn,__createBinding:Yt,__decorate:on,__disposeResources:An,__esDecorate:dn,__exportStar:mn,__extends:sn,__generator:yn,__importDefault:_n,__importStar:kn,__makeTemplateObject:Tn,__metadata:pn,__param:ln,__propKey:un,__read:za,__rest:Xe,__rewriteRelativeImportExtension:Pn,__runInitializers:cn,__setFunctionName:hn,__spread:fn,__spreadArray:vn,__spreadArrays:gn,__values:Lt,default:po},Symbol.toStringTag,{value:"Module"})),mo="modulepreload",fo=function(t){return"/"+t},yr={},de=function(e,a,r){let n=Promise.resolve();if(a&&a.length>0){document.getElementsByTagName("link");const i=document.querySelector("meta[property=csp-nonce]"),l=(i==null?void 0:i.nonce)||(i==null?void 0:i.getAttribute("nonce"));n=Promise.allSettled(a.map(c=>{if(c=fo(c),c in yr)return;yr[c]=!0;const d=c.endsWith(".css"),u=d?'[rel="stylesheet"]':"";if(document.querySelector(`link[href="${c}"]${u}`))return;const h=document.createElement("link");if(h.rel=d?"stylesheet":mo,d||(h.as="script"),h.crossOrigin="",h.href=c,l&&h.setAttribute("nonce",l),document.head.appendChild(h),d)return new Promise((p,y)=>{h.addEventListener("load",p),h.addEventListener("error",()=>y(new Error(`Unable to preload CSS for ${c}`)))})}))}function s(i){const l=new Event("vite:preloadError",{cancelable:!0});if(l.payload=i,window.dispatchEvent(l),!l.defaultPrevented)throw i}return n.then(i=>{for(const l of i||[])l.status==="rejected"&&s(l.reason);return e().catch(s)})},go=t=>{let e;return t?e=t:typeof fetch>"u"?e=(...a)=>de(async()=>{const{default:r}=await Promise.resolve().then(()=>$e);return{default:r}},void 0).then(({default:r})=>r(...a)):e=fetch,(...a)=>e(...a)};class Ka extends Error{constructor(e,a="FunctionsError",r){super(e),this.name=a,this.context=r}}class mr extends Ka{constructor(e){super("Failed to send a request to the Edge Function","FunctionsFetchError",e)}}class fr extends Ka{constructor(e){super("Relay Error invoking the Edge Function","FunctionsRelayError",e)}}class gr extends Ka{constructor(e){super("Edge Function returned a non-2xx status code","FunctionsHttpError",e)}}var ka;(function(t){t.Any="any",t.ApNortheast1="ap-northeast-1",t.ApNortheast2="ap-northeast-2",t.ApSouth1="ap-south-1",t.ApSoutheast1="ap-southeast-1",t.ApSoutheast2="ap-southeast-2",t.CaCentral1="ca-central-1",t.EuCentral1="eu-central-1",t.EuWest1="eu-west-1",t.EuWest2="eu-west-2",t.EuWest3="eu-west-3",t.SaEast1="sa-east-1",t.UsEast1="us-east-1",t.UsWest1="us-west-1",t.UsWest2="us-west-2"})(ka||(ka={}));class vo{constructor(e,{headers:a={},customFetch:r,region:n=ka.Any}={}){this.url=e,this.headers=a,this.region=n,this.fetch=go(r)}setAuth(e){this.headers.Authorization=`Bearer ${e}`}invoke(e){return N(this,arguments,void 0,function*(a,r={}){var n;try{const{headers:s,method:i,body:l,signal:c}=r;let d={},{region:u}=r;u||(u=this.region);const h=new URL(`${this.url}/${a}`);u&&u!=="any"&&(d["x-region"]=u,h.searchParams.set("forceFunctionRegion",u));let p;l&&(s&&!Object.prototype.hasOwnProperty.call(s,"Content-Type")||!s)?typeof Blob<"u"&&l instanceof Blob||l instanceof ArrayBuffer?(d["Content-Type"]="application/octet-stream",p=l):typeof l=="string"?(d["Content-Type"]="text/plain",p=l):typeof FormData<"u"&&l instanceof FormData?p=l:(d["Content-Type"]="application/json",p=JSON.stringify(l)):p=l;const y=yield this.fetch(h.toString(),{method:i||"POST",headers:Object.assign(Object.assign(Object.assign({},d),this.headers),s),body:p,signal:c}).catch(v=>{throw v.name==="AbortError"?v:new mr(v)}),m=y.headers.get("x-relay-error");if(m&&m==="true")throw new fr(y);if(!y.ok)throw new gr(y);let f=((n=y.headers.get("Content-Type"))!==null&&n!==void 0?n:"text/plain").split(";")[0].trim(),g;return f==="application/json"?g=yield y.json():f==="application/octet-stream"||f==="application/pdf"?g=yield y.blob():f==="text/event-stream"?g=y:f==="multipart/form-data"?g=yield y.formData():g=yield y.text(),{data:g,error:null,response:y}}catch(s){return s instanceof Error&&s.name==="AbortError"?{data:null,error:new mr(s)}:{data:null,error:s,response:s instanceof gr||s instanceof fr?s.context:void 0}}})}}var K={};const et=qa(yo);var kt={},_t={},jt={},St={},Et={},bo=function(){if(typeof self<"u")return self;if(typeof window<"u")return window;if(typeof global<"u")return global;throw new Error("unable to locate global object")},Ze=bo();const wo=Ze.fetch,On=Ze.fetch.bind(Ze),In=Ze.Headers,xo=Ze.Request,To=Ze.Response,$e=Object.freeze(Object.defineProperty({__proto__:null,Headers:In,Request:xo,Response:To,default:On,fetch:wo},Symbol.toStringTag,{value:"Module"})),ko=qa($e);var Nt={},vr;function Rn(){if(vr)return Nt;vr=1,Object.defineProperty(Nt,"__esModule",{value:!0});class t extends Error{constructor(a){super(a.message),this.name="PostgrestError",this.details=a.details,this.hint=a.hint,this.code=a.code}}return Nt.default=t,Nt}var br;function Cn(){if(br)return Et;br=1,Object.defineProperty(Et,"__esModule",{value:!0});const t=et,e=t.__importDefault(ko),a=t.__importDefault(Rn());class r{constructor(s){var i,l;this.shouldThrowOnError=!1,this.method=s.method,this.url=s.url,this.headers=new Headers(s.headers),this.schema=s.schema,this.body=s.body,this.shouldThrowOnError=(i=s.shouldThrowOnError)!==null&&i!==void 0?i:!1,this.signal=s.signal,this.isMaybeSingle=(l=s.isMaybeSingle)!==null&&l!==void 0?l:!1,s.fetch?this.fetch=s.fetch:typeof fetch>"u"?this.fetch=e.default:this.fetch=fetch}throwOnError(){return this.shouldThrowOnError=!0,this}setHeader(s,i){return this.headers=new Headers(this.headers),this.headers.set(s,i),this}then(s,i){this.schema===void 0||(["GET","HEAD"].includes(this.method)?this.headers.set("Accept-Profile",this.schema):this.headers.set("Content-Profile",this.schema)),this.method!=="GET"&&this.method!=="HEAD"&&this.headers.set("Content-Type","application/json");const l=this.fetch;let c=l(this.url.toString(),{method:this.method,headers:this.headers,body:JSON.stringify(this.body),signal:this.signal}).then(async d=>{var u,h,p,y;let m=null,f=null,g=null,v=d.status,x=d.statusText;if(d.ok){if(this.method!=="HEAD"){const S=await d.text();S===""||(this.headers.get("Accept")==="text/csv"||this.headers.get("Accept")&&(!((u=this.headers.get("Accept"))===null||u===void 0)&&u.includes("application/vnd.pgrst.plan+text"))?f=S:f=JSON.parse(S))}const j=(h=this.headers.get("Prefer"))===null||h===void 0?void 0:h.match(/count=(exact|planned|estimated)/),A=(p=d.headers.get("content-range"))===null||p===void 0?void 0:p.split("/");j&&A&&A.length>1&&(g=parseInt(A[1])),this.isMaybeSingle&&this.method==="GET"&&Array.isArray(f)&&(f.length>1?(m={code:"PGRST116",details:`Results contain ${f.length} rows, application/vnd.pgrst.object+json requires 1 row`,hint:null,message:"JSON object requested, multiple (or no) rows returned"},f=null,g=null,v=406,x="Not Acceptable"):f.length===1?f=f[0]:f=null)}else{const j=await d.text();try{m=JSON.parse(j),Array.isArray(m)&&d.status===404&&(f=[],m=null,v=200,x="OK")}catch{d.status===404&&j===""?(v=204,x="No Content"):m={message:j}}if(m&&this.isMaybeSingle&&(!((y=m==null?void 0:m.details)===null||y===void 0)&&y.includes("0 rows"))&&(m=null,v=200,x="OK"),m&&this.shouldThrowOnError)throw new a.default(m)}return{error:m,data:f,count:g,status:v,statusText:x}});return this.shouldThrowOnError||(c=c.catch(d=>{var u,h,p;return{error:{message:`${(u=d==null?void 0:d.name)!==null&&u!==void 0?u:"FetchError"}: ${d==null?void 0:d.message}`,details:`${(h=d==null?void 0:d.stack)!==null&&h!==void 0?h:""}`,hint:"",code:`${(p=d==null?void 0:d.code)!==null&&p!==void 0?p:""}`},data:null,count:null,status:0,statusText:""}})),c.then(s,i)}returns(){return this}overrideTypes(){return this}}return Et.default=r,Et}var wr;function $n(){if(wr)return St;wr=1,Object.defineProperty(St,"__esModule",{value:!0});const e=et.__importDefault(Cn());class a extends e.default{select(n){let s=!1;const i=(n??"*").split("").map(l=>/\s/.test(l)&&!s?"":(l==='"'&&(s=!s),l)).join("");return this.url.searchParams.set("select",i),this.headers.append("Prefer","return=representation"),this}order(n,{ascending:s=!0,nullsFirst:i,foreignTable:l,referencedTable:c=l}={}){const d=c?`${c}.order`:"order",u=this.url.searchParams.get(d);return this.url.searchParams.set(d,`${u?`${u},`:""}${n}.${s?"asc":"desc"}${i===void 0?"":i?".nullsfirst":".nullslast"}`),this}limit(n,{foreignTable:s,referencedTable:i=s}={}){const l=typeof i>"u"?"limit":`${i}.limit`;return this.url.searchParams.set(l,`${n}`),this}range(n,s,{foreignTable:i,referencedTable:l=i}={}){const c=typeof l>"u"?"offset":`${l}.offset`,d=typeof l>"u"?"limit":`${l}.limit`;return this.url.searchParams.set(c,`${n}`),this.url.searchParams.set(d,`${s-n+1}`),this}abortSignal(n){return this.signal=n,this}single(){return this.headers.set("Accept","application/vnd.pgrst.object+json"),this}maybeSingle(){return this.method==="GET"?this.headers.set("Accept","application/json"):this.headers.set("Accept","application/vnd.pgrst.object+json"),this.isMaybeSingle=!0,this}csv(){return this.headers.set("Accept","text/csv"),this}geojson(){return this.headers.set("Accept","application/geo+json"),this}explain({analyze:n=!1,verbose:s=!1,settings:i=!1,buffers:l=!1,wal:c=!1,format:d="text"}={}){var u;const h=[n?"analyze":null,s?"verbose":null,i?"settings":null,l?"buffers":null,c?"wal":null].filter(Boolean).join("|"),p=(u=this.headers.get("Accept"))!==null&&u!==void 0?u:"application/json";return this.headers.set("Accept",`application/vnd.pgrst.plan+${d}; for="${p}"; options=${h};`),d==="json"?this:this}rollback(){return this.headers.append("Prefer","tx=rollback"),this}returns(){return this}maxAffected(n){return this.headers.append("Prefer","handling=strict"),this.headers.append("Prefer",`max-affected=${n}`),this}}return St.default=a,St}var xr;function Va(){if(xr)return jt;xr=1,Object.defineProperty(jt,"__esModule",{value:!0});const e=et.__importDefault($n());class a extends e.default{eq(n,s){return this.url.searchParams.append(n,`eq.${s}`),this}neq(n,s){return this.url.searchParams.append(n,`neq.${s}`),this}gt(n,s){return this.url.searchParams.append(n,`gt.${s}`),this}gte(n,s){return this.url.searchParams.append(n,`gte.${s}`),this}lt(n,s){return this.url.searchParams.append(n,`lt.${s}`),this}lte(n,s){return this.url.searchParams.append(n,`lte.${s}`),this}like(n,s){return this.url.searchParams.append(n,`like.${s}`),this}likeAllOf(n,s){return this.url.searchParams.append(n,`like(all).{${s.join(",")}}`),this}likeAnyOf(n,s){return this.url.searchParams.append(n,`like(any).{${s.join(",")}}`),this}ilike(n,s){return this.url.searchParams.append(n,`ilike.${s}`),this}ilikeAllOf(n,s){return this.url.searchParams.append(n,`ilike(all).{${s.join(",")}}`),this}ilikeAnyOf(n,s){return this.url.searchParams.append(n,`ilike(any).{${s.join(",")}}`),this}is(n,s){return this.url.searchParams.append(n,`is.${s}`),this}in(n,s){const i=Array.from(new Set(s)).map(l=>typeof l=="string"&&new RegExp("[,()]").test(l)?`"${l}"`:`${l}`).join(",");return this.url.searchParams.append(n,`in.(${i})`),this}contains(n,s){return typeof s=="string"?this.url.searchParams.append(n,`cs.${s}`):Array.isArray(s)?this.url.searchParams.append(n,`cs.{${s.join(",")}}`):this.url.searchParams.append(n,`cs.${JSON.stringify(s)}`),this}containedBy(n,s){return typeof s=="string"?this.url.searchParams.append(n,`cd.${s}`):Array.isArray(s)?this.url.searchParams.append(n,`cd.{${s.join(",")}}`):this.url.searchParams.append(n,`cd.${JSON.stringify(s)}`),this}rangeGt(n,s){return this.url.searchParams.append(n,`sr.${s}`),this}rangeGte(n,s){return this.url.searchParams.append(n,`nxl.${s}`),this}rangeLt(n,s){return this.url.searchParams.append(n,`sl.${s}`),this}rangeLte(n,s){return this.url.searchParams.append(n,`nxr.${s}`),this}rangeAdjacent(n,s){return this.url.searchParams.append(n,`adj.${s}`),this}overlaps(n,s){return typeof s=="string"?this.url.searchParams.append(n,`ov.${s}`):this.url.searchParams.append(n,`ov.{${s.join(",")}}`),this}textSearch(n,s,{config:i,type:l}={}){let c="";l==="plain"?c="pl":l==="phrase"?c="ph":l==="websearch"&&(c="w");const d=i===void 0?"":`(${i})`;return this.url.searchParams.append(n,`${c}fts${d}.${s}`),this}match(n){return Object.entries(n).forEach(([s,i])=>{this.url.searchParams.append(s,`eq.${i}`)}),this}not(n,s,i){return this.url.searchParams.append(n,`not.${s}.${i}`),this}or(n,{foreignTable:s,referencedTable:i=s}={}){const l=i?`${i}.or`:"or";return this.url.searchParams.append(l,`(${n})`),this}filter(n,s,i){return this.url.searchParams.append(n,`${s}.${i}`),this}}return jt.default=a,jt}var Tr;function Dn(){if(Tr)return _t;Tr=1,Object.defineProperty(_t,"__esModule",{value:!0});const e=et.__importDefault(Va());class a{constructor(n,{headers:s={},schema:i,fetch:l}){this.url=n,this.headers=new Headers(s),this.schema=i,this.fetch=l}select(n,s){const{head:i=!1,count:l}=s??{},c=i?"HEAD":"GET";let d=!1;const u=(n??"*").split("").map(h=>/\s/.test(h)&&!d?"":(h==='"'&&(d=!d),h)).join("");return this.url.searchParams.set("select",u),l&&this.headers.append("Prefer",`count=${l}`),new e.default({method:c,url:this.url,headers:this.headers,schema:this.schema,fetch:this.fetch})}insert(n,{count:s,defaultToNull:i=!0}={}){var l;const c="POST";if(s&&this.headers.append("Prefer",`count=${s}`),i||this.headers.append("Prefer","missing=default"),Array.isArray(n)){const d=n.reduce((u,h)=>u.concat(Object.keys(h)),[]);if(d.length>0){const u=[...new Set(d)].map(h=>`"${h}"`);this.url.searchParams.set("columns",u.join(","))}}return new e.default({method:c,url:this.url,headers:this.headers,schema:this.schema,body:n,fetch:(l=this.fetch)!==null&&l!==void 0?l:fetch})}upsert(n,{onConflict:s,ignoreDuplicates:i=!1,count:l,defaultToNull:c=!0}={}){var d;const u="POST";if(this.headers.append("Prefer",`resolution=${i?"ignore":"merge"}-duplicates`),s!==void 0&&this.url.searchParams.set("on_conflict",s),l&&this.headers.append("Prefer",`count=${l}`),c||this.headers.append("Prefer","missing=default"),Array.isArray(n)){const h=n.reduce((p,y)=>p.concat(Object.keys(y)),[]);if(h.length>0){const p=[...new Set(h)].map(y=>`"${y}"`);this.url.searchParams.set("columns",p.join(","))}}return new e.default({method:u,url:this.url,headers:this.headers,schema:this.schema,body:n,fetch:(d=this.fetch)!==null&&d!==void 0?d:fetch})}update(n,{count:s}={}){var i;const l="PATCH";return s&&this.headers.append("Prefer",`count=${s}`),new e.default({method:l,url:this.url,headers:this.headers,schema:this.schema,body:n,fetch:(i=this.fetch)!==null&&i!==void 0?i:fetch})}delete({count:n}={}){var s;const i="DELETE";return n&&this.headers.append("Prefer",`count=${n}`),new e.default({method:i,url:this.url,headers:this.headers,schema:this.schema,fetch:(s=this.fetch)!==null&&s!==void 0?s:fetch})}}return _t.default=a,_t}var kr;function _o(){if(kr)return kt;kr=1,Object.defineProperty(kt,"__esModule",{value:!0});const t=et,e=t.__importDefault(Dn()),a=t.__importDefault(Va());class r{constructor(s,{headers:i={},schema:l,fetch:c}={}){this.url=s,this.headers=new Headers(i),this.schemaName=l,this.fetch=c}from(s){const i=new URL(`${this.url}/${s}`);return new e.default(i,{headers:new Headers(this.headers),schema:this.schemaName,fetch:this.fetch})}schema(s){return new r(this.url,{headers:this.headers,schema:s,fetch:this.fetch})}rpc(s,i={},{head:l=!1,get:c=!1,count:d}={}){var u;let h;const p=new URL(`${this.url}/rpc/${s}`);let y;l||c?(h=l?"HEAD":"GET",Object.entries(i).filter(([f,g])=>g!==void 0).map(([f,g])=>[f,Array.isArray(g)?`{${g.join(",")}}`:`${g}`]).forEach(([f,g])=>{p.searchParams.append(f,g)})):(h="POST",y=i);const m=new Headers(this.headers);return d&&m.set("Prefer",`count=${d}`),new a.default({method:h,url:p,headers:m,schema:this.schemaName,body:y,fetch:(u=this.fetch)!==null&&u!==void 0?u:fetch})}}return kt.default=r,kt}Object.defineProperty(K,"__esModule",{value:!0});K.PostgrestError=K.PostgrestBuilder=K.PostgrestTransformBuilder=K.PostgrestFilterBuilder=K.PostgrestQueryBuilder=K.PostgrestClient=void 0;const tt=et,Ln=tt.__importDefault(_o());K.PostgrestClient=Ln.default;const Un=tt.__importDefault(Dn());K.PostgrestQueryBuilder=Un.default;const Mn=tt.__importDefault(Va());K.PostgrestFilterBuilder=Mn.default;const Bn=tt.__importDefault($n());K.PostgrestTransformBuilder=Bn.default;const Fn=tt.__importDefault(Cn());K.PostgrestBuilder=Fn.default;const Wn=tt.__importDefault(Rn());K.PostgrestError=Wn.default;var jo=K.default={PostgrestClient:Ln.default,PostgrestQueryBuilder:Un.default,PostgrestFilterBuilder:Mn.default,PostgrestTransformBuilder:Bn.default,PostgrestBuilder:Fn.default,PostgrestError:Wn.default};const{PostgrestClient:So,PostgrestQueryBuilder:uu,PostgrestFilterBuilder:hu,PostgrestTransformBuilder:pu,PostgrestBuilder:yu,PostgrestError:mu}=jo;class Eo{static detectEnvironment(){var e;if(typeof WebSocket<"u")return{type:"native",constructor:WebSocket};if(typeof globalThis<"u"&&typeof globalThis.WebSocket<"u")return{type:"native",constructor:globalThis.WebSocket};if(typeof global<"u"&&typeof global.WebSocket<"u")return{type:"native",constructor:global.WebSocket};if(typeof globalThis<"u"&&typeof globalThis.WebSocketPair<"u"&&typeof globalThis.WebSocket>"u")return{type:"cloudflare",error:"Cloudflare Workers detected. WebSocket clients are not supported in Cloudflare Workers.",workaround:"Use Cloudflare Workers WebSocket API for server-side WebSocket handling, or deploy to a different runtime."};if(typeof globalThis<"u"&&globalThis.EdgeRuntime||typeof navigator<"u"&&(!((e=navigator.userAgent)===null||e===void 0)&&e.includes("Vercel-Edge")))return{type:"unsupported",error:"Edge runtime detected (Vercel Edge/Netlify Edge). WebSockets are not supported in edge functions.",workaround:"Use serverless functions or a different deployment target for WebSocket functionality."};if(typeof process<"u"){const a=process.versions;if(a&&a.node){const r=a.node,n=parseInt(r.replace(/^v/,"").split(".")[0]);return n>=22?typeof globalThis.WebSocket<"u"?{type:"native",constructor:globalThis.WebSocket}:{type:"unsupported",error:`Node.js ${n} detected but native WebSocket not found.`,workaround:"Provide a WebSocket implementation via the transport option."}:{type:"unsupported",error:`Node.js ${n} detected without native WebSocket support.`,workaround:`For Node.js < 22, install "ws" package and provide it via the transport option:
import ws from "ws"
new RealtimeClient(url, { transport: ws })`}}}return{type:"unsupported",error:"Unknown JavaScript runtime without WebSocket support.",workaround:"Ensure you're running in a supported environment (browser, Node.js, Deno) or provide a custom WebSocket implementation."}}static getWebSocketConstructor(){const e=this.detectEnvironment();if(e.constructor)return e.constructor;let a=e.error||"WebSocket not supported in this environment.";throw e.workaround&&(a+=`
Suggested solution: ${e.workaround}`),new Error(a)}static createWebSocket(e,a){const r=this.getWebSocketConstructor();return new r(e,a)}static isWebSocketSupported(){try{const e=this.detectEnvironment();return e.type==="native"||e.type==="ws"}catch{return!1}}}const No="2.76.1",Ao=`realtime-js/${No}`,Po="1.0.0",_a=1e4,Oo=1e3,Io=100;var ht;(function(t){t[t.connecting=0]="connecting",t[t.open=1]="open",t[t.closing=2]="closing",t[t.closed=3]="closed"})(ht||(ht={}));var H;(function(t){t.closed="closed",t.errored="errored",t.joined="joined",t.joining="joining",t.leaving="leaving"})(H||(H={}));var se;(function(t){t.close="phx_close",t.error="phx_error",t.join="phx_join",t.reply="phx_reply",t.leave="phx_leave",t.access_token="access_token"})(se||(se={}));var ja;(function(t){t.websocket="websocket"})(ja||(ja={}));var Ae;(function(t){t.Connecting="connecting",t.Open="open",t.Closing="closing",t.Closed="closed"})(Ae||(Ae={}));class Ro{constructor(){this.HEADER_LENGTH=1}decode(e,a){return e.constructor===ArrayBuffer?a(this._binaryDecode(e)):a(typeof e=="string"?JSON.parse(e):{})}_binaryDecode(e){const a=new DataView(e),r=new TextDecoder;return this._decodeBroadcast(e,a,r)}_decodeBroadcast(e,a,r){const n=a.getUint8(1),s=a.getUint8(2);let i=this.HEADER_LENGTH+2;const l=r.decode(e.slice(i,i+n));i=i+n;const c=r.decode(e.slice(i,i+s));i=i+s;const d=JSON.parse(r.decode(e.slice(i,e.byteLength)));return{ref:null,topic:l,event:c,payload:d}}}class Hn{constructor(e,a){this.callback=e,this.timerCalc=a,this.timer=void 0,this.tries=0,this.callback=e,this.timerCalc=a}reset(){this.tries=0,clearTimeout(this.timer),this.timer=void 0}scheduleTimeout(){clearTimeout(this.timer),this.timer=setTimeout(()=>{this.tries=this.tries+1,this.callback()},this.timerCalc(this.tries+1))}}var B;(function(t){t.abstime="abstime",t.bool="bool",t.date="date",t.daterange="daterange",t.float4="float4",t.float8="float8",t.int2="int2",t.int4="int4",t.int4range="int4range",t.int8="int8",t.int8range="int8range",t.json="json",t.jsonb="jsonb",t.money="money",t.numeric="numeric",t.oid="oid",t.reltime="reltime",t.text="text",t.time="time",t.timestamp="timestamp",t.timestamptz="timestamptz",t.timetz="timetz",t.tsrange="tsrange",t.tstzrange="tstzrange"})(B||(B={}));const _r=(t,e,a={})=>{var r;const n=(r=a.skipTypes)!==null&&r!==void 0?r:[];return e?Object.keys(e).reduce((s,i)=>(s[i]=Co(i,t,e,n),s),{}):{}},Co=(t,e,a,r)=>{const n=e.find(l=>l.name===t),s=n==null?void 0:n.type,i=a[t];return s&&!r.includes(s)?qn(s,i):Sa(i)},qn=(t,e)=>{if(t.charAt(0)==="_"){const a=t.slice(1,t.length);return Uo(e,a)}switch(t){case B.bool:return $o(e);case B.float4:case B.float8:case B.int2:case B.int4:case B.int8:case B.numeric:case B.oid:return Do(e);case B.json:case B.jsonb:return Lo(e);case B.timestamp:return Mo(e);case B.abstime:case B.date:case B.daterange:case B.int4range:case B.int8range:case B.money:case B.reltime:case B.text:case B.time:case B.timestamptz:case B.timetz:case B.tsrange:case B.tstzrange:return Sa(e);default:return Sa(e)}},Sa=t=>t,$o=t=>{switch(t){case"t":return!0;case"f":return!1;default:return t}},Do=t=>{if(typeof t=="string"){const e=parseFloat(t);if(!Number.isNaN(e))return e}return t},Lo=t=>{if(typeof t=="string")try{return JSON.parse(t)}catch(e){return console.log(`JSON parse error: ${e}`),t}return t},Uo=(t,e)=>{if(typeof t!="string")return t;const a=t.length-1,r=t[a];if(t[0]==="{"&&r==="}"){let s;const i=t.slice(1,a);try{s=JSON.parse("["+i+"]")}catch{s=i?i.split(","):[]}return s.map(l=>qn(e,l))}return t},Mo=t=>typeof t=="string"?t.replace(" ","T"):t,Gn=t=>{const e=new URL(t);return e.protocol=e.protocol.replace(/^ws/i,"http"),e.pathname=e.pathname.replace(/\/+$/,"").replace(/\/socket\/websocket$/i,"").replace(/\/socket$/i,"").replace(/\/websocket$/i,""),e.pathname===""||e.pathname==="/"?e.pathname="/api/broadcast":e.pathname=e.pathname+"/api/broadcast",e.href};class na{constructor(e,a,r={},n=_a){this.channel=e,this.event=a,this.payload=r,this.timeout=n,this.sent=!1,this.timeoutTimer=void 0,this.ref="",this.receivedResp=null,this.recHooks=[],this.refEvent=null}resend(e){this.timeout=e,this._cancelRefEvent(),this.ref="",this.refEvent=null,this.receivedResp=null,this.sent=!1,this.send()}send(){this._hasReceived("timeout")||(this.startTimeout(),this.sent=!0,this.channel.socket.push({topic:this.channel.topic,event:this.event,payload:this.payload,ref:this.ref,join_ref:this.channel._joinRef()}))}updatePayload(e){this.payload=Object.assign(Object.assign({},this.payload),e)}receive(e,a){var r;return this._hasReceived(e)&&a((r=this.receivedResp)===null||r===void 0?void 0:r.response),this.recHooks.push({status:e,callback:a}),this}startTimeout(){if(this.timeoutTimer)return;this.ref=this.channel.socket._makeRef(),this.refEvent=this.channel._replyEventName(this.ref);const e=a=>{this._cancelRefEvent(),this._cancelTimeout(),this.receivedResp=a,this._matchReceive(a)};this.channel._on(this.refEvent,{},e),this.timeoutTimer=setTimeout(()=>{this.trigger("timeout",{})},this.timeout)}trigger(e,a){this.refEvent&&this.channel._trigger(this.refEvent,{status:e,response:a})}destroy(){this._cancelRefEvent(),this._cancelTimeout()}_cancelRefEvent(){this.refEvent&&this.channel._off(this.refEvent,{})}_cancelTimeout(){clearTimeout(this.timeoutTimer),this.timeoutTimer=void 0}_matchReceive({status:e,response:a}){this.recHooks.filter(r=>r.status===e).forEach(r=>r.callback(a))}_hasReceived(e){return this.receivedResp&&this.receivedResp.status===e}}var jr;(function(t){t.SYNC="sync",t.JOIN="join",t.LEAVE="leave"})(jr||(jr={}));class pt{constructor(e,a){this.channel=e,this.state={},this.pendingDiffs=[],this.joinRef=null,this.enabled=!1,this.caller={onJoin:()=>{},onLeave:()=>{},onSync:()=>{}};const r=(a==null?void 0:a.events)||{state:"presence_state",diff:"presence_diff"};this.channel._on(r.state,{},n=>{const{onJoin:s,onLeave:i,onSync:l}=this.caller;this.joinRef=this.channel._joinRef(),this.state=pt.syncState(this.state,n,s,i),this.pendingDiffs.forEach(c=>{this.state=pt.syncDiff(this.state,c,s,i)}),this.pendingDiffs=[],l()}),this.channel._on(r.diff,{},n=>{const{onJoin:s,onLeave:i,onSync:l}=this.caller;this.inPendingSyncState()?this.pendingDiffs.push(n):(this.state=pt.syncDiff(this.state,n,s,i),l())}),this.onJoin((n,s,i)=>{this.channel._trigger("presence",{event:"join",key:n,currentPresences:s,newPresences:i})}),this.onLeave((n,s,i)=>{this.channel._trigger("presence",{event:"leave",key:n,currentPresences:s,leftPresences:i})}),this.onSync(()=>{this.channel._trigger("presence",{event:"sync"})})}static syncState(e,a,r,n){const s=this.cloneDeep(e),i=this.transformState(a),l={},c={};return this.map(s,(d,u)=>{i[d]||(c[d]=u)}),this.map(i,(d,u)=>{const h=s[d];if(h){const p=u.map(g=>g.presence_ref),y=h.map(g=>g.presence_ref),m=u.filter(g=>y.indexOf(g.presence_ref)<0),f=h.filter(g=>p.indexOf(g.presence_ref)<0);m.length>0&&(l[d]=m),f.length>0&&(c[d]=f)}else l[d]=u}),this.syncDiff(s,{joins:l,leaves:c},r,n)}static syncDiff(e,a,r,n){const{joins:s,leaves:i}={joins:this.transformState(a.joins),leaves:this.transformState(a.leaves)};return r||(r=()=>{}),n||(n=()=>{}),this.map(s,(l,c)=>{var d;const u=(d=e[l])!==null&&d!==void 0?d:[];if(e[l]=this.cloneDeep(c),u.length>0){const h=e[l].map(y=>y.presence_ref),p=u.filter(y=>h.indexOf(y.presence_ref)<0);e[l].unshift(...p)}r(l,u,c)}),this.map(i,(l,c)=>{let d=e[l];if(!d)return;const u=c.map(h=>h.presence_ref);d=d.filter(h=>u.indexOf(h.presence_ref)<0),e[l]=d,n(l,d,c),d.length===0&&delete e[l]}),e}static map(e,a){return Object.getOwnPropertyNames(e).map(r=>a(r,e[r]))}static transformState(e){return e=this.cloneDeep(e),Object.getOwnPropertyNames(e).reduce((a,r)=>{const n=e[r];return"metas"in n?a[r]=n.metas.map(s=>(s.presence_ref=s.phx_ref,delete s.phx_ref,delete s.phx_ref_prev,s)):a[r]=n,a},{})}static cloneDeep(e){return JSON.parse(JSON.stringify(e))}onJoin(e){this.caller.onJoin=e}onLeave(e){this.caller.onLeave=e}onSync(e){this.caller.onSync=e}inPendingSyncState(){return!this.joinRef||this.joinRef!==this.channel._joinRef()}}var Sr;(function(t){t.ALL="*",t.INSERT="INSERT",t.UPDATE="UPDATE",t.DELETE="DELETE"})(Sr||(Sr={}));var yt;(function(t){t.BROADCAST="broadcast",t.PRESENCE="presence",t.POSTGRES_CHANGES="postgres_changes",t.SYSTEM="system"})(yt||(yt={}));var ue;(function(t){t.SUBSCRIBED="SUBSCRIBED",t.TIMED_OUT="TIMED_OUT",t.CLOSED="CLOSED",t.CHANNEL_ERROR="CHANNEL_ERROR"})(ue||(ue={}));class Ya{constructor(e,a={config:{}},r){var n,s;if(this.topic=e,this.params=a,this.socket=r,this.bindings={},this.state=H.closed,this.joinedOnce=!1,this.pushBuffer=[],this.subTopic=e.replace(/^realtime:/i,""),this.params.config=Object.assign({broadcast:{ack:!1,self:!1},presence:{key:"",enabled:!1},private:!1},a.config),this.timeout=this.socket.timeout,this.joinPush=new na(this,se.join,this.params,this.timeout),this.rejoinTimer=new Hn(()=>this._rejoinUntilConnected(),this.socket.reconnectAfterMs),this.joinPush.receive("ok",()=>{this.state=H.joined,this.rejoinTimer.reset(),this.pushBuffer.forEach(i=>i.send()),this.pushBuffer=[]}),this._onClose(()=>{this.rejoinTimer.reset(),this.socket.log("channel",`close ${this.topic} ${this._joinRef()}`),this.state=H.closed,this.socket._remove(this)}),this._onError(i=>{this._isLeaving()||this._isClosed()||(this.socket.log("channel",`error ${this.topic}`,i),this.state=H.errored,this.rejoinTimer.scheduleTimeout())}),this.joinPush.receive("timeout",()=>{this._isJoining()&&(this.socket.log("channel",`timeout ${this.topic}`,this.joinPush.timeout),this.state=H.errored,this.rejoinTimer.scheduleTimeout())}),this.joinPush.receive("error",i=>{this._isLeaving()||this._isClosed()||(this.socket.log("channel",`error ${this.topic}`,i),this.state=H.errored,this.rejoinTimer.scheduleTimeout())}),this._on(se.reply,{},(i,l)=>{this._trigger(this._replyEventName(l),i)}),this.presence=new pt(this),this.broadcastEndpointURL=Gn(this.socket.endPoint),this.private=this.params.config.private||!1,!this.private&&(!((s=(n=this.params.config)===null||n===void 0?void 0:n.broadcast)===null||s===void 0)&&s.replay))throw`tried to use replay on public channel '${this.topic}'. It must be a private channel.`}subscribe(e,a=this.timeout){var r,n,s;if(this.socket.isConnected()||this.socket.connect(),this.state==H.closed){const{config:{broadcast:i,presence:l,private:c}}=this.params,d=(n=(r=this.bindings.postgres_changes)===null||r===void 0?void 0:r.map(y=>y.filter))!==null&&n!==void 0?n:[],u=!!this.bindings[yt.PRESENCE]&&this.bindings[yt.PRESENCE].length>0||((s=this.params.config.presence)===null||s===void 0?void 0:s.enabled)===!0,h={},p={broadcast:i,presence:Object.assign(Object.assign({},l),{enabled:u}),postgres_changes:d,private:c};this.socket.accessTokenValue&&(h.access_token=this.socket.accessTokenValue),this._onError(y=>e==null?void 0:e(ue.CHANNEL_ERROR,y)),this._onClose(()=>e==null?void 0:e(ue.CLOSED)),this.updateJoinPayload(Object.assign({config:p},h)),this.joinedOnce=!0,this._rejoin(a),this.joinPush.receive("ok",async({postgres_changes:y})=>{var m;if(this.socket.setAuth(),y===void 0){e==null||e(ue.SUBSCRIBED);return}else{const f=this.bindings.postgres_changes,g=(m=f==null?void 0:f.length)!==null&&m!==void 0?m:0,v=[];for(let x=0;x<g;x++){const T=f[x],{filter:{event:j,schema:A,table:S,filter:E}}=T,_=y&&y[x];if(_&&_.event===j&&_.schema===A&&_.table===S&&_.filter===E)v.push(Object.assign(Object.assign({},T),{id:_.id}));else{this.unsubscribe(),this.state=H.errored,e==null||e(ue.CHANNEL_ERROR,new Error("mismatch between server and client bindings for postgres changes"));return}}this.bindings.postgres_changes=v,e&&e(ue.SUBSCRIBED);return}}).receive("error",y=>{this.state=H.errored,e==null||e(ue.CHANNEL_ERROR,new Error(JSON.stringify(Object.values(y).join(", ")||"error")))}).receive("timeout",()=>{e==null||e(ue.TIMED_OUT)})}return this}presenceState(){return this.presence.state}async track(e,a={}){return await this.send({type:"presence",event:"track",payload:e},a.timeout||this.timeout)}async untrack(e={}){return await this.send({type:"presence",event:"untrack"},e)}on(e,a,r){return this.state===H.joined&&e===yt.PRESENCE&&(this.socket.log("channel",`resubscribe to ${this.topic} due to change in presence callbacks on joined channel`),this.unsubscribe().then(()=>this.subscribe())),this._on(e,a,r)}async httpSend(e,a,r={}){var n;const s=this.socket.accessTokenValue?`Bearer ${this.socket.accessTokenValue}`:"";if(a==null)return Promise.reject("Payload is required for httpSend()");const i={method:"POST",headers:{Authorization:s,apikey:this.socket.apiKey?this.socket.apiKey:"","Content-Type":"application/json"},body:JSON.stringify({messages:[{topic:this.subTopic,event:e,payload:a,private:this.private}]})},l=await this._fetchWithTimeout(this.broadcastEndpointURL,i,(n=r.timeout)!==null&&n!==void 0?n:this.timeout);if(l.status===202)return{success:!0};let c=l.statusText;try{const d=await l.json();c=d.error||d.message||c}catch{}return Promise.reject(new Error(c))}async send(e,a={}){var r,n;if(!this._canPush()&&e.type==="broadcast"){console.warn("Realtime send() is automatically falling back to REST API. This behavior will be deprecated in the future. Please use httpSend() explicitly for REST delivery.");const{event:s,payload:i}=e,c={method:"POST",headers:{Authorization:this.socket.accessTokenValue?`Bearer ${this.socket.accessTokenValue}`:"",apikey:this.socket.apiKey?this.socket.apiKey:"","Content-Type":"application/json"},body:JSON.stringify({messages:[{topic:this.subTopic,event:s,payload:i,private:this.private}]})};try{const d=await this._fetchWithTimeout(this.broadcastEndpointURL,c,(r=a.timeout)!==null&&r!==void 0?r:this.timeout);return await((n=d.body)===null||n===void 0?void 0:n.cancel()),d.ok?"ok":"error"}catch(d){return d.name==="AbortError"?"timed out":"error"}}else return new Promise(s=>{var i,l,c;const d=this._push(e.type,e,a.timeout||this.timeout);e.type==="broadcast"&&!(!((c=(l=(i=this.params)===null||i===void 0?void 0:i.config)===null||l===void 0?void 0:l.broadcast)===null||c===void 0)&&c.ack)&&s("ok"),d.receive("ok",()=>s("ok")),d.receive("error",()=>s("error")),d.receive("timeout",()=>s("timed out"))})}updateJoinPayload(e){this.joinPush.updatePayload(e)}unsubscribe(e=this.timeout){this.state=H.leaving;const a=()=>{this.socket.log("channel",`leave ${this.topic}`),this._trigger(se.close,"leave",this._joinRef())};this.joinPush.destroy();let r=null;return new Promise(n=>{r=new na(this,se.leave,{},e),r.receive("ok",()=>{a(),n("ok")}).receive("timeout",()=>{a(),n("timed out")}).receive("error",()=>{n("error")}),r.send(),this._canPush()||r.trigger("ok",{})}).finally(()=>{r==null||r.destroy()})}teardown(){this.pushBuffer.forEach(e=>e.destroy()),this.pushBuffer=[],this.rejoinTimer.reset(),this.joinPush.destroy(),this.state=H.closed,this.bindings={}}async _fetchWithTimeout(e,a,r){const n=new AbortController,s=setTimeout(()=>n.abort(),r),i=await this.socket.fetch(e,Object.assign(Object.assign({},a),{signal:n.signal}));return clearTimeout(s),i}_push(e,a,r=this.timeout){if(!this.joinedOnce)throw`tried to push '${e}' to '${this.topic}' before joining. Use channel.subscribe() before pushing events`;let n=new na(this,e,a,r);return this._canPush()?n.send():this._addToPushBuffer(n),n}_addToPushBuffer(e){if(e.startTimeout(),this.pushBuffer.push(e),this.pushBuffer.length>Io){const a=this.pushBuffer.shift();a&&(a.destroy(),this.socket.log("channel",`discarded push due to buffer overflow: ${a.event}`,a.payload))}}_onMessage(e,a,r){return a}_isMember(e){return this.topic===e}_joinRef(){return this.joinPush.ref}_trigger(e,a,r){var n,s;const i=e.toLocaleLowerCase(),{close:l,error:c,leave:d,join:u}=se;if(r&&[l,c,d,u].indexOf(i)>=0&&r!==this._joinRef())return;let p=this._onMessage(i,a,r);if(a&&!p)throw"channel onMessage callbacks must return the payload, modified or unmodified";["insert","update","delete"].includes(i)?(n=this.bindings.postgres_changes)===null||n===void 0||n.filter(y=>{var m,f,g;return((m=y.filter)===null||m===void 0?void 0:m.event)==="*"||((g=(f=y.filter)===null||f===void 0?void 0:f.event)===null||g===void 0?void 0:g.toLocaleLowerCase())===i}).map(y=>y.callback(p,r)):(s=this.bindings[i])===null||s===void 0||s.filter(y=>{var m,f,g,v,x,T;if(["broadcast","presence","postgres_changes"].includes(i))if("id"in y){const j=y.id,A=(m=y.filter)===null||m===void 0?void 0:m.event;return j&&((f=a.ids)===null||f===void 0?void 0:f.includes(j))&&(A==="*"||(A==null?void 0:A.toLocaleLowerCase())===((g=a.data)===null||g===void 0?void 0:g.type.toLocaleLowerCase()))}else{const j=(x=(v=y==null?void 0:y.filter)===null||v===void 0?void 0:v.event)===null||x===void 0?void 0:x.toLocaleLowerCase();return j==="*"||j===((T=a==null?void 0:a.event)===null||T===void 0?void 0:T.toLocaleLowerCase())}else return y.type.toLocaleLowerCase()===i}).map(y=>{if(typeof p=="object"&&"ids"in p){const m=p.data,{schema:f,table:g,commit_timestamp:v,type:x,errors:T}=m;p=Object.assign(Object.assign({},{schema:f,table:g,commit_timestamp:v,eventType:x,new:{},old:{},errors:T}),this._getPayloadRecords(m))}y.callback(p,r)})}_isClosed(){return this.state===H.closed}_isJoined(){return this.state===H.joined}_isJoining(){return this.state===H.joining}_isLeaving(){return this.state===H.leaving}_replyEventName(e){return`chan_reply_${e}`}_on(e,a,r){const n=e.toLocaleLowerCase(),s={type:n,filter:a,callback:r};return this.bindings[n]?this.bindings[n].push(s):this.bindings[n]=[s],this}_off(e,a){const r=e.toLocaleLowerCase();return this.bindings[r]&&(this.bindings[r]=this.bindings[r].filter(n=>{var s;return!(((s=n.type)===null||s===void 0?void 0:s.toLocaleLowerCase())===r&&Ya.isEqual(n.filter,a))})),this}static isEqual(e,a){if(Object.keys(e).length!==Object.keys(a).length)return!1;for(const r in e)if(e[r]!==a[r])return!1;return!0}_rejoinUntilConnected(){this.rejoinTimer.scheduleTimeout(),this.socket.isConnected()&&this._rejoin()}_onClose(e){this._on(se.close,{},e)}_onError(e){this._on(se.error,{},a=>e(a))}_canPush(){return this.socket.isConnected()&&this._isJoined()}_rejoin(e=this.timeout){this._isLeaving()||(this.socket._leaveOpenTopic(this.topic),this.state=H.joining,this.joinPush.resend(e))}_getPayloadRecords(e){const a={new:{},old:{}};return(e.type==="INSERT"||e.type==="UPDATE")&&(a.new=_r(e.columns,e.record)),(e.type==="UPDATE"||e.type==="DELETE")&&(a.old=_r(e.columns,e.old_record)),a}}const sa=()=>{},At={HEARTBEAT_INTERVAL:25e3,RECONNECT_DELAY:10,HEARTBEAT_TIMEOUT_FALLBACK:100},Bo=[1e3,2e3,5e3,1e4],Fo=1e4,Wo=`
  addEventListener("message", (e) => {
    if (e.data.event === "start") {
      setInterval(() => postMessage({ event: "keepAlive" }), e.data.interval);
    }
  });`;class Ho{constructor(e,a){var r;if(this.accessTokenValue=null,this.apiKey=null,this.channels=new Array,this.endPoint="",this.httpEndpoint="",this.headers={},this.params={},this.timeout=_a,this.transport=null,this.heartbeatIntervalMs=At.HEARTBEAT_INTERVAL,this.heartbeatTimer=void 0,this.pendingHeartbeatRef=null,this.heartbeatCallback=sa,this.ref=0,this.reconnectTimer=null,this.logger=sa,this.conn=null,this.sendBuffer=[],this.serializer=new Ro,this.stateChangeCallbacks={open:[],close:[],error:[],message:[]},this.accessToken=null,this._connectionState="disconnected",this._wasManualDisconnect=!1,this._authPromise=null,this._resolveFetch=n=>{let s;return n?s=n:typeof fetch>"u"?s=(...i)=>de(async()=>{const{default:l}=await Promise.resolve().then(()=>$e);return{default:l}},void 0).then(({default:l})=>l(...i)).catch(l=>{throw new Error(`Failed to load @supabase/node-fetch: ${l.message}. This is required for HTTP requests in Node.js environments without native fetch.`)}):s=fetch,(...i)=>s(...i)},!(!((r=a==null?void 0:a.params)===null||r===void 0)&&r.apikey))throw new Error("API key is required to connect to Realtime");this.apiKey=a.params.apikey,this.endPoint=`${e}/${ja.websocket}`,this.httpEndpoint=Gn(e),this._initializeOptions(a),this._setupReconnectionTimer(),this.fetch=this._resolveFetch(a==null?void 0:a.fetch)}connect(){if(!(this.isConnecting()||this.isDisconnecting()||this.conn!==null&&this.isConnected())){if(this._setConnectionState("connecting"),this._setAuthSafely("connect"),this.transport)this.conn=new this.transport(this.endpointURL());else try{this.conn=Eo.createWebSocket(this.endpointURL())}catch(e){this._setConnectionState("disconnected");const a=e.message;throw a.includes("Node.js")?new Error(`${a}
To use Realtime in Node.js, you need to provide a WebSocket implementation:
Option 1: Use Node.js 22+ which has native WebSocket support
Option 2: Install and provide the "ws" package:
  npm install ws
  import ws from "ws"
  const client = new RealtimeClient(url, {
    ...options,
    transport: ws
  })`):new Error(`WebSocket not available: ${a}`)}this._setupConnectionHandlers()}}endpointURL(){return this._appendParams(this.endPoint,Object.assign({},this.params,{vsn:Po}))}disconnect(e,a){if(!this.isDisconnecting())if(this._setConnectionState("disconnecting",!0),this.conn){const r=setTimeout(()=>{this._setConnectionState("disconnected")},100);this.conn.onclose=()=>{clearTimeout(r),this._setConnectionState("disconnected")},e?this.conn.close(e,a??""):this.conn.close(),this._teardownConnection()}else this._setConnectionState("disconnected")}getChannels(){return this.channels}async removeChannel(e){const a=await e.unsubscribe();return this.channels.length===0&&this.disconnect(),a}async removeAllChannels(){const e=await Promise.all(this.channels.map(a=>a.unsubscribe()));return this.channels=[],this.disconnect(),e}log(e,a,r){this.logger(e,a,r)}connectionState(){switch(this.conn&&this.conn.readyState){case ht.connecting:return Ae.Connecting;case ht.open:return Ae.Open;case ht.closing:return Ae.Closing;default:return Ae.Closed}}isConnected(){return this.connectionState()===Ae.Open}isConnecting(){return this._connectionState==="connecting"}isDisconnecting(){return this._connectionState==="disconnecting"}channel(e,a={config:{}}){const r=`realtime:${e}`,n=this.getChannels().find(s=>s.topic===r);if(n)return n;{const s=new Ya(`realtime:${e}`,a,this);return this.channels.push(s),s}}push(e){const{topic:a,event:r,payload:n,ref:s}=e,i=()=>{this.encode(e,l=>{var c;(c=this.conn)===null||c===void 0||c.send(l)})};this.log("push",`${a} ${r} (${s})`,n),this.isConnected()?i():this.sendBuffer.push(i)}async setAuth(e=null){this._authPromise=this._performAuth(e);try{await this._authPromise}finally{this._authPromise=null}}async sendHeartbeat(){var e;if(!this.isConnected()){try{this.heartbeatCallback("disconnected")}catch(a){this.log("error","error in heartbeat callback",a)}return}if(this.pendingHeartbeatRef){this.pendingHeartbeatRef=null,this.log("transport","heartbeat timeout. Attempting to re-establish connection");try{this.heartbeatCallback("timeout")}catch(a){this.log("error","error in heartbeat callback",a)}this._wasManualDisconnect=!1,(e=this.conn)===null||e===void 0||e.close(Oo,"heartbeat timeout"),setTimeout(()=>{var a;this.isConnected()||(a=this.reconnectTimer)===null||a===void 0||a.scheduleTimeout()},At.HEARTBEAT_TIMEOUT_FALLBACK);return}this.pendingHeartbeatRef=this._makeRef(),this.push({topic:"phoenix",event:"heartbeat",payload:{},ref:this.pendingHeartbeatRef});try{this.heartbeatCallback("sent")}catch(a){this.log("error","error in heartbeat callback",a)}this._setAuthSafely("heartbeat")}onHeartbeat(e){this.heartbeatCallback=e}flushSendBuffer(){this.isConnected()&&this.sendBuffer.length>0&&(this.sendBuffer.forEach(e=>e()),this.sendBuffer=[])}_makeRef(){let e=this.ref+1;return e===this.ref?this.ref=0:this.ref=e,this.ref.toString()}_leaveOpenTopic(e){let a=this.channels.find(r=>r.topic===e&&(r._isJoined()||r._isJoining()));a&&(this.log("transport",`leaving duplicate topic "${e}"`),a.unsubscribe())}_remove(e){this.channels=this.channels.filter(a=>a.topic!==e.topic)}_onConnMessage(e){this.decode(e.data,a=>{if(a.topic==="phoenix"&&a.event==="phx_reply")try{this.heartbeatCallback(a.payload.status==="ok"?"ok":"error")}catch(d){this.log("error","error in heartbeat callback",d)}a.ref&&a.ref===this.pendingHeartbeatRef&&(this.pendingHeartbeatRef=null);const{topic:r,event:n,payload:s,ref:i}=a,l=i?`(${i})`:"",c=s.status||"";this.log("receive",`${c} ${r} ${n} ${l}`.trim(),s),this.channels.filter(d=>d._isMember(r)).forEach(d=>d._trigger(n,s,i)),this._triggerStateCallbacks("message",a)})}_clearTimer(e){var a;e==="heartbeat"&&this.heartbeatTimer?(clearInterval(this.heartbeatTimer),this.heartbeatTimer=void 0):e==="reconnect"&&((a=this.reconnectTimer)===null||a===void 0||a.reset())}_clearAllTimers(){this._clearTimer("heartbeat"),this._clearTimer("reconnect")}_setupConnectionHandlers(){this.conn&&("binaryType"in this.conn&&(this.conn.binaryType="arraybuffer"),this.conn.onopen=()=>this._onConnOpen(),this.conn.onerror=e=>this._onConnError(e),this.conn.onmessage=e=>this._onConnMessage(e),this.conn.onclose=e=>this._onConnClose(e))}_teardownConnection(){this.conn&&(this.conn.onopen=null,this.conn.onerror=null,this.conn.onmessage=null,this.conn.onclose=null,this.conn=null),this._clearAllTimers(),this.channels.forEach(e=>e.teardown())}_onConnOpen(){this._setConnectionState("connected"),this.log("transport",`connected to ${this.endpointURL()}`),this.flushSendBuffer(),this._clearTimer("reconnect"),this.worker?this.workerRef||this._startWorkerHeartbeat():this._startHeartbeat(),this._triggerStateCallbacks("open")}_startHeartbeat(){this.heartbeatTimer&&clearInterval(this.heartbeatTimer),this.heartbeatTimer=setInterval(()=>this.sendHeartbeat(),this.heartbeatIntervalMs)}_startWorkerHeartbeat(){this.workerUrl?this.log("worker",`starting worker for from ${this.workerUrl}`):this.log("worker","starting default worker");const e=this._workerObjectUrl(this.workerUrl);this.workerRef=new Worker(e),this.workerRef.onerror=a=>{this.log("worker","worker error",a.message),this.workerRef.terminate()},this.workerRef.onmessage=a=>{a.data.event==="keepAlive"&&this.sendHeartbeat()},this.workerRef.postMessage({event:"start",interval:this.heartbeatIntervalMs})}_onConnClose(e){var a;this._setConnectionState("disconnected"),this.log("transport","close",e),this._triggerChanError(),this._clearTimer("heartbeat"),this._wasManualDisconnect||(a=this.reconnectTimer)===null||a===void 0||a.scheduleTimeout(),this._triggerStateCallbacks("close",e)}_onConnError(e){this._setConnectionState("disconnected"),this.log("transport",`${e}`),this._triggerChanError(),this._triggerStateCallbacks("error",e)}_triggerChanError(){this.channels.forEach(e=>e._trigger(se.error))}_appendParams(e,a){if(Object.keys(a).length===0)return e;const r=e.match(/\?/)?"&":"?",n=new URLSearchParams(a);return`${e}${r}${n}`}_workerObjectUrl(e){let a;if(e)a=e;else{const r=new Blob([Wo],{type:"application/javascript"});a=URL.createObjectURL(r)}return a}_setConnectionState(e,a=!1){this._connectionState=e,e==="connecting"?this._wasManualDisconnect=!1:e==="disconnecting"&&(this._wasManualDisconnect=a)}async _performAuth(e=null){let a;e?a=e:this.accessToken?a=await this.accessToken():a=this.accessTokenValue,this.accessTokenValue!=a&&(this.accessTokenValue=a,this.channels.forEach(r=>{const n={access_token:a,version:Ao};a&&r.updateJoinPayload(n),r.joinedOnce&&r._isJoined()&&r._push(se.access_token,{access_token:a})}))}async _waitForAuthIfNeeded(){this._authPromise&&await this._authPromise}_setAuthSafely(e="general"){this.setAuth().catch(a=>{this.log("error",`error setting auth in ${e}`,a)})}_triggerStateCallbacks(e,a){try{this.stateChangeCallbacks[e].forEach(r=>{try{r(a)}catch(n){this.log("error",`error in ${e} callback`,n)}})}catch(r){this.log("error",`error triggering ${e} callbacks`,r)}}_setupReconnectionTimer(){this.reconnectTimer=new Hn(async()=>{setTimeout(async()=>{await this._waitForAuthIfNeeded(),this.isConnected()||this.connect()},At.RECONNECT_DELAY)},this.reconnectAfterMs)}_initializeOptions(e){var a,r,n,s,i,l,c,d,u;if(this.transport=(a=e==null?void 0:e.transport)!==null&&a!==void 0?a:null,this.timeout=(r=e==null?void 0:e.timeout)!==null&&r!==void 0?r:_a,this.heartbeatIntervalMs=(n=e==null?void 0:e.heartbeatIntervalMs)!==null&&n!==void 0?n:At.HEARTBEAT_INTERVAL,this.worker=(s=e==null?void 0:e.worker)!==null&&s!==void 0?s:!1,this.accessToken=(i=e==null?void 0:e.accessToken)!==null&&i!==void 0?i:null,this.heartbeatCallback=(l=e==null?void 0:e.heartbeatCallback)!==null&&l!==void 0?l:sa,e!=null&&e.params&&(this.params=e.params),e!=null&&e.logger&&(this.logger=e.logger),(e!=null&&e.logLevel||e!=null&&e.log_level)&&(this.logLevel=e.logLevel||e.log_level,this.params=Object.assign(Object.assign({},this.params),{log_level:this.logLevel})),this.reconnectAfterMs=(c=e==null?void 0:e.reconnectAfterMs)!==null&&c!==void 0?c:h=>Bo[h-1]||Fo,this.encode=(d=e==null?void 0:e.encode)!==null&&d!==void 0?d:(h,p)=>p(JSON.stringify(h)),this.decode=(u=e==null?void 0:e.decode)!==null&&u!==void 0?u:this.serializer.decode.bind(this.serializer),this.worker){if(typeof window<"u"&&!window.Worker)throw new Error("Web Worker is not supported");this.workerUrl=e==null?void 0:e.workerUrl}}}class Ja extends Error{constructor(e){super(e),this.__isStorageError=!0,this.name="StorageError"}}function F(t){return typeof t=="object"&&t!==null&&"__isStorageError"in t}class qo extends Ja{constructor(e,a,r){super(e),this.name="StorageApiError",this.status=a,this.statusCode=r}toJSON(){return{name:this.name,message:this.message,status:this.status,statusCode:this.statusCode}}}class Ea extends Ja{constructor(e,a){super(e),this.name="StorageUnknownError",this.originalError=a}}const Za=t=>{let e;return t?e=t:typeof fetch>"u"?e=(...a)=>de(async()=>{const{default:r}=await Promise.resolve().then(()=>$e);return{default:r}},void 0).then(({default:r})=>r(...a)):e=fetch,(...a)=>e(...a)},Go=()=>N(void 0,void 0,void 0,function*(){return typeof Response>"u"?(yield de(()=>Promise.resolve().then(()=>$e),void 0)).Response:Response}),Na=t=>{if(Array.isArray(t))return t.map(a=>Na(a));if(typeof t=="function"||t!==Object(t))return t;const e={};return Object.entries(t).forEach(([a,r])=>{const n=a.replace(/([-_][a-z])/gi,s=>s.toUpperCase().replace(/[-_]/g,""));e[n]=Na(r)}),e},zo=t=>{if(typeof t!="object"||t===null)return!1;const e=Object.getPrototypeOf(t);return(e===null||e===Object.prototype||Object.getPrototypeOf(e)===null)&&!(Symbol.toStringTag in t)&&!(Symbol.iterator in t)},oa=t=>t.msg||t.message||t.error_description||t.error||JSON.stringify(t),Ko=(t,e,a)=>N(void 0,void 0,void 0,function*(){const r=yield Go();t instanceof r&&!(a!=null&&a.noResolveJson)?t.json().then(n=>{const s=t.status||500,i=(n==null?void 0:n.statusCode)||s+"";e(new qo(oa(n),s,i))}).catch(n=>{e(new Ea(oa(n),n))}):e(new Ea(oa(t),t))}),Vo=(t,e,a,r)=>{const n={method:t,headers:(e==null?void 0:e.headers)||{}};return t==="GET"||!r?n:(zo(r)?(n.headers=Object.assign({"Content-Type":"application/json"},e==null?void 0:e.headers),n.body=JSON.stringify(r)):n.body=r,e!=null&&e.duplex&&(n.duplex=e.duplex),Object.assign(Object.assign({},n),a))};function wt(t,e,a,r,n,s){return N(this,void 0,void 0,function*(){return new Promise((i,l)=>{t(a,Vo(e,r,n,s)).then(c=>{if(!c.ok)throw c;return r!=null&&r.noResolveJson?c:c.json()}).then(c=>i(c)).catch(c=>Ko(c,l,r))})})}function ft(t,e,a,r){return N(this,void 0,void 0,function*(){return wt(t,"GET",e,a,r)})}function ne(t,e,a,r,n){return N(this,void 0,void 0,function*(){return wt(t,"POST",e,r,n,a)})}function Aa(t,e,a,r,n){return N(this,void 0,void 0,function*(){return wt(t,"PUT",e,r,n,a)})}function Yo(t,e,a,r){return N(this,void 0,void 0,function*(){return wt(t,"HEAD",e,Object.assign(Object.assign({},a),{noResolveJson:!0}),r)})}function Qa(t,e,a,r,n){return N(this,void 0,void 0,function*(){return wt(t,"DELETE",e,r,n,a)})}class Jo{constructor(e,a){this.downloadFn=e,this.shouldThrowOnError=a}then(e,a){return this.execute().then(e,a)}execute(){return N(this,void 0,void 0,function*(){try{return{data:(yield this.downloadFn()).body,error:null}}catch(e){if(this.shouldThrowOnError)throw e;if(F(e))return{data:null,error:e};throw e}})}}var zn;class Zo{constructor(e,a){this.downloadFn=e,this.shouldThrowOnError=a,this[zn]="BlobDownloadBuilder",this.promise=null}asStream(){return new Jo(this.downloadFn,this.shouldThrowOnError)}then(e,a){return this.getPromise().then(e,a)}catch(e){return this.getPromise().catch(e)}finally(e){return this.getPromise().finally(e)}getPromise(){return this.promise||(this.promise=this.execute()),this.promise}execute(){return N(this,void 0,void 0,function*(){try{return{data:yield(yield this.downloadFn()).blob(),error:null}}catch(e){if(this.shouldThrowOnError)throw e;if(F(e))return{data:null,error:e};throw e}})}}zn=Symbol.toStringTag;const Qo={limit:100,offset:0,sortBy:{column:"name",order:"asc"}},Er={cacheControl:"3600",contentType:"text/plain;charset=UTF-8",upsert:!1};class Xo{constructor(e,a={},r,n){this.shouldThrowOnError=!1,this.url=e,this.headers=a,this.bucketId=r,this.fetch=Za(n)}throwOnError(){return this.shouldThrowOnError=!0,this}uploadOrUpdate(e,a,r,n){return N(this,void 0,void 0,function*(){try{let s;const i=Object.assign(Object.assign({},Er),n);let l=Object.assign(Object.assign({},this.headers),e==="POST"&&{"x-upsert":String(i.upsert)});const c=i.metadata;typeof Blob<"u"&&r instanceof Blob?(s=new FormData,s.append("cacheControl",i.cacheControl),c&&s.append("metadata",this.encodeMetadata(c)),s.append("",r)):typeof FormData<"u"&&r instanceof FormData?(s=r,s.append("cacheControl",i.cacheControl),c&&s.append("metadata",this.encodeMetadata(c))):(s=r,l["cache-control"]=`max-age=${i.cacheControl}`,l["content-type"]=i.contentType,c&&(l["x-metadata"]=this.toBase64(this.encodeMetadata(c)))),n!=null&&n.headers&&(l=Object.assign(Object.assign({},l),n.headers));const d=this._removeEmptyFolders(a),u=this._getFinalPath(d),h=yield(e=="PUT"?Aa:ne)(this.fetch,`${this.url}/object/${u}`,s,Object.assign({headers:l},i!=null&&i.duplex?{duplex:i.duplex}:{}));return{data:{path:d,id:h.Id,fullPath:h.Key},error:null}}catch(s){if(this.shouldThrowOnError)throw s;if(F(s))return{data:null,error:s};throw s}})}upload(e,a,r){return N(this,void 0,void 0,function*(){return this.uploadOrUpdate("POST",e,a,r)})}uploadToSignedUrl(e,a,r,n){return N(this,void 0,void 0,function*(){const s=this._removeEmptyFolders(e),i=this._getFinalPath(s),l=new URL(this.url+`/object/upload/sign/${i}`);l.searchParams.set("token",a);try{let c;const d=Object.assign({upsert:Er.upsert},n),u=Object.assign(Object.assign({},this.headers),{"x-upsert":String(d.upsert)});typeof Blob<"u"&&r instanceof Blob?(c=new FormData,c.append("cacheControl",d.cacheControl),c.append("",r)):typeof FormData<"u"&&r instanceof FormData?(c=r,c.append("cacheControl",d.cacheControl)):(c=r,u["cache-control"]=`max-age=${d.cacheControl}`,u["content-type"]=d.contentType);const h=yield Aa(this.fetch,l.toString(),c,{headers:u});return{data:{path:s,fullPath:h.Key},error:null}}catch(c){if(this.shouldThrowOnError)throw c;if(F(c))return{data:null,error:c};throw c}})}createSignedUploadUrl(e,a){return N(this,void 0,void 0,function*(){try{let r=this._getFinalPath(e);const n=Object.assign({},this.headers);a!=null&&a.upsert&&(n["x-upsert"]="true");const s=yield ne(this.fetch,`${this.url}/object/upload/sign/${r}`,{},{headers:n}),i=new URL(this.url+s.url),l=i.searchParams.get("token");if(!l)throw new Ja("No token returned by API");return{data:{signedUrl:i.toString(),path:e,token:l},error:null}}catch(r){if(this.shouldThrowOnError)throw r;if(F(r))return{data:null,error:r};throw r}})}update(e,a,r){return N(this,void 0,void 0,function*(){return this.uploadOrUpdate("PUT",e,a,r)})}move(e,a,r){return N(this,void 0,void 0,function*(){try{return{data:yield ne(this.fetch,`${this.url}/object/move`,{bucketId:this.bucketId,sourceKey:e,destinationKey:a,destinationBucket:r==null?void 0:r.destinationBucket},{headers:this.headers}),error:null}}catch(n){if(this.shouldThrowOnError)throw n;if(F(n))return{data:null,error:n};throw n}})}copy(e,a,r){return N(this,void 0,void 0,function*(){try{return{data:{path:(yield ne(this.fetch,`${this.url}/object/copy`,{bucketId:this.bucketId,sourceKey:e,destinationKey:a,destinationBucket:r==null?void 0:r.destinationBucket},{headers:this.headers})).Key},error:null}}catch(n){if(this.shouldThrowOnError)throw n;if(F(n))return{data:null,error:n};throw n}})}createSignedUrl(e,a,r){return N(this,void 0,void 0,function*(){try{let n=this._getFinalPath(e),s=yield ne(this.fetch,`${this.url}/object/sign/${n}`,Object.assign({expiresIn:a},r!=null&&r.transform?{transform:r.transform}:{}),{headers:this.headers});const i=r!=null&&r.download?`&download=${r.download===!0?"":r.download}`:"";return s={signedUrl:encodeURI(`${this.url}${s.signedURL}${i}`)},{data:s,error:null}}catch(n){if(this.shouldThrowOnError)throw n;if(F(n))return{data:null,error:n};throw n}})}createSignedUrls(e,a,r){return N(this,void 0,void 0,function*(){try{const n=yield ne(this.fetch,`${this.url}/object/sign/${this.bucketId}`,{expiresIn:a,paths:e},{headers:this.headers}),s=r!=null&&r.download?`&download=${r.download===!0?"":r.download}`:"";return{data:n.map(i=>Object.assign(Object.assign({},i),{signedUrl:i.signedURL?encodeURI(`${this.url}${i.signedURL}${s}`):null})),error:null}}catch(n){if(this.shouldThrowOnError)throw n;if(F(n))return{data:null,error:n};throw n}})}download(e,a){const n=typeof(a==null?void 0:a.transform)<"u"?"render/image/authenticated":"object",s=this.transformOptsToQueryString((a==null?void 0:a.transform)||{}),i=s?`?${s}`:"",l=this._getFinalPath(e),c=()=>ft(this.fetch,`${this.url}/${n}/${l}${i}`,{headers:this.headers,noResolveJson:!0});return new Zo(c,this.shouldThrowOnError)}info(e){return N(this,void 0,void 0,function*(){const a=this._getFinalPath(e);try{const r=yield ft(this.fetch,`${this.url}/object/info/${a}`,{headers:this.headers});return{data:Na(r),error:null}}catch(r){if(this.shouldThrowOnError)throw r;if(F(r))return{data:null,error:r};throw r}})}exists(e){return N(this,void 0,void 0,function*(){const a=this._getFinalPath(e);try{return yield Yo(this.fetch,`${this.url}/object/${a}`,{headers:this.headers}),{data:!0,error:null}}catch(r){if(this.shouldThrowOnError)throw r;if(F(r)&&r instanceof Ea){const n=r.originalError;if([400,404].includes(n==null?void 0:n.status))return{data:!1,error:r}}throw r}})}getPublicUrl(e,a){const r=this._getFinalPath(e),n=[],s=a!=null&&a.download?`download=${a.download===!0?"":a.download}`:"";s!==""&&n.push(s);const l=typeof(a==null?void 0:a.transform)<"u"?"render/image":"object",c=this.transformOptsToQueryString((a==null?void 0:a.transform)||{});c!==""&&n.push(c);let d=n.join("&");return d!==""&&(d=`?${d}`),{data:{publicUrl:encodeURI(`${this.url}/${l}/public/${r}${d}`)}}}remove(e){return N(this,void 0,void 0,function*(){try{return{data:yield Qa(this.fetch,`${this.url}/object/${this.bucketId}`,{prefixes:e},{headers:this.headers}),error:null}}catch(a){if(this.shouldThrowOnError)throw a;if(F(a))return{data:null,error:a};throw a}})}list(e,a,r){return N(this,void 0,void 0,function*(){try{const n=Object.assign(Object.assign(Object.assign({},Qo),a),{prefix:e||""});return{data:yield ne(this.fetch,`${this.url}/object/list/${this.bucketId}`,n,{headers:this.headers},r),error:null}}catch(n){if(this.shouldThrowOnError)throw n;if(F(n))return{data:null,error:n};throw n}})}listV2(e,a){return N(this,void 0,void 0,function*(){try{const r=Object.assign({},e);return{data:yield ne(this.fetch,`${this.url}/object/list-v2/${this.bucketId}`,r,{headers:this.headers},a),error:null}}catch(r){if(this.shouldThrowOnError)throw r;if(F(r))return{data:null,error:r};throw r}})}encodeMetadata(e){return JSON.stringify(e)}toBase64(e){return typeof Buffer<"u"?Buffer.from(e).toString("base64"):btoa(e)}_getFinalPath(e){return`${this.bucketId}/${e.replace(/^\/+/,"")}`}_removeEmptyFolders(e){return e.replace(/^\/|\/$/g,"").replace(/\/+/g,"/")}transformOptsToQueryString(e){const a=[];return e.width&&a.push(`width=${e.width}`),e.height&&a.push(`height=${e.height}`),e.resize&&a.push(`resize=${e.resize}`),e.format&&a.push(`format=${e.format}`),e.quality&&a.push(`quality=${e.quality}`),a.join("&")}}const Kn="2.76.1",Vn={"X-Client-Info":`storage-js/${Kn}`};class ei{constructor(e,a={},r,n){this.shouldThrowOnError=!1;const s=new URL(e);n!=null&&n.useNewHostname&&/supabase\.(co|in|red)$/.test(s.hostname)&&!s.hostname.includes("storage.supabase.")&&(s.hostname=s.hostname.replace("supabase.","storage.supabase.")),this.url=s.href.replace(/\/$/,""),this.headers=Object.assign(Object.assign({},Vn),a),this.fetch=Za(r)}throwOnError(){return this.shouldThrowOnError=!0,this}listBuckets(){return N(this,void 0,void 0,function*(){try{return{data:yield ft(this.fetch,`${this.url}/bucket`,{headers:this.headers}),error:null}}catch(e){if(this.shouldThrowOnError)throw e;if(F(e))return{data:null,error:e};throw e}})}getBucket(e){return N(this,void 0,void 0,function*(){try{return{data:yield ft(this.fetch,`${this.url}/bucket/${e}`,{headers:this.headers}),error:null}}catch(a){if(this.shouldThrowOnError)throw a;if(F(a))return{data:null,error:a};throw a}})}createBucket(e){return N(this,arguments,void 0,function*(a,r={public:!1}){try{return{data:yield ne(this.fetch,`${this.url}/bucket`,{id:a,name:a,type:r.type,public:r.public,file_size_limit:r.fileSizeLimit,allowed_mime_types:r.allowedMimeTypes},{headers:this.headers}),error:null}}catch(n){if(this.shouldThrowOnError)throw n;if(F(n))return{data:null,error:n};throw n}})}updateBucket(e,a){return N(this,void 0,void 0,function*(){try{return{data:yield Aa(this.fetch,`${this.url}/bucket/${e}`,{id:e,name:e,public:a.public,file_size_limit:a.fileSizeLimit,allowed_mime_types:a.allowedMimeTypes},{headers:this.headers}),error:null}}catch(r){if(this.shouldThrowOnError)throw r;if(F(r))return{data:null,error:r};throw r}})}emptyBucket(e){return N(this,void 0,void 0,function*(){try{return{data:yield ne(this.fetch,`${this.url}/bucket/${e}/empty`,{},{headers:this.headers}),error:null}}catch(a){if(this.shouldThrowOnError)throw a;if(F(a))return{data:null,error:a};throw a}})}deleteBucket(e){return N(this,void 0,void 0,function*(){try{return{data:yield Qa(this.fetch,`${this.url}/bucket/${e}`,{},{headers:this.headers}),error:null}}catch(a){if(this.shouldThrowOnError)throw a;if(F(a))return{data:null,error:a};throw a}})}}class ti{constructor(e,a={},r){this.shouldThrowOnError=!1,this.url=e.replace(/\/$/,""),this.headers=Object.assign(Object.assign({},Vn),a),this.fetch=Za(r)}throwOnError(){return this.shouldThrowOnError=!0,this}createBucket(e){return N(this,void 0,void 0,function*(){try{return{data:yield ne(this.fetch,`${this.url}/bucket`,{name:e},{headers:this.headers}),error:null}}catch(a){if(this.shouldThrowOnError)throw a;if(F(a))return{data:null,error:a};throw a}})}listBuckets(e){return N(this,void 0,void 0,function*(){try{const a=new URLSearchParams;(e==null?void 0:e.limit)!==void 0&&a.set("limit",e.limit.toString()),(e==null?void 0:e.offset)!==void 0&&a.set("offset",e.offset.toString()),e!=null&&e.sortColumn&&a.set("sortColumn",e.sortColumn),e!=null&&e.sortOrder&&a.set("sortOrder",e.sortOrder),e!=null&&e.search&&a.set("search",e.search);const r=a.toString(),n=r?`${this.url}/bucket?${r}`:`${this.url}/bucket`,s=yield ft(this.fetch,n,{headers:this.headers});return{data:Array.isArray(s)?s.filter(l=>l.type==="ANALYTICS"):[],error:null}}catch(a){if(this.shouldThrowOnError)throw a;if(F(a))return{data:null,error:a};throw a}})}deleteBucket(e){return N(this,void 0,void 0,function*(){try{return{data:yield Qa(this.fetch,`${this.url}/bucket/${e}`,{},{headers:this.headers}),error:null}}catch(a){if(this.shouldThrowOnError)throw a;if(F(a))return{data:null,error:a};throw a}})}}const Xa={"X-Client-Info":`storage-js/${Kn}`,"Content-Type":"application/json"};class Yn extends Error{constructor(e){super(e),this.__isStorageVectorsError=!0,this.name="StorageVectorsError"}}function Z(t){return typeof t=="object"&&t!==null&&"__isStorageVectorsError"in t}class ia extends Yn{constructor(e,a,r){super(e),this.name="StorageVectorsApiError",this.status=a,this.statusCode=r}toJSON(){return{name:this.name,message:this.message,status:this.status,statusCode:this.statusCode}}}class ai extends Yn{constructor(e,a){super(e),this.name="StorageVectorsUnknownError",this.originalError=a}}var Nr;(function(t){t.InternalError="InternalError",t.S3VectorConflictException="S3VectorConflictException",t.S3VectorNotFoundException="S3VectorNotFoundException",t.S3VectorBucketNotEmpty="S3VectorBucketNotEmpty",t.S3VectorMaxBucketsExceeded="S3VectorMaxBucketsExceeded",t.S3VectorMaxIndexesExceeded="S3VectorMaxIndexesExceeded"})(Nr||(Nr={}));const er=t=>{let e;return t?e=t:typeof fetch>"u"?e=(...a)=>de(async()=>{const{default:r}=await Promise.resolve().then(()=>$e);return{default:r}},void 0).then(({default:r})=>r(...a)):e=fetch,(...a)=>e(...a)},ri=t=>{if(typeof t!="object"||t===null)return!1;const e=Object.getPrototypeOf(t);return(e===null||e===Object.prototype||Object.getPrototypeOf(e)===null)&&!(Symbol.toStringTag in t)&&!(Symbol.iterator in t)},Ar=t=>t.msg||t.message||t.error_description||t.error||JSON.stringify(t),ni=(t,e,a)=>N(void 0,void 0,void 0,function*(){if(t&&typeof t=="object"&&"status"in t&&"ok"in t&&typeof t.status=="number"&&!(a!=null&&a.noResolveJson)){const n=t.status||500,s=t;if(typeof s.json=="function")s.json().then(i=>{const l=(i==null?void 0:i.statusCode)||(i==null?void 0:i.code)||n+"";e(new ia(Ar(i),n,l))}).catch(()=>{const i=n+"",l=s.statusText||`HTTP ${n} error`;e(new ia(l,n,i))});else{const i=n+"",l=s.statusText||`HTTP ${n} error`;e(new ia(l,n,i))}}else e(new ai(Ar(t),t))}),si=(t,e,a,r)=>{const n={method:t,headers:(e==null?void 0:e.headers)||{}};return r?(ri(r)?(n.headers=Object.assign({"Content-Type":"application/json"},e==null?void 0:e.headers),n.body=JSON.stringify(r)):n.body=r,Object.assign(Object.assign({},n),a)):n};function oi(t,e,a,r,n,s){return N(this,void 0,void 0,function*(){return new Promise((i,l)=>{t(a,si(e,r,n,s)).then(c=>{if(!c.ok)throw c;if(r!=null&&r.noResolveJson)return c;const d=c.headers.get("content-type");return!d||!d.includes("application/json")?{}:c.json()}).then(c=>i(c)).catch(c=>ni(c,l,r))})})}function Q(t,e,a,r,n){return N(this,void 0,void 0,function*(){return oi(t,"POST",e,r,n,a)})}class ii{constructor(e,a={},r){this.shouldThrowOnError=!1,this.url=e.replace(/\/$/,""),this.headers=Object.assign(Object.assign({},Xa),a),this.fetch=er(r)}throwOnError(){return this.shouldThrowOnError=!0,this}createIndex(e){return N(this,void 0,void 0,function*(){try{return{data:(yield Q(this.fetch,`${this.url}/CreateIndex`,e,{headers:this.headers}))||{},error:null}}catch(a){if(this.shouldThrowOnError)throw a;if(Z(a))return{data:null,error:a};throw a}})}getIndex(e,a){return N(this,void 0,void 0,function*(){try{return{data:yield Q(this.fetch,`${this.url}/GetIndex`,{vectorBucketName:e,indexName:a},{headers:this.headers}),error:null}}catch(r){if(this.shouldThrowOnError)throw r;if(Z(r))return{data:null,error:r};throw r}})}listIndexes(e){return N(this,void 0,void 0,function*(){try{return{data:yield Q(this.fetch,`${this.url}/ListIndexes`,e,{headers:this.headers}),error:null}}catch(a){if(this.shouldThrowOnError)throw a;if(Z(a))return{data:null,error:a};throw a}})}deleteIndex(e,a){return N(this,void 0,void 0,function*(){try{return{data:(yield Q(this.fetch,`${this.url}/DeleteIndex`,{vectorBucketName:e,indexName:a},{headers:this.headers}))||{},error:null}}catch(r){if(this.shouldThrowOnError)throw r;if(Z(r))return{data:null,error:r};throw r}})}}class li{constructor(e,a={},r){this.shouldThrowOnError=!1,this.url=e.replace(/\/$/,""),this.headers=Object.assign(Object.assign({},Xa),a),this.fetch=er(r)}throwOnError(){return this.shouldThrowOnError=!0,this}putVectors(e){return N(this,void 0,void 0,function*(){try{if(e.vectors.length<1||e.vectors.length>500)throw new Error("Vector batch size must be between 1 and 500 items");return{data:(yield Q(this.fetch,`${this.url}/PutVectors`,e,{headers:this.headers}))||{},error:null}}catch(a){if(this.shouldThrowOnError)throw a;if(Z(a))return{data:null,error:a};throw a}})}getVectors(e){return N(this,void 0,void 0,function*(){try{return{data:yield Q(this.fetch,`${this.url}/GetVectors`,e,{headers:this.headers}),error:null}}catch(a){if(this.shouldThrowOnError)throw a;if(Z(a))return{data:null,error:a};throw a}})}listVectors(e){return N(this,void 0,void 0,function*(){try{if(e.segmentCount!==void 0){if(e.segmentCount<1||e.segmentCount>16)throw new Error("segmentCount must be between 1 and 16");if(e.segmentIndex!==void 0&&(e.segmentIndex<0||e.segmentIndex>=e.segmentCount))throw new Error(`segmentIndex must be between 0 and ${e.segmentCount-1}`)}return{data:yield Q(this.fetch,`${this.url}/ListVectors`,e,{headers:this.headers}),error:null}}catch(a){if(this.shouldThrowOnError)throw a;if(Z(a))return{data:null,error:a};throw a}})}queryVectors(e){return N(this,void 0,void 0,function*(){try{return{data:yield Q(this.fetch,`${this.url}/QueryVectors`,e,{headers:this.headers}),error:null}}catch(a){if(this.shouldThrowOnError)throw a;if(Z(a))return{data:null,error:a};throw a}})}deleteVectors(e){return N(this,void 0,void 0,function*(){try{if(e.keys.length<1||e.keys.length>500)throw new Error("Keys batch size must be between 1 and 500 items");return{data:(yield Q(this.fetch,`${this.url}/DeleteVectors`,e,{headers:this.headers}))||{},error:null}}catch(a){if(this.shouldThrowOnError)throw a;if(Z(a))return{data:null,error:a};throw a}})}}class di{constructor(e,a={},r){this.shouldThrowOnError=!1,this.url=e.replace(/\/$/,""),this.headers=Object.assign(Object.assign({},Xa),a),this.fetch=er(r)}throwOnError(){return this.shouldThrowOnError=!0,this}createBucket(e){return N(this,void 0,void 0,function*(){try{return{data:(yield Q(this.fetch,`${this.url}/CreateVectorBucket`,{vectorBucketName:e},{headers:this.headers}))||{},error:null}}catch(a){if(this.shouldThrowOnError)throw a;if(Z(a))return{data:null,error:a};throw a}})}getBucket(e){return N(this,void 0,void 0,function*(){try{return{data:yield Q(this.fetch,`${this.url}/GetVectorBucket`,{vectorBucketName:e},{headers:this.headers}),error:null}}catch(a){if(this.shouldThrowOnError)throw a;if(Z(a))return{data:null,error:a};throw a}})}listBuckets(){return N(this,arguments,void 0,function*(e={}){try{return{data:yield Q(this.fetch,`${this.url}/ListVectorBuckets`,e,{headers:this.headers}),error:null}}catch(a){if(this.shouldThrowOnError)throw a;if(Z(a))return{data:null,error:a};throw a}})}deleteBucket(e){return N(this,void 0,void 0,function*(){try{return{data:(yield Q(this.fetch,`${this.url}/DeleteVectorBucket`,{vectorBucketName:e},{headers:this.headers}))||{},error:null}}catch(a){if(this.shouldThrowOnError)throw a;if(Z(a))return{data:null,error:a};throw a}})}}class ci extends di{constructor(e,a={}){super(e,a.headers||{},a.fetch)}from(e){return new ui(this.url,this.headers,e,this.fetch)}}class ui extends ii{constructor(e,a,r,n){super(e,a,n),this.vectorBucketName=r}createIndex(e){const a=Object.create(null,{createIndex:{get:()=>super.createIndex}});return N(this,void 0,void 0,function*(){return a.createIndex.call(this,Object.assign(Object.assign({},e),{vectorBucketName:this.vectorBucketName}))})}listIndexes(){const e=Object.create(null,{listIndexes:{get:()=>super.listIndexes}});return N(this,arguments,void 0,function*(a={}){return e.listIndexes.call(this,Object.assign(Object.assign({},a),{vectorBucketName:this.vectorBucketName}))})}getIndex(e){const a=Object.create(null,{getIndex:{get:()=>super.getIndex}});return N(this,void 0,void 0,function*(){return a.getIndex.call(this,this.vectorBucketName,e)})}deleteIndex(e){const a=Object.create(null,{deleteIndex:{get:()=>super.deleteIndex}});return N(this,void 0,void 0,function*(){return a.deleteIndex.call(this,this.vectorBucketName,e)})}index(e){return new hi(this.url,this.headers,this.vectorBucketName,e,this.fetch)}}class hi extends li{constructor(e,a,r,n,s){super(e,a,s),this.vectorBucketName=r,this.indexName=n}putVectors(e){const a=Object.create(null,{putVectors:{get:()=>super.putVectors}});return N(this,void 0,void 0,function*(){return a.putVectors.call(this,Object.assign(Object.assign({},e),{vectorBucketName:this.vectorBucketName,indexName:this.indexName}))})}getVectors(e){const a=Object.create(null,{getVectors:{get:()=>super.getVectors}});return N(this,void 0,void 0,function*(){return a.getVectors.call(this,Object.assign(Object.assign({},e),{vectorBucketName:this.vectorBucketName,indexName:this.indexName}))})}listVectors(){const e=Object.create(null,{listVectors:{get:()=>super.listVectors}});return N(this,arguments,void 0,function*(a={}){return e.listVectors.call(this,Object.assign(Object.assign({},a),{vectorBucketName:this.vectorBucketName,indexName:this.indexName}))})}queryVectors(e){const a=Object.create(null,{queryVectors:{get:()=>super.queryVectors}});return N(this,void 0,void 0,function*(){return a.queryVectors.call(this,Object.assign(Object.assign({},e),{vectorBucketName:this.vectorBucketName,indexName:this.indexName}))})}deleteVectors(e){const a=Object.create(null,{deleteVectors:{get:()=>super.deleteVectors}});return N(this,void 0,void 0,function*(){return a.deleteVectors.call(this,Object.assign(Object.assign({},e),{vectorBucketName:this.vectorBucketName,indexName:this.indexName}))})}}class pi extends ei{constructor(e,a={},r,n){super(e,a,r,n)}from(e){return new Xo(this.url,this.headers,e,this.fetch)}get vectors(){return new ci(this.url+"/vector",{headers:this.headers,fetch:this.fetch})}get analytics(){return new ti(this.url+"/iceberg",this.headers,this.fetch)}}const yi="2.76.1";let dt="";typeof Deno<"u"?dt="deno":typeof document<"u"?dt="web":typeof navigator<"u"&&navigator.product==="ReactNative"?dt="react-native":dt="node";const mi={"X-Client-Info":`supabase-js-${dt}/${yi}`},fi={headers:mi},gi={schema:"public"},vi={autoRefreshToken:!0,persistSession:!0,detectSessionInUrl:!0,flowType:"implicit"},bi={},wi=t=>{let e;return t?e=t:typeof fetch>"u"?e=On:e=fetch,(...a)=>e(...a)},xi=()=>typeof Headers>"u"?In:Headers,Ti=(t,e,a)=>{const r=wi(a),n=xi();return async(s,i)=>{var l;const c=(l=await e())!==null&&l!==void 0?l:t;let d=new n(i==null?void 0:i.headers);return d.has("apikey")||d.set("apikey",t),d.has("Authorization")||d.set("Authorization",`Bearer ${c}`),r(s,Object.assign(Object.assign({},i),{headers:d}))}};function ki(t){return t.endsWith("/")?t:t+"/"}function _i(t,e){var a,r;const{db:n,auth:s,realtime:i,global:l}=t,{db:c,auth:d,realtime:u,global:h}=e,p={db:Object.assign(Object.assign({},c),n),auth:Object.assign(Object.assign({},d),s),realtime:Object.assign(Object.assign({},u),i),storage:{},global:Object.assign(Object.assign(Object.assign({},h),l),{headers:Object.assign(Object.assign({},(a=h==null?void 0:h.headers)!==null&&a!==void 0?a:{}),(r=l==null?void 0:l.headers)!==null&&r!==void 0?r:{})}),accessToken:async()=>""};return t.accessToken?p.accessToken=t.accessToken:delete p.accessToken,p}function ji(t){const e=t==null?void 0:t.trim();if(!e)throw new Error("supabaseUrl is required.");if(!e.match(/^https?:\/\//i))throw new Error("Invalid supabaseUrl: Must be a valid HTTP or HTTPS URL.");try{return new URL(ki(e))}catch{throw Error("Invalid supabaseUrl: Provided URL is malformed.")}}const Jn="2.76.1",He=30*1e3,Pa=3,la=Pa*He,Si="http://localhost:9999",Ei="supabase.auth.token",Ni={"X-Client-Info":`gotrue-js/${Jn}`},Oa="X-Supabase-Api-Version",Zn={"2024-01-01":{timestamp:Date.parse("2024-01-01T00:00:00.0Z"),name:"2024-01-01"}},Ai=/^([a-z0-9_-]{4})*($|[a-z0-9_-]{3}$|[a-z0-9_-]{2}$)$/i,Pi=10*60*1e3;class gt extends Error{constructor(e,a,r){super(e),this.__isAuthError=!0,this.name="AuthError",this.status=a,this.code=r}}function P(t){return typeof t=="object"&&t!==null&&"__isAuthError"in t}class Oi extends gt{constructor(e,a,r){super(e,a,r),this.name="AuthApiError",this.status=a,this.code=r}}function Ii(t){return P(t)&&t.name==="AuthApiError"}class Pe extends gt{constructor(e,a){super(e),this.name="AuthUnknownError",this.originalError=a}}class xe extends gt{constructor(e,a,r,n){super(e,r,n),this.name=a,this.status=r}}class ve extends xe{constructor(){super("Auth session missing!","AuthSessionMissingError",400,void 0)}}function Ri(t){return P(t)&&t.name==="AuthSessionMissingError"}class Ue extends xe{constructor(){super("Auth session or user missing","AuthInvalidTokenResponseError",500,void 0)}}class Pt extends xe{constructor(e){super(e,"AuthInvalidCredentialsError",400,void 0)}}class Ot extends xe{constructor(e,a=null){super(e,"AuthImplicitGrantRedirectError",500,void 0),this.details=null,this.details=a}toJSON(){return{name:this.name,message:this.message,status:this.status,details:this.details}}}function Ci(t){return P(t)&&t.name==="AuthImplicitGrantRedirectError"}class Pr extends xe{constructor(e,a=null){super(e,"AuthPKCEGrantCodeExchangeError",500,void 0),this.details=null,this.details=a}toJSON(){return{name:this.name,message:this.message,status:this.status,details:this.details}}}class Ia extends xe{constructor(e,a){super(e,"AuthRetryableFetchError",a,void 0)}}function da(t){return P(t)&&t.name==="AuthRetryableFetchError"}class Or extends xe{constructor(e,a,r){super(e,"AuthWeakPasswordError",a,"weak_password"),this.reasons=r}}class Ra extends xe{constructor(e){super(e,"AuthInvalidJwtError",400,"invalid_jwt")}}const Ut="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_".split(""),Ir=` 	
\r=`.split(""),$i=(()=>{const t=new Array(128);for(let e=0;e<t.length;e+=1)t[e]=-1;for(let e=0;e<Ir.length;e+=1)t[Ir[e].charCodeAt(0)]=-2;for(let e=0;e<Ut.length;e+=1)t[Ut[e].charCodeAt(0)]=e;return t})();function Rr(t,e,a){if(t!==null)for(e.queue=e.queue<<8|t,e.queuedBits+=8;e.queuedBits>=6;){const r=e.queue>>e.queuedBits-6&63;a(Ut[r]),e.queuedBits-=6}else if(e.queuedBits>0)for(e.queue=e.queue<<6-e.queuedBits,e.queuedBits=6;e.queuedBits>=6;){const r=e.queue>>e.queuedBits-6&63;a(Ut[r]),e.queuedBits-=6}}function Qn(t,e,a){const r=$i[t];if(r>-1)for(e.queue=e.queue<<6|r,e.queuedBits+=6;e.queuedBits>=8;)a(e.queue>>e.queuedBits-8&255),e.queuedBits-=8;else{if(r===-2)return;throw new Error(`Invalid Base64-URL character "${String.fromCharCode(t)}"`)}}function Cr(t){const e=[],a=i=>{e.push(String.fromCodePoint(i))},r={utf8seq:0,codepoint:0},n={queue:0,queuedBits:0},s=i=>{Ui(i,r,a)};for(let i=0;i<t.length;i+=1)Qn(t.charCodeAt(i),n,s);return e.join("")}function Di(t,e){if(t<=127){e(t);return}else if(t<=2047){e(192|t>>6),e(128|t&63);return}else if(t<=65535){e(224|t>>12),e(128|t>>6&63),e(128|t&63);return}else if(t<=1114111){e(240|t>>18),e(128|t>>12&63),e(128|t>>6&63),e(128|t&63);return}throw new Error(`Unrecognized Unicode codepoint: ${t.toString(16)}`)}function Li(t,e){for(let a=0;a<t.length;a+=1){let r=t.charCodeAt(a);if(r>55295&&r<=56319){const n=(r-55296)*1024&65535;r=(t.charCodeAt(a+1)-56320&65535|n)+65536,a+=1}Di(r,e)}}function Ui(t,e,a){if(e.utf8seq===0){if(t<=127){a(t);return}for(let r=1;r<6;r+=1)if(!(t>>7-r&1)){e.utf8seq=r;break}if(e.utf8seq===2)e.codepoint=t&31;else if(e.utf8seq===3)e.codepoint=t&15;else if(e.utf8seq===4)e.codepoint=t&7;else throw new Error("Invalid UTF-8 sequence");e.utf8seq-=1}else if(e.utf8seq>0){if(t<=127)throw new Error("Invalid UTF-8 sequence");e.codepoint=e.codepoint<<6|t&63,e.utf8seq-=1,e.utf8seq===0&&a(e.codepoint)}}function Ve(t){const e=[],a={queue:0,queuedBits:0},r=n=>{e.push(n)};for(let n=0;n<t.length;n+=1)Qn(t.charCodeAt(n),a,r);return new Uint8Array(e)}function Mi(t){const e=[];return Li(t,a=>e.push(a)),new Uint8Array(e)}function Oe(t){const e=[],a={queue:0,queuedBits:0},r=n=>{e.push(n)};return t.forEach(n=>Rr(n,a,r)),Rr(null,a,r),e.join("")}function Bi(t){return Math.round(Date.now()/1e3)+t}function Fi(){return"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,function(t){const e=Math.random()*16|0;return(t=="x"?e:e&3|8).toString(16)})}const J=()=>typeof window<"u"&&typeof document<"u",_e={tested:!1,writable:!1},Xn=()=>{if(!J())return!1;try{if(typeof globalThis.localStorage!="object")return!1}catch{return!1}if(_e.tested)return _e.writable;const t=`lswt-${Math.random()}${Math.random()}`;try{globalThis.localStorage.setItem(t,t),globalThis.localStorage.removeItem(t),_e.tested=!0,_e.writable=!0}catch{_e.tested=!0,_e.writable=!1}return _e.writable};function Wi(t){const e={},a=new URL(t);if(a.hash&&a.hash[0]==="#")try{new URLSearchParams(a.hash.substring(1)).forEach((n,s)=>{e[s]=n})}catch{}return a.searchParams.forEach((r,n)=>{e[n]=r}),e}const es=t=>{let e;return t?e=t:typeof fetch>"u"?e=(...a)=>de(async()=>{const{default:r}=await Promise.resolve().then(()=>$e);return{default:r}},void 0).then(({default:r})=>r(...a)):e=fetch,(...a)=>e(...a)},Hi=t=>typeof t=="object"&&t!==null&&"status"in t&&"ok"in t&&"json"in t&&typeof t.json=="function",qe=async(t,e,a)=>{await t.setItem(e,JSON.stringify(a))},je=async(t,e)=>{const a=await t.getItem(e);if(!a)return null;try{return JSON.parse(a)}catch{return a}},fe=async(t,e)=>{await t.removeItem(e)};class Jt{constructor(){this.promise=new Jt.promiseConstructor((e,a)=>{this.resolve=e,this.reject=a})}}Jt.promiseConstructor=Promise;function ca(t){const e=t.split(".");if(e.length!==3)throw new Ra("Invalid JWT structure");for(let r=0;r<e.length;r++)if(!Ai.test(e[r]))throw new Ra("JWT not in base64url format");return{header:JSON.parse(Cr(e[0])),payload:JSON.parse(Cr(e[1])),signature:Ve(e[2]),raw:{header:e[0],payload:e[1]}}}async function qi(t){return await new Promise(e=>{setTimeout(()=>e(null),t)})}function Gi(t,e){return new Promise((r,n)=>{(async()=>{for(let s=0;s<1/0;s++)try{const i=await t(s);if(!e(s,null,i)){r(i);return}}catch(i){if(!e(s,i)){n(i);return}}})()})}function zi(t){return("0"+t.toString(16)).substr(-2)}function Ki(){const e=new Uint32Array(56);if(typeof crypto>"u"){const a="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-._~",r=a.length;let n="";for(let s=0;s<56;s++)n+=a.charAt(Math.floor(Math.random()*r));return n}return crypto.getRandomValues(e),Array.from(e,zi).join("")}async function Vi(t){const a=new TextEncoder().encode(t),r=await crypto.subtle.digest("SHA-256",a),n=new Uint8Array(r);return Array.from(n).map(s=>String.fromCharCode(s)).join("")}async function Yi(t){if(!(typeof crypto<"u"&&typeof crypto.subtle<"u"&&typeof TextEncoder<"u"))return console.warn("WebCrypto API is not supported. Code challenge method will default to use plain instead of sha256."),t;const a=await Vi(t);return btoa(a).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,"")}async function Me(t,e,a=!1){const r=Ki();let n=r;a&&(n+="/PASSWORD_RECOVERY"),await qe(t,`${e}-code-verifier`,n);const s=await Yi(r);return[s,r===s?"plain":"s256"]}const Ji=/^2[0-9]{3}-(0[1-9]|1[0-2])-(0[1-9]|1[0-9]|2[0-9]|3[0-1])$/i;function Zi(t){const e=t.headers.get(Oa);if(!e||!e.match(Ji))return null;try{return new Date(`${e}T00:00:00.0Z`)}catch{return null}}function Qi(t){if(!t)throw new Error("Missing exp claim");const e=Math.floor(Date.now()/1e3);if(t<=e)throw new Error("JWT has expired")}function Xi(t){switch(t){case"RS256":return{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}};case"ES256":return{name:"ECDSA",namedCurve:"P-256",hash:{name:"SHA-256"}};default:throw new Error("Invalid alg claim")}}const el=/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/;function Be(t){if(!el.test(t))throw new Error("@supabase/auth-js: Expected parameter to be UUID but is not")}function ua(){const t={};return new Proxy(t,{get:(e,a)=>{if(a==="__isUserNotAvailableProxy")return!0;if(typeof a=="symbol"){const r=a.toString();if(r==="Symbol(Symbol.toPrimitive)"||r==="Symbol(Symbol.toStringTag)"||r==="Symbol(util.inspect.custom)")return}throw new Error(`@supabase/auth-js: client was created with userStorage option and there was no user stored in the user storage. Accessing the "${a}" property of the session object is not supported. Please use getUser() instead.`)},set:(e,a)=>{throw new Error(`@supabase/auth-js: client was created with userStorage option and there was no user stored in the user storage. Setting the "${a}" property of the session object is not supported. Please use getUser() to fetch a user object you can manipulate.`)},deleteProperty:(e,a)=>{throw new Error(`@supabase/auth-js: client was created with userStorage option and there was no user stored in the user storage. Deleting the "${a}" property of the session object is not supported. Please use getUser() to fetch a user object you can manipulate.`)}})}function $r(t){return JSON.parse(JSON.stringify(t))}const Ee=t=>t.msg||t.message||t.error_description||t.error||JSON.stringify(t),tl=[502,503,504];async function Dr(t){var e;if(!Hi(t))throw new Ia(Ee(t),0);if(tl.includes(t.status))throw new Ia(Ee(t),t.status);let a;try{a=await t.json()}catch(s){throw new Pe(Ee(s),s)}let r;const n=Zi(t);if(n&&n.getTime()>=Zn["2024-01-01"].timestamp&&typeof a=="object"&&a&&typeof a.code=="string"?r=a.code:typeof a=="object"&&a&&typeof a.error_code=="string"&&(r=a.error_code),r){if(r==="weak_password")throw new Or(Ee(a),t.status,((e=a.weak_password)===null||e===void 0?void 0:e.reasons)||[]);if(r==="session_not_found")throw new ve}else if(typeof a=="object"&&a&&typeof a.weak_password=="object"&&a.weak_password&&Array.isArray(a.weak_password.reasons)&&a.weak_password.reasons.length&&a.weak_password.reasons.reduce((s,i)=>s&&typeof i=="string",!0))throw new Or(Ee(a),t.status,a.weak_password.reasons);throw new Oi(Ee(a),t.status||500,r)}const al=(t,e,a,r)=>{const n={method:t,headers:(e==null?void 0:e.headers)||{}};return t==="GET"?n:(n.headers=Object.assign({"Content-Type":"application/json;charset=UTF-8"},e==null?void 0:e.headers),n.body=JSON.stringify(r),Object.assign(Object.assign({},n),a))};async function O(t,e,a,r){var n;const s=Object.assign({},r==null?void 0:r.headers);s[Oa]||(s[Oa]=Zn["2024-01-01"].name),r!=null&&r.jwt&&(s.Authorization=`Bearer ${r.jwt}`);const i=(n=r==null?void 0:r.query)!==null&&n!==void 0?n:{};r!=null&&r.redirectTo&&(i.redirect_to=r.redirectTo);const l=Object.keys(i).length?"?"+new URLSearchParams(i).toString():"",c=await rl(t,e,a+l,{headers:s,noResolveJson:r==null?void 0:r.noResolveJson},{},r==null?void 0:r.body);return r!=null&&r.xform?r==null?void 0:r.xform(c):{data:Object.assign({},c),error:null}}async function rl(t,e,a,r,n,s){const i=al(e,r,n,s);let l;try{l=await t(a,Object.assign({},i))}catch(c){throw console.error(c),new Ia(Ee(c),0)}if(l.ok||await Dr(l),r!=null&&r.noResolveJson)return l;try{return await l.json()}catch(c){await Dr(c)}}function re(t){var e;let a=null;ol(t)&&(a=Object.assign({},t),t.expires_at||(a.expires_at=Bi(t.expires_in)));const r=(e=t.user)!==null&&e!==void 0?e:t;return{data:{session:a,user:r},error:null}}function Lr(t){const e=re(t);return!e.error&&t.weak_password&&typeof t.weak_password=="object"&&Array.isArray(t.weak_password.reasons)&&t.weak_password.reasons.length&&t.weak_password.message&&typeof t.weak_password.message=="string"&&t.weak_password.reasons.reduce((a,r)=>a&&typeof r=="string",!0)&&(e.data.weak_password=t.weak_password),e}function be(t){var e;return{data:{user:(e=t.user)!==null&&e!==void 0?e:t},error:null}}function nl(t){return{data:t,error:null}}function sl(t){const{action_link:e,email_otp:a,hashed_token:r,redirect_to:n,verification_type:s}=t,i=Xe(t,["action_link","email_otp","hashed_token","redirect_to","verification_type"]),l={action_link:e,email_otp:a,hashed_token:r,redirect_to:n,verification_type:s},c=Object.assign({},i);return{data:{properties:l,user:c},error:null}}function Ur(t){return t}function ol(t){return t.access_token&&t.refresh_token&&t.expires_in}const ha=["global","local","others"];class il{constructor({url:e="",headers:a={},fetch:r}){this.url=e,this.headers=a,this.fetch=es(r),this.mfa={listFactors:this._listFactors.bind(this),deleteFactor:this._deleteFactor.bind(this)},this.oauth={listClients:this._listOAuthClients.bind(this),createClient:this._createOAuthClient.bind(this),getClient:this._getOAuthClient.bind(this),deleteClient:this._deleteOAuthClient.bind(this),regenerateClientSecret:this._regenerateOAuthClientSecret.bind(this)}}async signOut(e,a=ha[0]){if(ha.indexOf(a)<0)throw new Error(`@supabase/auth-js: Parameter scope must be one of ${ha.join(", ")}`);try{return await O(this.fetch,"POST",`${this.url}/logout?scope=${a}`,{headers:this.headers,jwt:e,noResolveJson:!0}),{data:null,error:null}}catch(r){if(P(r))return{data:null,error:r};throw r}}async inviteUserByEmail(e,a={}){try{return await O(this.fetch,"POST",`${this.url}/invite`,{body:{email:e,data:a.data},headers:this.headers,redirectTo:a.redirectTo,xform:be})}catch(r){if(P(r))return{data:{user:null},error:r};throw r}}async generateLink(e){try{const{options:a}=e,r=Xe(e,["options"]),n=Object.assign(Object.assign({},r),a);return"newEmail"in r&&(n.new_email=r==null?void 0:r.newEmail,delete n.newEmail),await O(this.fetch,"POST",`${this.url}/admin/generate_link`,{body:n,headers:this.headers,xform:sl,redirectTo:a==null?void 0:a.redirectTo})}catch(a){if(P(a))return{data:{properties:null,user:null},error:a};throw a}}async createUser(e){try{return await O(this.fetch,"POST",`${this.url}/admin/users`,{body:e,headers:this.headers,xform:be})}catch(a){if(P(a))return{data:{user:null},error:a};throw a}}async listUsers(e){var a,r,n,s,i,l,c;try{const d={nextPage:null,lastPage:0,total:0},u=await O(this.fetch,"GET",`${this.url}/admin/users`,{headers:this.headers,noResolveJson:!0,query:{page:(r=(a=e==null?void 0:e.page)===null||a===void 0?void 0:a.toString())!==null&&r!==void 0?r:"",per_page:(s=(n=e==null?void 0:e.perPage)===null||n===void 0?void 0:n.toString())!==null&&s!==void 0?s:""},xform:Ur});if(u.error)throw u.error;const h=await u.json(),p=(i=u.headers.get("x-total-count"))!==null&&i!==void 0?i:0,y=(c=(l=u.headers.get("link"))===null||l===void 0?void 0:l.split(","))!==null&&c!==void 0?c:[];return y.length>0&&(y.forEach(m=>{const f=parseInt(m.split(";")[0].split("=")[1].substring(0,1)),g=JSON.parse(m.split(";")[1].split("=")[1]);d[`${g}Page`]=f}),d.total=parseInt(p)),{data:Object.assign(Object.assign({},h),d),error:null}}catch(d){if(P(d))return{data:{users:[]},error:d};throw d}}async getUserById(e){Be(e);try{return await O(this.fetch,"GET",`${this.url}/admin/users/${e}`,{headers:this.headers,xform:be})}catch(a){if(P(a))return{data:{user:null},error:a};throw a}}async updateUserById(e,a){Be(e);try{return await O(this.fetch,"PUT",`${this.url}/admin/users/${e}`,{body:a,headers:this.headers,xform:be})}catch(r){if(P(r))return{data:{user:null},error:r};throw r}}async deleteUser(e,a=!1){Be(e);try{return await O(this.fetch,"DELETE",`${this.url}/admin/users/${e}`,{headers:this.headers,body:{should_soft_delete:a},xform:be})}catch(r){if(P(r))return{data:{user:null},error:r};throw r}}async _listFactors(e){Be(e.userId);try{const{data:a,error:r}=await O(this.fetch,"GET",`${this.url}/admin/users/${e.userId}/factors`,{headers:this.headers,xform:n=>({data:{factors:n},error:null})});return{data:a,error:r}}catch(a){if(P(a))return{data:null,error:a};throw a}}async _deleteFactor(e){Be(e.userId),Be(e.id);try{return{data:await O(this.fetch,"DELETE",`${this.url}/admin/users/${e.userId}/factors/${e.id}`,{headers:this.headers}),error:null}}catch(a){if(P(a))return{data:null,error:a};throw a}}async _listOAuthClients(e){var a,r,n,s,i,l,c;try{const d={nextPage:null,lastPage:0,total:0},u=await O(this.fetch,"GET",`${this.url}/admin/oauth/clients`,{headers:this.headers,noResolveJson:!0,query:{page:(r=(a=e==null?void 0:e.page)===null||a===void 0?void 0:a.toString())!==null&&r!==void 0?r:"",per_page:(s=(n=e==null?void 0:e.perPage)===null||n===void 0?void 0:n.toString())!==null&&s!==void 0?s:""},xform:Ur});if(u.error)throw u.error;const h=await u.json(),p=(i=u.headers.get("x-total-count"))!==null&&i!==void 0?i:0,y=(c=(l=u.headers.get("link"))===null||l===void 0?void 0:l.split(","))!==null&&c!==void 0?c:[];return y.length>0&&(y.forEach(m=>{const f=parseInt(m.split(";")[0].split("=")[1].substring(0,1)),g=JSON.parse(m.split(";")[1].split("=")[1]);d[`${g}Page`]=f}),d.total=parseInt(p)),{data:Object.assign(Object.assign({},h),d),error:null}}catch(d){if(P(d))return{data:{clients:[]},error:d};throw d}}async _createOAuthClient(e){try{return await O(this.fetch,"POST",`${this.url}/admin/oauth/clients`,{body:e,headers:this.headers,xform:a=>({data:a,error:null})})}catch(a){if(P(a))return{data:null,error:a};throw a}}async _getOAuthClient(e){try{return await O(this.fetch,"GET",`${this.url}/admin/oauth/clients/${e}`,{headers:this.headers,xform:a=>({data:a,error:null})})}catch(a){if(P(a))return{data:null,error:a};throw a}}async _deleteOAuthClient(e){try{return await O(this.fetch,"DELETE",`${this.url}/admin/oauth/clients/${e}`,{headers:this.headers,xform:a=>({data:a,error:null})})}catch(a){if(P(a))return{data:null,error:a};throw a}}async _regenerateOAuthClientSecret(e){try{return await O(this.fetch,"POST",`${this.url}/admin/oauth/clients/${e}/regenerate_secret`,{headers:this.headers,xform:a=>({data:a,error:null})})}catch(a){if(P(a))return{data:null,error:a};throw a}}}function Mr(t={}){return{getItem:e=>t[e]||null,setItem:(e,a)=>{t[e]=a},removeItem:e=>{delete t[e]}}}const Fe={debug:!!(globalThis&&Xn()&&globalThis.localStorage&&globalThis.localStorage.getItem("supabase.gotrue-js.locks.debug")==="true")};class ts extends Error{constructor(e){super(e),this.isAcquireTimeout=!0}}class ll extends ts{}async function dl(t,e,a){Fe.debug&&console.log("@supabase/gotrue-js: navigatorLock: acquire lock",t,e);const r=new globalThis.AbortController;return e>0&&setTimeout(()=>{r.abort(),Fe.debug&&console.log("@supabase/gotrue-js: navigatorLock acquire timed out",t)},e),await Promise.resolve().then(()=>globalThis.navigator.locks.request(t,e===0?{mode:"exclusive",ifAvailable:!0}:{mode:"exclusive",signal:r.signal},async n=>{if(n){Fe.debug&&console.log("@supabase/gotrue-js: navigatorLock: acquired",t,n.name);try{return await a()}finally{Fe.debug&&console.log("@supabase/gotrue-js: navigatorLock: released",t,n.name)}}else{if(e===0)throw Fe.debug&&console.log("@supabase/gotrue-js: navigatorLock: not immediately available",t),new ll(`Acquiring an exclusive Navigator LockManager lock "${t}" immediately failed`);if(Fe.debug)try{const s=await globalThis.navigator.locks.query();console.log("@supabase/gotrue-js: Navigator LockManager state",JSON.stringify(s,null,"  "))}catch(s){console.warn("@supabase/gotrue-js: Error when querying Navigator LockManager state",s)}return console.warn("@supabase/gotrue-js: Navigator LockManager returned a null lock when using #request without ifAvailable set to true, it appears this browser is not following the LockManager spec https://developer.mozilla.org/en-US/docs/Web/API/LockManager/request"),await a()}}))}function cl(){if(typeof globalThis!="object")try{Object.defineProperty(Object.prototype,"__magic__",{get:function(){return this},configurable:!0}),__magic__.globalThis=__magic__,delete Object.prototype.__magic__}catch{typeof self<"u"&&(self.globalThis=self)}}function as(t){if(!/^0x[a-fA-F0-9]{40}$/.test(t))throw new Error(`@supabase/auth-js: Address "${t}" is invalid.`);return t.toLowerCase()}function ul(t){return parseInt(t,16)}function hl(t){const e=new TextEncoder().encode(t);return"0x"+Array.from(e,r=>r.toString(16).padStart(2,"0")).join("")}function pl(t){var e;const{chainId:a,domain:r,expirationTime:n,issuedAt:s=new Date,nonce:i,notBefore:l,requestId:c,resources:d,scheme:u,uri:h,version:p}=t;{if(!Number.isInteger(a))throw new Error(`@supabase/auth-js: Invalid SIWE message field "chainId". Chain ID must be a EIP-155 chain ID. Provided value: ${a}`);if(!r)throw new Error('@supabase/auth-js: Invalid SIWE message field "domain". Domain must be provided.');if(i&&i.length<8)throw new Error(`@supabase/auth-js: Invalid SIWE message field "nonce". Nonce must be at least 8 characters. Provided value: ${i}`);if(!h)throw new Error('@supabase/auth-js: Invalid SIWE message field "uri". URI must be provided.');if(p!=="1")throw new Error(`@supabase/auth-js: Invalid SIWE message field "version". Version must be '1'. Provided value: ${p}`);if(!((e=t.statement)===null||e===void 0)&&e.includes(`
`))throw new Error(`@supabase/auth-js: Invalid SIWE message field "statement". Statement must not include '\\n'. Provided value: ${t.statement}`)}const y=as(t.address),m=u?`${u}://${r}`:r,f=t.statement?`${t.statement}
`:"",g=`${m} wants you to sign in with your Ethereum account:
${y}
${f}`;let v=`URI: ${h}
Version: ${p}
Chain ID: ${a}${i?`
Nonce: ${i}`:""}
Issued At: ${s.toISOString()}`;if(n&&(v+=`
Expiration Time: ${n.toISOString()}`),l&&(v+=`
Not Before: ${l.toISOString()}`),c&&(v+=`
Request ID: ${c}`),d){let x=`
Resources:`;for(const T of d){if(!T||typeof T!="string")throw new Error(`@supabase/auth-js: Invalid SIWE message field "resources". Every resource must be a valid string. Provided value: ${T}`);x+=`
- ${T}`}v+=x}return`${g}
${v}`}class W extends Error{constructor({message:e,code:a,cause:r,name:n}){var s;super(e,{cause:r}),this.__isWebAuthnError=!0,this.name=(s=n??(r instanceof Error?r.name:void 0))!==null&&s!==void 0?s:"Unknown Error",this.code=a}}class Mt extends W{constructor(e,a){super({code:"ERROR_PASSTHROUGH_SEE_CAUSE_PROPERTY",cause:a,message:e}),this.name="WebAuthnUnknownError",this.originalError=a}}function yl({error:t,options:e}){var a,r,n;const{publicKey:s}=e;if(!s)throw Error("options was missing required publicKey property");if(t.name==="AbortError"){if(e.signal instanceof AbortSignal)return new W({message:"Registration ceremony was sent an abort signal",code:"ERROR_CEREMONY_ABORTED",cause:t})}else if(t.name==="ConstraintError"){if(((a=s.authenticatorSelection)===null||a===void 0?void 0:a.requireResidentKey)===!0)return new W({message:"Discoverable credentials were required but no available authenticator supported it",code:"ERROR_AUTHENTICATOR_MISSING_DISCOVERABLE_CREDENTIAL_SUPPORT",cause:t});if(e.mediation==="conditional"&&((r=s.authenticatorSelection)===null||r===void 0?void 0:r.userVerification)==="required")return new W({message:"User verification was required during automatic registration but it could not be performed",code:"ERROR_AUTO_REGISTER_USER_VERIFICATION_FAILURE",cause:t});if(((n=s.authenticatorSelection)===null||n===void 0?void 0:n.userVerification)==="required")return new W({message:"User verification was required but no available authenticator supported it",code:"ERROR_AUTHENTICATOR_MISSING_USER_VERIFICATION_SUPPORT",cause:t})}else{if(t.name==="InvalidStateError")return new W({message:"The authenticator was previously registered",code:"ERROR_AUTHENTICATOR_PREVIOUSLY_REGISTERED",cause:t});if(t.name==="NotAllowedError")return new W({message:t.message,code:"ERROR_PASSTHROUGH_SEE_CAUSE_PROPERTY",cause:t});if(t.name==="NotSupportedError")return s.pubKeyCredParams.filter(l=>l.type==="public-key").length===0?new W({message:'No entry in pubKeyCredParams was of type "public-key"',code:"ERROR_MALFORMED_PUBKEYCREDPARAMS",cause:t}):new W({message:"No available authenticator supported any of the specified pubKeyCredParams algorithms",code:"ERROR_AUTHENTICATOR_NO_SUPPORTED_PUBKEYCREDPARAMS_ALG",cause:t});if(t.name==="SecurityError"){const i=window.location.hostname;if(rs(i)){if(s.rp.id!==i)return new W({message:`The RP ID "${s.rp.id}" is invalid for this domain`,code:"ERROR_INVALID_RP_ID",cause:t})}else return new W({message:`${window.location.hostname} is an invalid domain`,code:"ERROR_INVALID_DOMAIN",cause:t})}else if(t.name==="TypeError"){if(s.user.id.byteLength<1||s.user.id.byteLength>64)return new W({message:"User ID was not between 1 and 64 characters",code:"ERROR_INVALID_USER_ID_LENGTH",cause:t})}else if(t.name==="UnknownError")return new W({message:"The authenticator was unable to process the specified options, or could not create a new credential",code:"ERROR_AUTHENTICATOR_GENERAL_ERROR",cause:t})}return new W({message:"a Non-Webauthn related error has occurred",code:"ERROR_PASSTHROUGH_SEE_CAUSE_PROPERTY",cause:t})}function ml({error:t,options:e}){const{publicKey:a}=e;if(!a)throw Error("options was missing required publicKey property");if(t.name==="AbortError"){if(e.signal instanceof AbortSignal)return new W({message:"Authentication ceremony was sent an abort signal",code:"ERROR_CEREMONY_ABORTED",cause:t})}else{if(t.name==="NotAllowedError")return new W({message:t.message,code:"ERROR_PASSTHROUGH_SEE_CAUSE_PROPERTY",cause:t});if(t.name==="SecurityError"){const r=window.location.hostname;if(rs(r)){if(a.rpId!==r)return new W({message:`The RP ID "${a.rpId}" is invalid for this domain`,code:"ERROR_INVALID_RP_ID",cause:t})}else return new W({message:`${window.location.hostname} is an invalid domain`,code:"ERROR_INVALID_DOMAIN",cause:t})}else if(t.name==="UnknownError")return new W({message:"The authenticator was unable to process the specified options, or could not create a new assertion signature",code:"ERROR_AUTHENTICATOR_GENERAL_ERROR",cause:t})}return new W({message:"a Non-Webauthn related error has occurred",code:"ERROR_PASSTHROUGH_SEE_CAUSE_PROPERTY",cause:t})}class fl{createNewAbortSignal(){if(this.controller){const a=new Error("Cancelling existing WebAuthn API call for new one");a.name="AbortError",this.controller.abort(a)}const e=new AbortController;return this.controller=e,e.signal}cancelCeremony(){if(this.controller){const e=new Error("Manually cancelling existing WebAuthn API call");e.name="AbortError",this.controller.abort(e),this.controller=void 0}}}const gl=new fl;function vl(t){if(!t)throw new Error("Credential creation options are required");if(typeof PublicKeyCredential<"u"&&"parseCreationOptionsFromJSON"in PublicKeyCredential&&typeof PublicKeyCredential.parseCreationOptionsFromJSON=="function")return PublicKeyCredential.parseCreationOptionsFromJSON(t);const{challenge:e,user:a,excludeCredentials:r}=t,n=Xe(t,["challenge","user","excludeCredentials"]),s=Ve(e).buffer,i=Object.assign(Object.assign({},a),{id:Ve(a.id).buffer}),l=Object.assign(Object.assign({},n),{challenge:s,user:i});if(r&&r.length>0){l.excludeCredentials=new Array(r.length);for(let c=0;c<r.length;c++){const d=r[c];l.excludeCredentials[c]=Object.assign(Object.assign({},d),{id:Ve(d.id).buffer,type:d.type||"public-key",transports:d.transports})}}return l}function bl(t){if(!t)throw new Error("Credential request options are required");if(typeof PublicKeyCredential<"u"&&"parseRequestOptionsFromJSON"in PublicKeyCredential&&typeof PublicKeyCredential.parseRequestOptionsFromJSON=="function")return PublicKeyCredential.parseRequestOptionsFromJSON(t);const{challenge:e,allowCredentials:a}=t,r=Xe(t,["challenge","allowCredentials"]),n=Ve(e).buffer,s=Object.assign(Object.assign({},r),{challenge:n});if(a&&a.length>0){s.allowCredentials=new Array(a.length);for(let i=0;i<a.length;i++){const l=a[i];s.allowCredentials[i]=Object.assign(Object.assign({},l),{id:Ve(l.id).buffer,type:l.type||"public-key",transports:l.transports})}}return s}function wl(t){var e;if("toJSON"in t&&typeof t.toJSON=="function")return t.toJSON();const a=t;return{id:t.id,rawId:t.id,response:{attestationObject:Oe(new Uint8Array(t.response.attestationObject)),clientDataJSON:Oe(new Uint8Array(t.response.clientDataJSON))},type:"public-key",clientExtensionResults:t.getClientExtensionResults(),authenticatorAttachment:(e=a.authenticatorAttachment)!==null&&e!==void 0?e:void 0}}function xl(t){var e;if("toJSON"in t&&typeof t.toJSON=="function")return t.toJSON();const a=t,r=t.getClientExtensionResults(),n=t.response;return{id:t.id,rawId:t.id,response:{authenticatorData:Oe(new Uint8Array(n.authenticatorData)),clientDataJSON:Oe(new Uint8Array(n.clientDataJSON)),signature:Oe(new Uint8Array(n.signature)),userHandle:n.userHandle?Oe(new Uint8Array(n.userHandle)):void 0},type:"public-key",clientExtensionResults:r,authenticatorAttachment:(e=a.authenticatorAttachment)!==null&&e!==void 0?e:void 0}}function rs(t){return t==="localhost"||/^([a-z0-9]+(-[a-z0-9]+)*\.)+[a-z]{2,}$/i.test(t)}function Br(){var t,e;return!!(J()&&"PublicKeyCredential"in window&&window.PublicKeyCredential&&"credentials"in navigator&&typeof((t=navigator==null?void 0:navigator.credentials)===null||t===void 0?void 0:t.create)=="function"&&typeof((e=navigator==null?void 0:navigator.credentials)===null||e===void 0?void 0:e.get)=="function")}async function Tl(t){try{const e=await navigator.credentials.create(t);return e?e instanceof PublicKeyCredential?{data:e,error:null}:{data:null,error:new Mt("Browser returned unexpected credential type",e)}:{data:null,error:new Mt("Empty credential response",e)}}catch(e){return{data:null,error:yl({error:e,options:t})}}}async function kl(t){try{const e=await navigator.credentials.get(t);return e?e instanceof PublicKeyCredential?{data:e,error:null}:{data:null,error:new Mt("Browser returned unexpected credential type",e)}:{data:null,error:new Mt("Empty credential response",e)}}catch(e){return{data:null,error:ml({error:e,options:t})}}}const _l={hints:["security-key"],authenticatorSelection:{authenticatorAttachment:"cross-platform",requireResidentKey:!1,userVerification:"preferred",residentKey:"discouraged"},attestation:"none"},jl={userVerification:"preferred",hints:["security-key"]};function Bt(...t){const e=n=>n!==null&&typeof n=="object"&&!Array.isArray(n),a=n=>n instanceof ArrayBuffer||ArrayBuffer.isView(n),r={};for(const n of t)if(n)for(const s in n){const i=n[s];if(i!==void 0)if(Array.isArray(i))r[s]=i;else if(a(i))r[s]=i;else if(e(i)){const l=r[s];e(l)?r[s]=Bt(l,i):r[s]=Bt(i)}else r[s]=i}return r}function Sl(t,e){return Bt(_l,t,e||{})}function El(t,e){return Bt(jl,t,e||{})}class Nl{constructor(e){this.client=e,this.enroll=this._enroll.bind(this),this.challenge=this._challenge.bind(this),this.verify=this._verify.bind(this),this.authenticate=this._authenticate.bind(this),this.register=this._register.bind(this)}async _enroll(e){return this.client.mfa.enroll(Object.assign(Object.assign({},e),{factorType:"webauthn"}))}async _challenge({factorId:e,webauthn:a,friendlyName:r,signal:n},s){try{const{data:i,error:l}=await this.client.mfa.challenge({factorId:e,webauthn:a});if(!i)return{data:null,error:l};const c=n??gl.createNewAbortSignal();if(i.webauthn.type==="create"){const{user:d}=i.webauthn.credential_options.publicKey;d.name||(d.name=`${d.id}:${r}`),d.displayName||(d.displayName=d.name)}switch(i.webauthn.type){case"create":{const d=Sl(i.webauthn.credential_options.publicKey,s==null?void 0:s.create),{data:u,error:h}=await Tl({publicKey:d,signal:c});return u?{data:{factorId:e,challengeId:i.id,webauthn:{type:i.webauthn.type,credential_response:u}},error:null}:{data:null,error:h}}case"request":{const d=El(i.webauthn.credential_options.publicKey,s==null?void 0:s.request),{data:u,error:h}=await kl(Object.assign(Object.assign({},i.webauthn.credential_options),{publicKey:d,signal:c}));return u?{data:{factorId:e,challengeId:i.id,webauthn:{type:i.webauthn.type,credential_response:u}},error:null}:{data:null,error:h}}}}catch(i){return P(i)?{data:null,error:i}:{data:null,error:new Pe("Unexpected error in challenge",i)}}}async _verify({challengeId:e,factorId:a,webauthn:r}){return this.client.mfa.verify({factorId:a,challengeId:e,webauthn:r})}async _authenticate({factorId:e,webauthn:{rpId:a=typeof window<"u"?window.location.hostname:void 0,rpOrigins:r=typeof window<"u"?[window.location.origin]:void 0,signal:n}},s){if(!a)return{data:null,error:new gt("rpId is required for WebAuthn authentication")};try{if(!Br())return{data:null,error:new Pe("Browser does not support WebAuthn",null)};const{data:i,error:l}=await this.challenge({factorId:e,webauthn:{rpId:a,rpOrigins:r},signal:n},{request:s});if(!i)return{data:null,error:l};const{webauthn:c}=i;return this._verify({factorId:e,challengeId:i.challengeId,webauthn:{type:c.type,rpId:a,rpOrigins:r,credential_response:c.credential_response}})}catch(i){return P(i)?{data:null,error:i}:{data:null,error:new Pe("Unexpected error in authenticate",i)}}}async _register({friendlyName:e,rpId:a=typeof window<"u"?window.location.hostname:void 0,rpOrigins:r=typeof window<"u"?[window.location.origin]:void 0,signal:n},s){if(!a)return{data:null,error:new gt("rpId is required for WebAuthn registration")};try{if(!Br())return{data:null,error:new Pe("Browser does not support WebAuthn",null)};const{data:i,error:l}=await this._enroll({friendlyName:e});if(!i)return await this.client.mfa.listFactors().then(u=>{var h;return(h=u.data)===null||h===void 0?void 0:h.all.find(p=>p.factor_type==="webauthn"&&p.friendly_name===e&&p.status!=="unverified")}).then(u=>u?this.client.mfa.unenroll({factorId:u==null?void 0:u.id}):void 0),{data:null,error:l};const{data:c,error:d}=await this._challenge({factorId:i.id,friendlyName:i.friendly_name,webauthn:{rpId:a,rpOrigins:r},signal:n},{create:s});return c?this._verify({factorId:i.id,challengeId:c.challengeId,webauthn:{rpId:a,rpOrigins:r,type:c.webauthn.type,credential_response:c.webauthn.credential_response}}):{data:null,error:d}}catch(i){return P(i)?{data:null,error:i}:{data:null,error:new Pe("Unexpected error in register",i)}}}}cl();const Al={url:Si,storageKey:Ei,autoRefreshToken:!0,persistSession:!0,detectSessionInUrl:!0,headers:Ni,flowType:"implicit",debug:!1,hasCustomAuthorizationHeader:!1};async function Fr(t,e,a){return await a()}const We={};class vt{get jwks(){var e,a;return(a=(e=We[this.storageKey])===null||e===void 0?void 0:e.jwks)!==null&&a!==void 0?a:{keys:[]}}set jwks(e){We[this.storageKey]=Object.assign(Object.assign({},We[this.storageKey]),{jwks:e})}get jwks_cached_at(){var e,a;return(a=(e=We[this.storageKey])===null||e===void 0?void 0:e.cachedAt)!==null&&a!==void 0?a:Number.MIN_SAFE_INTEGER}set jwks_cached_at(e){We[this.storageKey]=Object.assign(Object.assign({},We[this.storageKey]),{cachedAt:e})}constructor(e){var a,r;this.userStorage=null,this.memoryStorage=null,this.stateChangeEmitters=new Map,this.autoRefreshTicker=null,this.visibilityChangedCallback=null,this.refreshingDeferred=null,this.initializePromise=null,this.detectSessionInUrl=!0,this.hasCustomAuthorizationHeader=!1,this.suppressGetSessionWarning=!1,this.lockAcquired=!1,this.pendingInLock=[],this.broadcastChannel=null,this.logger=console.log,this.instanceID=vt.nextInstanceID,vt.nextInstanceID+=1,this.instanceID>0&&J()&&console.warn("Multiple GoTrueClient instances detected in the same browser context. It is not an error, but this should be avoided as it may produce undefined behavior when used concurrently under the same storage key.");const n=Object.assign(Object.assign({},Al),e);if(this.logDebugMessages=!!n.debug,typeof n.debug=="function"&&(this.logger=n.debug),this.persistSession=n.persistSession,this.storageKey=n.storageKey,this.autoRefreshToken=n.autoRefreshToken,this.admin=new il({url:n.url,headers:n.headers,fetch:n.fetch}),this.url=n.url,this.headers=n.headers,this.fetch=es(n.fetch),this.lock=n.lock||Fr,this.detectSessionInUrl=n.detectSessionInUrl,this.flowType=n.flowType,this.hasCustomAuthorizationHeader=n.hasCustomAuthorizationHeader,n.lock?this.lock=n.lock:J()&&(!((a=globalThis==null?void 0:globalThis.navigator)===null||a===void 0)&&a.locks)?this.lock=dl:this.lock=Fr,this.jwks||(this.jwks={keys:[]},this.jwks_cached_at=Number.MIN_SAFE_INTEGER),this.mfa={verify:this._verify.bind(this),enroll:this._enroll.bind(this),unenroll:this._unenroll.bind(this),challenge:this._challenge.bind(this),listFactors:this._listFactors.bind(this),challengeAndVerify:this._challengeAndVerify.bind(this),getAuthenticatorAssuranceLevel:this._getAuthenticatorAssuranceLevel.bind(this),webauthn:new Nl(this)},this.persistSession?(n.storage?this.storage=n.storage:Xn()?this.storage=globalThis.localStorage:(this.memoryStorage={},this.storage=Mr(this.memoryStorage)),n.userStorage&&(this.userStorage=n.userStorage)):(this.memoryStorage={},this.storage=Mr(this.memoryStorage)),J()&&globalThis.BroadcastChannel&&this.persistSession&&this.storageKey){try{this.broadcastChannel=new globalThis.BroadcastChannel(this.storageKey)}catch(s){console.error("Failed to create a new BroadcastChannel, multi-tab state changes will not be available",s)}(r=this.broadcastChannel)===null||r===void 0||r.addEventListener("message",async s=>{this._debug("received broadcast notification from other tab or client",s),await this._notifyAllSubscribers(s.data.event,s.data.session,!1)})}this.initialize()}_debug(...e){return this.logDebugMessages&&this.logger(`GoTrueClient@${this.instanceID} (${Jn}) ${new Date().toISOString()}`,...e),this}async initialize(){return this.initializePromise?await this.initializePromise:(this.initializePromise=(async()=>await this._acquireLock(-1,async()=>await this._initialize()))(),await this.initializePromise)}async _initialize(){var e;try{const a=Wi(window.location.href);let r="none";if(this._isImplicitGrantCallback(a)?r="implicit":await this._isPKCECallback(a)&&(r="pkce"),J()&&this.detectSessionInUrl&&r!=="none"){const{data:n,error:s}=await this._getSessionFromURL(a,r);if(s){if(this._debug("#_initialize()","error detecting session from URL",s),Ci(s)){const c=(e=s.details)===null||e===void 0?void 0:e.code;if(c==="identity_already_exists"||c==="identity_not_found"||c==="single_identity_not_deletable")return{error:s}}return await this._removeSession(),{error:s}}const{session:i,redirectType:l}=n;return this._debug("#_initialize()","detected session in URL",i,"redirect type",l),await this._saveSession(i),setTimeout(async()=>{l==="recovery"?await this._notifyAllSubscribers("PASSWORD_RECOVERY",i):await this._notifyAllSubscribers("SIGNED_IN",i)},0),{error:null}}return await this._recoverAndRefresh(),{error:null}}catch(a){return P(a)?{error:a}:{error:new Pe("Unexpected error during initialization",a)}}finally{await this._handleVisibilityChange(),this._debug("#_initialize()","end")}}async signInAnonymously(e){var a,r,n;try{const s=await O(this.fetch,"POST",`${this.url}/signup`,{headers:this.headers,body:{data:(r=(a=e==null?void 0:e.options)===null||a===void 0?void 0:a.data)!==null&&r!==void 0?r:{},gotrue_meta_security:{captcha_token:(n=e==null?void 0:e.options)===null||n===void 0?void 0:n.captchaToken}},xform:re}),{data:i,error:l}=s;if(l||!i)return{data:{user:null,session:null},error:l};const c=i.session,d=i.user;return i.session&&(await this._saveSession(i.session),await this._notifyAllSubscribers("SIGNED_IN",c)),{data:{user:d,session:c},error:null}}catch(s){if(P(s))return{data:{user:null,session:null},error:s};throw s}}async signUp(e){var a,r,n;try{let s;if("email"in e){const{email:u,password:h,options:p}=e;let y=null,m=null;this.flowType==="pkce"&&([y,m]=await Me(this.storage,this.storageKey)),s=await O(this.fetch,"POST",`${this.url}/signup`,{headers:this.headers,redirectTo:p==null?void 0:p.emailRedirectTo,body:{email:u,password:h,data:(a=p==null?void 0:p.data)!==null&&a!==void 0?a:{},gotrue_meta_security:{captcha_token:p==null?void 0:p.captchaToken},code_challenge:y,code_challenge_method:m},xform:re})}else if("phone"in e){const{phone:u,password:h,options:p}=e;s=await O(this.fetch,"POST",`${this.url}/signup`,{headers:this.headers,body:{phone:u,password:h,data:(r=p==null?void 0:p.data)!==null&&r!==void 0?r:{},channel:(n=p==null?void 0:p.channel)!==null&&n!==void 0?n:"sms",gotrue_meta_security:{captcha_token:p==null?void 0:p.captchaToken}},xform:re})}else throw new Pt("You must provide either an email or phone number and a password");const{data:i,error:l}=s;if(l||!i)return{data:{user:null,session:null},error:l};const c=i.session,d=i.user;return i.session&&(await this._saveSession(i.session),await this._notifyAllSubscribers("SIGNED_IN",c)),{data:{user:d,session:c},error:null}}catch(s){if(P(s))return{data:{user:null,session:null},error:s};throw s}}async signInWithPassword(e){try{let a;if("email"in e){const{email:s,password:i,options:l}=e;a=await O(this.fetch,"POST",`${this.url}/token?grant_type=password`,{headers:this.headers,body:{email:s,password:i,gotrue_meta_security:{captcha_token:l==null?void 0:l.captchaToken}},xform:Lr})}else if("phone"in e){const{phone:s,password:i,options:l}=e;a=await O(this.fetch,"POST",`${this.url}/token?grant_type=password`,{headers:this.headers,body:{phone:s,password:i,gotrue_meta_security:{captcha_token:l==null?void 0:l.captchaToken}},xform:Lr})}else throw new Pt("You must provide either an email or phone number and a password");const{data:r,error:n}=a;return n?{data:{user:null,session:null},error:n}:!r||!r.session||!r.user?{data:{user:null,session:null},error:new Ue}:(r.session&&(await this._saveSession(r.session),await this._notifyAllSubscribers("SIGNED_IN",r.session)),{data:Object.assign({user:r.user,session:r.session},r.weak_password?{weakPassword:r.weak_password}:null),error:n})}catch(a){if(P(a))return{data:{user:null,session:null},error:a};throw a}}async signInWithOAuth(e){var a,r,n,s;return await this._handleProviderSignIn(e.provider,{redirectTo:(a=e.options)===null||a===void 0?void 0:a.redirectTo,scopes:(r=e.options)===null||r===void 0?void 0:r.scopes,queryParams:(n=e.options)===null||n===void 0?void 0:n.queryParams,skipBrowserRedirect:(s=e.options)===null||s===void 0?void 0:s.skipBrowserRedirect})}async exchangeCodeForSession(e){return await this.initializePromise,this._acquireLock(-1,async()=>this._exchangeCodeForSession(e))}async signInWithWeb3(e){const{chain:a}=e;switch(a){case"ethereum":return await this.signInWithEthereum(e);case"solana":return await this.signInWithSolana(e);default:throw new Error(`@supabase/auth-js: Unsupported chain "${a}"`)}}async signInWithEthereum(e){var a,r,n,s,i,l,c,d,u,h,p;let y,m;if("message"in e)y=e.message,m=e.signature;else{const{chain:f,wallet:g,statement:v,options:x}=e;let T;if(J())if(typeof g=="object")T=g;else{const k=window;if("ethereum"in k&&typeof k.ethereum=="object"&&"request"in k.ethereum&&typeof k.ethereum.request=="function")T=k.ethereum;else throw new Error("@supabase/auth-js: No compatible Ethereum wallet interface on the window object (window.ethereum) detected. Make sure the user already has a wallet installed and connected for this app. Prefer passing the wallet interface object directly to signInWithWeb3({ chain: 'ethereum', wallet: resolvedUserWallet }) instead.")}else{if(typeof g!="object"||!(x!=null&&x.url))throw new Error("@supabase/auth-js: Both wallet and url must be specified in non-browser environments.");T=g}const j=new URL((a=x==null?void 0:x.url)!==null&&a!==void 0?a:window.location.href),A=await T.request({method:"eth_requestAccounts"}).then(k=>k).catch(()=>{throw new Error("@supabase/auth-js: Wallet method eth_requestAccounts is missing or invalid")});if(!A||A.length===0)throw new Error("@supabase/auth-js: No accounts available. Please ensure the wallet is connected.");const S=as(A[0]);let E=(r=x==null?void 0:x.signInWithEthereum)===null||r===void 0?void 0:r.chainId;if(!E){const k=await T.request({method:"eth_chainId"});E=ul(k)}const _={domain:j.host,address:S,statement:v,uri:j.href,version:"1",chainId:E,nonce:(n=x==null?void 0:x.signInWithEthereum)===null||n===void 0?void 0:n.nonce,issuedAt:(i=(s=x==null?void 0:x.signInWithEthereum)===null||s===void 0?void 0:s.issuedAt)!==null&&i!==void 0?i:new Date,expirationTime:(l=x==null?void 0:x.signInWithEthereum)===null||l===void 0?void 0:l.expirationTime,notBefore:(c=x==null?void 0:x.signInWithEthereum)===null||c===void 0?void 0:c.notBefore,requestId:(d=x==null?void 0:x.signInWithEthereum)===null||d===void 0?void 0:d.requestId,resources:(u=x==null?void 0:x.signInWithEthereum)===null||u===void 0?void 0:u.resources};y=pl(_),m=await T.request({method:"personal_sign",params:[hl(y),S]})}try{const{data:f,error:g}=await O(this.fetch,"POST",`${this.url}/token?grant_type=web3`,{headers:this.headers,body:Object.assign({chain:"ethereum",message:y,signature:m},!((h=e.options)===null||h===void 0)&&h.captchaToken?{gotrue_meta_security:{captcha_token:(p=e.options)===null||p===void 0?void 0:p.captchaToken}}:null),xform:re});if(g)throw g;return!f||!f.session||!f.user?{data:{user:null,session:null},error:new Ue}:(f.session&&(await this._saveSession(f.session),await this._notifyAllSubscribers("SIGNED_IN",f.session)),{data:Object.assign({},f),error:g})}catch(f){if(P(f))return{data:{user:null,session:null},error:f};throw f}}async signInWithSolana(e){var a,r,n,s,i,l,c,d,u,h,p,y;let m,f;if("message"in e)m=e.message,f=e.signature;else{const{chain:g,wallet:v,statement:x,options:T}=e;let j;if(J())if(typeof v=="object")j=v;else{const S=window;if("solana"in S&&typeof S.solana=="object"&&("signIn"in S.solana&&typeof S.solana.signIn=="function"||"signMessage"in S.solana&&typeof S.solana.signMessage=="function"))j=S.solana;else throw new Error("@supabase/auth-js: No compatible Solana wallet interface on the window object (window.solana) detected. Make sure the user already has a wallet installed and connected for this app. Prefer passing the wallet interface object directly to signInWithWeb3({ chain: 'solana', wallet: resolvedUserWallet }) instead.")}else{if(typeof v!="object"||!(T!=null&&T.url))throw new Error("@supabase/auth-js: Both wallet and url must be specified in non-browser environments.");j=v}const A=new URL((a=T==null?void 0:T.url)!==null&&a!==void 0?a:window.location.href);if("signIn"in j&&j.signIn){const S=await j.signIn(Object.assign(Object.assign(Object.assign({issuedAt:new Date().toISOString()},T==null?void 0:T.signInWithSolana),{version:"1",domain:A.host,uri:A.href}),x?{statement:x}:null));let E;if(Array.isArray(S)&&S[0]&&typeof S[0]=="object")E=S[0];else if(S&&typeof S=="object"&&"signedMessage"in S&&"signature"in S)E=S;else throw new Error("@supabase/auth-js: Wallet method signIn() returned unrecognized value");if("signedMessage"in E&&"signature"in E&&(typeof E.signedMessage=="string"||E.signedMessage instanceof Uint8Array)&&E.signature instanceof Uint8Array)m=typeof E.signedMessage=="string"?E.signedMessage:new TextDecoder().decode(E.signedMessage),f=E.signature;else throw new Error("@supabase/auth-js: Wallet method signIn() API returned object without signedMessage and signature fields")}else{if(!("signMessage"in j)||typeof j.signMessage!="function"||!("publicKey"in j)||typeof j!="object"||!j.publicKey||!("toBase58"in j.publicKey)||typeof j.publicKey.toBase58!="function")throw new Error("@supabase/auth-js: Wallet does not have a compatible signMessage() and publicKey.toBase58() API");m=[`${A.host} wants you to sign in with your Solana account:`,j.publicKey.toBase58(),...x?["",x,""]:[""],"Version: 1",`URI: ${A.href}`,`Issued At: ${(n=(r=T==null?void 0:T.signInWithSolana)===null||r===void 0?void 0:r.issuedAt)!==null&&n!==void 0?n:new Date().toISOString()}`,...!((s=T==null?void 0:T.signInWithSolana)===null||s===void 0)&&s.notBefore?[`Not Before: ${T.signInWithSolana.notBefore}`]:[],...!((i=T==null?void 0:T.signInWithSolana)===null||i===void 0)&&i.expirationTime?[`Expiration Time: ${T.signInWithSolana.expirationTime}`]:[],...!((l=T==null?void 0:T.signInWithSolana)===null||l===void 0)&&l.chainId?[`Chain ID: ${T.signInWithSolana.chainId}`]:[],...!((c=T==null?void 0:T.signInWithSolana)===null||c===void 0)&&c.nonce?[`Nonce: ${T.signInWithSolana.nonce}`]:[],...!((d=T==null?void 0:T.signInWithSolana)===null||d===void 0)&&d.requestId?[`Request ID: ${T.signInWithSolana.requestId}`]:[],...!((h=(u=T==null?void 0:T.signInWithSolana)===null||u===void 0?void 0:u.resources)===null||h===void 0)&&h.length?["Resources",...T.signInWithSolana.resources.map(E=>`- ${E}`)]:[]].join(`
`);const S=await j.signMessage(new TextEncoder().encode(m),"utf8");if(!S||!(S instanceof Uint8Array))throw new Error("@supabase/auth-js: Wallet signMessage() API returned an recognized value");f=S}}try{const{data:g,error:v}=await O(this.fetch,"POST",`${this.url}/token?grant_type=web3`,{headers:this.headers,body:Object.assign({chain:"solana",message:m,signature:Oe(f)},!((p=e.options)===null||p===void 0)&&p.captchaToken?{gotrue_meta_security:{captcha_token:(y=e.options)===null||y===void 0?void 0:y.captchaToken}}:null),xform:re});if(v)throw v;return!g||!g.session||!g.user?{data:{user:null,session:null},error:new Ue}:(g.session&&(await this._saveSession(g.session),await this._notifyAllSubscribers("SIGNED_IN",g.session)),{data:Object.assign({},g),error:v})}catch(g){if(P(g))return{data:{user:null,session:null},error:g};throw g}}async _exchangeCodeForSession(e){const a=await je(this.storage,`${this.storageKey}-code-verifier`),[r,n]=(a??"").split("/");try{const{data:s,error:i}=await O(this.fetch,"POST",`${this.url}/token?grant_type=pkce`,{headers:this.headers,body:{auth_code:e,code_verifier:r},xform:re});if(await fe(this.storage,`${this.storageKey}-code-verifier`),i)throw i;return!s||!s.session||!s.user?{data:{user:null,session:null,redirectType:null},error:new Ue}:(s.session&&(await this._saveSession(s.session),await this._notifyAllSubscribers("SIGNED_IN",s.session)),{data:Object.assign(Object.assign({},s),{redirectType:n??null}),error:i})}catch(s){if(P(s))return{data:{user:null,session:null,redirectType:null},error:s};throw s}}async signInWithIdToken(e){try{const{options:a,provider:r,token:n,access_token:s,nonce:i}=e,l=await O(this.fetch,"POST",`${this.url}/token?grant_type=id_token`,{headers:this.headers,body:{provider:r,id_token:n,access_token:s,nonce:i,gotrue_meta_security:{captcha_token:a==null?void 0:a.captchaToken}},xform:re}),{data:c,error:d}=l;return d?{data:{user:null,session:null},error:d}:!c||!c.session||!c.user?{data:{user:null,session:null},error:new Ue}:(c.session&&(await this._saveSession(c.session),await this._notifyAllSubscribers("SIGNED_IN",c.session)),{data:c,error:d})}catch(a){if(P(a))return{data:{user:null,session:null},error:a};throw a}}async signInWithOtp(e){var a,r,n,s,i;try{if("email"in e){const{email:l,options:c}=e;let d=null,u=null;this.flowType==="pkce"&&([d,u]=await Me(this.storage,this.storageKey));const{error:h}=await O(this.fetch,"POST",`${this.url}/otp`,{headers:this.headers,body:{email:l,data:(a=c==null?void 0:c.data)!==null&&a!==void 0?a:{},create_user:(r=c==null?void 0:c.shouldCreateUser)!==null&&r!==void 0?r:!0,gotrue_meta_security:{captcha_token:c==null?void 0:c.captchaToken},code_challenge:d,code_challenge_method:u},redirectTo:c==null?void 0:c.emailRedirectTo});return{data:{user:null,session:null},error:h}}if("phone"in e){const{phone:l,options:c}=e,{data:d,error:u}=await O(this.fetch,"POST",`${this.url}/otp`,{headers:this.headers,body:{phone:l,data:(n=c==null?void 0:c.data)!==null&&n!==void 0?n:{},create_user:(s=c==null?void 0:c.shouldCreateUser)!==null&&s!==void 0?s:!0,gotrue_meta_security:{captcha_token:c==null?void 0:c.captchaToken},channel:(i=c==null?void 0:c.channel)!==null&&i!==void 0?i:"sms"}});return{data:{user:null,session:null,messageId:d==null?void 0:d.message_id},error:u}}throw new Pt("You must provide either an email or phone number.")}catch(l){if(P(l))return{data:{user:null,session:null},error:l};throw l}}async verifyOtp(e){var a,r;try{let n,s;"options"in e&&(n=(a=e.options)===null||a===void 0?void 0:a.redirectTo,s=(r=e.options)===null||r===void 0?void 0:r.captchaToken);const{data:i,error:l}=await O(this.fetch,"POST",`${this.url}/verify`,{headers:this.headers,body:Object.assign(Object.assign({},e),{gotrue_meta_security:{captcha_token:s}}),redirectTo:n,xform:re});if(l)throw l;if(!i)throw new Error("An error occurred on token verification.");const c=i.session,d=i.user;return c!=null&&c.access_token&&(await this._saveSession(c),await this._notifyAllSubscribers(e.type=="recovery"?"PASSWORD_RECOVERY":"SIGNED_IN",c)),{data:{user:d,session:c},error:null}}catch(n){if(P(n))return{data:{user:null,session:null},error:n};throw n}}async signInWithSSO(e){var a,r,n;try{let s=null,i=null;return this.flowType==="pkce"&&([s,i]=await Me(this.storage,this.storageKey)),await O(this.fetch,"POST",`${this.url}/sso`,{body:Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({},"providerId"in e?{provider_id:e.providerId}:null),"domain"in e?{domain:e.domain}:null),{redirect_to:(r=(a=e.options)===null||a===void 0?void 0:a.redirectTo)!==null&&r!==void 0?r:void 0}),!((n=e==null?void 0:e.options)===null||n===void 0)&&n.captchaToken?{gotrue_meta_security:{captcha_token:e.options.captchaToken}}:null),{skip_http_redirect:!0,code_challenge:s,code_challenge_method:i}),headers:this.headers,xform:nl})}catch(s){if(P(s))return{data:null,error:s};throw s}}async reauthenticate(){return await this.initializePromise,await this._acquireLock(-1,async()=>await this._reauthenticate())}async _reauthenticate(){try{return await this._useSession(async e=>{const{data:{session:a},error:r}=e;if(r)throw r;if(!a)throw new ve;const{error:n}=await O(this.fetch,"GET",`${this.url}/reauthenticate`,{headers:this.headers,jwt:a.access_token});return{data:{user:null,session:null},error:n}})}catch(e){if(P(e))return{data:{user:null,session:null},error:e};throw e}}async resend(e){try{const a=`${this.url}/resend`;if("email"in e){const{email:r,type:n,options:s}=e,{error:i}=await O(this.fetch,"POST",a,{headers:this.headers,body:{email:r,type:n,gotrue_meta_security:{captcha_token:s==null?void 0:s.captchaToken}},redirectTo:s==null?void 0:s.emailRedirectTo});return{data:{user:null,session:null},error:i}}else if("phone"in e){const{phone:r,type:n,options:s}=e,{data:i,error:l}=await O(this.fetch,"POST",a,{headers:this.headers,body:{phone:r,type:n,gotrue_meta_security:{captcha_token:s==null?void 0:s.captchaToken}}});return{data:{user:null,session:null,messageId:i==null?void 0:i.message_id},error:l}}throw new Pt("You must provide either an email or phone number and a type")}catch(a){if(P(a))return{data:{user:null,session:null},error:a};throw a}}async getSession(){return await this.initializePromise,await this._acquireLock(-1,async()=>this._useSession(async a=>a))}async _acquireLock(e,a){this._debug("#_acquireLock","begin",e);try{if(this.lockAcquired){const r=this.pendingInLock.length?this.pendingInLock[this.pendingInLock.length-1]:Promise.resolve(),n=(async()=>(await r,await a()))();return this.pendingInLock.push((async()=>{try{await n}catch{}})()),n}return await this.lock(`lock:${this.storageKey}`,e,async()=>{this._debug("#_acquireLock","lock acquired for storage key",this.storageKey);try{this.lockAcquired=!0;const r=a();for(this.pendingInLock.push((async()=>{try{await r}catch{}})()),await r;this.pendingInLock.length;){const n=[...this.pendingInLock];await Promise.all(n),this.pendingInLock.splice(0,n.length)}return await r}finally{this._debug("#_acquireLock","lock released for storage key",this.storageKey),this.lockAcquired=!1}})}finally{this._debug("#_acquireLock","end")}}async _useSession(e){this._debug("#_useSession","begin");try{const a=await this.__loadSession();return await e(a)}finally{this._debug("#_useSession","end")}}async __loadSession(){this._debug("#__loadSession()","begin"),this.lockAcquired||this._debug("#__loadSession()","used outside of an acquired lock!",new Error().stack);try{let e=null;const a=await je(this.storage,this.storageKey);if(this._debug("#getSession()","session from storage",a),a!==null&&(this._isValidSession(a)?e=a:(this._debug("#getSession()","session from storage is not valid"),await this._removeSession())),!e)return{data:{session:null},error:null};const r=e.expires_at?e.expires_at*1e3-Date.now()<la:!1;if(this._debug("#__loadSession()",`session has${r?"":" not"} expired`,"expires_at",e.expires_at),!r){if(this.userStorage){const i=await je(this.userStorage,this.storageKey+"-user");i!=null&&i.user?e.user=i.user:e.user=ua()}if(this.storage.isServer&&e.user){let i=this.suppressGetSessionWarning;e=new Proxy(e,{get:(c,d,u)=>(!i&&d==="user"&&(console.warn("Using the user object as returned from supabase.auth.getSession() or from some supabase.auth.onAuthStateChange() events could be insecure! This value comes directly from the storage medium (usually cookies on the server) and may not be authentic. Use supabase.auth.getUser() instead which authenticates the data by contacting the Supabase Auth server."),i=!0,this.suppressGetSessionWarning=!0),Reflect.get(c,d,u))})}return{data:{session:e},error:null}}const{data:n,error:s}=await this._callRefreshToken(e.refresh_token);return s?{data:{session:null},error:s}:{data:{session:n},error:null}}finally{this._debug("#__loadSession()","end")}}async getUser(e){return e?await this._getUser(e):(await this.initializePromise,await this._acquireLock(-1,async()=>await this._getUser()))}async _getUser(e){try{return e?await O(this.fetch,"GET",`${this.url}/user`,{headers:this.headers,jwt:e,xform:be}):await this._useSession(async a=>{var r,n,s;const{data:i,error:l}=a;if(l)throw l;return!(!((r=i.session)===null||r===void 0)&&r.access_token)&&!this.hasCustomAuthorizationHeader?{data:{user:null},error:new ve}:await O(this.fetch,"GET",`${this.url}/user`,{headers:this.headers,jwt:(s=(n=i.session)===null||n===void 0?void 0:n.access_token)!==null&&s!==void 0?s:void 0,xform:be})})}catch(a){if(P(a))return Ri(a)&&(await this._removeSession(),await fe(this.storage,`${this.storageKey}-code-verifier`)),{data:{user:null},error:a};throw a}}async updateUser(e,a={}){return await this.initializePromise,await this._acquireLock(-1,async()=>await this._updateUser(e,a))}async _updateUser(e,a={}){try{return await this._useSession(async r=>{const{data:n,error:s}=r;if(s)throw s;if(!n.session)throw new ve;const i=n.session;let l=null,c=null;this.flowType==="pkce"&&e.email!=null&&([l,c]=await Me(this.storage,this.storageKey));const{data:d,error:u}=await O(this.fetch,"PUT",`${this.url}/user`,{headers:this.headers,redirectTo:a==null?void 0:a.emailRedirectTo,body:Object.assign(Object.assign({},e),{code_challenge:l,code_challenge_method:c}),jwt:i.access_token,xform:be});if(u)throw u;return i.user=d.user,await this._saveSession(i),await this._notifyAllSubscribers("USER_UPDATED",i),{data:{user:i.user},error:null}})}catch(r){if(P(r))return{data:{user:null},error:r};throw r}}async setSession(e){return await this.initializePromise,await this._acquireLock(-1,async()=>await this._setSession(e))}async _setSession(e){try{if(!e.access_token||!e.refresh_token)throw new ve;const a=Date.now()/1e3;let r=a,n=!0,s=null;const{payload:i}=ca(e.access_token);if(i.exp&&(r=i.exp,n=r<=a),n){const{data:l,error:c}=await this._callRefreshToken(e.refresh_token);if(c)return{data:{user:null,session:null},error:c};if(!l)return{data:{user:null,session:null},error:null};s=l}else{const{data:l,error:c}=await this._getUser(e.access_token);if(c)throw c;s={access_token:e.access_token,refresh_token:e.refresh_token,user:l.user,token_type:"bearer",expires_in:r-a,expires_at:r},await this._saveSession(s),await this._notifyAllSubscribers("SIGNED_IN",s)}return{data:{user:s.user,session:s},error:null}}catch(a){if(P(a))return{data:{session:null,user:null},error:a};throw a}}async refreshSession(e){return await this.initializePromise,await this._acquireLock(-1,async()=>await this._refreshSession(e))}async _refreshSession(e){try{return await this._useSession(async a=>{var r;if(!e){const{data:i,error:l}=a;if(l)throw l;e=(r=i.session)!==null&&r!==void 0?r:void 0}if(!(e!=null&&e.refresh_token))throw new ve;const{data:n,error:s}=await this._callRefreshToken(e.refresh_token);return s?{data:{user:null,session:null},error:s}:n?{data:{user:n.user,session:n},error:null}:{data:{user:null,session:null},error:null}})}catch(a){if(P(a))return{data:{user:null,session:null},error:a};throw a}}async _getSessionFromURL(e,a){try{if(!J())throw new Ot("No browser detected.");if(e.error||e.error_description||e.error_code)throw new Ot(e.error_description||"Error in URL with unspecified error_description",{error:e.error||"unspecified_error",code:e.error_code||"unspecified_code"});switch(a){case"implicit":if(this.flowType==="pkce")throw new Pr("Not a valid PKCE flow url.");break;case"pkce":if(this.flowType==="implicit")throw new Ot("Not a valid implicit grant flow url.");break;default:}if(a==="pkce"){if(this._debug("#_initialize()","begin","is PKCE flow",!0),!e.code)throw new Pr("No code detected.");const{data:x,error:T}=await this._exchangeCodeForSession(e.code);if(T)throw T;const j=new URL(window.location.href);return j.searchParams.delete("code"),window.history.replaceState(window.history.state,"",j.toString()),{data:{session:x.session,redirectType:null},error:null}}const{provider_token:r,provider_refresh_token:n,access_token:s,refresh_token:i,expires_in:l,expires_at:c,token_type:d}=e;if(!s||!l||!i||!d)throw new Ot("No session defined in URL");const u=Math.round(Date.now()/1e3),h=parseInt(l);let p=u+h;c&&(p=parseInt(c));const y=p-u;y*1e3<=He&&console.warn(`@supabase/gotrue-js: Session as retrieved from URL expires in ${y}s, should have been closer to ${h}s`);const m=p-h;u-m>=120?console.warn("@supabase/gotrue-js: Session as retrieved from URL was issued over 120s ago, URL could be stale",m,p,u):u-m<0&&console.warn("@supabase/gotrue-js: Session as retrieved from URL was issued in the future? Check the device clock for skew",m,p,u);const{data:f,error:g}=await this._getUser(s);if(g)throw g;const v={provider_token:r,provider_refresh_token:n,access_token:s,expires_in:h,expires_at:p,refresh_token:i,token_type:d,user:f.user};return window.location.hash="",this._debug("#_getSessionFromURL()","clearing window.location.hash"),{data:{session:v,redirectType:e.type},error:null}}catch(r){if(P(r))return{data:{session:null,redirectType:null},error:r};throw r}}_isImplicitGrantCallback(e){return!!(e.access_token||e.error_description)}async _isPKCECallback(e){const a=await je(this.storage,`${this.storageKey}-code-verifier`);return!!(e.code&&a)}async signOut(e={scope:"global"}){return await this.initializePromise,await this._acquireLock(-1,async()=>await this._signOut(e))}async _signOut({scope:e}={scope:"global"}){return await this._useSession(async a=>{var r;const{data:n,error:s}=a;if(s)return{error:s};const i=(r=n.session)===null||r===void 0?void 0:r.access_token;if(i){const{error:l}=await this.admin.signOut(i,e);if(l&&!(Ii(l)&&(l.status===404||l.status===401||l.status===403)))return{error:l}}return e!=="others"&&(await this._removeSession(),await fe(this.storage,`${this.storageKey}-code-verifier`)),{error:null}})}onAuthStateChange(e){const a=Fi(),r={id:a,callback:e,unsubscribe:()=>{this._debug("#unsubscribe()","state change callback with id removed",a),this.stateChangeEmitters.delete(a)}};return this._debug("#onAuthStateChange()","registered callback with id",a),this.stateChangeEmitters.set(a,r),(async()=>(await this.initializePromise,await this._acquireLock(-1,async()=>{this._emitInitialSession(a)})))(),{data:{subscription:r}}}async _emitInitialSession(e){return await this._useSession(async a=>{var r,n;try{const{data:{session:s},error:i}=a;if(i)throw i;await((r=this.stateChangeEmitters.get(e))===null||r===void 0?void 0:r.callback("INITIAL_SESSION",s)),this._debug("INITIAL_SESSION","callback id",e,"session",s)}catch(s){await((n=this.stateChangeEmitters.get(e))===null||n===void 0?void 0:n.callback("INITIAL_SESSION",null)),this._debug("INITIAL_SESSION","callback id",e,"error",s),console.error(s)}})}async resetPasswordForEmail(e,a={}){let r=null,n=null;this.flowType==="pkce"&&([r,n]=await Me(this.storage,this.storageKey,!0));try{return await O(this.fetch,"POST",`${this.url}/recover`,{body:{email:e,code_challenge:r,code_challenge_method:n,gotrue_meta_security:{captcha_token:a.captchaToken}},headers:this.headers,redirectTo:a.redirectTo})}catch(s){if(P(s))return{data:null,error:s};throw s}}async getUserIdentities(){var e;try{const{data:a,error:r}=await this.getUser();if(r)throw r;return{data:{identities:(e=a.user.identities)!==null&&e!==void 0?e:[]},error:null}}catch(a){if(P(a))return{data:null,error:a};throw a}}async linkIdentity(e){return"token"in e?this.linkIdentityIdToken(e):this.linkIdentityOAuth(e)}async linkIdentityOAuth(e){var a;try{const{data:r,error:n}=await this._useSession(async s=>{var i,l,c,d,u;const{data:h,error:p}=s;if(p)throw p;const y=await this._getUrlForProvider(`${this.url}/user/identities/authorize`,e.provider,{redirectTo:(i=e.options)===null||i===void 0?void 0:i.redirectTo,scopes:(l=e.options)===null||l===void 0?void 0:l.scopes,queryParams:(c=e.options)===null||c===void 0?void 0:c.queryParams,skipBrowserRedirect:!0});return await O(this.fetch,"GET",y,{headers:this.headers,jwt:(u=(d=h.session)===null||d===void 0?void 0:d.access_token)!==null&&u!==void 0?u:void 0})});if(n)throw n;return J()&&!(!((a=e.options)===null||a===void 0)&&a.skipBrowserRedirect)&&window.location.assign(r==null?void 0:r.url),{data:{provider:e.provider,url:r==null?void 0:r.url},error:null}}catch(r){if(P(r))return{data:{provider:e.provider,url:null},error:r};throw r}}async linkIdentityIdToken(e){return await this._useSession(async a=>{var r;try{const{error:n,data:{session:s}}=a;if(n)throw n;const{options:i,provider:l,token:c,access_token:d,nonce:u}=e,h=await O(this.fetch,"POST",`${this.url}/token?grant_type=id_token`,{headers:this.headers,jwt:(r=s==null?void 0:s.access_token)!==null&&r!==void 0?r:void 0,body:{provider:l,id_token:c,access_token:d,nonce:u,link_identity:!0,gotrue_meta_security:{captcha_token:i==null?void 0:i.captchaToken}},xform:re}),{data:p,error:y}=h;return y?{data:{user:null,session:null},error:y}:!p||!p.session||!p.user?{data:{user:null,session:null},error:new Ue}:(p.session&&(await this._saveSession(p.session),await this._notifyAllSubscribers("USER_UPDATED",p.session)),{data:p,error:y})}catch(n){if(P(n))return{data:{user:null,session:null},error:n};throw n}})}async unlinkIdentity(e){try{return await this._useSession(async a=>{var r,n;const{data:s,error:i}=a;if(i)throw i;return await O(this.fetch,"DELETE",`${this.url}/user/identities/${e.identity_id}`,{headers:this.headers,jwt:(n=(r=s.session)===null||r===void 0?void 0:r.access_token)!==null&&n!==void 0?n:void 0})})}catch(a){if(P(a))return{data:null,error:a};throw a}}async _refreshAccessToken(e){const a=`#_refreshAccessToken(${e.substring(0,5)}...)`;this._debug(a,"begin");try{const r=Date.now();return await Gi(async n=>(n>0&&await qi(200*Math.pow(2,n-1)),this._debug(a,"refreshing attempt",n),await O(this.fetch,"POST",`${this.url}/token?grant_type=refresh_token`,{body:{refresh_token:e},headers:this.headers,xform:re})),(n,s)=>{const i=200*Math.pow(2,n);return s&&da(s)&&Date.now()+i-r<He})}catch(r){if(this._debug(a,"error",r),P(r))return{data:{session:null,user:null},error:r};throw r}finally{this._debug(a,"end")}}_isValidSession(e){return typeof e=="object"&&e!==null&&"access_token"in e&&"refresh_token"in e&&"expires_at"in e}async _handleProviderSignIn(e,a){const r=await this._getUrlForProvider(`${this.url}/authorize`,e,{redirectTo:a.redirectTo,scopes:a.scopes,queryParams:a.queryParams});return this._debug("#_handleProviderSignIn()","provider",e,"options",a,"url",r),J()&&!a.skipBrowserRedirect&&window.location.assign(r),{data:{provider:e,url:r},error:null}}async _recoverAndRefresh(){var e,a;const r="#_recoverAndRefresh()";this._debug(r,"begin");try{const n=await je(this.storage,this.storageKey);if(n&&this.userStorage){let i=await je(this.userStorage,this.storageKey+"-user");!this.storage.isServer&&Object.is(this.storage,this.userStorage)&&!i&&(i={user:n.user},await qe(this.userStorage,this.storageKey+"-user",i)),n.user=(e=i==null?void 0:i.user)!==null&&e!==void 0?e:ua()}else if(n&&!n.user&&!n.user){const i=await je(this.storage,this.storageKey+"-user");i&&(i!=null&&i.user)?(n.user=i.user,await fe(this.storage,this.storageKey+"-user"),await qe(this.storage,this.storageKey,n)):n.user=ua()}if(this._debug(r,"session from storage",n),!this._isValidSession(n)){this._debug(r,"session is not valid"),n!==null&&await this._removeSession();return}const s=((a=n.expires_at)!==null&&a!==void 0?a:1/0)*1e3-Date.now()<la;if(this._debug(r,`session has${s?"":" not"} expired with margin of ${la}s`),s){if(this.autoRefreshToken&&n.refresh_token){const{error:i}=await this._callRefreshToken(n.refresh_token);i&&(console.error(i),da(i)||(this._debug(r,"refresh failed with a non-retryable error, removing the session",i),await this._removeSession()))}}else if(n.user&&n.user.__isUserNotAvailableProxy===!0)try{const{data:i,error:l}=await this._getUser(n.access_token);!l&&(i!=null&&i.user)?(n.user=i.user,await this._saveSession(n),await this._notifyAllSubscribers("SIGNED_IN",n)):this._debug(r,"could not get user data, skipping SIGNED_IN notification")}catch(i){console.error("Error getting user data:",i),this._debug(r,"error getting user data, skipping SIGNED_IN notification",i)}else await this._notifyAllSubscribers("SIGNED_IN",n)}catch(n){this._debug(r,"error",n),console.error(n);return}finally{this._debug(r,"end")}}async _callRefreshToken(e){var a,r;if(!e)throw new ve;if(this.refreshingDeferred)return this.refreshingDeferred.promise;const n=`#_callRefreshToken(${e.substring(0,5)}...)`;this._debug(n,"begin");try{this.refreshingDeferred=new Jt;const{data:s,error:i}=await this._refreshAccessToken(e);if(i)throw i;if(!s.session)throw new ve;await this._saveSession(s.session),await this._notifyAllSubscribers("TOKEN_REFRESHED",s.session);const l={data:s.session,error:null};return this.refreshingDeferred.resolve(l),l}catch(s){if(this._debug(n,"error",s),P(s)){const i={data:null,error:s};return da(s)||await this._removeSession(),(a=this.refreshingDeferred)===null||a===void 0||a.resolve(i),i}throw(r=this.refreshingDeferred)===null||r===void 0||r.reject(s),s}finally{this.refreshingDeferred=null,this._debug(n,"end")}}async _notifyAllSubscribers(e,a,r=!0){const n=`#_notifyAllSubscribers(${e})`;this._debug(n,"begin",a,`broadcast = ${r}`);try{this.broadcastChannel&&r&&this.broadcastChannel.postMessage({event:e,session:a});const s=[],i=Array.from(this.stateChangeEmitters.values()).map(async l=>{try{await l.callback(e,a)}catch(c){s.push(c)}});if(await Promise.all(i),s.length>0){for(let l=0;l<s.length;l+=1)console.error(s[l]);throw s[0]}}finally{this._debug(n,"end")}}async _saveSession(e){this._debug("#_saveSession()",e),this.suppressGetSessionWarning=!0;const a=Object.assign({},e),r=a.user&&a.user.__isUserNotAvailableProxy===!0;if(this.userStorage){!r&&a.user&&await qe(this.userStorage,this.storageKey+"-user",{user:a.user});const n=Object.assign({},a);delete n.user;const s=$r(n);await qe(this.storage,this.storageKey,s)}else{const n=$r(a);await qe(this.storage,this.storageKey,n)}}async _removeSession(){this._debug("#_removeSession()"),await fe(this.storage,this.storageKey),await fe(this.storage,this.storageKey+"-code-verifier"),await fe(this.storage,this.storageKey+"-user"),this.userStorage&&await fe(this.userStorage,this.storageKey+"-user"),await this._notifyAllSubscribers("SIGNED_OUT",null)}_removeVisibilityChangedCallback(){this._debug("#_removeVisibilityChangedCallback()");const e=this.visibilityChangedCallback;this.visibilityChangedCallback=null;try{e&&J()&&(window!=null&&window.removeEventListener)&&window.removeEventListener("visibilitychange",e)}catch(a){console.error("removing visibilitychange callback failed",a)}}async _startAutoRefresh(){await this._stopAutoRefresh(),this._debug("#_startAutoRefresh()");const e=setInterval(()=>this._autoRefreshTokenTick(),He);this.autoRefreshTicker=e,e&&typeof e=="object"&&typeof e.unref=="function"?e.unref():typeof Deno<"u"&&typeof Deno.unrefTimer=="function"&&Deno.unrefTimer(e),setTimeout(async()=>{await this.initializePromise,await this._autoRefreshTokenTick()},0)}async _stopAutoRefresh(){this._debug("#_stopAutoRefresh()");const e=this.autoRefreshTicker;this.autoRefreshTicker=null,e&&clearInterval(e)}async startAutoRefresh(){this._removeVisibilityChangedCallback(),await this._startAutoRefresh()}async stopAutoRefresh(){this._removeVisibilityChangedCallback(),await this._stopAutoRefresh()}async _autoRefreshTokenTick(){this._debug("#_autoRefreshTokenTick()","begin");try{await this._acquireLock(0,async()=>{try{const e=Date.now();try{return await this._useSession(async a=>{const{data:{session:r}}=a;if(!r||!r.refresh_token||!r.expires_at){this._debug("#_autoRefreshTokenTick()","no session");return}const n=Math.floor((r.expires_at*1e3-e)/He);this._debug("#_autoRefreshTokenTick()",`access token expires in ${n} ticks, a tick lasts ${He}ms, refresh threshold is ${Pa} ticks`),n<=Pa&&await this._callRefreshToken(r.refresh_token)})}catch(a){console.error("Auto refresh tick failed with error. This is likely a transient error.",a)}}finally{this._debug("#_autoRefreshTokenTick()","end")}})}catch(e){if(e.isAcquireTimeout||e instanceof ts)this._debug("auto refresh token tick lock not available");else throw e}}async _handleVisibilityChange(){if(this._debug("#_handleVisibilityChange()"),!J()||!(window!=null&&window.addEventListener))return this.autoRefreshToken&&this.startAutoRefresh(),!1;try{this.visibilityChangedCallback=async()=>await this._onVisibilityChanged(!1),window==null||window.addEventListener("visibilitychange",this.visibilityChangedCallback),await this._onVisibilityChanged(!0)}catch(e){console.error("_handleVisibilityChange",e)}}async _onVisibilityChanged(e){const a=`#_onVisibilityChanged(${e})`;this._debug(a,"visibilityState",document.visibilityState),document.visibilityState==="visible"?(this.autoRefreshToken&&this._startAutoRefresh(),e||(await this.initializePromise,await this._acquireLock(-1,async()=>{if(document.visibilityState!=="visible"){this._debug(a,"acquired the lock to recover the session, but the browser visibilityState is no longer visible, aborting");return}await this._recoverAndRefresh()}))):document.visibilityState==="hidden"&&this.autoRefreshToken&&this._stopAutoRefresh()}async _getUrlForProvider(e,a,r){const n=[`provider=${encodeURIComponent(a)}`];if(r!=null&&r.redirectTo&&n.push(`redirect_to=${encodeURIComponent(r.redirectTo)}`),r!=null&&r.scopes&&n.push(`scopes=${encodeURIComponent(r.scopes)}`),this.flowType==="pkce"){const[s,i]=await Me(this.storage,this.storageKey),l=new URLSearchParams({code_challenge:`${encodeURIComponent(s)}`,code_challenge_method:`${encodeURIComponent(i)}`});n.push(l.toString())}if(r!=null&&r.queryParams){const s=new URLSearchParams(r.queryParams);n.push(s.toString())}return r!=null&&r.skipBrowserRedirect&&n.push(`skip_http_redirect=${r.skipBrowserRedirect}`),`${e}?${n.join("&")}`}async _unenroll(e){try{return await this._useSession(async a=>{var r;const{data:n,error:s}=a;return s?{data:null,error:s}:await O(this.fetch,"DELETE",`${this.url}/factors/${e.factorId}`,{headers:this.headers,jwt:(r=n==null?void 0:n.session)===null||r===void 0?void 0:r.access_token})})}catch(a){if(P(a))return{data:null,error:a};throw a}}async _enroll(e){try{return await this._useSession(async a=>{var r,n;const{data:s,error:i}=a;if(i)return{data:null,error:i};const l=Object.assign({friendly_name:e.friendlyName,factor_type:e.factorType},e.factorType==="phone"?{phone:e.phone}:e.factorType==="totp"?{issuer:e.issuer}:{}),{data:c,error:d}=await O(this.fetch,"POST",`${this.url}/factors`,{body:l,headers:this.headers,jwt:(r=s==null?void 0:s.session)===null||r===void 0?void 0:r.access_token});return d?{data:null,error:d}:(e.factorType==="totp"&&c.type==="totp"&&(!((n=c==null?void 0:c.totp)===null||n===void 0)&&n.qr_code)&&(c.totp.qr_code=`data:image/svg+xml;utf-8,${c.totp.qr_code}`),{data:c,error:null})})}catch(a){if(P(a))return{data:null,error:a};throw a}}async _verify(e){return this._acquireLock(-1,async()=>{try{return await this._useSession(async a=>{var r;const{data:n,error:s}=a;if(s)return{data:null,error:s};const i=Object.assign({challenge_id:e.challengeId},"webauthn"in e?{webauthn:Object.assign(Object.assign({},e.webauthn),{credential_response:e.webauthn.type==="create"?wl(e.webauthn.credential_response):xl(e.webauthn.credential_response)})}:{code:e.code}),{data:l,error:c}=await O(this.fetch,"POST",`${this.url}/factors/${e.factorId}/verify`,{body:i,headers:this.headers,jwt:(r=n==null?void 0:n.session)===null||r===void 0?void 0:r.access_token});return c?{data:null,error:c}:(await this._saveSession(Object.assign({expires_at:Math.round(Date.now()/1e3)+l.expires_in},l)),await this._notifyAllSubscribers("MFA_CHALLENGE_VERIFIED",l),{data:l,error:c})})}catch(a){if(P(a))return{data:null,error:a};throw a}})}async _challenge(e){return this._acquireLock(-1,async()=>{try{return await this._useSession(async a=>{var r;const{data:n,error:s}=a;if(s)return{data:null,error:s};const i=await O(this.fetch,"POST",`${this.url}/factors/${e.factorId}/challenge`,{body:e,headers:this.headers,jwt:(r=n==null?void 0:n.session)===null||r===void 0?void 0:r.access_token});if(i.error)return i;const{data:l}=i;if(l.type!=="webauthn")return{data:l,error:null};switch(l.webauthn.type){case"create":return{data:Object.assign(Object.assign({},l),{webauthn:Object.assign(Object.assign({},l.webauthn),{credential_options:Object.assign(Object.assign({},l.webauthn.credential_options),{publicKey:vl(l.webauthn.credential_options.publicKey)})})}),error:null};case"request":return{data:Object.assign(Object.assign({},l),{webauthn:Object.assign(Object.assign({},l.webauthn),{credential_options:Object.assign(Object.assign({},l.webauthn.credential_options),{publicKey:bl(l.webauthn.credential_options.publicKey)})})}),error:null}}})}catch(a){if(P(a))return{data:null,error:a};throw a}})}async _challengeAndVerify(e){const{data:a,error:r}=await this._challenge({factorId:e.factorId});return r?{data:null,error:r}:await this._verify({factorId:e.factorId,challengeId:a.id,code:e.code})}async _listFactors(){var e;const{data:{user:a},error:r}=await this.getUser();if(r)return{data:null,error:r};const n={all:[],phone:[],totp:[],webauthn:[]};for(const s of(e=a==null?void 0:a.factors)!==null&&e!==void 0?e:[])n.all.push(s),s.status==="verified"&&n[s.factor_type].push(s);return{data:n,error:null}}async _getAuthenticatorAssuranceLevel(){return this._acquireLock(-1,async()=>await this._useSession(async e=>{var a,r;const{data:{session:n},error:s}=e;if(s)return{data:null,error:s};if(!n)return{data:{currentLevel:null,nextLevel:null,currentAuthenticationMethods:[]},error:null};const{payload:i}=ca(n.access_token);let l=null;i.aal&&(l=i.aal);let c=l;((r=(a=n.user.factors)===null||a===void 0?void 0:a.filter(h=>h.status==="verified"))!==null&&r!==void 0?r:[]).length>0&&(c="aal2");const u=i.amr||[];return{data:{currentLevel:l,nextLevel:c,currentAuthenticationMethods:u},error:null}}))}async fetchJwk(e,a={keys:[]}){let r=a.keys.find(l=>l.kid===e);if(r)return r;const n=Date.now();if(r=this.jwks.keys.find(l=>l.kid===e),r&&this.jwks_cached_at+Pi>n)return r;const{data:s,error:i}=await O(this.fetch,"GET",`${this.url}/.well-known/jwks.json`,{headers:this.headers});if(i)throw i;return!s.keys||s.keys.length===0||(this.jwks=s,this.jwks_cached_at=n,r=s.keys.find(l=>l.kid===e),!r)?null:r}async getClaims(e,a={}){try{let r=e;if(!r){const{data:y,error:m}=await this.getSession();if(m||!y.session)return{data:null,error:m};r=y.session.access_token}const{header:n,payload:s,signature:i,raw:{header:l,payload:c}}=ca(r);a!=null&&a.allowExpired||Qi(s.exp);const d=!n.alg||n.alg.startsWith("HS")||!n.kid||!("crypto"in globalThis&&"subtle"in globalThis.crypto)?null:await this.fetchJwk(n.kid,a!=null&&a.keys?{keys:a.keys}:a==null?void 0:a.jwks);if(!d){const{error:y}=await this.getUser(r);if(y)throw y;return{data:{claims:s,header:n,signature:i},error:null}}const u=Xi(n.alg),h=await crypto.subtle.importKey("jwk",d,u,!0,["verify"]);if(!await crypto.subtle.verify(u,h,i,Mi(`${l}.${c}`)))throw new Ra("Invalid JWT signature");return{data:{claims:s,header:n,signature:i},error:null}}catch(r){if(P(r))return{data:null,error:r};throw r}}}vt.nextInstanceID=0;const Pl=vt;class Ol extends Pl{constructor(e){super(e)}}class Il{constructor(e,a,r){var n,s,i;this.supabaseUrl=e,this.supabaseKey=a;const l=ji(e);if(!a)throw new Error("supabaseKey is required.");this.realtimeUrl=new URL("realtime/v1",l),this.realtimeUrl.protocol=this.realtimeUrl.protocol.replace("http","ws"),this.authUrl=new URL("auth/v1",l),this.storageUrl=new URL("storage/v1",l),this.functionsUrl=new URL("functions/v1",l);const c=`sb-${l.hostname.split(".")[0]}-auth-token`,d={db:gi,realtime:bi,auth:Object.assign(Object.assign({},vi),{storageKey:c}),global:fi},u=_i(r??{},d);this.storageKey=(n=u.auth.storageKey)!==null&&n!==void 0?n:"",this.headers=(s=u.global.headers)!==null&&s!==void 0?s:{},u.accessToken?(this.accessToken=u.accessToken,this.auth=new Proxy({},{get:(h,p)=>{throw new Error(`@supabase/supabase-js: Supabase Client is configured with the accessToken option, accessing supabase.auth.${String(p)} is not possible`)}})):this.auth=this._initSupabaseAuthClient((i=u.auth)!==null&&i!==void 0?i:{},this.headers,u.global.fetch),this.fetch=Ti(a,this._getAccessToken.bind(this),u.global.fetch),this.realtime=this._initRealtimeClient(Object.assign({headers:this.headers,accessToken:this._getAccessToken.bind(this)},u.realtime)),this.rest=new So(new URL("rest/v1",l).href,{headers:this.headers,schema:u.db.schema,fetch:this.fetch}),this.storage=new pi(this.storageUrl.href,this.headers,this.fetch,r==null?void 0:r.storage),u.accessToken||this._listenForAuthEvents()}get functions(){return new vo(this.functionsUrl.href,{headers:this.headers,customFetch:this.fetch})}from(e){return this.rest.from(e)}schema(e){return this.rest.schema(e)}rpc(e,a={},r={head:!1,get:!1,count:void 0}){return this.rest.rpc(e,a,r)}channel(e,a={config:{}}){return this.realtime.channel(e,a)}getChannels(){return this.realtime.getChannels()}removeChannel(e){return this.realtime.removeChannel(e)}removeAllChannels(){return this.realtime.removeAllChannels()}async _getAccessToken(){var e,a;if(this.accessToken)return await this.accessToken();const{data:r}=await this.auth.getSession();return(a=(e=r.session)===null||e===void 0?void 0:e.access_token)!==null&&a!==void 0?a:this.supabaseKey}_initSupabaseAuthClient({autoRefreshToken:e,persistSession:a,detectSessionInUrl:r,storage:n,userStorage:s,storageKey:i,flowType:l,lock:c,debug:d},u,h){const p={Authorization:`Bearer ${this.supabaseKey}`,apikey:`${this.supabaseKey}`};return new Ol({url:this.authUrl.href,headers:Object.assign(Object.assign({},p),u),storageKey:i,autoRefreshToken:e,persistSession:a,detectSessionInUrl:r,storage:n,userStorage:s,flowType:l,lock:c,debug:d,fetch:h,hasCustomAuthorizationHeader:Object.keys(this.headers).some(y=>y.toLowerCase()==="authorization")})}_initRealtimeClient(e){return new Ho(this.realtimeUrl.href,Object.assign(Object.assign({},e),{params:Object.assign({apikey:this.supabaseKey},e==null?void 0:e.params)}))}_listenForAuthEvents(){return this.auth.onAuthStateChange((a,r)=>{this._handleTokenChanged(a,"CLIENT",r==null?void 0:r.access_token)})}_handleTokenChanged(e,a,r){(e==="TOKEN_REFRESHED"||e==="SIGNED_IN")&&this.changedAccessToken!==r?(this.changedAccessToken=r,this.realtime.setAuth(r)):e==="SIGNED_OUT"&&(this.realtime.setAuth(),a=="STORAGE"&&this.auth.signOut(),this.changedAccessToken=void 0)}}const Rl=(t,e,a)=>new Il(t,e,a);function Cl(){if(typeof window<"u"||typeof process>"u")return!1;const t=process.version;if(t==null)return!1;const e=t.match(/^v(\d+)\./);return e?parseInt(e[1],10)<=18:!1}Cl()&&console.warn("âš ï¸  Node.js 18 and below are deprecated and will no longer be supported in future versions of @supabase/supabase-js. Please upgrade to Node.js 20 or later. For more information, visit: https://github.com/orgs/supabase/discussions/37217");const $l="https://ftwlzdhkzqfuosdorgjt.supabase.co",Dl="eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJzdXBhYmFzZSIsInJlZiI6ImZ0d2x6ZGhrenFmdW9zZG9yZ2p0Iiwicm9sZSI6ImFub24iLCJpYXQiOjE3MzE1Mjc0MzksImV4cCI6MjA0NzEwMzQzOX0.msaWtaLGNMDiyuxIOFDwULWee0nqcM7p_LAYWB14j1k",U=Rl($l,Dl,{auth:{persistSession:!0,autoRefreshToken:!0,detectSessionInUrl:!0}}),Ll=w.createContext({user:null,isAdmin:!1,loading:!0,signIn:async()=>{},signOut:async()=>{}}),pa="ben@phippsmusic.com";function Ul({children:t}){const[e,a]=w.useState(null),[r,n]=w.useState(!1),[s,i]=w.useState(!0);w.useEffect(()=>{U.auth.getSession().then(({data:{session:u}})=>{u!=null&&u.user&&(a({id:u.user.id,email:u.user.email||""}),n(u.user.email===pa)),i(!1)});const{data:{subscription:d}}=U.auth.onAuthStateChange((u,h)=>{h!=null&&h.user?(a({id:h.user.id,email:h.user.email||""}),n(h.user.email===pa)):(a(null),n(!1)),i(!1)});return()=>{d.unsubscribe()}},[]);const l=async(d,u)=>{i(!0);try{const{data:h,error:p}=await U.auth.signInWithPassword({email:d,password:u});if(p)throw p;if(h.user.email!==pa)throw await U.auth.signOut(),new Error("Unauthorized access");a({id:h.user.id,email:h.user.email}),n(!0)}catch(h){throw console.error("Sign in failed:",h),h}finally{i(!1)}},c=async()=>{try{await U.auth.signOut(),a(null),n(!1)}catch(d){throw console.error("Sign out failed:",d),d}};return o.jsx(Ll.Provider,{value:{user:e,isAdmin:r,loading:s,signIn:l,signOut:c},children:t})}/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */var Ml={xmlns:"http://www.w3.org/2000/svg",width:24,height:24,viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:2,strokeLinecap:"round",strokeLinejoin:"round"};/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const Bl=t=>t.replace(/([a-z0-9])([A-Z])/g,"$1-$2").toLowerCase().trim(),$=(t,e)=>{const a=w.forwardRef(({color:r="currentColor",size:n=24,strokeWidth:s=2,absoluteStrokeWidth:i,className:l="",children:c,...d},u)=>w.createElement("svg",{ref:u,...Ml,width:n,height:n,stroke:r,strokeWidth:i?Number(s)*24/Number(n):s,className:["lucide",`lucide-${Bl(t)}`,l].join(" "),...d},[...e.map(([h,p])=>w.createElement(h,p)),...Array.isArray(c)?c:[c]]));return a.displayName=`${t}`,a};/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const pe=$("AlertCircle",[["circle",{cx:"12",cy:"12",r:"10",key:"1mglay"}],["line",{x1:"12",x2:"12",y1:"8",y2:"12",key:"1pkeuh"}],["line",{x1:"12",x2:"12.01",y1:"16",y2:"16",key:"4dfq90"}]]);/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const Fl=$("AlertTriangle",[["path",{d:"m21.73 18-8-14a2 2 0 0 0-3.48 0l-8 14A2 2 0 0 0 4 21h16a2 2 0 0 0 1.73-3Z",key:"c3ski4"}],["path",{d:"M12 9v4",key:"juzpu7"}],["path",{d:"M12 17h.01",key:"p32p05"}]]);/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const ye=$("ArrowLeft",[["path",{d:"m12 19-7-7 7-7",key:"1l729n"}],["path",{d:"M19 12H5",key:"x3x0zl"}]]);/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const bt=$("ArrowRight",[["path",{d:"M5 12h14",key:"1ays0h"}],["path",{d:"m12 5 7 7-7 7",key:"xquz4c"}]]);/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const tr=$("Calendar",[["path",{d:"M8 2v4",key:"1cmpym"}],["path",{d:"M16 2v4",key:"4m81vk"}],["rect",{width:"18",height:"18",x:"3",y:"4",rx:"2",key:"1hopcy"}],["path",{d:"M3 10h18",key:"8toen8"}]]);/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const Wl=$("CheckCircle2",[["circle",{cx:"12",cy:"12",r:"10",key:"1mglay"}],["path",{d:"m9 12 2 2 4-4",key:"dzmm74"}]]);/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const ot=$("CheckCircle",[["path",{d:"M22 11.08V12a10 10 0 1 1-5.93-9.14",key:"g774vq"}],["path",{d:"m9 11 3 3L22 4",key:"1pflzl"}]]);/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const ns=$("Check",[["path",{d:"M20 6 9 17l-5-5",key:"1gmf2c"}]]);/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const ss=$("Clock",[["circle",{cx:"12",cy:"12",r:"10",key:"1mglay"}],["polyline",{points:"12 6 12 12 16 14",key:"68esgv"}]]);/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const Hl=$("Disc",[["circle",{cx:"12",cy:"12",r:"10",key:"1mglay"}],["circle",{cx:"12",cy:"12",r:"2",key:"1c9p78"}]]);/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const ql=$("Heart",[["path",{d:"M19 14c1.49-1.46 3-3.21 3-5.5A5.5 5.5 0 0 0 16.5 3c-1.76 0-3 .5-4.5 2-1.5-1.5-2.74-2-4.5-2A5.5 5.5 0 0 0 2 8.5c0 2.3 1.5 4.05 3 5.5l7 7Z",key:"c3ymky"}]]);/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const os=$("Image",[["rect",{width:"18",height:"18",x:"3",y:"3",rx:"2",ry:"2",key:"1m3agn"}],["circle",{cx:"9",cy:"9",r:"2",key:"af1f0g"}],["path",{d:"m21 15-3.086-3.086a2 2 0 0 0-2.828 0L6 21",key:"1xmnt7"}]]);/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const Gl=$("Link",[["path",{d:"M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71",key:"1cjeqo"}],["path",{d:"M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71",key:"19qd67"}]]);/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const zl=$("ListMusic",[["path",{d:"M21 15V6",key:"h1cx4g"}],["path",{d:"M18.5 18a2.5 2.5 0 1 0 0-5 2.5 2.5 0 0 0 0 5Z",key:"8saifv"}],["path",{d:"M12 12H3",key:"18klou"}],["path",{d:"M16 6H3",key:"1wxfjs"}],["path",{d:"M12 18H3",key:"11ftsu"}]]);/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const Re=$("Loader2",[["path",{d:"M21 12a9 9 0 1 1-6.219-8.56",key:"13zald"}]]);/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const Kl=$("Mail",[["rect",{width:"20",height:"16",x:"2",y:"4",rx:"2",key:"18n3k1"}],["path",{d:"m22 7-8.97 5.7a1.94 1.94 0 0 1-2.06 0L2 7",key:"1ocrg3"}]]);/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const Vl=$("Menu",[["line",{x1:"4",x2:"20",y1:"12",y2:"12",key:"1e0a9i"}],["line",{x1:"4",x2:"20",y1:"6",y2:"6",key:"1owob3"}],["line",{x1:"4",x2:"20",y1:"18",y2:"18",key:"yk5zj1"}]]);/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const Yl=$("MessageSquare",[["path",{d:"M21 15a2 2 0 0 1-2 2H7l-4 4V5a2 2 0 0 1 2-2h14a2 2 0 0 1 2 2z",key:"1lielz"}]]);/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const me=$("Music2",[["circle",{cx:"8",cy:"18",r:"4",key:"1fc0mg"}],["path",{d:"M12 18V2l7 4",key:"g04rme"}]]);/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const Zt=$("Music4",[["path",{d:"M9 18V5l12-2v13",key:"1jmyc2"}],["path",{d:"m9 9 12-2",key:"1e64n2"}],["circle",{cx:"6",cy:"18",r:"3",key:"fqmcym"}],["circle",{cx:"18",cy:"16",r:"3",key:"1hluhg"}]]);/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const Jl=$("Newspaper",[["path",{d:"M4 22h16a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2H8a2 2 0 0 0-2 2v16a2 2 0 0 1-2 2Zm0 0a2 2 0 0 1-2-2v-9c0-1.1.9-2 2-2h2",key:"7pis2x"}],["path",{d:"M18 14h-8",key:"sponae"}],["path",{d:"M15 18h-5",key:"95g1m2"}],["path",{d:"M10 6h8v4h-8V6Z",key:"smlsk5"}]]);/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const Zl=$("RefreshCw",[["path",{d:"M3 12a9 9 0 0 1 9-9 9.75 9.75 0 0 1 6.74 2.74L21 8",key:"v9h5vc"}],["path",{d:"M21 3v5h-5",key:"1q7to0"}],["path",{d:"M21 12a9 9 0 0 1-9 9 9.75 9.75 0 0 1-6.74-2.74L3 16",key:"3uifl3"}],["path",{d:"M8 16H3v5",key:"1cv678"}]]);/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const Ft=$("Search",[["circle",{cx:"11",cy:"11",r:"8",key:"4ej97u"}],["path",{d:"m21 21-4.3-4.3",key:"1qie3q"}]]);/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const is=$("Send",[["path",{d:"m22 2-7 20-4-9-9-4Z",key:"1q3vgg"}],["path",{d:"M22 2 11 13",key:"nzbqef"}]]);/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const ls=$("Star",[["polygon",{points:"12 2 15.09 8.26 22 9.27 17 14.14 18.18 21.02 12 17.77 5.82 21.02 7 14.14 2 9.27 8.91 8.26 12 2",key:"8f66p6"}]]);/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const Ca=$("Tag",[["path",{d:"M12.586 2.586A2 2 0 0 0 11.172 2H4a2 2 0 0 0-2 2v7.172a2 2 0 0 0 .586 1.414l8.704 8.704a2.426 2.426 0 0 0 3.42 0l6.58-6.58a2.426 2.426 0 0 0 0-3.42z",key:"vktsd0"}],["circle",{cx:"7.5",cy:"7.5",r:".5",fill:"currentColor",key:"kqv944"}]]);/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const Qt=$("User",[["path",{d:"M19 21v-2a4 4 0 0 0-4-4H9a4 4 0 0 0-4 4v2",key:"975kel"}],["circle",{cx:"12",cy:"7",r:"4",key:"17ys0d"}]]);/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const Xt=$("Users",[["path",{d:"M16 21v-2a4 4 0 0 0-4-4H6a4 4 0 0 0-4 4v2",key:"1yyitq"}],["circle",{cx:"9",cy:"7",r:"4",key:"nufk8"}],["path",{d:"M22 21v-2a4 4 0 0 0-3-3.87",key:"kshegd"}],["path",{d:"M16 3.13a4 4 0 0 1 0 7.75",key:"1da9ce"}]]);/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const at=$("X",[["path",{d:"M18 6 6 18",key:"1bl5f8"}],["path",{d:"m6 6 12 12",key:"d8bk6v"}]]);/**
 * @license lucide-react v0.344.0 - ISC
 *
 * This source code is licensed under the ISC license.
 * See the LICENSE file in the root directory of this source tree.
 */const Ql=$("Zap",[["polygon",{points:"13 2 3 14 12 14 11 22 21 10 12 10 13 2",key:"45s27k"}]]);class ds extends w.Component{constructor(){super(...arguments);ae(this,"state",{hasError:!1,error:null});ae(this,"handleRetry",()=>{window.location.reload()})}static getDerivedStateFromError(a){return{hasError:!0,error:a}}componentDidCatch(a,r){console.error("Uncaught error:",a,r)}render(){var a,r;if(this.state.hasError){const s=((a=this.state.error)==null?void 0:a.message.includes("Supabase"))?"Unable to connect to the database. Please check your connection and try again.":"Something went wrong. Please try refreshing the page.";return o.jsx("div",{className:"min-h-screen flex items-center justify-center bg-gray-50 p-4",children:o.jsxs("div",{className:"bg-white p-6 rounded-lg shadow-lg max-w-md w-full",children:[o.jsxs("div",{className:"flex items-center gap-3 text-red-600 mb-4",children:[o.jsx(Fl,{className:"w-6 h-6"}),o.jsx("h2",{className:"text-lg font-semibold",children:"Error"})]}),o.jsx("p",{className:"text-gray-600 mb-4",children:s}),((r=this.state.error)==null?void 0:r.message)&&o.jsx("pre",{className:"bg-gray-50 p-3 rounded text-sm text-gray-700 mb-4 overflow-auto",children:this.state.error.message}),o.jsxs("button",{onClick:this.handleRetry,className:"w-full bg-red-600 text-white py-2 rounded-lg hover:bg-red-700 transition-colors flex items-center justify-center gap-2",children:[o.jsx(Zl,{className:"w-4 h-4"}),"Retry"]})]})})}return this.props.children}}function De(){const[t,e]=w.useState([]),[a,r]=w.useState(!0),[n,s]=w.useState(null);return w.useEffect(()=>{async function i(){try{r(!0),s(null);const{data:l,error:c}=await U.from("genres").select("*").order("display_order");if(c)throw c;const{data:d,error:u}=await U.from("sub_genres").select("*").order("name");if(u)throw u;const h=l.map(p=>({...p,subGenres:d.filter(y=>y.genre_id===p.id).map(y=>({id:y.id,name:y.name,description:y.description}))}));e(h)}catch(l){console.error("Failed to fetch genres:",l),s(l instanceof Error?l:new Error("Failed to fetch genres"))}finally{r(!1)}}i()},[]),{genres:t,loading:a,error:n}}function mt(t){return t?t.toLowerCase().includes("r&b")?"rnb-soul":t.toString().toLowerCase().trim().replace(/[^\w\s-]/g,"").replace(/\s+/g,"-").replace(/-+/g,"-").replace(/^-+|-+$/g,""):""}function Ge(){const t=new Date;return`${t.getFullYear()}-${t.getMonth()+1}-${t.getDate()}`}function z(t){let e=0;for(let a=0;a<t.length;a++){const r=t.charCodeAt(a);e=(e<<5)-e+r,e=e&e}return e}function Xl({onClose:t}){const{genres:e,loading:a}=De();if(a)return o.jsx("div",{className:"p-6",children:o.jsx("div",{className:"grid grid-cols-3 gap-4",children:[...Array(6)].map((n,s)=>o.jsx("div",{className:"h-12 bg-gray-100 rounded-lg animate-pulse"},`skeleton-${s}`))})});const r=e.reduce((n,s,i)=>{const l=Math.floor(i/Math.ceil(e.length/3));return n[l]||(n[l]=[]),n[l].push(s),n},[]);return o.jsxs("div",{className:"p-6",children:[o.jsxs(R,{to:"/genres",onClick:t,className:"flex items-center gap-2 p-3 mb-4 text-gray-600 hover:text-green-600 hover:bg-gray-50 rounded-lg transition-colors",children:[o.jsx(zl,{className:"w-5 h-5"}),o.jsx("span",{className:"font-medium",children:"View All Genres & Sub-genres"})]}),o.jsx("div",{className:"grid grid-cols-3 gap-6",children:r.map((n,s)=>o.jsx("div",{className:"space-y-1",children:n.map(i=>o.jsxs(R,{to:`/genre/${mt(i.name)}`,onClick:t,className:"flex items-center gap-2 p-3 rounded-lg hover:bg-gray-50 text-gray-900 group",children:[o.jsx("div",{className:"p-1.5 bg-gray-50 rounded group-hover:bg-green-50 transition-colors",children:o.jsx(me,{className:"w-4 h-4 text-gray-500 group-hover:text-green-600"})}),o.jsx("span",{className:"font-medium",children:i.name})]},i.id))},s))})]})}function X(){const t=Kt(),e=Ce(),[a,r]=w.useState(!1),[n,s]=w.useState(!1),i=w.useRef();w.useRef(null);const l=t.pathname.startsWith("/submit"),c=()=>{i.current&&clearTimeout(i.current),r(!0)},d=()=>{i.current=setTimeout(()=>{r(!1)},300)};w.useEffect(()=>{s(!1)},[t.pathname]),w.useEffect(()=>()=>{i.current&&clearTimeout(i.current)},[]);const u=()=>{e("/playlists",{state:{focusSearch:!0}})};return o.jsx("header",{className:"bg-gradient-to-r from-green-500 to-green-600 text-white relative z-50",children:o.jsxs("div",{className:"container mx-auto px-4",children:[o.jsxs("div",{className:"flex justify-between items-center h-16",children:[o.jsxs(R,{to:"/",className:"flex items-center gap-2 sm:gap-3 hover:opacity-90 transition-opacity",children:[o.jsx(Zt,{className:"w-6 h-6 sm:w-8 sm:h-8 flex-shrink-0"}),o.jsx("h1",{className:"text-lg sm:text-2xl font-bold whitespace-nowrap",children:"Playlist Partner"})]}),o.jsxs("div",{className:"md:hidden flex items-center gap-2",children:[o.jsx("button",{onClick:u,className:"p-2 hover:bg-white/10 rounded-lg","aria-label":"Search",children:o.jsx(Ft,{className:"w-6 h-6"})}),!l&&o.jsx(R,{to:"/submit",className:"flex items-center gap-2 bg-white text-green-600 px-4 py-2 rounded-lg hover:bg-green-50 transition-colors",children:"Submit"}),o.jsx("button",{onClick:()=>s(!n),className:"p-2 hover:bg-white/10 rounded-lg","aria-label":"Toggle menu",children:n?o.jsx(at,{className:"w-6 h-6"}):o.jsx(Vl,{className:"w-6 h-6"})})]}),o.jsxs("div",{className:"hidden md:flex items-center gap-6",children:[o.jsxs("button",{onClick:u,className:"flex items-center gap-2 px-4 py-2 bg-white/10 backdrop-blur-sm text-white/90 rounded-lg border border-white/20 hover:bg-white/20 hover:border-white/40 transition-all",children:[o.jsx(Ft,{className:"w-4 h-4"}),o.jsx("span",{className:"text-sm",children:"Search playlists..."})]}),o.jsx(R,{to:"/playlists",className:"flex items-center gap-2 text-white hover:text-white/90 transition-colors py-2 px-3 -ml-3",children:"Browse Playlists"}),o.jsxs("div",{onMouseEnter:c,onMouseLeave:d,className:"relative",children:[o.jsx(R,{to:"/genres",className:"flex items-center gap-2 text-white hover:text-white/90 transition-colors py-2 px-3 -ml-3",children:"Browse Genres"}),a&&o.jsxs("div",{className:"absolute top-full right-0 w-[800px] bg-white shadow-xl rounded-lg mt-1",children:[o.jsx("div",{className:"absolute h-3 -top-3 inset-x-0"}),o.jsx(Xl,{onClose:()=>r(!1)})]})]}),o.jsx(R,{to:"/for-curators",className:"flex items-center gap-2 text-white hover:text-white/90 transition-colors py-2 px-3 -ml-3",children:"For Curators"}),o.jsx(R,{to:"/about",className:"flex items-center gap-2 text-white hover:text-white/90 transition-colors py-2 px-3 -ml-3",children:"About"}),o.jsx(R,{to:"/blog",className:"flex items-center gap-2 text-white hover:text-white/90 transition-colors py-2 px-3 -ml-3",children:"Blog"}),!l&&o.jsx(R,{to:"/submit",className:"flex items-center gap-2 bg-white text-green-600 px-4 py-2 rounded-lg hover:bg-green-50 transition-colors",children:"Submit Track"})]})]}),n&&o.jsx("div",{className:"md:hidden border-t border-white/10",children:o.jsxs("nav",{className:"py-4 space-y-2",children:[o.jsx(R,{to:"/playlists",className:"block px-4 py-2 hover:bg-white/10 rounded-lg",onClick:()=>s(!1),children:"Browse Playlists"}),o.jsx(R,{to:"/genres",className:"block px-4 py-2 hover:bg-white/10 rounded-lg",onClick:()=>s(!1),children:"Browse Genres"}),o.jsx(R,{to:"/for-curators",className:"block px-4 py-2 hover:bg-white/10 rounded-lg",onClick:()=>s(!1),children:"For Curators"}),o.jsx(R,{to:"/about",className:"block px-4 py-2 hover:bg-white/10 rounded-lg",onClick:()=>s(!1),children:"About"}),o.jsx(R,{to:"/blog",className:"block px-4 py-2 hover:bg-white/10 rounded-lg",onClick:()=>s(!1),children:"Blog"})]})})]})})}function ee(){const{genres:t}=De();return o.jsx("footer",{className:"bg-gray-900 text-gray-300 mt-auto",children:o.jsxs("div",{className:"container mx-auto px-4 py-12",children:[o.jsxs("div",{className:"mb-12",children:[o.jsxs("div",{className:"flex items-center gap-3 mb-4",children:[o.jsx(Zt,{className:"w-8 h-8"}),o.jsx("h2",{className:"text-2xl font-bold",children:"Playlist Partner"})]}),o.jsx("p",{className:"text-gray-400 max-w-2xl",children:"Artists have made over 100,000+ successful submissions through Playlist Partner. No barriers, no fees—just music finding its rightful audience. Your next fan is waiting."})]}),o.jsxs("div",{className:"border-t border-gray-800 pt-8",children:[o.jsx("h3",{className:"text-lg font-semibold mb-6",children:"Browse Genres"}),o.jsx("div",{className:"grid grid-cols-2 sm:grid-cols-3 md:grid-cols-4 lg:grid-cols-6 gap-x-4 gap-y-3",children:t.map(e=>o.jsx(R,{to:`/genre/${e.slug}`,className:"text-gray-400 hover:text-green-500 transition-colors",children:e.name},e.id))})]}),o.jsx("div",{className:"border-t border-gray-800 mt-12 pt-8 text-center text-sm text-gray-500",children:o.jsxs("p",{children:["© ",new Date().getFullYear()," PlaylistPartner. All rights reserved."]})})]})})}function ce({title:t,description:e,image:a="https://ftwlzdhkzqfuosdorgjt.supabase.co/storage/v1/object/public/playlistpartner%20public/playlistpartner%20og%20image.png",url:r,type:n="website",noIndex:s=!1,playlist:i,article:l,structuredData:c}){var m;const d=i?`Submit Music to ${i.name} - Free Spotify Playlist Submission`:t||"Free Spotify Playlist Submission – No Signup | PlaylistPartner",u=i?`Get your music featured on ${i.name}, a Spotify playlist curated by ${i.curator_name} with ${i.followers.toLocaleString()} followers. No account needed! Access ${((m=i.genre_count)==null?void 0:m.toLocaleString())||"thousands of"} ${i.genre||"playlists"} and connect with curators on PlaylistPartner.com.`:"Submit your music to thousands of independent Spotify playlist curators for free. No signup required—connect with curators and grow your audience today with PlaylistPartner.",h=e||u,p=r||window.location.href.split("?")[0],y=window.location.origin;return o.jsxs(co,{children:[o.jsx("title",{children:d}),o.jsx("meta",{name:"description",content:h,"data-react-helmet":"true"}),o.jsx("link",{rel:"canonical",href:p}),o.jsx("meta",{name:"robots",content:s?"noindex, nofollow":"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1"}),o.jsx("meta",{property:"og:site_name",content:"PlaylistPartner"}),o.jsx("meta",{property:"og:title",content:d,"data-react-helmet":"true"}),o.jsx("meta",{property:"og:description",content:h,"data-react-helmet":"true"}),o.jsx("meta",{property:"og:type",content:n}),o.jsx("meta",{property:"og:url",content:p}),o.jsx("meta",{property:"og:image",content:a,"data-react-helmet":"true"}),o.jsx("meta",{property:"og:image:width",content:"1200"}),o.jsx("meta",{property:"og:image:height",content:"630"}),o.jsx("meta",{name:"twitter:card",content:"summary_large_image"}),o.jsx("meta",{name:"twitter:title",content:d,"data-react-helmet":"true"}),o.jsx("meta",{name:"twitter:description",content:h,"data-react-helmet":"true"}),o.jsx("meta",{name:"twitter:image",content:a,"data-react-helmet":"true"}),o.jsx("meta",{name:"twitter:site",content:"@playlistpartner"}),l&&o.jsxs(o.Fragment,{children:[o.jsx("meta",{property:"article:published_time",content:l.publishedTime}),l.modifiedTime&&o.jsx("meta",{property:"article:modified_time",content:l.modifiedTime}),l.author&&o.jsx("meta",{property:"article:author",content:l.author}),l.section&&o.jsx("meta",{property:"article:section",content:l.section})]}),o.jsx("script",{type:"application/ld+json",children:JSON.stringify(c||{"@context":"https://schema.org","@type":"WebSite",name:"PlaylistPartner",url:y,inLanguage:"en-US",description:"Submit your music to thousands of independent Spotify playlist curators for free. No signup required—connect with curators and grow your audience today with PlaylistPartner.",publisher:{"@type":"Organization",name:"PlaylistPartner",logo:{"@type":"ImageObject",url:"https://ftwlzdhkzqfuosdorgjt.supabase.co/storage/v1/object/public/playlistpartner%20public//playlist%20partner%20logo%20square.png",width:"500",height:"500"}},potentialAction:{"@type":"ViewAction",target:p}})})]})}const Wt="last_submission_data",ed=30*24*60*60*1e3;function cs(t){try{const e={artistName:t.artistName,email:t.email,lastTrack:t.track,lastUpdated:Date.now()};localStorage.setItem(Wt,JSON.stringify(e))}catch(e){console.error("Failed to save submission data:",e)}}function Qe(){try{const t=localStorage.getItem(Wt);if(!t)return null;const e=JSON.parse(t);return Date.now()-e.lastUpdated>ed?(localStorage.removeItem(Wt),null):{artistName:e.artistName,email:e.email,lastTrack:e.lastTrack}}catch(t){return console.error("Failed to retrieve submission data:",t),null}}function us(){try{localStorage.removeItem(Wt),localStorage.removeItem("trackSubmissions"),localStorage.removeItem("playlist_submissions"),localStorage.removeItem("spotify_token"),sessionStorage.clear()}catch(t){console.error("Failed to reset storage data:",t)}}const ar=[{id:"7DRq7XUc3LEt7u8U9Hm8sx",title:"$8K in plugins (for free) + a contract tool for indies",slug:"usd8k-in-plugins-for-free-a-contract-tool-for-indies",body:{data:{},content:[{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Bypass: Music Industry News for Independent Artists",nodeType:"text"}],nodeType:"heading-1"},{data:{},content:[{data:{},marks:[{type:"italic"}],value:"Wednesday edition - 3 min read",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"IK’s 43-for-1 Plugin Deal Feels Illegal (It’s Not)",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"What��s Up",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"IK Multimedia’s back with its annual Group Buy, and this time, they’re not even joking. Buy AmpliTube 5 for $30 and you get 42 plugins completely free. It’s live till October 31, so yes, Halloween is your deadline.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"So What",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"You can grab full versions of T-RackS 6 modules, FAME Studio Reverb, MODO Bass, Hammond B-3X, the works (that’s $8000 worth of gear for free). Technically, the entire T-RackS suite counts as one pick, and that one pick gives you 42 plugins.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Now What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"It’s thirty bucks. You’ve paid more for worse decisions. Buy AmpliTube 5 at pluginboutique.com, register the serial at ikmultimedia.com, then claim your picks in IK’s Promotions page. The sale ends after Halloween so don’t be that one person asking Reddit if it’s still live on November 1",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"},{data:{uri:"https://bedroomproducersblog.com/2025/10/21/ik-multimedia-group-buy-2025/"},content:[{data:{},marks:[{type:"underline"}],value:"[Full story at Bedroom Producers Blog]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"How To Use Instagram Without Burning Out",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"The Drop",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Instagram’s being honest about what it wants: short Reels, active DMs, and creators who keep the lights on. Yeah, those pretty grids and overdesigned posts don’t cut it anymore. They even capped Live access to accounts with 1,000 followers, which basically means they’re forcing smaller artists to earn visibility the hard way.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"The Ripple",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"This is still the best free marketing tool you’ve got. Reels = reach. DMs = community. Everything else is just noise. Use your analytics to see what gets saved and shared, then build more of that.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"The Take",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Check the Hypebot guide for the full strat, but the bottom line: start strong, post stuff that feels real (studio clips, snippets, or anything you think your fans would like) then monitor your saves and shares.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"},{data:{uri:"http://hypebot.com/hypebot/2025/10/musicians-guide-to-instagram.html"},content:[{data:{},marks:[{type:"underline"}],value:"[Full story at Hypebot]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Clearnote Is Fixing the Collab Headache",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"What's Up",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"For everyone still using Google Docs for contracts - just stop. It’s sketchy. Clearnote just launched in invite-only beta built for artists who need real split sheets, collab agreements, and producer deals without calling a lawyer. It’s not public yet, but it’s coming early next year.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"So What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"If you’re treating contracts like an afterthought (let’s be honest), well, congrats - you’re the reason Clearnote exists. It tracks your agreements so everyone’s protected if things blow up. All your deals are in one dashboard, ready to pull up when someone suddenly remembers they “helped with that hook.â€",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Now What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Before your next collab, go to ",nodeType:"text"},{data:{uri:"http://clearnote.ai"},content:[{data:{},marks:[{type:"underline"}],value:"clearnote.ai",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:" and make a contract. It takes two minutes to sign up so no excuses. Don’t send a thing until the contract’s signed. You’ll save yourself months of awkward DMs and legal bills no one has time for. Future-you will thank you.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"},{data:{uri:"https://musically.com/2025/10/22/ai-roundup-clearnote-launch-voice-swap-funding-beatoven-sfx/"},content:[{data:{},marks:[{type:"underline"}],value:"[Full story at Music Ally]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"While You Were Making Music...",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:"🎠",nodeType:"text"},{data:{uri:"https://www.musicbusinessworldwide.com/youtube-showcases-new-ai-likeness-detection-tool/"},content:[{data:{},marks:[{type:"underline"}],value:"YouTube’s new AI likeness detector is here [let’s hope it spots deepfakes faster than copyright claims]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"âš¾ ",nodeType:"text"},{data:{uri:"https://www.digitalmusicnews.com/2025/10/23/pharrell-williams-to-open-world-series-performance/"},content:[{data:{},marks:[{type:"underline"}],value:"Pharrell’s playing the World Series [good luck following that with your hometown show next weekend]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"🎧 ",nodeType:"text"},{data:{uri:"https://www.digitalmusicnews.com/2025/10/22/spotifys-discover-weekly-lists-hit-with-a-deluge-of-ai-slop/"},content:[{data:{},marks:[{type:"underline"}],value:"Spotify’s Discover Weekly turns into AI soup [Spotify: “we call that innovationâ€]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[{type:"italic"}],value:"Today's edition by Jordan F.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"italic"}],value:"For indies who ship music, not excuses.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"}],nodeType:"document"},excerpt:"IK Multimedia Group Buy offers $8,000 in plugins for $30 including AmpliTube 5. Instagram prioritizes Reels and DMs over static posts for artist reach. Clearnote launches beta platform for music collaboration contracts and split sheets.",category:"News",featuredImage:{url:"//images.ctfassets.net/b3nqx2d7xn8z/58f2LbDFCWgoouYITvnLtm/4f4494b8dea3df683045eede63a7f0e6/_8K_in_plugins__for_free____a_contract_tool_for_indies.jpg",title:"Bypass newsletter header about free music plugins and indie contract tools"},publishDate:"2025-10-22T00:00-07:00",featured:!1,createdAt:"2025-10-24T01:51:17.357Z",updatedAt:"2025-10-24T01:51:17.357Z"},{id:"62v3RFwl5E0d7eb7ZDrHZa",title:"beatBread’s $100M + NINA’s Payouts",slug:"beatbreads-usd100m-ninas-payouts",body:{data:{},content:[{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Bypass: Music Industry News for Independent Artists",nodeType:"text"}],nodeType:"heading-1"},{data:{},content:[{data:{},marks:[{type:"italic"}],value:"Friday edition - 2 min read",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:`beatBread’s $100M Fund
`,nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"What’s Up",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:`
beatBread’s feeling generous - $100M generous. They recently launched their Global Independence Fund so indies can get funding without handing over control.	
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"So What",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Hate when labels turn “advances†into a leash? beatBread is funding artists without the usual label ball-and-chain. You can get advances on your catalog or upcoming releases and still keep creative control. Just read the fine print, there’s always a catch somewhere.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Now What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"If you’ve got the streams, you’ve got the leverage. Get all your data (royalties, splits, release schedule) and see what beatBread’s offering. Then ask your distributor why they aren’t doing the same. If you’re in AIM/WIN/IMPALA circles, check member routes.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"},{data:{uri:"https://www.musicbusinessworldwide.com/beatbread-unveils-100m-global-indie-fund-in-partnership-with-aim-win-impala/"},content:[{data:{},marks:[{type:"underline"}],value:"[Read more on Music Business Worldwide]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"NINA’s “Pay Your Fans†Model",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"What's Up",nodeType:"text"},{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:"Somebody finally figured it out. Who’s that somebody? NINA. They’re literally paying your fans to do the promo for you.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"So What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"The idea’s not new, but the setup works. NINA tracks who’s driving sales, and cuts them in on the action. When’s the last time a company said, “We’ll pay people to talk about your song� ",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Now What",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:"Before you go all in, test it. Upload one track, set a fair price, and give the link to your tightest fans first. Watch who actually helps you make sales and who just likes your posts.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"},{data:{uri:"https://www.hypebot.com/hypebot/2025/10/ninas-community-revenue-share-model-is-a-breath-of-fresh-air.html"},content:[{data:{},marks:[{type:"underline"}],value:"[Full story on Hypebot]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"TikTok’s SoundOn Launched Tkandz to UK Top 30",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Who Did It",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Tkandz and CXSPER didn’t need a label and look where they are now. Their track “Now or Never†made Spotify’s Top 100 globally after releasing through TikTok’s SoundOn.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"How They Did It",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"They didn’t spend $20 a month for Distrokid. They used SoundOn for the sweet price of: ",nodeType:"text"},{data:{},marks:[{type:"italic"}],value:"free",nodeType:"text"},{data:{},marks:[],value:". “Now or Never†hit 1.5 million TikTok creations, 3.36 billion views, and landed at #30 on UK charts.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"How You Can Too",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Sign up on soundon.global (it’s free). All you need are your artist photo and ID. Once you’re in, upload your track at least 4 weeks before release. You’ll get 100% of your royalties the first year, 90% after that, and you keep your masters.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"},{data:{uri:"https://www.musicbusinessworldwide.com/tiktoks-soundon-touts-latest-success-with-viral-hit-now-or-never-by-tkandz-and-cxsper/"},content:[{data:{},marks:[{type:"underline"}],value:"[Read more on Music Business Worldwide]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"While You Were Making Music...",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:"💸 ",nodeType:"text"},{data:{uri:"https://www.billboard.com/pro/bts-comeback-how-much-money-k-pop-boy-band-new-music-make/"},content:[{data:{},marks:[{type:"underline"}],value:"BTS comeback money math (Billboard) [merch printers, start your engines]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:" ",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"🤖 ",nodeType:"text"},{data:{uri:"https://www.musicbusinessworldwide.com/spotify-to-develop-artist-first-ai-music-products-in-partnership-with-sony-umg-warner-merlin-and-believe/"},content:[{data:{},marks:[{type:"underline"}],value:"Spotify teams with majors on “artist-first†AI (MBW) [artist-first… says who?]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"🇺🇸 ",nodeType:"text"},{data:{uri:"https://www.digitalmusicnews.com/2025/10/17/trumps-tiktok-usa-deal-not-finished/"},content:[{data:{},marks:[{type:"underline"}],value:"TikTok’s USA deal still not finished (DMN) [wake me when the ink dries] ",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"One thing to do today:",nodeType:"text"},{data:{},marks:[],value:" ",nodeType:"text"},{data:{uri:"https://babyaud.io/freebies?srsltid=AfmBOoouzmypw30pPQZ6JaxlPjNNtFiNgD3t7LwxpctPN3YvUxZMOjlL"},content:[{data:{},marks:[{type:"underline"}],value:"Free plugins that don’t suck: Magic Dice, Pitch Drift, and Magic Switch from BABY Audio. A little random, a little retro, a lot of fun.",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[{type:"italic"}],value:"Today's edition by Jordan F.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"italic"}],value:"For indies who ship music, not excuses.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"}],nodeType:"document"},excerpt:"beatBread launches $100M Global Independence Fund for artist advances without label control. NINA introduces pay-your-fans promotion model while TikTok's SoundOn distribution propels Tkandz to UK Top 30 with free service and 100% first-year royalties.",category:"News",featuredImage:{url:"//images.ctfassets.net/b3nqx2d7xn8z/60GYEv5FxWY1cN1z6ApMhN/90a0f8884ad282e02bf505382c28e6c5/beatBreadâ__s__100M___NINAâ__s_Payouts.jpg",title:"Bypass newsletter header about beatBread funding and NINA's fan payment model"},publishDate:"2025-10-18T00:00-07:00",featured:!1,createdAt:"2025-10-19T12:30:05.140Z",updatedAt:"2025-10-19T12:30:05.140Z"},{id:"4JWnbqOvwZ4ykTpemLwi0d",title:"Free reach, free sounds — SoundCloud + Splice updates",slug:"free-reach-free-sounds-soundcloud-splice-updates",body:{data:{},content:[{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Bypass: Music Industry News for Independent Artists",nodeType:"text"}],nodeType:"heading-1"},{data:{},content:[{data:{},marks:[{type:"italic"}],value:"Wednesday edition - 4 min read",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"SoundCloud’s Latest Update = Free Reach (If You’re Smart)",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"What’s Up",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:`
Like everybody else, SoundCloud got social. New feeds show what your friends like and what’s trending nearby, with daily mixes (Liked by Your Crew, Hot for You) and a community Trending Trackwall.`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"So What",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:"I mean, sure - these ",nodeType:"text"},{data:{},marks:[{type:"italic"}],value:"are",nodeType:"text"},{data:{},marks:[],value:" listener features. But you can game them. Early likes, reposts, and comments can push your track into Liked by Your Crew, Hot for You, and the Trending Trackwall. Feels like they’re trying to bring back the SoundCloud era.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Now What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:"Use your email list. Ask fans to like and comment early, and set up a small circle to do the same. That early engagement is what triggers the new feeds.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"},{data:{uri:"https://techcrunch.com/2025/10/09/soundcloud-gets-more-social-by-adding-a-way-to-see-the-songs-your-friends-like/"},content:[{data:{},marks:[{type:"underline"}],value:"[Full story at TechCrunch]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Meet Splice INSTRUMENT, the New LABS",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"What's Up",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:"Spitfire’s LABS has a new mailing address: Splice INSTRUMENT. Same great sounds, shinier interface, and a few hundred free presets to get started. It runs on Mac, PC, and a mild anxiety about paywalls.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"So What",nodeType:"text"},{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:"It’s hard not to flinch when a free tool joins a company that’s all about subscriptions, but credit where credit’s due - Splice didn’t ruin it. If you were using LABS, the same sounds live inside INSTRUMENT, with a full catalog of 1,200+ sounds available for $12.99 per month (also included in Creator/Creator+).",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Now What",nodeType:"text"},{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:"Install INSTRUMENT now. If it beats your stock sounds, keep it in rotation and consider the $12.99 tier later. Bonus: new (free) instruments land monthly; download them once and they’re yours.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"},{data:{uri:"https://musically.com/2025/10/03/splice-is-now-officially-in-the-virtual-instruments-market/"},content:[{data:{},marks:[{type:"underline"}],value:"[Full story at Music Ally]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"How Often to Post on TikTok… Without Burning Out",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"What's Up",nodeType:"text"},{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:"Turns out you don’t need to live on TikTok. Buffer looked at over 11M+ TikToks from 150k accounts and found a sweet spot for posting content: all you need to do is post 2–5 times per week and you’ll see ~17% more views per post than once a week.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"So What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:"Quality + consistency beats spam, and the “more, more, more†thing barely moves the needle past a certain point. Make better stuff a few times a week and skip the grind entirely.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Now What",nodeType:"text"},{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:"Get a 2–5 posts/week rhythm going. Batch record when you can, schedule, and track saves/comments (not just views). Consistency is key, but the ",nodeType:"text"},{data:{},marks:[{type:"italic"}],value:"right",nodeType:"text"},{data:{},marks:[],value:" kind is what gets you seen.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"},{data:{uri:"https://musically.com/2025/10/10/data-from-11-mil-tiktoks-reveal-optimal-posting-frequency/"},content:[{data:{},marks:[{type:"underline"}],value:"[Full story at Music Ally]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"While You Were Making Music...",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:"🎤 ",nodeType:"text"},{data:{uri:"https://www.musicbusinessworldwide.com/sir-lucian-grainge-we-will-not-license-ai-models-that-use-artists-voices-without-consent/"},content:[{data:{},marks:[{type:"underline"}],value:"Universal’s Lucian Grainge says no to AI voice cloning [finally, a major label with boundaries]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"🎬 ",nodeType:"text"},{data:{uri:"https://www.digitalmusicnews.com/2025/10/14/netflix-and-spotify-team-up-for-video-podcast-partnership/"},content:[{data:{},marks:[{type:"underline"}],value:"Netflix + Spotify team up on video podcasts [the crossover nobody asked for but might watch anyway]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"💶 ",nodeType:"text"},{data:{uri:"https://www.digitalmusicnews.com/2025/10/14/ireland-makes-basic-income-for-artists-permanent/"},content:[{data:{},marks:[{type:"underline"}],value:"Ireland makes basic income for artists permanent [imagine getting paid just to create - wild concept, I know]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[{type:"italic"}],value:"Today's edition by Jordan F.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"italic"}],value:"For indies who ship music, not excuses.",nodeType:"text"},{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"}],nodeType:"document"},excerpt:"SoundCloud launches social discovery feeds with trending trackwall feature. Splice INSTRUMENT replaces Spitfire LABS offering free and premium sounds. Buffer research reveals optimal TikTok posting frequency of 2-5 times weekly for maximum engagement.",category:"News",featuredImage:{url:"//images.ctfassets.net/b3nqx2d7xn8z/oesjhl91l2BOETwm57QWJ/52b18bae92b5a103aebd873064858a89/Free_reach__free_sounds_â___SoundCloud___Splice_updates.jpg",title:"Bypass newsletter header about SoundCloud social features and Splice INSTRUMENT launch"},publishDate:"2025-10-15T00:00-07:00",featured:!1,createdAt:"2025-10-17T01:17:29.035Z",updatedAt:"2025-10-17T01:17:29.035Z"},{id:"6Dqs461LxJ8o6ZfuXJi7Af",title:"Two deadlines that matter",slug:"two-deadlines-that-matter",body:{data:{},content:[{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Bypass: Music Industry News for Independent Artists",nodeType:"text"}],nodeType:"heading-1"},{data:{},content:[{data:{},marks:[{type:"italic"}],value:"Friday edition - 2 min read",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Post Today, Get Seen Today (Yep, on Facebook)",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"What’s Up",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Facebook just tweaked its Reels algorithm to show you 50% more content that’s posted the same day you’re scrolling. Still don’t know what Zuck’s game is, but indies can only stand to gain from this change.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"So What",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Timing matters (again). Facebook used to serve you week-old Reels no one cared about anymore. Now, if you post about something that’s trending, there’s a real shot people will see it today instead of next Tuesday – or, who are we kidding, never.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Now What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Still batch-posting for your entire week? Cut that out. Post Reels the same day you want them seen. Drop that song clip, show snippet, or quick rant while it’s hot. For once, the algorithm is on your side. Don’t waste it.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"},{data:{uri:"https://techcrunch.com/2025/10/07/facebook-updates-its-algorithm-to-give-users-more-control-over-which-videos-they-see/"},content:[{data:{},marks:[{type:"underline"}],value:"[Full story at TechCrunch]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Say Thanks on Wrapped or Miss Your Chance",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"What's Up",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Spotify Wrapped 2025 is right around the corner, and this year it wants you. Artists can upload a 30-second vertical video that’ll appear in their top fans’ Wrapped. Deadline: November 14.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"So What",nodeType:"text"},{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:"Last year, 18,000 artists submitted Wrapped videos that reached millions of fans. This isn’t just a nice gesture, though. The real strategy here is exposing yourself to your most loyal fans. The ones who’ll buy your tickets or tell their friends about you.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Now What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:"Open Spotify for Artists and film your clip this week. Thirty seconds tops. Share a milestone or two, thank your fans, or tease what’s coming next year. Do it before November 14 or you’ll be thanking no one.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"},{data:{uri:"https://www.digitalmusicnews.com/2025/10/09/spotify-wrapped-2025-coming-soon/"},content:[{data:{},marks:[{type:"underline"}],value:"[Full story at Digital Music News]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Bandcamp Friday Returns: Keep 100% on Dec 5",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"What's Up",nodeType:"text"},{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:"For anyone who missed Bandcamp Friday last week (Oct 3), you got another shot on Dec 5. If you don’t know already, Bandcamp Friday is the TGIF for indies: you keep 100% of sales. Since it started, fans have spent over $131 million directly supporting artists. Nope, that’s not a typo.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"So What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:"Sure, December 5 is what, seven weeks away, but that’s the perfect amount of time to plan a drop that sells. If you’ve got music, merch, or a back catalog, that’s your day to make rent.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Now What",nodeType:"text"},{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:`Save the date. Feel free to tattoo “December 5†on your forehead (kidding, don’t). Plan out album/single releases, merch drops and how you’ll bundle something for fans to grab. Start hyping it two weeks early: “Buy on Dec 5, and I keep 100%.†People want to help – you just have to remind them.
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"},{data:{uri:"https://www.hypebot.com/hypebot/2025/10/bandcamp-friday-returns-today-waiving-fees-to-support-artists.html"},content:[{data:{},marks:[{type:"underline"}],value:"[Read more on Hypebot]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"While You Were Making Music...",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:"🎮 ",nodeType:"text"},{data:{uri:"https://musically.com/2025/10/09/forget-fake-streams-fake-fortnite-bots-are-an-issue-for-epic-games/"},content:[{data:{},marks:[{type:"underline"}],value:"Fake Fortnite bots are the new fake streams [different industry, same problem]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"🧑â€âš–ï¸ ",nodeType:"text"},{data:{uri:"https://www.musicbusinessworldwide.com/drake-lawsuit-against-umg-over-kendrick-lamars-not-like-us-dismissed-by-us-court/"},content:[{data:{},marks:[{type:"underline"}],value:"Drake’s “Not Like Us†case tossed [the beef didn’t start in court, Drake, take it outside]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"🦸â€â™‚ï¸ ",nodeType:"text"},{data:{uri:"https://www.musicbusinessworldwide.com/wmg-is-like-marvel-for-music-and-4-other-things-we-learned-from-robert-kyncls-bloomberg-interview/"},content:[{data:{},marks:[{type:"underline"}],value:"WMG’s CEO says it’s “Marvel for music†[great, where are the heroes?]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[{type:"italic"}],value:"Today's edition by Jordan F.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"italic"}],value:"For indies who ship music, not excuses.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"}],nodeType:"document"},excerpt:"Facebook Reels prioritizes same-day content with 50% more visibility. Spotify Wrapped artist videos deadline November 14 for reaching top fans. Bandcamp Friday returns December 5 offering 100% sales to independent artists.",category:"News",featuredImage:{url:"//images.ctfassets.net/b3nqx2d7xn8z/5ikjMTmJCDaJKpyN4KmVHy/545db0b64b7e10035b9695b838d047da/Two_deadlines_that_matter.jpg",title:"Bypass newsletter header about two important music industry deadlines"},publishDate:"2025-10-10T00:00-07:00",featured:!1,createdAt:"2025-10-11T02:16:05.810Z",updatedAt:"2025-10-11T02:16:05.810Z"},{id:"1iETvG7SKwly1T6RQtDgyy",title:"83% of Songwriters Have Unpaid Royalties + TikTok Superfans Pay 90%",slug:"83-of-songwriters-have-unpaid-royalties-tiktok-superfans-pay-90",body:{data:{},content:[{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Bypass: Music Industry News for Independent Artists",nodeType:"text"}],nodeType:"heading-1"},{data:{},content:[{data:{},marks:[{type:"italic"}],value:"Wednesday edition - 2 min read",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"83% of Songwriters Have Unpaid Money Sitting in MLC",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:`
What’s Up`,nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Seriously, guys. 83%? Talk about leaving money on the table. But good news: MUSO.AI just launched Catalog Audit, a tool that scans the MLC database to find your missing royalties.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"So What",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"You might be asking: what’s MLC, and why should you care? Well, MLC (Mechanical Licensing Collective) are the folks who collect your streaming royalties for songwriting. Take a look at these stats: 144 million tracks have problems, and 2.7 trillion streams' worth of royalties are sitting unclaimed. That could be one of your songs.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Now What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Go to MUSO.AI and create a free account to see a preview of your catalog issues. Upgrade to Pro ($12.50/month) to get the full report to see exactly where you’re missing out. Rimas Publishing (Bad Bunny’s publisher) is already using this to recover royalties, so do yourself a favor and claim what’s yours.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"},{data:{uri:"https://www.digitalmusicnews.com/2025/10/06/muso-ai-catalog-audit-mlc-mismatch-solution/"},content:[{data:{},marks:[{type:"underline"}],value:"[Full story at Digital Music News]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"TikTok Just Made It Worth Your Time (If You’re in the US/Canada)",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"What's Up",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Platforms love to underpay you – until they don’t. If you’re in the US/Canada, TikTok just juiced up its payouts for creator-musicians. We’re talking about a 70% rev-share by default + a 20% bonus path that leaves you with 90% of the revenue. ",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"So What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"This is subscription money from superfans willing to pay for exclusive content. But there’s a catch. In the US/Canada, TikTok actually doesn't list the minimum requirements; you'll get an in-app notification when your account qualifies.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Now What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"If you already have what TikTok is asking for, turn on Subscriptions. If you don’t, start growing on TikTok and turn on Subscriptions the second your account is eligible. Once you’re in, make the superfan tools do most of the heavy lifting. Offer one weekly perk (early drops, BTS, etc.) and keep delivering so those fans stick around.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"},{data:{uri:"https://www.digitalmusicnews.com/2025/10/07/tiktok-subscription-payouts-us/"},content:[{data:{},marks:[{type:"underline"}],value:"[Full story at Digital Music News]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Stop Waiting on Streams. Use EVEN. ",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"What's Up",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"We finally got Patreon for music – except it’s per drop, not monthly. EVEN (yep, ALL CAPS) lets you sell albums directly to superfans before streaming. Here’s where it gets good: you get paid daily, auto splits are handled for collabs, and all eligible sales are reported directly to Billboard via Luminate.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"So What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"If you can bring the crowd, EVEN gets you paid tomorrow, not in three months. And if you still haven’t started that email list, EVEN’s got you covered. You get your fans' contact info every time they make a purchase. ",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Now What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Here’s your list of chores: use EVEN for a 7-14 day pre-release window. Price the album at $8-15, add one bonus track (demo/stems/BTS), turn on auto-splits for collaborators, and point all your socials to the drop. Yeah, Bandcamp already does most of these things, but only EVEN can get you on the charts.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"},{data:{uri:"https://www.hypebot.com/hypebot/2025/10/how-evens-direct-to-fan-platform-works.html"},content:[{data:{},marks:[{type:"underline"}],value:"[Read more on Hypebot]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"While You Were Making Music...",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:"🤖 ",nodeType:"text"},{data:{uri:"https://musically.com/2025/10/07/taylor-swift-accused-of-using-ai-videos-in-showgirl-promo/"},content:[{data:{},marks:[{type:"underline"}],value:"Taylor Swift accused of using AI in ‘Showgirl’ promo [expect more “is it AI?†fights]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"📢 ",nodeType:"text"},{data:{uri:"https://www.digitalmusicnews.com/2025/10/07/california-passes-law-banning-loud-streaming-commercials/"},content:[{data:{},marks:[{type:"underline"}],value:"California bans loud streaming commercials [RIP jump-scare ads]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"🧑â€âš–ï¸ ",nodeType:"text"},{data:{uri:"https://www.musicbusinessworldwide.com/anthropic-must-face-music-publishers-copyright-claims-after-judge-denies-dismissal-motion/"},content:[{data:{},marks:[{type:"underline"}],value:"Anthropic must face publishers’ copyright claims [see you in court]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[{type:"italic"}],value:"Today's edition by Jordan F.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"italic"}],value:"For indies who ship music, not excuses.",nodeType:"text"}],nodeType:"paragraph"}],nodeType:"document"},excerpt:"83% of songwriters have unclaimed royalties in MLC database according to MUSO.AI audit tool. TikTok offers 90% revenue share for creator-musicians while EVEN platform enables direct-to-fan album sales with Billboard chart reporting.",category:"News",featuredImage:{url:"//images.ctfassets.net/b3nqx2d7xn8z/6Hg0HYQljvtuqq8Kw1cmCg/962e8609d77dc8bb432b0a35ae9db00e/83-_have_unpaid_royalties___TikTok_superfans_pay_90-.jpg",title:"83- have unpaid royalties + TikTok superfans pay 90-Bypass newsletter header about unclaimed music royalties and TikTok superfan payments"},publishDate:"2025-10-08T00:00-07:00",featured:!1,createdAt:"2025-10-08T23:02:01.226Z",updatedAt:"2025-10-08T23:02:01.226Z"},{id:"1J687xGAR77U3bLOgZy6rQ",title:"Spotify's CEO is out + Amazon's monthly Wrapped",slug:"spotifys-ceo-is-out-amazons-monthly-wrapped",body:{data:{},content:[{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Bypass: Music Industry News for Independent Artists",nodeType:"text"}],nodeType:"heading-1"},{data:{},content:[{data:{},marks:[{type:"italic"}],value:"Friday edition - 3 min read",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Ek Finally Reads the Room, Steps Back",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"What's Up",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"So what did it, Ek? The artist exodus? The AI fiasco? Spotify CEO Daniel Ek is stepping back from the heat. Come January 2026, he'll be Executive Chairman while two longtime execs (Gustav Söderström and Alex Norström) become co-CEOs. ",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"So What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"With Spotify being THE biggest music streaming platform in the world (unfortunately), leadership changes could affect your payouts, your visibility, everything. The timing’s sus, though. The announcement dropped the same day Sylvan Esso pulled their entire catalog (that’s nearly 1 billion streams) from Spotify. They’re not the first, though—artists have been jumping ship over Ek's investments in defense tech company Helsing.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Now What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Diversify yesterday. You need to be in a position where you can drop Spotify like a bad habit if you have to. Söderström and Norström have been running things since 2023, so it might be the same old rodeo. Either way, don’t keep all your streams in one pool.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"},{data:{uri:"https://techcrunch.com/2025/09/30/spotifys-founder-and-ceo-daniel-ek-is-stepping-down/"},content:[{data:{},marks:[{type:"underline"}],value:"[Full story at TechCrunch]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Amazon Music Insights: Wrapped, But Monthly",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"What’s Up",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Guess who just rolled out Wrapped, I mean, ",nodeType:"text"},{data:{},marks:[{type:"italic"}],value:"Insights",nodeType:"text"},{data:{},marks:[],value:". Amazon Music is finally catching up with every other streaming platform, launching recaps showing fans their top artists and songs. But here’s the twist: instead of it being at the end of every year, it’s every month.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"So What",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"You know that friend who won't shut up about an artist until you finally cave and listen? You need those fans. Every time that fan shares their Insight on Instagram, that's free promo. They do all the footwork and can reach followers you otherwise wouldn’t. ",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Now What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Download the Amazon Music app, check your own Insights (tap LIBRARY, then the Insights icon), then start encouraging fans to share theirs. Repost their highlights, shout out your top listeners, make it a thing. This is how you turn casual listeners into superfans.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"},{data:{uri:"https://www.hypebot.com/hypebot/2025/10/amazon-music-insights-are-a-win-for-artists-and-fans.html"},content:[{data:{},marks:[{type:"underline"}],value:"[Read more on Hypebot]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"The White House Wants Your Take On AI… No, Really",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"What's Up",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Someone’s finally listening to indies, and it’s not just their music. The White House opened a Request for Information on AI regulation, and the best part is, anyone can submit comments. Deadline: October 27, 2025.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"So What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"For once, you get a seat at the table ",nodeType:"text"},{data:{},marks:[{type:"italic"}],value:"before",nodeType:"text"},{data:{},marks:[],value:" the laws are written. The White House doesn’t do this often, so here are three things you need them to hear: (1) AI companies need to tell us what they stole – sorry, “trained onâ€. (2) Give us a real opt-out system, no BS. (3) “We need to beat China†won’t cut it this time. ",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Now What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Plot twist: the government just shut down (no funding = no accepting comments, I guess). But don’t let that stop you. Set a reminder for October 20 so you don't forget the October 27 deadline. Remember to bookmark ",nodeType:"text"},{data:{uri:"https://www.federalregister.gov/documents/2025/09/26/2025-18737/notice-of-request-for-information-regulatory-reform-on-artificial-intelligence"},content:[{data:{},marks:[{type:"underline"}],value:"this link",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:". Ten minutes could be the difference between you getting your songs protected and AI companies being protected.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"},{data:{uri:"https://www.hypebot.com/hypebot/2025/10/artists-voice-your-opinion-in-white-houses-rfi-on-future-ai-regulation.html"},content:[{data:{},marks:[{type:"underline"}],value:"[Read more on Hypebot]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"While You Were Making Music...",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:"🤦â€â™‚ï¸ ",nodeType:"text"},{data:{uri:"https://www.billboard.com/pro/rod-wave-last-lap-tour-lawsuit-promoter-sues-advance/"},content:[{data:{},marks:[{type:"underline"}],value:`Google wants AI regulators to "oversee outputs, not inputs" [translation: don't look at what we stole, look at what users made instead] `,nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"📊 ",nodeType:"text"},{data:{uri:"https://www.hypebot.com/hypebot/2025/10/global-music-revenue-grew-first-half-of-2025.html"},content:[{data:{},marks:[{type:"underline"}],value:"Global music revenue hit $18.3B in H1 2025, but DSPs are grabbing more value than artists [what? DSPs were screwing artists all this time? No…] ",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"âš–ï¸ ",nodeType:"text"},{data:{uri:"https://www.billboard.com/pro/rod-wave-last-lap-tour-lawsuit-promoter-sues-advance/"},content:[{data:{},marks:[{type:"underline"}],value:"Rod Wave keeping $27M in tour advances for shows he didn't do [your daily reminder to read contracts before buying jets]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[{type:"italic"}],value:"Today's edition by Jordan F.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"italic"}],value:"For indies who ship music, not excuses.",nodeType:"text"}],nodeType:"paragraph"}],nodeType:"document"},excerpt:"Spotify CEO Daniel Ek transitions to Executive Chairman role amid artist exodus over defense investments. Amazon Music launches monthly Insights feature while White House opens public comments on AI regulation affecting musicians. Key updates for independent artists.",category:"News",featuredImage:{url:"//images.ctfassets.net/b3nqx2d7xn8z/01qlDA9O6BXPn1fZ94WF90/7cc52425ccf9dbd2be47fae78d2739ff/Spotifys_CEO_is_out___Amazons_monthly_Wrapped.jpg",title:"Bypass newsletter header about Spotify CEO changes and Amazon Music monthly Wrapped feature"},publishDate:"2025-10-03T00:00-07:00",featured:!1,createdAt:"2025-10-04T00:37:46.694Z",updatedAt:"2025-10-04T00:37:46.694Z"},{id:"pueMapCf2q8qbKltJfHia",title:"Bypass: You could pay rent with music soon?! + Spotify fights AI",slug:"bypass-you-could-pay-rent-with-music-soon-spotify-fights-ai",body:{data:{},content:[{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Bypass: Music Industry News for Independent Artists",nodeType:"text"}],nodeType:"heading-1"},{data:{},content:[{data:{},marks:[{type:"italic"}],value:"Wednesday edition - 3 min read",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:`Spotify Fights AI Slop 
`,nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"What's Up",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Seems like all the criticism finally got to Spotify. They just announced they’ve removed 75 million AI spam tracks in the past year. All that slop was and is diluting YOUR royalty pool. Now they’re rolling out a new spam filter this fall that’ll tag bad uploads and stop recommending them to listeners. ",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"So What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"The spam filter matters, but Spotify’s also taking “content mismatch†seriously (finally). This is a long-standing issue with Spotify, where randos can upload slop straight to your Spotify profile. If you’ve been a victim, you know how frustrating this gets. It seriously tanks your stats because listeners are confused about the quality of your music.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Now What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Been impersonated? Then these new policies from Spotify might help you. They claim they’re “reducing wait times†for content mismatch forms - but we’ll have to see about that. ",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"},{data:{uri:"https://musically.com/2025/09/25/spotify-reveals-its-latest-measures-to-handle-ai-music/"},content:[{data:{},marks:[{type:"underline"}],value:"[Read more on HypeBot]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Being an Indie Artist Could Actually Pay",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"What’s Up",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Throw away those aprons, Rep. Rashida Tlaib just reintroduced the Living Wage for Musicians Act, which would set a penny per stream minimum. Right now, streaming is 84% of recorded music revenue but artists only make fractions of pennies after everyone takes their cut.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"So What",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Streaming platforms would have to add 50% of subscription fees (capped at $4-$10) plus 10% of ad revenue into a fund that pays you directly. Currently, you need 800K monthly streams just to make $15/hr. With this bill, you’ll get to live every musician's dream: finally paying rent.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Now What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Look, congress loves big tech more than struggling artists. So put some pressure on them by writing your congressional representative and asking them to co-sponsor the bill. Reps. Ocasio-Cortez, Omar, Thompson, and Ramirez already signed on. Even if it dies in committee (because let’s be real here), momentum matters for the next attempt.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"},{data:{uri:"https://musically.com/2025/08/19/living-wage-for-musicians-act-to-be-reintroduced-in-us-congress/"},content:[{data:{},marks:[{type:"underline"}],value:"[Read more on Music Ally]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Facebook Launches Free Fan-Building Tools",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"What's Up",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Facebook. That’s a name you wouldn’t think would pop up in music discovery. Meta recently launched free fan-building tools, one of which is Fan Challenges—a potential game changer (what's your game, Zuck?).",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"So What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Facebook isn’t just for grandmas posting wholesome memes. Meta’s betting on creator tools now - and Fan Challenges is honestly a great idea. It lets you encourage covers or remixes. That right there is organic growth. And with TikTok’s ownership still in limbo, betting your entire fanbase on one platform looks riskier every day.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Now What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Launch a Fan Challenge this week with the right hashtags. They are live on your Facebook page right now - just sign in.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:" ",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"},{data:{uri:"https://www.hypebot.com/hypebot/2025/09/facebook-marketing-for-musicians-new-tools.html"},content:[{data:{},marks:[{type:"underline"}],value:"[Read more on HypeBot]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"While You Were Making Music...",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:"🤖",nodeType:"text"},{data:{uri:"https://www.musicbusinessworldwide.com/universal-and-sony-music-partner-with-new-platform-to-detect-ai-music-copyright-theft-using-groundbreaking-neural-fingerprinting-technology/"},content:[{data:{},marks:[{type:"underline"}],value:"Universal and Sony launch AI detection tool [great to see major record labels protecting… major labels]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"📱 ",nodeType:"text"},{data:{uri:"https://www.hypebot.com/hypebot/2025/09/intagram-tops-3-billion-users-and-points-to-a-future-where-reel-and-dms-dominate.html"},content:[{data:{},marks:[{type:"underline"}],value:"Instagram hits 3 billion users as Reels and DMs dominate [somehow still not as useful as a 2014 SoundCloud comment section]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"👕 ",nodeType:"text"},{data:{uri:"https://www.musicbusinessworldwide.com/why-lawsuits-over-counterfeit-merch-are-on-the-rise/"},content:[{data:{},marks:[{type:"underline"}],value:"Counterfeit merch lawsuits are exploding [DUCK!!! There are suits flying here, there and everywhere]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[{type:"italic"}],value:"Today's edition by Jordan F.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"italic"}],value:"For indies who ship music, not excuses.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"}],nodeType:"document"},excerpt:"Spotify removes 75 million AI spam tracks and launches new filter. Living Wage for Musicians Act proposes penny-per-stream minimum while Facebook debuts Fan Challenges tool. Essential updates for independent artists navigating streaming economics and platform changes.",category:"News",featuredImage:{url:"//images.ctfassets.net/b3nqx2d7xn8z/pDV1GjRAh4JgWp0vARYNh/6e106121e219d3c5a49c0e01a626647a/Your_paragraph_text.jpg",title:"Bypass newsletter header about music streaming pay rates and Spotify AI spam filter"},publishDate:"2025-10-01T00:00-07:00",featured:!1,createdAt:"2025-10-01T12:30:55.093Z",updatedAt:"2025-10-01T12:30:55.093Z"},{id:"2A7avBY5cKakFWpYj2v8uh",title:"Bypass: YouTube's new tools + fan conversion + data rights",slug:"bypass-youtubes-new-tools-fan-conversion-data-rights",body:{data:{},content:[{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Bypass: Music Industry News for Independent Artists",nodeType:"text"}],nodeType:"heading-1"},{data:{},content:[{data:{},marks:[{type:"italic"}],value:"Friday edition - 2 min read",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"YouTube Music Launches Superfan Tools (Finally)",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"What's Up",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"YouTube finally caught up with its launch of countdown timers for your releases, exclusive thank-you videos for top fans, and merch drop features.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"So What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"For indies, super fans are 100x more valuable than casual listeners. Right now, YouTube is letting artists take advantage of that. Their new tools let you reward your biggest supporters with exclusive content and early access. ",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Now What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:"Set up your YouTube Music for Artists account if you haven't already. Start setting up countdown timers for your next releases and plan exclusive thank-you videos for your most engaged fans. Superfans are like your own unpaid marketing team, so give them a little something special from time to time.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"},{data:{uri:"https://www.musicbusinessworldwide.com/youtube-music-launches-new-tools-to-connect-artists-with-superfans/"},content:[{data:{},marks:[{type:"underline"}],value:"[Read more on MusicBusiness Worldwide]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"The Fan Conversion Toolkit: Temple by Groover",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"What’s Up",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"New tool alert: Temple by Groover is a new suite of digital tools that help you reach new listeners, engage with your fanbase, and centralize all your music, merch and social links ",nodeType:"text"},{data:{},marks:[{type:"italic"}],value:"(cool name, by the way; Amazon, take notes)",nodeType:"text"},{data:{},marks:[],value:".",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"So What",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Let’s be honest, getting streams is the easy part; getting actual fans is a whole other ball game. You might have thousands of monthly listeners, but how many email addresses do you have? Temple gives you microsites, email captures, and advertising tools to own your audience.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Now What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Check out Temple by Groover, especially if you’re already using Groover for playlist promotion. Start with their link-in-bio microsites to consolidate everything in one place. If you want a stable music career, relying on algorithms alone won’t cut it.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"},{data:{uri:"https://www.hypebot.com/hypebot/2025/09/temple-by-groover-new-tools-help-indie-artists-grow-an-audience.html"},content:[{data:{},marks:[{type:"underline"}],value:"[Read more on Hypebot]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"OpenPlay vs. The Data Kidnappers",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"What's Up",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"This rights management platform is raising millions. Sounds boring, but this is huge for indies. ",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"So What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"You know that nightmare where someone steals your keys to keep you locked outside your car, and you can't just leave without it, so you're stuck there? No? Well, it's the same thing distributors do. If you've been through this, you know how brutal it gets. OpenPlay is fighting the scummy behavior of distributors who trap you with your own data. ",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Now What",nodeType:"text"}],nodeType:"heading-3"},{data:{},content:[{data:{},marks:[],value:`
`,nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Start asking serious questions if you’re taking your music career seriously – who’s controlling my data right now? If you don't know, that's exactly what OpenPlay is solving. Word is they’re dropping new tools soon.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"",nodeType:"text"},{data:{uri:"https://musically.com/2025/09/16/openplay-raises-a-new-multi-million-dollar-funding-round/"},content:[{data:{},marks:[{type:"underline"}],value:"[Full story at Music Ally]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"While You Were Making Music...",nodeType:"text"}],nodeType:"heading-2"},{data:{},content:[{data:{},marks:[],value:"📰 ",nodeType:"text"},{data:{uri:"https://www.billboard.com/pro/xania-monet-ai-artist-million-dollar-record-deal-what-mean/"},content:[{data:{},marks:[{type:"underline"}],value:"Xania Monet (AI artist) signs million-dollar record deal [wait, how would concerts work?]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"🔊 ",nodeType:"text"},{data:{uri:"https://www.digitalmusicnews.com/2025/09/18/kali-uchis-pulls-d4vd-collab/"},content:[{data:{},marks:[{type:"underline"}],value:"Kali Uchis pulls D4vd collaboration [when features go wrong]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"ðŸƒâ€â™€ï¸ ",nodeType:"text"},{data:{uri:"https://www.billboard.com/pro/poppy-amy-lee-courtney-laplante-end-of-you-hard-rock-songs/"},content:[{data:{},marks:[{type:"underline"}],value:"Poppy collaborates with Amy Lee and Courtney LaPlante [talk about a generational run]",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[{type:"bold"}],value:"One Thing To Do Today: ",nodeType:"text"},{data:{uri:"https://labs.spitfireaudio.com/"},content:[{data:{},marks:[{type:"underline"}],value:"Who says you can't afford an orchestra? Download Spitfire Audio's LABS collection and add professional orchestral elements to your tracks.",nodeType:"text"}],nodeType:"hyperlink"},{data:{},marks:[],value:"",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[],nodeType:"hr"},{data:{},content:[{data:{},marks:[{type:"italic"}],value:"Today's edition by Jordan F.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[{type:"italic"}],value:`For indies who ship music, not excuses.
`,nodeType:"text"}],nodeType:"paragraph"}],nodeType:"document"},excerpt:"YouTube Music launches countdown timers and superfan features for artists. Temple by Groover offers new fan conversion tools while OpenPlay raises millions to fight distributor data control. Essential updates for independent musicians building direct fan relationships.",category:"News",featuredImage:{url:"//images.ctfassets.net/b3nqx2d7xn8z/3hWAWFZxZ5j2JWGw5TuEZm/2ed859f2ece8b7c9d957e4e8309cddc6/YouTube-s_new_tools___fan_conversion___data_rights.jpg",title:"Bypass newsletter header about YouTube Music tools, fan conversion, and artist data rights"},publishDate:"2025-09-26T00:00-07:00",featured:!1,createdAt:"2025-09-26T07:30:04.053Z",updatedAt:"2025-09-26T07:30:04.053Z"},{id:"U3C9icaqjculieghca7aA",title:"Bypass: Why going viral won't save you + Spotify news",slug:"bypass-why-going-viral-wont-save-you-spotify-news",body:{nodeType:"document",data:{},content:[{nodeType:"heading-1",data:{},content:[{nodeType:"text",value:"Bypass: Music Industry News for Independent Artists",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Tuesday edition - 2 min read",marks:[{type:"italic"}],data:{}}]},{nodeType:"hr",data:{},content:[]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"heading-2",data:{},content:[{nodeType:"text",value:`Viral ≠ Fans
`,marks:[{type:"bold"}],data:{}}]},{nodeType:"heading-2",data:{},content:[{nodeType:"text",value:"What's Up",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
`,marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"New MIDiA Research data just dropped a bomb. Turns out “go viral and you’ll make it†is a big, fat lie. 48% of people who listen to music on social media never actually stream it. ",marks:[],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"So What",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
`,marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Ever wonder why some artists get their moment of virality and then disappear? Once listeners hear a snippet enough times, they’re never going to play the full song. Young listeners (16-24) are especially guilty of this - they discover but don’t go on to become actual fans.",marks:[],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"Now What",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
`,marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Don’t get it twisted, viral moments do work… ",marks:[],data:{}},{nodeType:"text",value:"sometimes",marks:[{type:"italic"}],data:{}},{nodeType:"text",value:". But getting real fans takes strategy. Make clips unsatisfying on purpose. Think of this like leading your listeners to where you want them. You can also directly tell them to listen to the full song instead of hoping they’ll check it out.",marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"",marks:[],data:{}},{nodeType:"hyperlink",data:{uri:"https://www.hypebot.com/hypebot/2025/09/all-eyes-no-ears-new-midia-data-shows-why-virality-is-not-building-fandom.html"},content:[{nodeType:"text",value:"[Read more on Hypebot]",marks:[{type:"underline"}],data:{}}]},{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"hr",data:{},content:[]},{nodeType:"heading-2",data:{},content:[{nodeType:"text",value:`TikTok Ban Delayed: Use it or Lose it
`,marks:[{type:"bold"}],data:{}}]},{nodeType:"heading-2",data:{},content:[{nodeType:"text",value:"What’s Up",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
`,marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"So, the TikTok ban was extended again. Why not just lift the ban at this point? Either way, this is good news for indies who want to get the most out of the platform before it's really gone. ",marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
`,marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"So What",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
`,marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Indies have another three months (or more) to milk the platform for discovery. There are talks about a potential sale to the US, but don’t count on that. Who knows what the algorithm might be like under new ownership?",marks:[],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"Now What",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
`,marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Keep using TikTok for discovery, but use this breathing room to make backup plans. Get as many email addresses as possible from your TikTok traffic and drive followers to platforms you control. Treat this like extra time, not a permanent solution.",marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"",marks:[],data:{}},{nodeType:"hyperlink",data:{uri:"https://musically.com/2025/09/17/tiktok-us-sale-or-ban-deadline-has-been-extended-to-16-december/"},content:[{nodeType:"text",value:"[Full story at Music Ally]",marks:[{type:"underline"}],data:{}}]},{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"hr",data:{},content:[]},{nodeType:"heading-2",data:{},content:[{nodeType:"text",value:`Spotify Finally Kills Shuffle Hell
`,marks:[{type:"bold"}],data:{}}]},{nodeType:"heading-2",data:{},content:[{nodeType:"text",value:"What's Up",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
`,marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Spotify just scrapped the shuffle-only model for mobile free-tier users. Yes, you heard that right. Free users make up about 60% of users on the platform - it makes you wonder who came up with this thing in the first place.",marks:[],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"So What",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
`,marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"The shuffle-only thing was basically a paywall that hurt indies. Major artists get radio plays and editorial playlists; you only have social media. You can now share your music with anyone without having to worry if they have a Spotify Premium plan. ",marks:[],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"Now What",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
`,marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Make sure your Spotify metadata is up-to-date. Free users aren’t waiting to start searching for music; they’re doing it now. Test this for yourself – search for your own tracks using a free account.",marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"",marks:[],data:{}},{nodeType:"hyperlink",data:{uri:"https://www.musicbusinessworldwide.com/spotify-scraps-shuffle-restriction-for-users-of-free-tier/"},content:[{nodeType:"text",value:"[Read more on MusicBusiness Worldwide]",marks:[{type:"underline"}],data:{}}]},{nodeType:"text",value:`
`,marks:[],data:{}}]},{nodeType:"heading-2",data:{},content:[{nodeType:"text",value:"While You Were Making Music...",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"🎬 ",marks:[],data:{}},{nodeType:"hyperlink",data:{uri:"https://musically.com/2025/09/22/indian-electronic-musician-ritviz-releases-ai-music-video/"},content:[{nodeType:"text",value:"Indian artist Ritviz drops AI-generated music video [we got AI music videos before GTA 6?!]",marks:[{type:"underline"}],data:{}}]},{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"🎫 ",marks:[],data:{}},{nodeType:"hyperlink",data:{uri:"https://www.hypebot.com/hypebot/2025/09/radiohead-tickets-listed-on-secondary-sites-despite-bands-efforts.html"},content:[{nodeType:"text",value:"Radiohead tickets hit secondary sites despite band's anti-scalping efforts [scalpers proving they're creeps and weirdos since 1992]",marks:[{type:"underline"}],data:{}}]},{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"âš–ï¸ ",marks:[],data:{}},{nodeType:"hyperlink",data:{uri:"https://musically.com/2025/09/22/labels-amend-suno-lawsuit-and-focus-on-source-of-training-data/"},content:[{nodeType:"text",value:"Labels amend Suno lawsuit to focus on AI training data sources [hey, Suno, “I found it on the internet†isn’t legal defense]",marks:[{type:"underline"}],data:{}}]},{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"hr",data:{},content:[]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Today's edition by Jordan F.",marks:[{type:"italic"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"For indies who ship music, not excuses.",marks:[{type:"italic"}],data:{}}]}]},excerpt:"New research shows viral TikTok music doesn't convert to streaming fans. Spotify ends shuffle-only mode for free users while TikTok ban gets extended, giving independent artists more discovery time.",category:"News",featuredImage:{url:"//images.ctfassets.net/b3nqx2d7xn8z/65NyL2TJ2hC4Y80oyd6gPq/d24e9d0c38274aa3ecef1ca95a7e01b9/Why_going_viral_won-t_save_you___Spotify_news.jpg",title:"Bypass newsletter header about viral music not converting to fans and Spotify news"},publishDate:"2025-09-23T00:00-07:00",featured:!1,createdAt:"2025-09-24T00:25:29.887Z",updatedAt:"2025-09-24T00:29:36.553Z"},{id:"91j7wtHobD28y948s9g4c",title:"Bypass: Deezer fights AI + Indies ditch Spotify",slug:"bypass-deezer-fights-ai-indies-ditch-spotify",body:{nodeType:"document",data:{},content:[{nodeType:"heading-1",data:{},content:[{nodeType:"text",value:"Bypass: Music Industry News for Independent Artists",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Thursday edition - 2 min read",marks:[{type:"italic"}],data:{}}]},{nodeType:"hr",data:{},content:[]},{nodeType:"heading-2",data:{},content:[{nodeType:"text",value:"Deezer Fights Back Against the AI Invasion",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"What's Up",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
`,marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Wow… a streaming platform that actually cares. Deezer has been tracking AI-generated music since the beginning of this year. As of September, 30,000 AI tracks are being uploaded daily. That's 28% of all uploads, up from just 10% in January.",marks:[],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"So What",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
`,marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Deezer is the ONLY platform that tags 100% of AI-generated content and removes these tracks from the algorithm. That tells you all you need to hear ",marks:[],data:{}},{nodeType:"text",value:"(looking at you, Spotify)",marks:[{type:"italic"}],data:{}},{nodeType:"text",value:". If you’re planning to join the Spotify exodus, Deezer might be your best bet.",marks:[],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"Now What",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Add Deezer to your distribution, if you haven’t already. It’s definitely the only platform that protects human artists. Going forward, consider working with platforms that are fighting for you, not against you.",marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
`,marks:[],data:{}},{nodeType:"hyperlink",data:{uri:"https://www.digitalmusicnews.com/2025/09/11/deezer-ai-tracks-daily-stat/"},content:[{nodeType:"text",value:"[Full story at Digital Music News]",marks:[{type:"underline"}],data:{}}]},{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"hr",data:{},content:[]},{nodeType:"heading-2",data:{},content:[{nodeType:"text",value:"Why These Indies Can Afford to Leave Spotify",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"heading-2",data:{},content:[{nodeType:"text",value:"Who Did It",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
`,marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Young Widows just joined the growing list of indies ditching Spotify completely. So far, King Gizzard & The Lizard Wizard, Xiu Xiu, Deerhoof, Hotline TNT and now Young Widows are protesting Daniel Ek’s $700+ million investment in military AI company Helsing. But how can they afford to do this? ",marks:[],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"How They Did It",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
`,marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"They know not to depend on one platform, especially Spotify. Think Bandcamp, vinyl sales, live shows, and direct fan relationships. Young Widows weren’t afraid to ask their fans for support. As they put it, “if you truly value an artist, buy their records, go to their shows, and support them directly.â€",marks:[],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"How You Can Too",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
`,marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Start building multiple streams of income: create a strong Bandcamp presence, develop live performance income, and invest in physical merch. Basic stuff, but these artists proved it works.",marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"",marks:[],data:{}},{nodeType:"hyperlink",data:{uri:"https://www.digitalmusicnews.com/2025/09/11/young-widows-spotify-removal/"},content:[{nodeType:"text",value:"[Full Story at Digital Music News]",marks:[{type:"underline"}],data:{}}]},{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"hr",data:{},content:[]},{nodeType:"heading-2",data:{},content:[{nodeType:"text",value:"TikTok Europe Hits 200M Monthly Users",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"heading-2",data:{},content:[{nodeType:"text",value:"What's Up",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
`,marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"TikTok just reminded us why it is the king of music discovery. They announced they’ve reached a significant milestone: over 200 million monthly users in Europe – and that’s nothing to scoff at. ",marks:[],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"So What",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
`,marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Europe is a huge continent, and according to TikTok, roughly one in four citizens in the region use the app monthly. That’s an untapped opportunity if I ever saw one. Your songs can reach multiple countries in the region simultaneously.",marks:[],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"Now What",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
`,marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Set up TikTok for Artists. You’ll get an idea of which European country vibes with your music. If people from Spain are listening to your songs more than anyone else, try to figure out why and appeal to that.",marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"",marks:[],data:{}},{nodeType:"hyperlink",data:{uri:"https://www.musicbusinessworldwide.com/tiktok-tops-200-million-monthly-users-in-europe/"},content:[{nodeType:"text",value:"[Read more on MusicBusiness Worldwide]",marks:[{type:"underline"}],data:{}}]},{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"heading-2",data:{},content:[{nodeType:"text",value:"While You Were Making Music...",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"🆠",marks:[],data:{}},{nodeType:"hyperlink",data:{uri:"https://www.billboard.com/music/chart-beat/kpop-demon-hunters-another-aria-chart-double-1236065204/"},content:[{nodeType:"text",value:"Netflix’s KPop Demon Hunters dominates Aussie charts [maybe they’ll start a record label after this]",marks:[{type:"underline"}],data:{}}]},{nodeType:"text",value:" ",marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"🎤 ",marks:[],data:{}},{nodeType:"hyperlink",data:{uri:"https://musically.com/2025/09/12/on-the-radar-radio-continues-international-expansion-with-uk-debut/"},content:[{nodeType:"text",value:"On the Radar Radio brings freestyles to the UK [guess they did cross the pond]",marks:[{type:"underline"}],data:{}}]},{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"âš–ï¸ ",marks:[],data:{}},{nodeType:"hyperlink",data:{uri:"https://www.digitalmusicnews.com/2025/09/12/neil-young-lawsuit-chrome-hearts/"},content:[{nodeType:"text",value:"Chrome Hearts is suing Neil Young and his band, the Chrome Hearts for trademark infringement [well… good luck, Neil; you’re gonna need it]",marks:[{type:"underline"}],data:{}}]},{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"hr",data:{},content:[]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Today's edition by Jordan F.",marks:[{type:"italic"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
For indies who ship music, not excuses.`,marks:[{type:"italic"}],data:{}}]}]},excerpt:"Deezer removes AI-generated music from algorithms while indie artists leave Spotify for Bandcamp and direct sales. TikTok Europe's 200 million users create new music discovery opportunities for independent musicians.",category:"News",featuredImage:{url:"//images.ctfassets.net/b3nqx2d7xn8z/3iiGFVASeZNAIikbL0yT72/f6e6f83a15de1c7e09ce9b95e0255879/Deezer_fights_AI___Indies_ditch_Spotify.jpg",title:"Bypass newsletter header about Deezer fighting AI music and indies leaving Spotify"},publishDate:"2025-09-18T00:00-07:00",featured:!1,createdAt:"2025-09-18T07:30:09.163Z",updatedAt:"2025-09-24T00:30:25.135Z"},{id:"6Nqo9xE8IlJS4P3ndtOf3b",title:"Bypass: Coda promises 100x payouts + RADAR launched Teen Jesus",slug:"bypass-coda-promises-100x-payouts-radar-launched-teen-jesus",body:{nodeType:"document",data:{},content:[{nodeType:"heading-1",data:{},content:[{nodeType:"text",value:"Bypass: Music Industry News for Independent Artists",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Wednesday edition - 3 min read",marks:[{type:"italic"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"",marks:[{type:"italic"}],data:{}}]},{nodeType:"hr",data:{},content:[]},{nodeType:"heading-2",data:{},content:[{nodeType:"text",value:"Coda Promises What Spotify Won’t",marks:[{type:"bold"}],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"What's Up",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
`,marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Move out of the way Spotify, there’s a new kid on the block. MassiveMusic’s Coda Music just launched with a big claim: you can earn up to 100x what other streaming platforms pay you now. The deal’s so good that even Eric Clapton and Evanescence signed up. ",marks:[],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"So What",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
`,marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"It’s pretty rare for a streaming platform to put artists first, let alone indies. But since it’s backed by Merlin, the major digital rights agency for independent artists, this isn’t your typical startup BS. Here’s how it works: you get a custom link, and every time fans sign up using that link, you get a percentage of their monthly subscription. ",marks:[],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"Now What",marks:[{type:"bold"}],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"Check if Coda is accepting new artists in your region. If you haven’t already, start building your email list to recruit fans for when you have access. You will be leagues ahead of other artists who are still making pennies per stream on other platforms. ",marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"",marks:[],data:{}},{nodeType:"hyperlink",data:{uri:"https://www.digitalmusicnews.com/2025/09/02/coda-massivemusic-artist-friendly-model/"},content:[{nodeType:"text",value:"[Full story at Digital Media News]",marks:[{type:"underline"}],data:{}}]},{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"hr",data:{},content:[]},{nodeType:"heading-2",data:{},content:[{nodeType:"text",value:"How RADAR Launched Teen Jesus",marks:[{type:"bold"}],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"Who Did It",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
`,marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Searching, searching",marks:[{type:"italic"}],data:{}},{nodeType:"text",value:"… found. Let’s be honest, Spotify has barely done anything to help indie artists, but once in a while, they get it right. Their RADAR program took Australian indie rock band Teen Jesus and the Jean Teasers from being indie unknowns to opening for Pearl Jam.",marks:[],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"How They Did It",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
`,marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"After just six months of joining RADAR, Teen Jesus witnessed a 224% jump in monthly listeners and 54% follower growth. They didn’t start with RADAR, though – they worked their way up through other programs like Fresh Finds and GLOW to get to where they are. ",marks:[],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"How You Can Too",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
`,marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"If you want to open for Pearl Jam ",marks:[],data:{}},{nodeType:"text",value:"(I mean, who doesn’t)",marks:[{type:"italic"}],data:{}},{nodeType:"text",value:", take a page out of Teen Jesus’ book. Focus on building genuine early listeners who might just be Spotify’s tastemakers. Release tracks consistently, promote authentically and track your growth. You can’t game the system here – it’s all organic growth.",marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"",marks:[],data:{}},{nodeType:"hyperlink",data:{uri:"https://www.musicbusinessworldwide.com/spotify-says-1000-artists-have-featured-in-its-radar-program-and-have-racked-up-338bn-streams-on-the-platform/"},content:[{nodeType:"text",value:"[Read more on MusicBusiness Worldwide]",marks:[{type:"underline"}],data:{}}]},{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"hr",data:{},content:[]},{nodeType:"heading-2",data:{},content:[{nodeType:"text",value:"The Amazon Music Opportunity You're Missing",marks:[{type:"bold"}],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"What's Up",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
`,marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Another week, another new AI feature. It’s getting hard to keep up. Amazon Music just launched its new Monday playlist generator with the most corporate-sounding name ever, ",marks:[],data:{}},{nodeType:"text",value:"“Weekly Vibeâ€",marks:[{type:"italic"}],data:{}},{nodeType:"text",value:". If you can look past the cheesy name, though, there’s a real opportunity to promote your music.",marks:[],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"So What",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
`,marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Unlike Spotify’s editorial-heavy approach, being featured on the Weekly Vibe playlist is entirely up to Amazon’s algorithm, which might not be a bad thing. We don’t know how Amazon’s algorithm works, but it definitely beats waiting around for playlist editors to finish sipping their coffee.",marks:[],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"Now What",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
`,marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Start uploading your tracks to Amazon Music if you haven’t already. Keep an eye out for the songs that perform the best and double down on similar styles. The real opportunity here is having your music in front of listeners who might not have found you on oversaturated Spotify.",marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"",marks:[],data:{}},{nodeType:"hyperlink",data:{uri:"https://techcrunch.com/2025/09/08/amazon-musics-new-ai-feature-generates-personalized-playlists-every-monday/"},content:[{nodeType:"text",value:"[Full Story at TechCrunch]",marks:[{type:"underline"}],data:{}}]},{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"heading-2",data:{},content:[{nodeType:"text",value:"While You Were Making Music...",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"🎧 ",marks:[],data:{}},{nodeType:"hyperlink",data:{uri:"https://www.billboard.com/pro/spotify-hifi-lossless-audio-release-plan-cost-feature/"},content:[{nodeType:"text",value:"Spotify’s Hifi finally arrives [it only took you guys 4 years]",marks:[{type:"underline"}],data:{}}]},{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"â–¶ï¸ ",marks:[],data:{}},{nodeType:"hyperlink",data:{uri:"https://routenote.com/blog/ed-sheeran-brings-new-album-play-to-fans-via-tiktoks-exclusive-livestream/"},content:[{nodeType:"text",value:"Ed Sheeran hits ‘Play’ on TikTok [showing everyone how it’s done] ",marks:[{type:"underline"}],data:{}}]},{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"👕 ",marks:[],data:{}},{nodeType:"hyperlink",data:{uri:"https://www.musicbusinessworldwide.com/twenty-one-pilots-sue-temu-for-trademark-infringement-over-blatant-copies-of-merch/"},content:[{nodeType:"text",value:"Twenty One Pilots sues Temu for merch knockoffs [team up, lawyer up]",marks:[{type:"underline"}],data:{}}]},{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"hr",data:{},content:[]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"",marks:[{type:"italic"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Today's edition by Jordan F.",marks:[{type:"italic"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
For indies who ship music, not excuses.`,marks:[{type:"italic"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
`,marks:[],data:{}}]}]},excerpt:"Independent artists can earn 100x more on Coda Music streaming platform, Spotify RADAR program success strategies, and Amazon Music's Weekly Vibe algorithmic playlist opportunities for unsigned musicians.",category:"News",featuredImage:{url:"//images.ctfassets.net/b3nqx2d7xn8z/1h3Pk71V8LQKVi1pUEIvS7/d6ca52b78bfa0221acd35646ea24eefc/Coda_promises_100x_payouts___RADAR_launched_Teen_Jesus.jpg",title:"Bypass newsletter header featuring Coda Music 100x payouts and Spotify RADAR Teen Jesus stories"},publishDate:"2025-09-17T00:00-07:00",featured:!1,createdAt:"2025-09-17T14:33:45.198Z",updatedAt:"2025-09-24T00:30:44.856Z"},{id:"7fT1oSTtNDBaXwFsTxdjFv",title:"Bypass: Spotify DMs Are Here + Why TikTok's Panicking About Music",slug:"bypass-spotify-dms-are-here-why-tiktoks-panicking-about-music",body:{nodeType:"document",data:{},content:[{nodeType:"heading-1",data:{},content:[{nodeType:"text",value:"Bypass: Music Industry News for Independent Artists",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Wednesday edition - 2 min read",marks:[{type:"italic"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
This is the first edition of Bypass—our new 2-minute news brief for independent artists.`,marks:[{type:"italic"}],data:{}}]},{nodeType:"hr",data:{},content:[]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"heading-2",data:{},content:[{nodeType:"text",value:"TikTok Goes All-In on Music Discovery",marks:[{type:"bold"}],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"What's Up",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"TikTok just launched its first global music campaign, ",marks:[],data:{}},{nodeType:"text",value:"“See Where Music Takes You.â€",marks:[{type:"italic"}],data:{}},{nodeType:"text",value:" Pretty sure this has nothing to do with the ban coming up in mid-September ",marks:[],data:{}},{nodeType:"text",value:"(cough, cough)",marks:[{type:"italic"}],data:{}},{nodeType:"text",value:".",marks:[],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"So What",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Regardless, TikTok is betting big on music discovery. They’re showcasing artists like Ravyn Lenae, who was able to amass 500 million streams using their platform. Basically, TikTok is saying, ",marks:[],data:{}},{nodeType:"text",value:"“Use us before we’re gone.â€Â Â ",marks:[{type:"italic"}],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"Now What ",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"This is what you need to do: post your music snippets daily to exploit the algorithm. Features like",marks:[],data:{}},{nodeType:"text",value:" “Add to Music Appâ€",marks:[{type:"italic"}],data:{}},{nodeType:"text",value:" allow users to easily save your songs to platforms like Spotify and Apple Music. This way, you can turn those viral moments into actual money.",marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"",marks:[],data:{}},{nodeType:"hyperlink",data:{uri:"https://www.digitalmusicnews.com/2025/08/28/tiktok-ad-blitz-music-discovery-campaign/"},content:[{nodeType:"text",value:"[Full story at Digital Media News]",marks:[{type:"underline"}],data:{}}]},{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"hr",data:{},content:[]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"heading-2",data:{},content:[{nodeType:"text",value:"Spotify Wants to Be TikTok (But Baby Steps, Please)",marks:[{type:"bold"}],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"What’s Up",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Is it me, or does every app want to be social media these days? Spotify just launched DMs as a way to “drive hype†",marks:[],data:{}},{nodeType:"text",value:"(I mean, it took you long enough)",marks:[{type:"italic"}],data:{}},{nodeType:"text",value:". ",marks:[],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"So What",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"When you think about it, this could help indie artists stay connected with fans about new music. Except Spotify is only rolling out DMs for fan-to-fan communications right now (yay). An artist messaging feature might be the next logical step for their promised “Superfan plan,†though, but no promises on timing.",marks:[],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"Now What",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"In the meantime, start planning your DM strategy in case artist messaging does roll out. Study how other artists use Instagram DMs and Bandsintown messaging. Don’t forget your email list; it’s one of the best ways of reach fans directly.",marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"",marks:[],data:{}},{nodeType:"hyperlink",data:{uri:"https://www.hypebot.com/hypebot/2025/08/spotify-adds-dms.html"},content:[{nodeType:"text",value:"[Read more on Hypebot]",marks:[{type:"underline"}],data:{}}]},{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"hr",data:{},content:[]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"heading-2",data:{},content:[{nodeType:"text",value:"Your Merch Orders Just Got Complicated",marks:[{type:"bold"}],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"What's Up",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Merch sales just hit a wall. Bandcamp warns users that some international carriers are pausing shipments to the US because of tariffs.",marks:[],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"So What",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Physical sales are stuck, but digital isn’t. The shipping freeze could actually push more fans to instant downloads and streaming. When fans can't wait for vinyl, they'll pay for the digital instead. That way, you can get sales right now - not to mention better margins.",marks:[],data:{}}]},{nodeType:"heading-3",data:{},content:[{nodeType:"text",value:"Now What",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Take advantage of digital sales. Also, check with international suppliers about shipping timelines. If the timeline drags out, consider switching to domestic fulfilment until things clear up.",marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"",marks:[],data:{}},{nodeType:"hyperlink",data:{uri:"https://www.digitalmusicnews.com/2025/08/28/us-tariffs-merch-order-chaos/"},content:[{nodeType:"text",value:"[Full story at Digital Music News]",marks:[{type:"underline"}],data:{}}]},{nodeType:"text",value:`
`,marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"heading-2",data:{},content:[{nodeType:"text",value:"While You Were Making Music...",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"🤠",marks:[],data:{}},{nodeType:"hyperlink",data:{uri:"https://www.billboard.com/video/lil-nas-x-speaks-out-after-being-arrested/"},content:[{nodeType:"text",value:'Lil Nas X speaks out after recent arrest [guess that "Old Town Road" got a little bumpy]',marks:[{type:"underline"}],data:{}}]},{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"âš–ï¸ ",marks:[],data:{}},{nodeType:"hyperlink",data:{uri:"https://www.digitalmusicnews.com/2025/08/29/benson-boone-ceremony-of-roses-lawsuit/"},content:[{nodeType:"text",value:"Sony sues counterfeit Benson Boone merch sellers ",marks:[{type:"underline"}],data:{}},{nodeType:"text",value:"[some things never change]",marks:[{type:"underline"},{type:"italic"}],data:{}}]},{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"💸 ",marks:[],data:{}},{nodeType:"hyperlink",data:{uri:"https://www.hypebot.com/hypebot/2025/08/soundexchange-distributions-topped-242-million-in-q2-2025.html"},content:[{nodeType:"text",value:"$242M in royalties paid out by SoundExchange ",marks:[{type:"underline"}],data:{}},{nodeType:"text",value:"[check if they owe you money]",marks:[{type:"underline"},{type:"italic"}],data:{}}]},{nodeType:"text",value:`
`,marks:[],data:{}}]},{nodeType:"hr",data:{},content:[]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"",marks:[{type:"bold"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"One Thing To Do Today:",marks:[{type:"bold"}],data:{}},{nodeType:"text",value:" ",marks:[],data:{}},{nodeType:"hyperlink",data:{uri:"https://www.uaudio.com/blogs/press/universal-audio-offers-free-la-2a-plug-in-during-labor-day-flash-sale"},content:[{nodeType:"text",value:"Free compressor, anyone? Universal Audio celebrates Labor Day by giving away its LA-2A compressor plugin for free.",marks:[{type:"underline"}],data:{}}]},{nodeType:"text",value:"",marks:[],data:{}}]},{nodeType:"hr",data:{},content:[]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Today's edition by Jordan F.",marks:[{type:"italic"}],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:`
For indies who ship music, not excuses.`,marks:[{type:"italic"}],data:{}}]}]},excerpt:"Independent music industry news covering TikTok's new music discovery campaign, Spotify DMs for artists, and how US tariffs affect merchandise shipping. Actionable insights for unsigned artists navigating platform changes.",category:"News",featuredImage:{url:"//images.ctfassets.net/b3nqx2d7xn8z/Jh5FPtOAtJ4g3XTTvy44H/bc6715c0ad1e4c472c12baeb45286e1d/bypass_sep_3_2025_spotify_tiktok_2.jpg",title:"Bypass logo and header for music industry news brief with article title about Spotify DMs and TikTok"},publishDate:"2025-09-03T00:00-07:00",featured:!1,createdAt:"2025-09-03T16:37:58.239Z",updatedAt:"2025-09-03T17:04:40.151Z"},{id:"7K2P6aKXnvRPX39RyaiY3U",title:"Summer Update: 200K Submissions & Bug Fixes",slug:"summer-update-200k-submissions-and-bug-fixes",body:{data:{},content:[{data:{},content:[{data:{},marks:[],value:"I hope you're all getting some sun and inspiration wherever you're at (and if you're in the Southern Hemisphere, I hope winter is treating you kindly!). We've been busy making music, squashing bugs, and sanding down some rough edges in the Playlist Partner code. Plus, we have a milestone to celebrate!",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"First, we've addressed several bugs that you’ve reported, including:",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},content:[{data:{},content:[{data:{},marks:[{type:"bold"}],value:'"Back to Playlists"',nodeType:"text"},{data:{},marks:[],value:" now correctly returns you to the right page every time.",nodeType:"text"}],nodeType:"paragraph"}],nodeType:"list-item"},{data:{},content:[{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Sorting by Most Recent",nodeType:"text"},{data:{},marks:[],value:" no longer gives inconsistent orders.",nodeType:"text"}],nodeType:"paragraph"}],nodeType:"list-item"},{data:{},content:[{data:{},content:[{data:{},marks:[{type:"bold"}],value:"New Labels",nodeType:"text"},{data:{},marks:[],value:' clearly marking playlists as "Added Today," "Added Yesterday," and "Added This Week". This helps both curators showcase their new playlists and artists discover fresh opportunities more easily.',nodeType:"text"}],nodeType:"paragraph"}],nodeType:"list-item"}],nodeType:"unordered-list"},{data:{},content:[{data:{},marks:[],value:"Second, we just crossed ",nodeType:"text"},{data:{},marks:[{type:"bold"}],value:"200,000 successful submissions",nodeType:"text"},{data:{},marks:[],value:"! Huge thanks to you legends: artists and curators alike, for connecting, sharing your music, and making the platform thrive. We're also onboarding more new playlists than ever, giving you even more chances to get your music heard.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Whether you're enjoying the warmth or staying cozy indoors, have a fantastic August. Here's to good music being written and many more successful artist-curator connections!",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"- TEAM Playlist Partner",nodeType:"text"}],nodeType:"paragraph"}],nodeType:"document"},excerpt:"We've hit 200,000 successful submissions! Plus, check out recent bug fixes and new labels to easily find fresh playlists. Here's to more successful connections!",category:"News",featuredImage:{url:"//images.ctfassets.net/b3nqx2d7xn8z/5VBIPlLBnHZ8lH2w15Guv8/defedf3a23079f734ee3f09b2d97fa09/summer_update.jpeg",title:"Summer Update Graphic with Celebration Icons and Bold Text"},publishDate:"2025-08-01T08:08-07:00",featured:!1,createdAt:"2025-08-01T15:58:19.114Z",updatedAt:"2025-08-01T15:59:15.237Z"},{id:"6bHa6vnOHiKZdRjQaIWE5G",title:"Announcing Our New Music Marketing Guide Series",slug:"announcing-our-new-music-marketing-guide-series",body:{data:{},content:[{data:{},content:[{data:{},marks:[],value:"Since launching Playlist Partner and diving into the world of playlist submissions, we've always had bigger dreams. Today, we're excited to announce our upcoming series of music marketing guides, designed to help you expand your reach and build a sustainable career far beyond just playlist placements.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"We're collaborating with some amazing experts in the music marketing space to deliver insightful, actionable guides that will cover essential topics such as:",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},content:[{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Marketing Strategy and Release Planning",nodeType:"text"},{data:{},marks:[],value:" – How to strategically execute your releases for maximum impact across all platforms.",nodeType:"text"}],nodeType:"paragraph"}],nodeType:"list-item"},{data:{},content:[{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Email Marketing",nodeType:"text"},{data:{},marks:[],value:" – Learn how building and nurturing a dedicated email list can significantly boost your career growth.",nodeType:"text"}],nodeType:"paragraph"}],nodeType:"list-item"},{data:{},content:[{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Fanbase Loyalty",nodeType:"text"},{data:{},marks:[],value:" – Practical ways to build lasting, meaningful relationships with your fans.",nodeType:"text"}],nodeType:"paragraph"}],nodeType:"list-item"},{data:{},content:[{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Playlist Placement Strategies",nodeType:"text"},{data:{},marks:[],value:" – Proven tactics to improve your chances of getting featured on playlists.",nodeType:"text"}],nodeType:"paragraph"}],nodeType:"list-item"},{data:{},content:[{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Spotify Editorial Playlists",nodeType:"text"},{data:{},marks:[],value:" – Discover how Spotify selects tracks for their exclusive editorial playlists and how to increase your odds.",nodeType:"text"}],nodeType:"paragraph"}],nodeType:"list-item"},{data:{},content:[{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Spotify Algorithmic Playlists and Radio",nodeType:"text"},{data:{},marks:[],value:" – Tips on maximizing your music’s presence on Spotify Radio and other algorithmic playlists.",nodeType:"text"}],nodeType:"paragraph"}],nodeType:"list-item"},{data:{},content:[{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Social Media Mastery",nodeType:"text"},{data:{},marks:[],value:" – Building your brand authentically and effectively on social platforms.",nodeType:"text"}],nodeType:"paragraph"}],nodeType:"list-item"},{data:{},content:[{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Networking and Collaboration",nodeType:"text"},{data:{},marks:[],value:" – How to find and nurture collaborations that can amplify your exposure and credibility.",nodeType:"text"}],nodeType:"paragraph"}],nodeType:"list-item"},{data:{},content:[{data:{},content:[{data:{},marks:[{type:"bold"}],value:"Digital Advertising for Musicians",nodeType:"text"},{data:{},marks:[],value:" – Leverage ads on social media and streaming platforms to grow your audience strategically.",nodeType:"text"}],nodeType:"paragraph"}],nodeType:"list-item"}],nodeType:"unordered-list"},{data:{},content:[{data:{},marks:[],value:"Stay tuned—we’re committed to giving you the tools and insights needed to amplify your music and reach new heights in your career.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Thanks for your continued support and here's to growing together!",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"— TEAM Playlist Partner",nodeType:"text"}],nodeType:"paragraph"}],nodeType:"document"},excerpt:"Introducing our new music marketing guide series! Learn how to maximize your impact with strategic release planning, playlist placements, email marketing, and more.",category:"News",featuredImage:{url:"//images.ctfassets.net/b3nqx2d7xn8z/6mcBY1GpfQvml3Y7NmlFuI/2161aefa678e313657baef0297599483/spotify_marketing_guides.jpg",title:"Illustration of music marketing concepts with icons on a blue background."},publishDate:"2025-06-23T00:00-07:00",featured:!1,createdAt:"2025-06-23T23:16:50.555Z",updatedAt:"2025-06-23T23:16:50.555Z"},{id:"5TT2Cna5qQIGiOl6rKVlHo",title:"Recent Fixes and Updates",slug:"recent-fixes-and-updates",body:{nodeType:"document",data:{},content:[{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Thanks to everyone for submitting feedback on Playlist Partner 2.0 - we truly appreciate it!",marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Here's what we've addressed in the last few weeks:",marks:[],data:{}}]},{nodeType:"unordered-list",data:{},content:[{nodeType:"list-item",data:{},content:[{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Search Improvements",marks:[{type:"bold"}],data:{}},{nodeType:"text",value:": Search now works much better when applying multiple filters. We'd say it's pretty flawless now. 😊",marks:[],data:{}}]}]},{nodeType:"list-item",data:{},content:[{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Song Selection Saved",marks:[{type:"bold"}],data:{}},{nodeType:"text",value:": Your song selections are now preserved even if you close your browser window.",marks:[],data:{}}]}]},{nodeType:"list-item",data:{},content:[{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Daily Metadata Updates",marks:[{type:"bold"}],data:{}},{nodeType:"text",value:": Playlist metadata, such as follower count and track count, is now updated daily.",marks:[],data:{}}]}]},{nodeType:"list-item",data:{},content:[{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Featured Playlists",marks:[{type:"bold"}],data:{}},{nodeType:"text",value:": We've added a new section to highlight some of our favorite playlists and curators.",marks:[],data:{}}]}]},{nodeType:"list-item",data:{},content:[{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Clearer Notifications",marks:[{type:"bold"}],data:{}},{nodeType:"text",value:': Introduced clear "toast" messages to confirm all actions.',marks:[],data:{}}]}]},{nodeType:"list-item",data:{},content:[{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"More Playlists",marks:[{type:"bold"}],data:{}},{nodeType:"text",value:": We're actively onboarding even more playlists!",marks:[],data:{}}]}]}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"We've got plenty of exciting features in the pipeline - not just bug fixes. Stay tuned!",marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"Thanks again for your continued support.",marks:[],data:{}}]},{nodeType:"paragraph",data:{},content:[{nodeType:"text",value:"-",marks:[],data:{}},{nodeType:"text",value:" TEAM Playlist Partner",marks:[],data:{}}]}]},excerpt:"We've tackled your top requests and improved Playlist Partner 2.0! Enjoy smoother search, saved selections, daily metadata updates, and more.",category:"News",featuredImage:{url:"//images.ctfassets.net/b3nqx2d7xn8z/7ds4PCuy0lCKDJCIUV1xUY/93fe1218873ae3a1bdf424e00c2a3367/bug_fixes.png",title:"Cheerful ladybug illustration with the title “Recent Fixes and Updates†on a blue background"},publishDate:"2025-05-08T09:54-07:00",featured:!1,createdAt:"2025-06-23T22:36:46.075Z",updatedAt:"2025-06-23T23:33:34.006Z"},{id:"2s8044B1fJGMzeDA0NL700",title:"Introducing Playlist Partner 2.0",slug:"introducing-playlistpartner-2-0",body:{data:{},content:[{data:{},content:[{data:{},marks:[],value:"After getting frustrated by the existing playlist submission options, we, a small group of indie musicians, came together one weekend and quickly hacked together the first version of Playlist Partner. It was a scrappy patchwork of code, platforms, and duct tape holding it all together. This rough-and-ready MVP was our way of testing if there was interest in a 100% free, community-driven project created purely out of love for music.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Our goal was clear: create a new kind of site that didn’t destroy your Spotify account by forcing you to follow countless playlists that might not even feature your song, or artists you'd never listen to. Instead, we wanted to foster genuine connections and a mutual exchange of value agreed upon directly by artists and curators, not dictated by the platform.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"We were blown away by the response and the love our weekend experiment received. With your invaluable feedback in hand, we went back to the drawing board and meticulously rebuilt the platform from the ground up. And now, here we are on launch day!",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"PlaylistPartner 2.0 is smoother, faster, and more intuitive, both on the frontend and backend. It provides artists and curators with a robust, reliable foundation, enabling us to roll out even more powerful features in the future. Expect a snappier interface, a streamlined user experience, and a powerful new engine built to amplify your music's reach.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Over the coming weeks, you’ll notice a little feedback button floating around the right side of the site. Please use it to report any issues or submit your feature requests, we're excited to keep improving based on your input.",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"Thanks for supporting our project, and may the odds ever be in your favor!",nodeType:"text"}],nodeType:"paragraph"},{data:{},content:[{data:{},marks:[],value:"— TEAM Playlist Partner",nodeType:"text"}],nodeType:"paragraph"}],nodeType:"document"},excerpt:"PlaylistPartner 2.0 is here, rebuilt from scratch! Now smoother, faster, and built specifically for artists and curators. Check out the new features, give us your feedback, and help shape the future of free playlist submissions.",category:"News",featuredImage:{url:"//images.ctfassets.net/b3nqx2d7xn8z/18zwyIaISSiy1k32iYFKwm/db3f8c7ad0bfe902cdd29baea9b4276f/playlist_partner_2.0_featured_image_2.png",title:"Playlist Partner 2.0 Announcement"},publishDate:"2025-04-02T14:14-07:00",featured:!1,createdAt:"2025-06-23T22:23:06.179Z",updatedAt:"2025-06-23T22:26:31.945Z"}];function td(){const e=ar.filter(n=>n.category==="News").slice(0,2);function a(n){return new Date(n).toLocaleDateString("en-US",{month:"short",day:"numeric"})}function r(n){return n.startsWith("//")?`https:${n}`:n}return e.length===0?null:o.jsx("div",{className:"my-16",children:o.jsxs("div",{className:"max-w-[1400px] mx-auto",children:[o.jsx("h2",{className:"text-2xl font-semibold text-gray-900 mb-8",children:"Latest News from Playlist Partner"}),o.jsxs("div",{className:"grid md:grid-cols-3 gap-6",children:[e.map(n=>{var s;return o.jsxs(R,{to:`/blog/news/${n.slug}`,className:"group bg-white border border-gray-200 rounded-lg overflow-hidden hover:border-green-500 hover:shadow-md transition-all",children:[((s=n.featuredImage)==null?void 0:s.url)&&o.jsx("div",{className:"aspect-[3/2] overflow-hidden",children:o.jsx("img",{src:r(n.featuredImage.url),alt:n.featuredImage.title||n.title,className:"w-full h-full object-cover group-hover:scale-105 transition-transform duration-300"})}),o.jsxs("div",{className:"p-6",children:[o.jsx("h3",{className:"text-lg font-semibold text-gray-900 group-hover:text-green-600 transition-colors line-clamp-2 mb-3",children:n.title}),n.excerpt&&o.jsx("p",{className:"text-gray-600 text-sm mb-4 line-clamp-2",children:n.excerpt}),o.jsxs("div",{className:"flex items-center justify-between",children:[o.jsxs("div",{className:"flex items-center gap-1 text-xs text-gray-500",children:[o.jsx(tr,{className:"w-3 h-3"}),o.jsx("span",{children:a(n.publishDate||n.createdAt)})]}),o.jsxs("span",{className:"text-green-600 text-sm flex items-center gap-1 group-hover:gap-2 transition-all",children:["Read",o.jsx(bt,{className:"w-4 h-4"})]})]})]})]},n.id)}),o.jsx(R,{to:"/blog",className:"group bg-gradient-to-br from-green-50 to-green-100 border border-green-200 rounded-lg overflow-hidden hover:border-green-500 hover:shadow-md transition-all flex flex-col",children:o.jsxs("div",{className:"flex-1 flex flex-col justify-center items-center text-center p-6",children:[o.jsx("div",{className:"mb-4",children:o.jsx("div",{className:"w-16 h-16 bg-green-600 rounded-full flex items-center justify-center group-hover:scale-110 transition-transform",children:o.jsx(bt,{className:"w-8 h-8 text-white"})})}),o.jsx("h3",{className:"text-lg font-semibold text-gray-900 mb-2",children:"View All Posts"}),o.jsx("p",{className:"text-gray-600 text-sm",children:"Explore all blog posts and updates"})]})})]})]})})}const ad=w.lazy(()=>de(()=>import("./FeaturedPlaylists-ac3ZVIp7.js"),__vite__mapDeps([0,1,2])).then(t=>({default:t.FeaturedPlaylists}))),rd=w.lazy(()=>de(()=>Promise.resolve().then(()=>Td),void 0).then(t=>({default:t.SubmissionModal}))),nd=()=>o.jsx("div",{className:"bg-gradient-to-b from-green-50 to-white",children:o.jsx("div",{className:"container mx-auto px-4 py-12",children:o.jsxs("div",{className:"max-w-[1400px] mx-auto",children:[o.jsxs("div",{className:"text-center mb-12",children:[o.jsx("h1",{className:"text-4xl font-bold text-gray-900 mb-4",children:"Free Spotify Playlist Submissions - No Signup"}),o.jsx("h2",{className:"text-xl text-gray-600",children:"Connect Instantly with Thousands of Independent Playlist Curators"})]}),o.jsxs("div",{className:"grid md:grid-cols-3 gap-8 text-left",children:[o.jsxs("div",{className:"bg-white border border-gray-200 p-8 hover:border-green-500 transition-colors rounded-md",children:[o.jsx("h3",{className:"text-lg font-semibold text-gray-900 mb-3",children:"Direct Connections"}),o.jsx("p",{className:"text-gray-600",children:"Skip the middlemen and connect with real playlist curators who are passionate about discovering new music. Our platform eliminates gatekeepers, letting your music speak directly to those who can share it with their audiences."})]}),o.jsxs("div",{className:"bg-white border border-gray-200 p-8 hover:border-green-500 transition-colors rounded-md",children:[o.jsx("h3",{className:"text-lg font-semibold text-gray-900 mb-3",children:"Zero Barriers"}),o.jsx("p",{className:"text-gray-600",children:"No accounts, no credits—just instant Spotify submissions without hassle. Paste your track link and start submitting to playlists immediately. We've removed every obstacle between independent artists and playlist opportunities."})]}),o.jsxs("div",{className:"bg-white border border-gray-200 p-8 hover:border-green-500 transition-colors rounded-md",children:[o.jsx("h3",{className:"text-lg font-semibold text-gray-900 mb-3",children:"Community-Driven"}),o.jsx("p",{className:"text-gray-600",children:"Built by independent musicians for the indie community. Our platform fosters genuine relationships between artists and curators based on mutual appreciation rather than transactional expectations."})]})]})]})})}),sd=()=>{var e,a;const t=Qe();return o.jsx("div",{className:"my-8 pt-8 border-t border-gray-200",children:o.jsxs("div",{className:"max-w-[1400px] mx-auto",children:[o.jsxs("h2",{className:"text-2xl font-semibold text-gray-900 mb-6",children:["Today's Featured Playlists - ",new Date().toLocaleDateString("en-US",{weekday:"long",month:"long",day:"numeric"})]}),(t==null?void 0:t.lastTrack)&&o.jsxs("div",{className:"mb-6 flex items-center justify-between bg-white p-4 shadow-sm rounded-lg",children:[o.jsxs("div",{className:"flex items-center gap-4",children:[o.jsx("img",{src:(e=t.lastTrack.album.images[2])==null?void 0:e.url,alt:t.lastTrack.name,className:"w-12 h-12 object-cover rounded-md",loading:"lazy"}),o.jsxs("div",{children:[o.jsx("p",{className:"font-medium",children:t.lastTrack.name}),o.jsx("p",{className:"text-sm text-gray-600",children:(a=t.lastTrack.artists[0])==null?void 0:a.name})]})]}),o.jsx("button",{onClick:()=>{us(),window.location.reload()},className:"p-2 hover:bg-gray-100 rounded-full transition-colors",title:"Clear selected track",children:o.jsx(at,{className:"w-5 h-5 text-gray-500"})})]}),o.jsx("div",{className:"border-l-4 border-green-500 pl-6",children:o.jsx(w.Suspense,{fallback:o.jsx("div",{className:"h-32 flex items-center justify-center",children:o.jsx(Re,{className:"w-8 h-8 animate-spin"})}),children:o.jsx(ad,{})})})]})})},od=()=>o.jsx("div",{className:"bg-gradient-to-b from-gray-50 via-gray-100 to-gray-50 py-12 mt-16 mb-16 border-y border-gray-200",children:o.jsxs("div",{className:"text-center max-w-[1400px] mx-auto px-4",children:[o.jsx("p",{className:"text-gray-800 text-xl font-medium mb-6",children:"Find the Perfect Playlist for Your Music"}),o.jsx(R,{to:"/playlists",className:"inline-block px-12 py-5 bg-blue-600 text-white text-xl font-semibold rounded-lg hover:bg-blue-700 transition-all transform hover:scale-105 shadow-lg hover:shadow-xl",children:"Explore All Playlists"})]})});function id(){const[t,e]=w.useState(null);return o.jsxs(o.Fragment,{children:[o.jsx(ce,{}),o.jsxs("main",{children:[o.jsx(nd,{}),o.jsxs("div",{className:"container mx-auto px-4 pb-12",children:[o.jsx(w.Suspense,{fallback:null,children:o.jsx(sd,{})}),o.jsx(od,{}),o.jsx(td,{}),o.jsxs(w.Suspense,{fallback:null,children:[o.jsx(ld,{}),o.jsx(dd,{})]})]}),t&&o.jsx(w.Suspense,{fallback:null,children:o.jsx(rd,{playlist:t,onClose:()=>e(null),onSubmit:()=>e(null)})})]})]})}const ld=w.lazy(()=>de(()=>import("./FAQSection-B67sj2J0.js"),__vite__mapDeps([3,1,2]))),dd=w.lazy(()=>de(()=>import("./AdditionalInfoSection-Bsu7QzAv.js"),__vite__mapDeps([4,1,2])));function cd(t){const[e,a]=w.useState(null),[r,n]=w.useState(!0),[s,i]=w.useState(null),[l,c]=w.useState([]);return w.useEffect(()=>{let d=!0;async function u(){if(!t){i(new Error("Invalid playlist URL")),n(!1);return}try{n(!0),i(null);const{data:h,error:p}=await U.from("playlist_details").select("*").eq("slug",t).limit(1);if(p)throw p;if(!h||h.length===0)throw new Error("Playlist not found");const y=h[0];if(d){a(y);const{data:m,error:f}=await U.from("playlist_details").select("*").eq("genre",y.genre).neq("id",y.id).order("followers",{ascending:!1}).limit(4);!f&&m&&c(m)}}catch(h){console.error("Failed to fetch playlist:",h),d&&(i(h instanceof Error?h:new Error("Failed to fetch playlist")),a(null),c([]))}finally{d&&n(!1)}}return u(),()=>{d=!1}},[t]),{playlist:e,loading:r,error:s,relatedPlaylists:l,isNotFound:(s==null?void 0:s.message)==="Playlist not found"}}const $a="playlist_submissions";function ud(t,e){try{const a=JSON.parse(localStorage.getItem($a)||"[]"),r=a.find(n=>n.playlistId===t);r?r.tracks.some(n=>n.spotifyUrl===e)||r.tracks.push({spotifyUrl:e,timestamp:Date.now()}):a.push({playlistId:t,tracks:[{spotifyUrl:e,timestamp:Date.now()}]}),localStorage.setItem($a,JSON.stringify(a))}catch(a){console.error("Failed to track submission:",a)}}function hs(t,e){try{const r=JSON.parse(localStorage.getItem($a)||"[]").find(n=>n.playlistId===t);return!!(r!=null&&r.tracks.some(n=>n.spotifyUrl===e))}catch(a){return console.error("Failed to check submission status:",a),!1}}const Da="scrollPositions",hd=5*60*1e3,pd=10,yd=100;function Wr(){try{return JSON.parse(sessionStorage.getItem(Da)||"[]")}catch{return[]}}const ps={savePosition(t,e){try{const a=Wr(),r=window.scrollY;if(r>0){a.push({pathname:t,position:r,timestamp:Date.now(),searchParams:e==null?void 0:e.toString()});const n=a.filter(s=>Date.now()-s.timestamp<hd);sessionStorage.setItem(Da,JSON.stringify(n))}}catch(a){console.error("Failed to save scroll position:",a)}},restorePosition(t,e){try{const a=Wr(),r=a.find(n=>n.pathname===t);if(r){const n=a.filter(l=>l!==r);sessionStorage.setItem(Da,JSON.stringify(n)),r.searchParams&&e&&e(new URLSearchParams(r.searchParams));let s=0;const i=()=>{const l=document.documentElement.scrollHeight,c=r.position;if(l>=c||s>=pd){window.scrollTo({top:c,behavior:"instant"});return}s++,setTimeout(i,yd)};setTimeout(i,50)}}catch(a){console.error("Failed to restore scroll position:",a)}}};function ys(t){if(!t)return null;const e=new Date,a=new Date(t),r=new Date(e.getFullYear(),e.getMonth(),e.getDate()),n=new Date(r);n.setDate(n.getDate()-1);const s=new Date(r);s.setDate(s.getDate()-7);const i=new Date(a.getFullYear(),a.getMonth(),a.getDate());return i.getTime()===r.getTime()?"today":i.getTime()===n.getTime()?"yesterday":i>s?"this-week":null}function rr({playlist:t,onSubmit:e,isRelated:a,priority:r=!1,hideSubmit:n=!1,showFeaturedBadge:s=!1}){const i=Ce(),l=Kt(),[c]=Jr(),[d,u]=w.useState(!1),h=Qe(),p=(h==null?void 0:h.lastTrack)&&hs(t.id,h.lastTrack.external_urls.spotify),y=m=>{m.preventDefault(),a||ps.savePosition(l.pathname,c);const f=l.pathname.startsWith("/genre/");window.scrollTo({top:0,behavior:"instant"}),i(`/playlist/${t.slug}`,{state:{from:f?"genre":"home"}})};return o.jsxs("div",{className:"bg-white shadow-sm hover:shadow-md transition-shadow h-full flex flex-col",children:[o.jsxs("div",{className:"flex-1",children:[o.jsxs("a",{href:`/playlist/${t.slug}`,onClick:y,className:"cursor-pointer no-js-fallback",children:[o.jsxs("div",{className:"relative pb-[100%] bg-gray-100",children:[d||!t.image_url?o.jsx("div",{className:"absolute inset-0 flex items-center justify-center bg-gradient-to-br from-gray-100 to-gray-200",children:o.jsxs("div",{className:"text-center",children:[o.jsx(os,{className:"w-12 h-12 text-gray-400 mx-auto mb-2"}),o.jsx("div",{className:"text-sm text-gray-500 font-medium px-4 truncate max-w-[200px]",children:t.name})]})}):o.jsx("img",{src:t.image_url,alt:t.name,className:"absolute inset-0 w-full h-full object-cover sm:rounded-[2px] lg:rounded-[4px]",loading:r?"eager":"lazy",onError:()=>u(!0)}),t.featured&&s&&o.jsxs("div",{className:"absolute top-2 right-2 bg-yellow-400 text-yellow-900 px-2 py-1 rounded-full text-xs font-medium flex items-center gap-1",children:[o.jsx(ls,{className:"w-3 h-3"}),"Featured"]})]}),o.jsx("h3",{className:"text-base font-bold text-gray-900 mb-1 line-clamp-1 hover:text-green-600 transition-colors p-4 pb-0",children:t.name})]}),o.jsxs("div",{className:"p-4 pt-2",children:[o.jsx("p",{className:"text-sm text-gray-600 mb-2 line-clamp-2 flex-1",children:t.description}),o.jsxs("div",{className:"space-y-2",children:[o.jsxs("div",{className:"flex items-center gap-4 text-sm",children:[o.jsxs(R,{to:`/genre/${t.genre_slug}`,onClick:m=>m.stopPropagation(),className:"flex items-center text-gray-700 hover:text-green-600 transition-colors",children:[o.jsx(me,{className:"w-4 h-4 mr-1 flex-shrink-0"}),o.jsx("span",{className:"truncate",children:t.genre})]}),o.jsxs("div",{className:"flex items-center text-gray-700",children:[o.jsx(Xt,{className:"w-4 h-4 mr-1 flex-shrink-0"}),o.jsx("span",{children:t.followers.toLocaleString()})]})]}),t.curator_name&&o.jsxs("div",{className:"flex items-center gap-2 text-sm text-gray-600",children:[o.jsx(Qt,{className:"w-4 h-4 flex-shrink-0"}),t.curator_profile_url?o.jsx("a",{href:t.curator_profile_url,target:"_blank",rel:"noopener noreferrer",onClick:m=>m.stopPropagation(),className:"truncate hover:text-green-600 transition-colors",children:t.curator_name}):o.jsx("span",{className:"truncate",children:t.curator_name})]})]})]})]}),!n&&o.jsxs("div",{className:"px-4 py-3 border-t border-gray-100 mt-auto flex items-center justify-between",children:[p?o.jsxs("div",{className:"flex items-center gap-1.5 bg-gray-100 text-gray-500 px-3 py-1.5 rounded-full text-sm",children:[o.jsx(ns,{className:"w-3.5 h-3.5"}),"Submitted"]}):o.jsxs("button",{onClick:m=>{m.stopPropagation(),e(t.id)},className:"flex items-center gap-1.5 bg-green-500 text-white px-3 py-1.5 rounded-full text-sm hover:bg-green-600 transition-colors",children:[o.jsx(is,{className:"w-3.5 h-3.5"}),"Submit"]}),(()=>{const m=ys(t.published_at);if(!m)return null;const g={today:{text:"Added Today",bg:"bg-gray-100",textColor:"text-gray-600"},yesterday:{text:"Added Yesterday",bg:"bg-gray-100",textColor:"text-gray-600"},"this-week":{text:"Added This Week",bg:"bg-gray-100",textColor:"text-gray-600"}}[m];return o.jsxs("div",{className:`${g.bg} ${g.textColor} px-2 py-1 rounded-full text-xs font-medium flex items-center gap-1`,children:[o.jsx(ss,{className:"w-3 h-3"}),g.text]})})()]})]})}const Ht=10,ya=24*60*60*1e3;function $t(t){return gd(t,"track")||t}function md(t,e){try{if(!t||!e)return{allowed:!1,remainingSubmissions:0,timeUntilReset:null,totalSubmissions:0,alreadySubmittedToPlaylist:!1};const a=JSON.parse(localStorage.getItem("trackSubmissions")||"[]"),r=Date.now(),n=$t(t),s=a.filter(c=>r-c.timestamp<ya);s.length<a.length&&localStorage.setItem("trackSubmissions",JSON.stringify(s));const i=s.find(c=>$t(c.spotifyUrl)===n&&c.playlistId===e);if(i)return{allowed:!1,remainingSubmissions:0,timeUntilReset:Math.max(0,ya-(r-i.timestamp)),totalSubmissions:s.length,alreadySubmittedToPlaylist:!0};const l=s.filter(c=>$t(c.spotifyUrl)===n);if(l.length>=Ht){const c=l.reduce((u,h)=>h.timestamp<u.timestamp?h:u);return{allowed:!1,remainingSubmissions:0,timeUntilReset:Math.max(0,ya-(r-c.timestamp)),totalSubmissions:l.length,alreadySubmittedToPlaylist:!1}}return{allowed:!0,remainingSubmissions:Ht-l.length,timeUntilReset:null,totalSubmissions:l.length,alreadySubmittedToPlaylist:!1}}catch(a){return console.error("Rate limit check failed:",a),{allowed:!1,remainingSubmissions:0,timeUntilReset:null,totalSubmissions:0,alreadySubmittedToPlaylist:!1}}}function fd(t,e){if(!(!t||!e))try{const a=JSON.parse(localStorage.getItem("trackSubmissions")||"[]");a.push({timestamp:Date.now(),spotifyUrl:$t(t),playlistId:e}),localStorage.setItem("trackSubmissions",JSON.stringify(a))}catch(a){console.error("Failed to record submission:",a)}}function gd(t,e){if(!t)return null;try{const a=[new RegExp(`${e}/([a-zA-Z0-9]+)`),new RegExp(`${e}:([a-zA-Z0-9]+)`)];for(const r of a){const n=t.match(r);if(n&&n[1])return n[1]}return null}catch(a){return console.error("Failed to extract ID:",a),null}}const ms="https://bears.playlistpartner.com/api/spotify";function vd(t){try{if(t.startsWith("spotify:")){const a=t.split(":");return`https://open.spotify.com/${a[1]}/${a[2]}`}return`https://open.spotify.com${new URL(t).pathname}`}catch{return t}}function qt(t,e){if(!t)return null;try{const a=vd(t),r=[new RegExp(`${e}/([a-zA-Z0-9]+)`),new RegExp(`${e}:([a-zA-Z0-9]+)`)];for(const n of r){const s=a.match(n);if(s&&s[1])return s[1]}return null}catch(a){return console.error("Failed to extract ID:",a),null}}async function bd(t){if(!t.trim())return[];try{const e=await fetch(`${ms}/search?q=${encodeURIComponent(t)}&limit=5`);if(!e.ok){if(e.status===429){const r=await e.json();throw new Error(r.message||"Rate limit exceeded. Please try again later.")}throw new Error(`Search failed: ${e.status} ${e.statusText}`)}const a=await e.json();if(!a.tracks)throw new Error("Invalid response format from API");return a.tracks}catch(e){throw console.error("Failed to search tracks:",e),e instanceof Error?e:new Error("Failed to search tracks")}}async function Hr(t){if(!t)return null;try{const e=await fetch(`${ms}/track/${encodeURIComponent(t)}`);if(!e.ok){if(e.status===404)return null;if(e.status===429){const r=await e.json();throw new Error(r.message||"Rate limit exceeded. Please try again later.")}throw new Error(`Failed to fetch track: ${e.status} ${e.statusText}`)}const a=await e.json();if(!a.id||!a.name||!a.artists||!a.album)throw new Error("Invalid track data received from API");return a}catch(e){throw console.error("Failed to fetch track:",e),e instanceof Error?e:new Error("Failed to fetch track data")}}function wd(t,e){const[a,r]=w.useState(t);return w.useEffect(()=>{const n=setTimeout(()=>{r(t)},e);return()=>{clearTimeout(n)}},[t,e]),a}function fs({onTrackSelect:t,initialUrl:e,selectedTrack:a,onClearTrack:r}){var E;const[n,s]=w.useState(""),[i,l]=w.useState([]),[c,d]=w.useState(!1),[u,h]=w.useState(!1),[p,y]=w.useState(null),[m,f]=w.useState(-1),g=wd(n,300),v=w.useRef(null),x=w.useRef(null);w.useEffect(()=>{const _=k=>{v.current&&!v.current.contains(k.target)&&h(!1)};return document.addEventListener("mousedown",_),()=>document.removeEventListener("mousedown",_)},[]),w.useEffect(()=>{async function _(){if(!g.trim()){l([]),y(null);return}if(g.trim().length<2){l([]),y(null),h(!1);return}d(!0),y(null);try{const k=await bd(g);k.length===0&&y("No tracks found"),l(k),h(!0),f(-1)}catch(k){console.error("Failed to fetch tracks:",k),y("Failed to search tracks. Please try again.")}finally{d(!1)}}_()},[g]),w.useEffect(()=>{if(m>=0&&x.current){const _=x.current.querySelectorAll("button");_[m]&&_[m].scrollIntoView({behavior:"smooth",block:"nearest"})}},[m]),w.useEffect(()=>{async function _(){if(e){const k=qt(e,"track");if(k){d(!0),y(null);try{const L=await Hr(k);L?t(L):y("Track not found")}catch(L){console.error("Failed to fetch initial track:",L),y("Failed to load track. Please try again.")}finally{d(!1)}}}}_()},[e,t]);const T=async _=>{t(_),h(!1),s(""),y(null)},j=async _=>{s(_),y(null);const k=qt(_,"track");if(k){d(!0);try{const L=await Hr(k);L?T(L):y("Invalid Spotify URL or track not found")}catch(L){console.error("Failed to fetch track:",L),y("Failed to load track. Please try again.")}finally{d(!1)}}},A=_=>{_.preventDefault(),_.stopPropagation(),r(),s(""),y(null),h(!1),setTimeout(()=>{var L;const k=(L=v.current)==null?void 0:L.querySelector("input");k&&k.focus()},0)},S=_=>{if(!u||i.length===0){_.key==="Enter"&&(_.preventDefault(),_.stopPropagation());return}switch(_.key){case"ArrowDown":_.preventDefault(),f(k=>k<i.length-1?k+1:k);break;case"ArrowUp":_.preventDefault(),f(k=>k>0?k-1:-1);break;case"Enter":_.preventDefault(),_.stopPropagation(),m>=0&&m<i.length&&T(i[m]);break;case"Escape":h(!1),f(-1);break}};return a?o.jsxs("div",{className:"mt-3 p-3 bg-gray-50 rounded-lg flex items-center gap-4 group relative",children:[o.jsx("img",{src:(E=a.album.images[a.album.images.length-1])==null?void 0:E.url,alt:a.album.name,className:"w-16 h-16 object-cover rounded-md"}),o.jsxs("div",{className:"flex-1",children:[o.jsx("h3",{className:"font-medium text-gray-900",children:a.name}),o.jsx("p",{className:"text-sm text-gray-600",children:a.artists.map(_=>_.name).join(", ")}),o.jsx("p",{className:"text-xs text-gray-500",children:a.album.name})]}),o.jsx("button",{onClick:A,className:"absolute top-2 right-2 p-1 rounded-full bg-gray-200 hover:bg-gray-300 transition-colors","aria-label":"Clear selection",children:o.jsx(at,{className:"w-4 h-4 text-gray-600"})})]}):o.jsxs("div",{ref:v,className:"relative",children:[o.jsxs("div",{className:"relative",children:[o.jsx(Ft,{className:"absolute left-3 top-1/2 transform -translate-y-1/2 text-gray-400 w-5 h-5"}),o.jsx("input",{type:"text",placeholder:"Search for your track or paste Spotify URL...",value:n,onChange:_=>j(_.target.value),onFocus:()=>h(!0),onKeyDown:S,className:"w-full pl-10 pr-4 py-2 border border-gray-300 rounded-lg focus:ring-2 focus:ring-green-500 focus:border-transparent"}),c&&o.jsx(Re,{className:"absolute right-3 top-1/2 transform -translate-y-1/2 text-gray-400 w-5 h-5 animate-spin"})]}),p&&o.jsxs("div",{className:"mt-2 text-sm text-red-600 flex items-center gap-1",children:[o.jsx(pe,{className:"w-4 h-4"}),p]}),u&&(i.length>0||c)&&o.jsxs("div",{ref:x,className:"absolute z-50 w-full mt-1 bg-white rounded-lg shadow-lg border border-gray-200 max-h-80 overflow-y-auto",children:[i.map((_,k)=>{var L;return o.jsxs("button",{onClick:q=>{q.preventDefault(),T(_)},onMouseEnter:()=>f(k),className:`w-full p-3 flex items-center gap-3 border-b border-gray-100 last:border-0 transition-colors ${k===m?"bg-indigo-50":"hover:bg-gray-50"}`,children:[o.jsx("img",{src:(L=_.album.images[_.album.images.length-1])==null?void 0:L.url,alt:_.album.name,className:"w-10 h-10 object-cover rounded"}),o.jsxs("div",{className:"flex-1 text-left",children:[o.jsx("p",{className:"font-medium text-gray-900 line-clamp-1",children:_.name}),o.jsx("p",{className:"text-sm text-gray-500 line-clamp-1",children:_.artists.map(q=>q.name).join(", ")})]})]},_.id)}),c&&o.jsxs("div",{className:"p-4 text-center text-gray-500",children:[o.jsx(Re,{className:"w-6 h-6 animate-spin mx-auto"}),o.jsx("p",{className:"mt-2",children:"Searching tracks..."})]})]})]})}const xd={async submit(t){const{data:e,error:a}=await U.from("submissions").insert({playlist_id:t.playlistId,track_id:t.trackId,track_name:t.trackName,track_url:t.trackUrl,artist_name:t.artistName,email:t.email,message:t.message,status:"pending",created_at:new Date().toISOString(),updated_at:new Date().toISOString()}).select(`
        *,
        playlist:playlists (
          name
        )
      `).single();if(a)throw console.error("Failed to create submission:",a),a;return e},async getAll(){const{data:t,error:e}=await U.from("submission_details").select("*").order("created_at",{ascending:!1});if(e)throw console.error("Failed to fetch submissions:",e),e;return t.map(a=>({...a,playlist:{name:a.playlist_name}}))},async getHistory(t){const{data:e,error:a}=await U.from("submission_details").select("*").eq("email",t).order("created_at",{ascending:!1});if(a)throw console.error("Failed to fetch submission history:",a),a;return e.map(r=>({...r,playlist:{name:r.playlist_name}}))},async getForPlaylist(t){const{data:e,error:a}=await U.from("submission_details").select("*").eq("playlist_id",t).order("created_at",{ascending:!1});if(a)throw console.error("Failed to fetch playlist submissions:",a),a;return e.map(r=>({...r,playlist:{name:r.playlist_name}}))},async updateStatus(t,e){const{data:a,error:r}=await U.from("submissions").update({status:e,reviewed_at:e==="pending"?null:new Date().toISOString(),updated_at:new Date().toISOString()}).eq("id",t).select(`
        *,
        playlist:playlists (
          name
        )
      `).single();if(r)throw console.error("Failed to update submission status:",r),r;return a}};function rt({playlist:t,onClose:e,onSubmit:a}){const[r,n]=w.useState(()=>{var x;const v=Qe();return{spotifyUrl:((x=v==null?void 0:v.lastTrack)==null?void 0:x.external_urls.spotify)||"",artistName:(v==null?void 0:v.artistName)||"",email:(v==null?void 0:v.email)||"",message:""}}),[s,i]=w.useState(()=>{const v=Qe();return(v==null?void 0:v.lastTrack)||null}),[l,c]=w.useState({}),[d,u]=w.useState({allowed:!0,remainingSubmissions:Ht,timeUntilReset:null,totalSubmissions:0,alreadySubmittedToPlaylist:!1}),[h,p]=w.useState("");w.useEffect(()=>{const v=T=>{const j=document.querySelector(".modal-content");j&&!j.contains(T.target)&&e()},x=T=>{T.key==="Escape"&&e()};return document.addEventListener("mousedown",v),document.addEventListener("keydown",x),()=>{document.removeEventListener("mousedown",v),document.removeEventListener("keydown",x)}},[e]),w.useEffect(()=>{if(r.spotifyUrl){const v=md(r.spotifyUrl,t.id);u(v)}},[r.spotifyUrl,t.id]),w.useEffect(()=>{let v;const x=()=>{if(d.timeUntilReset){const T=Math.floor(d.timeUntilReset/36e5),j=Math.floor(d.timeUntilReset%(1e3*60*60)/(1e3*60)),A=Math.floor(d.timeUntilReset%(1e3*60)/1e3);p(`${T}h ${j}m ${A}s`)}};return d.timeUntilReset&&(x(),v=setInterval(()=>{const T=d.timeUntilReset-1e3;T<=0?(clearInterval(v),u(j=>({...j,timeUntilReset:null,allowed:!0}))):(u(j=>({...j,timeUntilReset:T})),x())},1e3)),()=>{v&&clearInterval(v)}},[d.timeUntilReset]);const y=()=>{const v={};return s||(v.spotifyUrl="Please select a track"),r.artistName.trim()||(v.artistName="Artist name is required"),/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(r.email)||(v.email="Please enter a valid email address"),c(v),Object.keys(v).length===0},m=async v=>{if(v.preventDefault(),!(!d.allowed||d.alreadySubmittedToPlaylist)&&y())try{const x=qt(r.spotifyUrl,"track");if(!x||!s)throw new Error("Invalid track selection");await xd.submit({playlistId:t.id,trackId:x,trackName:s.name,trackUrl:r.spotifyUrl,artistName:r.artistName,email:r.email,message:r.message}),cs({artistName:r.artistName,email:r.email,track:s}),fd(r.spotifyUrl,t.id),ud(t.id,r.spotifyUrl),a(r)}catch(x){console.error("Failed to submit track:",x),c(T=>({...T,submit:"Failed to submit track. Please try again."}))}},f=v=>{i(v),n(x=>{var T;return{...x,spotifyUrl:v.external_urls.spotify,artistName:((T=v.artists[0])==null?void 0:T.name)||x.artistName}}),c(x=>({...x,spotifyUrl:void 0}))},g=()=>{i(null),n(v=>({...v,spotifyUrl:"",artistName:v.artistName})),c(v=>({...v,spotifyUrl:void 0}))};return o.jsx("div",{className:"fixed inset-0 bg-black bg-opacity-50 flex items-center justify-center p-4 z-50",children:o.jsxs("div",{className:"modal-content bg-white rounded-xl max-w-lg w-full max-h-[90vh] overflow-y-auto",children:[o.jsxs("div",{className:"p-4 sm:p-6 border-b border-gray-200",children:[o.jsxs("div",{className:"flex justify-between items-start",children:[o.jsxs("div",{className:"flex gap-3 sm:gap-4",children:[t.image_url&&o.jsx("img",{src:t.image_url,alt:t.name,className:"w-12 h-12 sm:w-16 sm:h-16 rounded-lg object-cover shadow-sm",style:{marginTop:"0.43rem"}}),o.jsxs("div",{children:[o.jsx("h2",{className:"text-lg sm:text-xl font-bold text-gray-900",children:"Submit Your Track"}),o.jsxs("p",{className:"text-sm sm:text-base text-gray-600",children:["Submitting to: ",o.jsx("span",{className:"font-medium",children:t.name})]})]})]}),o.jsx("button",{onClick:e,className:"text-gray-400 hover:text-gray-500 transition-colors",children:o.jsx(at,{className:"w-6 h-6"})})]}),s&&o.jsx("div",{className:"mt-3 flex flex-col gap-2 text-sm",children:o.jsx("div",{className:`px-3 py-2 rounded-lg ${d.alreadySubmittedToPlaylist?"bg-yellow-100 text-yellow-800":d.allowed?"bg-green-100 text-green-800":"bg-red-100 text-red-800"}`,children:d.alreadySubmittedToPlaylist?o.jsxs("div",{className:"flex items-center gap-1",children:[o.jsx(pe,{className:"w-4 h-4"}),"Already submitted to this playlist"]}):d.allowed?o.jsxs("span",{children:[d.remainingSubmissions,"/",Ht," Submissions Remaining Today"]}):o.jsxs(o.Fragment,{children:[o.jsxs("div",{className:"flex items-center gap-1",children:[o.jsx(pe,{className:"w-4 h-4"}),"Each track can be submitted to up to 10 playlists per day."]}),h&&o.jsxs("div",{className:"text-sm mt-1",children:["(Resets in ",h,")"]})]})})})]}),o.jsxs("form",{onSubmit:m,className:"p-4 sm:p-6 space-y-3 sm:space-y-4",children:[o.jsxs("div",{children:[o.jsxs("label",{className:"flex gap-2 text-sm font-medium text-gray-700 mb-1",children:[o.jsx(Gl,{className:"w-4 h-4"}),"Search and Select Your Track"]}),o.jsx(fs,{onTrackSelect:f,selectedTrack:s,onClearTrack:g}),l.spotifyUrl&&o.jsx("p",{className:"mt-1 text-sm text-red-600",children:l.spotifyUrl})]}),o.jsxs("div",{children:[o.jsxs("label",{className:"flex gap-2 text-sm font-medium text-gray-700 mb-1",children:[o.jsx(Qt,{className:"w-4 h-4"}),"Artist Name"]}),o.jsx("input",{type:"text",placeholder:"Your artist name",value:r.artistName,onChange:v=>n(x=>({...x,artistName:v.target.value})),className:"w-full p-2 border border-gray-300 rounded-lg focus:ring-2 focus:ring-green-500 focus:border-transparent",disabled:!d.allowed||d.alreadySubmittedToPlaylist}),l.artistName&&o.jsx("p",{className:"mt-1 text-sm text-red-600",children:l.artistName})]}),o.jsxs("div",{children:[o.jsxs("label",{className:"flex gap-2 text-sm font-medium text-gray-700 mb-1",children:[o.jsx(Kl,{className:"w-4 h-4"}),"Email"]}),o.jsx("input",{type:"email",placeholder:"your@email.com",value:r.email,onChange:v=>n(x=>({...x,email:v.target.value})),className:"w-full p-2 border border-gray-300 rounded-lg focus:ring-2 focus:ring-green-500 focus:border-transparent",disabled:!d.allowed||d.alreadySubmittedToPlaylist}),l.email&&o.jsx("p",{className:"mt-1 text-sm text-red-600",children:l.email})]}),o.jsxs("div",{children:[o.jsxs("label",{className:"flex gap-2 text-sm font-medium text-gray-700 mb-1",children:[o.jsx(Yl,{className:"w-4 h-4"}),"Message (Optional)"]}),o.jsx("textarea",{placeholder:"Tell the curator about your track...",value:r.message,onChange:v=>n(x=>({...x,message:v.target.value})),rows:3,className:"w-full p-2 border border-gray-300 rounded-lg focus:ring-2 focus:ring-green-500 focus:border-transparent resize-none sm:resize-y",disabled:!d.allowed||d.alreadySubmittedToPlaylist})]}),l.submit&&o.jsxs("div",{className:"flex items-center gap-2 text-red-600 text-sm",children:[o.jsx(pe,{className:"w-4 h-4"}),o.jsx("p",{children:l.submit})]}),o.jsxs("div",{className:"flex justify-end gap-3 pt-2 sm:pt-4",children:[o.jsx("button",{type:"button",onClick:e,className:"px-4 py-2 text-gray-700 hover:bg-gray-100 rounded-lg transition-colors",children:"Cancel"}),o.jsxs("button",{type:"submit",disabled:!d.allowed||d.alreadySubmittedToPlaylist,className:`px-4 py-2 rounded-lg flex items-center gap-2 transition-colors ${!d.allowed||d.alreadySubmittedToPlaylist?"bg-gray-300 text-gray-500 cursor-not-allowed":"bg-green-500 text-white hover:bg-green-600"}`,children:[o.jsx(me,{className:"w-4 h-4"}),"Submit Track"]})]})]})]})})}const Td=Object.freeze(Object.defineProperty({__proto__:null,SubmissionModal:rt},Symbol.toStringTag,{value:"Module"}));function kd({message:t,type:e,onClose:a}){const[r,n]=w.useState(!1);w.useEffect(()=>{const l=setTimeout(()=>{n(!0)},4700);return()=>clearTimeout(l)},[]),w.useEffect(()=>{if(r){const l=setTimeout(()=>{a()},300);return()=>clearTimeout(l)}},[r,a]);const s={success:"bg-green-500",error:"bg-red-500",info:"bg-blue-500"}[e],i={success:Wl,error:pe,info:pe}[e];return o.jsxs("div",{className:`
        fixed bottom-4 right-4 
        ${s} text-white px-4 py-3 rounded-lg shadow-lg 
        flex items-center gap-3 max-w-md
        transition-all duration-300
        ${r?"opacity-0 translate-y-2":"opacity-100 translate-y-0"}
      `,children:[o.jsx(i,{className:"w-5 h-5 flex-shrink-0"}),o.jsx("p",{className:"flex-1",children:t}),o.jsx("button",{onClick:()=>n(!0),className:"p-1 hover:bg-white/20 rounded-full transition-colors",children:o.jsx(at,{className:"w-4 h-4"})})]})}function xt(t){const[e]=w.useState(()=>{let a=document.getElementById("toast-container");return a||(a=document.createElement("div"),a.id="toast-container",document.body.appendChild(a)),a});return Yr.createPortal(o.jsx(kd,{...t}),e)}function _d({playlist:t,baseUrl:e}){var r;const a={"@context":"https://schema.org","@type":"MusicPlaylist",name:t.name,description:`Get your music featured on ${t.name}, a Spotify playlist curated by ${t.curator_name} with ${t.followers.toLocaleString()} followers. No account needed! Access thousands of playlists and connect with curators on PlaylistPartner.com.`,numTracks:t.track_count,url:`${e}/playlist/${t.spotify_id}`,sameAs:[`https://open.spotify.com/playlist/${t.spotify_id}`],dateModified:t.updated_at,image:t.image_url,author:{"@type":"Person",name:t.curator_name,url:t.curator_profile_url},genre:[t.genre,...((r=t.sub_genres)==null?void 0:r.slice(0,2))||[]].filter(Boolean),interactionStatistic:{"@type":"InteractionCounter",interactionType:"https://schema.org/FollowAction",userInteractionCount:t.followers},isPartOf:{"@id":e}};return o.jsx("script",{type:"application/ld+json",children:JSON.stringify(a)})}function jd(){var A;const{slug:t}=Vt(),e=Ce(),a=Kt(),[r,n]=w.useState(!1),[s,i]=w.useState(null),[l,c]=w.useState(0),{playlist:d,loading:u,error:h,relatedPlaylists:p,isNotFound:y}=cd(t||""),[m,f]=w.useState(!1);w.useEffect(()=>{f(!1)},[t]),w.useEffect(()=>{!u&&d&&!h&&!y&&typeof window<"u"&&window.prerenderReady!==void 0&&(window.prerenderReady=!0)},[u,d,h,y]),w.useEffect(()=>{async function S(){if(d!=null&&d.genre){const{count:E}=await U.from("playlist_details").select("*",{count:"exact",head:!0}).eq("genre",d.genre);c(E||0)}}d&&S()},[d]);const g=Qe(),v=d&&(g==null?void 0:g.lastTrack)&&hs(d.id,g.lastTrack.external_urls.spotify),x=()=>{var E;const S=(E=a.state)==null?void 0:E.from;e(S==="genre"?-1:"/playlists")},T=async S=>{try{n(!1),i({type:"success",message:`Track submitted to ${d==null?void 0:d.name}! Watch your inbox for feedback from the curator.`})}catch(E){console.error("Failed to submit track:",E),i({type:"error",message:"Failed to submit track. Please try again."})}};if(u)return o.jsx("div",{className:"container mx-auto px-4 py-8",children:o.jsxs("div",{className:"animate-pulse",children:[o.jsx("div",{className:"h-8 w-48 bg-gray-200 rounded mb-6"}),o.jsx("div",{className:"bg-white shadow-lg",children:o.jsxs("div",{className:"grid md:grid-cols-2",children:[o.jsx("div",{className:"aspect-square bg-gray-200"}),o.jsxs("div",{className:"p-6",children:[o.jsx("div",{className:"h-8 w-3/4 bg-gray-200 rounded mb-4"}),o.jsx("div",{className:"h-4 w-1/2 bg-gray-200 rounded mb-4"}),o.jsx("div",{className:"h-20 bg-gray-200 rounded mb-4"})]})]})})]})});if(y||!d)return o.jsx("div",{className:"container mx-auto px-4 py-8",children:o.jsxs("div",{className:"text-center",children:[o.jsxs("div",{className:"flex items-center justify-center gap-2 text-red-600 mb-4",children:[o.jsx(pe,{className:"w-6 h-6"}),o.jsx("h2",{className:"text-2xl font-bold",children:"Playlist Not Found"})]}),o.jsx("p",{className:"text-gray-600 mb-6",children:"The playlist you're looking for doesn't exist or may have been removed."}),o.jsxs("button",{onClick:x,className:"text-green-600 hover:text-green-700 flex items-center gap-2 mx-auto",children:[o.jsx(ye,{className:"w-4 h-4"}),"Back to Playlists"]})]})});if(h)return o.jsx("div",{className:"container mx-auto px-4 py-8",children:o.jsxs("div",{className:"text-center",children:[o.jsxs("div",{className:"flex items-center justify-center gap-2 text-red-600 mb-4",children:[o.jsx(pe,{className:"w-6 h-6"}),o.jsx("h2",{className:"text-2xl font-bold",children:"Error Loading Playlist"})]}),o.jsx("p",{className:"text-gray-600 mb-6",children:h.message||"Something went wrong. Please try again."}),o.jsxs("button",{onClick:x,className:"text-green-600 hover:text-green-700 flex items-center gap-2 mx-auto",children:[o.jsx(ye,{className:"w-4 h-4"}),"Back to Playlists"]})]})});const j=`Get your music featured on ${d.name}, a Spotify playlist curated by ${d.curator_name||"Independent Curator"}. No account needed! Access ${l} ${d.genre} playlists and connect with curators on PlaylistPartner.com.`;return o.jsxs(o.Fragment,{children:[o.jsx(ce,{title:d==null?void 0:d.name,description:j,image:d==null?void 0:d.image_url,playlist:d?{name:d.name,curator_name:d.curator_name,followers:d.followers,updated_at:d.updated_at,genre:d.genre,genre_count:l}:void 0}),d&&o.jsx(_d,{playlist:d,baseUrl:window.location.origin}),o.jsxs("main",{className:"container mx-auto px-4 py-8",children:[o.jsxs("button",{onClick:x,className:"inline-flex items-center gap-2 text-green-600 hover:text-green-700 mb-6",children:[o.jsx(ye,{className:"w-4 h-4"}),"Back to Playlists"]}),o.jsx("div",{className:"bg-white shadow-lg",children:o.jsxs("div",{className:"grid md:grid-cols-2",children:[o.jsx("div",{className:"relative aspect-square bg-gray-100",children:!d.image_url||m?o.jsx("div",{className:"absolute inset-0 flex items-center justify-center bg-gradient-to-br from-gray-100 to-gray-200",children:o.jsxs("div",{className:"text-center",children:[o.jsx(os,{className:"w-16 h-16 text-gray-400 mx-auto mb-3"}),o.jsx("div",{className:"text-base text-gray-500 font-medium px-4 truncate max-w-[300px]",children:d.name})]})}):o.jsx("img",{src:d.image_url,alt:d.name,className:"w-full h-full object-cover",onError:()=>f(!0)})}),o.jsxs("div",{className:"p-6 flex flex-col justify-between",children:[o.jsxs("div",{children:[o.jsxs("div",{className:"flex items-start justify-between gap-4 mb-2",children:[o.jsx("h1",{className:"text-3xl md:text-4xl font-bold",children:d.name}),o.jsxs("div",{className:"flex gap-2 flex-shrink-0",children:[d.featured&&o.jsxs("div",{className:"bg-yellow-400 text-yellow-900 px-3 py-1.5 rounded-full text-sm font-medium flex items-center gap-1.5",children:[o.jsx(ls,{className:"w-4 h-4"}),"Featured"]}),(()=>{const S=ys(d.published_at);if(!S)return null;const _={today:{text:"Added Today",bg:"bg-green-500",textColor:"text-white"},yesterday:{text:"Added Yesterday",bg:"bg-blue-500",textColor:"text-white"},"this-week":{text:"Added This Week",bg:"bg-purple-500",textColor:"text-white"}}[S];return o.jsxs("div",{className:`${_.bg} ${_.textColor} px-3 py-1.5 rounded-full text-sm font-medium flex items-center gap-1.5`,children:[o.jsx(ss,{className:"w-4 h-4"}),_.text]})})()]})]}),o.jsxs("div",{className:"flex items-center gap-2 text-gray-600 mb-4",children:[o.jsx(Qt,{className:"w-5 h-5"}),o.jsx("span",{className:"text-lg",children:"Curated by "}),d.curator_profile_url?o.jsx("a",{href:d.curator_profile_url,target:"_blank",rel:"noopener noreferrer",className:"text-lg hover:text-green-600 transition-colors",children:d.curator_name}):o.jsx("span",{className:"text-lg",children:d.curator_name||"Independent Curator"})]}),o.jsx("p",{className:"text-gray-600 text-lg mb-4",children:d.description}),o.jsxs("div",{className:"flex flex-wrap gap-6 mb-4",children:[o.jsxs(R,{to:`/genre/${d.genre_slug}`,className:"flex items-center text-gray-700 hover:text-green-600 transition-colors",children:[o.jsx(me,{className:"w-5 h-5 mr-2"}),o.jsx("span",{className:"text-lg",children:d.genre})]}),o.jsxs("div",{className:"flex items-center text-gray-700",children:[o.jsx(Xt,{className:"w-5 h-5 mr-2"}),o.jsxs("span",{className:"text-lg",children:[d.followers.toLocaleString()," followers"]})]})]}),((A=d.sub_genres)==null?void 0:A.length)>0&&o.jsx("div",{className:"flex flex-wrap gap-2 mb-6",children:d.sub_genres.map(S=>o.jsx(R,{to:`/genre/${d.genre_slug}/${S.toLowerCase().replace(/\s+/g,"-")}`,className:"px-3 py-1 bg-gray-100 text-gray-700 rounded-full text-sm hover:bg-gray-200 transition-colors",children:S},S))})]}),v?o.jsxs("div",{className:"w-full sm:w-auto flex items-center justify-center gap-2 bg-gray-100 text-gray-500 px-6 py-3 font-medium",children:[o.jsx(ns,{className:"w-5 h-5"}),"Track Submitted"]}):o.jsxs("button",{onClick:()=>n(!0),className:"w-full sm:w-auto flex items-center justify-center gap-2 bg-green-500 text-white px-6 py-3 hover:bg-green-600 transition-colors text-lg font-medium",children:[o.jsx(is,{className:"w-5 h-5"}),"Submit Your Track"]})]})]})}),p.length>0&&o.jsxs("div",{className:"mt-12",children:[o.jsx("h2",{className:"text-2xl font-bold mb-6",children:"Related Playlists"}),o.jsx("div",{className:"grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4 gap-6",children:p.map(S=>o.jsx(rr,{playlist:S,onSubmit:()=>n(!0),isRelated:!0,hideSubmit:!0},S.id))})]}),r&&d&&o.jsx(rt,{playlist:d,onClose:()=>n(!1),onSubmit:T}),s&&o.jsx(xt,{message:s.message,type:s.type,onClose:()=>i(null)})]})]})}function Sd({filters:t,onFilterChange:e,hideGenreFilter:a,autoFocus:r}){const{genres:n,loading:s}=De(),i=n.find(d=>d.name===t.genre),l=w.useRef(null),c=w.useRef(null);return w.useEffect(()=>{r&&l.current&&c.current&&(l.current.focus(),c.current.classList.add("search-focus-animation"),setTimeout(()=>{var d;(d=c.current)==null||d.classList.remove("search-focus-animation")},1800),window.history.replaceState({},""))},[r]),o.jsx("div",{className:"bg-white shadow-sm -mx-4 px-4",children:o.jsx("div",{className:"max-w-[1400px] mx-auto",children:o.jsxs("div",{className:`grid ${a?"grid-cols-2":"grid-cols-1 md:grid-cols-2 lg:grid-cols-4"} gap-4 py-4`,children:[o.jsxs("div",{ref:c,className:"relative search-container",children:[o.jsx(Ft,{className:"absolute left-3 top-1/2 transform -translate-y-1/2 text-gray-400 w-5 h-5 z-10"}),o.jsx("input",{ref:l,type:"text",placeholder:"Search playlists...",value:t.search,onChange:d=>e({...t,search:d.target.value}),className:"w-full pl-10 pr-4 py-2 border border-gray-300 rounded-lg focus:ring-2 focus:ring-green-500 focus:border-transparent transition-all"})]}),!a&&o.jsxs("div",{className:"relative",children:[o.jsx(me,{className:"absolute left-3 top-1/2 transform -translate-y-1/2 text-gray-400 w-5 h-5"}),o.jsxs("select",{value:t.genre,onChange:d=>e({...t,genre:d.target.value,subGenre:""}),className:"w-full pl-10 pr-4 py-2 border border-gray-300 rounded-lg appearance-none focus:ring-2 focus:ring-green-500 focus:border-transparent disabled:bg-gray-50 disabled:text-gray-500",disabled:s,children:[o.jsx("option",{value:"",children:"All Genres"}),n.map(d=>o.jsx("option",{value:d.name,children:d.name},d.id))]})]}),o.jsx("div",{className:"relative",children:o.jsxs("select",{value:t.subGenre||"",onChange:d=>e({...t,subGenre:d.target.value}),className:`w-full px-4 py-2 border border-gray-300 rounded-lg appearance-none transition-colors
                ${i?"focus:ring-2 focus:ring-green-500 focus:border-transparent":"bg-gray-50 text-gray-400 cursor-not-allowed"}`,disabled:!i,children:[o.jsx("option",{value:"",children:i?"All Sub-genres":"-- Select a genre first --"}),i==null?void 0:i.subGenres.map(d=>o.jsx("option",{value:d.name,children:d.name},d.id))]})}),o.jsx("div",{className:"relative",children:o.jsxs("select",{value:t.sortBy,onChange:d=>e({...t,sortBy:d.target.value}),className:"w-full px-4 py-2 border border-gray-300 rounded-lg appearance-none focus:ring-2 focus:ring-green-500 focus:border-transparent",children:[o.jsx("option",{value:"default",children:"Default (Most Recent)"}),o.jsx("option",{value:"followers-high",children:"Most Followers"}),o.jsx("option",{value:"followers-low",children:"Least Followers"})]})})]})})})}const it="playlist_state";function ea(t){const[e,a]=w.useState(()=>{try{const f=sessionStorage.getItem(it);if(f){const g=JSON.parse(f);if(JSON.stringify(g.filters)===JSON.stringify(t))return g.playlists}return[]}catch{return[]}}),[r,n]=w.useState(!0),[s,i]=w.useState(null),[l,c]=w.useState(!0),[d,u]=w.useState(()=>{try{const f=sessionStorage.getItem(it);if(f){const g=JSON.parse(f);if(JSON.stringify(g.filters)===JSON.stringify(t))return g.currentPage}return 1}catch{return 1}}),[h,p]=w.useState(0),y=12;return w.useEffect(()=>{!r&&h>0&&typeof window<"u"&&window.prerenderReady!==void 0&&(window.prerenderReady=!0)},[r,h]),w.useEffect(()=>{(()=>{const g=sessionStorage.getItem(it);if(g){const v=JSON.parse(g);return JSON.stringify(v.filters)!==JSON.stringify(t)}return!0})()&&(a([]),u(1),c(!0),sessionStorage.removeItem(it))},[t==null?void 0:t.genre,t==null?void 0:t.subGenre,t==null?void 0:t.search,t==null?void 0:t.sortBy]),w.useEffect(()=>{if(e.length>0){const f={playlists:e,currentPage:d,filters:t||{}};sessionStorage.setItem(it,JSON.stringify(f))}},[e,d,t]),w.useEffect(()=>{async function f(){try{n(!0),i(null);let g=U.from("playlist_details").select("*",{count:"exact"});if(t!=null&&t.genre&&(g=g.eq("genre",t.genre)),t!=null&&t.subGenre&&(g=g.contains("sub_genres",[t.subGenre])),t!=null&&t.search){const v=`%${t.search}%`;g=g.or(`name.ilike.${v},description.ilike.${v}`)}switch(t==null?void 0:t.sortBy){case"followers-high":case"followers-low":if(!(t!=null&&t.genre)&&!(t!=null&&t.subGenre)){let v=U.from("playlist_details").select("*").eq("featured",!0).order("id",{ascending:!1});if(t!=null&&t.search){const k=`%${t.search}%`;v=v.or(`name.ilike.${k},description.ilike.${k}`)}const{data:x}=await v,T=x?[...x].sort((k,L)=>{const q=Ge(),Te=z(`${q}-featured-${k.id}`),ke=z(`${q}-featured-${L.id}`);return Te-ke}).slice(0,4):[];let j,A;d===1?(j=Math.max(8,12-T.length),A=0):(j=12,A=12-T.length+(d-2)*12);let S=U.from("playlist_details").select("*",{count:"exact"}).order("followers",{ascending:t.sortBy==="followers-low"}).order("id",{ascending:!1});if(t!=null&&t.search){const k=`%${t.search}%`;S=S.or(`name.ilike.${k},description.ilike.${k}`)}const{data:E,count:_}=await S.range(A,A+j-1);if(d===1){const k=[...T,...E||[]];a(k)}else a(k=>[...k,...E||[]]);p(_||0),c(A+j<(_||0)),n(!1);return}else{let v=U.from("playlist_details").select("*").eq("featured",!0).eq("genre",t.genre).order("id",{ascending:!1});if(t!=null&&t.subGenre&&(v=v.contains("sub_genres",[t.subGenre])),t!=null&&t.search){const k=`%${t.search}%`;v=v.or(`name.ilike.${k},description.ilike.${k}`)}const{data:x}=await v,T=x?[...x].sort((k,L)=>{const q=Ge(),Te=z(`${q}-featured-${k.id}`),ke=z(`${q}-featured-${L.id}`);return Te-ke}).slice(0,4):[];let j,A;d===1?(j=Math.max(8,12-T.length),A=0):(j=12,A=12-T.length+(d-2)*12);let S=U.from("playlist_details").select("*",{count:"exact"}).eq("genre",t.genre).order("followers",{ascending:t.sortBy==="followers-low"}).order("id",{ascending:!1});if(t!=null&&t.subGenre&&(S=S.contains("sub_genres",[t.subGenre])),t!=null&&t.search){const k=`%${t.search}%`;S=S.or(`name.ilike.${k},description.ilike.${k}`)}const{data:E,count:_}=await S.range(A,A+j-1);if(d===1){const k=[...T,...E||[]];a(k)}else a(k=>[...k,...E||[]]);p(_||0),c(A+j<(_||0)),n(!1);return}case"default":default:if(!(t!=null&&t.genre)&&!(t!=null&&t.subGenre)){let v=U.from("playlist_details").select("*").eq("featured",!0).order("id",{ascending:!1});if(t!=null&&t.search){const k=`%${t.search}%`;v=v.or(`name.ilike.${k},description.ilike.${k}`)}const{data:x}=await v,T=x?[...x].sort((k,L)=>{const q=Ge(),Te=z(`${q}-featured-${k.id}`),ke=z(`${q}-featured-${L.id}`);return Te-ke}).slice(0,4):[];let j,A;d===1?(j=Math.max(8,12-T.length),A=0):(j=12,A=12-T.length+(d-2)*12);let S=U.from("playlist_details").select("*",{count:"exact"}).order("published_at",{ascending:!1,nullsFirst:!1}).order("id",{ascending:!1});if(t!=null&&t.search){const k=`%${t.search}%`;S=S.or(`name.ilike.${k},description.ilike.${k}`)}const{data:E,count:_}=await S.range(A,A+j-1);if(d===1){const k=[...T,...E||[]];a(k)}else a(k=>[...k,...E||[]]);p(_||0),c(A+j<(_||0)),n(!1);return}else{let v=U.from("playlist_details").select("*").eq("featured",!0).eq("genre",t.genre).order("id",{ascending:!1});if(t!=null&&t.subGenre&&(v=v.contains("sub_genres",[t.subGenre])),t!=null&&t.search){const k=`%${t.search}%`;v=v.or(`name.ilike.${k},description.ilike.${k}`)}const{data:x}=await v,T=x?[...x].sort((k,L)=>{const q=Ge(),Te=z(`${q}-featured-${k.id}`),ke=z(`${q}-featured-${L.id}`);return Te-ke}).slice(0,4):[];let j,A;d===1?(j=Math.max(8,12-T.length),A=0):(j=12,A=12-T.length+(d-2)*12);let S=U.from("playlist_details").select("*",{count:"exact"}).eq("genre",t.genre).order("published_at",{ascending:!1,nullsFirst:!1}).order("id",{ascending:!1});if(t!=null&&t.subGenre&&(S=S.contains("sub_genres",[t.subGenre])),t!=null&&t.search){const k=`%${t.search}%`;S=S.or(`name.ilike.${k},description.ilike.${k}`)}const{data:E,count:_}=await S.range(A,A+j-1);if(d===1){const k=[...T,...E||[]];a(k)}else a(k=>[...k,...E||[]]);p(_||0),c(A+j<(_||0)),n(!1);return}}}catch(g){console.error("Failed to fetch playlists:",g),i(g instanceof Error?g:new Error("Failed to fetch playlists"))}finally{n(!1)}}f()},[d,t==null?void 0:t.genre,t==null?void 0:t.subGenre,t==null?void 0:t.search,t==null?void 0:t.sortBy]),{playlists:e,loading:r,error:s,hasMore:l,loadMore:()=>{!r&&l&&u(f=>f+1)},currentPage:d,totalCount:h,itemsPerPage:y}}function Ed(){var j,A,S;const t=Kt(),[e,a]=Jr(),[r,n]=w.useState(()=>{var k;const E=(k=t.state)==null?void 0:k.filters,_=sessionStorage.getItem("playlist_filters");return _&&!(E!=null&&E.fromSubmission)?JSON.parse(_):E?(window.history.replaceState({},""),{search:"",genre:E.genre||"",subGenre:E.subGenre||"",sortBy:"default"}):{search:"",genre:"",subGenre:"",sortBy:"default"}});w.useEffect(()=>{window.scrollTo(0,0)},[]);const{playlists:s,loading:i,error:l,hasMore:c,loadMore:d,totalCount:u}=ea({...r,genre:r.genre||void 0,subGenre:r.subGenre||void 0}),[h,p]=w.useState(null),[y,m]=w.useState(null),f=Qe(),[g,v]=w.useState(!0);w.useEffect(()=>{var E;if(!i&&s.length>0&&g){const _=(E=t.state)==null?void 0:E.filters;_!=null&&_.fromSubmission?window.scrollTo(0,0):ps.restorePosition(t.pathname,a),v(!1)}},[i,s.length,t.pathname,t.state,a,g]),w.useEffect(()=>{sessionStorage.setItem("playlist_filters",JSON.stringify(r))},[r]);const x=s.length>0?1:0,T=s.length;return o.jsxs(o.Fragment,{children:[o.jsx(ce,{}),o.jsxs("main",{children:[o.jsxs("div",{className:"container mx-auto px-4 pb-12",children:[o.jsx(Sd,{filters:r,onFilterChange:n,autoFocus:(j=t.state)==null?void 0:j.focusSearch}),(f==null?void 0:f.lastTrack)&&o.jsxs("div",{className:"mb-6 flex items-center justify-between bg-white p-4 shadow-sm rounded-lg max-w-[1400px] mx-auto",children:[o.jsxs("div",{className:"flex items-center gap-4",children:[o.jsx("img",{src:(A=f.lastTrack.album.images[2])==null?void 0:A.url,alt:f.lastTrack.name,className:"w-12 h-12 object-cover rounded-md"}),o.jsxs("div",{children:[o.jsx("p",{className:"font-medium",children:f.lastTrack.name}),o.jsx("p",{className:"text-sm text-gray-600",children:(S=f.lastTrack.artists[0])==null?void 0:S.name})]})]}),o.jsx("button",{onClick:()=>{us(),window.location.reload()},className:"p-2 hover:bg-gray-100 rounded-full transition-colors",title:"Clear selected track",children:o.jsx(at,{className:"w-5 h-5 text-gray-500"})})]}),o.jsxs("div",{className:"max-w-[1400px] mx-auto",style:{minHeight:"800px"},children:[s.length>0&&o.jsxs("div",{className:"text-sm text-gray-600 mb-6 mt-6",children:["Showing ",x,"-",T," of ",u," playlists"]}),o.jsx("div",{className:"grid grid-cols-1 sm:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4 gap-4",children:s.map((E,_)=>o.jsx(rr,{playlist:E,onSubmit:k=>p(s.find(L=>L.id===k)||null),priority:_<4,showFeaturedBadge:_<4},`${E.id}-${_}`))}),i&&o.jsx("div",{className:"flex items-center justify-center py-12",children:o.jsx(Re,{className:"w-8 h-8 text-green-500 animate-spin"})}),l&&o.jsx("div",{className:"text-center py-12",children:o.jsx("p",{className:"text-red-500",children:"Failed to load playlists. Please try again."})}),!i&&!l&&s.length===0&&o.jsx("div",{className:"text-center py-12",children:o.jsx("p",{className:"text-gray-500 text-lg",children:"No playlists found matching your criteria."})}),c&&!i&&o.jsx("div",{className:"text-center mt-8",children:o.jsx("button",{onClick:d,className:"px-6 py-3 bg-green-500 text-white rounded-lg hover:bg-green-600 transition-colors",children:"Load More Playlists"})})]})]}),h&&o.jsx(rt,{playlist:h,onClose:()=>p(null),onSubmit:()=>{p(null),m({type:"success",message:`Track submitted to ${h.name}! Watch your inbox for feedback from the curator.`})}}),y&&o.jsx(xt,{message:y.message,type:y.type,onClose:()=>m(null)})]})]})}function Nd(){const t=Ce(),[e,a]=w.useState(null);w.useEffect(()=>{typeof window<"u"&&window.prerenderReady!==void 0&&(window.prerenderReady=!0)},[]);const r=n=>{var s;cs({artistName:((s=n.artists[0])==null?void 0:s.name)||"",email:"",track:n}),t("/submit/genre",{state:{selectedTrack:n}})};return o.jsxs("div",{className:"container mx-auto px-4 py-8 max-w-2xl",children:[o.jsxs("button",{onClick:()=>t("/playlists"),className:"flex items-center gap-2 text-gray-600 hover:text-gray-800 transition-colors mb-6",children:[o.jsx(ye,{className:"w-5 h-5"}),"Back to Playlists"]}),o.jsxs("div",{className:"space-y-6",children:[o.jsxs("div",{className:"text-center",children:[o.jsx("h1",{className:"text-3xl font-bold mb-2",children:"Submit Your Track"}),o.jsx("p",{className:"text-gray-600",children:"Search for your track on Spotify to get started"})]}),o.jsx("div",{className:"bg-white p-6 rounded-xl shadow-lg",children:o.jsx(fs,{onTrackSelect:r,selectedTrack:e,onClearTrack:()=>a(null)})}),e&&o.jsxs("button",{onClick:()=>r(e),className:"w-full flex items-center justify-center gap-2 bg-green-500 text-white p-4 rounded-lg hover:bg-green-600 transition-colors",children:["Continue to Genre Selection",o.jsx(bt,{className:"w-5 h-5"})]})]})]})}function Ad(){const t=Ce(),{genres:e}=De(),[a,r]=w.useState(""),[n,s]=w.useState(""),i=e.find(u=>u.id===a),l=(i==null?void 0:i.subGenres)||[],c=u=>{s(u)},d=u=>{if(!a||!i)return;const h=n?l.find(p=>p.id===n):null;window.scrollTo(0,0),t("/playlists",{state:{filters:{genre:i.name,subGenre:(h==null?void 0:h.name)||"",fromSubmission:!0}},replace:!0})};return o.jsx("div",{className:"container mx-auto px-4 py-8 max-w-4xl",children:o.jsxs("div",{className:"space-y-8",children:[o.jsxs("div",{className:"text-center",children:[o.jsx("h1",{className:"text-3xl font-bold mb-2",children:"Select Your Genre"}),o.jsx("p",{className:"text-gray-600",children:"Choose the main category that best fits your track"})]}),o.jsxs("div",{children:[o.jsx("h2",{className:"text-lg font-medium mb-3",children:"Main Genre"}),o.jsx("div",{className:"grid grid-cols-2 sm:grid-cols-3 md:grid-cols-4 gap-3",children:e.map(u=>o.jsxs("button",{onClick:()=>{r(u.id),s("")},className:`p-4 text-center border-2 rounded-lg transition-colors ${a===u.id?"border-green-500 bg-green-50":"border-gray-200 hover:border-green-500 hover:bg-green-50"}`,children:[o.jsx(me,{className:"w-6 h-6 mx-auto mb-2 text-gray-600"}),o.jsx("span",{className:"font-medium",children:u.name})]},u.id))})]}),a&&l.length>0&&o.jsxs("div",{children:[o.jsx("h2",{className:"text-lg font-medium mb-3",children:"Sub-genre (Optional)"}),o.jsx("div",{className:"grid grid-cols-2 sm:grid-cols-3 md:grid-cols-4 gap-3",children:l.map(u=>o.jsx("button",{onClick:()=>c(u.id),className:`p-3 text-center border-2 rounded-lg transition-colors ${n===u.id?"border-green-500 bg-green-50":"border-gray-200 hover:border-green-500 hover:bg-green-50"}`,children:o.jsx("span",{className:"font-medium",children:u.name})},u.id))})]}),o.jsxs("div",{className:"flex justify-between items-center",children:[o.jsxs("button",{onClick:()=>t("/submit"),className:"flex items-center gap-2 text-gray-600 hover:text-gray-800 transition-colors",children:[o.jsx(ye,{className:"w-5 h-5"}),"Back to Track Selection"]}),o.jsxs("button",{onClick:()=>d(),disabled:!a,className:`flex items-center gap-2 px-6 py-3 rounded-lg font-medium transition-colors ${a?"bg-green-500 text-white hover:bg-green-600":"bg-gray-200 text-gray-500 cursor-not-allowed"}`,children:["Continue to Playlists",o.jsx(bt,{className:"w-5 h-5"})]})]})]})})}function Pd(t=4,e,a){const[r,n]=w.useState([]),[s,i]=w.useState(!0),[l,c]=w.useState(null);return w.useEffect(()=>{!s&&r.length>0&&typeof window<"u"&&window.prerenderReady!==void 0&&(window.prerenderReady=!0)},[s,r.length]),w.useEffect(()=>{async function d(){try{i(!0),c(null);let u=U.from("playlist_details").select("*").eq("featured",!0);e&&(u=u.eq("genre",e)),a&&(u=u.contains("sub_genres",[a]));const{data:h,error:p}=await u;if(p)throw p;const y=h||[];if(y.length>=t){const S=Ge(),E=[...y].sort((_,k)=>{const L=z(`${S}-${_.id}`),q=z(`${S}-${k.id}`);return L-q});n(E.slice(0,t));return}const m=t-y.length;let f=U.from("playlist_details").select("*").eq("featured",!1);e&&(f=f.eq("genre",e)),a&&(f=f.contains("sub_genres",[a]));const{data:g,error:v}=await f;if(v)throw v;const x=Ge(),T=[...y].sort((S,E)=>{const _=z(`${x}-featured-${S.id}`),k=z(`${x}-featured-${E.id}`);return _-k}),j=[...g||[]].sort((S,E)=>{const _=z(`${x}-nonfeatured-${S.id}`),k=z(`${x}-nonfeatured-${E.id}`);return _-k}),A=[...T,...j.slice(0,m)];n(A)}catch(u){console.error("Failed to fetch playlists:",u),c(u instanceof Error?u:new Error("Failed to fetch playlists"))}finally{i(!1)}}d()},[t,e,a]),{playlists:r,loading:s,error:l}}function gs({genre:t,subGenre:e,totalCount:a,onViewAll:r}){const{playlists:n,loading:s}=Pd(8,t,e),[i,l]=w.useState(null),[c,d]=w.useState(null);if(s||n.length===0)return null;const h=new Date().toLocaleDateString("en-US",{weekday:"long",month:"long",day:"numeric"}),p=e?`Today's Featured ${e} ${t} Playlists - ${h}`:`Today's Featured ${t} Playlists - ${h}`,y=new URLSearchParams;return y.set("genre",t),e&&y.set("subGenre",e),o.jsxs(o.Fragment,{children:[o.jsxs("div",{className:"border-l-4 border-green-500 pl-6 mb-8",children:[o.jsx("h2",{className:"text-2xl font-semibold text-gray-900 mb-6",children:p}),o.jsx("div",{className:"grid grid-cols-1 sm:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4 gap-4",children:n.map(m=>o.jsx(rr,{playlist:m,onSubmit:f=>l(n.find(g=>g.id===f)||null),priority:!0,showFeaturedBadge:!0},m.id))})]}),o.jsx("div",{className:"text-center mb-12",children:o.jsxs("button",{onClick:r,className:"inline-block px-8 py-4 bg-green-500 text-white text-lg font-semibold rounded-lg hover:bg-green-600 transition-all transform hover:scale-105 shadow-lg hover:shadow-xl",children:["View All ",a.toLocaleString()," ",e?`${e} ${t}`:t," Playlists"]})}),i&&o.jsx(rt,{playlist:i,onClose:()=>l(null),onSubmit:()=>{l(null),d({type:"success",message:`Track submitted to ${i.name}! Watch your inbox for feedback from the curator.`})}}),c&&o.jsx(xt,{message:c.message,type:c.type,onClose:()=>d(null)})]})}const Od="https://ftwlzdhkzqfuosdorgjt.supabase.co/storage/v1/object/public/playlistpartner%20public/playlistpartner%20og%20image.png";function Id(){const{genre:t}=Vt(),e=t?decodeURIComponent(t):"",{genres:a,loading:r}=De(),n=a.find(v=>v.slug===e),[s,i]=w.useState(null),[l,c]=w.useState(!1),[d,u]=w.useState(null),h=Ce(),{totalCount:p}=ea({genre:n==null?void 0:n.name}),y=()=>{n&&(window.scrollTo(0,0),h("/playlists",{state:{filters:{genre:n.name,fromSubmission:!0}},replace:!0}))};if(r)return o.jsx("div",{className:"container mx-auto px-4 py-8",children:o.jsx("div",{className:"flex items-center justify-center min-h-[400px]",children:o.jsx(Re,{className:"w-8 h-8 text-green-500 animate-spin"})})});if(!r&&!n)return o.jsxs("div",{className:"container mx-auto px-4 py-8",children:[o.jsx("h1",{className:"text-2xl font-bold mb-4",children:"Genre Not Found"}),o.jsx(R,{to:"/",className:"text-green-600 hover:text-green-700",children:"Return to Home"})]});const m=`Free ${n.name} Spotify Playlist Submission - No Signup`,f=`Submit your ${n.name} tracks to ${p} Spotify playlists for free. Connect with independent curators and grow your audience — no signup needed.`,g=async v=>{try{c(!1),u({type:"success",message:`Track submitted to ${s==null?void 0:s.name}! Watch your inbox for feedback from the curator.`})}catch(x){console.error("Failed to submit track:",x),u({type:"error",message:"Failed to submit track. Please try again."})}};return o.jsxs(o.Fragment,{children:[o.jsx(ce,{title:m,description:f,image:Od,url:`${window.location.origin}/genre/${n.slug}`,type:"website"}),o.jsxs("main",{className:"container mx-auto px-4 py-8",children:[o.jsxs(R,{to:"/",className:"inline-flex items-center gap-2 text-green-600 hover:text-green-700 mb-6",children:[o.jsx(ye,{className:"w-4 h-4"}),"Back to All Genres"]}),o.jsx("div",{className:"bg-white p-6 rounded-lg shadow-sm mb-8",children:o.jsxs("div",{className:"flex items-start gap-4",children:[o.jsx("div",{className:"p-3 bg-green-50 rounded-lg",children:o.jsx(me,{className:"w-8 h-8 text-green-600"})}),o.jsxs("div",{children:[o.jsxs("h1",{className:"text-3xl font-bold mb-2",children:[n.name," Spotify Playlist Submission"]}),o.jsx("p",{className:"text-gray-600 mb-4",children:n.description}),o.jsx("div",{className:"flex gap-4 text-sm text-gray-600",children:o.jsxs("span",{children:[p," Playlists"]})})]})]})}),o.jsx(gs,{genre:n.name,totalCount:p,onViewAll:y}),l&&s&&o.jsx(rt,{playlist:s,onClose:()=>{c(!1),i(null)},onSubmit:g}),d&&o.jsx(xt,{message:d.message,type:d.type,onClose:()=>u(null)})]})]})}const Rd="https://ftwlzdhkzqfuosdorgjt.supabase.co/storage/v1/object/public/playlistpartner%20public/playlistpartner%20og%20image.png";function Cd(){const{genre:t,subGenre:e}=Vt(),a=t?decodeURIComponent(t):"",r=e?decodeURIComponent(e):"",{genres:n,loading:s}=De(),i=n.find(j=>j.slug===a),l=i==null?void 0:i.subGenres.find(j=>mt(j.name)===r),[c,d]=w.useState(null),[u,h]=w.useState(!1),[p,y]=w.useState(null),m=Ce(),{totalCount:f}=ea({genre:i==null?void 0:i.name,subGenre:l==null?void 0:l.name}),g=()=>{!i||!l||(window.scrollTo(0,0),m("/playlists",{state:{filters:{genre:i.name,subGenre:l.name,fromSubmission:!0}},replace:!0}))};if(s)return o.jsx("div",{className:"container mx-auto px-4 py-8",children:o.jsx("div",{className:"flex items-center justify-center min-h-[400px]",children:o.jsx(Re,{className:"w-8 h-8 text-green-500 animate-spin"})})});if(!s&&(!i||!l))return o.jsxs("div",{className:"container mx-auto px-4 py-8",children:[o.jsx("h1",{className:"text-2xl font-bold mb-4",children:"Sub-Genre Not Found"}),o.jsx(R,{to:"/",className:"text-green-600 hover:text-green-700",children:"Return to Home"})]});const v=`Free ${l.name} Spotify Playlist Submission - No Signup`,x=`Submit your ${l.name} tracks to ${f} Spotify playlists for free. Connect with independent curators and grow your audience — no signup needed.`,T=async j=>{try{h(!1),y({type:"success",message:`Track submitted to ${c==null?void 0:c.name}! Watch your inbox for feedback from the curator.`})}catch(A){console.error("Failed to submit track:",A),y({type:"error",message:"Failed to submit track. Please try again."})}};return o.jsxs(o.Fragment,{children:[o.jsx(ce,{title:v,description:x,image:Rd,url:`${window.location.origin}/genre/${i.slug}/${l.slug}`,type:"website"}),o.jsxs("main",{className:"container mx-auto px-4 py-8",children:[o.jsxs(R,{to:`/genre/${encodeURIComponent(i.slug)}`,className:"inline-flex items-center gap-2 text-green-600 hover:text-green-700 mb-6",children:[o.jsx(ye,{className:"w-4 h-4"}),"Back to ",i.name," Playlists"]}),o.jsx("div",{className:"bg-white p-6 rounded-lg shadow-sm mb-8",children:o.jsxs("div",{className:"flex items-start gap-4",children:[o.jsx("div",{className:"p-3 bg-green-50 rounded-lg",children:o.jsx(me,{className:"w-8 h-8 text-green-600"})}),o.jsxs("div",{children:[o.jsxs("h1",{className:"text-3xl font-bold mb-2",children:[l.name," Spotify Playlist Submission"]}),o.jsx("p",{className:"text-gray-600 mb-4",children:l.description||`Discover curated playlists specializing in ${l.name} ${i.name} music. Submit your tracks to playlist curators who understand and appreciate your specific style.`}),o.jsx("div",{className:"flex gap-4 text-sm text-gray-600",children:o.jsxs("span",{children:[f," Playlists"]})})]})]})}),o.jsx(gs,{genre:i.name,subGenre:l.name,totalCount:f,onViewAll:g}),u&&c&&o.jsx(rt,{playlist:c,onClose:()=>{h(!1),d(null)},onSubmit:T}),p&&o.jsx(xt,{message:p.message,type:p.type,onClose:()=>y(null)})]})]})}function $d(){const{genres:t,loading:e}=De();return w.useEffect(()=>{!e&&t.length>0&&typeof window<"u"&&window.prerenderReady!==void 0&&(window.prerenderReady=!0)},[e,t]),o.jsxs(o.Fragment,{children:[o.jsx(ce,{title:"Browse Spotify Playlist Genres - Free Music Submission | PlaylistPartner",description:"Discover Spotify playlists in every genre and sub-genre. Submit your music directly to curators for free - from hip-hop to classical, find the perfect playlists for your sound.",image:"https://ftwlzdhkzqfuosdorgjt.supabase.co/storage/v1/object/public/playlistpartner%20public/playlistpartner%20og%20image.png",url:`${window.location.origin}/genres`,type:"website"}),o.jsxs("main",{className:"container mx-auto px-4 py-8 max-w-5xl",children:[o.jsxs(R,{to:"/",className:"inline-flex items-center gap-2 text-green-600 hover:text-green-700 mb-6",children:[o.jsx(ye,{className:"w-4 h-4"}),"Back to Home"]}),o.jsxs("div",{className:"bg-white rounded-lg shadow-sm p-6 mb-8",children:[o.jsx("h1",{className:"text-3xl font-bold text-gray-900 mb-2",children:"Spotify Playlist Genres"}),o.jsx("p",{className:"text-gray-600",children:"Discover Spotify playlists in every genre and sub-genre. Submit your music directly to curators for free - from hip-hop to classical, find the perfect playlists for your sound."})]}),e?o.jsx("div",{className:"grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-6",children:[...Array(6)].map((a,r)=>o.jsxs("div",{className:"bg-white p-6 rounded-lg shadow-sm animate-pulse",children:[o.jsx("div",{className:"h-6 w-1/3 bg-gray-200 rounded mb-4"}),o.jsx("div",{className:"space-y-2",children:[...Array(4)].map((n,s)=>o.jsx("div",{className:"h-4 bg-gray-100 rounded w-2/3"},s))})]},r))}):o.jsx("div",{className:"grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-6",children:t.map(a=>o.jsxs("div",{className:"bg-white p-6 rounded-lg shadow-sm",children:[o.jsxs(R,{to:`/genre/${mt(a.name)}`,className:"group flex items-center gap-3 mb-4",children:[o.jsx("div",{className:"p-2 bg-gray-50 rounded-lg group-hover:bg-green-50 transition-colors",children:o.jsx(me,{className:"w-5 h-5 text-gray-500 group-hover:text-green-600"})}),o.jsx("h2",{className:"text-xl font-semibold text-gray-900 group-hover:text-green-600 transition-colors",children:a.name})]}),a.subGenres.length>0&&o.jsx("div",{className:"space-y-1",children:a.subGenres.map(r=>o.jsxs(R,{to:`/genre/${mt(a.name)}/${mt(r.name)}`,className:"block text-gray-600 hover:text-green-600 transition-colors pl-11",children:[r.name,r.description&&o.jsx("p",{className:"text-sm text-gray-500 mt-0.5",children:r.description})]},r.id))})]},a.id))})]})]})}function Dd(){const{totalCount:t}=ea({});return o.jsxs(o.Fragment,{children:[o.jsx(ce,{title:"About PlaylistPartner - Free Spotify Playlist Submission Platform",description:"Learn about PlaylistPartner, your free platform for submitting music to Spotify playlist curators. No signup required, direct curator connections."}),o.jsx("div",{className:"bg-gradient-to-b from-green-50 to-white",children:o.jsxs("div",{className:"container mx-auto px-4 py-16 md:py-24",children:[o.jsxs("div",{className:"max-w-3xl mx-auto text-center mb-16",children:[o.jsx(Zt,{className:"w-12 h-12 text-green-600 mx-auto mb-6"}),o.jsx("h1",{className:"text-4xl font-bold text-gray-900 mb-6",children:"Music Promotion Made Simple"}),o.jsx("p",{className:"text-xl text-gray-600",children:"Submit your music directly to Spotify playlist curators without the typical barriers. No signups, no fees, and no waiting around. Only on PlaylistPartner."})]}),o.jsxs("div",{className:"max-w-5xl mx-auto grid md:grid-cols-3 gap-8 mb-24",children:[o.jsxs("div",{className:"bg-white p-6 rounded-lg shadow-sm text-center",children:[o.jsx(ql,{className:"w-8 h-8 text-green-600 mx-auto mb-4"}),o.jsx("h3",{className:"text-lg font-semibold mb-2",children:"Always Free"}),o.jsx("p",{className:"text-gray-600",children:"No hidden fees or premium features. Submit your music to 10 playlists daily – it's that simple."})]}),o.jsxs("div",{className:"bg-white p-6 rounded-lg shadow-sm text-center",children:[o.jsx(Ql,{className:"w-8 h-8 text-green-600 mx-auto mb-4"}),o.jsx("h3",{className:"text-lg font-semibold mb-2",children:"No Sign Up"}),o.jsx("p",{className:"text-gray-600",children:"Start submitting your music immediately. No account creation required."})]}),o.jsxs("div",{className:"bg-white p-6 rounded-lg shadow-sm text-center",children:[o.jsx(Xt,{className:"w-8 h-8 text-green-600 mx-auto mb-4"}),o.jsx("h3",{className:"text-lg font-semibold mb-2",children:"Direct Connection"}),o.jsx("p",{className:"text-gray-600",children:"Connect directly with curators in your genre and style. Filter playlists by genre, sub-genre, or search."})]})]}),o.jsxs("div",{className:"max-w-4xl mx-auto mb-24",children:[o.jsx("h2",{className:"text-3xl font-bold text-center mb-12",children:"How It Works"}),o.jsxs("div",{className:"space-y-12",children:[o.jsxs("div",{className:"flex items-start gap-6",children:[o.jsx("div",{className:"w-10 h-10 rounded-full bg-green-100 flex-shrink-0 flex items-center justify-center",children:o.jsx("span",{className:"text-green-600 font-bold",children:"1"})}),o.jsxs("div",{children:[o.jsx("h3",{className:"text-xl font-semibold mb-2",children:"Find Your Playlists"}),o.jsx("p",{className:"text-gray-600",children:"Browse our curated collection of Spotify playlists by genre, sub genre or follower count."})]})]}),o.jsxs("div",{className:"flex items-start gap-6",children:[o.jsx("div",{className:"w-10 h-10 rounded-full bg-green-100 flex-shrink-0 flex items-center justify-center",children:o.jsx("span",{className:"text-green-600 font-bold",children:"2"})}),o.jsxs("div",{children:[o.jsx("h3",{className:"text-xl font-semibold mb-2",children:"Submit Your Track"}),o.jsx("p",{className:"text-gray-600",children:"Select your track from Spotify and submit it to any playlist that matches your style. Add a personal message to the curator to increase your chances."})]})]}),o.jsxs("div",{className:"flex items-start gap-6",children:[o.jsx("div",{className:"w-10 h-10 rounded-full bg-green-100 flex-shrink-0 flex items-center justify-center",children:o.jsx("span",{className:"text-green-600 font-bold",children:"3"})}),o.jsxs("div",{children:[o.jsx("h3",{className:"text-xl font-semibold mb-2",children:"Get Featured"}),o.jsx("p",{className:"text-gray-600",children:"Curators review your submission and add tracks that fit their playlist. Build relationships with curators and grow your audience organically."})]})]})]})]}),o.jsx("div",{className:"max-w-4xl mx-auto border-t border-gray-200 pt-16",children:o.jsxs("div",{className:"grid grid-cols-2 md:grid-cols-4 gap-8",children:[o.jsxs("div",{className:"text-center",children:[o.jsxs("div",{className:"text-3xl font-bold text-green-600 mb-1",children:[t.toLocaleString(),"+"]}),o.jsx("div",{className:"text-sm text-gray-600",children:"Active Playlists"})]}),o.jsxs("div",{className:"text-center",children:[o.jsx("div",{className:"text-3xl font-bold text-green-600 mb-1",children:"15K+"}),o.jsx("div",{className:"text-sm text-gray-600",children:"Monthly Submissions"})]}),o.jsxs("div",{className:"text-center",children:[o.jsx("div",{className:"text-3xl font-bold text-green-600 mb-1",children:"2000+"}),o.jsx("div",{className:"text-sm text-gray-600",children:"Curators"})]}),o.jsxs("div",{className:"text-center",children:[o.jsx("div",{className:"text-3xl font-bold text-green-600 mb-1",children:"100%"}),o.jsx("div",{className:"text-sm text-gray-600",children:"Free"})]})]})}),o.jsxs("div",{className:"max-w-xl mx-auto text-center mt-24",children:[o.jsx("h2",{className:"text-2xl font-bold mb-6",children:"Ready to Share Your Music?"}),o.jsxs("div",{className:"flex flex-col sm:flex-row gap-4 justify-center",children:[o.jsx("a",{href:"/submit",className:"inline-flex items-center justify-center bg-green-500 text-white px-8 py-3 rounded-lg hover:bg-green-600 transition-colors font-medium",children:"Submit Your Music"}),o.jsx("a",{href:"/playlists",className:"inline-flex items-center justify-center bg-white text-gray-700 px-8 py-3 rounded-lg hover:bg-gray-100 transition-colors font-medium border border-gray-200",children:"Browse Playlists"})]})]})]})})]})}function Ld(){const[t,e]=w.useState({name:"",email:"",playlistUrl:""}),[a,r]=w.useState(!1),[n,s]=w.useState(null),[i,l]=w.useState(!1);w.useEffect(()=>{typeof window<"u"&&window.prerenderReady!==void 0&&(window.prerenderReady=!0)},[]);const c=u=>{const h=qt(u,"playlist");if(!h)throw new Error("Please enter a valid Spotify playlist URL");return h},d=async u=>{u.preventDefault(),s(null),r(!0);try{if(!/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(t.email))throw new Error("Please enter a valid email address");const h=c(t.playlistUrl),{error:p}=await U.from("curator_applications").insert({name:t.name,email:t.email,playlist_url:t.playlistUrl,playlist_id:h});if(p)throw p;l(!0),e({name:"",email:"",playlistUrl:""})}catch(h){console.error("Application submission failed:",h),s(h instanceof Error?h.message:"Failed to submit application")}finally{r(!1)}};return o.jsxs(o.Fragment,{children:[o.jsx(ce,{title:"Become a Curator - PlaylistPartner",description:"Join our network of Spotify playlist curators. Apply to list your playlists and connect with artists in your genre."}),o.jsx("div",{className:"bg-gradient-to-b from-green-50 to-white",children:o.jsx("div",{className:"container mx-auto px-4 py-16 md:py-24",children:o.jsxs("div",{className:"max-w-4xl mx-auto",children:[o.jsxs("div",{className:"text-center mb-16",children:[o.jsx(Zt,{className:"w-12 h-12 text-green-600 mx-auto mb-6"}),o.jsx("h1",{className:"text-4xl font-bold text-gray-900 mb-12",children:"Join Our Curator Network"}),o.jsxs("div",{className:"grid md:grid-cols-2 gap-8",children:[o.jsxs("div",{className:"bg-white p-8 rounded-xl shadow-sm",children:[o.jsx("div",{className:"p-3 bg-green-50 rounded-lg w-12 h-12 flex items-center justify-center mx-auto mb-4",children:o.jsx(Hl,{className:"w-6 h-6 text-green-600"})}),o.jsx("h2",{className:"text-xl font-bold mb-4",children:"For Music Curators"}),o.jsx("p",{className:"text-gray-600",children:"Love discovering and sharing new music? Add your playlists to PlaylistPartner to receive fresh submissions from independent artists, grow your following, and strengthen your reputation as a tastemaker in your genre."})]}),o.jsxs("div",{className:"bg-white p-8 rounded-xl shadow-sm",children:[o.jsx("div",{className:"p-3 bg-green-50 rounded-lg w-12 h-12 flex items-center justify-center mx-auto mb-4",children:o.jsx(Xt,{className:"w-6 h-6 text-green-600"})}),o.jsx("h2",{className:"text-xl font-bold mb-4",children:"For Artists"}),o.jsx("p",{className:"text-gray-600",children:"Already making music? List your artist playlists to connect with other independent artists in your genre, expand your network, and build meaningful relationships within your music community."})]})]})]}),o.jsxs("div",{className:"bg-white p-8 rounded-xl shadow-sm mb-12",children:[o.jsx("h2",{className:"text-2xl font-bold mb-6",children:"What We Look For"}),o.jsx("p",{className:"text-gray-600 mb-4",children:"Our curator network maintains high standards to ensure quality. We look for:"}),o.jsxs("ul",{className:"space-y-3 text-gray-600",children:[o.jsxs("li",{className:"flex items-center gap-2",children:[o.jsx(ot,{className:"w-5 h-5 text-green-500 flex-shrink-0"}),"Consistent playlist activity with regular updates"]}),o.jsxs("li",{className:"flex items-center gap-2",children:[o.jsx(ot,{className:"w-5 h-5 text-green-500 flex-shrink-0"}),"Genuine follower engagement"]}),o.jsxs("li",{className:"flex items-center gap-2",children:[o.jsx(ot,{className:"w-5 h-5 text-green-500 flex-shrink-0"}),"Clear genre focus and curation style"]}),o.jsxs("li",{className:"flex items-center gap-2",children:[o.jsx(ot,{className:"w-5 h-5 text-green-500 flex-shrink-0"}),"Professional playlist presentation"]})]})]}),o.jsx("div",{className:"bg-white p-8 rounded-xl shadow-sm",children:i?o.jsxs("div",{className:"text-center py-8",children:[o.jsx(ot,{className:"w-16 h-16 text-green-500 mx-auto mb-4"}),o.jsx("h2",{className:"text-2xl font-bold text-gray-900 mb-4",children:"Application Received!"}),o.jsx("p",{className:"text-gray-600 mb-6",children:"Thank you for your interest in joining PlaylistPartner. We'll review your application and get back to you as soon as possible."}),o.jsx("button",{onClick:()=>l(!1),className:"text-green-600 hover:text-green-700 font-medium",children:"Submit Another Application"})]}):o.jsxs(o.Fragment,{children:[o.jsx("h2",{className:"text-2xl font-bold mb-6",children:"Apply to Join"}),o.jsxs("form",{onSubmit:d,className:"space-y-6",children:[o.jsxs("div",{children:[o.jsx("label",{htmlFor:"name",className:"block text-sm font-medium text-gray-700 mb-1",children:"Your Name"}),o.jsx("input",{type:"text",id:"name",value:t.name,onChange:u=>e(h=>({...h,name:u.target.value})),className:"w-full p-3 border border-gray-300 rounded-lg focus:ring-2 focus:ring-green-500 focus:border-transparent",placeholder:"Enter your name",required:!0,disabled:a})]}),o.jsxs("div",{children:[o.jsx("label",{htmlFor:"email",className:"block text-sm font-medium text-gray-700 mb-1",children:"Email Address"}),o.jsx("input",{type:"email",id:"email",value:t.email,onChange:u=>e(h=>({...h,email:u.target.value})),className:"w-full p-3 border border-gray-300 rounded-lg focus:ring-2 focus:ring-green-500 focus:border-transparent",placeholder:"you@example.com",required:!0,disabled:a})]}),o.jsxs("div",{children:[o.jsx("label",{htmlFor:"playlistUrl",className:"block text-sm font-medium text-gray-700 mb-1",children:"Your Best Playlist"}),o.jsx("input",{type:"url",id:"playlistUrl",value:t.playlistUrl,onChange:u=>e(h=>({...h,playlistUrl:u.target.value})),className:"w-full p-3 border border-gray-300 rounded-lg focus:ring-2 focus:ring-green-500 focus:border-transparent",placeholder:"https://open.spotify.com/playlist/...",required:!0,disabled:a}),o.jsx("p",{className:"mt-1 text-sm text-gray-500",children:"Please provide the Spotify URL of your best performing playlist"})]}),n&&o.jsxs("div",{className:"flex items-center gap-2 text-red-600 bg-red-50 p-3 rounded-lg",children:[o.jsx(pe,{className:"w-5 h-5 flex-shrink-0"}),o.jsx("p",{children:n})]}),o.jsx("button",{type:"submit",disabled:a,className:"w-full flex items-center justify-center gap-2 bg-green-500 text-white p-3 rounded-lg hover:bg-green-600 transition-colors disabled:bg-gray-400 disabled:cursor-not-allowed font-medium",children:a?o.jsxs(o.Fragment,{children:[o.jsx(Re,{className:"w-5 h-5 animate-spin"}),"Submitting..."]}):"Submit Application"})]})]})}),o.jsxs("div",{className:"mt-12 bg-white p-8 rounded-xl shadow-sm",children:[o.jsx("h2",{className:"text-2xl font-bold mb-6",children:"What Happens Next?"}),o.jsxs("div",{className:"space-y-6",children:[o.jsxs("div",{className:"flex items-start gap-4",children:[o.jsx("div",{className:"w-8 h-8 bg-green-100 rounded-full flex items-center justify-center flex-shrink-0",children:o.jsx("span",{className:"text-green-600 font-bold",children:"1"})}),o.jsx("div",{children:o.jsx("p",{className:"text-gray-600",children:"Submit your application with links to your playlists"})})]}),o.jsxs("div",{className:"flex items-start gap-4",children:[o.jsx("div",{className:"w-8 h-8 bg-green-100 rounded-full flex items-center justify-center flex-shrink-0",children:o.jsx("span",{className:"text-green-600 font-bold",children:"2"})}),o.jsx("div",{children:o.jsx("p",{className:"text-gray-600",children:"Our team reviews your submission against our quality criteria"})})]}),o.jsxs("div",{className:"flex items-start gap-4",children:[o.jsx("div",{className:"w-8 h-8 bg-green-100 rounded-full flex items-center justify-center flex-shrink-0",children:o.jsx("span",{className:"text-green-600 font-bold",children:"3"})}),o.jsx("div",{children:o.jsx("p",{className:"text-gray-600",children:"If approved, you'll receive instructions for adding your playlists"})})]}),o.jsxs("div",{className:"flex items-start gap-4",children:[o.jsx("div",{className:"w-8 h-8 bg-green-100 rounded-full flex items-center justify-center flex-shrink-0",children:o.jsx("span",{className:"text-green-600 font-bold",children:"4"})}),o.jsx("div",{children:o.jsx("p",{className:"text-gray-600",children:"Start connecting with artists and growing your network"})})]})]})]})]})})})]})}function Ud(){const[t,e]=w.useState(1),a=9,r=ar,n=r.length,s=Math.ceil(n/a),i=(t-1)*a,l=i+a,c=r.slice(i,l);function d(h){return new Date(h).toLocaleDateString("en-US",{year:"numeric",month:"long",day:"numeric"})}function u(h){return h.startsWith("//")?`https:${h}`:h}return o.jsxs(o.Fragment,{children:[o.jsx(ce,{title:"Blog / News | PlaylistPartner",description:"Stay updated with the latest news, features, and improvements from PlaylistPartner. Plus practical music marketing tips.",type:"website",structuredData:{"@context":"https://schema.org","@type":"Blog",name:"Playlist Partner Blog",description:"Stay updated with the latest news, features, and improvements from Playlist Partner. Plus practical music marketing tips.",url:window.location.href,inLanguage:"en-US",publisher:{"@type":"Organization",name:"Playlist Partner",logo:{"@type":"ImageObject",url:"https://ftwlzdhkzqfuosdorgjt.supabase.co/storage/v1/object/public/playlistpartner%20public//playlist%20partner%20logo%20square.png",width:"500",height:"500"}}}}),o.jsx("div",{className:"bg-gradient-to-b from-green-50 to-white",children:o.jsxs("section",{className:"max-w-7xl mx-auto px-4 sm:px-6 lg:px-8 py-12 md:py-20",children:[o.jsxs("div",{className:"text-center mb-12",children:[o.jsx("h1",{className:"text-4xl md:text-5xl font-bold text-gray-900 mb-4",children:"Playlist Partner Blog"}),o.jsx("p",{className:"text-xl text-gray-600 max-w-3xl mx-auto",children:"Stay updated with the latest news, features, and improvements from Playlist Partner. Plus, coming soon: practical music marketing tips to boost your career."})]}),c.length===0&&o.jsx("div",{className:"text-center py-12",children:o.jsx("p",{className:"text-gray-600",children:"No blog posts available yet. Check back soon!"})}),c.length>0&&o.jsxs(o.Fragment,{children:[o.jsx("div",{className:"grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-8 mb-12",children:c.map(h=>{var p,y,m;return o.jsxs("article",{className:"bg-white rounded-lg shadow-md overflow-hidden hover:shadow-lg transition-shadow",children:[((p=h.featuredImage)==null?void 0:p.url)&&o.jsx(R,{to:`/blog/${((y=h.category)==null?void 0:y.toLowerCase())||"news"}/${h.slug}`,children:o.jsx("img",{src:u(h.featuredImage.url),alt:h.featuredImage.title||h.title,className:"w-full aspect-[3/2] object-cover"})}),o.jsxs("div",{className:"p-6",children:[o.jsx(R,{to:`/blog/${((m=h.category)==null?void 0:m.toLowerCase())||"news"}/${h.slug}`,children:o.jsx("h2",{className:"text-xl font-semibold text-gray-900 mb-2 hover:text-green-600 transition-colors",children:h.title})}),h.excerpt&&o.jsx("p",{className:"text-gray-600 mb-4 line-clamp-3",children:h.excerpt}),o.jsxs("div",{className:"flex flex-wrap items-center gap-4 text-sm text-gray-500",children:[o.jsxs("div",{className:"flex items-center gap-1",children:[o.jsx(tr,{className:"w-4 h-4"}),o.jsx("span",{children:d(h.publishDate)})]}),h.category&&o.jsxs("div",{className:"flex items-center gap-1",children:[o.jsx(Ca,{className:"w-4 h-4"}),o.jsx("span",{children:h.category})]})]})]})]},h.id)})}),s>1&&o.jsxs("div",{className:"flex justify-center gap-2",children:[o.jsx("button",{onClick:()=>e(t-1),disabled:t===1,className:"px-4 py-2 border border-gray-300 rounded-md text-gray-700 hover:bg-gray-50 disabled:opacity-50 disabled:cursor-not-allowed",children:"Previous"}),o.jsx("div",{className:"flex items-center gap-2",children:Array.from({length:s},(h,p)=>p+1).map(h=>o.jsx("button",{onClick:()=>e(h),className:`px-3 py-1 rounded-md ${h===t?"bg-green-600 text-white":"text-gray-700 hover:bg-gray-50"}`,children:h},h))}),o.jsx("button",{onClick:()=>e(t+1),disabled:t===s,className:"px-4 py-2 border border-gray-300 rounded-md text-gray-700 hover:bg-gray-50 disabled:opacity-50 disabled:cursor-not-allowed",children:"Next"})]})]})]})})]})}var b=function(t){return t.DOCUMENT="document",t.PARAGRAPH="paragraph",t.HEADING_1="heading-1",t.HEADING_2="heading-2",t.HEADING_3="heading-3",t.HEADING_4="heading-4",t.HEADING_5="heading-5",t.HEADING_6="heading-6",t.OL_LIST="ordered-list",t.UL_LIST="unordered-list",t.LIST_ITEM="list-item",t.HR="hr",t.QUOTE="blockquote",t.EMBEDDED_ENTRY="embedded-entry-block",t.EMBEDDED_ASSET="embedded-asset-block",t.EMBEDDED_RESOURCE="embedded-resource-block",t.TABLE="table",t.TABLE_ROW="table-row",t.TABLE_CELL="table-cell",t.TABLE_HEADER_CELL="table-header-cell",t}({}),V=function(t){return t.ASSET_HYPERLINK="asset-hyperlink",t.EMBEDDED_ENTRY="embedded-entry-inline",t.EMBEDDED_RESOURCE="embedded-resource-inline",t.ENTRY_HYPERLINK="entry-hyperlink",t.HYPERLINK="hyperlink",t.RESOURCE_HYPERLINK="resource-hyperlink",t}({}),ct=function(t){return t.BOLD="bold",t.ITALIC="italic",t.UNDERLINE="underline",t.CODE="code",t.SUPERSCRIPT="superscript",t.SUBSCRIPT="subscript",t.STRIKETHROUGH="strikethrough",t}({});function La(t,e){(e==null||e>t.length)&&(e=t.length);for(var a=0,r=new Array(e);a<e;a++)r[a]=t[a];return r}function Md(t){if(Array.isArray(t))return La(t)}function ge(t,e,a){return e in t?Object.defineProperty(t,e,{value:a,enumerable:!0,configurable:!0,writable:!0}):t[e]=a,t}function Bd(t){if(typeof Symbol<"u"&&t[Symbol.iterator]!=null||t["@@iterator"]!=null)return Array.from(t)}function Fd(){throw new TypeError("Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function Wd(t){return Md(t)||Bd(t)||Hd(t)||Fd()}function Hd(t,e){if(t){if(typeof t=="string")return La(t,e);var a=Object.prototype.toString.call(t).slice(8,-1);if(a==="Object"&&t.constructor&&(a=t.constructor.name),a==="Map"||a==="Set")return Array.from(a);if(a==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(a))return La(t,e)}}var vs=[b.PARAGRAPH,b.HEADING_1,b.HEADING_2,b.HEADING_3,b.HEADING_4,b.HEADING_5,b.HEADING_6,b.OL_LIST,b.UL_LIST,b.HR,b.QUOTE,b.EMBEDDED_ENTRY,b.EMBEDDED_ASSET,b.EMBEDDED_RESOURCE,b.TABLE],nr=[b.PARAGRAPH,b.HEADING_1,b.HEADING_2,b.HEADING_3,b.HEADING_4,b.HEADING_5,b.HEADING_6,b.OL_LIST,b.UL_LIST,b.HR,b.QUOTE,b.EMBEDDED_ENTRY,b.EMBEDDED_ASSET,b.EMBEDDED_RESOURCE],qd=[b.TABLE,b.TABLE_ROW,b.TABLE_CELL,b.TABLE_HEADER_CELL],Gd=[b.HR,b.EMBEDDED_ENTRY,b.EMBEDDED_ASSET,b.EMBEDDED_RESOURCE],ie,bs=(ie={},ge(ie,b.OL_LIST,[b.LIST_ITEM]),ge(ie,b.UL_LIST,[b.LIST_ITEM]),ge(ie,b.LIST_ITEM,nr),ge(ie,b.QUOTE,[b.PARAGRAPH]),ge(ie,b.TABLE,[b.TABLE_ROW]),ge(ie,b.TABLE_ROW,[b.TABLE_CELL,b.TABLE_HEADER_CELL]),ge(ie,b.TABLE_CELL,[b.PARAGRAPH,b.UL_LIST,b.OL_LIST]),ge(ie,b.TABLE_HEADER_CELL,[b.PARAGRAPH]),ie),ws=[b.HEADING_1,b.HEADING_2,b.HEADING_3,b.HEADING_4,b.HEADING_5,b.HEADING_6],zd=[b.PARAGRAPH].concat(Wd(ws)),Kd=[b.DOCUMENT,b.PARAGRAPH,b.HEADING_1,b.HEADING_2,b.HEADING_3,b.HEADING_4,b.HEADING_5,b.HEADING_6,b.OL_LIST,b.UL_LIST,b.LIST_ITEM,b.HR,b.QUOTE,b.EMBEDDED_ENTRY,b.EMBEDDED_ASSET,V.HYPERLINK,V.ENTRY_HYPERLINK,V.ASSET_HYPERLINK,V.EMBEDDED_ENTRY,"text"],Vd=[ct.BOLD,ct.CODE,ct.ITALIC,ct.UNDERLINE],Yd={nodeType:b.DOCUMENT,data:{},content:[{nodeType:b.PARAGRAPH,data:{},content:[{nodeType:"text",value:"",marks:[],data:{}}]}]};function Jd(t,e,a){return e in t?Object.defineProperty(t,e,{value:a,enumerable:!0,configurable:!0,writable:!0}):t[e]=a,t}function Zd(t){for(var e=1;e<arguments.length;e++){var a=arguments[e]!=null?arguments[e]:{},r=Object.keys(a);typeof Object.getOwnPropertySymbols=="function"&&(r=r.concat(Object.getOwnPropertySymbols(a).filter(function(n){return Object.getOwnPropertyDescriptor(a,n).enumerable}))),r.forEach(function(n){Jd(t,n,a[n])})}return t}function Qd(t,e){var a=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);a.push.apply(a,r)}return a}function Xd(t,e){return e=e??{},Object.getOwnPropertyDescriptors?Object.defineProperties(t,Object.getOwnPropertyDescriptors(e)):Qd(Object(e)).forEach(function(a){Object.defineProperty(t,a,Object.getOwnPropertyDescriptor(e,a))}),t}function ec(t){"@swc/helpers - typeof";return t&&typeof Symbol<"u"&&t.constructor===Symbol?"symbol":typeof t}function xs(t,e){var a=!0,r=!1,n=void 0;try{for(var s=Object.keys(t)[Symbol.iterator](),i;!(a=(i=s.next()).done);a=!0){var l=i.value;if(e===t[l])return!0}}catch(c){r=!0,n=c}finally{try{!a&&s.return!=null&&s.return()}finally{if(r)throw n}}return!1}function tc(t){return xs(V,t.nodeType)}function ac(t){return xs(b,t.nodeType)}function rc(t){return t.nodeType==="text"}function Ts(t){if(t.nodeType!==b.PARAGRAPH||t.content.length!==1)return!1;var e=t.content[0];return e.nodeType==="text"&&e.value===""}function nc(t){return t!=null&&(typeof t>"u"?"undefined":ec(t))==="object"&&"content"in t&&Array.isArray(t.content)}var sc=2;function oc(t){if(!nc(t)||t.content.length<sc)return t;var e=t.content[t.content.length-1];return Ts(e)?Xd(Zd({},t),{content:t.content.slice(0,-1)}):t}const ic=Object.freeze(Object.defineProperty({__proto__:null,isBlock:ac,isEmptyParagraph:Ts,isInline:tc,isText:rc,stripEmptyTrailingParagraphFromDocument:oc},Symbol.toStringTag,{value:"Module"}));var lc=t=>{if(Object.prototype.toString.call(t)!=="[object Object]")return!1;const e=Object.getPrototypeOf(t);return e===null||e===Object.prototype};const dc=zt(lc);function Ua(t,e){(e==null||e>t.length)&&(e=t.length);for(var a=0,r=new Array(e);a<e;a++)r[a]=t[a];return r}function cc(t){if(Array.isArray(t))return Ua(t)}function uc(t){if(typeof Symbol<"u"&&t[Symbol.iterator]!=null||t["@@iterator"]!=null)return Array.from(t)}function hc(){throw new TypeError("Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function pc(t){return cc(t)||uc(t)||yc(t)||hc()}function yc(t,e){if(t){if(typeof t=="string")return Ua(t,e);var a=Object.prototype.toString.call(t).slice(8,-1);if(a==="Object"&&t.constructor&&(a=t.constructor.name),a==="Map"||a==="Set")return Array.from(a);if(a==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(a))return Ua(t,e)}}var It=function(t){var e=t.path,a=t.property,r=t.typeName,n=t.value;return{details:'The type of "'.concat(a,'" is incorrect, expected type: ').concat(r),name:"type",path:e.toArray(),type:r,value:n}},mc=function(t){var e=t.min,a=t.value,r=t.path;return{name:"size",min:e,path:r.toArray(),details:"Size must be at least ".concat(e),value:a}},fc=function(t){var e=t.max,a=t.value,r=t.path;return{name:"size",max:e,path:r.toArray(),details:"Size must be at most ".concat(e),value:a}},gc=function(t){var e=t.expected,a=t.value,r=t.path;return{details:"Value must be one of expected values",name:"in",expected:pc(e).sort(),path:r.toArray(),value:a}},vc=function(t){var e=t.property,a=t.path;return{details:'The property "'.concat(e,'" is not expected'),name:"unexpected",path:a.toArray()}},bc=function(t){var e=t.property,a=t.path;return{details:'The property "'.concat(e,'" is required here'),name:"required",path:a.toArray()}};function Ma(t,e){(e==null||e>t.length)&&(e=t.length);for(var a=0,r=new Array(e);a<e;a++)r[a]=t[a];return r}function wc(t){if(Array.isArray(t))return Ma(t)}function xc(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function Tc(t,e){for(var a=0;a<e.length;a++){var r=e[a];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(t,r.key,r)}}function kc(t,e,a){return e&&Tc(t.prototype,e),t}function G(t,e,a){return e in t?Object.defineProperty(t,e,{value:a,enumerable:!0,configurable:!0,writable:!0}):t[e]=a,t}function _c(t){if(typeof Symbol<"u"&&t[Symbol.iterator]!=null||t["@@iterator"]!=null)return Array.from(t)}function jc(){throw new TypeError("Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function qr(t){return wc(t)||_c(t)||Sc(t)||jc()}function Sc(t,e){if(t){if(typeof t=="string")return Ma(t,e);var a=Object.prototype.toString.call(t).slice(8,-1);if(a==="Object"&&t.constructor&&(a=t.constructor.name),a==="Map"||a==="Set")return Array.from(a);if(a==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(a))return Ma(t,e)}}var le=function(){function t(e,a){var r=this,n=this;xc(this,t),G(this,"obj",void 0),G(this,"path",void 0),G(this,"_errors",void 0),G(this,"catch",void 0),G(this,"exists",void 0),G(this,"object",void 0),G(this,"string",void 0),G(this,"number",void 0),G(this,"array",void 0),G(this,"enum",void 0),G(this,"empty",void 0),G(this,"minLength",void 0),G(this,"noAdditionalProperties",void 0),G(this,"each",void 0),this.obj=e,this.path=a,this._errors=[],this.catch=function(){for(var s=arguments.length,i=new Array(s),l=0;l<s;l++)i[l]=arguments[l];var c;(c=n._errors).push.apply(c,qr(i))},this.exists=function(s){return s in r.obj?!0:(r.catch(bc({property:s,path:r.path.of(s)})),!1)},this.object=function(s){var i=s?r.obj[s]:r.obj;if(s&&!r.exists(s))return!1;if(dc(i))return!0;var l=s?r.path.of(s):r.path,c,d=(c=s??r.path.last())!==null&&c!==void 0?c:"value";return r.catch(It({typeName:"Object",property:d,path:l,value:i})),!1},this.string=function(s){var i=r.obj[s];return s&&!r.exists(s)?!1:typeof i=="string"?!0:(r.catch(It({typeName:"String",property:s,path:r.path.of(s),value:i})),!1)},this.number=function(s,i){var l=r.obj[s];return i&&!(s in r.obj)?!0:r.exists(s)?typeof l=="number"&&!Number.isNaN(l)?!0:(r.catch(It({typeName:"Number",property:s,path:r.path.of(s),value:l})),!1):!1},this.array=function(s){var i=r.obj[s];return s&&!r.exists(s)?!1:Array.isArray(i)?!0:(r.catch(It({typeName:"Array",property:s,path:r.path.of(s),value:i})),!1)},this.enum=function(s,i){var l=r.obj[s];return typeof l=="string"&&i.includes(l)?!0:(r.catch(gc({expected:i,value:l,path:r.path.of(s)})),!1)},this.empty=function(s){if(!r.array(s))return!1;var i=r.obj[s];return i.length===0?!0:(r.catch(fc({max:0,value:i,path:r.path.of(s)})),!1)},this.minLength=function(s,i){if(!r.array(s))return!1;var l=r.obj[s];return l.length>=i?!0:(r.catch(mc({min:i,value:l,path:r.path.of(s)})),!1)},this.noAdditionalProperties=function(s){var i=Object.keys(r.obj).sort().filter(function(l){return!s.includes(l)});return i.forEach(function(l){return r.catch(vc({property:l,path:r.path.of(l)}))}),i.length===0},this.each=function(s,i){if(r.array(s)){var l=r.obj[s],c=!1;l.forEach(function(d,u){if(!c){var h=i(d,r.path.of(s).of(u));h.length>0&&(c=!0),r.catch.apply(r,qr(h))}})}}}return kc(t,[{key:"errors",get:function(){var a=this,r=function(n){return JSON.stringify({details:n.details,path:n.path})};return this._errors.filter(function(n,s){return a._errors.findIndex(function(i){return r(n)===r(i)})===s})}}]),t}();function Ba(t,e){(e==null||e>t.length)&&(e=t.length);for(var a=0,r=new Array(e);a<e;a++)r[a]=t[a];return r}function Ec(t){if(Array.isArray(t))return Ba(t)}function sr(t){if(t===void 0)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return t}function ks(t,e,a){return e=Gt(e),Ic(t,Ss()?Reflect.construct(e,a||[],Gt(t).constructor):e.apply(t,a))}function or(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function Nc(t,e){for(var a=0;a<e.length;a++){var r=e[a];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(t,r.key,r)}}function Ac(t,e,a){return e&&Nc(t.prototype,e),t}function Ye(t,e,a){return e in t?Object.defineProperty(t,e,{value:a,enumerable:!0,configurable:!0,writable:!0}):t[e]=a,t}function Gt(t){return Gt=Object.setPrototypeOf?Object.getPrototypeOf:function(a){return a.__proto__||Object.getPrototypeOf(a)},Gt(t)}function _s(t,e){if(typeof e!="function"&&e!==null)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&Fa(t,e)}function Pc(t){if(typeof Symbol<"u"&&t[Symbol.iterator]!=null||t["@@iterator"]!=null)return Array.from(t)}function Oc(){throw new TypeError("Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function Ic(t,e){return e&&(Rc(e)==="object"||typeof e=="function")?e:sr(t)}function Fa(t,e){return Fa=Object.setPrototypeOf||function(r,n){return r.__proto__=n,r},Fa(t,e)}function js(t){return Ec(t)||Pc(t)||Cc(t)||Oc()}function Rc(t){"@swc/helpers - typeof";return t&&typeof Symbol<"u"&&t.constructor===Symbol?"symbol":typeof t}function Cc(t,e){if(t){if(typeof t=="string")return Ba(t,e);var a=Object.prototype.toString.call(t).slice(8,-1);if(a==="Object"&&t.constructor&&(a=t.constructor.name),a==="Map"||a==="Set")return Array.from(a);if(a==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(a))return Ba(t,e)}}function Ss(){try{var t=!Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],function(){}))}catch{}return(Ss=function(){return!!t})()}var ut=[],ir=function(){function t(e,a){or(this,t),Ye(this,"contentRule",void 0),Ye(this,"validateData",void 0),this.contentRule=e,this.validateData=a}return Ac(t,[{key:"assert",value:function(a,r){var n=new le(a,r);if(!n.object())return n.errors;n.noAdditionalProperties(["nodeType","data","content"]);var s=Array.isArray(this.contentRule)?{nodeTypes:this.contentRule}:this.contentRule(a,r),i=s.nodeTypes,l=s.min,c=l===void 0?0:l;if(i.length===0&&c>0)throw new Error("Invalid content rule. Cannot have enforce a 'min' of ".concat(c," with no nodeTypes"));if(n.minLength("content",c),i.length===0?n.empty("content"):n.each("content",function(m,f){var g=new le(m,f);return g.object()&&g.enum("nodeType",i),g.errors}),n.object("data")){var d,u,h,p,y=(p=(u=(h=this).validateData)===null||u===void 0?void 0:u.call(h,a.data,r.of("data")))!==null&&p!==void 0?p:[];(d=n).catch.apply(d,js(y))}return n.errors}}]),t}(),$c=function(t){_s(e,t);function e(a,r){or(this,e);var n;return n=ks(this,e,[r,function(s,i){return sr(n).assertLink(s,i)}]),Ye(n,"linkType",void 0),Ye(n,"type",void 0),Ye(n,"assertLink",void 0),n.linkType=a,n.assertLink=function(s,i){var l=new le(s,i);if(l.object("target")){var c,d=new le(s.target.sys,i.of("target").of("sys"));d.object()&&(d.enum("type",[n.type]),d.enum("linkType",[n.linkType]),n.type==="Link"?(d.string("id"),d.noAdditionalProperties(["type","linkType","id"])):n.type==="ResourceLink"&&(d.string("urn"),d.noAdditionalProperties(["type","linkType","urn"]))),(c=l).catch.apply(c,js(d.errors))}return l.noAdditionalProperties(["target"]),l.errors},n.type=n.linkType.startsWith("Contentful:")?"ResourceLink":"Link",n}return e}(ir),Dc=function(t){_s(e,t);function e(){or(this,e);var a;return a=ks(this,e,[["text"],function(r,n){return sr(a).assertLink(r,n)}]),Ye(a,"assertLink",function(r,n){var s=new le(r,n);return s.string("uri"),s.noAdditionalProperties(["uri"]),s.errors}),a}return e}(ir),he=function(t,e){return new ir(t,e)},Ne=function(t,e){return new $c(t,e)};function Wa(t,e){(e==null||e>t.length)&&(e=t.length);for(var a=0,r=new Array(e);a<e;a++)r[a]=t[a];return r}function Lc(t){if(Array.isArray(t))return Wa(t)}function Uc(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function lt(t,e,a){return e in t?Object.defineProperty(t,e,{value:a,enumerable:!0,configurable:!0,writable:!0}):t[e]=a,t}function Mc(t){if(typeof Symbol<"u"&&t[Symbol.iterator]!=null||t["@@iterator"]!=null)return Array.from(t)}function Bc(){throw new TypeError("Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function Fc(t){return Lc(t)||Mc(t)||Wc(t)||Bc()}function Wc(t,e){if(t){if(typeof t=="string")return Wa(t,e);var a=Object.prototype.toString.call(t).slice(8,-1);if(a==="Object"&&t.constructor&&(a=t.constructor.name),a==="Map"||a==="Set")return Array.from(a);if(a==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(a))return Wa(t,e)}}var Hc=function t(){var e=this,a=arguments.length>0&&arguments[0]!==void 0?arguments[0]:[];Uc(this,t),lt(this,"path",void 0),lt(this,"of",void 0),lt(this,"isRoot",void 0),lt(this,"last",void 0),lt(this,"toArray",void 0),this.path=a,this.of=function(r){return new t(Fc(e.path).concat([r]))},this.isRoot=function(){return e.path.length===0},this.last=function(){return e.path[e.path.length-1]},this.toArray=function(){return e.path}};function qc(t,e){var a=new le(t,e);return a.object()&&(a.noAdditionalProperties(["nodeType","data","value","marks"]),a.object("data"),a.each("marks",function(r,n){var s=new le(r,n);return s.object()&&s.string("type"),s.errors}),a.string("value")),a.errors}function Ha(t,e){(e==null||e>t.length)&&(e=t.length);for(var a=0,r=new Array(e);a<e;a++)r[a]=t[a];return r}function Gc(t){if(Array.isArray(t))return Ha(t)}function M(t,e,a){return e in t?Object.defineProperty(t,e,{value:a,enumerable:!0,configurable:!0,writable:!0}):t[e]=a,t}function zc(t){if(typeof Symbol<"u"&&t[Symbol.iterator]!=null||t["@@iterator"]!=null)return Array.from(t)}function Kc(){throw new TypeError("Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function Es(t){return Gc(t)||zc(t)||Vc(t)||Kc()}function Vc(t,e){if(t){if(typeof t=="string")return Ha(t,e);var a=Object.prototype.toString.call(t).slice(8,-1);if(a==="Object"&&t.constructor&&(a=t.constructor.name),a==="Map"||a==="Set")return Array.from(a);if(a==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(a))return Ha(t,e)}}var Se=he(Es(Object.values(V)).concat(["text"]).sort()),Gr=he([b.LIST_ITEM]),zr=Ne("Entry",ut),Kr=he(function(){return{nodeTypes:[b.PARAGRAPH],min:1}},function(t,e){var a=new le(t,e);return a.noAdditionalProperties(["colspan","rowspan"]),a.number("colspan",!0),a.number("rowspan",!0),a.errors}),D,Yc=(D={},M(D,b.DOCUMENT,he(vs)),M(D,b.PARAGRAPH,Se),M(D,b.HEADING_1,Se),M(D,b.HEADING_2,Se),M(D,b.HEADING_3,Se),M(D,b.HEADING_4,Se),M(D,b.HEADING_5,Se),M(D,b.HEADING_6,Se),M(D,b.QUOTE,he(bs[b.QUOTE])),M(D,b.EMBEDDED_ENTRY,zr),M(D,b.EMBEDDED_ASSET,Ne("Asset",ut)),M(D,b.EMBEDDED_RESOURCE,Ne("Contentful:Entry",ut)),M(D,b.HR,he(ut)),M(D,b.OL_LIST,Gr),M(D,b.UL_LIST,Gr),M(D,b.LIST_ITEM,he(Es(nr).sort())),M(D,b.TABLE,he(function(){return{nodeTypes:[b.TABLE_ROW],min:1}})),M(D,b.TABLE_ROW,he(function(){return{nodeTypes:[b.TABLE_CELL,b.TABLE_HEADER_CELL],min:1}})),M(D,b.TABLE_CELL,Kr),M(D,b.TABLE_HEADER_CELL,Kr),M(D,V.HYPERLINK,new Dc),M(D,V.EMBEDDED_ENTRY,zr),M(D,V.EMBEDDED_RESOURCE,Ne("Contentful:Entry",ut)),M(D,V.ENTRY_HYPERLINK,Ne("Entry",["text"])),M(D,V.ASSET_HYPERLINK,Ne("Asset",["text"])),M(D,V.RESOURCE_HYPERLINK,Ne("Contentful:Entry",["text"])),D);function Ns(t,e){if(t.nodeType==="text")return qc(t,e);var a=Yc[t.nodeType].assert(t,e);if(a.length>0)return a;var r=new le(t,e);return r.each("content",function(n,s){return Ns(n,s)}),r.errors}var Jc=function(t){var e=new Hc,a=new le(t,e);return a.object()&&a.enum("nodeType",[b.DOCUMENT]),a.errors.length>0?a.errors:Ns(t,e)};const Zc=Object.freeze(Object.defineProperty({__proto__:null,BLOCKS:b,CONTAINERS:bs,EMPTY_DOCUMENT:Yd,HEADINGS:ws,INLINES:V,LIST_ITEM_BLOCKS:nr,MARKS:ct,TABLE_BLOCKS:qd,TEXT_CONTAINERS:zd,TOP_LEVEL_BLOCKS:vs,V1_MARKS:Vd,V1_NODE_TYPES:Kd,VOID_BLOCKS:Gd,helpers:ic,validateRichTextDocument:Jc},Symbol.toStringTag,{value:"Module"})),Qc=qa(Zc);var C=w,I=Qc;function Xc(t,e){return C.isValidElement(t)&&t.key===null?C.cloneElement(t,{key:e}):t}function eu(t,e){return t.map((a,r)=>Xc(As(a,e),r))}function As(t,e){const{renderNode:a,renderMark:r,renderText:n,preserveWhitespace:s}=e;if(I.helpers.isText(t)){let i=n?n(t.value):t.value;if(s&&!n){i=i.replace(/ {2,}/g,d=>" ".repeat(d.length));const l=i.split(`
`),c=[];l.forEach((d,u)=>{c.push(d),u!==l.length-1&&c.push(C.createElement("br",null))}),i=c}return t.marks.reduce((l,c)=>r[c.type]?r[c.type](l):l,i)}else{const i=eu(t.content,e);return!t.nodeType||!a[t.nodeType]?C.createElement(C.Fragment,null,i):a[t.nodeType](t,i)}}const tu={[I.BLOCKS.DOCUMENT]:(t,e)=>e,[I.BLOCKS.PARAGRAPH]:(t,e)=>C.createElement("p",null,e),[I.BLOCKS.HEADING_1]:(t,e)=>C.createElement("h1",null,e),[I.BLOCKS.HEADING_2]:(t,e)=>C.createElement("h2",null,e),[I.BLOCKS.HEADING_3]:(t,e)=>C.createElement("h3",null,e),[I.BLOCKS.HEADING_4]:(t,e)=>C.createElement("h4",null,e),[I.BLOCKS.HEADING_5]:(t,e)=>C.createElement("h5",null,e),[I.BLOCKS.HEADING_6]:(t,e)=>C.createElement("h6",null,e),[I.BLOCKS.EMBEDDED_ENTRY]:(t,e)=>C.createElement("div",null,e),[I.BLOCKS.EMBEDDED_RESOURCE]:(t,e)=>C.createElement("div",null,e),[I.BLOCKS.UL_LIST]:(t,e)=>C.createElement("ul",null,e),[I.BLOCKS.OL_LIST]:(t,e)=>C.createElement("ol",null,e),[I.BLOCKS.LIST_ITEM]:(t,e)=>C.createElement("li",null,e),[I.BLOCKS.QUOTE]:(t,e)=>C.createElement("blockquote",null,e),[I.BLOCKS.HR]:()=>C.createElement("hr",null),[I.BLOCKS.TABLE]:(t,e)=>C.createElement("table",null,C.createElement("tbody",null,e)),[I.BLOCKS.TABLE_ROW]:(t,e)=>C.createElement("tr",null,e),[I.BLOCKS.TABLE_HEADER_CELL]:(t,e)=>C.createElement("th",null,e),[I.BLOCKS.TABLE_CELL]:(t,e)=>C.createElement("td",null,e),[I.INLINES.ASSET_HYPERLINK]:t=>ma(I.INLINES.ASSET_HYPERLINK,t),[I.INLINES.ENTRY_HYPERLINK]:t=>ma(I.INLINES.ENTRY_HYPERLINK,t),[I.INLINES.RESOURCE_HYPERLINK]:t=>Vr(I.INLINES.RESOURCE_HYPERLINK,t),[I.INLINES.EMBEDDED_ENTRY]:t=>ma(I.INLINES.EMBEDDED_ENTRY,t),[I.INLINES.EMBEDDED_RESOURCE]:(t,e)=>Vr(I.INLINES.EMBEDDED_RESOURCE,t),[I.INLINES.HYPERLINK]:(t,e)=>C.createElement("a",{href:t.data.uri},e)},au={[I.MARKS.BOLD]:t=>C.createElement("b",null,t),[I.MARKS.ITALIC]:t=>C.createElement("i",null,t),[I.MARKS.UNDERLINE]:t=>C.createElement("u",null,t),[I.MARKS.CODE]:t=>C.createElement("code",null,t),[I.MARKS.SUPERSCRIPT]:t=>C.createElement("sup",null,t),[I.MARKS.SUBSCRIPT]:t=>C.createElement("sub",null,t),[I.MARKS.STRIKETHROUGH]:t=>C.createElement("s",null,t)};function ma(t,e){return C.createElement("span",{key:e.data.target.sys.id},"type: ",e.nodeType," id: ",e.data.target.sys.id)}function Vr(t,e){return C.createElement("span",{key:e.data.target.sys.urn},"type: ",e.nodeType," urn: ",e.data.target.sys.urn)}function ru(t,e={}){if(!t)return null;let a=t;return e.stripEmptyTrailingParagraph&&(a=I.helpers.stripEmptyTrailingParagraphFromDocument(t)),As(a,{renderNode:{...tu,...e.renderNode},renderMark:{...au,...e.renderMark},renderText:e.renderText,preserveWhitespace:e.preserveWhitespace})}var nu=ru;function su(){var u,h;const{category:t,slug:e}=Vt(),a=ar,r=a.find(p=>p.slug===e),n=r?a.filter(p=>p.category===r.category&&p.slug!==e).slice(0,2):[];function s(p){return new Date(p).toLocaleDateString("en-US",{year:"numeric",month:"long",day:"numeric"})}function i(p){return p.startsWith("//")?`https:${p}`:p}const l={renderNode:{[b.PARAGRAPH]:(p,y)=>o.jsx("p",{className:"mb-6 text-gray-700 leading-relaxed",children:y}),[b.HEADING_1]:(p,y)=>o.jsx("h1",{className:"text-3xl font-bold mb-6 text-gray-900",children:y}),[b.HEADING_2]:(p,y)=>o.jsx("h2",{className:"text-2xl font-semibold mb-4 text-gray-900",children:y}),[b.HEADING_3]:(p,y)=>o.jsx("h3",{className:"text-xl font-semibold mb-3 text-gray-900",children:y}),[b.UL_LIST]:(p,y)=>o.jsx("ul",{className:"list-disc pl-6 mb-6 space-y-2",children:y}),[b.OL_LIST]:(p,y)=>o.jsx("ol",{className:"list-decimal pl-6 mb-6 space-y-2",children:y}),[b.LIST_ITEM]:(p,y)=>o.jsx("li",{className:"text-gray-700 leading-relaxed",children:y}),[b.QUOTE]:(p,y)=>o.jsx("blockquote",{className:"border-l-4 border-green-600 pl-4 italic my-6 text-gray-600",children:y}),[b.EMBEDDED_ASSET]:p=>{var f,g;if(!((g=(f=p.data.target)==null?void 0:f.fields)!=null&&g.file))return null;const{file:y,title:m}=p.data.target.fields;return o.jsx("img",{src:i(y.url),alt:m||"",className:"w-full rounded-lg my-6"})},[V.HYPERLINK]:(p,y)=>o.jsx("a",{href:p.data.uri,target:"_blank",rel:"noopener noreferrer",className:"text-green-600 hover:text-green-700 underline",children:y})}};if(!r)return o.jsxs("div",{className:"min-h-screen flex flex-col justify-center items-center",children:[o.jsx("p",{className:"text-red-600 mb-4",children:"Post not found"}),o.jsx(R,{to:"/blog",className:"text-green-600 hover:text-green-700",children:"Back to Blog"})]});const c=(u=r.featuredImage)!=null&&u.url?i(r.featuredImage.url):void 0,d=[{"@context":"https://schema.org","@type":"BlogPosting",headline:r.title,description:r.excerpt||"",image:c||"https://ftwlzdhkzqfuosdorgjt.supabase.co/storage/v1/object/public/playlistpartner%20public/playlistpartner%20og%20image.png",datePublished:r.publishDate||r.createdAt,dateModified:r.updatedAt||r.publishDate||r.createdAt,author:{"@type":"Organization",name:"Playlist Partner",url:window.location.origin},publisher:{"@type":"Organization",name:"Playlist Partner",logo:{"@type":"ImageObject",url:"https://ftwlzdhkzqfuosdorgjt.supabase.co/storage/v1/object/public/playlistpartner%20public//playlist%20partner%20logo%20square.png",width:"500",height:"500"}},mainEntityOfPage:{"@type":"WebPage","@id":window.location.href},articleSection:r.category||"News",inLanguage:"en-US"},{"@context":"https://schema.org","@type":"BreadcrumbList",itemListElement:[{"@type":"ListItem",position:1,name:"Home",item:window.location.origin},{"@type":"ListItem",position:2,name:"Blog",item:`${window.location.origin}/blog`},{"@type":"ListItem",position:3,name:r.title,item:window.location.href}]}];return o.jsxs(o.Fragment,{children:[o.jsx(ce,{title:`${r.title} | PlaylistPartner`,description:r.excerpt||`Read ${r.title} on the PlaylistPartner blog`,image:c,type:"article",article:{publishedTime:r.publishDate||r.createdAt,modifiedTime:r.updatedAt||r.publishDate||r.createdAt,author:"Playlist Partner",section:r.category||"News"},structuredData:d}),o.jsxs("article",{className:"bg-white",children:[o.jsxs("div",{className:"max-w-4xl mx-auto px-4 sm:px-6 lg:px-8 py-12",children:[o.jsxs(R,{to:"/blog",className:"inline-flex items-center gap-2 text-green-600 hover:text-green-700 mb-8",children:[o.jsx(ye,{className:"w-4 h-4"}),"Back to Blog"]}),((h=r.featuredImage)==null?void 0:h.url)&&o.jsx("img",{src:i(r.featuredImage.url),alt:r.featuredImage.title||r.title,className:"w-full aspect-[3/2] object-cover rounded-lg mb-8"}),o.jsxs("header",{className:"mb-8",children:[o.jsx("h1",{className:"text-4xl md:text-5xl font-bold text-gray-900 mb-4",children:r.title}),o.jsxs("div",{className:"flex flex-wrap items-center gap-6 text-gray-600",children:[o.jsxs("div",{className:"flex items-center gap-2",children:[o.jsx(tr,{className:"w-5 h-5"}),o.jsx("span",{children:s(r.publishDate||r.createdAt)})]}),o.jsxs("div",{className:"flex items-center gap-2",children:[o.jsx(Qt,{className:"w-5 h-5"}),o.jsxs("span",{children:["By ",o.jsx(R,{to:"/",className:"hover:text-green-600 transition-colors",children:"Playlist Partner"})]})]}),r.category&&o.jsxs("div",{className:"inline-flex items-center gap-1 px-3 py-1 bg-green-100 text-green-800 text-sm font-medium rounded-full",children:[o.jsx(Ca,{className:"w-3 h-3"}),r.category]})]})]}),o.jsx("div",{className:"prose prose-lg max-w-none mt-8 prose-ul:list-disc prose-ol:list-decimal prose-li:marker:text-gray-700",children:r.body?nu(r.body,l):o.jsx("div",{className:"bg-gray-50 p-6 rounded-lg",children:o.jsx("p",{className:"text-gray-600",children:"No content available for this post."})})}),o.jsx("div",{className:"mt-12 pt-8 border-t border-gray-200",children:o.jsxs("div",{className:"flex items-center gap-2 text-sm text-gray-600",children:[o.jsx("span",{children:"Filed under:"}),o.jsxs("div",{className:"inline-flex items-center gap-1 px-3 py-1 bg-gray-100 rounded-full",children:[o.jsx(Ca,{className:"w-3 h-3"}),r.category||"News"]})]})})]}),n.length>0&&o.jsxs("div",{className:"max-w-4xl mx-auto px-4 sm:px-6 lg:px-8 mt-8",children:[o.jsxs("div",{className:"flex items-center gap-3 mb-8",children:[o.jsx(Jl,{className:"w-6 h-6 text-gray-700"}),o.jsx("h2",{className:"text-2xl font-semibold text-gray-900",children:"Related News & Guides"})]}),o.jsx("div",{className:"grid md:grid-cols-2 gap-6 mb-16",children:n.map(p=>{var y,m;return o.jsxs(R,{to:`/blog/${((y=p.category)==null?void 0:y.toLowerCase())||"news"}/${p.slug}`,className:"bg-white border border-gray-200 rounded-lg shadow-sm hover:shadow-md transition-shadow overflow-hidden group",children:[((m=p.featuredImage)==null?void 0:m.url)&&o.jsx("div",{className:"aspect-[3/2] overflow-hidden",children:o.jsx("img",{src:i(p.featuredImage.url),alt:p.featuredImage.title||p.title,className:"w-full h-full object-cover group-hover:scale-105 transition-transform duration-300"})}),o.jsxs("div",{className:"p-6",children:[o.jsx("h3",{className:"font-semibold text-gray-900 group-hover:text-green-600 transition-colors line-clamp-2",children:p.title}),p.excerpt&&o.jsx("p",{className:"text-sm text-gray-600 mt-2 line-clamp-2",children:p.excerpt})]})]},p.id)})})]}),o.jsx("section",{className:"bg-gradient-to-r from-green-600 to-green-700 py-12",children:o.jsxs("div",{className:"max-w-4xl mx-auto px-4 sm:px-6 lg:px-8 text-center",children:[o.jsx("h2",{className:"text-3xl font-bold text-white mb-2",children:"Ready to Submit Your Music?"}),o.jsx("p",{className:"text-xl text-green-100 mb-8",children:"Browse 10,000+ curated playlists"}),o.jsxs("div",{className:"flex flex-col sm:flex-row gap-4 justify-center",children:[o.jsx(R,{to:"/playlists",className:"inline-flex items-center justify-center px-6 py-3 bg-white text-green-700 font-semibold rounded-lg hover:bg-gray-100 transition-colors",children:"Browse Playlists"}),o.jsxs(R,{to:"/submit",className:"inline-flex items-center justify-center px-6 py-3 bg-green-800 text-white font-semibold rounded-lg hover:bg-green-900 transition-colors",children:["Submit Track",o.jsx(bt,{className:"w-5 h-5 ml-2"})]})]})]})})]})]})}function ou(){return o.jsx(ds,{children:o.jsx("div",{className:"min-h-screen flex flex-col",children:o.jsxs(Is,{children:[o.jsx(Y,{path:"/",element:o.jsxs(o.Fragment,{children:[o.jsx(X,{}),o.jsx(id,{}),o.jsx(ee,{})]})}),o.jsx(Y,{path:"/playlists",element:o.jsxs(o.Fragment,{children:[o.jsx(X,{}),o.jsx(Ed,{}),o.jsx(ee,{})]})}),o.jsx(Y,{path:"/submit",element:o.jsxs(o.Fragment,{children:[o.jsx(X,{}),o.jsx(Nd,{}),o.jsx(ee,{})]})}),o.jsx(Y,{path:"/submit/genre",element:o.jsxs(o.Fragment,{children:[o.jsx(X,{}),o.jsx(Ad,{}),o.jsx(ee,{})]})}),o.jsx(Y,{path:"/playlist/:slug/*",element:o.jsxs(o.Fragment,{children:[o.jsx(X,{}),o.jsx(jd,{}),o.jsx(ee,{})]})}),o.jsx(Y,{path:"/genres",element:o.jsxs(o.Fragment,{children:[o.jsx(X,{}),o.jsx($d,{}),o.jsx(ee,{})]})}),o.jsx(Y,{path:"/genre/:genre",element:o.jsxs(o.Fragment,{children:[o.jsx(X,{}),o.jsx(Id,{}),o.jsx(ee,{})]})}),o.jsx(Y,{path:"/genre/:genre/:subGenre",element:o.jsxs(o.Fragment,{children:[o.jsx(X,{}),o.jsx(Cd,{}),o.jsx(ee,{})]})}),o.jsx(Y,{path:"/about",element:o.jsxs(o.Fragment,{children:[o.jsx(X,{}),o.jsx(Dd,{}),o.jsx(ee,{})]})}),o.jsx(Y,{path:"/for-curators",element:o.jsxs(o.Fragment,{children:[o.jsx(X,{}),o.jsx(Ld,{}),o.jsx(ee,{})]})}),o.jsx(Y,{path:"/blog",element:o.jsxs(o.Fragment,{children:[o.jsx(X,{}),o.jsx(Ud,{}),o.jsx(ee,{})]})}),o.jsx(Y,{path:"/blog/:category/:slug",element:o.jsxs(o.Fragment,{children:[o.jsx(X,{}),o.jsx(su,{}),o.jsx(ee,{})]})}),o.jsx(Y,{path:"*",element:o.jsx(Rs,{to:"/",replace:!0})})]})})})}const iu={};Zr(document.getElementById("root")).render(o.jsx(w.StrictMode,{children:o.jsx(nn,{context:iu,children:o.jsx(Cs,{children:o.jsx(Ul,{children:o.jsx(ds,{children:o.jsx(ou,{})})})})})}));export{Re as L,rr as P,rt as S,xt as T,Pd as u};
//# sourceMappingURL=index-CSodN85K.js.map