// SONARA — Producer Opportunità (feed richieste open + filter sidebar Airbnb-style) const OpIcons = window.SonaraIcons; /* ICONS */ const ChevIc = ({ size = 12 }) => ; const StarIc = ({ size = 12, filled = true }) => ; const ClockIc = ({ size = 12 }) => ; const PinIc = ({ size = 12 }) => ; const PaperIc = ({ size = 12 }) => ; const UsersIc = ({ size = 12 }) => ; const SearchIc = ({ size = 14 }) => ; const PlayIc = ({ size = 11 }) => ; const PaperclipIc = ({ size = 12 }) => ; const BoltIc = ({ size = 11 }) => ; const XIc = ({ size = 12 }) => ; const BookmarkIc = ({ size = 13 }) => ; const BellIc = ({ size = 12 }) => ; const NICO_GENRES = ["Trap", "Drill", "Hip-hop", "R&B"]; const REQS = [ { id: "REQ-9214", kind: "Beat custom", title: "Cerco beat trap 808 pesante stile Travis Scott late-night", brief: "Sto lavorando ad un singolo per uscita estate. Cerco un beat trap con vibe notturna, 808 spaziali, BPM 138-145, key minore. Ref: Travis Scott — \"After Hours\", Drake — \"Headlines\" (cassa più tirata).\n\nDeve essere originale, non type beat caricato online. Mi piacerebbe collaborare a lungo termine se il primo round va bene.", artist: "AlessioRap", artistFull: "Alessio Marchetti", artistInit: "AR", verified: true, city: "Milano", country: "IT", rating: 4.7, pastProjects: 3, budget: { min: 100, max: 200 }, deadlineDays: 10, offers: 4, posted: "2h fa", expiresIn: "28gg", postedHours: 2, matchTags: ["Trap", "BPM 138-145"], genres: ["Trap"], bpm: 142, mkey: "F# min", attachments: [{ name: "ref-travis.mp3", size: "3.2 MB" }, { name: "topline-rough.m4a", size: "1.8 MB" }], new: true, briefComplete: true, }, { id: "REQ-9210", kind: "Mix + Master", title: "Mix EP 5 tracce drill — stems pronti", brief: "EP completo 5 tracce drill UK-influence, già recorded. Stems puliti (vox + 808 + drums + melodie). Cerco mix radio-ready + master.", artist: "Quartiere9", artistFull: "Davide Romano", artistInit: "Q9", verified: true, city: "Roma", country: "IT", rating: 4.9, pastProjects: 12, budget: { min: 600, max: 900 }, deadlineDays: 21, offers: 7, posted: "5h fa", expiresIn: "27gg", postedHours: 5, matchTags: ["Drill", "Mix + Master"], genres: ["Drill"], briefComplete: true, }, { id: "REQ-9203", kind: "Custom production", title: "Brano R&B con vibe Daniel Caesar / Brent Faiyaz", brief: "Beat + mix base per singolo R&B. Cerco mood notturno, chitarre arpeggiate, drum break leggero.", artist: "Lina Sky", artistFull: "Lina Sky", artistInit: "LS", verified: false, city: "Bologna", country: "IT", rating: null, pastProjects: 0, budget: { min: 400, max: 400, fixed: true }, deadlineDays: 7, offers: 2, posted: "Ieri", expiresIn: "23gg", postedHours: 26, matchTags: ["R&B"], genres: ["R&B"], new: true, briefComplete: false, }, { id: "REQ-9198", kind: "Vocal production", title: "Vocal production + tuning su 1 brano trap melodico", brief: "Ho registrato voce e doppie ma serve tuning fine, comping, ad-lib di rinforzo e processing finale prima del mix.", artist: "DamoBeats", artistFull: "Damiano B.", artistInit: "DB", verified: true, city: "Milano", country: "IT", rating: 4.5, pastProjects: 2, budget: { min: 80, max: 150 }, deadlineDays: 4, offers: 3, posted: "2gg fa", expiresIn: "22gg", postedHours: 50, matchTags: ["Trap", "Vocal prod"], genres: ["Trap"], briefComplete: true, }, { id: "REQ-9192", kind: "Beat custom", title: "Beat hip-hop boom bap con campioni vinilici", brief: "Cerco beat boom bap old-school, 90-95 BPM. Devono esserci sample vinilici puliti (no copyright). Per un EP indipendente.", artist: "Rino82", artistFull: "Riccardo N.", artistInit: "R8", verified: false, city: "Torino", country: "IT", rating: 4.2, pastProjects: 1, budget: { min: 150, max: 300 }, deadlineDays: 15, offers: 5, posted: "3gg fa", expiresIn: "20gg", postedHours: 74, matchTags: ["Hip-hop"], genres: ["Hip-hop"], bpm: 92, briefComplete: true, }, { id: "REQ-9185", kind: "Mastering", title: "Master per singolo trap già missato", brief: "Mix già pronto, cerco master loud + adattamento Spotify + WAV/MP3 finali. 48h se possibile.", artist: "Yoshi K.", artistFull: "Yoshi K.", artistInit: "YK", verified: true, city: "Milano", country: "IT", rating: 4.8, pastProjects: 5, budget: { min: 70, max: 100 }, deadlineDays: 2, offers: 6, posted: "4gg fa", expiresIn: "16gg", postedHours: 98, matchTags: ["Trap", "Master"], genres: ["Trap"], briefComplete: true, }, // Extra forYou — variety { id: "REQ-9176", kind: "Beat custom", title: "Beat drill UK 140 BPM scuro con flauti", brief: "Per featuring tra 2 artisti, vibe Central Cee / Headie One. Flauti dark, 808 scivolosi, switch alla seconda strofa.", artist: "Jaxon", artistFull: "Jaxon", artistInit: "JX", verified: true, city: "Milano", country: "IT", rating: 4.6, pastProjects: 4, budget: { min: 250, max: 450 }, deadlineDays: 8, offers: 9, posted: "1gg fa", expiresIn: "21gg", postedHours: 28, matchTags: ["Drill", "BPM 140"], genres: ["Drill"], bpm: 140, mkey: "C min", briefComplete: true, }, { id: "REQ-9170", kind: "Mix stereo", title: "Mix singolo trap melodico — premium", brief: "Singolo solista, 808 puliti, voce in primo piano, autotune leggero. Cerco mix radio-ready stile Lazza/Sfera.", artist: "ElenaR.", artistFull: "Elena Rovera", artistInit: "ER", verified: true, city: "Napoli", country: "IT", rating: 4.9, pastProjects: 18, budget: { min: 180, max: 280 }, deadlineDays: 12, offers: 11, posted: "2gg fa", expiresIn: "20gg", postedHours: 52, matchTags: ["Trap", "Mix"], genres: ["Trap"], briefComplete: true, }, // Out-of-match — only in "Tutte" { id: "REQ-9181", kind: "Songwriting", title: "Topline + testo per brano indie-pop italiano", brief: "Beat indie-pop pronto, cerco topliner per melodia + testo (italiano). Vibe Coma_Cose / Maneskin ballad.", artist: "Olivia M.", artistFull: "Olivia Marletti", artistInit: "OM", verified: false, city: "Firenze", country: "IT", rating: null, pastProjects: 0, budget: { min: 200, max: 400 }, deadlineDays: 14, offers: 2, posted: "5gg fa", expiresIn: "15gg", postedHours: 122, matchTags: ["Indie-pop"], genres: ["Indie-pop"], outOfMatch: true, briefComplete: false, }, { id: "REQ-9174", kind: "Sound design", title: "Sound design per podcast true-crime", brief: "8 puntate, mi serve sigla + transizioni + atmo dark/tensione. Stile Serial / Indagini.", artist: "Studio Onda", artistFull: "Studio Onda", artistInit: "SO", verified: true, city: "Roma", country: "IT", rating: 4.6, pastProjects: 9, budget: { min: 800, max: 1500 }, deadlineDays: 30, offers: 11, posted: "1 sett. fa", expiresIn: "13gg", postedHours: 168, matchTags: ["Sound design"], genres: ["Cinematic"], outOfMatch: true, briefComplete: true, }, { id: "REQ-9168", kind: "Mix + Master", title: "Mix album cantautorato acustico — 9 tracce", brief: "Album cantautorato registrato in analogico, stems puliti. Cerco mix che mantenga il sapore caldo dei nastri.", artist: "Pietro V.", artistFull: "Pietro Vannucci", artistInit: "PV", verified: true, city: "Verona", country: "IT", rating: 4.9, pastProjects: 7, budget: { min: 900, max: 1400 }, deadlineDays: 28, offers: 8, posted: "1 sett. fa", expiresIn: "13gg", postedHours: 170, matchTags: ["Cantautorato"], genres: ["Cantautorato"], outOfMatch: true, briefComplete: true, }, { id: "REQ-9160", kind: "Beat custom", title: "Beat techno/house 124 BPM per DJ set", brief: "Producer techno emergente, cerco beat originale per chiusura set. 124 BPM, dark, build lungo.", artist: "K-Line", artistFull: "K-Line", artistInit: "KL", verified: false, city: "Berlino", country: "DE", rating: 4.3, pastProjects: 2, budget: { min: 300, max: 500 }, deadlineDays: 12, offers: 14, posted: "1 sett. fa", expiresIn: "10gg", postedHours: 175, matchTags: ["Techno"], genres: ["Elettronica"], bpm: 124, outOfMatch: true, briefComplete: true, }, ]; const SAVED_SEARCHES = [ { id: "ss1", name: "Trap Milano premium", desc: "Trap · Milano · €200+ · <5 offerte", count: 3, alert: "instant" }, { id: "ss2", name: "Mix EP completo", desc: "Mix+Master · €500+ · 14gg+", count: 8, alert: "daily" }, { id: "ss3", name: "Custom R&B", desc: "Custom · R&B · €300+", count: 1, alert: "weekly" }, ]; const ALL_GENRES = ["Trap", "Drill", "Hip-hop", "R&B", "Pop", "Indie-pop", "Cantautorato", "Elettronica", "Cinematic", "Jazz", "Lofi", "Rock"]; const ALL_TYPES = ["Beat custom", "Mix stereo", "Mastering", "Mix + Master", "Vocal production", "Custom production", "Sound design", "Songwriting"]; const ALL_KEYS = ["C", "C# / Db", "D", "D# / Eb", "E", "F", "F# / Gb", "G", "G# / Ab", "A", "A# / Bb", "B"]; const DEFAULT_FILTERS = { search: "", types: [], genres: [], budget: [0, 2000], geo: "italy", // italy | europe | world | near radius: 50, offers: "all", // all | lt3 | mid | high deadline: "all", // all | rush | week2 | week4 | longer verifiedOnly: false, briefCompleteOnly: false, noOffersOnly: false, bpmRange: [60, 200], keys: [], }; /* ──────────────────────────────────────────────────────── */ /* PRIMITIVES */ /* ──────────────────────────────────────────────────────── */ function FilterSection({ title, badge, children, defaultOpen = true }) { const [open, setOpen] = React.useState(defaultOpen); return (
{open &&
{children}
}
); } function PillRow({ options, value, onChange, multi = true }) { return (
{options.map(opt => { const v = typeof opt === "string" ? opt : opt.v; const l = typeof opt === "string" ? opt : opt.l; const active = multi ? value.includes(v) : value === v; return ( ); })}
); } function Segmented({ options, value, onChange }) { return (
{options.map(opt => ( ))}
); } function FsToggle({ label, sub, checked, onChange }) { return (