@diplodoc/transform 4.70.4 → 4.72.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (44) hide show
  1. package/dist/css/_yfm-only.css +4 -4
  2. package/dist/css/_yfm-only.css.map +3 -3
  3. package/dist/css/_yfm-only.min.css +1 -1
  4. package/dist/css/_yfm-only.min.css.map +3 -3
  5. package/dist/css/base.css.map +1 -1
  6. package/dist/css/base.min.css.map +1 -1
  7. package/dist/css/print.css.map +1 -1
  8. package/dist/css/yfm.css +4 -4
  9. package/dist/css/yfm.css.map +3 -3
  10. package/dist/css/yfm.min.css +1 -1
  11. package/dist/css/yfm.min.css.map +3 -3
  12. package/dist/js/base.js +396 -215
  13. package/dist/js/base.js.map +4 -4
  14. package/dist/js/base.min.js +1 -6
  15. package/dist/js/base.min.js.map +4 -4
  16. package/dist/js/yfm.js +429 -228
  17. package/dist/js/yfm.js.map +4 -4
  18. package/dist/js/yfm.min.js +1 -6
  19. package/dist/js/yfm.min.js.map +4 -4
  20. package/dist/scss/{_inline-code.scss → _tooltip.scss} +1 -1
  21. package/dist/scss/_yfm-only.scss +1 -1
  22. package/lib/plugins/anchors/index.js +1 -1
  23. package/lib/plugins/anchors/index.js.map +1 -1
  24. package/lib/plugins/images/index.js +7 -0
  25. package/lib/plugins/images/index.js.map +1 -1
  26. package/lib/plugins/term/termDefinitions.js +54 -27
  27. package/lib/plugins/term/termDefinitions.js.map +1 -1
  28. package/lib/typings.d.ts +10 -0
  29. package/package.json +2 -2
  30. package/src/js/anchor.ts +27 -3
  31. package/src/js/{inline-code/constant.ts → constant.ts} +1 -9
  32. package/src/js/inline-code/index.ts +24 -42
  33. package/src/js/tooltip/constant.ts +25 -0
  34. package/src/js/tooltip/index.ts +2 -0
  35. package/src/js/tooltip/tooltip.ts +263 -0
  36. package/src/js/tooltip/types.ts +59 -0
  37. package/src/js/tooltip/utils.ts +247 -0
  38. package/src/scss/{_inline-code.scss → _tooltip.scss} +1 -1
  39. package/src/scss/_yfm-only.scss +1 -1
  40. package/src/transform/plugins/anchors/index.ts +1 -1
  41. package/src/transform/plugins/images/index.ts +8 -0
  42. package/src/transform/plugins/term/termDefinitions.ts +71 -33
  43. package/src/transform/typings.ts +10 -0
  44. package/src/js/inline-code/utils.ts +0 -217
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
- "sources": ["../../node_modules/get-root-node-polyfill/index.js", "../../src/js/polyfill.js", "../../src/js/utils.ts", "../../src/js/code.ts", "../../src/js/anchor.ts", "../../src/js/inline-code/constant.ts", "../../src/js/term/utils.ts", "../../src/js/inline-code/utils.ts", "../../src/js/inline-code/index.ts"],
4
- "sourcesContent": ["'use strict';\n\n// Node getRootNode(optional GetRootNodeOptions options);\n\n/**\n * Returns the context object\u2019s shadow-including root if options\u2019s composed is true.\n * Returns the context object\u2019s root otherwise.\n *\n * The root of an object is itself, if its parent is null, or else it is the root of its parent.\n *\n * The shadow-including root of an object is its root\u2019s host\u2019s shadow-including root,\n * if the object\u2019s root is a shadow root, and its root otherwise.\n *\n * https://dom.spec.whatwg.org/#dom-node-getrootnode\n *\n * @memberof Node.prototype\n * @param {!Object} [opt = {}] - Options.\n * @param {!boolean} [opt.composed] - See above description.\n * @returns {!Node} The root node.\n */\nfunction getRootNode(opt) {\n var composed = typeof opt === 'object' && Boolean(opt.composed);\n\n return composed ? getShadowIncludingRoot(this) : getRoot(this);\n}\n\nfunction getShadowIncludingRoot(node) {\n var root = getRoot(node);\n\n if (isShadowRoot(root)) {\n return getShadowIncludingRoot(root.host);\n }\n\n return root;\n}\n\nfunction getRoot(node) {\n if (node.parentNode != null) {\n return getRoot(node.parentNode);\n }\n\n return node;\n}\n\nfunction isShadowRoot(node) {\n return node.nodeName === '#document-fragment' && node.constructor.name === 'ShadowRoot';\n}\n\nif (typeof module === 'object' && module.exports) {\n module.exports = getRootNode;\n}\n", "import getRootNode from 'get-root-node-polyfill';\n\nif (typeof document !== 'undefined') {\n // matches polyfill for old edge\n (function (e) {\n const matches =\n e.matches ||\n e.matchesSelector ||\n e.webkitMatchesSelector ||\n e.mozMatchesSelector ||\n e.msMatchesSelector ||\n e.oMatchesSelector;\n\n if (matches) {\n e.matches = e.matchesSelector = matches;\n } else {\n e.matches = e.matchesSelector = function matches(selector) {\n const rootNode = e.getRootNode ? e.getRootNode() : getRootNode.call(e);\n const matches = rootNode.querySelectorAll(selector);\n const th = this;\n return Array.prototype.some.call(matches, (e) => {\n return e === th;\n });\n };\n }\n // eslint-disable-next-line no-undef\n })(Element.prototype);\n}\n", "export const getEventTarget = (event: Event) => {\n const path = event.composedPath();\n return Array.isArray(path) && path.length > 0 ? path[0] : event.target;\n};\n\nexport const isCustom = (event: Event) => {\n const target = getEventTarget(event);\n return !target || !(target as HTMLElement).matches;\n};\n\nexport const copyToClipboard = async (text: string) => {\n if (!text) {\n return;\n }\n\n if (navigator.clipboard && typeof navigator.clipboard.writeText) {\n return navigator.clipboard.writeText(text);\n }\n\n const textarea = document.createElement('textarea');\n textarea.setAttribute('style', 'position: absolute; left: 1000%');\n textarea.textContent = text;\n document.body.append(textarea);\n\n textarea.select();\n document.execCommand('copy');\n\n document.body.removeChild(textarea);\n};\n", "import {copyToClipboard, getEventTarget, isCustom} from './utils';\n\nconst COPY_BUTTON_SELECTOR = '.yfm-clipboard-button';\nconst WRAP_BUTTON_SELECTOR = '.yfm-wrapping-button';\n\nfunction notifySuccess(svgButton: HTMLElement | null) {\n if (!svgButton) {\n return;\n }\n\n const id = svgButton.getAttribute('data-animation');\n\n // @ts-expect-error\n const icon = svgButton.getRootNode().getElementById(`visibileAnimation-${id}`);\n\n if (!icon) {\n return;\n }\n\n icon.beginElement();\n}\n\nfunction buttonCopyFn(target: HTMLElement) {\n const container = target.parentNode?.parentNode;\n const code = container?.querySelector<HTMLElement>('pre code');\n if (!container || !code) {\n return;\n }\n\n // Get all text nodes and filter out line numbers\n const textContent = Array.from(code.childNodes)\n .filter((node) => {\n // Skip line number spans\n if (node instanceof HTMLElement && node.classList.contains('yfm-line-number')) {\n return false;\n }\n return true;\n })\n .map((node) => node.textContent)\n .join('');\n\n copyToClipboard(textContent.trim()).then(() => {\n notifySuccess(container.querySelector('.yfm-clipboard-icon'));\n\n setTimeout(() => target.blur(), 1500);\n });\n}\n\nfunction buttonWrapFn(target: HTMLElement) {\n const container = target.parentNode?.parentNode;\n const code = container?.querySelector<HTMLElement>('pre code');\n if (!container || !code) {\n return;\n }\n\n code.classList.toggle('wrap');\n\n setTimeout(() => target.blur(), 500);\n}\n\nif (typeof document !== 'undefined') {\n document.addEventListener('click', (event) => {\n if (isCustom(event)) {\n return;\n }\n\n const target = getEventTarget(event) as HTMLElement;\n\n if (target.matches(COPY_BUTTON_SELECTOR)) {\n buttonCopyFn(target);\n } else if (target.matches(WRAP_BUTTON_SELECTOR)) {\n buttonWrapFn(target);\n }\n });\n}\n", "import {copyToClipboard, getEventTarget, isCustom} from './utils';\n\nconst ANCHOR_BUTTON_SELECTOR = '.yfm-clipboard-anchor';\n\nif (typeof document !== 'undefined') {\n document.addEventListener('click', (event) => {\n const target = getEventTarget(event) as HTMLElement;\n\n if (isCustom(event) || !target.matches(ANCHOR_BUTTON_SELECTOR)) {\n return;\n }\n\n const href = target.getAttribute('data-href') || '';\n const link = new URL(href, window.location.href).toString();\n\n copyToClipboard(link);\n });\n}\n", "import type {Lang} from 'src/transform/typings';\n\nexport const INLINE_CODE = '.yfm-clipboard-inline-code';\n\nexport const INLINE_CODE_ID = 'tooltip_inline_clipboard_dialog';\n\nexport const INLINE_CODE_CLASS = 'yfm inline_code_tooltip';\n\nexport const OPEN_CLASS = 'open';\n\nexport const LANG_TOKEN: Record<Lang, string> = {\n ru: '\u0421\u043A\u043E\u043F\u0438\u0440\u043E\u0432\u0430\u043D\u043E',\n en: 'Copied',\n ar: '\u062A\u0645 \u0627\u0644\u0646\u0633\u062E',\n cs: 'Zkop\u00EDrov\u00E1no',\n fr: 'Copi\u00E9',\n es: 'Copiado',\n he: '\u05D4\u05D5\u05E2\u05EA\u05E7',\n bg: '\u041A\u043E\u043F\u0438\u0440\u0430\u043D\u043E',\n et: 'Kopeeritud',\n el: '\u0391\u03BD\u03C4\u03B9\u03B3\u03C1\u03AC\u03C6\u03B7\u03BA\u03B5',\n pt: 'Copiado',\n zh: '\u5DF2\u590D\u5236',\n 'zh-tw': '\u5DF2\u8907\u88FD',\n kk: '\u041A\u04E9\u0448\u0456\u0440\u0456\u043B\u0434\u0456',\n tr: 'Kopyaland\u0131',\n uz: 'Nusxalandi',\n};\n", "export const Selector = {\n TITLE: '.yfm .yfm-term_title',\n CONTENT: '.yfm .yfm-term_dfn',\n};\nexport const openClass = 'open';\nexport const openDefinitionClass = Selector.CONTENT.replace(/\\./g, '') + ' ' + openClass;\nlet isListenerNeeded = true;\n\nexport function setDefinitionId(definitionElement: HTMLElement, termElement: HTMLElement): void {\n const termId = termElement.getAttribute('id') || Math.random().toString(36).substr(2, 8);\n definitionElement?.setAttribute('term-id', termId);\n}\n\nexport function setDefinitonAriaAttributes(\n definitionElement: HTMLElement,\n termElement: HTMLElement,\n): void {\n const ariaLive = termElement.getAttribute('aria-live') || 'polite';\n definitionElement?.setAttribute('aria-live', ariaLive);\n definitionElement?.setAttribute('aria-modal', 'true');\n}\n\nexport function setDefinitionPosition(\n definitionElement: HTMLElement,\n termElement: HTMLElement,\n): void {\n const {\n x: termX,\n y: termY,\n right: termRight,\n left: termLeft,\n width: termWidth,\n height: termHeight,\n } = termElement.getBoundingClientRect();\n\n const termParent = termParentElement(termElement);\n\n if (!termParent) {\n return;\n }\n\n const {right: termParentRight, left: termParentLeft} = termParent.getBoundingClientRect();\n\n if ((termParentRight < termLeft || termParentLeft > termRight) && !isListenerNeeded) {\n closeDefinition(definitionElement);\n return;\n }\n\n if (isListenerNeeded && termParent) {\n termParent.addEventListener('scroll', termOnResize);\n isListenerNeeded = false;\n }\n\n const relativeX = Number(definitionElement.getAttribute('relativeX'));\n const relativeY = Number(definitionElement.getAttribute('relativeY'));\n\n if (relativeX === termX && relativeY === termY) {\n return;\n }\n\n definitionElement.setAttribute('relativeX', String(termX));\n definitionElement.setAttribute('relativeY', String(termY));\n\n const offsetTop = termHeight + 5;\n const definitionParent = definitionElement.parentElement;\n\n if (!definitionParent) {\n return;\n }\n\n const {width: definitionWidth} = definitionElement.getBoundingClientRect();\n const {left: definitionParentLeft} = definitionParent.getBoundingClientRect();\n\n // If definition not fit document change base alignment\n const definitionLeftCoordinate = Number(getCoords(termElement).left);\n const definitionRightCoordinate = definitionWidth + definitionLeftCoordinate;\n\n const definitionOutOfScreenOnLeft = definitionLeftCoordinate - definitionWidth < 0;\n const definitionOutOfScreenOnRight = definitionRightCoordinate > document.body.clientWidth;\n\n const isAlignSwapped = definitionOutOfScreenOnRight || document.dir === 'rtl';\n const fitDefinitionDocument =\n isAlignSwapped && !definitionOutOfScreenOnLeft ? definitionWidth - termWidth : 0;\n const customHeaderTop = getCoords(definitionParent).top - definitionParent.offsetTop;\n const offsetRight = 5;\n const shiftLeft = definitionOutOfScreenOnRight\n ? definitionRightCoordinate - document.body.clientWidth + offsetRight\n : 0;\n const offsetLeft =\n getCoords(termElement).left -\n definitionParentLeft +\n definitionParent.offsetLeft -\n fitDefinitionDocument;\n\n const isShiftLeftNeeded = offsetLeft + definitionWidth >= document.body.clientWidth;\n\n definitionElement.style.top =\n Number(getCoords(termElement).top + offsetTop - customHeaderTop) + 'px';\n definitionElement.style.left = Number(offsetLeft - (isShiftLeftNeeded ? shiftLeft : 0)) + 'px';\n}\n\nfunction termOnResize() {\n const openedDefinition = document.getElementsByClassName(openDefinitionClass)[0] as HTMLElement;\n\n if (!openedDefinition) {\n return;\n }\n const termId = openedDefinition.getAttribute('term-id') || '';\n const termElement = document.getElementById(termId);\n\n if (!termElement) {\n return;\n }\n\n setDefinitionPosition(openedDefinition, termElement);\n}\n\nfunction termParentElement(term: HTMLElement | null) {\n if (!term) {\n return null;\n }\n\n const closestScrollableParent = term.closest('table') || term.closest('code');\n\n return closestScrollableParent || term.parentElement;\n}\n\nexport function openDefinition(target: HTMLElement) {\n const openedDefinition = document.getElementsByClassName(openDefinitionClass)[0] as HTMLElement;\n\n const termId = target.getAttribute('id');\n const termKey = target.getAttribute('term-key');\n const definitionId = `${termKey}_element`;\n\n // Check if term is in modal window\n const isInModal = target.closest('.wide-container');\n\n let definitionElement: HTMLElement | null;\n\n if (isInModal) {\n // Find definition in modal window\n const modalContent = target.closest('.wide-content');\n if (!modalContent) {\n return;\n }\n definitionElement = modalContent.querySelector(`[id=\"${definitionId}\"]`) as HTMLElement;\n } else {\n // Find definition in normal document\n definitionElement = document.getElementById(definitionId);\n }\n\n const isSameTerm = openedDefinition && termId === openedDefinition.getAttribute('term-id');\n if (isSameTerm) {\n closeDefinition(openedDefinition);\n return;\n }\n\n const isTargetDefinitionContent = target.closest(\n [Selector.CONTENT.replace(' ', ''), openClass].join('.'),\n );\n\n if (openedDefinition && !isTargetDefinitionContent) {\n closeDefinition(openedDefinition);\n }\n\n if (!target.matches(Selector.TITLE) || !definitionElement) {\n return;\n }\n\n setDefinitionId(definitionElement, target);\n setDefinitonAriaAttributes(definitionElement, target);\n setDefinitionPosition(definitionElement, target);\n\n definitionElement.classList.toggle(openClass);\n\n trapFocus(definitionElement);\n}\n\nexport function closeDefinition(definition: HTMLElement) {\n definition.classList.remove(openClass);\n const term = getTermByDefinition(definition);\n const termParent = termParentElement(term);\n\n if (!termParent) {\n return;\n }\n\n termParent.removeEventListener('scroll', termOnResize);\n isListenerNeeded = true;\n}\n\nexport function getCoords(elem: HTMLElement) {\n const box = elem.getBoundingClientRect();\n\n const body = document.body;\n const docEl = document.documentElement;\n\n const scrollTop = window.pageYOffset || docEl.scrollTop || body.scrollTop;\n const scrollLeft = window.pageXOffset || docEl.scrollLeft || body.scrollLeft;\n\n const clientTop = docEl.clientTop || body.clientTop || 0;\n const clientLeft = docEl.clientLeft || body.clientLeft || 0;\n\n const top = box.top + scrollTop - clientTop;\n const left = box.left + scrollLeft - clientLeft;\n\n return {top: Math.round(top), left: Math.round(left)};\n}\n\nexport function trapFocus(element: HTMLElement) {\n const focusableElements = element.querySelectorAll(\n 'button, [href], input, select, textarea, [tabindex]:not([tabindex=\"-1\"])',\n );\n const firstFocusableElement = focusableElements[0] as HTMLElement;\n const lastFocusableElement = focusableElements[focusableElements.length - 1] as HTMLElement;\n\n if (firstFocusableElement) {\n firstFocusableElement.focus();\n }\n\n element.addEventListener('keydown', function (e) {\n const isTabPressed = e.key === 'Tab' || e.keyCode === 9;\n if (!isTabPressed) {\n return;\n }\n\n if (e.shiftKey) {\n if (document.activeElement === firstFocusableElement) {\n lastFocusableElement.focus();\n e.preventDefault();\n }\n } else if (document.activeElement === lastFocusableElement) {\n firstFocusableElement.focus();\n e.preventDefault();\n }\n });\n}\n\nexport function getTermByDefinition(definition: HTMLElement) {\n const termId = definition.getAttribute('term-id');\n\n if (!termId) {\n return null;\n }\n\n // Check if definition is in modal window\n const isInModal = definition.closest('.wide-container');\n\n if (isInModal) {\n // Find term in modal window\n const modalContent = definition.closest('.wide-content');\n if (!modalContent) {\n return null;\n }\n return modalContent.querySelector(`[id=\"${termId}\"]`) as HTMLElement;\n }\n\n // Find term in normal document\n return document.getElementById(termId);\n}\n", "import type {Lang} from 'src/transform/typings';\n\nimport {getCoords} from '../term/utils';\n\nimport {INLINE_CODE, INLINE_CODE_CLASS, INLINE_CODE_ID, LANG_TOKEN, OPEN_CLASS} from './constant';\n\nexport let timer: ReturnType<typeof setTimeout> | null = null;\n\nlet isListenerNeeded = true;\n\nexport function getTooltipElement(): HTMLElement | null {\n return document.getElementById(INLINE_CODE_ID);\n}\n\nfunction setTooltipAriaAttributes(tooltipElement: HTMLElement, targetElement: HTMLElement): void {\n const ariaLive = targetElement.getAttribute('aria-live') || 'polite';\n tooltipElement?.setAttribute('aria-live', ariaLive);\n tooltipElement?.setAttribute('aria-modal', 'true');\n}\n\nfunction checkTimerAndClear() {\n if (timer) {\n clearTimeout(timer);\n timer = null;\n }\n}\n\nfunction tooltipParentElement(target: HTMLElement | null) {\n if (!target) {\n return null;\n }\n\n const closestScrollableParent = target.closest('table') || target.closest('code');\n\n return closestScrollableParent || target.parentElement;\n}\n\nfunction tooltipOnResize() {\n const openedDefinition = getTooltipElement();\n\n if (!openedDefinition) {\n return;\n }\n const inlineId = openedDefinition.getAttribute('inline-id') || '';\n const targetElement = document.getElementById(inlineId);\n\n if (!targetElement) {\n return;\n }\n\n setTooltipPosition(openedDefinition, targetElement);\n}\n\nexport function setTooltipPosition(tooltipElement: HTMLElement, targetElement: HTMLElement): void {\n const {\n x: inlineX,\n y: inlineY,\n right: inlineRight,\n left: inlineLeft,\n width: inlineWidth,\n height: inlineHeight,\n } = targetElement.getBoundingClientRect();\n\n const tooltipParent = tooltipParentElement(targetElement);\n\n if (!tooltipParent) {\n return;\n }\n\n const {right: tooltipParentRight, left: tooltipParentLeft} =\n tooltipParent.getBoundingClientRect();\n\n if ((tooltipParentRight < inlineLeft || tooltipParentLeft > inlineRight) && !isListenerNeeded) {\n closeTooltip(tooltipElement);\n return;\n }\n\n if (isListenerNeeded && tooltipParent) {\n tooltipParent.addEventListener('scroll', tooltipOnResize);\n isListenerNeeded = false;\n }\n\n const relativeX = Number(tooltipElement.getAttribute('relativeX'));\n const relativeY = Number(tooltipElement.getAttribute('relativeY'));\n\n if (relativeX === inlineX && relativeY === inlineY) {\n return;\n }\n\n tooltipElement.setAttribute('relativeX', String(inlineX));\n tooltipElement.setAttribute('relativeY', String(inlineY));\n\n const offsetTop = inlineHeight + 5;\n const definitionParent = tooltipElement.parentElement;\n\n if (!definitionParent) {\n return;\n }\n\n const {width: definitionWidth} = tooltipElement.getBoundingClientRect();\n const {left: definitionParentLeft} = definitionParent.getBoundingClientRect();\n\n // If definition not fit document change base alignment\n const definitionLeftCoordinate = Number(getCoords(targetElement).left);\n const definitionRightCoordinate = definitionWidth + definitionLeftCoordinate;\n\n const definitionOutOfScreenOnLeft = definitionLeftCoordinate - definitionWidth < 0;\n const definitionOutOfScreenOnRight = definitionRightCoordinate > document.body.clientWidth;\n\n const isAlignSwapped = definitionOutOfScreenOnRight || document.dir === 'rtl';\n const fitDefinitionDocument =\n isAlignSwapped && !definitionOutOfScreenOnLeft ? definitionWidth - inlineWidth : 0;\n const customHeaderTop = getCoords(definitionParent).top - definitionParent.offsetTop;\n const offsetRight = 5;\n const shiftLeft = definitionOutOfScreenOnRight\n ? definitionRightCoordinate - document.body.clientWidth + offsetRight\n : 0;\n const offsetLeft =\n getCoords(targetElement).left -\n definitionParentLeft +\n definitionParent.offsetLeft -\n fitDefinitionDocument;\n\n const isShiftLeftNeeded = offsetLeft + definitionWidth >= document.body.clientWidth;\n\n tooltipElement.style.top =\n Number(getCoords(targetElement).top + offsetTop - customHeaderTop) + 'px';\n tooltipElement.style.left = Number(offsetLeft - (isShiftLeftNeeded ? shiftLeft : 0)) + 'px';\n}\n\nexport function getInlineCodeByTooltip(definition: HTMLElement) {\n const inlineId = definition.getAttribute('inline-id');\n\n return inlineId ? document.getElementById(inlineId) : null;\n}\n\nfunction closeTooltipFn(definition: HTMLElement) {\n definition.classList.remove(OPEN_CLASS);\n const inline = getInlineCodeByTooltip(definition);\n const inlineCodepParent = tooltipParentElement(inline);\n const tooltipParent = tooltipParentElement(definition);\n\n definition.removeAttribute('inline-id');\n\n if (!inlineCodepParent || !tooltipParent) {\n return;\n }\n\n tooltipParent.removeChild(definition);\n inlineCodepParent.removeEventListener('scroll', tooltipOnResize);\n isListenerNeeded = true;\n}\n\nfunction createTooltip() {\n let tooltip = getTooltipElement();\n\n if (!tooltip) {\n const pageContent = document.querySelector('.dc-doc-page__content') || document.body;\n const lang = document.documentElement.lang || 'en';\n const tooltipText = LANG_TOKEN[lang as Lang] ?? LANG_TOKEN.en;\n const host = document.createElement('div');\n\n host.innerHTML = `\n <div id=\"${INLINE_CODE_ID}\" class=\"${INLINE_CODE_CLASS}\"\n role=\"dialog\" aria-live=\"polite\" aria-modal=\"true\">\n ${tooltipText}\n </div>\n `;\n\n tooltip = host.firstElementChild as HTMLElement;\n pageContent.appendChild(tooltip);\n }\n\n return tooltip;\n}\n\nexport function openTooltip(target: HTMLElement) {\n const tooltip = createTooltip();\n\n if (!target.matches(INLINE_CODE) || !tooltip) {\n return;\n }\n\n tooltip.setAttribute('inline-id', target.getAttribute('id') || '');\n setTooltipAriaAttributes(tooltip, target);\n setTooltipPosition(tooltip, target);\n\n // In order not to get rid of the smooth appearance effect, I had to do this\n if (tooltip.classList.contains(OPEN_CLASS)) {\n tooltip.classList.remove(OPEN_CLASS);\n requestAnimationFrame(() => {\n tooltip.classList.add(OPEN_CLASS);\n });\n } else {\n tooltip.classList.add(OPEN_CLASS);\n }\n\n return tooltip;\n}\n\nexport function closeTooltip(target: HTMLElement) {\n checkTimerAndClear();\n closeTooltipFn(target);\n}\n\nexport function tooltipWorker(target: HTMLElement) {\n const definition = openTooltip(target);\n\n if (!definition) {\n return;\n }\n checkTimerAndClear();\n timer = setTimeout(() => {\n closeTooltip(definition);\n timer = null;\n }, 1000);\n}\n", "import {copyToClipboard, getEventTarget, isCustom} from '../utils';\n\nimport {INLINE_CODE, OPEN_CLASS} from './constant';\nimport {\n closeTooltip,\n getInlineCodeByTooltip,\n getTooltipElement,\n setTooltipPosition,\n tooltipWorker,\n} from './utils';\n\nexport function inlineCopyFn(target: HTMLElement) {\n const innerText = target.innerText;\n\n if (!innerText) {\n return;\n }\n\n copyToClipboard(innerText).then(() => {\n tooltipWorker(target);\n });\n}\n\nif (typeof document !== 'undefined') {\n document.addEventListener('click', (event) => {\n const target = getEventTarget(event) as HTMLElement;\n\n const inline = target.matches(INLINE_CODE);\n\n if (isCustom(event) || !inline) {\n return;\n }\n\n inlineCopyFn(target);\n });\n\n document.addEventListener('keydown', (event) => {\n if (event.key === 'Enter' && document.activeElement) {\n const activeElement = document.activeElement as HTMLElement;\n const classInlineCode = INLINE_CODE.replace('.', '');\n\n if (!activeElement.classList.contains(classInlineCode)) {\n return;\n }\n\n const innerText = activeElement.innerText;\n\n if (!innerText) {\n return;\n }\n\n copyToClipboard(innerText).then(() => {\n tooltipWorker(activeElement);\n });\n }\n\n const inlineTooltip = getTooltipElement();\n\n if (event.key === 'Escape' && inlineTooltip) {\n closeTooltip(inlineTooltip);\n getInlineCodeByTooltip(inlineTooltip)?.focus(); // Set focus back to open button after closing popup\n }\n });\n\n window.addEventListener('resize', () => {\n const inlineTooltip = getTooltipElement();\n if (!inlineTooltip) {\n return;\n }\n\n const inlineId = inlineTooltip.getAttribute('inline-id') || '';\n const inlineCodeElement = document.getElementById(inlineId);\n\n if (!inlineCodeElement) {\n inlineTooltip.classList.toggle(OPEN_CLASS);\n return;\n }\n\n setTooltipPosition(inlineTooltip, inlineCodeElement);\n });\n}\n"],
5
- "mappings": "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",
6
- "names": ["getRootNode", "matches", "getRootNode", "e"]
3
+ "sources": ["../../node_modules/get-root-node-polyfill/index.js", "../../src/js/polyfill.js", "../../src/js/utils.ts", "../../src/js/code.ts", "../../src/js/tooltip/constant.ts", "../../src/js/tooltip/utils.ts", "../../src/js/tooltip/tooltip.ts", "../../src/js/constant.ts", "../../src/js/anchor.ts", "../../src/js/inline-code/index.ts"],
4
+ "sourcesContent": ["'use strict';\n\n// Node getRootNode(optional GetRootNodeOptions options);\n\n/**\n * Returns the context object\u2019s shadow-including root if options\u2019s composed is true.\n * Returns the context object\u2019s root otherwise.\n *\n * The root of an object is itself, if its parent is null, or else it is the root of its parent.\n *\n * The shadow-including root of an object is its root\u2019s host\u2019s shadow-including root,\n * if the object\u2019s root is a shadow root, and its root otherwise.\n *\n * https://dom.spec.whatwg.org/#dom-node-getrootnode\n *\n * @memberof Node.prototype\n * @param {!Object} [opt = {}] - Options.\n * @param {!boolean} [opt.composed] - See above description.\n * @returns {!Node} The root node.\n */\nfunction getRootNode(opt) {\n var composed = typeof opt === 'object' && Boolean(opt.composed);\n\n return composed ? getShadowIncludingRoot(this) : getRoot(this);\n}\n\nfunction getShadowIncludingRoot(node) {\n var root = getRoot(node);\n\n if (isShadowRoot(root)) {\n return getShadowIncludingRoot(root.host);\n }\n\n return root;\n}\n\nfunction getRoot(node) {\n if (node.parentNode != null) {\n return getRoot(node.parentNode);\n }\n\n return node;\n}\n\nfunction isShadowRoot(node) {\n return node.nodeName === '#document-fragment' && node.constructor.name === 'ShadowRoot';\n}\n\nif (typeof module === 'object' && module.exports) {\n module.exports = getRootNode;\n}\n", "import getRootNode from 'get-root-node-polyfill';\n\nif (typeof document !== 'undefined') {\n // matches polyfill for old edge\n (function (e) {\n const matches =\n e.matches ||\n e.matchesSelector ||\n e.webkitMatchesSelector ||\n e.mozMatchesSelector ||\n e.msMatchesSelector ||\n e.oMatchesSelector;\n\n if (matches) {\n e.matches = e.matchesSelector = matches;\n } else {\n e.matches = e.matchesSelector = function matches(selector) {\n const rootNode = e.getRootNode ? e.getRootNode() : getRootNode.call(e);\n const matches = rootNode.querySelectorAll(selector);\n const th = this;\n return Array.prototype.some.call(matches, (e) => {\n return e === th;\n });\n };\n }\n // eslint-disable-next-line no-undef\n })(Element.prototype);\n}\n", "export const getEventTarget = (event: Event) => {\n const path = event.composedPath();\n return Array.isArray(path) && path.length > 0 ? path[0] : event.target;\n};\n\nexport const isCustom = (event: Event) => {\n const target = getEventTarget(event);\n return !target || !(target as HTMLElement).matches;\n};\n\nexport const copyToClipboard = async (text: string) => {\n if (!text) {\n return;\n }\n\n if (navigator.clipboard && typeof navigator.clipboard.writeText) {\n return navigator.clipboard.writeText(text);\n }\n\n const textarea = document.createElement('textarea');\n textarea.setAttribute('style', 'position: absolute; left: 1000%');\n textarea.textContent = text;\n document.body.append(textarea);\n\n textarea.select();\n document.execCommand('copy');\n\n document.body.removeChild(textarea);\n};\n", "import {copyToClipboard, getEventTarget, isCustom} from './utils';\n\nconst COPY_BUTTON_SELECTOR = '.yfm-clipboard-button';\nconst WRAP_BUTTON_SELECTOR = '.yfm-wrapping-button';\n\nfunction notifySuccess(svgButton: HTMLElement | null) {\n if (!svgButton) {\n return;\n }\n\n const id = svgButton.getAttribute('data-animation');\n\n // @ts-expect-error\n const icon = svgButton.getRootNode().getElementById(`visibileAnimation-${id}`);\n\n if (!icon) {\n return;\n }\n\n icon.beginElement();\n}\n\nfunction buttonCopyFn(target: HTMLElement) {\n const container = target.parentNode?.parentNode;\n const code = container?.querySelector<HTMLElement>('pre code');\n if (!container || !code) {\n return;\n }\n\n // Get all text nodes and filter out line numbers\n const textContent = Array.from(code.childNodes)\n .filter((node) => {\n // Skip line number spans\n if (node instanceof HTMLElement && node.classList.contains('yfm-line-number')) {\n return false;\n }\n return true;\n })\n .map((node) => node.textContent)\n .join('');\n\n copyToClipboard(textContent.trim()).then(() => {\n notifySuccess(container.querySelector('.yfm-clipboard-icon'));\n\n setTimeout(() => target.blur(), 1500);\n });\n}\n\nfunction buttonWrapFn(target: HTMLElement) {\n const container = target.parentNode?.parentNode;\n const code = container?.querySelector<HTMLElement>('pre code');\n if (!container || !code) {\n return;\n }\n\n code.classList.toggle('wrap');\n\n setTimeout(() => target.blur(), 500);\n}\n\nif (typeof document !== 'undefined') {\n document.addEventListener('click', (event) => {\n if (isCustom(event)) {\n return;\n }\n\n const target = getEventTarget(event) as HTMLElement;\n\n if (target.matches(COPY_BUTTON_SELECTOR)) {\n buttonCopyFn(target);\n } else if (target.matches(WRAP_BUTTON_SELECTOR)) {\n buttonWrapFn(target);\n }\n });\n}\n", "import type {OffsetValues, Side, SideObject} from './types';\n\nexport const PAGE_CONTAINER_SELECTOR = '.dc-doc-page__content';\n\nexport const TOOLTIP_BASE_CLASS = 'yfm yfm-tooltip';\n\nexport const TOOLTIP_OPEN_CLASS = 'open';\n\nexport const TOOLTIP_DATA_ATTR = 'data-tooltip-id';\n\nexport const DEFAULT_OFFSET_VALUES: OffsetValues = {mainAxis: 5};\n\nexport const OPPOSITE_SIDES: Record<Side, Side> = {\n top: 'bottom',\n bottom: 'top',\n left: 'right',\n right: 'left',\n};\n\nexport const DEFAULT_SIDE_OBJECT: SideObject = {\n top: 0,\n bottom: 0,\n left: 0,\n right: 0,\n};\n", "import type {\n Alignment,\n Coords,\n ElementRect,\n OffsetValues,\n Placement,\n Side,\n SideObject,\n} from './types';\n\nimport {DEFAULT_SIDE_OBJECT, OPPOSITE_SIDES} from './constant';\n\nfunction isVerticalSide(side: Side): boolean {\n return side === 'top' || side === 'bottom';\n}\n\nfunction createSideObject(value: Partial<SideObject> | number = 0): SideObject {\n if (typeof value === 'number') {\n return {top: value, bottom: value, left: value, right: value};\n }\n\n return {...DEFAULT_SIDE_OBJECT, ...value};\n}\n\nfunction parsePlacement(placement: Placement): {side: Side; alignment?: Alignment} {\n const [side, alignment] = placement.split('-') as [Side, Alignment | undefined];\n\n return {side, alignment};\n}\n\nfunction getOppositeSide(side: Side): Side {\n return OPPOSITE_SIDES[side];\n}\n\nfunction flipPlacement(placement: Placement): Placement {\n const {side, alignment} = parsePlacement(placement);\n const opposite = getOppositeSide(side);\n\n return (alignment ? `${opposite}-${alignment}` : opposite) as Placement;\n}\n\nfunction getOverflow(tooltip: ElementRect, coords: Coords, viewport: ElementRect): SideObject {\n const rect = updateRect(tooltip, {top: coords.y, left: coords.x});\n\n return detectOverflow(viewport, rect, 5);\n}\n\nfunction shouldFlip(overflow: SideObject, flippedOverflow: SideObject, side: Side): boolean {\n const opposite = getOppositeSide(side);\n\n return overflow[side] > 0 && flippedOverflow[opposite] < overflow[side];\n}\n\nexport function computePosition(\n reference: ElementRect,\n tooltip: ElementRect,\n viewport: ElementRect,\n placement: Placement,\n offset: OffsetValues,\n isRtl: boolean,\n flip = true,\n): {coords: Coords; placement: Placement} {\n const coords = computeCoordsFromPlacement(reference, tooltip, offset, placement, isRtl);\n\n if (!flip) {\n return {coords, placement};\n }\n\n const overflow = getOverflow(tooltip, coords, viewport);\n const {side} = parsePlacement(placement);\n\n if (overflow[side] <= 0) {\n return {coords, placement};\n }\n\n const flipped = flipPlacement(placement);\n const flippedCoords = computeCoordsFromPlacement(reference, tooltip, offset, flipped, isRtl);\n const flippedOverflow = getOverflow(tooltip, flippedCoords, viewport);\n\n if (shouldFlip(overflow, flippedOverflow, side)) {\n return {coords: flippedCoords, placement: flipped};\n }\n\n return {coords, placement};\n}\n\nexport function generateId() {\n const random = Math.random().toString(36).substring(2, 6);\n const now = Date.now().toString(36);\n\n return `${random}${now}`;\n}\n\nexport function createRect(\n params: Pick<ElementRect, 'top' | 'left' | 'width' | 'height'>,\n): ElementRect {\n return {\n ...params,\n right: params.left + params.width,\n bottom: params.top + params.height,\n };\n}\n\nexport function updateRect(rect: ElementRect, params: Partial<ElementRect>): ElementRect {\n return createRect({\n top: params.top ?? rect.top,\n left: params.left ?? rect.left,\n width: params.width ?? rect.width,\n height: params.height ?? rect.height,\n });\n}\n\nexport function getViewportRect(): ElementRect {\n const {documentElement, body} = document;\n\n const scrollTop = window.scrollY || documentElement.scrollTop || body.scrollTop;\n const scrollLeft = window.scrollX || documentElement.scrollLeft || body.scrollLeft;\n\n const clientTop = documentElement.clientTop || body.clientTop || 0;\n const clientLeft = documentElement.clientLeft || body.clientLeft || 0;\n\n return createRect({\n top: Math.round(scrollTop - clientTop),\n left: Math.round(scrollLeft - clientLeft),\n width: document.body.clientWidth,\n height: document.body.clientHeight,\n });\n}\n\nexport function getElementRect(element: HTMLElement): ElementRect {\n const viewport = getViewportRect();\n const box = element.getBoundingClientRect();\n\n return createRect({\n top: Math.round(box.top + viewport.top),\n left: Math.round(box.left + viewport.left),\n width: box.width,\n height: box.height,\n });\n}\n\nexport function computeAxisOffset(offset: OffsetValues, side: Side, isRtl?: boolean): Coords {\n const {mainAxis = 0, crossAxis = 0} = offset;\n\n const isVertical = isVerticalSide(side);\n const mainDirection = side === 'top' || side === 'left' ? -1 : 1;\n const crossDirection = isRtl && isVertical ? -1 : 1;\n\n const mainOffset = mainAxis * mainDirection;\n const crossOffset = crossAxis * crossDirection;\n\n if (isVertical) {\n return {x: crossOffset, y: mainOffset};\n }\n\n return {x: mainOffset, y: crossOffset};\n}\n\nexport function computeCoordsFromPlacement(\n reference: ElementRect,\n tooltip: ElementRect,\n offset: OffsetValues,\n placement: Placement,\n isRtl: boolean,\n) {\n const {side, alignment} = parsePlacement(placement);\n const isVertical = isVerticalSide(side);\n const alignmentAxis = isVertical ? 'x' : 'y';\n const alignLength = alignmentAxis === 'y' ? 'height' : 'width';\n\n const centerX = reference.left + reference.width / 2 - tooltip.width / 2;\n const centerY = reference.top + reference.height / 2 - tooltip.height / 2;\n const alignmentOffset = reference[alignLength] / 2 - tooltip[alignLength] / 2;\n\n const coords: Coords = {x: reference.left, y: reference.top};\n\n switch (side) {\n case 'top': {\n coords.x = centerX;\n coords.y = reference.top - tooltip.height;\n break;\n }\n\n case 'bottom': {\n coords.x = centerX;\n coords.y = reference.top + reference.height;\n break;\n }\n\n case 'right': {\n coords.x = reference.left + reference.width;\n coords.y = centerY;\n break;\n }\n\n case 'left': {\n coords.x = reference.left - tooltip.width;\n coords.y = centerY;\n break;\n }\n }\n\n switch (alignment) {\n case 'start': {\n coords[alignmentAxis] -= alignmentOffset * (isRtl && isVertical ? -1 : 1);\n break;\n }\n\n case 'end': {\n coords[alignmentAxis] += alignmentOffset * (isRtl && isVertical ? -1 : 1);\n break;\n }\n }\n\n const axisOffset = computeAxisOffset(offset, side, isRtl);\n\n coords.x += axisOffset.x;\n coords.y += axisOffset.y;\n\n return coords;\n}\n\nexport function convertToRelativeToOffsetParentRect(rect: ElementRect, offsetParent: HTMLElement) {\n const offsetRect = getElementRect(offsetParent);\n\n return createRect({\n top: rect.top - offsetRect.top + offsetParent.offsetTop,\n left: rect.left - offsetRect.left + offsetParent.offsetLeft,\n width: rect.width,\n height: rect.height,\n });\n}\n\nexport function detectOverflow(\n boundary: ElementRect,\n element: ElementRect,\n padding: Partial<SideObject> | number = 0,\n): SideObject {\n const {top, bottom, left, right} = createSideObject(padding);\n\n return {\n top: boundary.top - element.top + top,\n bottom: element.bottom - boundary.bottom + bottom,\n left: boundary.left - element.left + left,\n right: element.right - boundary.right + right,\n };\n}\n", "import type {\n Coords,\n TooltipContext,\n TooltipContextElements,\n TooltipElementOptions,\n TooltipOptions,\n} from './types';\n\nimport {\n DEFAULT_OFFSET_VALUES,\n PAGE_CONTAINER_SELECTOR,\n TOOLTIP_BASE_CLASS,\n TOOLTIP_DATA_ATTR,\n TOOLTIP_OPEN_CLASS,\n} from './constant';\nimport {\n computePosition,\n convertToRelativeToOffsetParentRect,\n createRect,\n generateId,\n getElementRect,\n getViewportRect,\n updateRect,\n} from './utils';\n\ninterface TooltipState {\n currentId: string | null;\n timer: ReturnType<typeof setTimeout> | null;\n unsubscribe: (() => void) | null;\n}\n\nexport function createTooltipFactory(options: TooltipOptions = {}) {\n const {closeDelay = 1_000, additionalClassName} = options;\n let initialized = false;\n\n const state: TooltipState = {\n currentId: null,\n timer: null,\n unsubscribe: null,\n };\n\n const getActiveTooltip = () => {\n if (!state.currentId) {\n return null;\n }\n\n return document.getElementById(state.currentId);\n };\n\n const getActiveReference = () => {\n if (!state.currentId) {\n return null;\n }\n\n return getReferenceByTooltipId(state.currentId);\n };\n\n const hide = () => {\n const tooltip = getActiveTooltip();\n\n if (state.timer) {\n clearTimeout(state.timer);\n state.timer = null;\n }\n\n if (state.unsubscribe) {\n state.unsubscribe();\n state.unsubscribe = null;\n }\n\n if (tooltip) {\n tooltip.classList.remove(TOOLTIP_OPEN_CLASS);\n detachTooltip(tooltip);\n\n state.currentId = null;\n }\n };\n\n const show = (reference: HTMLElement, text: string) => {\n hide();\n\n const tooltip = createTooltipElement({text, className: additionalClassName});\n const update = updateTooltipPosition.bind(null, options, reference, tooltip);\n\n state.currentId = tooltip.id;\n\n attachTooltip(tooltip, reference);\n\n state.unsubscribe = subscribeToScroll(reference, update);\n\n tooltip.classList.add(TOOLTIP_OPEN_CLASS);\n\n update();\n\n if (closeDelay > 0) {\n state.timer = setTimeout(hide, closeDelay);\n }\n };\n\n const handleUpdate = () => {\n const activeTooltip = getActiveTooltip();\n const activeReference = getActiveReference();\n\n if (activeTooltip && !activeReference) {\n hide();\n return;\n }\n\n if (activeTooltip && activeReference) {\n updateTooltipPosition(options, activeReference, activeTooltip);\n }\n };\n\n const init = () => {\n if (!initialized) {\n initialized = true;\n\n window.addEventListener('scroll', handleUpdate);\n window.addEventListener('resize', handleUpdate);\n }\n };\n\n const cleanup = () => {\n if (initialized) {\n initialized = false;\n\n window.removeEventListener('scroll', handleUpdate);\n window.removeEventListener('resize', handleUpdate);\n }\n };\n\n return {\n get visible() {\n return Boolean(state.currentId);\n },\n getActiveReference,\n show,\n hide,\n init,\n cleanup,\n };\n}\n\nfunction createTooltipElement(options: TooltipElementOptions) {\n const {text, className} = options;\n\n const id = generateId();\n const tooltip = document.createElement('div');\n\n tooltip.id = id;\n tooltip.className = className ? `${TOOLTIP_BASE_CLASS} ${className}` : TOOLTIP_BASE_CLASS;\n\n tooltip.setAttribute('role', 'tooltip');\n tooltip.setAttribute('aria-live', 'polite');\n\n tooltip.textContent = text;\n\n return tooltip;\n}\n\nfunction attachTooltip(tooltip: HTMLElement, reference: HTMLElement) {\n const container = document.querySelector(PAGE_CONTAINER_SELECTOR) || document.body;\n const ariaLive = reference.getAttribute('aria-live');\n\n reference.setAttribute(TOOLTIP_DATA_ATTR, tooltip.id);\n\n if (ariaLive) {\n tooltip.setAttribute('aria-live', ariaLive);\n }\n\n container.appendChild(tooltip);\n}\n\nfunction detachTooltip(tooltip: HTMLElement) {\n if (tooltip.id) {\n const reference = getReferenceByTooltipId(tooltip.id);\n\n reference?.removeAttribute(TOOLTIP_DATA_ATTR);\n }\n\n tooltip.remove();\n}\n\nfunction getReferenceByTooltipId(id: string) {\n return document.querySelector<HTMLElement>(`[${TOOLTIP_DATA_ATTR}=\"${id}\"]`);\n}\n\nfunction subscribeToScroll(reference: HTMLElement, update: () => void) {\n const scrollableElement = getParentScrollableElement(reference);\n\n scrollableElement.addEventListener('scroll', update);\n\n return () => {\n scrollableElement.removeEventListener('scroll', update);\n };\n}\n\nfunction getParentScrollableElement(target: HTMLElement) {\n const closestScrollableParent = target.closest('table') || target.closest('code');\n\n return closestScrollableParent || target.parentElement || document.body;\n}\n\nfunction createTooltipContext(\n referenceElement: HTMLElement,\n tooltipElement: HTMLElement,\n): TooltipContext | null {\n const tooltipParent = tooltipElement.parentElement;\n\n if (!tooltipParent) {\n return null;\n }\n\n const elements: TooltipContextElements = {\n reference: referenceElement,\n tooltip: tooltipElement,\n offsetParent: tooltipParent,\n };\n\n const viewport = getViewportRect();\n const reference = getElementRect(referenceElement);\n const {width, height} = tooltipElement.getBoundingClientRect();\n\n return {\n isRtl: document.dir === 'rtl',\n viewport,\n reference,\n tooltip: createRect({top: 0, left: 0, width, height}),\n elements,\n };\n}\n\nfunction updateTooltipPosition(\n options: TooltipOptions,\n referenceElement: HTMLElement,\n tooltipElement: HTMLElement,\n) {\n const context = createTooltipContext(referenceElement, tooltipElement);\n\n if (!context) {\n return;\n }\n\n const coords = getTooltipCoords(context, options);\n\n tooltipElement.style.top = `${coords.y}px`;\n tooltipElement.style.left = `${coords.x}px`;\n}\n\nfunction getTooltipCoords(context: TooltipContext, options: TooltipOptions): Coords {\n const {placement = 'bottom-start', offset = DEFAULT_OFFSET_VALUES, flip = true} = options;\n const {reference, tooltip, viewport, isRtl} = context;\n\n const {coords} = computePosition(reference, tooltip, viewport, placement, offset, isRtl, flip);\n\n const rect = updateRect(tooltip, {top: coords.y, left: coords.x});\n const relativeRect = convertToRelativeToOffsetParentRect(rect, context.elements.offsetParent);\n\n return {\n x: relativeRect.left,\n y: relativeRect.top,\n };\n}\n", "import type {Lang} from 'src/transform/typings';\n\nexport const COPIED_LANG_TOKEN: Record<Lang, string> = {\n ru: '\u0421\u043A\u043E\u043F\u0438\u0440\u043E\u0432\u0430\u043D\u043E',\n en: 'Copied',\n ar: '\u062A\u0645 \u0627\u0644\u0646\u0633\u062E',\n cs: 'Zkop\u00EDrov\u00E1no',\n fr: 'Copi\u00E9',\n es: 'Copiado',\n he: '\u05D4\u05D5\u05E2\u05EA\u05E7',\n bg: '\u041A\u043E\u043F\u0438\u0440\u0430\u043D\u043E',\n et: 'Kopeeritud',\n el: '\u0391\u03BD\u03C4\u03B9\u03B3\u03C1\u03AC\u03C6\u03B7\u03BA\u03B5',\n pt: 'Copiado',\n zh: '\u5DF2\u590D\u5236',\n 'zh-tw': '\u5DF2\u8907\u88FD',\n kk: '\u041A\u04E9\u0448\u0456\u0440\u0456\u043B\u0434\u0456',\n tr: 'Kopyaland\u0131',\n uz: 'Nusxalandi',\n};\n", "import type {Lang} from 'src/transform/typings';\n\nimport {createTooltipFactory} from './tooltip';\nimport {copyToClipboard, getEventTarget, isCustom} from './utils';\nimport {COPIED_LANG_TOKEN} from './constant';\n\nconst ALLOWED_PROTOCOL_RE = /^(?:https?|file):$/;\nconst ANCHOR_BUTTON_SELECTOR = '.yfm-clipboard-anchor';\n\nconst tooltip = createTooltipFactory();\n\nfunction getLink(target: HTMLElement) {\n const href = target.nodeName === 'A' ? (target as HTMLAnchorElement).href : target.dataset.href;\n const link = new URL(href || '', window.location.href);\n\n if (ALLOWED_PROTOCOL_RE.test(link.protocol)) {\n return link.href;\n }\n\n return window.location.href;\n}\n\nif (typeof document !== 'undefined') {\n tooltip.init();\n\n document.addEventListener('click', (event) => {\n const target = getEventTarget(event) as HTMLElement;\n\n if (isCustom(event) || !target.matches(ANCHOR_BUTTON_SELECTOR)) {\n return;\n }\n\n const link = getLink(target);\n\n copyToClipboard(link).then(() => {\n const lang = document.documentElement.lang || 'en';\n const tooltipText = COPIED_LANG_TOKEN[lang as Lang] ?? COPIED_LANG_TOKEN.en;\n\n tooltip.show(target, tooltipText);\n });\n });\n}\n", "import type {Lang} from 'src/transform/typings';\n\nimport {createTooltipFactory} from '../tooltip';\nimport {copyToClipboard, getEventTarget, isCustom} from '../utils';\nimport {COPIED_LANG_TOKEN} from '../constant';\n\nconst CLASS_INLINE_CODE = 'yfm-clipboard-inline-code';\nconst INLINE_CODE = `.${CLASS_INLINE_CODE}`;\n\nconst tooltip = createTooltipFactory({\n // NOTE: Add additional className for backward capability\n additionalClassName: 'inline_code_tooltip',\n});\n\nexport function inlineCopyFn(target: HTMLElement) {\n const innerText = target.innerText;\n\n if (!innerText) {\n return;\n }\n\n copyToClipboard(innerText).then(() => {\n const lang = document.documentElement.lang || 'en';\n const tooltipText = COPIED_LANG_TOKEN[lang as Lang] ?? COPIED_LANG_TOKEN.en;\n\n tooltip.show(target, tooltipText);\n });\n}\n\nif (typeof document !== 'undefined') {\n tooltip.init();\n\n document.addEventListener('click', (event) => {\n const target = getEventTarget(event) as HTMLElement;\n const inline = target.matches(INLINE_CODE);\n\n if (isCustom(event) || !inline) {\n return;\n }\n\n inlineCopyFn(target);\n });\n\n document.addEventListener('keydown', (event) => {\n if (event.key === 'Enter' && document.activeElement) {\n const activeElement = document.activeElement as HTMLElement;\n\n if (!activeElement.classList.contains(CLASS_INLINE_CODE)) {\n return;\n }\n\n inlineCopyFn(activeElement);\n }\n\n if (event.key === 'Escape' && tooltip.visible) {\n const reference = tooltip.getActiveReference();\n\n tooltip.hide();\n // Set focus back to open button after closing popup\n reference?.focus();\n }\n });\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["getRootNode", "matches", "getRootNode", "e", "tooltip", "tooltip", "tooltip"]
7
7
  }
@@ -1,7 +1,2 @@
1
- "use strict";(()=>{(()=>{var k=Object.create,L=Object.defineProperty,j=Object.getOwnPropertyDescriptor,N=Object.getOwnPropertyNames,F=Object.getPrototypeOf,M=Object.prototype.hasOwnProperty,q=(t,e)=>function(){return e||(0,t[N(t)[0]])((e={exports:{}}).exports,e),e.exports},W=(t,e,n,o)=>{if(e&&typeof e=="object"||typeof e=="function")for(let i of N(e))!M.call(t,i)&&i!==n&&L(t,i,{get:()=>e[i],enumerable:!(o=j(e,i))||o.enumerable});return t},z=(t,e,n)=>(n=t!=null?k(F(t)):{},W(e||!t||!t.__esModule?L(n,"default",{value:t,enumerable:!0}):n,t)),Y=q({"node_modules/get-root-node-polyfill/index.js"(t,e){"use strict";function n(c){var u=typeof c=="object"&&!!c.composed;return u?o(this):i(this)}function o(c){var u=i(c);return r(u)?o(u.host):u}function i(c){return c.parentNode!=null?i(c.parentNode):c}function r(c){return c.nodeName==="#document-fragment"&&c.constructor.name==="ShadowRoot"}typeof e=="object"&&e.exports&&(e.exports=n)}}),H=z(Y());typeof document!="undefined"&&(function(t){let e=t.matches||t.matchesSelector||t.webkitMatchesSelector||t.mozMatchesSelector||t.msMatchesSelector||t.oMatchesSelector;e?t.matches=t.matchesSelector=e:t.matches=t.matchesSelector=function(o){let r=(t.getRootNode?t.getRootNode():H.default.call(t)).querySelectorAll(o),c=this;return Array.prototype.some.call(r,u=>u===c)}})(Element.prototype);var f=t=>{let e=t.composedPath();return Array.isArray(e)&&e.length>0?e[0]:t.target},v=t=>{let e=f(t);return!e||!e.matches},p=async t=>{if(!t)return;if(navigator.clipboard&&typeof navigator.clipboard.writeText)return navigator.clipboard.writeText(t);let e=document.createElement("textarea");e.setAttribute("style","position: absolute; left: 1000%"),e.textContent=t,document.body.append(e),e.select(),document.execCommand("copy"),document.body.removeChild(e)},X=".yfm-clipboard-button",U=".yfm-wrapping-button";function $(t){if(!t)return;let e=t.getAttribute("data-animation"),n=t.getRootNode().getElementById(`visibileAnimation-${e}`);n&&n.beginElement()}function K(t){var e;let n=(e=t.parentNode)==null?void 0:e.parentNode,o=n==null?void 0:n.querySelector("pre code");if(!n||!o)return;let i=Array.from(o.childNodes).filter(r=>!(r instanceof HTMLElement&&r.classList.contains("yfm-line-number"))).map(r=>r.textContent).join("");p(i.trim()).then(()=>{$(n.querySelector(".yfm-clipboard-icon")),setTimeout(()=>t.blur(),1500)})}function G(t){var e;let n=(e=t.parentNode)==null?void 0:e.parentNode,o=n==null?void 0:n.querySelector("pre code");!n||!o||(o.classList.toggle("wrap"),setTimeout(()=>t.blur(),500))}typeof document!="undefined"&&document.addEventListener("click",t=>{if(v(t))return;let e=f(t);e.matches(X)?K(e):e.matches(U)&&G(e)});var J=".yfm-clipboard-anchor";typeof document!="undefined"&&document.addEventListener("click",t=>{let e=f(t);if(v(t)||!e.matches(J))return;let n=e.getAttribute("data-href")||"",o=new URL(n,window.location.href).toString();p(o)});var b=".yfm-clipboard-inline-code",A="tooltip_inline_clipboard_dialog",Z="yfm inline_code_tooltip",l="open",O={ru:"\u0421\u043A\u043E\u043F\u0438\u0440\u043E\u0432\u0430\u043D\u043E",en:"Copied",ar:"\u062A\u0645 \u0627\u0644\u0646\u0633\u062E",cs:"Zkop\xEDrov\xE1no",fr:"Copi\xE9",es:"Copiado",he:"\u05D4\u05D5\u05E2\u05EA\u05E7",bg:"\u041A\u043E\u043F\u0438\u0440\u0430\u043D\u043E",et:"Kopeeritud",el:"\u0391\u03BD\u03C4\u03B9\u03B3\u03C1\u03AC\u03C6\u03B7\u03BA\u03B5",pt:"Copiado",zh:"\u5DF2\u590D\u5236","zh-tw":"\u5DF2\u8907\u88FD",kk:"\u041A\u04E9\u0448\u0456\u0440\u0456\u043B\u0434\u0456",tr:"Kopyaland\u0131",uz:"Nusxalandi"},Q={TITLE:".yfm .yfm-term_title",CONTENT:".yfm .yfm-term_dfn"},V="open",gt=Q.CONTENT.replace(/\./g,"")+" "+V;function m(t){let e=t.getBoundingClientRect(),n=document.body,o=document.documentElement,i=window.pageYOffset||o.scrollTop||n.scrollTop,r=window.pageXOffset||o.scrollLeft||n.scrollLeft,c=o.clientTop||n.clientTop||0,u=o.clientLeft||n.clientLeft||0,s=e.top+i-c,C=e.left+r-u;return{top:Math.round(s),left:Math.round(C)}}var a=null,g=!0;function h(){return document.getElementById(A)}function tt(t,e){let n=e.getAttribute("aria-live")||"polite";t==null||t.setAttribute("aria-live",n),t==null||t.setAttribute("aria-modal","true")}function S(){a&&(clearTimeout(a),a=null)}function _(t){return t?t.closest("table")||t.closest("code")||t.parentElement:null}function w(){let t=h();if(!t)return;let e=t.getAttribute("inline-id")||"",n=document.getElementById(e);n&&T(t,n)}function T(t,e){let{x:n,y:o,right:i,left:r,width:c,height:u}=e.getBoundingClientRect(),s=_(e);if(!s)return;let{right:C,left:rt}=s.getBoundingClientRect();if((C<r||rt>i)&&!g){E(t);return}g&&s&&(s.addEventListener("scroll",w),g=!1);let ct=Number(t.getAttribute("relativeX")),ut=Number(t.getAttribute("relativeY"));if(ct===n&&ut===o)return;t.setAttribute("relativeX",String(n)),t.setAttribute("relativeY",String(o));let lt=u+5,d=t.parentElement;if(!d)return;let{width:y}=t.getBoundingClientRect(),{left:st}=d.getBoundingClientRect(),R=Number(m(e).left),B=y+R,at=R-y<0,D=B>document.body.clientWidth,dt=(D||document.dir==="rtl")&&!at?y-c:0,ft=m(d).top-d.offsetTop,pt=D?B-document.body.clientWidth+5:0,I=m(e).left-st+d.offsetLeft-dt,mt=I+y>=document.body.clientWidth;t.style.top=Number(m(e).top+lt-ft)+"px",t.style.left=Number(I-(mt?pt:0))+"px"}function x(t){let e=t.getAttribute("inline-id");return e?document.getElementById(e):null}function et(t){t.classList.remove(l);let e=x(t),n=_(e),o=_(t);t.removeAttribute("inline-id"),!(!n||!o)&&(o.removeChild(t),n.removeEventListener("scroll",w),g=!0)}function nt(){var t;let e=h();if(!e){let n=document.querySelector(".dc-doc-page__content")||document.body,o=document.documentElement.lang||"en",i=(t=O[o])!=null?t:O.en,r=document.createElement("div");r.innerHTML=`
2
- <div id="${A}" class="${Z}"
3
- role="dialog" aria-live="polite" aria-modal="true">
4
- ${i}
5
- </div>
6
- `,e=r.firstElementChild,n.appendChild(e)}return e}function ot(t){let e=nt();if(!(!t.matches(b)||!e))return e.setAttribute("inline-id",t.getAttribute("id")||""),tt(e,t),T(e,t),e.classList.contains(l)?(e.classList.remove(l),requestAnimationFrame(()=>{e.classList.add(l)})):e.classList.add(l),e}function E(t){S(),et(t)}function P(t){let e=ot(t);e&&(S(),a=setTimeout(()=>{E(e),a=null},1e3))}function it(t){let e=t.innerText;e&&p(e).then(()=>{P(t)})}typeof document!="undefined"&&(document.addEventListener("click",t=>{let e=f(t),n=e.matches(b);v(t)||!n||it(e)}),document.addEventListener("keydown",t=>{var e;if(t.key==="Enter"&&document.activeElement){let o=document.activeElement,i=b.replace(".","");if(!o.classList.contains(i))return;let r=o.innerText;if(!r)return;p(r).then(()=>{P(o)})}let n=h();t.key==="Escape"&&n&&(E(n),(e=x(n))==null||e.focus())}),window.addEventListener("resize",()=>{let t=h();if(!t)return;let e=t.getAttribute("inline-id")||"",n=document.getElementById(e);if(!n){t.classList.toggle(l);return}T(t,n)}))})();})();
1
+ "use strict";(()=>{(()=>{var q=Object.create,T=Object.defineProperty,U=Object.getOwnPropertyDescriptor,O=Object.getOwnPropertyNames,z=Object.getPrototypeOf,V=Object.prototype.hasOwnProperty,W=(t,e)=>function(){return e||(0,t[O(t)[0]])((e={exports:{}}).exports,e),e.exports},H=(t,e,o,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of O(e))!V.call(t,n)&&n!==o&&T(t,n,{get:()=>e[n],enumerable:!(r=U(e,n))||r.enumerable});return t},K=(t,e,o)=>(o=t!=null?q(z(t)):{},H(e||!t||!t.__esModule?T(o,"default",{value:t,enumerable:!0}):o,t)),Y=W({"node_modules/get-root-node-polyfill/index.js"(t,e){"use strict";function o(c){var s=typeof c=="object"&&!!c.composed;return s?r(this):n(this)}function r(c){var s=n(c);return i(s)?r(s.host):s}function n(c){return c.parentNode!=null?n(c.parentNode):c}function i(c){return c.nodeName==="#document-fragment"&&c.constructor.name==="ShadowRoot"}typeof e=="object"&&e.exports&&(e.exports=o)}}),G=K(Y());typeof document!="undefined"&&(function(t){let e=t.matches||t.matchesSelector||t.webkitMatchesSelector||t.mozMatchesSelector||t.msMatchesSelector||t.oMatchesSelector;e?t.matches=t.matchesSelector=e:t.matches=t.matchesSelector=function(r){let i=(t.getRootNode?t.getRootNode():G.default.call(t)).querySelectorAll(r),c=this;return Array.prototype.some.call(i,s=>s===c)}})(Element.prototype);var g=t=>{let e=t.composedPath();return Array.isArray(e)&&e.length>0?e[0]:t.target},y=t=>{let e=g(t);return!e||!e.matches},E=async t=>{if(!t)return;if(navigator.clipboard&&typeof navigator.clipboard.writeText)return navigator.clipboard.writeText(t);let e=document.createElement("textarea");e.setAttribute("style","position: absolute; left: 1000%"),e.textContent=t,document.body.append(e),e.select(),document.execCommand("copy"),document.body.removeChild(e)},J=".yfm-clipboard-button",X=".yfm-wrapping-button";function Z(t){if(!t)return;let e=t.getAttribute("data-animation"),o=t.getRootNode().getElementById(`visibileAnimation-${e}`);o&&o.beginElement()}function Q(t){var e;let o=(e=t.parentNode)==null?void 0:e.parentNode,r=o==null?void 0:o.querySelector("pre code");if(!o||!r)return;let n=Array.from(r.childNodes).filter(i=>!(i instanceof HTMLElement&&i.classList.contains("yfm-line-number"))).map(i=>i.textContent).join("");E(n.trim()).then(()=>{Z(o.querySelector(".yfm-clipboard-icon")),setTimeout(()=>t.blur(),1500)})}function tt(t){var e;let o=(e=t.parentNode)==null?void 0:e.parentNode,r=o==null?void 0:o.querySelector("pre code");!o||!r||(r.classList.toggle("wrap"),setTimeout(()=>t.blur(),500))}typeof document!="undefined"&&document.addEventListener("click",t=>{if(y(t))return;let e=g(t);e.matches(J)?Q(e):e.matches(X)&&tt(e)});var et=".dc-doc-page__content",x="yfm yfm-tooltip",A="open",_="data-tooltip-id",ot={mainAxis:5},nt={top:"bottom",bottom:"top",left:"right",right:"left"},rt={top:0,bottom:0,left:0,right:0};function L(t){return t==="top"||t==="bottom"}function it(t=0){return typeof t=="number"?{top:t,bottom:t,left:t,right:t}:{...rt,...t}}function w(t){let[e,o]=t.split("-");return{side:e,alignment:o}}function S(t){return nt[t]}function ct(t){let{side:e,alignment:o}=w(t),r=S(e);return o?`${r}-${o}`:r}function C(t,e,o){let r=N(t,{top:e.y,left:e.x});return ft(o,r,5)}function st(t,e,o){let r=S(o);return t[o]>0&&e[r]<t[o]}function ut(t,e,o,r,n,i,c=!0){let s=D(t,e,n,r,i);if(!c)return{coords:s,placement:r};let d=C(e,s,o),{side:l}=w(r);if(d[l]<=0)return{coords:s,placement:r};let p=ct(r),f=D(t,e,n,p,i),a=C(e,f,o);return st(d,a,l)?{coords:f,placement:p}:{coords:s,placement:r}}function lt(){let t=Math.random().toString(36).substring(2,6),e=Date.now().toString(36);return`${t}${e}`}function m(t){return{...t,right:t.left+t.width,bottom:t.top+t.height}}function N(t,e){var o,r,n,i;return m({top:(o=e.top)!=null?o:t.top,left:(r=e.left)!=null?r:t.left,width:(n=e.width)!=null?n:t.width,height:(i=e.height)!=null?i:t.height})}function P(){let{documentElement:t,body:e}=document,o=window.scrollY||t.scrollTop||e.scrollTop,r=window.scrollX||t.scrollLeft||e.scrollLeft,n=t.clientTop||e.clientTop||0,i=t.clientLeft||e.clientLeft||0;return m({top:Math.round(o-n),left:Math.round(r-i),width:document.body.clientWidth,height:document.body.clientHeight})}function R(t){let e=P(),o=t.getBoundingClientRect();return m({top:Math.round(o.top+e.top),left:Math.round(o.left+e.left),width:o.width,height:o.height})}function at(t,e,o){let{mainAxis:r=0,crossAxis:n=0}=t,i=L(e),c=e==="top"||e==="left"?-1:1,s=o&&i?-1:1,d=r*c,l=n*s;return i?{x:l,y:d}:{x:d,y:l}}function D(t,e,o,r,n){let{side:i,alignment:c}=w(r),s=L(i),d=s?"x":"y",l=d==="y"?"height":"width",p=t.left+t.width/2-e.width/2,f=t.top+t.height/2-e.height/2,a=t[l]/2-e[l]/2,u={x:t.left,y:t.top};switch(i){case"top":{u.x=p,u.y=t.top-e.height;break}case"bottom":{u.x=p,u.y=t.top+t.height;break}case"right":{u.x=t.left+t.width,u.y=f;break}case"left":{u.x=t.left-e.width,u.y=f;break}}switch(c){case"start":{u[d]-=a*(n&&s?-1:1);break}case"end":{u[d]+=a*(n&&s?-1:1);break}}let h=at(o,i,n);return u.x+=h.x,u.y+=h.y,u}function dt(t,e){let o=R(e);return m({top:t.top-o.top+e.offsetTop,left:t.left-o.left+e.offsetLeft,width:t.width,height:t.height})}function ft(t,e,o=0){let{top:r,bottom:n,left:i,right:c}=it(o);return{top:t.top-e.top+r,bottom:e.bottom-t.bottom+n,left:t.left-e.left+i,right:e.right-t.right+c}}function I(t={}){let{closeDelay:e=1e3,additionalClassName:o}=t,r=!1,n={currentId:null,timer:null,unsubscribe:null},i=()=>n.currentId?document.getElementById(n.currentId):null,c=()=>n.currentId?k(n.currentId):null,s=()=>{let a=i();n.timer&&(clearTimeout(n.timer),n.timer=null),n.unsubscribe&&(n.unsubscribe(),n.unsubscribe=null),a&&(a.classList.remove(A),mt(a),n.currentId=null)},d=(a,u)=>{s();let h=pt({text:u,className:o}),M=B.bind(null,t,a,h);n.currentId=h.id,ht(h,a),n.unsubscribe=bt(a,M),h.classList.add(A),M(),e>0&&(n.timer=setTimeout(s,e))},l=()=>{let a=i(),u=c();if(a&&!u){s();return}a&&u&&B(t,u,a)};return{get visible(){return!!n.currentId},getActiveReference:c,show:d,hide:s,init:()=>{r||(r=!0,window.addEventListener("scroll",l),window.addEventListener("resize",l))},cleanup:()=>{r&&(r=!1,window.removeEventListener("scroll",l),window.removeEventListener("resize",l))}}}function pt(t){let{text:e,className:o}=t,r=lt(),n=document.createElement("div");return n.id=r,n.className=o?`${x} ${o}`:x,n.setAttribute("role","tooltip"),n.setAttribute("aria-live","polite"),n.textContent=e,n}function ht(t,e){let o=document.querySelector(et)||document.body,r=e.getAttribute("aria-live");e.setAttribute(_,t.id),r&&t.setAttribute("aria-live",r),o.appendChild(t)}function mt(t){if(t.id){let e=k(t.id);e==null||e.removeAttribute(_)}t.remove()}function k(t){return document.querySelector(`[${_}="${t}"]`)}function bt(t,e){let o=gt(t);return o.addEventListener("scroll",e),()=>{o.removeEventListener("scroll",e)}}function gt(t){return t.closest("table")||t.closest("code")||t.parentElement||document.body}function vt(t,e){let o=e.parentElement;if(!o)return null;let r={reference:t,tooltip:e,offsetParent:o},n=P(),i=R(t),{width:c,height:s}=e.getBoundingClientRect();return{isRtl:document.dir==="rtl",viewport:n,reference:i,tooltip:m({top:0,left:0,width:c,height:s}),elements:r}}function B(t,e,o){let r=vt(e,o);if(!r)return;let n=yt(r,t);o.style.top=`${n.y}px`,o.style.left=`${n.x}px`}function yt(t,e){let{placement:o="bottom-start",offset:r=ot,flip:n=!0}=e,{reference:i,tooltip:c,viewport:s,isRtl:d}=t,{coords:l}=ut(i,c,s,o,r,d,n),p=N(c,{top:l.y,left:l.x}),f=dt(p,t.elements.offsetParent);return{x:f.left,y:f.top}}var v={ru:"\u0421\u043A\u043E\u043F\u0438\u0440\u043E\u0432\u0430\u043D\u043E",en:"Copied",ar:"\u062A\u0645 \u0627\u0644\u0646\u0633\u062E",cs:"Zkop\xEDrov\xE1no",fr:"Copi\xE9",es:"Copiado",he:"\u05D4\u05D5\u05E2\u05EA\u05E7",bg:"\u041A\u043E\u043F\u0438\u0440\u0430\u043D\u043E",et:"Kopeeritud",el:"\u0391\u03BD\u03C4\u03B9\u03B3\u03C1\u03AC\u03C6\u03B7\u03BA\u03B5",pt:"Copiado",zh:"\u5DF2\u590D\u5236","zh-tw":"\u5DF2\u8907\u88FD",kk:"\u041A\u04E9\u0448\u0456\u0440\u0456\u043B\u0434\u0456",tr:"Kopyaland\u0131",uz:"Nusxalandi"},Et=/^(?:https?|file):$/,_t=".yfm-clipboard-anchor",F=I();function wt(t){let e=t.nodeName==="A"?t.href:t.dataset.href,o=new URL(e||"",window.location.href);return Et.test(o.protocol)?o.href:window.location.href}typeof document!="undefined"&&(F.init(),document.addEventListener("click",t=>{let e=g(t);if(y(t)||!e.matches(_t))return;let o=wt(e);E(o).then(()=>{var r;let n=document.documentElement.lang||"en",i=(r=v[n])!=null?r:v.en;F.show(e,i)})}));var $="yfm-clipboard-inline-code",Tt=`.${$}`,b=I({additionalClassName:"inline_code_tooltip"});function j(t){let e=t.innerText;e&&E(e).then(()=>{var o;let r=document.documentElement.lang||"en",n=(o=v[r])!=null?o:v.en;b.show(t,n)})}typeof document!="undefined"&&(b.init(),document.addEventListener("click",t=>{let e=g(t),o=e.matches(Tt);y(t)||!o||j(e)}),document.addEventListener("keydown",t=>{if(t.key==="Enter"&&document.activeElement){let e=document.activeElement;if(!e.classList.contains($))return;j(e)}if(t.key==="Escape"&&b.visible){let e=b.getActiveReference();b.hide(),e==null||e.focus()}}))})();})();
7
2
  //# sourceMappingURL=base.min.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
- "sources": ["../../node_modules/get-root-node-polyfill/index.js", "../../src/js/polyfill.js", "../../src/js/utils.ts", "../../src/js/code.ts", "../../src/js/anchor.ts", "../../src/js/inline-code/constant.ts", "../../src/js/term/utils.ts", "../../src/js/inline-code/utils.ts", "../../src/js/inline-code/index.ts"],
4
- "sourcesContent": ["'use strict';\n\n// Node getRootNode(optional GetRootNodeOptions options);\n\n/**\n * Returns the context object\u2019s shadow-including root if options\u2019s composed is true.\n * Returns the context object\u2019s root otherwise.\n *\n * The root of an object is itself, if its parent is null, or else it is the root of its parent.\n *\n * The shadow-including root of an object is its root\u2019s host\u2019s shadow-including root,\n * if the object\u2019s root is a shadow root, and its root otherwise.\n *\n * https://dom.spec.whatwg.org/#dom-node-getrootnode\n *\n * @memberof Node.prototype\n * @param {!Object} [opt = {}] - Options.\n * @param {!boolean} [opt.composed] - See above description.\n * @returns {!Node} The root node.\n */\nfunction getRootNode(opt) {\n var composed = typeof opt === 'object' && Boolean(opt.composed);\n\n return composed ? getShadowIncludingRoot(this) : getRoot(this);\n}\n\nfunction getShadowIncludingRoot(node) {\n var root = getRoot(node);\n\n if (isShadowRoot(root)) {\n return getShadowIncludingRoot(root.host);\n }\n\n return root;\n}\n\nfunction getRoot(node) {\n if (node.parentNode != null) {\n return getRoot(node.parentNode);\n }\n\n return node;\n}\n\nfunction isShadowRoot(node) {\n return node.nodeName === '#document-fragment' && node.constructor.name === 'ShadowRoot';\n}\n\nif (typeof module === 'object' && module.exports) {\n module.exports = getRootNode;\n}\n", "import getRootNode from 'get-root-node-polyfill';\n\nif (typeof document !== 'undefined') {\n // matches polyfill for old edge\n (function (e) {\n const matches =\n e.matches ||\n e.matchesSelector ||\n e.webkitMatchesSelector ||\n e.mozMatchesSelector ||\n e.msMatchesSelector ||\n e.oMatchesSelector;\n\n if (matches) {\n e.matches = e.matchesSelector = matches;\n } else {\n e.matches = e.matchesSelector = function matches(selector) {\n const rootNode = e.getRootNode ? e.getRootNode() : getRootNode.call(e);\n const matches = rootNode.querySelectorAll(selector);\n const th = this;\n return Array.prototype.some.call(matches, (e) => {\n return e === th;\n });\n };\n }\n // eslint-disable-next-line no-undef\n })(Element.prototype);\n}\n", "export const getEventTarget = (event: Event) => {\n const path = event.composedPath();\n return Array.isArray(path) && path.length > 0 ? path[0] : event.target;\n};\n\nexport const isCustom = (event: Event) => {\n const target = getEventTarget(event);\n return !target || !(target as HTMLElement).matches;\n};\n\nexport const copyToClipboard = async (text: string) => {\n if (!text) {\n return;\n }\n\n if (navigator.clipboard && typeof navigator.clipboard.writeText) {\n return navigator.clipboard.writeText(text);\n }\n\n const textarea = document.createElement('textarea');\n textarea.setAttribute('style', 'position: absolute; left: 1000%');\n textarea.textContent = text;\n document.body.append(textarea);\n\n textarea.select();\n document.execCommand('copy');\n\n document.body.removeChild(textarea);\n};\n", "import {copyToClipboard, getEventTarget, isCustom} from './utils';\n\nconst COPY_BUTTON_SELECTOR = '.yfm-clipboard-button';\nconst WRAP_BUTTON_SELECTOR = '.yfm-wrapping-button';\n\nfunction notifySuccess(svgButton: HTMLElement | null) {\n if (!svgButton) {\n return;\n }\n\n const id = svgButton.getAttribute('data-animation');\n\n // @ts-expect-error\n const icon = svgButton.getRootNode().getElementById(`visibileAnimation-${id}`);\n\n if (!icon) {\n return;\n }\n\n icon.beginElement();\n}\n\nfunction buttonCopyFn(target: HTMLElement) {\n const container = target.parentNode?.parentNode;\n const code = container?.querySelector<HTMLElement>('pre code');\n if (!container || !code) {\n return;\n }\n\n // Get all text nodes and filter out line numbers\n const textContent = Array.from(code.childNodes)\n .filter((node) => {\n // Skip line number spans\n if (node instanceof HTMLElement && node.classList.contains('yfm-line-number')) {\n return false;\n }\n return true;\n })\n .map((node) => node.textContent)\n .join('');\n\n copyToClipboard(textContent.trim()).then(() => {\n notifySuccess(container.querySelector('.yfm-clipboard-icon'));\n\n setTimeout(() => target.blur(), 1500);\n });\n}\n\nfunction buttonWrapFn(target: HTMLElement) {\n const container = target.parentNode?.parentNode;\n const code = container?.querySelector<HTMLElement>('pre code');\n if (!container || !code) {\n return;\n }\n\n code.classList.toggle('wrap');\n\n setTimeout(() => target.blur(), 500);\n}\n\nif (typeof document !== 'undefined') {\n document.addEventListener('click', (event) => {\n if (isCustom(event)) {\n return;\n }\n\n const target = getEventTarget(event) as HTMLElement;\n\n if (target.matches(COPY_BUTTON_SELECTOR)) {\n buttonCopyFn(target);\n } else if (target.matches(WRAP_BUTTON_SELECTOR)) {\n buttonWrapFn(target);\n }\n });\n}\n", "import {copyToClipboard, getEventTarget, isCustom} from './utils';\n\nconst ANCHOR_BUTTON_SELECTOR = '.yfm-clipboard-anchor';\n\nif (typeof document !== 'undefined') {\n document.addEventListener('click', (event) => {\n const target = getEventTarget(event) as HTMLElement;\n\n if (isCustom(event) || !target.matches(ANCHOR_BUTTON_SELECTOR)) {\n return;\n }\n\n const href = target.getAttribute('data-href') || '';\n const link = new URL(href, window.location.href).toString();\n\n copyToClipboard(link);\n });\n}\n", "import type {Lang} from 'src/transform/typings';\n\nexport const INLINE_CODE = '.yfm-clipboard-inline-code';\n\nexport const INLINE_CODE_ID = 'tooltip_inline_clipboard_dialog';\n\nexport const INLINE_CODE_CLASS = 'yfm inline_code_tooltip';\n\nexport const OPEN_CLASS = 'open';\n\nexport const LANG_TOKEN: Record<Lang, string> = {\n ru: '\u0421\u043A\u043E\u043F\u0438\u0440\u043E\u0432\u0430\u043D\u043E',\n en: 'Copied',\n ar: '\u062A\u0645 \u0627\u0644\u0646\u0633\u062E',\n cs: 'Zkop\u00EDrov\u00E1no',\n fr: 'Copi\u00E9',\n es: 'Copiado',\n he: '\u05D4\u05D5\u05E2\u05EA\u05E7',\n bg: '\u041A\u043E\u043F\u0438\u0440\u0430\u043D\u043E',\n et: 'Kopeeritud',\n el: '\u0391\u03BD\u03C4\u03B9\u03B3\u03C1\u03AC\u03C6\u03B7\u03BA\u03B5',\n pt: 'Copiado',\n zh: '\u5DF2\u590D\u5236',\n 'zh-tw': '\u5DF2\u8907\u88FD',\n kk: '\u041A\u04E9\u0448\u0456\u0440\u0456\u043B\u0434\u0456',\n tr: 'Kopyaland\u0131',\n uz: 'Nusxalandi',\n};\n", "export const Selector = {\n TITLE: '.yfm .yfm-term_title',\n CONTENT: '.yfm .yfm-term_dfn',\n};\nexport const openClass = 'open';\nexport const openDefinitionClass = Selector.CONTENT.replace(/\\./g, '') + ' ' + openClass;\nlet isListenerNeeded = true;\n\nexport function setDefinitionId(definitionElement: HTMLElement, termElement: HTMLElement): void {\n const termId = termElement.getAttribute('id') || Math.random().toString(36).substr(2, 8);\n definitionElement?.setAttribute('term-id', termId);\n}\n\nexport function setDefinitonAriaAttributes(\n definitionElement: HTMLElement,\n termElement: HTMLElement,\n): void {\n const ariaLive = termElement.getAttribute('aria-live') || 'polite';\n definitionElement?.setAttribute('aria-live', ariaLive);\n definitionElement?.setAttribute('aria-modal', 'true');\n}\n\nexport function setDefinitionPosition(\n definitionElement: HTMLElement,\n termElement: HTMLElement,\n): void {\n const {\n x: termX,\n y: termY,\n right: termRight,\n left: termLeft,\n width: termWidth,\n height: termHeight,\n } = termElement.getBoundingClientRect();\n\n const termParent = termParentElement(termElement);\n\n if (!termParent) {\n return;\n }\n\n const {right: termParentRight, left: termParentLeft} = termParent.getBoundingClientRect();\n\n if ((termParentRight < termLeft || termParentLeft > termRight) && !isListenerNeeded) {\n closeDefinition(definitionElement);\n return;\n }\n\n if (isListenerNeeded && termParent) {\n termParent.addEventListener('scroll', termOnResize);\n isListenerNeeded = false;\n }\n\n const relativeX = Number(definitionElement.getAttribute('relativeX'));\n const relativeY = Number(definitionElement.getAttribute('relativeY'));\n\n if (relativeX === termX && relativeY === termY) {\n return;\n }\n\n definitionElement.setAttribute('relativeX', String(termX));\n definitionElement.setAttribute('relativeY', String(termY));\n\n const offsetTop = termHeight + 5;\n const definitionParent = definitionElement.parentElement;\n\n if (!definitionParent) {\n return;\n }\n\n const {width: definitionWidth} = definitionElement.getBoundingClientRect();\n const {left: definitionParentLeft} = definitionParent.getBoundingClientRect();\n\n // If definition not fit document change base alignment\n const definitionLeftCoordinate = Number(getCoords(termElement).left);\n const definitionRightCoordinate = definitionWidth + definitionLeftCoordinate;\n\n const definitionOutOfScreenOnLeft = definitionLeftCoordinate - definitionWidth < 0;\n const definitionOutOfScreenOnRight = definitionRightCoordinate > document.body.clientWidth;\n\n const isAlignSwapped = definitionOutOfScreenOnRight || document.dir === 'rtl';\n const fitDefinitionDocument =\n isAlignSwapped && !definitionOutOfScreenOnLeft ? definitionWidth - termWidth : 0;\n const customHeaderTop = getCoords(definitionParent).top - definitionParent.offsetTop;\n const offsetRight = 5;\n const shiftLeft = definitionOutOfScreenOnRight\n ? definitionRightCoordinate - document.body.clientWidth + offsetRight\n : 0;\n const offsetLeft =\n getCoords(termElement).left -\n definitionParentLeft +\n definitionParent.offsetLeft -\n fitDefinitionDocument;\n\n const isShiftLeftNeeded = offsetLeft + definitionWidth >= document.body.clientWidth;\n\n definitionElement.style.top =\n Number(getCoords(termElement).top + offsetTop - customHeaderTop) + 'px';\n definitionElement.style.left = Number(offsetLeft - (isShiftLeftNeeded ? shiftLeft : 0)) + 'px';\n}\n\nfunction termOnResize() {\n const openedDefinition = document.getElementsByClassName(openDefinitionClass)[0] as HTMLElement;\n\n if (!openedDefinition) {\n return;\n }\n const termId = openedDefinition.getAttribute('term-id') || '';\n const termElement = document.getElementById(termId);\n\n if (!termElement) {\n return;\n }\n\n setDefinitionPosition(openedDefinition, termElement);\n}\n\nfunction termParentElement(term: HTMLElement | null) {\n if (!term) {\n return null;\n }\n\n const closestScrollableParent = term.closest('table') || term.closest('code');\n\n return closestScrollableParent || term.parentElement;\n}\n\nexport function openDefinition(target: HTMLElement) {\n const openedDefinition = document.getElementsByClassName(openDefinitionClass)[0] as HTMLElement;\n\n const termId = target.getAttribute('id');\n const termKey = target.getAttribute('term-key');\n const definitionId = `${termKey}_element`;\n\n // Check if term is in modal window\n const isInModal = target.closest('.wide-container');\n\n let definitionElement: HTMLElement | null;\n\n if (isInModal) {\n // Find definition in modal window\n const modalContent = target.closest('.wide-content');\n if (!modalContent) {\n return;\n }\n definitionElement = modalContent.querySelector(`[id=\"${definitionId}\"]`) as HTMLElement;\n } else {\n // Find definition in normal document\n definitionElement = document.getElementById(definitionId);\n }\n\n const isSameTerm = openedDefinition && termId === openedDefinition.getAttribute('term-id');\n if (isSameTerm) {\n closeDefinition(openedDefinition);\n return;\n }\n\n const isTargetDefinitionContent = target.closest(\n [Selector.CONTENT.replace(' ', ''), openClass].join('.'),\n );\n\n if (openedDefinition && !isTargetDefinitionContent) {\n closeDefinition(openedDefinition);\n }\n\n if (!target.matches(Selector.TITLE) || !definitionElement) {\n return;\n }\n\n setDefinitionId(definitionElement, target);\n setDefinitonAriaAttributes(definitionElement, target);\n setDefinitionPosition(definitionElement, target);\n\n definitionElement.classList.toggle(openClass);\n\n trapFocus(definitionElement);\n}\n\nexport function closeDefinition(definition: HTMLElement) {\n definition.classList.remove(openClass);\n const term = getTermByDefinition(definition);\n const termParent = termParentElement(term);\n\n if (!termParent) {\n return;\n }\n\n termParent.removeEventListener('scroll', termOnResize);\n isListenerNeeded = true;\n}\n\nexport function getCoords(elem: HTMLElement) {\n const box = elem.getBoundingClientRect();\n\n const body = document.body;\n const docEl = document.documentElement;\n\n const scrollTop = window.pageYOffset || docEl.scrollTop || body.scrollTop;\n const scrollLeft = window.pageXOffset || docEl.scrollLeft || body.scrollLeft;\n\n const clientTop = docEl.clientTop || body.clientTop || 0;\n const clientLeft = docEl.clientLeft || body.clientLeft || 0;\n\n const top = box.top + scrollTop - clientTop;\n const left = box.left + scrollLeft - clientLeft;\n\n return {top: Math.round(top), left: Math.round(left)};\n}\n\nexport function trapFocus(element: HTMLElement) {\n const focusableElements = element.querySelectorAll(\n 'button, [href], input, select, textarea, [tabindex]:not([tabindex=\"-1\"])',\n );\n const firstFocusableElement = focusableElements[0] as HTMLElement;\n const lastFocusableElement = focusableElements[focusableElements.length - 1] as HTMLElement;\n\n if (firstFocusableElement) {\n firstFocusableElement.focus();\n }\n\n element.addEventListener('keydown', function (e) {\n const isTabPressed = e.key === 'Tab' || e.keyCode === 9;\n if (!isTabPressed) {\n return;\n }\n\n if (e.shiftKey) {\n if (document.activeElement === firstFocusableElement) {\n lastFocusableElement.focus();\n e.preventDefault();\n }\n } else if (document.activeElement === lastFocusableElement) {\n firstFocusableElement.focus();\n e.preventDefault();\n }\n });\n}\n\nexport function getTermByDefinition(definition: HTMLElement) {\n const termId = definition.getAttribute('term-id');\n\n if (!termId) {\n return null;\n }\n\n // Check if definition is in modal window\n const isInModal = definition.closest('.wide-container');\n\n if (isInModal) {\n // Find term in modal window\n const modalContent = definition.closest('.wide-content');\n if (!modalContent) {\n return null;\n }\n return modalContent.querySelector(`[id=\"${termId}\"]`) as HTMLElement;\n }\n\n // Find term in normal document\n return document.getElementById(termId);\n}\n", "import type {Lang} from 'src/transform/typings';\n\nimport {getCoords} from '../term/utils';\n\nimport {INLINE_CODE, INLINE_CODE_CLASS, INLINE_CODE_ID, LANG_TOKEN, OPEN_CLASS} from './constant';\n\nexport let timer: ReturnType<typeof setTimeout> | null = null;\n\nlet isListenerNeeded = true;\n\nexport function getTooltipElement(): HTMLElement | null {\n return document.getElementById(INLINE_CODE_ID);\n}\n\nfunction setTooltipAriaAttributes(tooltipElement: HTMLElement, targetElement: HTMLElement): void {\n const ariaLive = targetElement.getAttribute('aria-live') || 'polite';\n tooltipElement?.setAttribute('aria-live', ariaLive);\n tooltipElement?.setAttribute('aria-modal', 'true');\n}\n\nfunction checkTimerAndClear() {\n if (timer) {\n clearTimeout(timer);\n timer = null;\n }\n}\n\nfunction tooltipParentElement(target: HTMLElement | null) {\n if (!target) {\n return null;\n }\n\n const closestScrollableParent = target.closest('table') || target.closest('code');\n\n return closestScrollableParent || target.parentElement;\n}\n\nfunction tooltipOnResize() {\n const openedDefinition = getTooltipElement();\n\n if (!openedDefinition) {\n return;\n }\n const inlineId = openedDefinition.getAttribute('inline-id') || '';\n const targetElement = document.getElementById(inlineId);\n\n if (!targetElement) {\n return;\n }\n\n setTooltipPosition(openedDefinition, targetElement);\n}\n\nexport function setTooltipPosition(tooltipElement: HTMLElement, targetElement: HTMLElement): void {\n const {\n x: inlineX,\n y: inlineY,\n right: inlineRight,\n left: inlineLeft,\n width: inlineWidth,\n height: inlineHeight,\n } = targetElement.getBoundingClientRect();\n\n const tooltipParent = tooltipParentElement(targetElement);\n\n if (!tooltipParent) {\n return;\n }\n\n const {right: tooltipParentRight, left: tooltipParentLeft} =\n tooltipParent.getBoundingClientRect();\n\n if ((tooltipParentRight < inlineLeft || tooltipParentLeft > inlineRight) && !isListenerNeeded) {\n closeTooltip(tooltipElement);\n return;\n }\n\n if (isListenerNeeded && tooltipParent) {\n tooltipParent.addEventListener('scroll', tooltipOnResize);\n isListenerNeeded = false;\n }\n\n const relativeX = Number(tooltipElement.getAttribute('relativeX'));\n const relativeY = Number(tooltipElement.getAttribute('relativeY'));\n\n if (relativeX === inlineX && relativeY === inlineY) {\n return;\n }\n\n tooltipElement.setAttribute('relativeX', String(inlineX));\n tooltipElement.setAttribute('relativeY', String(inlineY));\n\n const offsetTop = inlineHeight + 5;\n const definitionParent = tooltipElement.parentElement;\n\n if (!definitionParent) {\n return;\n }\n\n const {width: definitionWidth} = tooltipElement.getBoundingClientRect();\n const {left: definitionParentLeft} = definitionParent.getBoundingClientRect();\n\n // If definition not fit document change base alignment\n const definitionLeftCoordinate = Number(getCoords(targetElement).left);\n const definitionRightCoordinate = definitionWidth + definitionLeftCoordinate;\n\n const definitionOutOfScreenOnLeft = definitionLeftCoordinate - definitionWidth < 0;\n const definitionOutOfScreenOnRight = definitionRightCoordinate > document.body.clientWidth;\n\n const isAlignSwapped = definitionOutOfScreenOnRight || document.dir === 'rtl';\n const fitDefinitionDocument =\n isAlignSwapped && !definitionOutOfScreenOnLeft ? definitionWidth - inlineWidth : 0;\n const customHeaderTop = getCoords(definitionParent).top - definitionParent.offsetTop;\n const offsetRight = 5;\n const shiftLeft = definitionOutOfScreenOnRight\n ? definitionRightCoordinate - document.body.clientWidth + offsetRight\n : 0;\n const offsetLeft =\n getCoords(targetElement).left -\n definitionParentLeft +\n definitionParent.offsetLeft -\n fitDefinitionDocument;\n\n const isShiftLeftNeeded = offsetLeft + definitionWidth >= document.body.clientWidth;\n\n tooltipElement.style.top =\n Number(getCoords(targetElement).top + offsetTop - customHeaderTop) + 'px';\n tooltipElement.style.left = Number(offsetLeft - (isShiftLeftNeeded ? shiftLeft : 0)) + 'px';\n}\n\nexport function getInlineCodeByTooltip(definition: HTMLElement) {\n const inlineId = definition.getAttribute('inline-id');\n\n return inlineId ? document.getElementById(inlineId) : null;\n}\n\nfunction closeTooltipFn(definition: HTMLElement) {\n definition.classList.remove(OPEN_CLASS);\n const inline = getInlineCodeByTooltip(definition);\n const inlineCodepParent = tooltipParentElement(inline);\n const tooltipParent = tooltipParentElement(definition);\n\n definition.removeAttribute('inline-id');\n\n if (!inlineCodepParent || !tooltipParent) {\n return;\n }\n\n tooltipParent.removeChild(definition);\n inlineCodepParent.removeEventListener('scroll', tooltipOnResize);\n isListenerNeeded = true;\n}\n\nfunction createTooltip() {\n let tooltip = getTooltipElement();\n\n if (!tooltip) {\n const pageContent = document.querySelector('.dc-doc-page__content') || document.body;\n const lang = document.documentElement.lang || 'en';\n const tooltipText = LANG_TOKEN[lang as Lang] ?? LANG_TOKEN.en;\n const host = document.createElement('div');\n\n host.innerHTML = `\n <div id=\"${INLINE_CODE_ID}\" class=\"${INLINE_CODE_CLASS}\"\n role=\"dialog\" aria-live=\"polite\" aria-modal=\"true\">\n ${tooltipText}\n </div>\n `;\n\n tooltip = host.firstElementChild as HTMLElement;\n pageContent.appendChild(tooltip);\n }\n\n return tooltip;\n}\n\nexport function openTooltip(target: HTMLElement) {\n const tooltip = createTooltip();\n\n if (!target.matches(INLINE_CODE) || !tooltip) {\n return;\n }\n\n tooltip.setAttribute('inline-id', target.getAttribute('id') || '');\n setTooltipAriaAttributes(tooltip, target);\n setTooltipPosition(tooltip, target);\n\n // In order not to get rid of the smooth appearance effect, I had to do this\n if (tooltip.classList.contains(OPEN_CLASS)) {\n tooltip.classList.remove(OPEN_CLASS);\n requestAnimationFrame(() => {\n tooltip.classList.add(OPEN_CLASS);\n });\n } else {\n tooltip.classList.add(OPEN_CLASS);\n }\n\n return tooltip;\n}\n\nexport function closeTooltip(target: HTMLElement) {\n checkTimerAndClear();\n closeTooltipFn(target);\n}\n\nexport function tooltipWorker(target: HTMLElement) {\n const definition = openTooltip(target);\n\n if (!definition) {\n return;\n }\n checkTimerAndClear();\n timer = setTimeout(() => {\n closeTooltip(definition);\n timer = null;\n }, 1000);\n}\n", "import {copyToClipboard, getEventTarget, isCustom} from '../utils';\n\nimport {INLINE_CODE, OPEN_CLASS} from './constant';\nimport {\n closeTooltip,\n getInlineCodeByTooltip,\n getTooltipElement,\n setTooltipPosition,\n tooltipWorker,\n} from './utils';\n\nexport function inlineCopyFn(target: HTMLElement) {\n const innerText = target.innerText;\n\n if (!innerText) {\n return;\n }\n\n copyToClipboard(innerText).then(() => {\n tooltipWorker(target);\n });\n}\n\nif (typeof document !== 'undefined') {\n document.addEventListener('click', (event) => {\n const target = getEventTarget(event) as HTMLElement;\n\n const inline = target.matches(INLINE_CODE);\n\n if (isCustom(event) || !inline) {\n return;\n }\n\n inlineCopyFn(target);\n });\n\n document.addEventListener('keydown', (event) => {\n if (event.key === 'Enter' && document.activeElement) {\n const activeElement = document.activeElement as HTMLElement;\n const classInlineCode = INLINE_CODE.replace('.', '');\n\n if (!activeElement.classList.contains(classInlineCode)) {\n return;\n }\n\n const innerText = activeElement.innerText;\n\n if (!innerText) {\n return;\n }\n\n copyToClipboard(innerText).then(() => {\n tooltipWorker(activeElement);\n });\n }\n\n const inlineTooltip = getTooltipElement();\n\n if (event.key === 'Escape' && inlineTooltip) {\n closeTooltip(inlineTooltip);\n getInlineCodeByTooltip(inlineTooltip)?.focus(); // Set focus back to open button after closing popup\n }\n });\n\n window.addEventListener('resize', () => {\n const inlineTooltip = getTooltipElement();\n if (!inlineTooltip) {\n return;\n }\n\n const inlineId = inlineTooltip.getAttribute('inline-id') || '';\n const inlineCodeElement = document.getElementById(inlineId);\n\n if (!inlineCodeElement) {\n inlineTooltip.classList.toggle(OPEN_CLASS);\n return;\n }\n\n setTooltipPosition(inlineTooltip, inlineCodeElement);\n });\n}\n"],
5
- "mappings": "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",
6
- "names": ["require_get_root_node_polyfill", "__commonJS", "exports", "module", "getRootNode", "opt", "composed", "getShadowIncludingRoot", "getRoot", "node", "root", "isShadowRoot", "import_get_root_node_polyfill", "__toESM", "e", "matches", "selector", "th", "getEventTarget", "event", "path", "isCustom", "target", "copyToClipboard", "text", "textarea", "COPY_BUTTON_SELECTOR", "WRAP_BUTTON_SELECTOR", "notifySuccess", "svgButton", "id", "icon", "buttonCopyFn", "_a", "container", "code", "textContent", "buttonWrapFn", "ANCHOR_BUTTON_SELECTOR", "href", "link", "INLINE_CODE", "INLINE_CODE_ID", "INLINE_CODE_CLASS", "OPEN_CLASS", "LANG_TOKEN", "Selector", "openClass", "openDefinitionClass", "getCoords", "elem", "box", "body", "docEl", "scrollTop", "scrollLeft", "clientTop", "clientLeft", "top", "left", "timer", "isListenerNeeded", "getTooltipElement", "setTooltipAriaAttributes", "tooltipElement", "targetElement", "ariaLive", "checkTimerAndClear", "tooltipParentElement", "tooltipOnResize", "openedDefinition", "inlineId", "setTooltipPosition", "inlineX", "inlineY", "inlineRight", "inlineLeft", "inlineWidth", "inlineHeight", "tooltipParent", "tooltipParentRight", "tooltipParentLeft", "closeTooltip", "relativeX", "relativeY", "offsetTop", "definitionParent", "definitionWidth", "definitionParentLeft", "definitionLeftCoordinate", "definitionRightCoordinate", "definitionOutOfScreenOnLeft", "definitionOutOfScreenOnRight", "fitDefinitionDocument", "customHeaderTop", "shiftLeft", "offsetLeft", "isShiftLeftNeeded", "getInlineCodeByTooltip", "definition", "closeTooltipFn", "inline", "inlineCodepParent", "createTooltip", "tooltip", "pageContent", "lang", "tooltipText", "host", "openTooltip", "tooltipWorker", "inlineCopyFn", "innerText", "activeElement", "classInlineCode", "inlineTooltip", "inlineCodeElement"]
3
+ "sources": ["../../node_modules/get-root-node-polyfill/index.js", "../../src/js/polyfill.js", "../../src/js/utils.ts", "../../src/js/code.ts", "../../src/js/tooltip/constant.ts", "../../src/js/tooltip/utils.ts", "../../src/js/tooltip/tooltip.ts", "../../src/js/constant.ts", "../../src/js/anchor.ts", "../../src/js/inline-code/index.ts"],
4
+ "sourcesContent": ["'use strict';\n\n// Node getRootNode(optional GetRootNodeOptions options);\n\n/**\n * Returns the context object\u2019s shadow-including root if options\u2019s composed is true.\n * Returns the context object\u2019s root otherwise.\n *\n * The root of an object is itself, if its parent is null, or else it is the root of its parent.\n *\n * The shadow-including root of an object is its root\u2019s host\u2019s shadow-including root,\n * if the object\u2019s root is a shadow root, and its root otherwise.\n *\n * https://dom.spec.whatwg.org/#dom-node-getrootnode\n *\n * @memberof Node.prototype\n * @param {!Object} [opt = {}] - Options.\n * @param {!boolean} [opt.composed] - See above description.\n * @returns {!Node} The root node.\n */\nfunction getRootNode(opt) {\n var composed = typeof opt === 'object' && Boolean(opt.composed);\n\n return composed ? getShadowIncludingRoot(this) : getRoot(this);\n}\n\nfunction getShadowIncludingRoot(node) {\n var root = getRoot(node);\n\n if (isShadowRoot(root)) {\n return getShadowIncludingRoot(root.host);\n }\n\n return root;\n}\n\nfunction getRoot(node) {\n if (node.parentNode != null) {\n return getRoot(node.parentNode);\n }\n\n return node;\n}\n\nfunction isShadowRoot(node) {\n return node.nodeName === '#document-fragment' && node.constructor.name === 'ShadowRoot';\n}\n\nif (typeof module === 'object' && module.exports) {\n module.exports = getRootNode;\n}\n", "import getRootNode from 'get-root-node-polyfill';\n\nif (typeof document !== 'undefined') {\n // matches polyfill for old edge\n (function (e) {\n const matches =\n e.matches ||\n e.matchesSelector ||\n e.webkitMatchesSelector ||\n e.mozMatchesSelector ||\n e.msMatchesSelector ||\n e.oMatchesSelector;\n\n if (matches) {\n e.matches = e.matchesSelector = matches;\n } else {\n e.matches = e.matchesSelector = function matches(selector) {\n const rootNode = e.getRootNode ? e.getRootNode() : getRootNode.call(e);\n const matches = rootNode.querySelectorAll(selector);\n const th = this;\n return Array.prototype.some.call(matches, (e) => {\n return e === th;\n });\n };\n }\n // eslint-disable-next-line no-undef\n })(Element.prototype);\n}\n", "export const getEventTarget = (event: Event) => {\n const path = event.composedPath();\n return Array.isArray(path) && path.length > 0 ? path[0] : event.target;\n};\n\nexport const isCustom = (event: Event) => {\n const target = getEventTarget(event);\n return !target || !(target as HTMLElement).matches;\n};\n\nexport const copyToClipboard = async (text: string) => {\n if (!text) {\n return;\n }\n\n if (navigator.clipboard && typeof navigator.clipboard.writeText) {\n return navigator.clipboard.writeText(text);\n }\n\n const textarea = document.createElement('textarea');\n textarea.setAttribute('style', 'position: absolute; left: 1000%');\n textarea.textContent = text;\n document.body.append(textarea);\n\n textarea.select();\n document.execCommand('copy');\n\n document.body.removeChild(textarea);\n};\n", "import {copyToClipboard, getEventTarget, isCustom} from './utils';\n\nconst COPY_BUTTON_SELECTOR = '.yfm-clipboard-button';\nconst WRAP_BUTTON_SELECTOR = '.yfm-wrapping-button';\n\nfunction notifySuccess(svgButton: HTMLElement | null) {\n if (!svgButton) {\n return;\n }\n\n const id = svgButton.getAttribute('data-animation');\n\n // @ts-expect-error\n const icon = svgButton.getRootNode().getElementById(`visibileAnimation-${id}`);\n\n if (!icon) {\n return;\n }\n\n icon.beginElement();\n}\n\nfunction buttonCopyFn(target: HTMLElement) {\n const container = target.parentNode?.parentNode;\n const code = container?.querySelector<HTMLElement>('pre code');\n if (!container || !code) {\n return;\n }\n\n // Get all text nodes and filter out line numbers\n const textContent = Array.from(code.childNodes)\n .filter((node) => {\n // Skip line number spans\n if (node instanceof HTMLElement && node.classList.contains('yfm-line-number')) {\n return false;\n }\n return true;\n })\n .map((node) => node.textContent)\n .join('');\n\n copyToClipboard(textContent.trim()).then(() => {\n notifySuccess(container.querySelector('.yfm-clipboard-icon'));\n\n setTimeout(() => target.blur(), 1500);\n });\n}\n\nfunction buttonWrapFn(target: HTMLElement) {\n const container = target.parentNode?.parentNode;\n const code = container?.querySelector<HTMLElement>('pre code');\n if (!container || !code) {\n return;\n }\n\n code.classList.toggle('wrap');\n\n setTimeout(() => target.blur(), 500);\n}\n\nif (typeof document !== 'undefined') {\n document.addEventListener('click', (event) => {\n if (isCustom(event)) {\n return;\n }\n\n const target = getEventTarget(event) as HTMLElement;\n\n if (target.matches(COPY_BUTTON_SELECTOR)) {\n buttonCopyFn(target);\n } else if (target.matches(WRAP_BUTTON_SELECTOR)) {\n buttonWrapFn(target);\n }\n });\n}\n", "import type {OffsetValues, Side, SideObject} from './types';\n\nexport const PAGE_CONTAINER_SELECTOR = '.dc-doc-page__content';\n\nexport const TOOLTIP_BASE_CLASS = 'yfm yfm-tooltip';\n\nexport const TOOLTIP_OPEN_CLASS = 'open';\n\nexport const TOOLTIP_DATA_ATTR = 'data-tooltip-id';\n\nexport const DEFAULT_OFFSET_VALUES: OffsetValues = {mainAxis: 5};\n\nexport const OPPOSITE_SIDES: Record<Side, Side> = {\n top: 'bottom',\n bottom: 'top',\n left: 'right',\n right: 'left',\n};\n\nexport const DEFAULT_SIDE_OBJECT: SideObject = {\n top: 0,\n bottom: 0,\n left: 0,\n right: 0,\n};\n", "import type {\n Alignment,\n Coords,\n ElementRect,\n OffsetValues,\n Placement,\n Side,\n SideObject,\n} from './types';\n\nimport {DEFAULT_SIDE_OBJECT, OPPOSITE_SIDES} from './constant';\n\nfunction isVerticalSide(side: Side): boolean {\n return side === 'top' || side === 'bottom';\n}\n\nfunction createSideObject(value: Partial<SideObject> | number = 0): SideObject {\n if (typeof value === 'number') {\n return {top: value, bottom: value, left: value, right: value};\n }\n\n return {...DEFAULT_SIDE_OBJECT, ...value};\n}\n\nfunction parsePlacement(placement: Placement): {side: Side; alignment?: Alignment} {\n const [side, alignment] = placement.split('-') as [Side, Alignment | undefined];\n\n return {side, alignment};\n}\n\nfunction getOppositeSide(side: Side): Side {\n return OPPOSITE_SIDES[side];\n}\n\nfunction flipPlacement(placement: Placement): Placement {\n const {side, alignment} = parsePlacement(placement);\n const opposite = getOppositeSide(side);\n\n return (alignment ? `${opposite}-${alignment}` : opposite) as Placement;\n}\n\nfunction getOverflow(tooltip: ElementRect, coords: Coords, viewport: ElementRect): SideObject {\n const rect = updateRect(tooltip, {top: coords.y, left: coords.x});\n\n return detectOverflow(viewport, rect, 5);\n}\n\nfunction shouldFlip(overflow: SideObject, flippedOverflow: SideObject, side: Side): boolean {\n const opposite = getOppositeSide(side);\n\n return overflow[side] > 0 && flippedOverflow[opposite] < overflow[side];\n}\n\nexport function computePosition(\n reference: ElementRect,\n tooltip: ElementRect,\n viewport: ElementRect,\n placement: Placement,\n offset: OffsetValues,\n isRtl: boolean,\n flip = true,\n): {coords: Coords; placement: Placement} {\n const coords = computeCoordsFromPlacement(reference, tooltip, offset, placement, isRtl);\n\n if (!flip) {\n return {coords, placement};\n }\n\n const overflow = getOverflow(tooltip, coords, viewport);\n const {side} = parsePlacement(placement);\n\n if (overflow[side] <= 0) {\n return {coords, placement};\n }\n\n const flipped = flipPlacement(placement);\n const flippedCoords = computeCoordsFromPlacement(reference, tooltip, offset, flipped, isRtl);\n const flippedOverflow = getOverflow(tooltip, flippedCoords, viewport);\n\n if (shouldFlip(overflow, flippedOverflow, side)) {\n return {coords: flippedCoords, placement: flipped};\n }\n\n return {coords, placement};\n}\n\nexport function generateId() {\n const random = Math.random().toString(36).substring(2, 6);\n const now = Date.now().toString(36);\n\n return `${random}${now}`;\n}\n\nexport function createRect(\n params: Pick<ElementRect, 'top' | 'left' | 'width' | 'height'>,\n): ElementRect {\n return {\n ...params,\n right: params.left + params.width,\n bottom: params.top + params.height,\n };\n}\n\nexport function updateRect(rect: ElementRect, params: Partial<ElementRect>): ElementRect {\n return createRect({\n top: params.top ?? rect.top,\n left: params.left ?? rect.left,\n width: params.width ?? rect.width,\n height: params.height ?? rect.height,\n });\n}\n\nexport function getViewportRect(): ElementRect {\n const {documentElement, body} = document;\n\n const scrollTop = window.scrollY || documentElement.scrollTop || body.scrollTop;\n const scrollLeft = window.scrollX || documentElement.scrollLeft || body.scrollLeft;\n\n const clientTop = documentElement.clientTop || body.clientTop || 0;\n const clientLeft = documentElement.clientLeft || body.clientLeft || 0;\n\n return createRect({\n top: Math.round(scrollTop - clientTop),\n left: Math.round(scrollLeft - clientLeft),\n width: document.body.clientWidth,\n height: document.body.clientHeight,\n });\n}\n\nexport function getElementRect(element: HTMLElement): ElementRect {\n const viewport = getViewportRect();\n const box = element.getBoundingClientRect();\n\n return createRect({\n top: Math.round(box.top + viewport.top),\n left: Math.round(box.left + viewport.left),\n width: box.width,\n height: box.height,\n });\n}\n\nexport function computeAxisOffset(offset: OffsetValues, side: Side, isRtl?: boolean): Coords {\n const {mainAxis = 0, crossAxis = 0} = offset;\n\n const isVertical = isVerticalSide(side);\n const mainDirection = side === 'top' || side === 'left' ? -1 : 1;\n const crossDirection = isRtl && isVertical ? -1 : 1;\n\n const mainOffset = mainAxis * mainDirection;\n const crossOffset = crossAxis * crossDirection;\n\n if (isVertical) {\n return {x: crossOffset, y: mainOffset};\n }\n\n return {x: mainOffset, y: crossOffset};\n}\n\nexport function computeCoordsFromPlacement(\n reference: ElementRect,\n tooltip: ElementRect,\n offset: OffsetValues,\n placement: Placement,\n isRtl: boolean,\n) {\n const {side, alignment} = parsePlacement(placement);\n const isVertical = isVerticalSide(side);\n const alignmentAxis = isVertical ? 'x' : 'y';\n const alignLength = alignmentAxis === 'y' ? 'height' : 'width';\n\n const centerX = reference.left + reference.width / 2 - tooltip.width / 2;\n const centerY = reference.top + reference.height / 2 - tooltip.height / 2;\n const alignmentOffset = reference[alignLength] / 2 - tooltip[alignLength] / 2;\n\n const coords: Coords = {x: reference.left, y: reference.top};\n\n switch (side) {\n case 'top': {\n coords.x = centerX;\n coords.y = reference.top - tooltip.height;\n break;\n }\n\n case 'bottom': {\n coords.x = centerX;\n coords.y = reference.top + reference.height;\n break;\n }\n\n case 'right': {\n coords.x = reference.left + reference.width;\n coords.y = centerY;\n break;\n }\n\n case 'left': {\n coords.x = reference.left - tooltip.width;\n coords.y = centerY;\n break;\n }\n }\n\n switch (alignment) {\n case 'start': {\n coords[alignmentAxis] -= alignmentOffset * (isRtl && isVertical ? -1 : 1);\n break;\n }\n\n case 'end': {\n coords[alignmentAxis] += alignmentOffset * (isRtl && isVertical ? -1 : 1);\n break;\n }\n }\n\n const axisOffset = computeAxisOffset(offset, side, isRtl);\n\n coords.x += axisOffset.x;\n coords.y += axisOffset.y;\n\n return coords;\n}\n\nexport function convertToRelativeToOffsetParentRect(rect: ElementRect, offsetParent: HTMLElement) {\n const offsetRect = getElementRect(offsetParent);\n\n return createRect({\n top: rect.top - offsetRect.top + offsetParent.offsetTop,\n left: rect.left - offsetRect.left + offsetParent.offsetLeft,\n width: rect.width,\n height: rect.height,\n });\n}\n\nexport function detectOverflow(\n boundary: ElementRect,\n element: ElementRect,\n padding: Partial<SideObject> | number = 0,\n): SideObject {\n const {top, bottom, left, right} = createSideObject(padding);\n\n return {\n top: boundary.top - element.top + top,\n bottom: element.bottom - boundary.bottom + bottom,\n left: boundary.left - element.left + left,\n right: element.right - boundary.right + right,\n };\n}\n", "import type {\n Coords,\n TooltipContext,\n TooltipContextElements,\n TooltipElementOptions,\n TooltipOptions,\n} from './types';\n\nimport {\n DEFAULT_OFFSET_VALUES,\n PAGE_CONTAINER_SELECTOR,\n TOOLTIP_BASE_CLASS,\n TOOLTIP_DATA_ATTR,\n TOOLTIP_OPEN_CLASS,\n} from './constant';\nimport {\n computePosition,\n convertToRelativeToOffsetParentRect,\n createRect,\n generateId,\n getElementRect,\n getViewportRect,\n updateRect,\n} from './utils';\n\ninterface TooltipState {\n currentId: string | null;\n timer: ReturnType<typeof setTimeout> | null;\n unsubscribe: (() => void) | null;\n}\n\nexport function createTooltipFactory(options: TooltipOptions = {}) {\n const {closeDelay = 1_000, additionalClassName} = options;\n let initialized = false;\n\n const state: TooltipState = {\n currentId: null,\n timer: null,\n unsubscribe: null,\n };\n\n const getActiveTooltip = () => {\n if (!state.currentId) {\n return null;\n }\n\n return document.getElementById(state.currentId);\n };\n\n const getActiveReference = () => {\n if (!state.currentId) {\n return null;\n }\n\n return getReferenceByTooltipId(state.currentId);\n };\n\n const hide = () => {\n const tooltip = getActiveTooltip();\n\n if (state.timer) {\n clearTimeout(state.timer);\n state.timer = null;\n }\n\n if (state.unsubscribe) {\n state.unsubscribe();\n state.unsubscribe = null;\n }\n\n if (tooltip) {\n tooltip.classList.remove(TOOLTIP_OPEN_CLASS);\n detachTooltip(tooltip);\n\n state.currentId = null;\n }\n };\n\n const show = (reference: HTMLElement, text: string) => {\n hide();\n\n const tooltip = createTooltipElement({text, className: additionalClassName});\n const update = updateTooltipPosition.bind(null, options, reference, tooltip);\n\n state.currentId = tooltip.id;\n\n attachTooltip(tooltip, reference);\n\n state.unsubscribe = subscribeToScroll(reference, update);\n\n tooltip.classList.add(TOOLTIP_OPEN_CLASS);\n\n update();\n\n if (closeDelay > 0) {\n state.timer = setTimeout(hide, closeDelay);\n }\n };\n\n const handleUpdate = () => {\n const activeTooltip = getActiveTooltip();\n const activeReference = getActiveReference();\n\n if (activeTooltip && !activeReference) {\n hide();\n return;\n }\n\n if (activeTooltip && activeReference) {\n updateTooltipPosition(options, activeReference, activeTooltip);\n }\n };\n\n const init = () => {\n if (!initialized) {\n initialized = true;\n\n window.addEventListener('scroll', handleUpdate);\n window.addEventListener('resize', handleUpdate);\n }\n };\n\n const cleanup = () => {\n if (initialized) {\n initialized = false;\n\n window.removeEventListener('scroll', handleUpdate);\n window.removeEventListener('resize', handleUpdate);\n }\n };\n\n return {\n get visible() {\n return Boolean(state.currentId);\n },\n getActiveReference,\n show,\n hide,\n init,\n cleanup,\n };\n}\n\nfunction createTooltipElement(options: TooltipElementOptions) {\n const {text, className} = options;\n\n const id = generateId();\n const tooltip = document.createElement('div');\n\n tooltip.id = id;\n tooltip.className = className ? `${TOOLTIP_BASE_CLASS} ${className}` : TOOLTIP_BASE_CLASS;\n\n tooltip.setAttribute('role', 'tooltip');\n tooltip.setAttribute('aria-live', 'polite');\n\n tooltip.textContent = text;\n\n return tooltip;\n}\n\nfunction attachTooltip(tooltip: HTMLElement, reference: HTMLElement) {\n const container = document.querySelector(PAGE_CONTAINER_SELECTOR) || document.body;\n const ariaLive = reference.getAttribute('aria-live');\n\n reference.setAttribute(TOOLTIP_DATA_ATTR, tooltip.id);\n\n if (ariaLive) {\n tooltip.setAttribute('aria-live', ariaLive);\n }\n\n container.appendChild(tooltip);\n}\n\nfunction detachTooltip(tooltip: HTMLElement) {\n if (tooltip.id) {\n const reference = getReferenceByTooltipId(tooltip.id);\n\n reference?.removeAttribute(TOOLTIP_DATA_ATTR);\n }\n\n tooltip.remove();\n}\n\nfunction getReferenceByTooltipId(id: string) {\n return document.querySelector<HTMLElement>(`[${TOOLTIP_DATA_ATTR}=\"${id}\"]`);\n}\n\nfunction subscribeToScroll(reference: HTMLElement, update: () => void) {\n const scrollableElement = getParentScrollableElement(reference);\n\n scrollableElement.addEventListener('scroll', update);\n\n return () => {\n scrollableElement.removeEventListener('scroll', update);\n };\n}\n\nfunction getParentScrollableElement(target: HTMLElement) {\n const closestScrollableParent = target.closest('table') || target.closest('code');\n\n return closestScrollableParent || target.parentElement || document.body;\n}\n\nfunction createTooltipContext(\n referenceElement: HTMLElement,\n tooltipElement: HTMLElement,\n): TooltipContext | null {\n const tooltipParent = tooltipElement.parentElement;\n\n if (!tooltipParent) {\n return null;\n }\n\n const elements: TooltipContextElements = {\n reference: referenceElement,\n tooltip: tooltipElement,\n offsetParent: tooltipParent,\n };\n\n const viewport = getViewportRect();\n const reference = getElementRect(referenceElement);\n const {width, height} = tooltipElement.getBoundingClientRect();\n\n return {\n isRtl: document.dir === 'rtl',\n viewport,\n reference,\n tooltip: createRect({top: 0, left: 0, width, height}),\n elements,\n };\n}\n\nfunction updateTooltipPosition(\n options: TooltipOptions,\n referenceElement: HTMLElement,\n tooltipElement: HTMLElement,\n) {\n const context = createTooltipContext(referenceElement, tooltipElement);\n\n if (!context) {\n return;\n }\n\n const coords = getTooltipCoords(context, options);\n\n tooltipElement.style.top = `${coords.y}px`;\n tooltipElement.style.left = `${coords.x}px`;\n}\n\nfunction getTooltipCoords(context: TooltipContext, options: TooltipOptions): Coords {\n const {placement = 'bottom-start', offset = DEFAULT_OFFSET_VALUES, flip = true} = options;\n const {reference, tooltip, viewport, isRtl} = context;\n\n const {coords} = computePosition(reference, tooltip, viewport, placement, offset, isRtl, flip);\n\n const rect = updateRect(tooltip, {top: coords.y, left: coords.x});\n const relativeRect = convertToRelativeToOffsetParentRect(rect, context.elements.offsetParent);\n\n return {\n x: relativeRect.left,\n y: relativeRect.top,\n };\n}\n", "import type {Lang} from 'src/transform/typings';\n\nexport const COPIED_LANG_TOKEN: Record<Lang, string> = {\n ru: '\u0421\u043A\u043E\u043F\u0438\u0440\u043E\u0432\u0430\u043D\u043E',\n en: 'Copied',\n ar: '\u062A\u0645 \u0627\u0644\u0646\u0633\u062E',\n cs: 'Zkop\u00EDrov\u00E1no',\n fr: 'Copi\u00E9',\n es: 'Copiado',\n he: '\u05D4\u05D5\u05E2\u05EA\u05E7',\n bg: '\u041A\u043E\u043F\u0438\u0440\u0430\u043D\u043E',\n et: 'Kopeeritud',\n el: '\u0391\u03BD\u03C4\u03B9\u03B3\u03C1\u03AC\u03C6\u03B7\u03BA\u03B5',\n pt: 'Copiado',\n zh: '\u5DF2\u590D\u5236',\n 'zh-tw': '\u5DF2\u8907\u88FD',\n kk: '\u041A\u04E9\u0448\u0456\u0440\u0456\u043B\u0434\u0456',\n tr: 'Kopyaland\u0131',\n uz: 'Nusxalandi',\n};\n", "import type {Lang} from 'src/transform/typings';\n\nimport {createTooltipFactory} from './tooltip';\nimport {copyToClipboard, getEventTarget, isCustom} from './utils';\nimport {COPIED_LANG_TOKEN} from './constant';\n\nconst ALLOWED_PROTOCOL_RE = /^(?:https?|file):$/;\nconst ANCHOR_BUTTON_SELECTOR = '.yfm-clipboard-anchor';\n\nconst tooltip = createTooltipFactory();\n\nfunction getLink(target: HTMLElement) {\n const href = target.nodeName === 'A' ? (target as HTMLAnchorElement).href : target.dataset.href;\n const link = new URL(href || '', window.location.href);\n\n if (ALLOWED_PROTOCOL_RE.test(link.protocol)) {\n return link.href;\n }\n\n return window.location.href;\n}\n\nif (typeof document !== 'undefined') {\n tooltip.init();\n\n document.addEventListener('click', (event) => {\n const target = getEventTarget(event) as HTMLElement;\n\n if (isCustom(event) || !target.matches(ANCHOR_BUTTON_SELECTOR)) {\n return;\n }\n\n const link = getLink(target);\n\n copyToClipboard(link).then(() => {\n const lang = document.documentElement.lang || 'en';\n const tooltipText = COPIED_LANG_TOKEN[lang as Lang] ?? COPIED_LANG_TOKEN.en;\n\n tooltip.show(target, tooltipText);\n });\n });\n}\n", "import type {Lang} from 'src/transform/typings';\n\nimport {createTooltipFactory} from '../tooltip';\nimport {copyToClipboard, getEventTarget, isCustom} from '../utils';\nimport {COPIED_LANG_TOKEN} from '../constant';\n\nconst CLASS_INLINE_CODE = 'yfm-clipboard-inline-code';\nconst INLINE_CODE = `.${CLASS_INLINE_CODE}`;\n\nconst tooltip = createTooltipFactory({\n // NOTE: Add additional className for backward capability\n additionalClassName: 'inline_code_tooltip',\n});\n\nexport function inlineCopyFn(target: HTMLElement) {\n const innerText = target.innerText;\n\n if (!innerText) {\n return;\n }\n\n copyToClipboard(innerText).then(() => {\n const lang = document.documentElement.lang || 'en';\n const tooltipText = COPIED_LANG_TOKEN[lang as Lang] ?? COPIED_LANG_TOKEN.en;\n\n tooltip.show(target, tooltipText);\n });\n}\n\nif (typeof document !== 'undefined') {\n tooltip.init();\n\n document.addEventListener('click', (event) => {\n const target = getEventTarget(event) as HTMLElement;\n const inline = target.matches(INLINE_CODE);\n\n if (isCustom(event) || !inline) {\n return;\n }\n\n inlineCopyFn(target);\n });\n\n document.addEventListener('keydown', (event) => {\n if (event.key === 'Enter' && document.activeElement) {\n const activeElement = document.activeElement as HTMLElement;\n\n if (!activeElement.classList.contains(CLASS_INLINE_CODE)) {\n return;\n }\n\n inlineCopyFn(activeElement);\n }\n\n if (event.key === 'Escape' && tooltip.visible) {\n const reference = tooltip.getActiveReference();\n\n tooltip.hide();\n // Set focus back to open button after closing popup\n reference?.focus();\n }\n });\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["require_get_root_node_polyfill", "__commonJS", "exports", "module", "getRootNode", "opt", "composed", "getShadowIncludingRoot", "getRoot", "node", "root", "isShadowRoot", "import_get_root_node_polyfill", "__toESM", "e", "matches", "selector", "th", "getEventTarget", "event", "path", "isCustom", "target", "copyToClipboard", "text", "textarea", "COPY_BUTTON_SELECTOR", "WRAP_BUTTON_SELECTOR", "notifySuccess", "svgButton", "id", "icon", "buttonCopyFn", "_a", "container", "code", "textContent", "buttonWrapFn", "PAGE_CONTAINER_SELECTOR", "TOOLTIP_BASE_CLASS", "TOOLTIP_OPEN_CLASS", "TOOLTIP_DATA_ATTR", "DEFAULT_OFFSET_VALUES", "OPPOSITE_SIDES", "DEFAULT_SIDE_OBJECT", "isVerticalSide", "side", "createSideObject", "value", "parsePlacement", "placement", "alignment", "getOppositeSide", "flipPlacement", "opposite", "getOverflow", "tooltip", "coords", "viewport", "rect", "updateRect", "detectOverflow", "shouldFlip", "overflow", "flippedOverflow", "computePosition", "reference", "offset", "isRtl", "flip", "computeCoordsFromPlacement", "flipped", "flippedCoords", "generateId", "random", "now", "createRect", "params", "_b", "_c", "_d", "getViewportRect", "documentElement", "body", "scrollTop", "scrollLeft", "clientTop", "clientLeft", "getElementRect", "element", "box", "computeAxisOffset", "mainAxis", "crossAxis", "isVertical", "mainDirection", "crossDirection", "mainOffset", "crossOffset", "alignmentAxis", "alignLength", "centerX", "centerY", "alignmentOffset", "axisOffset", "convertToRelativeToOffsetParentRect", "offsetParent", "offsetRect", "boundary", "padding", "top", "bottom", "left", "right", "createTooltipFactory", "options", "closeDelay", "additionalClassName", "initialized", "state", "getActiveTooltip", "getActiveReference", "getReferenceByTooltipId", "hide", "detachTooltip", "show", "createTooltipElement", "update", "updateTooltipPosition", "attachTooltip", "subscribeToScroll", "handleUpdate", "activeTooltip", "activeReference", "className", "ariaLive", "scrollableElement", "getParentScrollableElement", "createTooltipContext", "referenceElement", "tooltipElement", "tooltipParent", "elements", "width", "height", "context", "getTooltipCoords", "relativeRect", "COPIED_LANG_TOKEN", "ALLOWED_PROTOCOL_RE", "ANCHOR_BUTTON_SELECTOR", "getLink", "href", "link", "lang", "tooltipText", "CLASS_INLINE_CODE", "INLINE_CODE", "inlineCopyFn", "innerText", "inline", "activeElement"]
7
7
  }