UNPKG

@redocly/graphql-docs

Version:

Redocly GraphQL docs

40 lines (37 loc) 1.77 kB
import{jsx as e,Fragment as d,jsxs as a}from"react/jsx-runtime";import{memo as p,useCallback as m}from"react";import{DownloadIcon as f,GraphqlIcon as w,JsonIcon as x,Button as g,FileIcon as b}from"@redocly/theme";import{styled as r}from"../../../styled-components.js";import{useDownloadInfo as h}from"./useDownloadInfo.js";import{useTelemetry as u}from"../../../hooks/index.js";function v({downloadUrls:i}){const s=u(),n=h({downloadUrls:i}),l=m(o=>{switch(o){case"gql":return e(w,{});case"json":return e(x,{});default:return e(b,{})}},[]);return n?e(k,{children:(n||[]).map(({title:o,url:t,iconType:c})=>a(y,{onClick:()=>{s.sendGraphqlDocsDownloadDefinitionClickedMessage()},children:[a(j,{children:[l(c),e("a",{href:t,target:"_blank",download:!0,rel:"noreferrer",children:o})]}),e("a",{href:t,target:"_blank",download:!0,rel:"noreferrer",children:e(g,{variant:"text",size:"small",icon:e(f,{})})})]},o))}):e(d,{})}const z=p(v),y=r.div` display: flex; align-items: baseline; justify-content: space-between; width: 100%; border-bottom: 1px solid var(--border-color-secondary); padding-bottom: var(--spacing-sm); :last-of-type { padding-bottom: 0px; border-bottom: none; } `,j=r.span` display: flex; width: calc(100% - 25px); gap: var(--spacing-xs); align-items: center; svg { flex-shrink: 0; } a { width: 100%; color: var(--text-color-primary); word-break: break-word; text-decoration: none; text-overflow: ellipsis; overflow: hidden; white-space: nowrap; } `,k=r.div` display: flex; align-items: center; align-self: flex-start; justify-content: space-between; flex-direction: column; gap: var(--spacing-sm); font-size: var(--font-size-base); `;export{z as DownloadSpecification};