@digi-frontend/dgate-api-documentation 1.0.94 → 1.0.96

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.
@@ -1,2 +1,2 @@
1
- import{j as e}from"../../../../../_virtual/jsx-runtime.js";import s from"../../../../components/SVGLoader/SVGLoader.js";import l from"../../../../assets/icons/DownArrow.svg.js";import i from"../../../../assets/icons/RequestOption.svg.js";import a from"../../../../assets/icons/ArrowBack.svg.js";import o from"../../../../assets/icons/arrow-down.svg.js";import d from"../../../../assets/icons/newCopyIcon.svg.js";import r from"../../../../assets/icons/arrow-up.svg.js";import{d as t}from"../../../../../_virtual/index3.js";import{useState as n,useEffect as c,useMemo as v}from"react";import{handleStatusColor as h}from"../../../../helpers/methodAccordion.helper.js";import{httpStatusCodes as m}from"../../../../constants/index.js";import u from"../../../../components/Tooltip/Tooltip.js";import{useSectionToggle as p,SectionEnum as j}from"../../../../context/SectionToggleContext.js";import{copyToClipboard as x,capitalizeFirstLetter as b}from"../../../../utils/index.js";const N=({data:N,setActiveType:y,setActiveItemData:f})=>{var g,C,w,k,S,q,O,T;const[R,A]=n("header"),{toggleSection:E}=p(),[L,$]=n((null===(w=null===(C=null===(g=null==N?void 0:N.api)||void 0===g?void 0:g.servers)||void 0===C?void 0:C[0])||void 0===w?void 0:w.url)||""),[I,V]=n(!1);c(()=>{var e,s,l;$((null===(l=null===(s=null===(e=null==N?void 0:N.api)||void 0===e?void 0:e.servers)||void 0===s?void 0:s[0])||void 0===l?void 0:l.url)||"")},[N]),v(()=>{var e,s,l;const i=null===(l=null===(s=null===(e=N.api)||void 0===e?void 0:e.servers)||void 0===s?void 0:s.filter(e=>"/"!==e.url)[0])||void 0===l?void 0:l.url,a=null==N?void 0:N.path.split("/").slice(2);return`${i}${(null==a?void 0:a.length)?"/"+a.join("/"):""}`},[N]);const z=m.map(s=>({label:e.jsxs("div",{className:"statusCodeOptionContainer",children:[e.jsx("div",{className:"statusCodeOptionCircle",style:{backgroundColor:h(s)}}),e.jsx("span",{children:s})]}),value:s})),[D,_]=n(null),[B,G]=n(z[4]),[H,P]=n({});return((null==N?void 0:N.parameters)||[]).filter(e=>{var s;return(null===(s=e.in)||void 0===s?void 0:s.toLowerCase())===R.toLowerCase()}),c(()=>{if(B&&B.value){const e=null==N?void 0:N.responses[B.value];P(null==e?void 0:e.headers)}},[B,null==N?void 0:N.responses]),e.jsxs("div",{className:"api-details-expanded",children:[e.jsxs("div",{className:"test-button",children:[e.jsx("button",{className:"back-button",onClick:()=>{E(N.api.apiSpecId,[{type:j.OVERVIEW,setTo:!0}],{resetOthers:!0,filterKeys:[j.RESOURCE]}),y("OVERVIEW"),f(N.api)},children:e.jsx(s,{src:a})}),e.jsx(u,{content:"Comming soon",children:e.jsx("button",{className:"disabled",children:"Test"})})]}),e.jsx("h3",{children:N.api.title}),e.jsx("h1",{className:"api-title",children:null==N?void 0:N.summary}),e.jsx("div",{className:"url-box",children:e.jsxs("div",{className:"url-box_text-container",children:[e.jsx("span",{className:`method-label ${null===(k=null==N?void 0:N.method)||void 0===k?void 0:k.toLowerCase()}`,children:N.method}),e.jsxs("div",{className:"url-container",children:[e.jsxs("div",{className:"type-ddl",onClick:()=>V(e=>!e),children:[e.jsx("span",{className:"url-text",children:`${L}${N.path}`}),e.jsxs("div",{className:"icon-container",children:[0!==L.length&&e.jsx(s,{className:"icon",role:"button",tabIndex:0,onClick:e=>{e.stopPropagation(),x(L)},src:d}),0!==L.length&&e.jsx(s,{src:I?r:o})]})]}),I&&0!==L.length&&e.jsx("div",{className:"url-list",children:null===(q=null===(S=N.api)||void 0===S?void 0:S.servers)||void 0===q?void 0:q.map((s,l)=>e.jsxs("div",{className:"url-item",onClick:()=>{$(s.url),V(!1)},children:[e.jsx("input",{type:"radio",name:"api-method",checked:L===s.url,readOnly:!0}),e.jsx("span",{children:`${s.url}${N.path}`})]},l))})]})]})}),e.jsx("p",{className:"api-desc",children:(null==N?void 0:N.description)||"No Description"}),e.jsx("h3",{children:"Request"}),e.jsxs("div",{className:"request-section",children:[e.jsx("div",{className:"request-tabs",children:["header","path","query"].map(l=>e.jsxs("button",{className:"tab "+(R===l?"active":""),onClick:()=>A(l),children:[e.jsx(s,{src:i,className:"icon-left"}),e.jsx("span",{className:"tab-label",children:"requestBody"===l?"Request Body":l.charAt(0).toUpperCase()+l.slice(1)})]},l))}),e.jsx("div",{className:"table-wrapper",children:e.jsxs("table",{className:"param-table",children:[e.jsx("thead",{children:e.jsxs("tr",{children:[e.jsx("th",{className:"head-table-label",children:"Parameter Name"}),e.jsx("th",{className:"head-table-label",children:"Required"}),e.jsx("th",{className:"head-table-label",children:"Type"}),e.jsx("th",{className:"head-table-label",children:"Enum"}),e.jsx("th",{className:"head-table-label",children:"Description"})]})}),e.jsx("tbody",{children:null===(O=N.parameters)||void 0===O?void 0:O.filter(e=>{var s;return(null===(s=e.in)||void 0===s?void 0:s.toLowerCase())===R.toLowerCase()}).map((i,a)=>{var o,d,r,t,n,c,v;return e.jsxs("tr",{children:[e.jsx("td",{children:i.name}),e.jsx("td",{children:i.required?"True":"False"}),e.jsxs("td",{style:{textTransform:"capitalize"},children:[e.jsx("span",{children:(null===(o=null==i?void 0:i.schema)||void 0===o?void 0:o.type)||"-"}),"array"===(null===(d=null==i?void 0:i.schema)||void 0===d?void 0:d.type)&&(null===(t=null===(r=null==i?void 0:i.schema)||void 0===r?void 0:r.items)||void 0===t?void 0:t.type)&&e.jsxs("span",{style:{color:"#616874",fontSize:"0.75rem"},children:["_",b(null===(c=null===(n=i.schema)||void 0===n?void 0:n.items)||void 0===c?void 0:c.type)]})]}),e.jsx("td",{children:Array.isArray(null===(v=i.schema)||void 0===v?void 0:v.enum)?i.schema.enum.join(" / "):"-"}),e.jsxs("td",{className:"desc-cell",children:[e.jsx("div",{className:"desc-text "+(D===a?"expanded":""),children:i.description||"No description"}),e.jsx("button",{className:"desc-toggle",onClick:()=>_(D===a?null:a),children:e.jsx(s,{src:l,className:D===a?"rotated":""})})]})]},a)})})]})})]}),e.jsxs("div",{className:"response-section",children:[e.jsx("h3",{children:"Response"}),e.jsxs("div",{children:[e.jsx("div",{style:{height:"0.5rem",width:"7.5rem",marginLeft:"auto"},children:(null===(T=Object.keys((null==N?void 0:N.responses)||{}))||void 0===T?void 0:T.length)>0&&e.jsx("div",{className:"codeboxSection",children:e.jsx("div",{className:"codeboxHeader",children:e.jsx(t.SelectGroup,{size:"small",withSearch:!1,isMultiple:!1,clearable:!1,placeholder:"200",options:[{list:z}],value:B,onChange:e=>{G(e)}})})})}),e.jsxs("button",{className:"tab active ",children:[e.jsx(s,{src:i,className:"icon-left"}),"Header"]})]}),e.jsx("div",{className:"table-wrapper",children:e.jsxs("table",{className:"param-table",children:[e.jsx("thead",{children:e.jsxs("tr",{children:[e.jsx("th",{className:"head-table-label",children:"Header Name"}),e.jsx("th",{className:"head-table-label",children:"Required"}),e.jsx("th",{className:"head-table-label",children:"Type"}),e.jsx("th",{className:"head-table-label",children:"Enum"}),e.jsx("th",{className:"head-table-label",children:"Description"})]})}),e.jsx("tbody",{children:!!H&&Object.keys(H)&&Object.keys(H).map(s=>{var l,i,a,o,d,r,t,n,c,v,h,m,u,p,j;return e.jsxs("tr",{children:[e.jsx("td",{children:s}),e.jsx("td",{children:null===(l=H[s])||void 0===l?void 0:l.required.toString()}),e.jsxs("td",{style:{textTransform:"capitalize"},children:[e.jsx("span",{children:(null===(a=null===(i=H[s])||void 0===i?void 0:i.schema)||void 0===a?void 0:a.type)||"-"}),"array"===(null===(d=null===(o=H[s])||void 0===o?void 0:o.schema)||void 0===d?void 0:d.type)&&(null===(n=null===(t=null===(r=H[s])||void 0===r?void 0:r.schema)||void 0===t?void 0:t.items)||void 0===n?void 0:n.type)&&e.jsxs("span",{style:{color:"#616874",fontSize:"0.75rem"},children:["_",b(null===(h=null===(v=null===(c=H[s])||void 0===c?void 0:c.schema)||void 0===v?void 0:v.items)||void 0===h?void 0:h.type)]})]}),e.jsx("td",{children:null===(p=null===(u=null===(m=H[s])||void 0===m?void 0:m.schema)||void 0===u?void 0:u.enum)||void 0===p?void 0:p.join("/")}),e.jsx("td",{children:null===(j=H[s])||void 0===j?void 0:j.description})]})})})]})})]})]})};export{N as EndpointPage};
1
+ import{j as e}from"../../../../../_virtual/jsx-runtime.js";import s from"../../../../components/SVGLoader/SVGLoader.js";import l from"../../../../assets/icons/DownArrow.svg.js";import i from"../../../../assets/icons/RequestOption.svg.js";import a from"../../../../assets/icons/ArrowBack.svg.js";import o from"../../../../assets/icons/arrow-down.svg.js";import d from"../../../../assets/icons/newCopyIcon.svg.js";import r from"../../../../assets/icons/arrow-up.svg.js";import{d as t}from"../../../../../_virtual/index3.js";import{useState as n,useEffect as c,useMemo as v}from"react";import{handleStatusColor as h}from"../../../../helpers/methodAccordion.helper.js";import{httpStatusCodes as m}from"../../../../constants/index.js";import u from"../../../../components/Tooltip/Tooltip.js";import{useSectionToggle as p,SectionEnum as j}from"../../../../context/SectionToggleContext.js";import{copyToClipboard as x,capitalizeFirstLetter as b}from"../../../../utils/index.js";const N=({data:N,setActiveType:y,setActiveItemData:f})=>{var g,C,w,k,S,q,O,T;const[R,$]=n("header"),{toggleSection:A}=p(),[E,L]=n((null===(w=null===(C=null===(g=null==N?void 0:N.api)||void 0===g?void 0:g.servers)||void 0===C?void 0:C[0])||void 0===w?void 0:w.url)||""),[I,V]=n(!1);c(()=>{var e,s,l;L((null===(l=null===(s=null===(e=null==N?void 0:N.api)||void 0===e?void 0:e.servers)||void 0===s?void 0:s[0])||void 0===l?void 0:l.url)||"")},[N]),v(()=>{var e,s,l;const i=null===(l=null===(s=null===(e=N.api)||void 0===e?void 0:e.servers)||void 0===s?void 0:s.filter(e=>"/"!==e.url)[0])||void 0===l?void 0:l.url,a=null==N?void 0:N.path.split("/").slice(2);return`${i}${(null==a?void 0:a.length)?"/"+a.join("/"):""}`},[N]);const z=m.map(s=>({label:e.jsxs("div",{className:"statusCodeOptionContainer",children:[e.jsx("div",{className:"statusCodeOptionCircle",style:{backgroundColor:h(s)}}),e.jsx("span",{children:s})]}),value:s})),[D,_]=n(null),[B,G]=n(z[4]),[H,P]=n({});return((null==N?void 0:N.parameters)||[]).filter(e=>{var s;return(null===(s=e.in)||void 0===s?void 0:s.toLowerCase())===R.toLowerCase()}),c(()=>{if(B&&B.value){const e=null==N?void 0:N.responses[B.value];P(null==e?void 0:e.headers)}},[B,null==N?void 0:N.responses]),e.jsxs("div",{className:"api-details-expanded",children:[e.jsxs("div",{className:"test-button",children:[e.jsx("button",{className:"back-button",onClick:()=>{A(N.api.apiSpecId,[{type:j.OVERVIEW,setTo:!0}],{resetOthers:!0,filterKeys:[j.RESOURCE]}),y("OVERVIEW"),f(N.api)},children:e.jsx(s,{src:a})}),e.jsx(u,{content:"Comming soon",children:e.jsx("button",{className:"disabled",children:"Test"})})]}),e.jsx("h3",{children:N.api.title}),e.jsx("h1",{className:"api-title",children:null==N?void 0:N.summary}),e.jsxs("div",{className:"url-box",children:[I&&0!==E.length&&e.jsx("div",{className:"url-list",children:null===(S=null===(k=N.api)||void 0===k?void 0:k.servers)||void 0===S?void 0:S.map((s,l)=>e.jsxs("div",{className:"url-item",onClick:()=>{L(s.url),V(!1)},children:[e.jsx("input",{type:"radio",name:"api-method",checked:E===s.url,readOnly:!0}),e.jsx("span",{children:`${s.url}${N.path}`})]},l))}),e.jsxs("div",{className:"url-box_text-container",children:[e.jsx("span",{className:`method-label ${null===(q=null==N?void 0:N.method)||void 0===q?void 0:q.toLowerCase()}`,children:N.method}),e.jsx("div",{className:"url-container",children:e.jsxs("div",{className:"type-ddl",onClick:()=>V(e=>!e),children:[e.jsx("span",{className:"url-text",children:`${E}${N.path}`}),e.jsxs("div",{className:"icon-container",children:[e.jsx(s,{className:"icon",role:"button",tabIndex:0,onClick:e=>{e.stopPropagation(),x(`${E}${N.path}`)},src:d}),0!==E.length&&e.jsx(s,{src:I?r:o})]})]})})]})]}),e.jsx("p",{className:"api-desc",children:(null==N?void 0:N.description)||"No Description"}),e.jsx("h3",{children:"Request"}),e.jsxs("div",{className:"request-section",children:[e.jsx("div",{className:"request-tabs",children:["header","path","query"].map(l=>e.jsxs("button",{className:"tab "+(R===l?"active":""),onClick:()=>$(l),children:[e.jsx(s,{src:i,className:"icon-left"}),e.jsx("span",{className:"tab-label",children:"requestBody"===l?"Request Body":l.charAt(0).toUpperCase()+l.slice(1)})]},l))}),e.jsx("div",{className:"table-wrapper",children:e.jsxs("table",{className:"param-table",children:[e.jsx("thead",{children:e.jsxs("tr",{children:[e.jsx("th",{className:"head-table-label",children:"Parameter Name"}),e.jsx("th",{className:"head-table-label",children:"Required"}),e.jsx("th",{className:"head-table-label",children:"Type"}),e.jsx("th",{className:"head-table-label",children:"Enum"}),e.jsx("th",{className:"head-table-label",children:"Description"})]})}),e.jsx("tbody",{children:null===(O=N.parameters)||void 0===O?void 0:O.filter(e=>{var s;return(null===(s=e.in)||void 0===s?void 0:s.toLowerCase())===R.toLowerCase()}).map((i,a)=>{var o,d,r,t,n,c,v;return e.jsxs("tr",{children:[e.jsx("td",{children:i.name}),e.jsx("td",{children:i.required?"True":"False"}),e.jsxs("td",{style:{textTransform:"capitalize"},children:[e.jsx("span",{children:(null===(o=null==i?void 0:i.schema)||void 0===o?void 0:o.type)||"-"}),"array"===(null===(d=null==i?void 0:i.schema)||void 0===d?void 0:d.type)&&(null===(t=null===(r=null==i?void 0:i.schema)||void 0===r?void 0:r.items)||void 0===t?void 0:t.type)&&e.jsxs("span",{style:{color:"#616874",fontSize:"0.75rem"},children:["_",b(null===(c=null===(n=i.schema)||void 0===n?void 0:n.items)||void 0===c?void 0:c.type)]})]}),e.jsx("td",{children:Array.isArray(null===(v=i.schema)||void 0===v?void 0:v.enum)?i.schema.enum.join(" / "):"-"}),e.jsxs("td",{className:"desc-cell",children:[e.jsx("div",{className:"desc-text "+(D===a?"expanded":""),children:i.description||"No description"}),e.jsx("button",{className:"desc-toggle",onClick:()=>_(D===a?null:a),children:e.jsx(s,{src:l,className:D===a?"rotated":""})})]})]},a)})})]})})]}),e.jsxs("div",{className:"response-section",children:[e.jsx("h3",{children:"Response"}),e.jsxs("div",{children:[e.jsx("div",{style:{height:"0.5rem",width:"7.5rem",marginLeft:"auto"},children:(null===(T=Object.keys((null==N?void 0:N.responses)||{}))||void 0===T?void 0:T.length)>0&&e.jsx("div",{className:"codeboxSection",children:e.jsx("div",{className:"codeboxHeader",children:e.jsx(t.SelectGroup,{size:"small",withSearch:!1,isMultiple:!1,clearable:!1,placeholder:"200",options:[{list:z}],value:B,onChange:e=>{G(e)}})})})}),e.jsxs("button",{className:"tab active ",children:[e.jsx(s,{src:i,className:"icon-left"}),"Header"]})]}),e.jsx("div",{className:"table-wrapper",children:e.jsxs("table",{className:"param-table",children:[e.jsx("thead",{children:e.jsxs("tr",{children:[e.jsx("th",{className:"head-table-label",children:"Header Name"}),e.jsx("th",{className:"head-table-label",children:"Required"}),e.jsx("th",{className:"head-table-label",children:"Type"}),e.jsx("th",{className:"head-table-label",children:"Enum"}),e.jsx("th",{className:"head-table-label",children:"Description"})]})}),e.jsx("tbody",{children:!!H&&Object.keys(H)&&Object.keys(H).map(s=>{var l,i,a,o,d,r,t,n,c,v,h,m,u,p,j;return e.jsxs("tr",{children:[e.jsx("td",{children:s}),e.jsx("td",{children:null===(l=H[s])||void 0===l?void 0:l.required.toString()}),e.jsxs("td",{style:{textTransform:"capitalize"},children:[e.jsx("span",{children:(null===(a=null===(i=H[s])||void 0===i?void 0:i.schema)||void 0===a?void 0:a.type)||"-"}),"array"===(null===(d=null===(o=H[s])||void 0===o?void 0:o.schema)||void 0===d?void 0:d.type)&&(null===(n=null===(t=null===(r=H[s])||void 0===r?void 0:r.schema)||void 0===t?void 0:t.items)||void 0===n?void 0:n.type)&&e.jsxs("span",{style:{color:"#616874",fontSize:"0.75rem"},children:["_",b(null===(h=null===(v=null===(c=H[s])||void 0===c?void 0:c.schema)||void 0===v?void 0:v.items)||void 0===h?void 0:h.type)]})]}),e.jsx("td",{children:null===(p=null===(u=null===(m=H[s])||void 0===m?void 0:m.schema)||void 0===u?void 0:u.enum)||void 0===p?void 0:p.join("/")}),e.jsx("td",{children:null===(j=H[s])||void 0===j?void 0:j.description})]})})})]})})]})]})};export{N as EndpointPage};
2
2
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../../../../src/layout/docsComponents/DocsContent/EndpointPage/index.tsx"],"sourcesContent":["import SVGLoader from '../../../../components/SVGLoader/SVGLoader'\nimport {\n ArrowBack,\n arrowDown,\n arrowUp,\n DownArrowIcon,\n newCopyIcon,\n RequestOption,\n} from '../../../../assets/icons/index'\nimport { SelectGroup } from 'digitinary-ui'\nimport { useEffect, useMemo, useState } from 'react'\nimport { EndpointData, OverviewData } from 'src/layout/docsLayout'\nimport { handleStatusColor } from '../../../../helpers/methodAccordion.helper'\nimport { httpStatusCodes } from '../../../../constants/index'\nimport styles from '../../Codebox/style.module.scss'\nimport Tooltip from '../../../../components/Tooltip/Tooltip'\nimport './style.scss'\nimport { SectionEnum, useSectionToggle } from '../../../../../src/context/SectionToggleContext'\nimport { capitalizeFirstLetter, copyToClipboard } from '../../../../../src/utils'\n\nexport const EndpointPage = ({\n data,\n setActiveType,\n setActiveItemData,\n}: {\n data: EndpointData\n setActiveType: React.Dispatch<React.SetStateAction<'OVERVIEW' | 'ENDPOINT'>>\n setActiveItemData: React.Dispatch<React.SetStateAction<OverviewData | EndpointData>>\n}) => {\n const [activeTab, setActiveTab] = useState('header')\n const { toggleSection } = useSectionToggle()\n const [selectedUrl, setSelectedUrl] = useState(data?.api?.servers?.[0]?.url || '')\n const [isUrlDropdownOpen, setIsUrlDropdownOpen] = useState<boolean>(false)\n\n useEffect(() => {\n setSelectedUrl(data?.api?.servers?.[0]?.url || '')\n }, [data])\n\n const fullUrl = useMemo(() => {\n // env gateway url + api version(if appended) + context path\n const url = data.api?.servers?.filter((s) => s.url !== '/')[0]?.url\n const pathParts = data?.path.split('/').slice(2) // slice from index 2 to skip the first empty \"\" and \"comments\"\n const fullPath = !!pathParts?.length ? '/' + pathParts.join('/') : '' // this will contain the full path without the context path\n return `${url}${fullPath}`\n }, [data])\n\n const httpStatusCodeOptions = httpStatusCodes.map((code) => ({\n label: (\n <div className={'statusCodeOptionContainer'}>\n <div\n className={'statusCodeOptionCircle'}\n style={{ backgroundColor: handleStatusColor(code) }}\n ></div>\n <span>{code}</span>\n </div>\n ),\n value: code,\n }))\n\n const [expanded, setExpanded] = useState(null)\n const [selectedResStatusCode, setSelectedResStatusCode] = useState(httpStatusCodeOptions[4])\n const [headersList, setHeadersList] = useState({})\n const requestTableData = (data?.parameters || []).filter(\n (param) => param.in?.toLowerCase() === activeTab.toLowerCase()\n )\n\n useEffect(() => {\n if (selectedResStatusCode && selectedResStatusCode.value) {\n const headerObj = data?.responses[selectedResStatusCode.value]\n setHeadersList(headerObj?.headers)\n }\n }, [selectedResStatusCode, data?.responses])\n\n // ? TODO: 'body' should be returned after discussing with PO\n\n return (\n <div className=\"api-details-expanded\">\n <div className=\"test-button\">\n <button\n className=\"back-button\"\n onClick={() => {\n toggleSection(data.api.apiSpecId, [{ type: SectionEnum.OVERVIEW, setTo: true }], {\n resetOthers: true,\n filterKeys: [SectionEnum.RESOURCE],\n })\n setActiveType('OVERVIEW')\n setActiveItemData(data.api)\n }}\n >\n <SVGLoader src={ArrowBack} />\n </button>\n\n <Tooltip content=\"Comming soon\">\n <button className=\"disabled\">Test</button>\n </Tooltip>\n </div>\n <h3>{data.api.title}</h3>\n <h1 className=\"api-title\">{data?.summary}</h1>\n <div className=\"url-box\">\n <div className=\"url-box_text-container\">\n <span className={`method-label ${data?.method?.toLowerCase()}`}>{data.method}</span>\n <div className=\"url-container\">\n <div className=\"type-ddl\" onClick={() => setIsUrlDropdownOpen((prev) => !prev)}>\n <span className=\"url-text\">{`${selectedUrl}${data.path}`}</span>\n <div className=\"icon-container\">\n {selectedUrl.length !== 0 && (\n <SVGLoader\n className=\"icon\"\n role=\"button\"\n tabIndex={0}\n onClick={(e) => {\n e.stopPropagation()\n copyToClipboard(selectedUrl)\n }}\n src={newCopyIcon}\n />\n )}\n {selectedUrl.length !== 0 && (\n <SVGLoader src={!isUrlDropdownOpen ? arrowDown : arrowUp} />\n )}\n </div>\n </div>\n\n {isUrlDropdownOpen && selectedUrl.length !== 0 && (\n <div className=\"url-list\">\n {data.api?.servers?.map((server, index) => (\n <div\n key={index}\n className=\"url-item\"\n onClick={() => {\n setSelectedUrl(server.url)\n setIsUrlDropdownOpen(false)\n }}\n >\n <input\n type=\"radio\"\n name=\"api-method\"\n checked={selectedUrl === server.url}\n readOnly\n />\n <span>{`${server.url}${data.path}`}</span>\n </div>\n ))}\n </div>\n )}\n </div>\n </div>\n </div>\n\n <p className=\"api-desc\">{data?.description || 'No Description'}</p>\n\n <h3>Request</h3>\n\n <div className=\"request-section\">\n <div className=\"request-tabs\">\n {['header', 'path', 'query'].map((tab) => (\n <button\n key={tab}\n className={`tab ${activeTab === tab ? 'active' : ''}`}\n onClick={() => setActiveTab(tab)}\n >\n <SVGLoader src={RequestOption} className=\"icon-left\" />\n <span className=\"tab-label\">\n {tab === 'requestBody'\n ? 'Request Body'\n : tab.charAt(0).toUpperCase() + tab.slice(1)}\n </span>\n </button>\n ))}\n </div>\n\n {\n <div className=\"table-wrapper\">\n <table className=\"param-table\">\n <thead>\n <tr>\n <th className=\"head-table-label\">Parameter Name</th>\n <th className=\"head-table-label\">Required</th>\n <th className=\"head-table-label\">Type</th>\n <th className=\"head-table-label\">Enum</th>\n <th className=\"head-table-label\">Description</th>\n </tr>\n </thead>\n <tbody>\n {data.parameters\n ?.filter((p) => p.in?.toLowerCase() === activeTab.toLowerCase())\n .map((row, index) => (\n <tr key={index}>\n <td>{row.name}</td>\n <td>{row.required ? 'True' : 'False'}</td>\n <td style={{ textTransform: 'capitalize' }}>\n <span>{row?.schema?.type || '-'}</span>\n {row?.schema?.type === 'array' && row?.schema?.items?.type && (\n <span style={{ color: '#616874', fontSize: '0.75rem' }}>\n _{capitalizeFirstLetter(row.schema?.items?.type)}\n </span>\n )}\n </td>\n <td>{Array.isArray(row.schema?.enum) ? row.schema.enum.join(' / ') : '-'}</td>\n <td className=\"desc-cell\">\n <div className={`desc-text ${expanded === index ? 'expanded' : ''}`}>\n {row.description || 'No description'}\n </div>\n <button\n className=\"desc-toggle\"\n onClick={() => setExpanded(expanded === index ? null : index)}\n >\n <SVGLoader\n src={DownArrowIcon}\n className={expanded === index ? 'rotated' : ''}\n />\n </button>\n </td>\n </tr>\n ))}\n </tbody>\n </table>\n </div>\n }\n </div>\n\n <div className=\"response-section\">\n <h3>Response</h3>\n\n <div>\n <div style={{ height: '0.5rem', width: '7.5rem', marginLeft: 'auto' }}>\n {Object.keys(data?.responses || {})?.length > 0 && (\n <div className={'codeboxSection'}>\n <div className={`${'codeboxHeader'}`}>\n <SelectGroup\n size=\"small\"\n withSearch={false}\n isMultiple={false}\n clearable={false}\n placeholder=\"200\"\n options={[\n {\n list: httpStatusCodeOptions,\n },\n ]}\n value={selectedResStatusCode}\n onChange={(value) => {\n setSelectedResStatusCode(value)\n }}\n />\n </div>\n </div>\n )}\n </div>\n <button className=\"tab active \">\n <SVGLoader src={RequestOption} className=\"icon-left\" />\n Header\n </button>\n </div>\n\n <div className=\"table-wrapper\">\n <table className=\"param-table\">\n <thead>\n <tr>\n <th className=\"head-table-label\">Header Name</th>\n <th className=\"head-table-label\">Required</th>\n <th className=\"head-table-label\">Type</th>\n <th className=\"head-table-label\">Enum</th>\n <th className=\"head-table-label\">Description</th>\n </tr>\n </thead>\n <tbody>\n {!!headersList &&\n Object.keys(headersList) &&\n Object.keys(headersList).map((key) => (\n <tr>\n <td>{key}</td>\n <td>{headersList[key]?.required.toString()}</td>\n <td style={{ textTransform: 'capitalize' }}>\n <span>{headersList[key]?.schema?.type || '-'}</span>\n {headersList[key]?.schema?.type === 'array' &&\n headersList[key]?.schema?.items?.type && (\n <span style={{ color: '#616874', fontSize: '0.75rem' }}>\n _{capitalizeFirstLetter(headersList[key]?.schema?.items?.type)}\n </span>\n )}\n </td>\n <td>{headersList[key]?.schema?.enum?.join('/')}</td>\n <td>{headersList[key]?.description}</td>\n </tr>\n ))}\n </tbody>\n </table>\n </div>\n </div>\n </div>\n )\n}\n"],"names":["EndpointPage","data","setActiveType","setActiveItemData","activeTab","setActiveTab","useState","toggleSection","useSectionToggle","selectedUrl","setSelectedUrl","_c","_b","_a","api","servers","url","isUrlDropdownOpen","setIsUrlDropdownOpen","useEffect","useMemo","filter","s","pathParts","path","split","slice","length","join","httpStatusCodeOptions","httpStatusCodes","map","code","label","_jsxs","jsxs","className","children","_jsx","style","backgroundColor","handleStatusColor","value","expanded","setExpanded","selectedResStatusCode","setSelectedResStatusCode","headersList","setHeadersList","parameters","param","in","toLowerCase","headerObj","responses","headers","onClick","apiSpecId","type","SectionEnum","OVERVIEW","setTo","resetOthers","filterKeys","RESOURCE","SVGLoader","src","ArrowBack","jsx","Tooltip","content","title","summary","_d","method","prev","role","tabIndex","e","stopPropagation","copyToClipboard","newCopyIcon","arrowUp","arrowDown","_e","_f","server","index","name","checked","readOnly","description","tab","RequestOption","charAt","toUpperCase","_g","p","row","required","textTransform","schema","items","color","fontSize","capitalizeFirstLetter","Array","isArray","enum","DownArrowIcon","height","width","marginLeft","_h","Object","keys","SelectGroup","size","withSearch","isMultiple","clearable","placeholder","options","list","onChange","key","toString","_k","_j","_p","_o","_q"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sources":["../../../../../../src/layout/docsComponents/DocsContent/EndpointPage/index.tsx"],"sourcesContent":["import SVGLoader from '../../../../components/SVGLoader/SVGLoader'\nimport {\n ArrowBack,\n arrowDown,\n arrowUp,\n DownArrowIcon,\n newCopyIcon,\n RequestOption,\n} from '../../../../assets/icons/index'\nimport { SelectGroup } from 'digitinary-ui'\nimport { useEffect, useMemo, useState } from 'react'\nimport { EndpointData, OverviewData } from 'src/layout/docsLayout'\nimport { handleStatusColor } from '../../../../helpers/methodAccordion.helper'\nimport { httpStatusCodes } from '../../../../constants/index'\nimport styles from '../../Codebox/style.module.scss'\nimport Tooltip from '../../../../components/Tooltip/Tooltip'\nimport './style.scss'\nimport { SectionEnum, useSectionToggle } from '../../../../../src/context/SectionToggleContext'\nimport { capitalizeFirstLetter, copyToClipboard } from '../../../../../src/utils'\n\nexport const EndpointPage = ({\n data,\n setActiveType,\n setActiveItemData,\n}: {\n data: EndpointData\n setActiveType: React.Dispatch<React.SetStateAction<'OVERVIEW' | 'ENDPOINT'>>\n setActiveItemData: React.Dispatch<React.SetStateAction<OverviewData | EndpointData>>\n}) => {\n const [activeTab, setActiveTab] = useState('header')\n const { toggleSection } = useSectionToggle()\n const [selectedUrl, setSelectedUrl] = useState(data?.api?.servers?.[0]?.url || '')\n const [isUrlDropdownOpen, setIsUrlDropdownOpen] = useState<boolean>(false)\n\n useEffect(() => {\n setSelectedUrl(data?.api?.servers?.[0]?.url || '')\n }, [data])\n\n const fullUrl = useMemo(() => {\n // env gateway url + api version(if appended) + context path\n const url = data.api?.servers?.filter((s) => s.url !== '/')[0]?.url\n const pathParts = data?.path.split('/').slice(2) // slice from index 2 to skip the first empty \"\" and \"comments\"\n const fullPath = !!pathParts?.length ? '/' + pathParts.join('/') : '' // this will contain the full path without the context path\n return `${url}${fullPath}`\n }, [data])\n\n const httpStatusCodeOptions = httpStatusCodes.map((code) => ({\n label: (\n <div className={'statusCodeOptionContainer'}>\n <div\n className={'statusCodeOptionCircle'}\n style={{ backgroundColor: handleStatusColor(code) }}\n ></div>\n <span>{code}</span>\n </div>\n ),\n value: code,\n }))\n\n const [expanded, setExpanded] = useState(null)\n const [selectedResStatusCode, setSelectedResStatusCode] = useState(httpStatusCodeOptions[4])\n const [headersList, setHeadersList] = useState({})\n const requestTableData = (data?.parameters || []).filter(\n (param) => param.in?.toLowerCase() === activeTab.toLowerCase()\n )\n\n useEffect(() => {\n if (selectedResStatusCode && selectedResStatusCode.value) {\n const headerObj = data?.responses[selectedResStatusCode.value]\n setHeadersList(headerObj?.headers)\n }\n }, [selectedResStatusCode, data?.responses])\n\n // ? TODO: 'body' should be returned after discussing with PO\n\n return (\n <div className=\"api-details-expanded\">\n <div className=\"test-button\">\n <button\n className=\"back-button\"\n onClick={() => {\n toggleSection(data.api.apiSpecId, [{ type: SectionEnum.OVERVIEW, setTo: true }], {\n resetOthers: true,\n filterKeys: [SectionEnum.RESOURCE],\n })\n setActiveType('OVERVIEW')\n setActiveItemData(data.api)\n }}\n >\n <SVGLoader src={ArrowBack} />\n </button>\n\n <Tooltip content=\"Comming soon\">\n <button className=\"disabled\">Test</button>\n </Tooltip>\n </div>\n <h3>{data.api.title}</h3>\n <h1 className=\"api-title\">{data?.summary}</h1>\n <div className=\"url-box\">\n {isUrlDropdownOpen && selectedUrl.length !== 0 && (\n <div className=\"url-list\">\n {data.api?.servers?.map((server, index) => (\n <div\n key={index}\n className=\"url-item\"\n onClick={() => {\n setSelectedUrl(server.url)\n setIsUrlDropdownOpen(false)\n }}\n >\n <input\n type=\"radio\"\n name=\"api-method\"\n checked={selectedUrl === server.url}\n readOnly\n />\n <span>{`${server.url}${data.path}`}</span>\n </div>\n ))}\n </div>\n )}\n <div className=\"url-box_text-container\">\n <span className={`method-label ${data?.method?.toLowerCase()}`}>{data.method}</span>\n <div className=\"url-container\">\n <div className=\"type-ddl\" onClick={() => setIsUrlDropdownOpen((prev) => !prev)}>\n <span className=\"url-text\">{`${selectedUrl}${data.path}`}</span>\n <div className=\"icon-container\">\n <SVGLoader\n className=\"icon\"\n role=\"button\"\n tabIndex={0}\n onClick={(e) => {\n e.stopPropagation()\n copyToClipboard(`${selectedUrl}${data.path}`)\n }}\n src={newCopyIcon}\n />\n {selectedUrl.length !== 0 && (\n <SVGLoader src={!isUrlDropdownOpen ? arrowDown : arrowUp} />\n )}\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <p className=\"api-desc\">{data?.description || 'No Description'}</p>\n\n <h3>Request</h3>\n\n <div className=\"request-section\">\n <div className=\"request-tabs\">\n {['header', 'path', 'query'].map((tab) => (\n <button\n key={tab}\n className={`tab ${activeTab === tab ? 'active' : ''}`}\n onClick={() => setActiveTab(tab)}\n >\n <SVGLoader src={RequestOption} className=\"icon-left\" />\n <span className=\"tab-label\">\n {tab === 'requestBody'\n ? 'Request Body'\n : tab.charAt(0).toUpperCase() + tab.slice(1)}\n </span>\n </button>\n ))}\n </div>\n\n {\n <div className=\"table-wrapper\">\n <table className=\"param-table\">\n <thead>\n <tr>\n <th className=\"head-table-label\">Parameter Name</th>\n <th className=\"head-table-label\">Required</th>\n <th className=\"head-table-label\">Type</th>\n <th className=\"head-table-label\">Enum</th>\n <th className=\"head-table-label\">Description</th>\n </tr>\n </thead>\n <tbody>\n {data.parameters\n ?.filter((p) => p.in?.toLowerCase() === activeTab.toLowerCase())\n .map((row, index) => (\n <tr key={index}>\n <td>{row.name}</td>\n <td>{row.required ? 'True' : 'False'}</td>\n <td style={{ textTransform: 'capitalize' }}>\n <span>{row?.schema?.type || '-'}</span>\n {row?.schema?.type === 'array' && row?.schema?.items?.type && (\n <span style={{ color: '#616874', fontSize: '0.75rem' }}>\n _{capitalizeFirstLetter(row.schema?.items?.type)}\n </span>\n )}\n </td>\n <td>{Array.isArray(row.schema?.enum) ? row.schema.enum.join(' / ') : '-'}</td>\n <td className=\"desc-cell\">\n <div className={`desc-text ${expanded === index ? 'expanded' : ''}`}>\n {row.description || 'No description'}\n </div>\n <button\n className=\"desc-toggle\"\n onClick={() => setExpanded(expanded === index ? null : index)}\n >\n <SVGLoader\n src={DownArrowIcon}\n className={expanded === index ? 'rotated' : ''}\n />\n </button>\n </td>\n </tr>\n ))}\n </tbody>\n </table>\n </div>\n }\n </div>\n\n <div className=\"response-section\">\n <h3>Response</h3>\n\n <div>\n <div style={{ height: '0.5rem', width: '7.5rem', marginLeft: 'auto' }}>\n {Object.keys(data?.responses || {})?.length > 0 && (\n <div className={'codeboxSection'}>\n <div className={`${'codeboxHeader'}`}>\n <SelectGroup\n size=\"small\"\n withSearch={false}\n isMultiple={false}\n clearable={false}\n placeholder=\"200\"\n options={[\n {\n list: httpStatusCodeOptions,\n },\n ]}\n value={selectedResStatusCode}\n onChange={(value) => {\n setSelectedResStatusCode(value)\n }}\n />\n </div>\n </div>\n )}\n </div>\n <button className=\"tab active \">\n <SVGLoader src={RequestOption} className=\"icon-left\" />\n Header\n </button>\n </div>\n\n <div className=\"table-wrapper\">\n <table className=\"param-table\">\n <thead>\n <tr>\n <th className=\"head-table-label\">Header Name</th>\n <th className=\"head-table-label\">Required</th>\n <th className=\"head-table-label\">Type</th>\n <th className=\"head-table-label\">Enum</th>\n <th className=\"head-table-label\">Description</th>\n </tr>\n </thead>\n <tbody>\n {!!headersList &&\n Object.keys(headersList) &&\n Object.keys(headersList).map((key) => (\n <tr>\n <td>{key}</td>\n <td>{headersList[key]?.required.toString()}</td>\n <td style={{ textTransform: 'capitalize' }}>\n <span>{headersList[key]?.schema?.type || '-'}</span>\n {headersList[key]?.schema?.type === 'array' &&\n headersList[key]?.schema?.items?.type && (\n <span style={{ color: '#616874', fontSize: '0.75rem' }}>\n _{capitalizeFirstLetter(headersList[key]?.schema?.items?.type)}\n </span>\n )}\n </td>\n <td>{headersList[key]?.schema?.enum?.join('/')}</td>\n <td>{headersList[key]?.description}</td>\n </tr>\n ))}\n </tbody>\n </table>\n </div>\n </div>\n </div>\n )\n}\n"],"names":["EndpointPage","data","setActiveType","setActiveItemData","activeTab","setActiveTab","useState","toggleSection","useSectionToggle","selectedUrl","setSelectedUrl","_c","_b","_a","api","servers","url","isUrlDropdownOpen","setIsUrlDropdownOpen","useEffect","useMemo","filter","s","pathParts","path","split","slice","length","join","httpStatusCodeOptions","httpStatusCodes","map","code","label","_jsxs","jsxs","className","children","_jsx","style","backgroundColor","handleStatusColor","value","expanded","setExpanded","selectedResStatusCode","setSelectedResStatusCode","headersList","setHeadersList","parameters","param","in","toLowerCase","headerObj","responses","headers","onClick","apiSpecId","type","SectionEnum","OVERVIEW","setTo","resetOthers","filterKeys","RESOURCE","SVGLoader","src","ArrowBack","Tooltip","content","title","summary","_e","_d","server","index","name","checked","readOnly","jsx","_f","method","prev","role","tabIndex","e","stopPropagation","copyToClipboard","newCopyIcon","arrowUp","arrowDown","description","tab","RequestOption","charAt","toUpperCase","_g","p","row","required","textTransform","schema","items","color","fontSize","capitalizeFirstLetter","Array","isArray","enum","DownArrowIcon","height","width","marginLeft","_h","Object","keys","SelectGroup","size","withSearch","isMultiple","clearable","placeholder","options","list","onChange","key","toString","_k","_j","_p","_o","_q"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../../../../src/layout/docsComponents/DocsContent/OverviewPage/index.tsx"],"sourcesContent":["import './style.scss'\nimport SVGLoader from '../../../../components/SVGLoader/SVGLoader'\nimport { arrowDown, arrowRightGray, arrowUp, newCopyIcon } from '../../../../assets/icons/index'\nimport { EndpointData, OverviewData } from 'src/layout/docsLayout'\nimport { SectionEnum, useSectionToggle } from '../../../../../src/context/SectionToggleContext'\nimport React, { useEffect, useState } from 'react'\nimport { copyToClipboard } from '../../../../utils'\n\nexport const OverviewPage = ({\n data,\n setActiveItemData,\n setActiveType,\n onProductNavigate,\n apis,\n}: {\n data: OverviewData\n setActiveItemData: React.Dispatch<React.SetStateAction<OverviewData | EndpointData>>\n setActiveType: React.Dispatch<React.SetStateAction<'OVERVIEW' | 'ENDPOINT'>>\n onProductNavigate?: (productId: number) => void\n apis: OverviewData[]\n}) => {\n const { toggleSection } = useSectionToggle()\n const [selectedUrl, setSelectedUrl] = useState(data?.servers?.[0]?.url || '')\n const [isUrlDropdownOpen, setIsUrlDropdownOpen] = useState<boolean>(false)\n\n useEffect(() => {\n setSelectedUrl(data?.servers?.[0]?.url || '')\n }, [data])\n const handleVersionClick = (verObj) => {\n if (verObj.apiSpecId === data.apiSpecId) {\n setActiveType('OVERVIEW')\n return\n }\n\n const matchedVersion = data.apiVersions.find((v) => v.apiSpecId === verObj.apiSpecId)\n\n if (!matchedVersion) {\n return\n }\n\n const matchedApi = apis.find((api) => api.apiSpecId === matchedVersion.apiSpecId)\n setActiveItemData(matchedApi)\n\n setActiveType('OVERVIEW')\n toggleSection(\n matchedApi.apiSpecId,\n [\n { type: SectionEnum.API_SECTION, setTo: true },\n { type: SectionEnum.OVERVIEW, setTo: true },\n ],\n {\n resetOthers: true,\n filterKeys: [\n SectionEnum.OVERVIEW,\n SectionEnum.API_SECTION,\n SectionEnum.ENDPOINTS_SECTION,\n SectionEnum.TAG_SECTION,\n ],\n }\n )\n }\n\n const handleClick = (endpoint) => {\n setActiveItemData({\n ...endpoint,\n api: {\n id: data.apiSpecId,\n title: data.title,\n description: data.description,\n version: data.version,\n ...data,\n },\n })\n setActiveType('ENDPOINT')\n const tagEntries = Object.entries(data?.tags || {})\n const sectionIndex = tagEntries.findIndex(([, endpoints]) =>\n endpoints.some((e) => e.id === endpoint.id)\n )\n\n const tagSectionIndex = Object.entries(data.tags)\n .sort(([a], [b]) => (a === 'default' ? 1 : b === 'default' ? -1 : a.localeCompare(b)))\n .findIndex(([_, tagData]) => tagData.find((t) => t.id === endpoint.id))\n\n toggleSection(\n data.apiSpecId,\n [\n { type: SectionEnum.API_SECTION, setTo: true },\n { type: SectionEnum.ENDPOINTS_SECTION, setTo: true },\n { type: SectionEnum.TAG_SECTION, setTo: true, index: tagSectionIndex },\n { type: SectionEnum.RESOURCE, setTo: true, id: endpoint.id },\n ],\n { resetOthers: true, filterKeys: [SectionEnum.OVERVIEW] }\n )\n }\n\n return (\n <div className=\"api-details-page\">\n <h2 className=\"welcome\">Welcome to</h2>\n <h1 className=\"api-title\">{data?.title}</h1>\n <p className=\"api-version\">\n API Version: <span>{data?.version}</span>\n </p>\n\n <div className=\"custom-url-input\">\n <label className=\"input-label\">API Base URL</label>\n <div className=\"url-container\">\n <div className=\"type-ddl\" onClick={() => setIsUrlDropdownOpen((prev) => !prev)}>\n <span className=\"url-text\">{selectedUrl || '-'}</span>\n <div className=\"icon-container\">\n {selectedUrl.length !== 0 && (\n <SVGLoader\n className=\"icon\"\n role=\"button\"\n tabIndex={0}\n onClick={(e) => {\n e.stopPropagation()\n copyToClipboard(selectedUrl)\n }}\n src={newCopyIcon}\n />\n )}\n {selectedUrl.length !== 0 && (\n <SVGLoader src={!isUrlDropdownOpen ? arrowDown : arrowUp} />\n )}\n </div>\n </div>\n {isUrlDropdownOpen && selectedUrl.length !== 0 && (\n <div className=\"url-list\">\n {data?.servers?.map((server, index) => (\n <div\n key={index}\n className=\"url-item\"\n onClick={() => {\n setSelectedUrl(server.url)\n setIsUrlDropdownOpen(false)\n }}\n >\n <input\n type=\"radio\"\n name=\"api-method\"\n checked={selectedUrl === server.url}\n readOnly\n />\n <span>{server.url}</span>\n </div>\n ))}\n </div>\n )}\n </div>\n </div>\n\n <p className=\"api-desc\">{`${data.description || 'No Description'}`}</p>\n {onProductNavigate && (\n <div className=\"api-product-tag\">\n Product with this API{' '}\n <span\n className=\"product-tag\"\n role=\"button\"\n tabIndex={-1}\n onClick={() => onProductNavigate(data.associatedProduct.productId)}\n >\n {data.associatedProduct.name}\n </span>\n </div>\n )}\n\n <h3 className=\"section-title\">Endpoints</h3>\n\n {Object.entries(data?.tags).map(([tag, endpoints]) => (\n <div className=\"endpoint-group\" key={tag}>\n <h4 className=\"tag-title\">{tag}</h4>\n <div className=\"endpoint-list\">\n {endpoints.map((endpoint, idx) => (\n <div\n className=\"endpoint-card\"\n onClick={() => handleClick(endpoint)}\n key={`${tag}-${idx}`}\n >\n <div>\n <div className=\"endpoint-card-header\">\n <span className={`method-label ${endpoint.method.toLowerCase()}`}>\n {endpoint.method}\n </span>\n <div className=\"title-wrapper\">\n <h5>\n {(endpoint.summary || 'Endpoint Name').slice(0, 40)}\n {(endpoint.summary?.length ?? 0) > 40 && '...'}\n </h5>\n </div>\n </div>\n <div className=\"endpoint-meta\">\n <p>{endpoint.path}</p>\n <p className=\"description\">{endpoint.description ?? 'No Description '}</p>\n </div>\n </div>\n\n <div className=\"endpoint-arrow\">\n <SVGLoader src={arrowRightGray} />\n </div>\n </div>\n ))}\n </div>\n </div>\n ))}\n\n {data.apiVersions?.length > 0 && (\n <div className=\"versions-section\">\n <h4>API Versions</h4>\n <div className=\"version-list\">\n {data.apiVersions.map((verObj, index) => (\n <button\n key={index}\n className=\"version-btn\"\n onClick={() => handleVersionClick(verObj)}\n >\n {verObj.metaData?.version || 'N/A'}\n </button>\n ))}\n </div>\n </div>\n )}\n </div>\n )\n}\n"],"names":["OverviewPage","data","setActiveItemData","setActiveType","onProductNavigate","apis","toggleSection","useSectionToggle","selectedUrl","setSelectedUrl","useState","_b","_a","servers","url","isUrlDropdownOpen","setIsUrlDropdownOpen","useEffect","_jsxs","className","children","_jsx","jsx","title","version","onClick","prev","jsxs","length","SVGLoader","role","tabIndex","e","stopPropagation","copyToClipboard","src","newCopyIcon","arrowUp","arrowDown","_c","map","server","index","type","name","checked","readOnly","description","associatedProduct","productId","Object","entries","tags","tag","endpoints","endpoint","idx","assign","api","id","apiSpecId","findIndex","some","tagSectionIndex","sort","a","b","localeCompare","_","tagData","find","t","SectionEnum","API_SECTION","setTo","ENDPOINTS_SECTION","TAG_SECTION","RESOURCE","resetOthers","filterKeys","OVERVIEW","handleClick","method","toLowerCase","summary","slice","path","arrowRightGray","_d","apiVersions","verObj","matchedVersion","v","matchedApi","handleVersionClick","metaData"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sources":["../../../../../../src/layout/docsComponents/DocsContent/OverviewPage/index.tsx"],"sourcesContent":["import './style.scss'\nimport SVGLoader from '../../../../components/SVGLoader/SVGLoader'\nimport { arrowDown, arrowRightGray, arrowUp, newCopyIcon } from '../../../../assets/icons/index'\nimport { EndpointData, OverviewData } from 'src/layout/docsLayout'\nimport { SectionEnum, useSectionToggle } from '../../../../../src/context/SectionToggleContext'\nimport React, { useEffect, useState } from 'react'\nimport { copyToClipboard } from '../../../../utils'\n\nexport const OverviewPage = ({\n data,\n setActiveItemData,\n setActiveType,\n onProductNavigate,\n apis,\n}: {\n data: OverviewData\n setActiveItemData: React.Dispatch<React.SetStateAction<OverviewData | EndpointData>>\n setActiveType: React.Dispatch<React.SetStateAction<'OVERVIEW' | 'ENDPOINT'>>\n onProductNavigate?: (productId: number) => void\n apis: OverviewData[]\n}) => {\n const { toggleSection } = useSectionToggle()\n const [selectedUrl, setSelectedUrl] = useState(data?.servers?.[0]?.url || '')\n const [isUrlDropdownOpen, setIsUrlDropdownOpen] = useState<boolean>(false)\n\n useEffect(() => {\n setSelectedUrl(data?.servers?.[0]?.url || '')\n }, [data])\n const handleVersionClick = (verObj) => {\n if (verObj.apiSpecId === data.apiSpecId) {\n setActiveType('OVERVIEW')\n return\n }\n\n const matchedVersion = data.apiVersions.find((v) => v.apiSpecId === verObj.apiSpecId)\n\n if (!matchedVersion) {\n return\n }\n\n const matchedApi = apis.find((api) => api.apiSpecId === matchedVersion.apiSpecId)\n setActiveItemData(matchedApi)\n\n setActiveType('OVERVIEW')\n toggleSection(\n matchedApi.apiSpecId,\n [\n { type: SectionEnum.API_SECTION, setTo: true },\n { type: SectionEnum.OVERVIEW, setTo: true },\n ],\n {\n resetOthers: true,\n filterKeys: [\n SectionEnum.OVERVIEW,\n SectionEnum.API_SECTION,\n SectionEnum.ENDPOINTS_SECTION,\n SectionEnum.TAG_SECTION,\n ],\n }\n )\n }\n\n const handleClick = (endpoint) => {\n setActiveItemData({\n ...endpoint,\n api: {\n id: data.apiSpecId,\n title: data.title,\n description: data.description,\n version: data.version,\n ...data,\n },\n })\n setActiveType('ENDPOINT')\n const tagEntries = Object.entries(data?.tags || {})\n const sectionIndex = tagEntries.findIndex(([, endpoints]) =>\n endpoints.some((e) => e.id === endpoint.id)\n )\n\n const tagSectionIndex = Object.entries(data.tags)\n .sort(([a], [b]) => (a === 'default' ? 1 : b === 'default' ? -1 : a.localeCompare(b)))\n .findIndex(([_, tagData]) => tagData.find((t) => t.id === endpoint.id))\n\n toggleSection(\n data.apiSpecId,\n [\n { type: SectionEnum.API_SECTION, setTo: true },\n { type: SectionEnum.ENDPOINTS_SECTION, setTo: true },\n { type: SectionEnum.TAG_SECTION, setTo: true, index: tagSectionIndex },\n { type: SectionEnum.RESOURCE, setTo: true, id: endpoint.id },\n ],\n { resetOthers: true, filterKeys: [SectionEnum.OVERVIEW] }\n )\n }\n\n return (\n <div className=\"api-details-page\">\n <h2 className=\"welcome\">Welcome to</h2>\n <h1 className=\"api-title\">{data?.title}</h1>\n <p className=\"api-version\">\n API Version: <span>{data?.version}</span>\n </p>\n <div className=\"custom-url-input\">\n <label className=\"input-label\">API Base URL</label>\n <div className=\"url-container\">\n <div className=\"type-ddl\" onClick={() => setIsUrlDropdownOpen((prev) => !prev)}>\n <span className=\"url-text\">{selectedUrl || '-'}</span>\n <div className=\"icon-container\">\n {selectedUrl.length !== 0 && (\n <SVGLoader\n className=\"icon\"\n role=\"button\"\n tabIndex={0}\n onClick={(e) => {\n e.stopPropagation()\n copyToClipboard(selectedUrl)\n }}\n src={newCopyIcon}\n />\n )}\n {selectedUrl.length !== 0 && (\n <SVGLoader src={!isUrlDropdownOpen ? arrowDown : arrowUp} />\n )}\n </div>\n </div>\n {isUrlDropdownOpen && selectedUrl.length !== 0 && (\n <div className=\"url-list\">\n {data?.servers?.map((server, index) => (\n <div\n key={index}\n className=\"url-item\"\n onClick={() => {\n setSelectedUrl(server.url)\n setIsUrlDropdownOpen(false)\n }}\n >\n <input\n type=\"radio\"\n name=\"api-method\"\n checked={selectedUrl === server.url}\n readOnly\n />\n <span>{server.url}</span>\n </div>\n ))}\n </div>\n )}\n </div>\n </div>\n\n <p className=\"api-desc\">{`${data.description || 'No Description'}`}</p>\n {onProductNavigate && (\n <div className=\"api-product-tag\">\n Product with this API{' '}\n <span\n className=\"product-tag\"\n role=\"button\"\n tabIndex={-1}\n onClick={() => onProductNavigate(data.associatedProduct.productId)}\n >\n {data.associatedProduct.name}\n </span>\n </div>\n )}\n\n <h3 className=\"section-title\">Endpoints</h3>\n\n {Object.entries(data?.tags).map(([tag, endpoints]) => (\n <div className=\"endpoint-group\" key={tag}>\n <h4 className=\"tag-title\">{tag}</h4>\n <div className=\"endpoint-list\">\n {endpoints.map((endpoint, idx) => (\n <div\n className=\"endpoint-card\"\n onClick={() => handleClick(endpoint)}\n key={`${tag}-${idx}`}\n >\n <div>\n <div className=\"endpoint-card-header\">\n <span className={`method-label ${endpoint.method.toLowerCase()}`}>\n {endpoint.method}\n </span>\n <div className=\"title-wrapper\">\n <h5>\n {(endpoint.summary || 'Endpoint Name').slice(0, 40)}\n {(endpoint.summary?.length ?? 0) > 40 && '...'}\n </h5>\n </div>\n </div>\n <div className=\"endpoint-meta\">\n <p>{endpoint.path}</p>\n <p className=\"description\">{endpoint.description ?? 'No Description '}</p>\n </div>\n </div>\n\n <div className=\"endpoint-arrow\">\n <SVGLoader src={arrowRightGray} />\n </div>\n </div>\n ))}\n </div>\n </div>\n ))}\n\n {data.apiVersions?.length > 0 && (\n <div className=\"versions-section\">\n <h4>API Versions</h4>\n <div className=\"version-list\">\n {data.apiVersions.map((verObj, index) => (\n <button\n key={index}\n className=\"version-btn\"\n onClick={() => handleVersionClick(verObj)}\n >\n {verObj.metaData?.version || 'N/A'}\n </button>\n ))}\n </div>\n </div>\n )}\n </div>\n )\n}\n"],"names":["OverviewPage","data","setActiveItemData","setActiveType","onProductNavigate","apis","toggleSection","useSectionToggle","selectedUrl","setSelectedUrl","useState","_b","_a","servers","url","isUrlDropdownOpen","setIsUrlDropdownOpen","useEffect","_jsxs","className","children","_jsx","jsx","title","version","onClick","prev","jsxs","length","SVGLoader","role","tabIndex","e","stopPropagation","copyToClipboard","src","newCopyIcon","arrowUp","arrowDown","_c","map","server","index","type","name","checked","readOnly","description","associatedProduct","productId","Object","entries","tags","tag","endpoints","endpoint","idx","assign","api","id","apiSpecId","findIndex","some","tagSectionIndex","sort","a","b","localeCompare","_","tagData","find","t","SectionEnum","API_SECTION","setTo","ENDPOINTS_SECTION","TAG_SECTION","RESOURCE","resetOthers","filterKeys","OVERVIEW","handleClick","method","toLowerCase","summary","slice","path","arrowRightGray","_d","apiVersions","verObj","matchedVersion","v","matchedApi","handleVersionClick","metaData"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- import{j as e}from"../../../../_virtual/jsx-runtime.js";import{useState as s}from"react";import{d as o}from"../../../../_virtual/index3.js";import t from"../../../components/SVGLoader/SVGLoader.js";import r from"../../../assets/icons/UpArrow.svg.js";import i from"../../../assets/icons/DownArrow.svg.js";import a from"../../../assets/icons/ApiIcon.svg.js";import n from"../../../assets/icons/FilterIcon.svg.js";import l from"../../../assets/icons/BookIcon.svg.js";import c from"../../../assets/icons/searchIcon.svg.js";import d from"../../../components/Tooltip/Tooltip.js";import m from"../../../components/dialog/index.js";import{METHOD_OPTIONS as h}from"../../../constants/methods.constant.js";import p from"./DocsHeader.module.scss.js";const j=({transformedOpenApis:j,updateFilteredData:u})=>{const[x,v]=s(!1),[f,g]=s(""),[N,b]=s([]),[_,C]=s(!1);return e.jsxs(e.Fragment,{children:[e.jsx("header",{className:p.api_docs_header,children:e.jsxs("div",{className:p.header_content,children:[e.jsxs(o.Button,{variant:"outlined",size:"small",className:p.search_filter_btn,onClick:()=>{v(!0)},children:["Search & Filter",e.jsx(t,{src:n})]}),e.jsxs("div",{className:p.nav_buttons,children:[e.jsx(d,{placement:"bottom",delay:[0,0],className:`guides-tooltip ${p.tippy_box_color}`,content:e.jsx("div",{children:"Coming Soon"}),children:e.jsxs(o.Button,{variant:"outlined",size:"small",className:"guide-btn",disabled:!0,children:[e.jsx(t,{src:l}),"GUIDES"]})}),e.jsxs(o.Button,{variant:"outlined",size:"small",className:p.api_btn,children:[e.jsx(t,{src:a}),"   API reference"]})]})]})}),e.jsx(m,{size:"sm",open:x,onClose:()=>{v(!1),C(!1)},icon:!1,withClose:!1,noActions:!0,content:e.jsxs("div",{className:"search-filter-form "+(_?"expanded":""),children:[e.jsx("div",{className:"search-filter-form__header",children:e.jsx("p",{className:"search-filter-form__header__title",children:"Search & Filter"})}),e.jsx(o.Input,{className:"name-input",placeholder:"Search by API name",value:f,onChange:e=>g(e),size:o.Size.Medium,clearable:!0,endAdornment:e.jsx(t,{src:c})}),e.jsxs("div",{className:"method-container",children:[e.jsx("label",{children:"Method"}),e.jsxs("div",{className:"typeDdl",onClick:()=>C(e=>!e),children:[e.jsx("span",{children:"Select Method"}),e.jsx(t,{src:_?r:i})]}),_&&e.jsx("div",{className:"methodList",children:h.map(s=>e.jsxs("div",{className:"method-item",children:[e.jsx("input",{type:"checkbox",className:"agreement-checkbox",checked:N.includes(s.value),onChange:e=>((e,s)=>{const{target:{checked:o}}=e;o?b(e=>[...e,s.value]):N.includes(s.value)&&b(e=>e.filter(e=>e!=s.value))})(e,s)}),e.jsx("span",{style:{color:s.color},children:s.label})]}))})]}),e.jsx("div",{className:"button-container",children:e.jsx(o.Button,{variant:"contained",color:"primary",size:"large",onClick:()=>{if(!((null==f?void 0:f.trim())||N&&0!==N.length))return u(j,!0),void v(!1);let e=[...j];if(null==f?void 0:f.trim()){const s=f.toLowerCase();e=e.filter(e=>e.title.toLowerCase().includes(s))}(null==N?void 0:N.length)&&(e=e.filter(e=>{const s=Object.values(e.tags||{}).flat().map(e=>{var s;return null===(s=e.method)||void 0===s?void 0:s.toLowerCase()});return N.some(e=>s.includes(e.toLowerCase()))})),u(e),v(!1)},className:"dialog-submit-btn",children:"Apply"})})]})})]})};export{j as default};
1
+ import{j as e}from"../../../../_virtual/jsx-runtime.js";import{useState as s}from"react";import{d as o}from"../../../../_virtual/index3.js";import t from"../../../components/SVGLoader/SVGLoader.js";import r from"../../../assets/icons/UpArrow.svg.js";import i from"../../../assets/icons/DownArrow.svg.js";import a from"../../../assets/icons/ApiIcon.svg.js";import n from"../../../assets/icons/FilterIcon.svg.js";import l from"../../../assets/icons/BookIcon.svg.js";import c from"../../../assets/icons/searchIcon.svg.js";import d from"../../../components/Tooltip/Tooltip.js";import m from"../../../components/dialog/index.js";import{METHOD_OPTIONS as h}from"../../../constants/methods.constant.js";import j from"./DocsHeader.module.scss.js";const p=({transformedOpenApis:p,updateFilteredData:u})=>{const[v,x]=s(!1),[f,g]=s(""),[N,b]=s([]),[_,C]=s(!1);return e.jsxs(e.Fragment,{children:[e.jsx("header",{className:j.api_docs_header,children:e.jsxs("div",{className:j.header_content,children:[e.jsxs(o.Button,{variant:"outlined",size:"small",className:j.search_filter_btn,onClick:()=>{x(!0)},children:["Search & Filter",e.jsx(t,{src:n})]}),e.jsxs("div",{className:j.nav_buttons,children:[e.jsx(d,{placement:"bottom",offset:[10,5],delay:[0,0],className:"guide-tooltip",content:e.jsx("div",{children:"Coming Soon"}),children:e.jsxs(o.Button,{variant:"outlined",size:"small",className:"guide-btn",disabled:!0,children:[e.jsx(t,{src:l}),"GUIDES"]})}),e.jsxs(o.Button,{variant:"outlined",size:"small",className:j.api_btn,children:[e.jsx(t,{src:a}),"   API reference"]})]})]})}),e.jsx(m,{size:"sm",open:v,onClose:()=>{x(!1),C(!1)},icon:!1,withClose:!1,noActions:!0,content:e.jsxs("div",{className:"search-filter-form "+(_?"expanded":""),children:[e.jsx("div",{className:"search-filter-form__header",children:e.jsx("p",{className:"search-filter-form__header__title",children:"Search & Filter"})}),e.jsx(o.Input,{className:"name-input",placeholder:"Search by API name",value:f,onChange:e=>g(e),size:o.Size.Medium,clearable:!0,endAdornment:e.jsx(t,{src:c})}),e.jsxs("div",{className:"method-container",children:[e.jsx("label",{children:"Method"}),e.jsxs("div",{className:"typeDdl",onClick:()=>C(e=>!e),children:[e.jsx("span",{children:"Select Method"}),e.jsx(t,{src:_?r:i})]}),_&&e.jsx("div",{className:"methodList",children:h.map(s=>e.jsxs("div",{className:"method-item",children:[e.jsx("input",{type:"checkbox",className:"agreement-checkbox",checked:N.includes(s.value),onChange:e=>((e,s)=>{const{target:{checked:o}}=e;o?b(e=>[...e,s.value]):N.includes(s.value)&&b(e=>e.filter(e=>e!=s.value))})(e,s)}),e.jsx("span",{style:{color:s.color},children:s.label})]}))})]}),e.jsx("div",{className:"button-container",children:e.jsx(o.Button,{variant:"contained",color:"primary",size:"large",onClick:()=>{if(!((null==f?void 0:f.trim())||N&&0!==N.length))return u(p,!0),void x(!1);let e=[...p];if(null==f?void 0:f.trim()){const s=f.toLowerCase();e=e.filter(e=>e.title.toLowerCase().includes(s))}(null==N?void 0:N.length)&&(e=e.filter(e=>{const s=Object.values(e.tags||{}).flat().map(e=>{var s;return null===(s=e.method)||void 0===s?void 0:s.toLowerCase()});return N.some(e=>s.includes(e.toLowerCase()))})),u(e),x(!1)},className:"dialog-submit-btn",children:"Apply"})})]})})]})};export{p as default};
2
2
  //# sourceMappingURL=DocsHeader.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"DocsHeader.js","sources":["../../../../../src/layout/docsComponents/DocsHeader/DocsHeader.tsx"],"sourcesContent":["import React, { useState, useRef } from 'react'\nimport { Button, Size, Input } from 'digitinary-ui'\nimport SVGLoader from '../../../components/SVGLoader/SVGLoader'\nimport {\n FilterIcon,\n BookIcon,\n ApiIcon,\n SearchIcon,\n UpArrowIcon,\n DownArrowIcon,\n} from '../../../assets/icons'\nimport Tooltip from '../../../components/Tooltip/Tooltip'\nimport CommonDialog from '../../../components/dialog/index'\nimport { METHOD_OPTIONS } from '../../../constants/methods.constant'\nimport styles from './DocsHeader.module.scss'\nimport { OverviewData } from '../../../../src/layout/docsLayout'\n\nconst DocsHeader = ({\n transformedOpenApis,\n updateFilteredData,\n}: {\n transformedOpenApis: OverviewData[]\n updateFilteredData: (filteredItems: OverviewData[], isReset?: boolean) => void\n}) => {\n const [showSearchFilter, setShowSearchFilter] = useState<boolean>(false)\n const [apiName, setApiName] = useState<string>('')\n const [selectedMethods, setSelectedMethods] = useState<any[]>([])\n const [isMethodDropdownOpen, setIsMethodDropdownOpen] = useState<boolean>(false)\n\n const handleOpenSearchFilter = (): void => {\n setShowSearchFilter(true)\n }\n\n const handleCloseSearchFilter = (): void => {\n setShowSearchFilter(false)\n setIsMethodDropdownOpen(false)\n }\n\n const handleApplyFilters = (): void => {\n // Reset: no filters applied\n if (!apiName?.trim() && (!selectedMethods || selectedMethods.length === 0)) {\n updateFilteredData(transformedOpenApis, true)\n setShowSearchFilter(false)\n return\n }\n\n let filteredItems = [...transformedOpenApis]\n\n // Filter by API name\n if (apiName?.trim()) {\n const lowerApiName = apiName.toLowerCase()\n filteredItems = filteredItems.filter((api) => api.title.toLowerCase().includes(lowerApiName))\n }\n\n // Filter by selected HTTP methods\n if (selectedMethods?.length) {\n filteredItems = filteredItems.filter((api) => {\n const allMethods = Object.values(api.tags || {})\n .flat()\n .map((endpoint: any) => endpoint.method?.toLowerCase())\n\n return selectedMethods.some((method) => allMethods.includes(method.toLowerCase()))\n })\n }\n\n updateFilteredData(filteredItems)\n setShowSearchFilter(false)\n }\n\n const handleCheckMethod = (e, method: (typeof METHOD_OPTIONS)[0]) => {\n const {\n target: { checked },\n } = e\n if (checked) {\n setSelectedMethods((prev) => [...prev, method.value])\n } else {\n if (selectedMethods.includes(method.value)) {\n setSelectedMethods((prev) => prev.filter((_m) => _m != method.value))\n }\n }\n }\n\n return (\n <>\n <header className={styles.api_docs_header}>\n <div className={styles.header_content}>\n <Button\n variant=\"outlined\"\n size=\"small\"\n className={styles.search_filter_btn}\n onClick={handleOpenSearchFilter}\n >\n Search & Filter\n <SVGLoader src={FilterIcon} />\n </Button>\n <div className={styles.nav_buttons}>\n <Tooltip\n placement=\"bottom\"\n delay={[0, 0]}\n className={`guides-tooltip ${styles.tippy_box_color}`}\n content={<div>Coming Soon</div>}\n >\n <Button variant=\"outlined\" size=\"small\" className=\"guide-btn\" disabled={true}>\n <SVGLoader src={BookIcon} />\n GUIDES\n </Button>\n </Tooltip>\n <Button variant=\"outlined\" size=\"small\" className={styles.api_btn}>\n <SVGLoader src={ApiIcon} /> &nbsp; API reference\n </Button>\n </div>\n </div>\n </header>\n <CommonDialog\n size=\"sm\"\n open={showSearchFilter}\n onClose={handleCloseSearchFilter}\n icon={false}\n withClose={false}\n noActions\n content={\n <div className={`search-filter-form ${isMethodDropdownOpen ? 'expanded' : ''}`}>\n <div className=\"search-filter-form__header\">\n <p className=\"search-filter-form__header__title\">Search & Filter</p>\n </div>\n <Input\n className=\"name-input\"\n placeholder=\"Search by API name\"\n value={apiName}\n onChange={(value) => setApiName(value as string)}\n size={Size.Medium}\n clearable\n endAdornment={<SVGLoader src={SearchIcon} />}\n />\n <div className=\"method-container\">\n <label>Method</label>\n {/* <SelectGroup\n isMultiple={true}\n size={Size.Medium}\n placeholder=\"Select Method\"\n value={selectedMethods}\n onChange={(value) => setSelectedMethods(value || [])}\n options={[\n \n ]}\n withSearch={false}\n className=\"method-select custom-select-border\"\n /> */}\n <div className=\"typeDdl\" onClick={() => setIsMethodDropdownOpen((prev) => !prev)}>\n <span>Select Method</span>\n <SVGLoader src={!isMethodDropdownOpen ? DownArrowIcon : UpArrowIcon} />\n </div>\n {isMethodDropdownOpen && (\n <div className=\"methodList\">\n {METHOD_OPTIONS.map((_m) => (\n <div className=\"method-item\">\n <input\n type=\"checkbox\"\n className=\"agreement-checkbox\"\n checked={selectedMethods.includes(_m.value)}\n onChange={(e) => handleCheckMethod(e, _m)}\n />\n <span style={{ color: _m.color }}>{_m.label}</span>\n </div>\n ))}\n </div>\n )}\n </div>\n <div className=\"button-container\">\n <Button\n variant=\"contained\"\n color=\"primary\"\n size=\"large\"\n onClick={handleApplyFilters}\n className=\"dialog-submit-btn\"\n >\n Apply\n </Button>\n </div>\n </div>\n }\n />\n </>\n )\n}\n\nexport default DocsHeader\n"],"names":["DocsHeader","transformedOpenApis","updateFilteredData","showSearchFilter","setShowSearchFilter","useState","apiName","setApiName","selectedMethods","setSelectedMethods","isMethodDropdownOpen","setIsMethodDropdownOpen","_jsxs","_jsx","jsx","className","styles","api_docs_header","children","header_content","Button","variant","size","search_filter_btn","onClick","SVGLoader","src","FilterIcon","jsxs","nav_buttons","Tooltip","placement","delay","tippy_box_color","content","disabled","BookIcon","api_btn","ApiIcon","CommonDialog","open","onClose","icon","withClose","noActions","Input","placeholder","value","onChange","Size","Medium","clearable","endAdornment","SearchIcon","prev","UpArrowIcon","DownArrowIcon","METHOD_OPTIONS","map","_m","type","checked","includes","e","method","target","filter","handleCheckMethod","style","color","label","trim","length","filteredItems","lowerApiName","toLowerCase","api","title","allMethods","Object","values","tags","flat","endpoint","_a","some"],"mappings":"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"}
1
+ {"version":3,"file":"DocsHeader.js","sources":["../../../../../src/layout/docsComponents/DocsHeader/DocsHeader.tsx"],"sourcesContent":["import React, { useState, useRef } from 'react'\nimport { Button, Size, Input } from 'digitinary-ui'\nimport SVGLoader from '../../../components/SVGLoader/SVGLoader'\nimport {\n FilterIcon,\n BookIcon,\n ApiIcon,\n SearchIcon,\n UpArrowIcon,\n DownArrowIcon,\n} from '../../../assets/icons'\nimport Tooltip from '../../../components/Tooltip/Tooltip'\nimport CommonDialog from '../../../components/dialog/index'\nimport { METHOD_OPTIONS } from '../../../constants/methods.constant'\nimport styles from './DocsHeader.module.scss'\nimport { OverviewData } from '../../../../src/layout/docsLayout'\n\nconst DocsHeader = ({\n transformedOpenApis,\n updateFilteredData,\n}: {\n transformedOpenApis: OverviewData[]\n updateFilteredData: (filteredItems: OverviewData[], isReset?: boolean) => void\n}) => {\n const [showSearchFilter, setShowSearchFilter] = useState<boolean>(false)\n const [apiName, setApiName] = useState<string>('')\n const [selectedMethods, setSelectedMethods] = useState<any[]>([])\n const [isMethodDropdownOpen, setIsMethodDropdownOpen] = useState<boolean>(false)\n\n const handleOpenSearchFilter = (): void => {\n setShowSearchFilter(true)\n }\n\n const handleCloseSearchFilter = (): void => {\n setShowSearchFilter(false)\n setIsMethodDropdownOpen(false)\n }\n\n const handleApplyFilters = (): void => {\n // Reset: no filters applied\n if (!apiName?.trim() && (!selectedMethods || selectedMethods.length === 0)) {\n updateFilteredData(transformedOpenApis, true)\n setShowSearchFilter(false)\n return\n }\n\n let filteredItems = [...transformedOpenApis]\n\n // Filter by API name\n if (apiName?.trim()) {\n const lowerApiName = apiName.toLowerCase()\n filteredItems = filteredItems.filter((api) => api.title.toLowerCase().includes(lowerApiName))\n }\n\n // Filter by selected HTTP methods\n if (selectedMethods?.length) {\n filteredItems = filteredItems.filter((api) => {\n const allMethods = Object.values(api.tags || {})\n .flat()\n .map((endpoint: any) => endpoint.method?.toLowerCase())\n\n return selectedMethods.some((method) => allMethods.includes(method.toLowerCase()))\n })\n }\n\n updateFilteredData(filteredItems)\n setShowSearchFilter(false)\n }\n\n const handleCheckMethod = (e, method: (typeof METHOD_OPTIONS)[0]) => {\n const {\n target: { checked },\n } = e\n if (checked) {\n setSelectedMethods((prev) => [...prev, method.value])\n } else {\n if (selectedMethods.includes(method.value)) {\n setSelectedMethods((prev) => prev.filter((_m) => _m != method.value))\n }\n }\n }\n\n return (\n <>\n <header className={styles.api_docs_header}>\n <div className={styles.header_content}>\n <Button\n variant=\"outlined\"\n size=\"small\"\n className={styles.search_filter_btn}\n onClick={handleOpenSearchFilter}\n >\n Search & Filter\n <SVGLoader src={FilterIcon} />\n </Button>\n <div className={styles.nav_buttons}>\n <Tooltip\n placement=\"bottom\"\n offset={[10, 5]}\n delay={[0, 0]}\n className=\"guide-tooltip\"\n content={<div>Coming Soon</div>}\n >\n <Button variant=\"outlined\" size=\"small\" className=\"guide-btn\" disabled={true}>\n <SVGLoader src={BookIcon} />\n GUIDES\n </Button>\n </Tooltip>\n <Button variant=\"outlined\" size=\"small\" className={styles.api_btn}>\n <SVGLoader src={ApiIcon} /> &nbsp; API reference\n </Button>\n </div>\n </div>\n </header>\n <CommonDialog\n size=\"sm\"\n open={showSearchFilter}\n onClose={handleCloseSearchFilter}\n icon={false}\n withClose={false}\n noActions\n content={\n <div className={`search-filter-form ${isMethodDropdownOpen ? 'expanded' : ''}`}>\n <div className=\"search-filter-form__header\">\n <p className=\"search-filter-form__header__title\">Search & Filter</p>\n </div>\n <Input\n className=\"name-input\"\n placeholder=\"Search by API name\"\n value={apiName}\n onChange={(value) => setApiName(value as string)}\n size={Size.Medium}\n clearable\n endAdornment={<SVGLoader src={SearchIcon} />}\n />\n <div className=\"method-container\">\n <label>Method</label>\n {/* <SelectGroup\n isMultiple={true}\n size={Size.Medium}\n placeholder=\"Select Method\"\n value={selectedMethods}\n onChange={(value) => setSelectedMethods(value || [])}\n options={[\n \n ]}\n withSearch={false}\n className=\"method-select custom-select-border\"\n /> */}\n <div className=\"typeDdl\" onClick={() => setIsMethodDropdownOpen((prev) => !prev)}>\n <span>Select Method</span>\n <SVGLoader src={!isMethodDropdownOpen ? DownArrowIcon : UpArrowIcon} />\n </div>\n {isMethodDropdownOpen && (\n <div className=\"methodList\">\n {METHOD_OPTIONS.map((_m) => (\n <div className=\"method-item\">\n <input\n type=\"checkbox\"\n className=\"agreement-checkbox\"\n checked={selectedMethods.includes(_m.value)}\n onChange={(e) => handleCheckMethod(e, _m)}\n />\n <span style={{ color: _m.color }}>{_m.label}</span>\n </div>\n ))}\n </div>\n )}\n </div>\n <div className=\"button-container\">\n <Button\n variant=\"contained\"\n color=\"primary\"\n size=\"large\"\n onClick={handleApplyFilters}\n className=\"dialog-submit-btn\"\n >\n Apply\n </Button>\n </div>\n </div>\n }\n />\n </>\n )\n}\n\nexport default DocsHeader\n"],"names":["DocsHeader","transformedOpenApis","updateFilteredData","showSearchFilter","setShowSearchFilter","useState","apiName","setApiName","selectedMethods","setSelectedMethods","isMethodDropdownOpen","setIsMethodDropdownOpen","_jsxs","_jsx","jsx","className","styles","api_docs_header","children","header_content","Button","variant","size","search_filter_btn","onClick","SVGLoader","src","FilterIcon","nav_buttons","Tooltip","placement","offset","delay","content","jsxs","disabled","BookIcon","api_btn","ApiIcon","CommonDialog","open","onClose","icon","withClose","noActions","Input","placeholder","value","onChange","Size","Medium","clearable","endAdornment","SearchIcon","prev","UpArrowIcon","DownArrowIcon","METHOD_OPTIONS","map","_m","type","checked","includes","e","method","target","filter","handleCheckMethod","style","color","label","trim","length","filteredItems","lowerApiName","toLowerCase","api","title","allMethods","Object","values","tags","flat","endpoint","_a","some"],"mappings":"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"}
package/dist/styles.css CHANGED
@@ -1642,15 +1642,6 @@ div.endBtnIcon {
1642
1642
  margin-right: 0.4075rem;
1643
1643
  }
1644
1644
 
1645
- .tippy_box_color {
1646
- margin-left: 2rem;
1647
- background-color: #000 !important;
1648
- border: none;
1649
- height: 1.875rem;
1650
- border-radius: 0.75rem;
1651
- margin-top: -0.5rem;
1652
- }
1653
-
1654
1645
  :global(.tippy-arrow) {
1655
1646
  transform: translateX(12px) !important;
1656
1647
  }
@@ -1807,6 +1798,22 @@ div.endBtnIcon {
1807
1798
  opacity: 1 !important;
1808
1799
  backdrop-filter: blur(0.5rem);
1809
1800
  background-color: rgba(0, 0, 0, 0.281) !important;
1801
+ }
1802
+ :global .guide-tooltip.guide-tooltip.guide-tooltip.guide-tooltip {
1803
+ background-color: #000;
1804
+ border: none;
1805
+ border-radius: 0.75rem;
1806
+ }
1807
+ :global .guide-tooltip.guide-tooltip.guide-tooltip.guide-tooltip.tippy-box .tippy-content.tippy-content {
1808
+ border-radius: 0.75rem;
1809
+ color: #fff;
1810
+ background-color: #000;
1811
+ }
1812
+ :global .guide-tooltip.guide-tooltip.guide-tooltip.guide-tooltip .tippy-arrow.tippy-arrow.tippy-arrow.tippy-arrow {
1813
+ color: #000;
1814
+ }
1815
+ :global .guide-tooltip.guide-tooltip.guide-tooltip.guide-tooltip .tippy-arrow.tippy-arrow.tippy-arrow.tippy-arrow::before {
1816
+ color: #000;
1810
1817
  }.codebox {
1811
1818
  border-radius: 0.25rem;
1812
1819
  overflow: hidden;
@@ -2234,7 +2241,6 @@ main .type-ddl {
2234
2241
  width: 100%;
2235
2242
  background-color: #edf1fb;
2236
2243
  border-radius: 0.375rem;
2237
- padding: 0.5rem 1rem;
2238
2244
  }
2239
2245
  main .url-text {
2240
2246
  flex: 1;
@@ -2365,6 +2371,7 @@ main .api-details-expanded h3 {
2365
2371
  margin-bottom: 0.5rem;
2366
2372
  }
2367
2373
  main .api-details-expanded .url-box {
2374
+ position: relative;
2368
2375
  background-color: #edf1fb;
2369
2376
  padding: 0.375rem 0.75rem;
2370
2377
  border-radius: 0.5rem;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@digi-frontend/dgate-api-documentation",
3
- "version": "1.0.94",
3
+ "version": "1.0.96",
4
4
  "main": "dist/src/index.js",
5
5
  "module": "dist/src/index.js",
6
6
  "types": "dist/types/index.d.ts",
@@ -97,52 +97,49 @@ export const EndpointPage = ({
97
97
  <h3>{data.api.title}</h3>
98
98
  <h1 className="api-title">{data?.summary}</h1>
99
99
  <div className="url-box">
100
+ {isUrlDropdownOpen && selectedUrl.length !== 0 && (
101
+ <div className="url-list">
102
+ {data.api?.servers?.map((server, index) => (
103
+ <div
104
+ key={index}
105
+ className="url-item"
106
+ onClick={() => {
107
+ setSelectedUrl(server.url)
108
+ setIsUrlDropdownOpen(false)
109
+ }}
110
+ >
111
+ <input
112
+ type="radio"
113
+ name="api-method"
114
+ checked={selectedUrl === server.url}
115
+ readOnly
116
+ />
117
+ <span>{`${server.url}${data.path}`}</span>
118
+ </div>
119
+ ))}
120
+ </div>
121
+ )}
100
122
  <div className="url-box_text-container">
101
123
  <span className={`method-label ${data?.method?.toLowerCase()}`}>{data.method}</span>
102
124
  <div className="url-container">
103
125
  <div className="type-ddl" onClick={() => setIsUrlDropdownOpen((prev) => !prev)}>
104
126
  <span className="url-text">{`${selectedUrl}${data.path}`}</span>
105
127
  <div className="icon-container">
106
- {selectedUrl.length !== 0 && (
107
- <SVGLoader
108
- className="icon"
109
- role="button"
110
- tabIndex={0}
111
- onClick={(e) => {
112
- e.stopPropagation()
113
- copyToClipboard(selectedUrl)
114
- }}
115
- src={newCopyIcon}
116
- />
117
- )}
128
+ <SVGLoader
129
+ className="icon"
130
+ role="button"
131
+ tabIndex={0}
132
+ onClick={(e) => {
133
+ e.stopPropagation()
134
+ copyToClipboard(`${selectedUrl}${data.path}`)
135
+ }}
136
+ src={newCopyIcon}
137
+ />
118
138
  {selectedUrl.length !== 0 && (
119
139
  <SVGLoader src={!isUrlDropdownOpen ? arrowDown : arrowUp} />
120
140
  )}
121
141
  </div>
122
142
  </div>
123
-
124
- {isUrlDropdownOpen && selectedUrl.length !== 0 && (
125
- <div className="url-list">
126
- {data.api?.servers?.map((server, index) => (
127
- <div
128
- key={index}
129
- className="url-item"
130
- onClick={() => {
131
- setSelectedUrl(server.url)
132
- setIsUrlDropdownOpen(false)
133
- }}
134
- >
135
- <input
136
- type="radio"
137
- name="api-method"
138
- checked={selectedUrl === server.url}
139
- readOnly
140
- />
141
- <span>{`${server.url}${data.path}`}</span>
142
- </div>
143
- ))}
144
- </div>
145
- )}
146
143
  </div>
147
144
  </div>
148
145
  </div>
@@ -14,7 +14,6 @@ main {
14
14
  width: 100%;
15
15
  background-color: #edf1fb;
16
16
  border-radius: 0.375rem;
17
- padding: 0.5rem 1rem;
18
17
  }
19
18
 
20
19
  .url-text {
@@ -171,6 +170,7 @@ main {
171
170
  }
172
171
 
173
172
  .url-box {
173
+ position: relative;
174
174
  background-color: #edf1fb;
175
175
  padding: 0.375rem 0.75rem;
176
176
  border-radius: 0.5rem;
@@ -100,7 +100,6 @@ export const OverviewPage = ({
100
100
  <p className="api-version">
101
101
  API Version: <span>{data?.version}</span>
102
102
  </p>
103
-
104
103
  <div className="custom-url-input">
105
104
  <label className="input-label">API Base URL</label>
106
105
  <div className="url-container">
@@ -28,7 +28,7 @@
28
28
  line-height: 1.25rem;
29
29
 
30
30
  .btnContentWrapper {
31
- .btnContent{
31
+ .btnContent {
32
32
  font-size: 0.918rem !important;
33
33
  }
34
34
  }
@@ -81,7 +81,7 @@
81
81
  height: 2.25rem;
82
82
 
83
83
  .btnContentWrapper {
84
- .btnContent{
84
+ .btnContent {
85
85
  font-size: 0.918rem !important;
86
86
  }
87
87
  }
@@ -96,15 +96,6 @@
96
96
  }
97
97
  }
98
98
 
99
- .tippy_box_color {
100
- margin-left: 2rem;
101
- background-color: #000 !important;
102
- border: none;
103
- height: 1.875rem;
104
- border-radius: 0.75rem;
105
- margin-top: -0.5rem;
106
- }
107
-
108
99
  :global(.tippy-arrow) {
109
100
  transform: translateX(12px) !important;
110
101
  }
@@ -280,4 +271,27 @@
280
271
  backdrop-filter: blur(0.5rem);
281
272
  background-color: rgba(0, 0, 0, 0.281) !important;
282
273
  }
274
+
275
+ // Tooltip overrides
276
+ .guide-tooltip.guide-tooltip.guide-tooltip.guide-tooltip {
277
+ background-color: #000;
278
+ border: none;
279
+ border-radius: 0.75rem;
280
+
281
+ &.tippy-box {
282
+ .tippy-content.tippy-content {
283
+ border-radius: 0.75rem;
284
+ color: #fff;
285
+ background-color: #000;
286
+ }
287
+ }
288
+
289
+ .tippy-arrow.tippy-arrow.tippy-arrow.tippy-arrow {
290
+ color: #000;
291
+
292
+ &::before {
293
+ color: #000;
294
+ }
295
+ }
296
+ }
283
297
  }
@@ -96,8 +96,9 @@ const DocsHeader = ({
96
96
  <div className={styles.nav_buttons}>
97
97
  <Tooltip
98
98
  placement="bottom"
99
+ offset={[10, 5]}
99
100
  delay={[0, 0]}
100
- className={`guides-tooltip ${styles.tippy_box_color}`}
101
+ className="guide-tooltip"
101
102
  content={<div>Coming Soon</div>}
102
103
  >
103
104
  <Button variant="outlined" size="small" className="guide-btn" disabled={true}>
package/variables.txt CHANGED
@@ -1 +1 @@
1
- export APP_VERSION=1.0.93
1
+ export APP_VERSION=1.0.95