| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457445844594460446144624463446444654466446744684469447044714472447344744475447644774478447944804481448244834484448544864487448844894490449144924493449444954496449744984499450045014502450345044505450645074508450945104511451245134514451545164517451845194520452145224523452445254526452745284529453045314532453345344535453645374538453945404541454245434544454545464547454845494550455145524553455445554556455745584559456045614562456345644565456645674568456945704571457245734574457545764577457845794580458145824583458445854586458745884589459045914592459345944595459645974598459946004601460246034604460546064607460846094610461146124613461446154616461746184619462046214622462346244625462646274628462946304631463246334634463546364637463846394640464146424643464446454646464746484649465046514652465346544655465646574658465946604661466246634664466546664667 | {  "name": "@shoelace-style/shoelace",  "description": "A forward-thinking library of web components.",  "version": "2.0.0-beta.43",  "author": "Cory LaViska",  "homepage": "https://github.com/shoelace-style/shoelace",  "license": "MIT",  "components": [    {      "className": "SlAlert",      "tag": "sl-alert",      "file": "src/components/alert/alert.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "closable",          "description": "Makes the alert closable.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "duration",          "description": "The length of time, in milliseconds, the alert will show before closing itself. If the user interacts with\nthe alert before it closes (e.g. moves the mouse over it), the timer will restart. Defaults to `Infinity`.",          "type": "number",          "defaultValue": "..."        },        {          "name": "open",          "description": "Indicates whether or not the alert is open. You can use this in lieu of the show/hide methods.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "type",          "description": "The type of alert.",          "type": "'primary' | 'success' | 'info' | 'warning' | 'danger'",          "values": [            "primary",            "success",            "info",            "warning",            "danger"          ],          "defaultValue": "'primary'"        }      ],      "methods": [        {          "name": "hide",          "description": "Hides the alert",          "params": []        },        {          "name": "show",          "description": "Shows the alert.",          "params": []        },        {          "name": "toast",          "description": "Displays the alert as a toast notification. This will move the alert out of its position in the DOM and, when\ndismissed, it will be removed from the DOM completely. By storing a reference to the alert, you can reuse it by\ncalling this method again. The returned promise will resolve after the alert is hidden.",          "params": []        }      ],      "events": [        {          "name": "sl-after-hide",          "description": "Emitted after the alert closes and all transitions are complete.",          "details": "void"        },        {          "name": "sl-after-show",          "description": "Emitted after the alert opens and all transitions are complete.",          "details": "void"        },        {          "name": "sl-hide",          "description": "Emitted when the alert closes.",          "details": "void"        },        {          "name": "sl-show",          "description": "Emitted when the alert opens.",          "details": "void"        }      ],      "slots": [        {          "name": "",          "description": "The alert's content."        },        {          "name": "icon",          "description": "An icon to show in the alert.\n"        }      ],      "cssCustomProperties": [        {          "name": "--box-shadow",          "description": "The alert's box shadow.\n"        }      ],      "parts": [        {          "name": "base",          "description": "The component's base wrapper."        },        {          "name": "icon",          "description": "The container that wraps the alert icon."        },        {          "name": "message",          "description": "The alert message."        },        {          "name": "close-button",          "description": "The close button.\n"        }      ],      "dependencies": [        "sl-icon-button"      ],      "animations": [        {          "name": "alert.show",          "description": "The animation to use when showing the alert."        },        {          "name": "alert.hide",          "description": "The animation to use when hiding the alert.\n"        }      ]    },    {      "className": "SlAnimation",      "tag": "sl-animation",      "file": "src/components/animation/animation.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "delay",          "description": "The number of milliseconds to delay the start of the animation.",          "type": "number",          "defaultValue": "0"        },        {          "name": "direction",          "description": "Determines the direction of playback as well as the behavior when reaching the end of an iteration.",          "type": "PlaybackDirection",          "defaultValue": "'normal'"        },        {          "name": "duration",          "description": "The number of milliseconds each iteration of the animation takes to complete.",          "type": "number",          "defaultValue": "1000"        },        {          "name": "easing",          "description": "The easing function to use for the animation. This can be a Shoelace easing function or a custom easing function\nsuch as `cubic-bezier(0, 1, .76, 1.14)`.",          "type": "string",          "defaultValue": "'linear'"        },        {          "name": "endDelay",          "attribute": "end-delay",          "description": "The number of milliseconds to delay after the active period of an animation sequence.",          "type": "number",          "defaultValue": "0"        },        {          "name": "fill",          "description": "Sets how the animation applies styles to its target before and after its execution.",          "type": "FillMode",          "defaultValue": "'auto'"        },        {          "name": "iterationStart",          "attribute": "iteration-start",          "description": "The offset at which to start the animation, usually between 0 (start) and 1 (end).",          "type": "number",          "defaultValue": "0"        },        {          "name": "iterations",          "description": "The number of iterations to run before the animation completes. Defaults to `Infinity`, which loops.",          "type": "number",          "defaultValue": "..."        },        {          "name": "keyframes",          "description": "The keyframes to use for the animation. If this is set, `name` will be ignored.",          "type": ""        },        {          "name": "name",          "description": "The name of the built-in animation to use. For custom animations, use the `keyframes` prop.",          "type": "string",          "defaultValue": "'none'"        },        {          "name": "pause",          "description": "Pauses the animation. The animation will resume when this prop is removed.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "playbackRate",          "attribute": "playback-rate",          "description": "Sets the animation's playback rate. The default is `1`, which plays the animation at a normal speed. Setting this\nto `2`, for example, will double the animation's speed. A negative value can be used to reverse the animation. This\nvalue can be changed without causing the animation to restart.",          "type": "number",          "defaultValue": "1"        }      ],      "methods": [        {          "name": "cancel",          "description": "Clears all KeyframeEffects caused by this animation and aborts its playback.",          "params": []        },        {          "name": "finish",          "description": "Sets the playback time to the end of the animation corresponding to the current playback direction.",          "params": []        },        {          "name": "getCurrentTime",          "description": "Gets the current time of the animation in milliseconds.",          "params": []        },        {          "name": "setCurrentTime",          "description": "Sets the current time of the animation in milliseconds.",          "params": [            {              "name": "time",              "type": "number"            }          ]        }      ],      "events": [        {          "name": "sl-cancel",          "description": "Emitted when the animation is canceled.",          "details": "void"        },        {          "name": "sl-finish",          "description": "Emitted when the animation finishes.",          "details": "void"        },        {          "name": "sl-start",          "description": "Emitted when the animation starts or restarts.",          "details": "void"        }      ],      "slots": [        {          "name": "",          "description": "The element to animate. If multiple elements are to be animated, wrap them in a single container."        }      ],      "cssCustomProperties": [],      "parts": [],      "dependencies": [],      "animations": []    },    {      "className": "SlAvatar",      "tag": "sl-avatar",      "file": "src/components/avatar/avatar.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "alt",          "description": "Alternative text for the image.",          "type": "string"        },        {          "name": "image",          "description": "The image source to use for the avatar.",          "type": "string"        },        {          "name": "initials",          "description": "Initials to use as a fallback when no image is available (1-2 characters max recommended).",          "type": "string"        },        {          "name": "shape",          "description": "The shape of the avatar.",          "type": "'circle' | 'square' | 'rounded'",          "values": [            "circle",            "square",            "rounded"          ],          "defaultValue": "'circle'"        }      ],      "methods": [],      "events": [],      "slots": [        {          "name": "icon",          "description": "The default icon to use when no image or initials are present.\n"        }      ],      "cssCustomProperties": [        {          "name": "--size",          "description": "The size of the avatar.\n"        }      ],      "parts": [        {          "name": "base",          "description": "The component's base wrapper."        },        {          "name": "icon",          "description": "The container that wraps the avatar icon."        },        {          "name": "initials",          "description": "The container that wraps the avatar initials."        },        {          "name": "image",          "description": "The avatar image.\n"        }      ],      "dependencies": [        "sl-icon"      ],      "animations": []    },    {      "className": "SlBadge",      "tag": "sl-badge",      "file": "src/components/badge/badge.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "pill",          "description": "Draws a pill-style badge with rounded edges.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "pulse",          "description": "Makes the badge pulsate to draw attention.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "type",          "description": "The badge's type.",          "type": "'primary' | 'success' | 'info' | 'warning' | 'danger'",          "values": [            "primary",            "success",            "info",            "warning",            "danger"          ],          "defaultValue": "'primary'"        }      ],      "methods": [],      "events": [],      "slots": [        {          "name": "",          "description": "The badge's content."        }      ],      "cssCustomProperties": [],      "parts": [        {          "name": "base",          "description": "The base wrapper\n"        }      ],      "dependencies": [],      "animations": []    },    {      "className": "SlButton",      "tag": "sl-button",      "file": "src/components/button/button.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "caret",          "description": "Draws the button with a caret for use with dropdowns, popovers, etc.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "circle",          "description": "Draws a circle button.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "disabled",          "description": "Disables the button.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "download",          "description": "Tells the browser to download the linked file as this filename. Only used when `href` is set.",          "type": "string"        },        {          "name": "href",          "description": "When set, the underlying button will be rendered as an `<a>` with this `href` instead of a `<button>`.",          "type": "string"        },        {          "name": "loading",          "description": "Draws the button in a loading state.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "name",          "description": "An optional name for the button. Ignored when `href` is set.",          "type": "string"        },        {          "name": "pill",          "description": "Draws a pill-style button with rounded edges.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "size",          "description": "The button's size.",          "type": "'small' | 'medium' | 'large'",          "values": [            "small",            "medium",            "large"          ],          "defaultValue": "'medium'"        },        {          "name": "submit",          "description": "Indicates if activating the button should submit the form. Ignored when `href` is set.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "target",          "description": "Tells the browser where to open the link. Only used when `href` is set.",          "type": "'_blank' | '_parent' | '_self' | '_top'",          "values": [            "_blank",            "_parent",            "_self",            "_top"          ]        },        {          "name": "type",          "description": "The button's type.",          "type": "'primary' | 'success' | 'info' | 'warning' | 'danger' | 'default' | 'text'",          "values": [            "primary",            "success",            "info",            "warning",            "danger",            "default",            "text"          ],          "defaultValue": "'default'"        },        {          "name": "value",          "description": "An optional value for the button. Ignored when `href` is set.",          "type": "string"        }      ],      "methods": [        {          "name": "blur",          "description": "Removes focus from the button.",          "params": []        },        {          "name": "click",          "description": "Simulates a click on the button.",          "params": []        },        {          "name": "focus",          "description": "Sets focus on the button.",          "params": [            {              "name": "options",              "type": "FocusOptions",              "isOptional": true            }          ]        }      ],      "events": [        {          "name": "sl-blur",          "description": "Emitted when the button loses focus.",          "details": "void"        },        {          "name": "sl-focus",          "description": "Emitted when the button gains focus.",          "details": "void"        }      ],      "slots": [        {          "name": "",          "description": "The button's label."        },        {          "name": "prefix",          "description": "Used to prepend an icon or similar element to the button."        },        {          "name": "suffix",          "description": "Used to append an icon or similar element to the button.\n"        }      ],      "cssCustomProperties": [],      "parts": [        {          "name": "base",          "description": "The component's base wrapper."        },        {          "name": "prefix",          "description": "The prefix container."        },        {          "name": "label",          "description": "The button's label."        },        {          "name": "suffix",          "description": "The suffix container."        },        {          "name": "caret",          "description": "The button's caret.\n"        }      ],      "dependencies": [        "sl-spinner"      ],      "animations": []    },    {      "className": "SlButtonGroup",      "tag": "sl-button-group",      "file": "src/components/button-group/button-group.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "label",          "description": "A label to use for the button group's `aria-label` attribute.",          "type": "string",          "defaultValue": "''"        }      ],      "methods": [],      "events": [],      "slots": [        {          "name": "",          "description": "One or more `<sl-button>` elements to display in the button group."        }      ],      "cssCustomProperties": [],      "parts": [        {          "name": "base",          "description": "The component's base wrapper.\n"        }      ],      "dependencies": [],      "animations": []    },    {      "className": "SlCard",      "tag": "sl-card",      "file": "src/components/card/card.ts",      "since": "2.0",      "status": "stable",      "props": [],      "methods": [],      "events": [],      "slots": [        {          "name": "",          "description": "The card's body."        },        {          "name": "header",          "description": "The card's header."        },        {          "name": "footer",          "description": "The card's footer."        },        {          "name": "image",          "description": "The card's image.\n"        }      ],      "cssCustomProperties": [        {          "name": "--border-color",          "description": "The card's border color, including borders that occur inside the card."        },        {          "name": "--border-radius",          "description": "The border radius for card edges."        },        {          "name": "--border-width",          "description": "The width of card borders."        },        {          "name": "--padding",          "description": "The padding to use for card sections.*\n"        }      ],      "parts": [        {          "name": "base",          "description": "The component's base wrapper."        },        {          "name": "image",          "description": "The card's image, if present."        },        {          "name": "header",          "description": "The card's header, if present."        },        {          "name": "body",          "description": "The card's body."        },        {          "name": "footer",          "description": "The card's footer, if present.\n"        }      ],      "dependencies": [],      "animations": []    },    {      "className": "SlCheckbox",      "tag": "sl-checkbox",      "file": "src/components/checkbox/checkbox.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "checked",          "description": "Draws the checkbox in a checked state.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "disabled",          "description": "Disables the checkbox.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "indeterminate",          "description": "Draws the checkbox in an indeterminate state.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "invalid",          "description": "This will be true when the control is in an invalid state. Validity is determined by the `required` prop.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "name",          "description": "The checkbox's name attribute.",          "type": "string"        },        {          "name": "required",          "description": "Makes the checkbox a required field.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "value",          "description": "The checkbox's value attribute.",          "type": "string"        }      ],      "methods": [        {          "name": "blur",          "description": "Removes focus from the checkbox.",          "params": []        },        {          "name": "click",          "description": "Simulates a click on the checkbox.",          "params": []        },        {          "name": "focus",          "description": "Sets focus on the checkbox.",          "params": [            {              "name": "options",              "type": "FocusOptions",              "isOptional": true            }          ]        },        {          "name": "reportValidity",          "description": "Checks for validity and shows the browser's validation message if the control is invalid.",          "params": []        },        {          "name": "setCustomValidity",          "description": "Sets a custom validation message. If `message` is not empty, the field will be considered invalid.",          "params": [            {              "name": "message",              "type": "string"            }          ]        }      ],      "events": [        {          "name": "sl-blur",          "description": "Emitted when the control loses focus.",          "details": "void"        },        {          "name": "sl-change",          "description": "Emitted when the control's checked state changes.",          "details": "void"        },        {          "name": "sl-focus",          "description": "Emitted when the control gains focus.",          "details": "void"        }      ],      "slots": [        {          "name": "",          "description": "The checkbox's label."        }      ],      "cssCustomProperties": [],      "parts": [        {          "name": "base",          "description": "The component's base wrapper."        },        {          "name": "control",          "description": "The checkbox control."        },        {          "name": "checked-icon",          "description": "The container the wraps the checked icon."        },        {          "name": "indeterminate-icon",          "description": "The container that wraps the indeterminate icon."        },        {          "name": "label",          "description": "The checkbox label.\n"        }      ],      "dependencies": [],      "animations": []    },    {      "className": "SlColorPicker",      "tag": "sl-color-picker",      "file": "src/components/color-picker/color-picker.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "disabled",          "description": "Disables the color picker.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "format",          "description": "The format to use for the display value. If opacity is enabled, these will translate to HEXA, RGBA, and HSLA\nrespectively. The color picker will always accept user input in any format (including CSS color names) and convert\nit to the desired format.",          "type": "'hex' | 'rgb' | 'hsl'",          "values": [            "hex",            "rgb",            "hsl"          ],          "defaultValue": "'hex'"        },        {          "name": "hoist",          "description": "Enable this option to prevent the panel from being clipped when the component is placed inside a container with\n`overflow: auto|scroll`.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "inline",          "description": "Renders the color picker inline rather than inside a dropdown.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "invalid",          "description": "This will be true when the control is in an invalid state. Validity is determined by the `setCustomValidity()`\nmethod using the browser's constraint validation API.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "name",          "description": "The input's name attribute.",          "type": "string",          "defaultValue": "''"        },        {          "name": "noFormatToggle",          "attribute": "no-format-toggle",          "description": "Removes the format toggle.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "opacity",          "description": "Whether to show the opacity slider.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "size",          "description": "Determines the size of the color picker's trigger. This has no effect on inline color pickers.",          "type": "'small' | 'medium' | 'large'",          "values": [            "small",            "medium",            "large"          ],          "defaultValue": "'medium'"        },        {          "name": "swatches",          "description": "An array of predefined color swatches to display. Can include any format the color picker can parse, including\nHEX(A), RGB(A), HSL(A), and CSS color names.",          "type": "",          "defaultValue": "..."        },        {          "name": "uppercase",          "description": "By default, the value will be set in lowercase. Set this to true to set it in uppercase instead.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "value",          "description": "The current color.",          "type": "string",          "defaultValue": "'#ffffff'"        }      ],      "methods": [        {          "name": "getFormattedValue",          "description": "Returns the current value as a string in the specified format.",          "params": [            {              "name": "format",              "type": "'hex' | 'rgb' | 'hsl' | 'hexa' | 'rgba' | 'hsla'",              "values": [                "hex",                "rgb",                "hsl",                "hexa",                "rgba",                "hsla"              ],              "defaultValue": "'hex'"            }          ]        },        {          "name": "reportValidity",          "description": "Checks for validity and shows the browser's validation message if the control is invalid.",          "params": []        },        {          "name": "setCustomValidity",          "description": "Sets a custom validation message. If `message` is not empty, the field will be considered invalid.",          "params": [            {              "name": "message",              "type": "string"            }          ]        }      ],      "events": [        {          "name": "sl-change",          "description": "Emitted when the color picker's value changes.",          "details": "void"        }      ],      "slots": [],      "cssCustomProperties": [        {          "name": "--grid-width",          "description": "The width of the color grid."        },        {          "name": "--grid-height",          "description": "The height of the color grid."        },        {          "name": "--grid-handle-size",          "description": "The size of the color grid's handle."        },        {          "name": "--slider-height",          "description": "The height of the hue and alpha sliders."        },        {          "name": "--slider-handle-size",          "description": "The diameter of the slider's handle.\n"        }      ],      "parts": [        {          "name": "base",          "description": "The component's base wrapper."        },        {          "name": "trigger",          "description": "The color picker's dropdown trigger."        },        {          "name": "swatches",          "description": "The container that holds swatches."        },        {          "name": "swatch",          "description": "Each individual swatch."        },        {          "name": "grid",          "description": "The color grid."        },        {          "name": "grid-handle",          "description": "The color grid's handle."        },        {          "name": "hue-slider",          "description": "The hue slider."        },        {          "name": "opacity-slider",          "description": "The opacity slider."        },        {          "name": "slider",          "description": "Hue and opacity sliders."        },        {          "name": "slider-handle",          "description": "Hue and opacity slider handles."        },        {          "name": "preview",          "description": "The preview color."        },        {          "name": "input",          "description": "The text input."        },        {          "name": "format-button",          "description": "The toggle format button's base.\n"        }      ],      "dependencies": [        "sl-button",        "sl-dropdown",        "sl-icon",        "sl-input"      ],      "animations": []    },    {      "className": "SlDetails",      "tag": "sl-details",      "file": "src/components/details/details.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "disabled",          "description": "Disables the details so it can't be toggled.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "open",          "description": "Indicates whether or not the details is open. You can use this in lieu of the show/hide methods.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "summary",          "description": "The summary to show in the details header. If you need to display HTML, use the `summary` slot instead.",          "type": "string"        }      ],      "methods": [        {          "name": "hide",          "description": "Hides the details",          "params": []        },        {          "name": "show",          "description": "Shows the details.",          "params": []        }      ],      "events": [        {          "name": "sl-after-hide",          "description": "Emitted after the details closes and all transitions are complete.",          "details": "void"        },        {          "name": "sl-after-show",          "description": "Emitted after the details opens and all transitions are complete.",          "details": "void"        },        {          "name": "sl-hide",          "description": "Emitted when the details closes.",          "details": "void"        },        {          "name": "sl-show",          "description": "Emitted when the details opens.",          "details": "void"        }      ],      "slots": [        {          "name": "",          "description": "The details' content."        },        {          "name": "summary",          "description": "The details' summary. Alternatively, you can use the summary prop.\n"        }      ],      "cssCustomProperties": [],      "parts": [        {          "name": "base",          "description": "The component's base wrapper."        },        {          "name": "header",          "description": "The summary header."        },        {          "name": "summary",          "description": "The details summary."        },        {          "name": "summary-icon",          "description": "The expand/collapse summary icon."        },        {          "name": "content",          "description": "The details content.\n"        }      ],      "dependencies": [        "sl-icon"      ],      "animations": [        {          "name": "details.show",          "description": "The animation to use when showing details. You can use `height: auto` with this animation."        },        {          "name": "details.hide",          "description": "The animation to use when hiding details. You can use `height: auto` with this animation.\n"        }      ]    },    {      "className": "SlDialog",      "tag": "sl-dialog",      "file": "src/components/dialog/dialog.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "label",          "description": "The dialog's label as displayed in the header. You should always include a relevant label even when using\n`no-header`, as it is required for proper accessibility.",          "type": "string",          "defaultValue": "''"        },        {          "name": "noHeader",          "attribute": "no-header",          "description": "Disables the header. This will also remove the default close button, so please ensure you provide an easy,\naccessible way for users to dismiss the dialog.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "open",          "description": "Indicates whether or not the dialog is open. You can use this in lieu of the show/hide methods.",          "type": "boolean",          "defaultValue": "false"        }      ],      "methods": [        {          "name": "hide",          "description": "Hides the dialog",          "params": []        },        {          "name": "show",          "description": "Shows the dialog.",          "params": []        }      ],      "events": [        {          "name": "sl-after-hide",          "description": "Emitted after the dialog closes and all transitions are complete.",          "details": "void"        },        {          "name": "sl-after-show",          "description": "Emitted after the dialog opens and all transitions are complete.",          "details": "void"        },        {          "name": "sl-hide",          "description": "Emitted when the dialog closes.",          "details": "void"        },        {          "name": "sl-initial-focus",          "description": "Emitted when the dialog opens and the panel gains focus. Calling `event.preventDefault()` will prevent focus and\nallow you to set it on a different element in the dialog, such as an input or button.",          "details": "void"        },        {          "name": "sl-overlay-dismiss",          "description": "Emitted when the overlay is clicked. Calling `event.preventDefault()` will prevent the dialog from closing.",          "details": "void"        },        {          "name": "sl-show",          "description": "Emitted when the dialog opens.",          "details": "void"        }      ],      "slots": [        {          "name": "",          "description": "The dialog's content."        },        {          "name": "label",          "description": "The dialog's label. Alternatively, you can use the label prop."        },        {          "name": "footer",          "description": "The dialog's footer, usually one or more buttons representing various options.\n"        }      ],      "cssCustomProperties": [        {          "name": "--width",          "description": "The preferred width of the dialog. Note that the dialog will shrink to accommodate smaller screens."        },        {          "name": "--header-spacing",          "description": "The amount of padding to use for the header."        },        {          "name": "--body-spacing",          "description": "The amount of padding to use for the body."        },        {          "name": "--footer-spacing",          "description": "The amount of padding to use for the footer.\n"        }      ],      "parts": [        {          "name": "base",          "description": "The component's base wrapper."        },        {          "name": "overlay",          "description": "The overlay."        },        {          "name": "panel",          "description": "The dialog panel (where the dialog and its content is rendered)."        },        {          "name": "header",          "description": "The dialog header."        },        {          "name": "title",          "description": "The dialog title."        },        {          "name": "close-button",          "description": "The close button."        },        {          "name": "body",          "description": "The dialog body."        },        {          "name": "footer",          "description": "The dialog footer.\n"        }      ],      "dependencies": [        "sl-icon-button"      ],      "animations": [        {          "name": "dialog.show",          "description": "The animation to use when showing the dialog."        },        {          "name": "dialog.hide",          "description": "The animation to use when hiding the dialog."        },        {          "name": "dialog.overlay.show",          "description": "The animation to use when showing the dialog's overlay."        },        {          "name": "dialog.overlay.hide",          "description": "The animation to use when hiding the dialog's overlay.\n"        }      ]    },    {      "className": "SlDrawer",      "tag": "sl-drawer",      "file": "src/components/drawer/drawer.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "contained",          "description": "By default, the drawer slides out of its containing block (usually the viewport). To make the drawer slide out of\nits parent element, set this prop and add `position: relative` to the parent.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "label",          "description": "The drawer's label as displayed in the header. You should always include a relevant label even when using\n`no-header`, as it is required for proper accessibility.",          "type": "string",          "defaultValue": "''"        },        {          "name": "noHeader",          "attribute": "no-header",          "description": "Removes the header. This will also remove the default close button, so please ensure you provide an easy,\naccessible way for users to dismiss the drawer.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "open",          "description": "Indicates whether or not the drawer is open. You can use this in lieu of the show/hide methods.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "placement",          "description": "The direction from which the drawer will open.",          "type": "'top' | 'end' | 'bottom' | 'start'",          "values": [            "top",            "end",            "bottom",            "start"          ],          "defaultValue": "'end'"        }      ],      "methods": [        {          "name": "hide",          "description": "Hides the drawer",          "params": []        },        {          "name": "show",          "description": "Shows the drawer.",          "params": []        }      ],      "events": [        {          "name": "sl-after-hide",          "description": "Emitted after the drawer closes and all transitions are complete.",          "details": "void"        },        {          "name": "sl-after-show",          "description": "Emitted after the drawer opens and all transitions are complete.",          "details": "void"        },        {          "name": "sl-hide",          "description": "Emitted when the drawer closes.",          "details": "void"        },        {          "name": "sl-initial-focus",          "description": "Emitted when the drawer opens and the panel gains focus. Calling `event.preventDefault()` will prevent focus and allow you to set it on a different element in the drawer, such as an input or button.",          "details": "void"        },        {          "name": "sl-overlay-dismiss",          "description": "Emitted when the overlay is clicked. Calling `event.preventDefault()` will prevent the drawer from closing.",          "details": "void"        },        {          "name": "sl-show",          "description": "Emitted when the drawer opens.",          "details": "void"        }      ],      "slots": [        {          "name": "",          "description": "The drawer's content."        },        {          "name": "label",          "description": "The drawer's label. Alternatively, you can use the label prop."        },        {          "name": "footer",          "description": "The drawer's footer, usually one or more buttons representing various options.\n"        }      ],      "cssCustomProperties": [        {          "name": "--size",          "description": "The preferred size of the drawer. This will be applied to the drawer's width or height\n  depending on its `placement`. Note that the drawer will shrink to accommodate smaller screens."        },        {          "name": "--header-spacing",          "description": "The amount of padding to use for the header."        },        {          "name": "--body-spacing",          "description": "The amount of padding to use for the body."        },        {          "name": "--footer-spacing",          "description": "The amount of padding to use for the footer.\n"        }      ],      "parts": [        {          "name": "base",          "description": "The component's base wrapper."        },        {          "name": "overlay",          "description": "The overlay."        },        {          "name": "panel",          "description": "The drawer panel (where the drawer and its content is rendered)."        },        {          "name": "header",          "description": "The drawer header."        },        {          "name": "title",          "description": "The drawer title."        },        {          "name": "close-button",          "description": "The close button."        },        {          "name": "body",          "description": "The drawer body."        },        {          "name": "footer",          "description": "The drawer footer.\n"        }      ],      "dependencies": [        "sl-icon-button"      ],      "animations": [        {          "name": "drawer.showTop",          "description": "The animation to use when showing a drawer with `top` placement."        },        {          "name": "drawer.showEnd",          "description": "The animation to use when showing a drawer with `end` placement."        },        {          "name": "drawer.showBottom",          "description": "The animation to use when showing a drawer with `bottom` placement."        },        {          "name": "drawer.showStart",          "description": "The animation to use when showing a drawer with `start` placement."        },        {          "name": "drawer.hideTop",          "description": "The animation to use when hiding a drawer with `top` placement."        },        {          "name": "drawer.hideEnd",          "description": "The animation to use when hiding a drawer with `end` placement."        },        {          "name": "drawer.hideBottom",          "description": "The animation to use when hiding a drawer with `bottom` placement."        },        {          "name": "drawer.hideStart",          "description": "The animation to use when hiding a drawer with `start` placement."        },        {          "name": "drawer.overlay.show",          "description": "The animation to use when showing the drawer's overlay."        },        {          "name": "drawer.overlay.hide",          "description": "The animation to use when hiding the drawer's overlay.\n"        }      ]    },    {      "className": "SlDropdown",      "tag": "sl-dropdown",      "file": "src/components/dropdown/dropdown.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "closeOnSelect",          "attribute": "close-on-select",          "description": "Determines whether the dropdown should hide when a menu item is selected.",          "type": "boolean",          "defaultValue": "true"        },        {          "name": "containingElement",          "description": "The dropdown will close when the user interacts outside of this element (e.g. clicking).",          "type": "HTMLElement"        },        {          "name": "disabled",          "description": "Disables the dropdown so the panel will not open.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "distance",          "description": "The distance in pixels from which to offset the panel away from its trigger.",          "type": "number",          "defaultValue": "2"        },        {          "name": "hoist",          "description": "Enable this option to prevent the panel from being clipped when the component is placed inside a container with\n`overflow: auto|scroll`.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "open",          "description": "Indicates whether or not the dropdown is open. You can use this in lieu of the show/hide methods.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "placement",          "description": "The preferred placement of the dropdown panel. Note that the actual placement may vary as needed to keep the panel\ninside of the viewport.",          "type": "'top' | 'bottom' | 'top-start' | 'top-end' | 'bottom-start' | 'bottom-end' | 'right' | 'right-start' | 'right-end' | 'left' | 'left-start' | 'left-end'",          "values": [            "top",            "bottom",            "top-start",            "top-end",            "bottom-start",            "bottom-end",            "right",            "right-start",            "right-end",            "left",            "left-start",            "left-end"          ],          "defaultValue": "'bottom-start'"        },        {          "name": "skidding",          "description": "The distance in pixels from which to offset the panel along its trigger.",          "type": "number",          "defaultValue": "0"        }      ],      "methods": [        {          "name": "hide",          "description": "Hides the dropdown panel",          "params": []        },        {          "name": "reposition",          "description": "Instructs the dropdown menu to reposition. Useful when the position or size of the trigger changes when the menu\nis activated.",          "params": []        },        {          "name": "show",          "description": "Shows the dropdown panel.",          "params": []        }      ],      "events": [        {          "name": "sl-after-hide",          "description": "Emitted after the dropdown closes and all animations are complete.",          "details": "void"        },        {          "name": "sl-after-show",          "description": "Emitted after the dropdown opens and all animations are complete.",          "details": "void"        },        {          "name": "sl-hide",          "description": "Emitted when the dropdown closes.",          "details": "void"        },        {          "name": "sl-show",          "description": "Emitted when the dropdown opens.",          "details": "void"        }      ],      "slots": [        {          "name": "trigger",          "description": "The dropdown's trigger, usually a `<sl-button>` element."        },        {          "name": "",          "description": "The dropdown's content."        }      ],      "cssCustomProperties": [],      "parts": [        {          "name": "base",          "description": "The component's base wrapper."        },        {          "name": "trigger",          "description": "The container that wraps the trigger."        },        {          "name": "panel",          "description": "The panel that gets shown when the dropdown is open.\n"        }      ],      "dependencies": [],      "animations": [        {          "name": "dropdown.show",          "description": "The animation to use when showing the dropdown."        },        {          "name": "dropdown.hide",          "description": "The animation to use when hiding the dropdown.\n"        }      ]    },    {      "className": "SlForm",      "tag": "sl-form",      "file": "src/components/form/form.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "novalidate",          "description": "Prevent the form from validating inputs before submitting.",          "type": "boolean",          "defaultValue": "false"        }      ],      "methods": [        {          "name": "getFormControls",          "description": "Gets all form control elements (native and custom).",          "params": []        },        {          "name": "getFormData",          "description": "Serializes all form controls elements and returns a `FormData` object.",          "params": []        },        {          "name": "submit",          "description": "Submits the form. If all controls are valid, the `sl-submit` event will be emitted and the promise will resolve\nwith `true`. If any form control is invalid, the promise will resolve with `false` and no event will be emitted.",          "params": []        }      ],      "events": [        {          "name": "sl-submit",          "description": "Emitted when the form is submitted. This event will not be emitted if any form control inside of\nit is in an invalid state, unless the form has the `novalidate` attribute. Note that there is never a need to prevent\nthis event, since it doen't send a GET or POST request like native forms. To \"prevent\" submission, use a conditional\naround the XHR request you use to submit the form's data with.",          "details": "{ formControls: HTMLElement[], formData: FormData }"        }      ],      "slots": [        {          "name": "",          "description": "The form's content."        }      ],      "cssCustomProperties": [],      "parts": [        {          "name": "base",          "description": "The component's base wrapper.\n"        }      ],      "dependencies": [],      "animations": []    },    {      "className": "SlFormatBytes",      "tag": "sl-format-bytes",      "file": "src/components/format-bytes/format-bytes.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "locale",          "description": "The locale to use when formatting the number.",          "type": "string"        },        {          "name": "unit",          "description": "The unit to display.",          "type": "'bytes' | 'bits'",          "values": [            "bytes",            "bits"          ],          "defaultValue": "'bytes'"        },        {          "name": "value",          "description": "The number to format in bytes.",          "type": "number",          "defaultValue": "0"        }      ],      "methods": [],      "events": [],      "slots": [],      "cssCustomProperties": [],      "parts": [],      "dependencies": [],      "animations": []    },    {      "className": "SlFormatDate",      "tag": "sl-format-date",      "file": "src/components/format-date/format-date.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "date",          "description": "The date/time to format. If not set, the current date and time will be used.",          "type": "'' | ''",          "values": [            "string",            null          ],          "defaultValue": "..."        },        {          "name": "day",          "description": "The format for displaying the day.",          "type": "'numeric' | '2-digit'",          "values": [            "numeric",            "2-digit"          ]        },        {          "name": "era",          "description": "The format for displaying the era.",          "type": "'narrow' | 'short' | 'long'",          "values": [            "narrow",            "short",            "long"          ]        },        {          "name": "hour",          "description": "The format for displaying the hour.",          "type": "'numeric' | '2-digit'",          "values": [            "numeric",            "2-digit"          ]        },        {          "name": "hourFormat",          "attribute": "hour-format",          "description": "When set, 24 hour time will always be used.",          "type": "'auto' | '12' | '24'",          "values": [            "auto",            "12",            "24"          ],          "defaultValue": "'auto'"        },        {          "name": "locale",          "description": "The locale to use when formatting the date/time.",          "type": "string"        },        {          "name": "minute",          "description": "The format for displaying the minute.",          "type": "'numeric' | '2-digit'",          "values": [            "numeric",            "2-digit"          ]        },        {          "name": "month",          "description": "The format for displaying the month.",          "type": "'narrow' | 'short' | 'long' | 'numeric' | '2-digit'",          "values": [            "narrow",            "short",            "long",            "numeric",            "2-digit"          ]        },        {          "name": "second",          "description": "The format for displaying the second.",          "type": "'numeric' | '2-digit'",          "values": [            "numeric",            "2-digit"          ]        },        {          "name": "timeZone",          "attribute": "time-zone",          "description": "The time zone to express the time in.",          "type": "string"        },        {          "name": "timeZoneName",          "attribute": "time-zone-name",          "description": "The format for displaying the time.",          "type": "'short' | 'long'",          "values": [            "short",            "long"          ]        },        {          "name": "weekday",          "description": "The format for displaying the weekday.",          "type": "'narrow' | 'short' | 'long'",          "values": [            "narrow",            "short",            "long"          ]        },        {          "name": "year",          "description": "The format for displaying the year.",          "type": "'numeric' | '2-digit'",          "values": [            "numeric",            "2-digit"          ]        }      ],      "methods": [],      "events": [],      "slots": [],      "cssCustomProperties": [],      "parts": [],      "dependencies": [],      "animations": []    },    {      "className": "SlFormatNumber",      "tag": "sl-format-number",      "file": "src/components/format-number/format-number.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "currency",          "description": "The currency to use when formatting. Must be an ISO 4217 currency code such as `USD` or `EUR`.",          "type": "string",          "defaultValue": "'USD'"        },        {          "name": "currencyDisplay",          "attribute": "currency-display",          "description": "How to display the currency.",          "type": "'symbol' | 'name' | 'code' | 'narrowSymbol'",          "values": [            "symbol",            "name",            "code",            "narrowSymbol"          ],          "defaultValue": "'symbol'"        },        {          "name": "locale",          "description": "The locale to use when formatting the number.",          "type": "string"        },        {          "name": "maximumFractionDigits",          "attribute": "maximum-fraction-digits",          "description": "The maximum number of fraction digits to use. Possible values are 0 - 20.",          "type": "number"        },        {          "name": "maximumSignificantDigits",          "attribute": "maximum-significant-digits",          "description": "The maximum number of significant digits to use,. Possible values are 1 - 21.",          "type": "number"        },        {          "name": "minimumFractionDigits",          "attribute": "minimum-fraction-digits",          "description": "The minimum number of fraction digits to use. Possible values are 0 - 20.",          "type": "number"        },        {          "name": "minimumIntegerDigits",          "attribute": "minimum-integer-digits",          "description": "The minimum number of integer digits to use. Possible values are 1 - 21.",          "type": "number"        },        {          "name": "minimumSignificantDigits",          "attribute": "minimum-significant-digits",          "description": "The minimum number of significant digits to use. Possible values are 1 - 21.",          "type": "number"        },        {          "name": "noGrouping",          "attribute": "no-grouping",          "description": "Turns off grouping separators.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "type",          "description": "The formatting style to use.",          "type": "'currency' | 'decimal' | 'percent'",          "values": [            "currency",            "decimal",            "percent"          ],          "defaultValue": "'decimal'"        },        {          "name": "value",          "description": "The number to format.",          "type": "number",          "defaultValue": "0"        }      ],      "methods": [],      "events": [],      "slots": [],      "cssCustomProperties": [],      "parts": [],      "dependencies": [],      "animations": []    },    {      "className": "SlIcon",      "tag": "sl-icon",      "file": "src/components/icon/icon.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "label",          "description": "An alternative description to use for accessibility. If omitted, the name or src will be used to generate it.",          "type": "string"        },        {          "name": "library",          "description": "The name of a registered custom icon library.",          "type": "string",          "defaultValue": "'default'"        },        {          "name": "name",          "description": "The name of the icon to draw.",          "type": "string"        },        {          "name": "src",          "description": "An external URL of an SVG file.",          "type": "string"        }      ],      "methods": [],      "events": [        {          "name": "sl-error",          "description": "Emitted when the icon failed to load.",          "details": "{ status: number }"        },        {          "name": "sl-load",          "description": "Emitted when the icon has loaded.",          "details": "void"        }      ],      "slots": [],      "cssCustomProperties": [],      "parts": [        {          "name": "base",          "description": "The component's base wrapper.\n"        }      ],      "dependencies": [],      "animations": []    },    {      "className": "SlIconButton",      "tag": "sl-icon-button",      "file": "src/components/icon-button/icon-button.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "disabled",          "description": "Disables the button.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "label",          "description": "A description that gets read by screen readers and other assistive devices. For optimal accessibility, you should\nalways include a label that describes what the icon button does.",          "type": "string",          "defaultValue": "''"        },        {          "name": "library",          "description": "The name of a registered custom icon library.",          "type": "string"        },        {          "name": "name",          "description": "The name of the icon to draw.",          "type": "string"        },        {          "name": "src",          "description": "An external URL of an SVG file.",          "type": "string"        }      ],      "methods": [],      "events": [],      "slots": [],      "cssCustomProperties": [],      "parts": [        {          "name": "base",          "description": "The component's base wrapper.\n"        }      ],      "dependencies": [        "sl-icon"      ],      "animations": []    },    {      "className": "SlImageComparer",      "tag": "sl-image-comparer",      "file": "src/components/image-comparer/image-comparer.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "position",          "description": "The position of the divider as a percentage.",          "type": "number",          "defaultValue": "50"        }      ],      "methods": [],      "events": [],      "slots": [        {          "name": "before",          "description": "The before image, an `<img>` or `<svg>` element."        },        {          "name": "after",          "description": "The after image, an `<img>` or `<svg>` element."        },        {          "name": "handle-icon",          "description": "The icon used inside the handle.\n"        }      ],      "cssCustomProperties": [        {          "name": "--divider-width",          "description": "The width of the dividing line."        },        {          "name": "--handle-size",          "description": "The size of the compare handle.\n"        }      ],      "parts": [        {          "name": "base",          "description": "The component's base wrapper."        },        {          "name": "before",          "description": "The container that holds the \"before\" image."        },        {          "name": "after",          "description": "The container that holds the \"after\" image."        },        {          "name": "divider",          "description": "The divider that separates the images."        },        {          "name": "handle",          "description": "The handle that the user drags to expose the after image.\n"        }      ],      "dependencies": [        "sl-icon"      ],      "animations": []    },    {      "className": "SlInclude",      "tag": "sl-include",      "file": "src/components/include/include.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "allowScripts",          "attribute": "allow-scripts",          "description": "Allows included scripts to be executed. You must ensure the content you're including is trusted, otherwise this\noption can lead to XSS vulnerabilities in your app!",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "mode",          "description": "The fetch mode to use.",          "type": "'cors' | 'no-cors' | 'same-origin'",          "values": [            "cors",            "no-cors",            "same-origin"          ],          "defaultValue": "'cors'"        },        {          "name": "src",          "description": "The location of the HTML file to include.",          "type": "string"        }      ],      "methods": [],      "events": [        {          "name": "sl-error",          "description": "Emitted when the included file fails to load due to an error.",          "details": "{ status: number }"        },        {          "name": "sl-load",          "description": "Emitted when the included file is loaded.",          "details": "void"        }      ],      "slots": [],      "cssCustomProperties": [],      "parts": [],      "dependencies": [],      "animations": []    },    {      "className": "SlInput",      "tag": "sl-input",      "file": "src/components/input/input.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "autocapitalize",          "description": "The input's autocaptialize attribute.",          "type": "'none' | 'off' | 'on' | 'sentences' | 'words' | 'characters'",          "values": [            "none",            "off",            "on",            "sentences",            "words",            "characters"          ]        },        {          "name": "autocomplete",          "description": "The input's autocomplete attribute.",          "type": "string"        },        {          "name": "autocorrect",          "description": "The input's autocorrect attribute.",          "type": "string"        },        {          "name": "autofocus",          "description": "The input's autofocus attribute.",          "type": "boolean"        },        {          "name": "clearable",          "description": "Adds a clear button when the input is populated.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "disabled",          "description": "Disables the input.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "helpText",          "attribute": "help-text",          "description": "The input's help text. Alternatively, you can use the help-text slot.",          "type": "string",          "defaultValue": "''"        },        {          "name": "inputmode",          "description": "The input's inputmode attribute.",          "type": "'none' | 'text' | 'numeric' | 'decimal' | 'email' | 'search' | 'tel' | 'url'",          "values": [            "none",            "text",            "numeric",            "decimal",            "email",            "search",            "tel",            "url"          ]        },        {          "name": "invalid",          "description": "This will be true when the control is in an invalid state. Validity is determined by props such as `type`,\n`required`, `minlength`, `maxlength`, and `pattern` using the browser's constraint validation API.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "label",          "description": "The input's label. Alternatively, you can use the label slot.",          "type": "string"        },        {          "name": "max",          "description": "The input's maximum value.",          "type": "string | number",          "values": [            "string",            "number"          ]        },        {          "name": "maxlength",          "description": "The maximum length of input that will be considered valid.",          "type": "number"        },        {          "name": "min",          "description": "The input's minimum value.",          "type": "string | number",          "values": [            "string",            "number"          ]        },        {          "name": "minlength",          "description": "The minimum length of input that will be considered valid.",          "type": "number"        },        {          "name": "name",          "description": "The input's name attribute.",          "type": "string"        },        {          "name": "pattern",          "description": "A pattern to validate input against.",          "type": "string"        },        {          "name": "pill",          "description": "Draws a pill-style input with rounded edges.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "placeholder",          "description": "The input's placeholder text.",          "type": "string"        },        {          "name": "readonly",          "description": "Makes the input readonly.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "required",          "description": "Makes the input a required field.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "size",          "description": "The input's size.",          "type": "'small' | 'medium' | 'large'",          "values": [            "small",            "medium",            "large"          ],          "defaultValue": "'medium'"        },        {          "name": "spellcheck",          "description": "Enables spell checking on the input.",          "type": "boolean"        },        {          "name": "step",          "description": "The input's step attribute.",          "type": "number"        },        {          "name": "togglePassword",          "attribute": "toggle-password",          "description": "Adds a password toggle button to password inputs.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "type",          "description": "The input's type.",          "type": "'number' | 'text' | 'email' | 'password' | 'search' | 'tel' | 'url'",          "values": [            "number",            "text",            "email",            "password",            "search",            "tel",            "url"          ],          "defaultValue": "'text'"        },        {          "name": "value",          "description": "The input's value attribute.",          "type": "string",          "defaultValue": "''"        }      ],      "methods": [        {          "name": "blur",          "description": "Removes focus from the input.",          "params": []        },        {          "name": "focus",          "description": "Sets focus on the input.",          "params": [            {              "name": "options",              "type": "FocusOptions",              "isOptional": true            }          ]        },        {          "name": "reportValidity",          "description": "Checks for validity and shows the browser's validation message if the control is invalid.",          "params": []        },        {          "name": "select",          "description": "Selects all the text in the input.",          "params": []        },        {          "name": "setCustomValidity",          "description": "Sets a custom validation message. If `message` is not empty, the field will be considered invalid.",          "params": [            {              "name": "message",              "type": "string"            }          ]        },        {          "name": "setRangeText",          "description": "Replaces a range of text with a new string.",          "params": [            {              "name": "replacement",              "type": "string"            },            {              "name": "start",              "type": "number"            },            {              "name": "end",              "type": "number"            },            {              "name": "selectMode",              "type": "'end' | 'start' | 'select' | 'preserve'",              "values": [                "end",                "start",                "select",                "preserve"              ],              "defaultValue": "'preserve'"            }          ]        },        {          "name": "setSelectionRange",          "description": "Sets the start and end positions of the text selection (0-based).",          "params": [            {              "name": "selectionStart",              "type": "number"            },            {              "name": "selectionEnd",              "type": "number"            },            {              "name": "selectionDirection",              "type": "'none' | 'forward' | 'backward'",              "values": [                "none",                "forward",                "backward"              ],              "defaultValue": "'none'"            }          ]        }      ],      "events": [        {          "name": "sl-blur",          "description": "Emitted when the control loses focus.",          "details": "void"        },        {          "name": "sl-change",          "description": "Emitted when the control's value changes.",          "details": "void"        },        {          "name": "sl-clear",          "description": "Emitted when the clear button is activated.",          "details": "void"        },        {          "name": "sl-focus",          "description": "Emitted when the control gains focus.",          "details": "void"        },        {          "name": "sl-input",          "description": "Emitted when the control receives input.",          "details": "void"        }      ],      "slots": [        {          "name": "label",          "description": "The input's label. Alternatively, you can use the label prop."        },        {          "name": "prefix",          "description": "Used to prepend an icon or similar element to the input."        },        {          "name": "suffix",          "description": "Used to append an icon or similar element to the input."        },        {          "name": "clear-icon",          "description": "An icon to use in lieu of the default clear icon."        },        {          "name": "show-password-icon",          "description": "An icon to use in lieu of the default show password icon."        },        {          "name": "hide-password-icon",          "description": "An icon to use in lieu of the default hide password icon."        },        {          "name": "help-text",          "description": "Help text that describes how to use the input. Alternatively, you can use the help-text prop.\n"        }      ],      "cssCustomProperties": [        {          "name": "--focus-ring",          "description": "The focus ring style to use when the control receives focus, a `box-shadow` property.\n"        }      ],      "parts": [        {          "name": "base",          "description": "The component's base wrapper."        },        {          "name": "form-control",          "description": "The form control that wraps the label, input, and help-text."        },        {          "name": "label",          "description": "The input label."        },        {          "name": "input",          "description": "The input control."        },        {          "name": "prefix",          "description": "The input prefix container."        },        {          "name": "clear-button",          "description": "The clear button."        },        {          "name": "password-toggle-button",          "description": "The password toggle button."        },        {          "name": "suffix",          "description": "The input suffix container."        },        {          "name": "help-text",          "description": "The input help text.\n"        }      ],      "dependencies": [        "sl-icon"      ],      "animations": []    },    {      "className": "SlMenu",      "tag": "sl-menu",      "file": "src/components/menu/menu.ts",      "since": "2.0",      "status": "stable",      "props": [],      "methods": [        {          "name": "typeToSelect",          "description": "Initiates type-to-select logic, which automatically selects an option based on what the user is currently typing.\nThe key passed will be appended to the internal query and the selection will be updated. After a brief period, the\ninternal query is cleared automatically. This method is intended to be used with the keydown event. Useful for\nenabling type-to-select when the menu doesn't have focus.",          "params": [            {              "name": "key",              "type": "string"            }          ]        }      ],      "events": [        {          "name": "sl-select",          "description": "Emitted when a menu item is selected.",          "details": "{ item: SlMenuItem }"        }      ],      "slots": [        {          "name": "",          "description": "The menu's content, including menu items, menu dividers, and menu labels."        }      ],      "cssCustomProperties": [],      "parts": [        {          "name": "base",          "description": "The component's base wrapper.\n"        }      ],      "dependencies": [],      "animations": []    },    {      "className": "SlMenuDivider",      "tag": "sl-menu-divider",      "file": "src/components/menu-divider/menu-divider.ts",      "since": "2.0",      "status": "stable",      "props": [],      "methods": [],      "events": [],      "slots": [],      "cssCustomProperties": [],      "parts": [        {          "name": "base",          "description": "The component's base wrapper.\n"        }      ],      "dependencies": [        "sl-menu"      ],      "animations": []    },    {      "className": "SlMenuItem",      "tag": "sl-menu-item",      "file": "src/components/menu-item/menu-item.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "checked",          "description": "Draws the item in a checked state.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "disabled",          "description": "Draws the menu item in a disabled state.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "value",          "description": "A unique value to store in the menu item. This can be used as a way to identify menu items when selected.",          "type": "string",          "defaultValue": "''"        }      ],      "methods": [        {          "name": "blur",          "description": "Removes focus from the button.",          "params": []        },        {          "name": "focus",          "description": "Sets focus on the button.",          "params": [            {              "name": "options",              "type": "FocusOptions",              "isOptional": true            }          ]        }      ],      "events": [],      "slots": [        {          "name": "",          "description": "The menu item's label."        },        {          "name": "prefix",          "description": "Used to prepend an icon or similar element to the menu item."        },        {          "name": "suffix",          "description": "Used to append an icon or similar element to the menu item.\n"        }      ],      "cssCustomProperties": [],      "parts": [        {          "name": "base",          "description": "The component's base wrapper."        },        {          "name": "checked-icon",          "description": "The container that wraps the checked icon."        },        {          "name": "prefix",          "description": "The prefix container."        },        {          "name": "label",          "description": "The menu item label."        },        {          "name": "suffix",          "description": "The suffix container.\n"        }      ],      "dependencies": [        "sl-icon"      ],      "animations": []    },    {      "className": "SlMenuLabel",      "tag": "sl-menu-label",      "file": "src/components/menu-label/menu-label.ts",      "since": "2.0",      "status": "stable",      "props": [],      "methods": [],      "events": [],      "slots": [        {          "name": "",          "description": "The menu label's content."        }      ],      "cssCustomProperties": [],      "parts": [        {          "name": "base",          "description": "The component's base wrapper.\n"        }      ],      "dependencies": [        "sl-menu"      ],      "animations": []    },    {      "className": "SlProgressBar",      "tag": "sl-progress-bar",      "file": "src/components/progress-bar/progress-bar.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "indeterminate",          "description": "When true, percentage is ignored, the label is hidden, and the progress bar is drawn in an indeterminate state.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "percentage",          "description": "The progress bar's percentage, 0 to 100.",          "type": "number",          "defaultValue": "0"        }      ],      "methods": [],      "events": [],      "slots": [        {          "name": "",          "description": "A label to show inside the indicator."        }      ],      "cssCustomProperties": [        {          "name": "--height",          "description": "The progress bar's height."        },        {          "name": "--track-color",          "description": "The track color."        },        {          "name": "--indicator-color",          "description": "The indicator color."        },        {          "name": "--label-color",          "description": "The label color.\n"        }      ],      "parts": [        {          "name": "base",          "description": "The component's base wrapper."        },        {          "name": "indicator",          "description": "The progress bar indicator."        },        {          "name": "label",          "description": "The progress bar label.\n"        }      ],      "dependencies": [],      "animations": []    },    {      "className": "SlProgressRing",      "tag": "sl-progress-ring",      "file": "src/components/progress-ring/progress-ring.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "percentage",          "description": "The current progress percentage, 0 - 100.",          "type": "number"        },        {          "name": "size",          "description": "The size of the progress ring in pixels.",          "type": "number",          "defaultValue": "128"        },        {          "name": "strokeWidth",          "attribute": "stroke-width",          "description": "The stroke width of the progress ring in pixels.",          "type": "number",          "defaultValue": "4"        }      ],      "methods": [],      "events": [],      "slots": [        {          "name": "",          "description": "A label to show inside the ring."        }      ],      "cssCustomProperties": [        {          "name": "--track-color",          "description": "The track color."        },        {          "name": "--indicator-color",          "description": "The indicator color.\n"        }      ],      "parts": [        {          "name": "base",          "description": "The component's base wrapper."        },        {          "name": "label",          "description": "The progress ring label.\n"        }      ],      "dependencies": [],      "animations": []    },    {      "className": "SlQrCode",      "tag": "sl-qr-code",      "file": "src/components/qr-code/qr-code.ts",      "since": "2.0",      "status": "experimental",      "props": [        {          "name": "background",          "description": "The background color. This can be any valid CSS color or `transparent`, but not a CSS custom property.",          "type": "string",          "defaultValue": "'#fff'"        },        {          "name": "errorCorrection",          "attribute": "error-correction",          "description": "The level of error correction to use.",          "type": "'L' | 'M' | 'Q' | 'H'",          "values": [            "L",            "M",            "Q",            "H"          ],          "defaultValue": "'H'"        },        {          "name": "fill",          "description": "The fill color. This can be any valid CSS color, but not a CSS custom property.",          "type": "string",          "defaultValue": "'#000'"        },        {          "name": "label",          "description": "The label used when screen readers announce the code. If unspecified, the value will be used.",          "type": "string",          "defaultValue": "''"        },        {          "name": "radius",          "description": "The edge radius of each module. Must be between 0 and 0.5.",          "type": "number",          "defaultValue": "0"        },        {          "name": "size",          "description": "The size of the code's overall square in pixels.",          "type": "number",          "defaultValue": "128"        },        {          "name": "value",          "description": "The QR code's value.",          "type": "string",          "defaultValue": "''"        }      ],      "methods": [],      "events": [],      "slots": [],      "cssCustomProperties": [],      "parts": [        {          "name": "base",          "description": "The component's base wrapper.\n"        }      ],      "dependencies": [],      "animations": []    },    {      "className": "SlRadio",      "tag": "sl-radio",      "file": "src/components/radio/radio.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "checked",          "description": "Draws the radio in a checked state.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "disabled",          "description": "Disables the radio.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "invalid",          "description": "This will be true when the control is in an invalid state. Validity in range inputs is determined by the message\nprovided by the `setCustomValidity` method.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "name",          "description": "The radio's name attribute.",          "type": "string"        },        {          "name": "value",          "description": "The radio's value attribute.",          "type": "string"        }      ],      "methods": [        {          "name": "blur",          "description": "Removes focus from the radio.",          "params": []        },        {          "name": "click",          "description": "Simulates a click on the radio.",          "params": []        },        {          "name": "focus",          "description": "Sets focus on the radio.",          "params": [            {              "name": "options",              "type": "FocusOptions",              "isOptional": true            }          ]        },        {          "name": "reportValidity",          "description": "Checks for validity and shows the browser's validation message if the control is invalid.",          "params": []        },        {          "name": "setCustomValidity",          "description": "Sets a custom validation message. If `message` is not empty, the field will be considered invalid.",          "params": [            {              "name": "message",              "type": "string"            }          ]        }      ],      "events": [        {          "name": "sl-blur",          "description": "Emitted when the control loses focus.",          "details": "void"        },        {          "name": "sl-change",          "description": "Emitted when the control's checked state changes.",          "details": "void"        },        {          "name": "sl-focus",          "description": "Emitted when the control gains focus.",          "details": "void"        }      ],      "slots": [        {          "name": "",          "description": "The radio's label."        }      ],      "cssCustomProperties": [],      "parts": [        {          "name": "base",          "description": "The component's base wrapper."        },        {          "name": "control",          "description": "The radio control."        },        {          "name": "checked-icon",          "description": "The container the wraps the checked icon."        },        {          "name": "label",          "description": "The radio label.\n"        }      ],      "dependencies": [],      "animations": []    },    {      "className": "SlRadioGroup",      "tag": "sl-radio-group",      "file": "src/components/radio-group/radio-group.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "label",          "description": "The radio group label. Required for proper accessibility. Alternatively, you can use the label slot.",          "type": "string",          "defaultValue": "''"        },        {          "name": "noFieldset",          "attribute": "no-fieldset",          "description": "Hides the fieldset and legend that surrounds the radio group. The label will still be read by screen readers.",          "type": "boolean",          "defaultValue": "false"        }      ],      "methods": [],      "events": [],      "slots": [        {          "name": "",          "description": "The default slot where radio controls are placed."        },        {          "name": "label",          "description": "The radio group label. Required for proper accessibility. Alternatively, you can use the label prop.\n"        }      ],      "cssCustomProperties": [],      "parts": [        {          "name": "base",          "description": "The component's base wrapper."        },        {          "name": "label",          "description": "The radio group label.\n"        }      ],      "dependencies": [],      "animations": []    },    {      "className": "SlRange",      "tag": "sl-range",      "file": "src/components/range/range.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "disabled",          "description": "Disables the input.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "helpText",          "attribute": "help-text",          "description": "The range's help text. Alternatively, you can use the help-text slot.",          "type": "string",          "defaultValue": "''"        },        {          "name": "invalid",          "description": "This will be true when the control is in an invalid state. Validity in range inputs is determined by the message\nprovided by the `setCustomValidity` method.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "label",          "description": "The range's label. Alternatively, you can use the label slot.",          "type": "string",          "defaultValue": "''"        },        {          "name": "max",          "description": "The input's max attribute.",          "type": "number",          "defaultValue": "100"        },        {          "name": "min",          "description": "The input's min attribute.",          "type": "number",          "defaultValue": "0"        },        {          "name": "name",          "description": "The input's name attribute.",          "type": "string",          "defaultValue": "''"        },        {          "name": "step",          "description": "The input's step attribute.",          "type": "number",          "defaultValue": "1"        },        {          "name": "tooltip",          "description": "The preferred placedment of the tooltip.",          "type": "'none' | 'top' | 'bottom'",          "values": [            "none",            "top",            "bottom"          ],          "defaultValue": "'top'"        },        {          "name": "value",          "description": "The input's value attribute.",          "type": "number",          "defaultValue": "0"        }      ],      "methods": [        {          "name": "blur",          "description": "Removes focus from the input.",          "params": []        },        {          "name": "focus",          "description": "Sets focus on the input.",          "params": [            {              "name": "options",              "type": "FocusOptions",              "isOptional": true            }          ]        },        {          "name": "setCustomValidity",          "description": "Sets a custom validation message. If `message` is not empty, the field will be considered invalid.",          "params": [            {              "name": "message",              "type": "string"            }          ]        },        {          "name": "tooltipFormatter",          "description": "A function used to format the tooltip's value.",          "params": [            {              "name": "value",              "type": "number"            }          ]        }      ],      "events": [        {          "name": "sl-blur",          "description": "Emitted when the control loses focus.",          "details": "void"        },        {          "name": "sl-change",          "description": "Emitted when the control's value changes.",          "details": "void"        },        {          "name": "sl-focus",          "description": "Emitted when the control gains focus.",          "details": "void"        }      ],      "slots": [        {          "name": "label",          "description": "The input's label. Alternatively, you can use the label prop."        },        {          "name": "help-text",          "description": "Help text that describes how to use the input. Alternatively, you can use the help-text prop.\n"        }      ],      "cssCustomProperties": [],      "parts": [        {          "name": "base",          "description": "The component's base wrapper."        },        {          "name": "input",          "description": "The native range input."        },        {          "name": "tooltip",          "description": "The range tooltip.\n"        }      ],      "dependencies": [],      "animations": []    },    {      "className": "SlRating",      "tag": "sl-rating",      "file": "src/components/rating/rating.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "disabled",          "description": "Disables the rating.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "max",          "description": "The highest rating to show.",          "type": "number",          "defaultValue": "5"        },        {          "name": "precision",          "description": "The minimum increment value allowed by the control.",          "type": "number",          "defaultValue": "1"        },        {          "name": "readonly",          "description": "Makes the rating readonly.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "value",          "description": "The current rating.",          "type": "number",          "defaultValue": "0"        }      ],      "methods": [        {          "name": "blur",          "description": "Removes focus from the rating.",          "params": []        },        {          "name": "focus",          "description": "Sets focus on the rating.",          "params": [            {              "name": "options",              "type": "FocusOptions",              "isOptional": true            }          ]        },        {          "name": "getSymbol",          "description": "The name of the icon to display as the symbol.",          "params": [            {              "name": "value",              "type": "number",              "isOptional": true            }          ]        }      ],      "events": [        {          "name": "sl-change",          "description": "Emitted when the rating's value changes.",          "details": "void"        }      ],      "slots": [],      "cssCustomProperties": [        {          "name": "--symbol-color",          "description": "The inactive color for symbols."        },        {          "name": "--symbol-color-active",          "description": "The active color for symbols."        },        {          "name": "--symbol-size",          "description": "The size of symbols."        },        {          "name": "--symbol-spacing",          "description": "The spacing to use around symbols.\n"        }      ],      "parts": [        {          "name": "base",          "description": "The component's base wrapper.\n"        }      ],      "dependencies": [        "sl-icon"      ],      "animations": []    },    {      "className": "SlRelativeTime",      "tag": "sl-relative-time",      "file": "src/components/relative-time/relative-time.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "date",          "description": "The date from which to calculate time from.",          "type": "'' | ''",          "values": [            "string",            null          ]        },        {          "name": "format",          "description": "The formatting style to use.",          "type": "'narrow' | 'short' | 'long'",          "values": [            "narrow",            "short",            "long"          ],          "defaultValue": "'long'"        },        {          "name": "locale",          "description": "The locale to use when formatting the number.",          "type": "string"        },        {          "name": "numeric",          "description": "When `auto`, values such as \"yesterday\" and \"tomorrow\" will be shown when possible. When `always`, values such as\n\"1 day ago\" and \"in 1 day\" will be shown.",          "type": "'auto' | 'always'",          "values": [            "auto",            "always"          ],          "defaultValue": "'auto'"        },        {          "name": "sync",          "description": "Keep the displayed value up to date as time passes.",          "type": "boolean",          "defaultValue": "false"        }      ],      "methods": [],      "events": [],      "slots": [],      "cssCustomProperties": [],      "parts": [],      "dependencies": [],      "animations": []    },    {      "className": "SlResizeObserver",      "tag": "sl-resize-observer",      "file": "src/components/resize-observer/resize-observer.ts",      "since": "2.0",      "status": "stable",      "props": [],      "methods": [],      "events": [        {          "name": "sl-resize",          "description": "Emitted when the element is resized.",          "details": "{ entries: ResizeObserverEntry[] }"        }      ],      "slots": [],      "cssCustomProperties": [],      "parts": [],      "dependencies": [],      "animations": []    },    {      "className": "SlResponsiveMedia",      "tag": "sl-responsive-media",      "file": "src/components/responsive-media/responsive-media.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "aspectRatio",          "attribute": "aspect-ratio",          "description": "The aspect ratio of the embedded media in the format of `width:height`, e.g. `16:9`, `4:3`, or `1:1`. Ratios not in\nthis format will be ignored.",          "type": "string",          "defaultValue": "'16:9'"        },        {          "name": "fit",          "description": "Determines how content will be resized to fit its container.",          "type": "'cover' | 'contain'",          "values": [            "cover",            "contain"          ],          "defaultValue": "'cover'"        }      ],      "methods": [],      "events": [],      "slots": [        {          "name": "",          "description": "The element to receive the aspect ratio. Should be a replaced element, such as `<img>`, `<iframe>`, or `<video>`."        }      ],      "cssCustomProperties": [],      "parts": [],      "dependencies": [],      "animations": []    },    {      "className": "SlSelect",      "tag": "sl-select",      "file": "src/components/select/select.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "clearable",          "description": "Adds a clear button when the select is populated.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "disabled",          "description": "Disables the select control.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "helpText",          "attribute": "help-text",          "description": "The select's help text. Alternatively, you can use the help-text slot.",          "type": "string"        },        {          "name": "hoist",          "description": "Enable this option to prevent the panel from being clipped when the component is placed inside a container with\n`overflow: auto|scroll`.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "invalid",          "description": "This will be true when the control is in an invalid state. Validity is determined by the `required` prop.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "label",          "description": "The select's label. Alternatively, you can use the label slot.",          "type": "string"        },        {          "name": "maxTagsVisible",          "attribute": "max-tags-visible",          "description": "The maximum number of tags to show when `multiple` is true. After the maximum, \"+n\" will be shown to indicate the\nnumber of additional items that are selected. Set to -1 to remove the limit.",          "type": "number",          "defaultValue": "3"        },        {          "name": "multiple",          "description": "Enables multiselect. With this enabled, value will be an array.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "name",          "description": "The select's name.",          "type": "string",          "defaultValue": "''"        },        {          "name": "pill",          "description": "Draws a pill-style select with rounded edges.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "placeholder",          "description": "The select's placeholder text.",          "type": "string",          "defaultValue": "''"        },        {          "name": "required",          "description": "The select's required attribute.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "size",          "description": "The select's size.",          "type": "'small' | 'medium' | 'large'",          "values": [            "small",            "medium",            "large"          ],          "defaultValue": "'medium'"        },        {          "name": "value",          "description": "The value of the control. This will be a string or an array depending on `multiple`.",          "type": "string | ",          "values": [            "string"          ],          "defaultValue": "''"        }      ],      "methods": [        {          "name": "reportValidity",          "description": "Checks for validity and shows the browser's validation message if the control is invalid.",          "params": []        },        {          "name": "setCustomValidity",          "description": "Sets a custom validation message. If `message` is not empty, the field will be considered invalid.",          "params": [            {              "name": "message",              "type": "string"            }          ]        }      ],      "events": [        {          "name": "sl-blur",          "description": "Emitted when the control loses focus.",          "details": "void"        },        {          "name": "sl-change",          "description": "Emitted when the control's value changes.",          "details": "void"        },        {          "name": "sl-clear",          "description": "Emitted when the clear button is activated.",          "details": "void"        },        {          "name": "sl-focus",          "description": "Emitted when the control gains focus.",          "details": "void"        }      ],      "slots": [        {          "name": "",          "description": "The select's options in the form of menu items."        },        {          "name": "label",          "description": "The select's label. Alternatively, you can use the label prop."        },        {          "name": "help-text",          "description": "Help text that describes how to use the select.\n"        }      ],      "cssCustomProperties": [        {          "name": "--focus-ring",          "description": "The focus ring style to use when the control receives focus, a `box-shadow` property.\n"        }      ],      "parts": [        {          "name": "base",          "description": "The component's base wrapper."        },        {          "name": "clear-button",          "description": "The input's clear button, exported from <sl-input>."        },        {          "name": "form-control",          "description": "The form control that wraps the label, input, and help text."        },        {          "name": "help-text",          "description": "The select's help text."        },        {          "name": "icon",          "description": "The select's icon."        },        {          "name": "label",          "description": "The select's label."        },        {          "name": "menu",          "description": "The select menu, a <sl-menu> element."        },        {          "name": "tag",          "description": "The multiselect option, a <sl-tag> element."        },        {          "name": "tags",          "description": "The container in which multiselect options are rendered.\n"        }      ],      "dependencies": [        "sl-dropdown",        "sl-icon",        "sl-icon-button",        "sl-menu",        "sl-tag"      ],      "animations": []    },    {      "className": "SlSkeleton",      "tag": "sl-skeleton",      "file": "src/components/skeleton/skeleton.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "effect",          "description": "Determines which effect the skeleton will use.",          "type": "'none' | 'pulse' | 'sheen'",          "values": [            "none",            "pulse",            "sheen"          ],          "defaultValue": "'sheen'"        }      ],      "methods": [],      "events": [],      "slots": [],      "cssCustomProperties": [        {          "name": "--border-radius",          "description": "The skeleton's border radius."        },        {          "name": "--color",          "description": "The color of the skeleton."        },        {          "name": "--sheen-color",          "description": "The sheen color when the skeleton is in its loading state.\n"        }      ],      "parts": [        {          "name": "base",          "description": "The component's base wrapper."        },        {          "name": "indicator",          "description": "The skeleton's indicator which is responsible for its color and animation.\n"        }      ],      "dependencies": [],      "animations": []    },    {      "className": "SlSpinner",      "tag": "sl-spinner",      "file": "src/components/spinner/spinner.ts",      "since": "2.0",      "status": "stable",      "props": [],      "methods": [],      "events": [],      "slots": [],      "cssCustomProperties": [        {          "name": "--track-color",          "description": "The color of the spinner's track."        },        {          "name": "--indicator-color",          "description": "The color of the spinner's indicator."        },        {          "name": "--stroke-width",          "description": "The width of the indicator.\n"        }      ],      "parts": [        {          "name": "base",          "description": "The component's base wrapper.\n"        }      ],      "dependencies": [],      "animations": []    },    {      "className": "SlSwitch",      "tag": "sl-switch",      "file": "src/components/switch/switch.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "checked",          "description": "Draws the switch in a checked state.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "disabled",          "description": "Disables the switch.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "invalid",          "description": "This will be true when the control is in an invalid state. Validity is determined by the `required` prop.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "name",          "description": "The switch's name attribute.",          "type": "string"        },        {          "name": "required",          "description": "Makes the switch a required field.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "value",          "description": "The switch's value attribute.",          "type": "string"        }      ],      "methods": [        {          "name": "blur",          "description": "Removes focus from the switch.",          "params": []        },        {          "name": "click",          "description": "Simulates a click on the switch.",          "params": []        },        {          "name": "focus",          "description": "Sets focus on the switch.",          "params": [            {              "name": "options",              "type": "FocusOptions",              "isOptional": true            }          ]        },        {          "name": "reportValidity",          "description": "Checks for validity and shows the browser's validation message if the control is invalid.",          "params": []        },        {          "name": "setCustomValidity",          "description": "Sets a custom validation message. If `message` is not empty, the field will be considered invalid.",          "params": [            {              "name": "message",              "type": "string"            }          ]        }      ],      "events": [        {          "name": "sl-blur",          "description": "Emitted when the control loses focus.",          "details": "void"        },        {          "name": "sl-change",          "description": "Emitted when the control's checked state changes.",          "details": "void"        },        {          "name": "sl-focus",          "description": "Emitted when the control gains focus.",          "details": "void"        }      ],      "slots": [        {          "name": "",          "description": "The switch's label."        }      ],      "cssCustomProperties": [        {          "name": "--width",          "description": "The width of the switch."        },        {          "name": "--height",          "description": "The height of the switch."        },        {          "name": "--thumb-size",          "description": "The size of the thumb.\n"        }      ],      "parts": [        {          "name": "base",          "description": "The component's base wrapper."        },        {          "name": "control",          "description": "The switch control."        },        {          "name": "thumb",          "description": "The switch position indicator."        },        {          "name": "label",          "description": "The switch label.\n"        }      ],      "dependencies": [],      "animations": []    },    {      "className": "SlTab",      "tag": "sl-tab",      "file": "src/components/tab/tab.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "active",          "description": "Draws the tab in an active state.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "closable",          "description": "Makes the tab closable and shows a close icon.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "disabled",          "description": "Draws the tab in a disabled state.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "panel",          "description": "The name of the tab panel the tab will control. The panel must be located in the same tab group.",          "type": "string",          "defaultValue": "''"        }      ],      "methods": [        {          "name": "blur",          "description": "Removes focus from the tab.",          "params": []        },        {          "name": "focus",          "description": "Sets focus to the tab.",          "params": [            {              "name": "options",              "type": "FocusOptions",              "isOptional": true            }          ]        }      ],      "events": [        {          "name": "sl-close",          "description": "Emitted when the tab is closable and the close button is activated.",          "details": "void"        }      ],      "slots": [        {          "name": "",          "description": "The tab's label."        }      ],      "cssCustomProperties": [        {          "name": "--focus-ring",          "description": "The focus ring's box shadow.\n"        }      ],      "parts": [        {          "name": "base",          "description": "The component's base wrapper."        },        {          "name": "close-button",          "description": "The close button, which is the icon button's base wrapper.\n"        }      ],      "dependencies": [        "sl-icon-button"      ],      "animations": []    },    {      "className": "SlTabGroup",      "tag": "sl-tab-group",      "file": "src/components/tab-group/tab-group.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "activation",          "description": "When set to auto, navigating tabs with the arrow keys will instantly show the corresponding tab panel. When set to\nmanual, the tab will receive focus but will not show until the user presses spacebar or enter.",          "type": "'auto' | 'manual'",          "values": [            "auto",            "manual"          ],          "defaultValue": "'auto'"        },        {          "name": "noScrollControls",          "attribute": "no-scroll-controls",          "description": "Disables the scroll arrows that appear when tabs overflow.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "placement",          "description": "The placement of the tabs.",          "type": "'top' | 'end' | 'bottom' | 'start'",          "values": [            "top",            "end",            "bottom",            "start"          ],          "defaultValue": "'top'"        }      ],      "methods": [        {          "name": "show",          "description": "Shows the specified tab panel.",          "params": [            {              "name": "panel",              "type": "string"            }          ]        }      ],      "events": [        {          "name": "sl-tab-hide",          "description": "Emitted when a tab is hidden.",          "details": "{ tab: string }"        },        {          "name": "sl-tab-show",          "description": "Emitted when a tab is shown.",          "details": "{ tab: string }"        }      ],      "slots": [        {          "name": "nav",          "description": "Used for grouping tabs in the tab group."        },        {          "name": "",          "description": "Used for grouping tab panels in the tab group."        }      ],      "cssCustomProperties": [        {          "name": "--tabs-border-color",          "description": "The color of the border that separates tabs.\n"        }      ],      "parts": [        {          "name": "base",          "description": "The component's base wrapper."        },        {          "name": "nav",          "description": "The tab group navigation container."        },        {          "name": "tabs",          "description": "The container that wraps the slotted tabs."        },        {          "name": "active-tab-indicator",          "description": "An element that displays the currently selected tab. This is a child of the tabs container."        },        {          "name": "body",          "description": "The tab group body where tab panels are slotted in."        },        {          "name": "scroll-button",          "description": "The previous and next scroll buttons that appear when tabs are scrollable.\n"        }      ],      "dependencies": [        "sl-icon-button"      ],      "animations": []    },    {      "className": "SlTabPanel",      "tag": "sl-tab-panel",      "file": "src/components/tab-panel/tab-panel.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "active",          "description": "When true, the tab panel will be shown.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "name",          "description": "The tab panel's name.",          "type": "string",          "defaultValue": "''"        }      ],      "methods": [],      "events": [],      "slots": [        {          "name": "",          "description": "The tab panel's content."        }      ],      "cssCustomProperties": [],      "parts": [        {          "name": "base",          "description": "The component's base wrapper.\n"        }      ],      "dependencies": [],      "animations": []    },    {      "className": "SlTag",      "tag": "sl-tag",      "file": "src/components/tag/tag.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "clearable",          "description": "Makes the tag clearable.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "pill",          "description": "Draws a pill-style tag with rounded edges.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "size",          "description": "The tag's size.",          "type": "'small' | 'medium' | 'large'",          "values": [            "small",            "medium",            "large"          ],          "defaultValue": "'medium'"        },        {          "name": "type",          "description": "The tag's type.",          "type": "'primary' | 'success' | 'info' | 'warning' | 'danger' | 'text'",          "values": [            "primary",            "success",            "info",            "warning",            "danger",            "text"          ],          "defaultValue": "'primary'"        }      ],      "methods": [],      "events": [        {          "name": "sl-clear",          "description": "Emitted when the clear button is activated.",          "details": "void"        }      ],      "slots": [        {          "name": "",          "description": "The tag's content."        }      ],      "cssCustomProperties": [],      "parts": [        {          "name": "base",          "description": "The component's base wrapper."        },        {          "name": "content",          "description": "The tag content."        },        {          "name": "clear-button",          "description": "The clear button.\n"        }      ],      "dependencies": [        "sl-icon-button"      ],      "animations": []    },    {      "className": "SlTextarea",      "tag": "sl-textarea",      "file": "src/components/textarea/textarea.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "autocapitalize",          "description": "The textarea's autocaptialize attribute.",          "type": "'none' | 'off' | 'on' | 'sentences' | 'words' | 'characters'",          "values": [            "none",            "off",            "on",            "sentences",            "words",            "characters"          ]        },        {          "name": "autocomplete",          "description": "The textarea's autocomplete attribute.",          "type": "string"        },        {          "name": "autocorrect",          "description": "The textarea's autocorrect attribute.",          "type": "string"        },        {          "name": "autofocus",          "description": "The textarea's autofocus attribute.",          "type": "boolean"        },        {          "name": "disabled",          "description": "Disables the textarea.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "helpText",          "attribute": "help-text",          "description": "The textarea's help text. Alternatively, you can use the help-text slot.",          "type": "string",          "defaultValue": "''"        },        {          "name": "inputmode",          "description": "The textarea's inputmode attribute.",          "type": "'none' | 'text' | 'numeric' | 'decimal' | 'email' | 'search' | 'tel' | 'url'",          "values": [            "none",            "text",            "numeric",            "decimal",            "email",            "search",            "tel",            "url"          ]        },        {          "name": "invalid",          "description": "This will be true when the control is in an invalid state. Validity is determined by props such as `type`,\n`required`, `minlength`, and `maxlength` using the browser's constraint validation API.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "label",          "description": "The textarea's label. Alternatively, you can use the label slot.",          "type": "string"        },        {          "name": "maxlength",          "description": "The maximum length of input that will be considered valid.",          "type": "number"        },        {          "name": "minlength",          "description": "The minimum length of input that will be considered valid.",          "type": "number"        },        {          "name": "name",          "description": "The textarea's name attribute.",          "type": "string"        },        {          "name": "pattern",          "description": "A pattern to validate input against.",          "type": "string"        },        {          "name": "placeholder",          "description": "The textarea's placeholder text.",          "type": "string"        },        {          "name": "readonly",          "description": "Makes the textarea readonly.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "required",          "description": "Makes the textarea a required field.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "resize",          "description": "Controls how the textarea can be resized.",          "type": "'none' | 'auto' | 'vertical'",          "values": [            "none",            "auto",            "vertical"          ],          "defaultValue": "'vertical'"        },        {          "name": "rows",          "description": "The number of rows to display by default.",          "type": "number",          "defaultValue": "4"        },        {          "name": "size",          "description": "The textarea's size.",          "type": "'small' | 'medium' | 'large'",          "values": [            "small",            "medium",            "large"          ],          "defaultValue": "'medium'"        },        {          "name": "spellcheck",          "description": "Enables spell checking on the textarea.",          "type": "boolean"        },        {          "name": "value",          "description": "The textarea's value attribute.",          "type": "string",          "defaultValue": "''"        }      ],      "methods": [        {          "name": "blur",          "description": "Removes focus from the textarea.",          "params": []        },        {          "name": "focus",          "description": "Sets focus on the textarea.",          "params": [            {              "name": "options",              "type": "FocusOptions",              "isOptional": true            }          ]        },        {          "name": "reportValidity",          "description": "Checks for validity and shows the browser's validation message if the control is invalid.",          "params": []        },        {          "name": "scrollPosition",          "description": "Gets or sets the textarea's scroll position.",          "params": [            {              "name": "position",              "type": "{ left?: number, top?: number }",              "isOptional": true            }          ]        },        {          "name": "select",          "description": "Selects all the text in the textarea.",          "params": []        },        {          "name": "setCustomValidity",          "description": "Sets a custom validation message. If `message` is not empty, the field will be considered invalid.",          "params": [            {              "name": "message",              "type": "string"            }          ]        },        {          "name": "setRangeText",          "description": "Replaces a range of text with a new string.",          "params": [            {              "name": "replacement",              "type": "string"            },            {              "name": "start",              "type": "number"            },            {              "name": "end",              "type": "number"            },            {              "name": "selectMode",              "type": "'end' | 'start' | 'select' | 'preserve'",              "values": [                "end",                "start",                "select",                "preserve"              ],              "defaultValue": "'preserve'"            }          ]        },        {          "name": "setSelectionRange",          "description": "Sets the start and end positions of the text selection (0-based).",          "params": [            {              "name": "selectionStart",              "type": "number"            },            {              "name": "selectionEnd",              "type": "number"            },            {              "name": "selectionDirection",              "type": "'none' | 'forward' | 'backward'",              "values": [                "none",                "forward",                "backward"              ],              "defaultValue": "'none'"            }          ]        }      ],      "events": [        {          "name": "sl-blur",          "description": "Emitted when the control loses focus.",          "details": "void"        },        {          "name": "sl-change",          "description": "Emitted when the control's value changes.",          "details": "void"        },        {          "name": "sl-focus",          "description": "Emitted when the control gains focus.",          "details": "void"        },        {          "name": "sl-input",          "description": "Emitted when the control receives input.",          "details": "void"        }      ],      "slots": [        {          "name": "label",          "description": "The textarea's label. Alternatively, you can use the label prop."        },        {          "name": "help-text",          "description": "Help text that describes how to use the input.\n"        }      ],      "cssCustomProperties": [],      "parts": [        {          "name": "base",          "description": "The component's base wrapper."        },        {          "name": "form-control",          "description": "The form control that wraps the label, textarea, and help text."        },        {          "name": "label",          "description": "The textarea label."        },        {          "name": "textarea",          "description": "The textarea control."        },        {          "name": "help-text",          "description": "The textarea help text.\n"        }      ],      "dependencies": [],      "animations": []    },    {      "className": "SlTooltip",      "tag": "sl-tooltip",      "file": "src/components/tooltip/tooltip.ts",      "since": "2.0",      "status": "stable",      "props": [        {          "name": "content",          "description": "The tooltip's content. Alternatively, you can use the content slot.",          "type": "string",          "defaultValue": "''"        },        {          "name": "disabled",          "description": "Disables the tooltip so it won't show when triggered.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "distance",          "description": "The distance in pixels from which to offset the tooltip away from its target.",          "type": "number",          "defaultValue": "10"        },        {          "name": "open",          "description": "Indicates whether or not the tooltip is open. You can use this in lieu of the show/hide methods.",          "type": "boolean",          "defaultValue": "false"        },        {          "name": "placement",          "description": "The preferred placement of the tooltip. Note that the actual placement may vary as needed to keep the tooltip\ninside of the viewport.",          "type": "'top' | 'bottom' | 'top-start' | 'top-end' | 'bottom-start' | 'bottom-end' | 'right' | 'right-start' | 'right-end' | 'left' | 'left-start' | 'left-end'",          "values": [            "top",            "bottom",            "top-start",            "top-end",            "bottom-start",            "bottom-end",            "right",            "right-start",            "right-end",            "left",            "left-start",            "left-end"          ],          "defaultValue": "'top'"        },        {          "name": "skidding",          "description": "The distance in pixels from which to offset the tooltip along its target.",          "type": "number",          "defaultValue": "0"        },        {          "name": "trigger",          "description": "Controls how the tooltip is activated. Possible options include `click`, `hover`, `focus`, and `manual`. Multiple\noptions can be passed by separating them with a space. When manual is used, the tooltip must be activated\nprogrammatically.",          "type": "string",          "defaultValue": "'hover focus'"        }      ],      "methods": [        {          "name": "hide",          "description": "Hides the tooltip",          "params": []        },        {          "name": "show",          "description": "Shows the tooltip.",          "params": []        }      ],      "events": [        {          "name": "sl-after-hide",          "description": "Emitted after the tooltip has hidden and all transitions are complete.",          "details": "void"        },        {          "name": "sl-after-show",          "description": "Emitted after the tooltip has shown and all transitions are complete.",          "details": "void"        },        {          "name": "sl-hide",          "description": "Emitted when the tooltip begins to hide.",          "details": "void"        },        {          "name": "sl-show",          "description": "Emitted when the tooltip begins to show.",          "details": "void"        }      ],      "slots": [        {          "name": "",          "description": "The tooltip's target element. Only the first element will be used as the target."        },        {          "name": "content",          "description": "The tooltip's content. Alternatively, you can use the content prop.\n"        }      ],      "cssCustomProperties": [        {          "name": "--max-width",          "description": "The maximum width of the tooltip."        },        {          "name": "--hide-delay",          "description": "The amount of time to wait before hiding the tooltip when hovering."        },        {          "name": "--show-delay",          "description": "The amount of time to wait before showing the tooltip when hovering.\n"        }      ],      "parts": [        {          "name": "base",          "description": "The component's base wrapper.\n"        }      ],      "dependencies": [],      "animations": [        {          "name": "tooltip.show",          "description": "The animation to use when showing the tooltip."        },        {          "name": "tooltip.hide",          "description": "The animation to use when hiding the tooltip.\n"        }      ]    }  ]}
 |