UNPKG

@public-ui/components

Version:

Contains all web components that belong to KoliBri - The accessible HTML-Standard.

4 lines 8.08 kB
/*! * KoliBri - The accessible HTML-Standard */ import{r as i,h as t,H as s,g as a}from"./index-1ed13705.js";import{w as e,B as n,I as d,D as h,m as o}from"./index-ebe5a881.js";import{o as l}from"./ariaCurrentService-6fe36ebc.js";import{d as r,K as f}from"./events-bad0a075.js";import{n as c}from"./dev.utils-cb61837d.js";import{a as u,e as b}from"./component-names-7924d82a.js";import{t as v}from"./i18n-260f0fe9.js";import{v as p,a as m,b as k,c as _}from"./access-and-short-key-f743a5c4.js";import{c as j}from"./clsx-09a06a12.js";import"./bem-e4c3a2e6.js";import{K as g}from"./Span-d15a3ea1.js";import{v as y}from"./href-d9ccbbdf.js";import{v as x,a as A,b as w,c as C,d as V}from"./link-variant-47605ebe.js";import{v as K}from"./custom-class-d73b81b1.js";import{v as L}from"./disabled-e1038f54.js";import{v as O}from"./hide-label-8b3a8709.js";import{v as I}from"./icons-a9c52ed8.js";import{a as T}from"./label-bf9966d0.js";import{v as D}from"./tooltip-align-465a8590.js";import"./i18n-45224cc3.js";import"./browser-f629a56a.js";import"./tslib.es6-1173d062.js";import"./Icon-446dff9e.js";import"./markdown-f827f2ac.js";import"./InternalUnderlinedBadgeText-781ef373.js";import"./isArray-7a60fa7f.js";import"./isObject-ffcbbb76.js";import"./align-d2572387.js";const S=["date","location","page","step","time","true","false"],$=(t,a)=>{e(t,"_ariaCurrentValue",(t=>"string"==typeof t&&S.includes(t)),new Set([`AriaCurrentValue {${S.join(", ")}`]),a,{defaultValue:"page"})},B=(t,a)=>{n(t,"_ariaOwns",a,{defaultValue:void 0})},E=(t,a)=>{n(t,"_download",a)},H=(t,a)=>{"object"==typeof a&&"function"==typeof(null==a?void 0:a.onClick)&&(t.state=Object.assign(Object.assign({},t.state),{_on:a}))},R=(t,a)=>{n(t,"_target",a)},q=class{constructor(t){i(this,t),this.internalDescriptionById=c(),this.catchRef=t=>{this.anchorRef=t},this.onClick=t=>{var a,i;!0===this.state._disabled?t.preventDefault():("function"==typeof(null===(a=this.state._on)||void 0===a?void 0:a.onClick)&&(t.preventDefault(),d(t,this.anchorRef),null===(i=this.state._on)||void 0===i||i.onClick(t,this.state._href)),this.host&&r(this.host,f.click,this.state._href))},this.getRenderValues=()=>{const t="string"==typeof this.state._target&&"_self"!==this.state._target,a={href:"string"==typeof this.state._href&&this.state._href.length>0?this.state._href:"javascript:void(0);",target:"string"==typeof this.state._target&&this.state._target.length>0?this.state._target:void 0,rel:t?"noopener":void 0,download:"string"==typeof this.state._download?this.state._download:void 0};return!0!==this.state._hideLabel||this.state._label||h("[KolLink] An aria-label must be set when _hide-label is set."),{isExternal:t,tagAttrs:a}},this._accessKey=void 0,this._ariaCurrentValue=void 0,this._ariaDescription=void 0,this._ariaExpanded=void 0,this._ariaOwns=void 0,this._customClass=void 0,this._disabled=!1,this._download=void 0,this._hideLabel=!1,this._href=void 0,this._icons=void 0,this._label=void 0,this._linkVariant=void 0,this._on=void 0,this._role=void 0,this._shortKey=void 0,this._tabIndex=void 0,this._target=void 0,this._tooltipAlign="right",this._buttonVariant="normal",this.state={_ariaCurrentValue:"page",_href:"",_icons:{}}}async kolFocus(){var t;null===(t=this.anchorRef)||void 0===t||t.focus()}render(){var a,i;const{isExternal:e,tagAttrs:l}=this.getRenderValues(),r=o(this.state._label),n=Boolean(null===(i=null===(a=this.state._ariaDescription)||void 0===a?void 0:a.trim())||void 0===i?void 0:i.length);return t(s,{key:"f4b7614d0e2338f6788664a4d2af3b7f8596446a"},t("a",Object.assign({key:"cf573cd4f7ace42825ff86906c9d2bfb00d3d675",ref:this.catchRef},l,{accessKey:this.state._accessKey,"aria-current":this.state._ariaCurrent,"aria-describedby":n?this.internalDescriptionById:void 0,"aria-disabled":this.state._disabled?"true":void 0,"aria-expanded":"boolean"==typeof this.state._ariaExpanded?String(this.state._ariaExpanded):void 0,"aria-owns":this.state._ariaOwns,"aria-label":this.state._hideLabel&&"string"==typeof this.state._label?`${this.state._label}${e?` (${v("kol-open-link-in-tab")})`:""}`:void 0,class:j("kol-link",{"kol-link--disabled":!0===this.state._disabled,"kol-link--external-link":e,"kol-link--hide-label":!0===this.state._hideLabel,[`kol-link--${this.state._buttonVariant}`]:"button"===this.state._role&&"custom"!==this.state._buttonVariant,[`kol-link--${this.state._linkVariant}`]:this.state._linkVariant,[this.state._customClass]:"custom"===this.state._buttonVariant&&"string"==typeof this.state._customClass&&this.state._customClass.length>0})},this.state._on,{onClick:this.onClick,onKeyPress:this.onClick,role:this.state._role,tabIndex:this.state._disabled?-1:this.state._tabIndex}),t(g,{key:"6843964d8916e46baba9fa60f9595a5110f56b3a",class:"kol-link__text",badgeText:this.state._accessKey||this.state._shortKey,icons:this.state._icons,hideLabel:this.state._hideLabel,label:r?"":this.state._label||this.state._href},t("slot",{key:"0bda74f7546d38397f925f6fd3d4ac26ca1493fd",name:"expert",slot:"expert"})),e&&t(b,{key:"a6c6a408eda2c2366de194b9c5e59d7e41fe1ab3",class:"kol-link__icon",_label:this.state._hideLabel?"":v("kol-open-link-in-tab"),_icons:"codicon codicon-link-external","aria-hidden":this.state._hideLabel})),t(u,{key:"a54e006832ffc7c4bcd92b17b7c4c28819211319","aria-hidden":"true",class:"kol-link__tooltip",hidden:r||!this.state._hideLabel,_badgeText:this.state._accessKey||this.state._shortKey,_align:this.state._tooltipAlign,_label:this.state._label||this.state._href}),n&&t("span",{key:"e2faae829a690eff8740fc24263f86ab840016ce",class:"visually-hidden",id:this.internalDescriptionById},this.state._ariaDescription))}validateAccessKey(t){p(this,t),m(t,this._shortKey)}validateAriaCurrentValue(t){$(this,t)}validateAriaDescription(t){x(this,t)}validateAriaExpanded(t){A(this,t)}validateAriaOwns(t){B(this,t)}validateCustomClass(t){K(this,t)}validateDisabled(t){L(this,t)}validateDownload(t){E(this,t)}validateHideLabel(t){O(this,t)}validateHref(t){y(this,t,{required:!0})}validateIcons(t){I(this,t)}validateLabel(t){T(this,t)}validateLinkVariant(t){w(this,t)}validateOn(t){H(this,t)}validateRole(t){C(this,t)}validateShortKey(t){k(this,t),m(this._accessKey,t)}validateTabIndex(t){_(this,t)}validateTarget(t){R(this,t)}validateTooltipAlign(t){D(this,t)}validateButtonVariant(t){V(this,t)}componentWillLoad(){this.validateAccessKey(this._accessKey),this.validateAriaCurrentValue(this._ariaCurrentValue),this.validateAriaDescription(this._ariaDescription),this.validateAriaExpanded(this._ariaExpanded),this.validateAriaOwns(this._ariaOwns),this.validateCustomClass(this._customClass),this.validateDisabled(this._disabled),this.validateDownload(this._download),this.validateHideLabel(this._hideLabel),this.validateHref(this._href),this.validateIcons(this._icons),this.validateLabel(this._label),this.validateLinkVariant(this._linkVariant),this.validateOn(this._on),this.validateRole(this._role),this.validateShortKey(this._shortKey),this.validateTabIndex(this._tabIndex),this.validateTarget(this._target),this.validateTooltipAlign(this._tooltipAlign),this.validateButtonVariant(this._buttonVariant),this.unsubscribeOnLocationChange=l((t=>{this.state._ariaCurrent=t===this.state._href?this.state._ariaCurrentValue:void 0})),m(this._accessKey,this._shortKey)}disconnectedCallback(){this.unsubscribeOnLocationChange&&this.unsubscribeOnLocationChange()}get host(){return a(this)}static get watchers(){return{_accessKey:["validateAccessKey"],_ariaCurrentValue:["validateAriaCurrentValue"],_ariaDescription:["validateAriaDescription"],_ariaExpanded:["validateAriaExpanded"],_ariaOwns:["validateAriaOwns"],_customClass:["validateCustomClass"],_disabled:["validateDisabled"],_download:["validateDownload"],_hideLabel:["validateHideLabel"],_href:["validateHref"],_icons:["validateIcons"],_label:["validateLabel"],_linkVariant:["validateLinkVariant"],_on:["validateOn"],_role:["validateRole"],_shortKey:["validateShortKey"],_tabIndex:["validateTabIndex"],_target:["validateTarget"],_tooltipAlign:["validateTooltipAlign"],_buttonVariant:["validateButtonVariant"]}}};export{q as kol_link_wc};