@scalar/api-reference
Version:
Generate beautiful API references from OpenAPI documents
40 lines (39 loc) • 2.03 kB
JavaScript
import ScreenReader_default from "../ScreenReader.vue.js";
import { createElementBlock, createElementVNode, createTextVNode, createVNode, defineComponent, guardReactiveProps, normalizeProps, openBlock, renderSlot, unref, useId, withCtx, withModifiers } from "vue";
import { ScalarButton, useBindCx } from "@scalar/components";
import { ScalarIconHash } from "@scalar/icons";
//#region src/components/Anchor/Anchor.vue?vue&type=script&setup=true&lang.ts
var _hoisted_1 = ["id"];
var _hoisted_2 = { class: "relative" };
var Anchor_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
__name: "Anchor",
emits: ["copyAnchorUrl"],
setup(__props, { emit: __emit }) {
const emit = __emit;
const labelId = useId();
const { cx } = useBindCx();
return (_ctx, _cache) => {
return openBlock(), createElementBlock("span", normalizeProps(guardReactiveProps(unref(cx)("group/heading wrap-break-word relative"))), [createElementVNode("span", {
id: unref(labelId),
class: "contents"
}, [renderSlot(_ctx.$slots, "default")], 8, _hoisted_1), createElementVNode("span", _hoisted_2, [_cache[2] || (_cache[2] = createElementVNode("span", null, "", -1)), createVNode(unref(ScalarButton), {
"aria-describedby": unref(labelId),
class: "absolute top-1/2 left-0 inline-block h-fit -translate-y-1/2 px-1.5 py-1 opacity-0 group-hover/heading:opacity-100 group-has-focus-visible/heading:opacity-100",
variant: "ghost",
onClick: _cache[0] || (_cache[0] = withModifiers(() => emit("copyAnchorUrl"), ["stop"]))
}, {
default: withCtx(() => [createVNode(unref(ScalarIconHash), {
"aria-hidden": "true",
class: "size-4.5"
}), createVNode(ScreenReader_default, null, {
default: withCtx(() => [..._cache[1] || (_cache[1] = [createTextVNode("Copy link", -1)])]),
_: 1
})]),
_: 1
}, 8, ["aria-describedby"])])], 16);
};
}
});
//#endregion
export { Anchor_vue_vue_type_script_setup_true_lang_default as default };
//# sourceMappingURL=Anchor.vue.script.js.map