@digi-frontend/dgate-api-documentation 1.0.57 → 1.0.60

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 (81) hide show
  1. package/dist/_virtual/index4.js +1 -1
  2. package/dist/_virtual/index5.js +1 -1
  3. package/dist/_virtual/index6.js +1 -1
  4. package/dist/_virtual/index7.js +1 -1
  5. package/dist/node_modules/digitinary-ui/dist/index.js.map +1 -1
  6. package/dist/node_modules/highlight.js/lib/core.js.map +1 -1
  7. package/dist/node_modules/react/cjs/react-jsx-runtime.development.js +1 -1
  8. package/dist/node_modules/react/cjs/react-jsx-runtime.development.js.map +1 -1
  9. package/dist/node_modules/react-fast-compare/index.js +1 -1
  10. package/dist/node_modules/react-fast-compare/index.js.map +1 -1
  11. package/dist/node_modules/react-property/lib/index.js.map +1 -1
  12. package/dist/node_modules/toposort/index.js +1 -1
  13. package/dist/node_modules/yup/index.esm.js +1 -1
  14. package/dist/node_modules/yup/index.esm.js.map +1 -1
  15. package/dist/src/components/InfoForm/InfoForm.js +1 -1
  16. package/dist/src/components/InfoForm/InfoForm.js.map +1 -1
  17. package/dist/src/components/JsonInput/JsonInput.js.map +1 -1
  18. package/dist/src/components/LivePreview/LivePreview.js.map +1 -1
  19. package/dist/src/components/MethodAccordion/MethodAccordion.js.map +1 -1
  20. package/dist/src/components/SVGLoader/SVGLoader.js.map +1 -1
  21. package/dist/src/components/SectionHead/SectionHead.js.map +1 -1
  22. package/dist/src/components/SimpleLabelValue/SimpleLabelValue.js.map +1 -1
  23. package/dist/src/components/Tooltip/Tooltip.js.map +1 -1
  24. package/dist/src/components/dialog/index.js.map +1 -1
  25. package/dist/src/components/table/table.js +1 -1
  26. package/dist/src/components/table/table.js.map +1 -1
  27. package/dist/src/components/table/tags-table.js.map +1 -1
  28. package/dist/src/context/SectionToggleContext.js +2 -0
  29. package/dist/src/context/SectionToggleContext.js.map +1 -0
  30. package/dist/src/helpers/docs.helper.js +1 -1
  31. package/dist/src/helpers/docs.helper.js.map +1 -1
  32. package/dist/src/helpers/layout.helper.js.map +1 -1
  33. package/dist/src/layout/docsComponents/Codebox/Codebox.js.map +1 -1
  34. package/dist/src/layout/docsComponents/DocsAside/DocsAside.js +1 -1
  35. package/dist/src/layout/docsComponents/DocsAside/DocsAside.js.map +1 -1
  36. package/dist/src/layout/docsComponents/DocsContent/DocsContent.js +1 -1
  37. package/dist/src/layout/docsComponents/DocsContent/DocsContent.js.map +1 -1
  38. package/dist/src/layout/docsComponents/DocsContent/EndpointPage/index.js +1 -1
  39. package/dist/src/layout/docsComponents/DocsContent/EndpointPage/index.js.map +1 -1
  40. package/dist/src/layout/docsComponents/DocsContent/OverviewPage/index.js +1 -1
  41. package/dist/src/layout/docsComponents/DocsContent/OverviewPage/index.js.map +1 -1
  42. package/dist/src/layout/docsComponents/DocsHeader/DocsHeader.js.map +1 -1
  43. package/dist/src/layout/docsComponents/DocsSideMenuTree/DocsSideMenuTree.js +1 -1
  44. package/dist/src/layout/docsComponents/DocsSideMenuTree/DocsSideMenuTree.js.map +1 -1
  45. package/dist/src/layout/docsLayout.js +1 -1
  46. package/dist/src/layout/docsLayout.js.map +1 -1
  47. package/dist/src/layout/layout.js +1 -1
  48. package/dist/src/layout/layout.js.map +1 -1
  49. package/dist/src/utils/index.js +1 -1
  50. package/dist/src/utils/index.js.map +1 -1
  51. package/dist/styles.css +753 -753
  52. package/dist/types/context/SectionToggleContext.d.ts +37 -0
  53. package/dist/types/layout/docsComponents/DocsContent/DocsContent.d.ts +2 -3
  54. package/dist/types/layout/docsComponents/DocsContent/EndpointPage/index.d.ts +4 -2
  55. package/dist/types/layout/docsComponents/DocsContent/OverviewPage/index.d.ts +2 -2
  56. package/dist/types/layout/docsComponents/DocsHeader/DocsHeader.d.ts +5 -2
  57. package/dist/types/layout/docsComponents/DocsSideMenuTree/DocsSideMenuTree.d.ts +3 -4
  58. package/dist/types/layout/docsLayout.d.ts +1 -6
  59. package/dist/types/types/docsLayout.type.d.ts +7 -0
  60. package/dist/types/utils/index.d.ts +1 -0
  61. package/package.json +1 -1
  62. package/src/components/InfoForm/InfoForm.tsx +2 -1
  63. package/src/components/table/table.tsx +1 -3
  64. package/src/context/SectionToggleContext.tsx +121 -0
  65. package/src/helpers/docs.helper.ts +1 -1
  66. package/src/layout/docsComponents/DocsAside/DocsAside.tsx +3 -3
  67. package/src/layout/docsComponents/DocsAside/style.module.scss +3 -3
  68. package/src/layout/docsComponents/DocsContent/DocsContent.tsx +18 -7
  69. package/src/layout/docsComponents/DocsContent/EndpointPage/index.tsx +46 -10
  70. package/src/layout/docsComponents/DocsContent/OverviewPage/index.tsx +37 -30
  71. package/src/layout/docsComponents/DocsHeader/DocsHeader.tsx +4 -3
  72. package/src/layout/docsComponents/DocsSideMenuTree/DocsSideMenuTree.tsx +68 -44
  73. package/src/layout/docsLayout.tsx +35 -96
  74. package/src/layout/layout.tsx +1 -0
  75. package/src/types/docsLayout.type.ts +7 -0
  76. package/src/utils/index.ts +5 -0
  77. package/the_npm_commands.sh +12 -0
  78. package/variables.txt +4 -0
  79. package/dist/src/layout/docsComponents/DocsContent/TagPage/index.js +0 -2
  80. package/dist/src/layout/docsComponents/DocsContent/TagPage/index.js.map +0 -1
  81. package/dist/types/layout/docsComponents/DocsContent/TagPage/index.d.ts +0 -8
@@ -1,2 +1,2 @@
1
- import{j as e}from"../../../_virtual/jsx-runtime.js";import{useState as i,useEffect as t}from"react";import{useFormikContext as o}from"../../../node_modules/formik/dist/formik.esm.js";import{d as n}from"../../../_virtual/index.js";import s from"./InfoForm.module.scss.js";import l from"../../constants/regex.js";import r from"../Tooltip/Tooltip.js";import a from"../../assets/icons/DeleteIcon.svg.js";import d from"../../assets/icons/EditIcon.svg.js";import c from"../../assets/icons/DeleteOutlinedIcon.svg.js";import v from"../SVGLoader/SVGLoader.js";import m from"../dialog/index.js";import{tagsTableHeaders as u}from"../../constants/index.js";import p from"../table/tags-table.js";const g=({readOnly:g})=>{var x,h,j,D,f;const[b,C]=i([]),[y,N]=i(),[I,k]=i(""),[w,O]=i(""),[A,S]=i(""),{values:T,setFieldValue:B,errors:L}=o(),[_,E]=i({}),[z,W]=i({}),[R,V]=i(null),[F,P]=i(null),[$,q]=i(!1),[M,G]=i(!1);t((()=>{if(T&&T.components&&T.components.securitySchemes){const e=Object.keys(T.components.securitySchemes);if(e.length){const i=T.components.securitySchemes[e[0]].scheme||T.components.securitySchemes[e[0]].type;k(i&&"public"==i.toLowerCase()?"Keyless":i)}}}),[]),t((()=>{N(K(b))}),[b]),t((()=>{T.tags&&T.tags.length&&C(T.tags)}),[T.tags]);const H=(e,i,t)=>{const o=b.map(((o,n)=>n===t?Object.assign(Object.assign({},o),{[e]:i}):o));C(o)},K=i=>i.map(((i,t)=>{var o,c,m,u,p,x,h,j,D,f,b,C,y,N,I,k,L,R,F,$,M,G,K,J,Q,U,X,Y;return{id:t,tagName:i.name,description:e.jsxs("div",{className:s.paramDescContainer,children:[e.jsx(r,{allowHTML:!0,disabled:(null===(o=T.tags[t].description)||void 0===o?void 0:o.length)<=12,content:e.jsx("div",{style:{padding:"0.625rem"},children:T.tags[t].description}),arrowWithBorder:!0,placement:"bottom-end",type:"function",delay:[0,0],onShow:()=>{var e;return null===(e=z[t])||void 0===e?void 0:e.hide()},children:e.jsxs("p",{style:{alignSelf:"center",fontWeight:600,fontSize:"1rem"},children:[T.tags[t].description?T.tags[t].description.substring(0,12):g&&"-",T.tags[t].description&&T.tags[t].description.length>12?"...":""]})},`${t}-description`),e.jsx(r,{arrowWithBorder:!0,placement:"bottom-end",type:"function",trigger:"click",delay:[0,0],onCreate:e=>W((i=>Object.assign(Object.assign({},i),{[t]:e}))),content:e.jsxs("div",{className:s.editDescTooltipContent,children:[e.jsx("p",{className:s.editDescTooltipContent_header,children:"Description"}),e.jsx(n.TextArea,{placeholder:"Describe tag...",value:i.description,disabled:g,onChange:e=>{(""===e||l.ASCII.test(e))&&H("description",e,t)},maxLength:25}),!g&&e.jsx(n.Button,{className:s.editDescTooltipContent_btn,variant:"outlined",size:"small",onClick:()=>{var e,o;B(`tags[${t}].description`,null===(e=i.description)||void 0===e?void 0:e.trim()),null===(o=z[t])||void 0===o||o.hide()},disabled:!(null===(c=i.description)||void 0===c?void 0:c.trim()),children:"Apply"})]}),children:g||T.tags[t].description?e.jsx(n.Button,{className:s.editDescBtn,variant:"link",color:"action",endIcon:e.jsx(v,{src:d,width:"1.5rem",height:"1.5rem"})}):e.jsx(n.Button,{className:s.editDescBtn,variant:"link",color:"action",endIcon:e.jsx(v,{src:d,width:"1.5rem",height:"1.5rem"}),children:g||T.tags[t].description?"View Description":"Add Description"})})]}),externalDocs:e.jsxs("div",{className:s.paramDescContainer,children:[(null===(m=T.tags[t].externalDocs)||void 0===m?void 0:m.description)&&(null===(u=T.tags[t].externalDocs)||void 0===u?void 0:u.url)&&e.jsxs("a",{className:s.externalDocsLink,href:(null===(x=null===(p=T.tags[t])||void 0===p?void 0:p.externalDocs)||void 0===x?void 0:x.url)&&(null===(D=null===(j=null===(h=T.tags[t])||void 0===h?void 0:h.externalDocs)||void 0===j?void 0:j.url)||void 0===D?void 0:D.indexOf("http"))>-1?null===(b=null===(f=T.tags[t])||void 0===f?void 0:f.externalDocs)||void 0===b?void 0:b.url:`https://${null===(y=null===(C=T.tags[t])||void 0===C?void 0:C.externalDocs)||void 0===y?void 0:y.url}`,target:"_blank",style:(null===(N=T.tags[t].externalDocs)||void 0===N?void 0:N.description)?{}:{textDecoration:"none",pointerEvents:"none"},children:[(null===(I=T.tags[t].externalDocs)||void 0===I?void 0:I.description)?null===(L=null===(k=T.tags[t].externalDocs)||void 0===k?void 0:k.description)||void 0===L?void 0:L.substring(0,12):g&&"-",(null===(R=T.tags[t].externalDocs)||void 0===R?void 0:R.description)&&(null===($=null===(F=T.tags[t].externalDocs)||void 0===F?void 0:F.description)||void 0===$?void 0:$.length)>12?"...":""]}),e.jsx(r,{arrowWithBorder:!0,placement:"bottom-end",type:"function",trigger:"click",delay:[0,0],onCreate:e=>E((i=>Object.assign(Object.assign({},i),{[t]:e}))),content:e.jsxs("div",{className:s.editDescTooltipContent,children:[e.jsx("p",{className:s.editDescTooltipContent_header,children:"External Docs Description"}),e.jsx(n.TextArea,{placeholder:"Describe External Doc...",value:null===(M=i.externalDocs)||void 0===M?void 0:M.description,disabled:g,maxLength:25,onChange:e=>{(""===e||l.ASCII.test(e))&&(H("externalDocs",Object.assign(Object.assign({},i.externalDocs),{description:e}),t),O(e))}}),e.jsx("p",{className:s.editDescTooltipContent_header,children:"External Docs Link"}),e.jsx(n.TextArea,{placeholder:"External Docs Link...",value:null===(G=i.externalDocs)||void 0===G?void 0:G.url,disabled:g,maxLength:200,restrictedCharsRegex:l.urlRegex,onChange:e=>{(""===e||l.ASCII.test(e))&&(H("externalDocs",Object.assign(Object.assign({},i.externalDocs),{url:e}),t),S(e))}}),!g&&e.jsx(n.Button,{className:s.editDescTooltipContent_btn,variant:"outlined",size:"small",onClick:()=>{var e;B(`tags[${t}].externalDocs`,{description:null==w?void 0:w.trim(),url:null==A?void 0:A.trim()}),O(""),S(""),null===(e=_[t])||void 0===e||e.hide()},disabled:!((null===(K=T.tags[t].externalDocs)||void 0===K?void 0:K.url)&&!(null==A?void 0:A.trim())||(null==A?void 0:A.trim())&&l.urlRegex.test(A)),children:"Apply"})]}),children:g||(null===(J=T.tags[t].externalDocs)||void 0===J?void 0:J.description)?e.jsx("div",{className:s.editExternalDocs,children:e.jsx(v,{src:d,width:"1.5rem",height:"1.5rem",onClick:e=>{var t,o;null==e||e.stopPropagation(),O(null===(t=i.externalDocs)||void 0===t?void 0:t.description),S(null===(o=i.externalDocs)||void 0===o?void 0:o.url)}})}):e.jsxs(n.Button,{className:s.editDescBtn,variant:"link",color:"action",endIcon:e.jsx(v,{src:d,width:"1.5rem",height:"1.5rem"}),onClick:()=>{var e,t;O(null===(e=i.externalDocs)||void 0===e?void 0:e.description),S(null===(t=i.externalDocs)||void 0===t?void 0:t.url)},children:[g||(null===(Q=T.tags[t])||void 0===Q?void 0:Q.externalDocs)&&((null===(X=null===(U=T.tags[t])||void 0===U?void 0:U.externalDocs)||void 0===X?void 0:X.url)||(null===(Y=T.tags[t].externalDocs)||void 0===Y?void 0:Y.description))?"View ":"Add "," ","External Docs Link"]})}),!g&&e.jsx("div",{className:s.paramDescContainer_separator}),!g&&e.jsx(n.Button,{className:s.deleteParamBtn,variant:"link",color:"error",endIcon:e.jsx(v,{src:a,width:"1.125rem",height:"1.125rem"}),onClick:()=>{return e=t,o=i.name,V(e),P(o),void q(!0);var e,o}})]})}}));return e.jsxs("form",{className:s.apiInfoForm,onSubmit:e=>e.preventDefault(),children:[e.jsxs("div",{className:s.apiDocRow,children:[e.jsx(n.Input,{size:"large",placeholder:"e.g. Payments",label:"API Name",required:!0,value:null===(x=null==T?void 0:T.info)||void 0===x?void 0:x.title,maxLength:35,onChange:e=>{B("info.title",e)},onClear:()=>{B("info.title","")},errorMsg:null===(h=null==L?void 0:L.info)||void 0===h?void 0:h.title,restrictedCharactersRegex:l.basic}),e.jsx(n.Input,{size:"large",label:"Version",required:!0,value:null===(j=null==T?void 0:T.info)||void 0===j?void 0:j.version,disabled:!0})]}),e.jsx(n.TextArea,{size:"large",placeholder:"Enter a description of the API's functionality...",label:"Description",value:null===(D=null==T?void 0:T.info)||void 0===D?void 0:D.description,maxLength:120,required:!0,onChange:e=>{(""===e||l.ASCII.test(e))&&B("info.description",e)},onClear:()=>{B("info.description","")},errorMsg:null===(f=null==L?void 0:L.info)||void 0===f?void 0:f.description}),e.jsx("div",{className:s.paramsTable,children:e.jsx(p,{id:"paramter-table",data:y,headCells:u,isFormOpen:M,setIsFormOpen:G,saveNewRow:e=>{C([...b,e]);const i=T.tags||[];B("tags",[...i,e])},readOnly:g})}),e.jsx(m,{status:"error",content:e.jsxs("p",{style:{textAlign:"center",fontWeight:400,fontSize:"1rem",lineHeight:"1.4375rem"},className:"delete-msg-container",children:["Are you sure you want to delete",e.jsxs("span",{className:"plan-name",children:[" ","Tag ",e.jsx("strong",{children:F})]}),"?"]}),onSubmit:{onClick:()=>{var e;null!==R&&(C((e=>e.filter(((e,i)=>i!==R)))),B("tags",null===(e=T.tags)||void 0===e?void 0:e.filter(((e,i)=>i!==R)))),q(!1),V(null)},text:"Delete",color:"error",fullWidth:!0},onCancel:{text:"Cancel",color:"normal",fullWidth:!0},onClose:()=>q(!1),open:$,icon:e.jsx(v,{src:c,width:"4.0625rem",height:"4.0625rem"})})]})};export{g as default};
1
+ import{j as e}from"../../../_virtual/jsx-runtime.js";import{useState as i,useEffect as t}from"react";import{useFormikContext as o}from"../../../node_modules/formik/dist/formik.esm.js";import{d as n}from"../../../_virtual/index.js";import s from"./InfoForm.module.scss.js";import l from"../../constants/regex.js";import r from"../Tooltip/Tooltip.js";import a from"../../assets/icons/DeleteIcon.svg.js";import d from"../../assets/icons/EditIcon.svg.js";import c from"../../assets/icons/DeleteOutlinedIcon.svg.js";import v from"../SVGLoader/SVGLoader.js";import u from"../dialog/index.js";import{tagsTableHeaders as m}from"../../constants/index.js";import p from"../table/tags-table.js";const g=({readOnly:g})=>{var x,h,j,D,f;const[b,C]=i([]),[y,N]=i(),[I,k]=i(""),[w,O]=i(""),[A,S]=i(""),{values:T,setFieldValue:B,errors:L}=o(),[_,E]=i({}),[z,W]=i({}),[R,V]=i(null),[F,P]=i(null),[$,q]=i(!1),[M,G]=i(!1);t((()=>{if(T&&T.components&&T.components.securitySchemes){const e=Object.keys(T.components.securitySchemes);if(e.length){const i=T.components.securitySchemes[e[0]].scheme||T.components.securitySchemes[e[0]].type;k(i&&"public"==i.toLowerCase()?"Keyless":i)}}}),[]),t((()=>{N(K(b))}),[b]),t((()=>{T.tags&&T.tags.length&&C(T.tags)}),[T.tags]);const H=(e,i,t)=>{const o=b.map(((o,n)=>n===t?Object.assign(Object.assign({},o),{[e]:i}):o));C(o)},K=i=>i.map(((i,t)=>{var o,c,u,m,p,x,h,j,D,f,b,C,y,N,I,k,L,R,F,$,M,G,K,J,Q,U,X,Y;return{id:t,tagName:i.name,description:e.jsxs("div",{className:s.paramDescContainer,children:[e.jsx(r,{allowHTML:!0,disabled:(null===(o=T.tags[t].description)||void 0===o?void 0:o.length)<=12,content:e.jsx("div",{style:{padding:"0.625rem"},children:T.tags[t].description}),arrowWithBorder:!0,placement:"bottom-end",type:"function",delay:[0,0],onShow:()=>{var e;return null===(e=z[t])||void 0===e?void 0:e.hide()},children:e.jsxs("p",{style:{alignSelf:"center",fontWeight:600,fontSize:"1rem"},children:[T.tags[t].description?T.tags[t].description.substring(0,12):g&&"-",T.tags[t].description&&T.tags[t].description.length>12?"...":""]})},`${t}-description`),e.jsx(r,{arrowWithBorder:!0,placement:"bottom-end",type:"function",trigger:"click",delay:[0,0],onCreate:e=>W((i=>Object.assign(Object.assign({},i),{[t]:e}))),content:e.jsxs("div",{className:s.editDescTooltipContent,children:[e.jsx("p",{className:s.editDescTooltipContent_header,children:"Description"}),e.jsx(n.TextArea,{placeholder:"Describe tag...",value:i.description,disabled:g,onChange:e=>{(""===e||l.ASCII.test(e))&&H("description",e,t)},maxLength:25}),!g&&e.jsx(n.Button,{className:s.editDescTooltipContent_btn,variant:"outlined",size:"small",onClick:()=>{var e,o;B(`tags[${t}].description`,null===(e=i.description)||void 0===e?void 0:e.trim()),null===(o=z[t])||void 0===o||o.hide()},disabled:!(null===(c=i.description)||void 0===c?void 0:c.trim()),children:"Apply"})]}),children:g||T.tags[t].description?e.jsx(n.Button,{className:s.editDescBtn,variant:"link",color:"action",endIcon:e.jsx(v,{src:d,width:"1.5rem",height:"1.5rem"})}):e.jsx(n.Button,{className:s.editDescBtn,variant:"link",color:"action",endIcon:e.jsx(v,{src:d,width:"1.5rem",height:"1.5rem"}),children:g||T.tags[t].description?"View Description":"Add Description"})})]}),externalDocs:e.jsxs("div",{className:s.paramDescContainer,children:[(null===(u=T.tags[t].externalDocs)||void 0===u?void 0:u.description)&&(null===(m=T.tags[t].externalDocs)||void 0===m?void 0:m.url)&&e.jsxs("a",{className:s.externalDocsLink,href:(null===(x=null===(p=T.tags[t])||void 0===p?void 0:p.externalDocs)||void 0===x?void 0:x.url)&&(null===(D=null===(j=null===(h=T.tags[t])||void 0===h?void 0:h.externalDocs)||void 0===j?void 0:j.url)||void 0===D?void 0:D.indexOf("http"))>-1?null===(b=null===(f=T.tags[t])||void 0===f?void 0:f.externalDocs)||void 0===b?void 0:b.url:`https://${null===(y=null===(C=T.tags[t])||void 0===C?void 0:C.externalDocs)||void 0===y?void 0:y.url}`,target:"_blank",style:(null===(N=T.tags[t].externalDocs)||void 0===N?void 0:N.description)?{}:{textDecoration:"none",pointerEvents:"none"},children:[(null===(I=T.tags[t].externalDocs)||void 0===I?void 0:I.description)?null===(L=null===(k=T.tags[t].externalDocs)||void 0===k?void 0:k.description)||void 0===L?void 0:L.substring(0,12):g&&"-",(null===(R=T.tags[t].externalDocs)||void 0===R?void 0:R.description)&&(null===($=null===(F=T.tags[t].externalDocs)||void 0===F?void 0:F.description)||void 0===$?void 0:$.length)>12?"...":""]}),e.jsx(r,{arrowWithBorder:!0,placement:"bottom-end",type:"function",trigger:"click",delay:[0,0],onCreate:e=>E((i=>Object.assign(Object.assign({},i),{[t]:e}))),content:e.jsxs("div",{className:s.editDescTooltipContent,children:[e.jsx("p",{className:s.editDescTooltipContent_header,children:"External Docs Description"}),e.jsx(n.TextArea,{placeholder:"Describe External Doc...",value:null===(M=i.externalDocs)||void 0===M?void 0:M.description,disabled:g,maxLength:25,onChange:e=>{(""===e||l.ASCII.test(e))&&(H("externalDocs",Object.assign(Object.assign({},i.externalDocs),{description:e}),t),O(e))}}),e.jsx("p",{className:s.editDescTooltipContent_header,children:"External Docs Link"}),e.jsx(n.TextArea,{placeholder:"External Docs Link...",value:null===(G=i.externalDocs)||void 0===G?void 0:G.url,disabled:g,maxLength:200,restrictedCharsRegex:l.urlRegex,onChange:e=>{(""===e||l.ASCII.test(e))&&(H("externalDocs",Object.assign(Object.assign({},i.externalDocs),{url:e}),t),S(e))}}),!g&&e.jsx(n.Button,{className:s.editDescTooltipContent_btn,variant:"outlined",size:"small",onClick:()=>{var e;B(`tags[${t}].externalDocs`,{description:null==w?void 0:w.trim(),url:null==A?void 0:A.trim()}),O(""),S(""),null===(e=_[t])||void 0===e||e.hide()},disabled:!((null===(K=T.tags[t].externalDocs)||void 0===K?void 0:K.url)&&!(null==A?void 0:A.trim())||(null==A?void 0:A.trim())&&l.urlRegex.test(A)),children:"Apply"})]}),children:g||(null===(J=T.tags[t].externalDocs)||void 0===J?void 0:J.description)?e.jsx("div",{className:s.editExternalDocs,children:e.jsx(v,{src:d,width:"1.5rem",height:"1.5rem",onClick:e=>{var t,o;null==e||e.stopPropagation(),O(null===(t=i.externalDocs)||void 0===t?void 0:t.description),S(null===(o=i.externalDocs)||void 0===o?void 0:o.url)}})}):e.jsxs(n.Button,{className:s.editDescBtn,variant:"link",color:"action",endIcon:e.jsx(v,{src:d,width:"1.5rem",height:"1.5rem"}),onClick:()=>{var e,t;O(null===(e=i.externalDocs)||void 0===e?void 0:e.description),S(null===(t=i.externalDocs)||void 0===t?void 0:t.url)},children:[g||(null===(Q=T.tags[t])||void 0===Q?void 0:Q.externalDocs)&&((null===(X=null===(U=T.tags[t])||void 0===U?void 0:U.externalDocs)||void 0===X?void 0:X.url)||(null===(Y=T.tags[t].externalDocs)||void 0===Y?void 0:Y.description))?"View ":"Add "," ","External Docs Link"]})}),!g&&e.jsx("div",{className:s.paramDescContainer_separator}),!g&&e.jsx(n.Button,{className:s.deleteParamBtn,variant:"link",color:"error",endIcon:e.jsx(v,{src:a,width:"1.125rem",height:"1.125rem"}),onClick:()=>{return e=t,o=i.name,V(e),P(o),void q(!0);var e,o}})]})}}));return e.jsxs("form",{className:s.apiInfoForm,onSubmit:e=>e.preventDefault(),children:[e.jsxs("div",{className:s.apiDocRow,children:[e.jsx(n.Input,{size:"large",placeholder:"e.g. Payments",label:"API Name",required:!0,value:null===(x=null==T?void 0:T.info)||void 0===x?void 0:x.title,maxLength:35,onChange:e=>{B("info.title",e)},onClear:()=>{B("info.title","")},errorMsg:null===(h=null==L?void 0:L.info)||void 0===h?void 0:h.title,restrictedCharactersRegex:l.basic}),e.jsx(n.Input,{size:"large",label:"Version",required:!0,value:null===(j=null==T?void 0:T.info)||void 0===j?void 0:j.version,disabled:!0})]}),e.jsx(n.TextArea,{size:"large",placeholder:"Enter a description of the API's functionality...",label:"Description",value:null===(D=null==T?void 0:T.info)||void 0===D?void 0:D.description,maxLength:120,required:!0,onChange:e=>{(""===e||l.ASCII.test(e))&&B("info.description",e)},onClear:()=>{B("info.description","")},errorMsg:null===(f=null==L?void 0:L.info)||void 0===f?void 0:f.description}),e.jsx("div",{className:s.paramsTable,children:e.jsx(p,{id:"paramter-table",data:y,headCells:m,isFormOpen:M,setIsFormOpen:G,saveNewRow:e=>{C([...b,e]);const i=T.tags||[];B("tags",[...i,e])},readOnly:g})}),e.jsx(u,{status:"error",content:e.jsxs("p",{style:{textAlign:"center",fontWeight:400,fontSize:"1rem",lineHeight:"1.4375rem"},className:"delete-msg-container",children:["Are you sure you want to delete",e.jsxs("span",{className:"plan-name",children:[" ","Tag ",e.jsx("strong",{children:F})]}),"?"]}),onSubmit:{onClick:()=>{var e;null!==R&&(C((e=>e.filter(((e,i)=>i!==R)))),B("tags",null===(e=T.tags)||void 0===e?void 0:e.filter(((e,i)=>i!==R)))),q(!1),V(null)},text:"Delete",color:"error",fullWidth:!0},onCancel:{text:"Cancel",color:"action",fullWidth:!0,variant:"outlined"},onClose:()=>q(!1),open:$,icon:e.jsx(v,{src:c,width:"4.0625rem",height:"4.0625rem"})})]})};export{g as default};
2
2
  //# sourceMappingURL=InfoForm.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"InfoForm.js","sources":["../../../../src/components/InfoForm/InfoForm.tsx"],"sourcesContent":["import { useEffect, useState } from 'react'\n// @ts-ignore\nimport { useFormikContext } from 'formik'\nimport { Button, Input, TextArea } from 'digitinary-ui'\nimport styles from './InfoForm.module.scss'\nimport regex from '../../constants/regex'\nimport { TransformedOpenApi } from '../../types/transformedOpenApi'\nimport Tooltip from '../../components/Tooltip/Tooltip'\nimport { DeleteIcon, DeleteOutlinedIcon, EditIcon } from '../../assets/icons'\nimport SVGLoader from '../../components/SVGLoader/SVGLoader'\nimport CommonDialog from '../../components/dialog'\nimport { tagsTableHeaders } from '../../constants/index'\nimport TagsTable from '../../components/table/tags-table'\n\nconst InfoForm = ({ readOnly }: { readOnly?: boolean }) => {\n const [tableData, setTableData] = useState([])\n const [tableRecords, setTableRecords] = useState()\n const [authType, setAuthType] = useState('')\n const [description, setDescription] = useState('')\n const [url, setURL] = useState('')\n const { values, setFieldValue, errors } = useFormikContext<TransformedOpenApi>()\n const [externalTooltipRefs, setExternalTooltipRefs] = useState<{ [key: number]: any }>({})\n const [tooltipRefs, setTooltipRefs] = useState<{ [key: number]: any }>({})\n const [selectedTagIndex, setSelectedTagIndex] = useState<number | null>(null)\n const [selectedTagName, setSelectedTagName] = useState<string | null>(null)\n const [openDeleteDialog, setOpenDeleteDialog] = useState(false)\n const [isFormOpen, setIsFormOpen] = useState(false)\n\n useEffect(() => {\n if (values && values.components && values.components.securitySchemes) {\n const authenticatorKeys = Object.keys(values.components.securitySchemes)\n if (authenticatorKeys.length) {\n const _authType =\n values.components.securitySchemes[authenticatorKeys[0]].scheme ||\n values.components.securitySchemes[authenticatorKeys[0]].type\n\n setAuthType(_authType && _authType.toLowerCase() == 'public' ? 'Keyless' : _authType)\n }\n }\n }, [])\n\n useEffect(() => {\n setTableRecords(generateTableRecords(tableData))\n }, [tableData])\n\n useEffect(() => {\n if (values.tags && values.tags.length) {\n setTableData(values.tags)\n }\n }, [values.tags])\n\n const confirmDeleteTag = () => {\n if (selectedTagIndex !== null) {\n setTableData((prev) => prev.filter((_, i) => i !== selectedTagIndex))\n setFieldValue(\n `tags`,\n values.tags?.filter((_, i) => i !== selectedTagIndex)\n )\n }\n setOpenDeleteDialog(false)\n setSelectedTagIndex(null)\n }\n\n const capitalize = (str) => {\n if (!str) return ''\n return str.charAt(0).toUpperCase() + str.slice(1)\n }\n\n const onTableChange = (key, value, index) => {\n const newTableData = tableData.map((item, tIndex) => {\n if (tIndex === index) {\n return { ...item, [key]: value }\n } else {\n return item\n }\n })\n\n setTableData(newTableData)\n }\n\n const saveNewRow = (tag) => {\n setTableData([...tableData, tag])\n const oldTags = values.tags || []\n setFieldValue(`tags`, [...oldTags, tag])\n }\n\n const handleDeleteClick = (id: number, name: string) => {\n setSelectedTagIndex(id)\n setSelectedTagName(name)\n\n setOpenDeleteDialog(true)\n }\n\n const generateTableRecords = (items) => {\n return items.map((item, index) => ({\n id: index,\n tagName: item.name,\n description: (\n <div className={styles.paramDescContainer}>\n <Tooltip\n key={`${index}-description`}\n allowHTML\n disabled={values.tags[index].description?.length <= 12}\n content={<div style={{ padding: '0.625rem' }}>{values.tags[index].description}</div>}\n arrowWithBorder\n placement=\"bottom-end\"\n type=\"function\"\n delay={[0, 0]}\n onShow={() => tooltipRefs[index]?.hide()}\n >\n <p style={{ alignSelf: 'center', fontWeight: 600, fontSize: '1rem' }}>\n {values.tags[index].description\n ? values.tags[index].description.substring(0, 12)\n : readOnly && '-'}\n {values.tags[index].description && values.tags[index].description.length > 12\n ? '...'\n : ''}\n </p>\n </Tooltip>\n <Tooltip\n arrowWithBorder\n placement=\"bottom-end\"\n type=\"function\"\n trigger=\"click\"\n delay={[0, 0]}\n onCreate={(instance) =>\n setTooltipRefs((prev) => ({\n ...prev,\n [index]: instance,\n }))\n }\n content={\n <div className={styles.editDescTooltipContent}>\n <p className={styles.editDescTooltipContent_header}>Description</p>\n <TextArea\n placeholder=\"Describe tag...\"\n value={item.description}\n disabled={readOnly}\n onChange={(value) => {\n if (value === '' || regex.ASCII.test(value))\n onTableChange('description', value, index)\n }}\n maxLength={25}\n />\n {!readOnly && (\n <Button\n className={styles.editDescTooltipContent_btn}\n variant=\"outlined\"\n size=\"small\"\n onClick={() => {\n setFieldValue(`tags[${index}].description`, item.description?.trim())\n tooltipRefs[index]?.hide()\n }}\n disabled={!item.description?.trim()}\n >\n Apply\n </Button>\n )}\n </div>\n }\n >\n {readOnly || values.tags[index].description ? (\n <Button\n className={styles.editDescBtn}\n variant=\"link\"\n color=\"action\"\n endIcon={<SVGLoader src={EditIcon} width=\"1.5rem\" height=\"1.5rem\" />}\n ></Button>\n ) : (\n <Button\n className={styles.editDescBtn}\n variant=\"link\"\n color=\"action\"\n endIcon={<SVGLoader src={EditIcon} width=\"1.5rem\" height=\"1.5rem\" />}\n >\n {readOnly || values.tags[index].description\n ? 'View Description'\n : 'Add Description'}\n </Button>\n )}\n </Tooltip>\n </div>\n ),\n externalDocs: (\n <div className={styles.paramDescContainer}>\n {values.tags[index].externalDocs?.description && values.tags[index].externalDocs?.url && (\n <a\n className={styles.externalDocsLink}\n href={\n values.tags[index]?.externalDocs?.url &&\n values.tags[index]?.externalDocs?.url?.indexOf('http') > -1\n ? values.tags[index]?.externalDocs?.url\n : `https://${values.tags[index]?.externalDocs?.url}`\n }\n target=\"_blank\"\n style={\n !values.tags[index].externalDocs?.description\n ? { textDecoration: 'none', pointerEvents: 'none' }\n : {}\n }\n >\n {values.tags[index].externalDocs?.description\n ? values.tags[index].externalDocs?.description?.substring(0, 12)\n : readOnly && '-'}\n {values.tags[index].externalDocs?.description &&\n values.tags[index].externalDocs?.description?.length > 12\n ? '...'\n : ''}\n </a>\n )}\n\n <Tooltip\n arrowWithBorder\n placement=\"bottom-end\"\n type=\"function\"\n trigger=\"click\"\n delay={[0, 0]}\n onCreate={(instance) =>\n setExternalTooltipRefs((prev) => ({\n ...prev,\n [index]: instance,\n }))\n }\n content={\n <div className={styles.editDescTooltipContent}>\n <p className={styles.editDescTooltipContent_header}>External Docs Description</p>\n <TextArea\n placeholder=\"Describe External Doc...\"\n value={item.externalDocs?.description}\n disabled={readOnly}\n maxLength={25}\n onChange={(value) => {\n if (value === '' || regex.ASCII.test(value)) {\n onTableChange(\n 'externalDocs',\n { ...item.externalDocs, description: value },\n index\n )\n setDescription(value)\n }\n }}\n />\n <p className={styles.editDescTooltipContent_header}>External Docs Link</p>\n <TextArea\n placeholder=\"External Docs Link...\"\n value={item.externalDocs?.url}\n disabled={readOnly}\n maxLength={200}\n restrictedCharsRegex={regex.urlRegex}\n onChange={(value) => {\n if (value === '' || regex.ASCII.test(value)) {\n onTableChange('externalDocs', { ...item.externalDocs, url: value }, index)\n setURL(value)\n }\n }}\n />\n {!readOnly && (\n <Button\n className={styles.editDescTooltipContent_btn}\n variant=\"outlined\"\n size=\"small\"\n onClick={() => {\n setFieldValue(`tags[${index}].externalDocs`, {\n description: description?.trim(),\n url: url?.trim(),\n })\n setDescription('')\n setURL('')\n externalTooltipRefs[index]?.hide()\n }}\n disabled={\n !(\n (values.tags[index].externalDocs?.url && !url?.trim()) ||\n (url?.trim() && regex.urlRegex.test(url))\n )\n }\n >\n Apply\n </Button>\n )}\n </div>\n }\n >\n {readOnly || values.tags[index].externalDocs?.description ? (\n <div className={styles.editExternalDocs}>\n <SVGLoader\n src={EditIcon}\n width=\"1.5rem\"\n height=\"1.5rem\"\n onClick={(e) => {\n e?.stopPropagation()\n setDescription(item.externalDocs?.description)\n setURL(item.externalDocs?.url)\n }}\n />\n </div>\n ) : (\n <Button\n className={styles.editDescBtn}\n variant=\"link\"\n color=\"action\"\n endIcon={<SVGLoader src={EditIcon} width=\"1.5rem\" height=\"1.5rem\" />}\n onClick={() => {\n setDescription(item.externalDocs?.description)\n setURL(item.externalDocs?.url)\n }}\n >\n {readOnly ||\n (values.tags[index]?.externalDocs &&\n (values.tags[index]?.externalDocs?.url ||\n values.tags[index].externalDocs?.description))\n ? 'View '\n : 'Add '}{' '}\n External Docs Link\n </Button>\n )}\n </Tooltip>\n\n {!readOnly && <div className={styles.paramDescContainer_separator}></div>}\n\n {!readOnly && (\n <Button\n className={styles.deleteParamBtn}\n variant=\"link\"\n color=\"error\"\n endIcon={<SVGLoader src={DeleteIcon} width=\"1.125rem\" height=\"1.125rem\" />}\n onClick={() => handleDeleteClick(index, item.name)}\n ></Button>\n )}\n </div>\n ),\n }))\n }\n\n return (\n <form className={styles.apiInfoForm} onSubmit={(e) => e.preventDefault()}>\n <div className={styles.apiDocRow}>\n <Input\n size=\"large\"\n placeholder=\"e.g. Payments\"\n label=\"API Name\"\n required\n value={values?.info?.title}\n maxLength={35}\n onChange={(value) => {\n setFieldValue('info.title', value)\n }}\n onClear={() => {\n setFieldValue('info.title', '')\n }}\n errorMsg={errors?.info?.title}\n restrictedCharactersRegex={regex.basic}\n />\n <Input size=\"large\" label=\"Version\" required value={values?.info?.version} disabled />\n </div>\n <TextArea\n size=\"large\"\n placeholder=\"Enter a description of the API's functionality...\"\n label=\"Description\"\n value={values?.info?.description}\n maxLength={120}\n required\n onChange={(value: string) => {\n if (value === '' || regex.ASCII.test(value)) {\n setFieldValue('info.description', value)\n }\n }}\n onClear={() => {\n setFieldValue('info.description', '')\n }}\n errorMsg={errors?.info?.description}\n />\n <div className={styles.paramsTable}>\n <TagsTable\n id=\"paramter-table\"\n data={tableRecords}\n headCells={tagsTableHeaders}\n isFormOpen={isFormOpen}\n setIsFormOpen={setIsFormOpen}\n saveNewRow={saveNewRow}\n readOnly={readOnly}\n />\n </div>\n <CommonDialog\n status=\"error\"\n content={\n <p\n style={{\n textAlign: 'center',\n fontWeight: 400,\n fontSize: '1rem',\n lineHeight: '1.4375rem',\n }}\n className=\"delete-msg-container\"\n >\n Are you sure you want to delete\n <span className=\"plan-name\">\n {' '}\n Tag <strong>{selectedTagName}</strong>\n </span>\n ?\n </p>\n }\n onSubmit={{\n onClick: confirmDeleteTag,\n text: 'Delete',\n color: 'error',\n fullWidth: true,\n }}\n onCancel={{\n text: 'Cancel',\n color: 'normal',\n fullWidth: true,\n }}\n onClose={() => setOpenDeleteDialog(false)}\n open={openDeleteDialog}\n icon={<SVGLoader src={DeleteOutlinedIcon} width=\"4.0625rem\" height=\"4.0625rem\" />}\n />\n </form>\n )\n}\n\nexport default InfoForm\n"],"names":["InfoForm","readOnly","tableData","setTableData","useState","tableRecords","setTableRecords","authType","setAuthType","description","setDescription","url","setURL","values","setFieldValue","errors","useFormikContext","externalTooltipRefs","setExternalTooltipRefs","tooltipRefs","setTooltipRefs","selectedTagIndex","setSelectedTagIndex","selectedTagName","setSelectedTagName","openDeleteDialog","setOpenDeleteDialog","isFormOpen","setIsFormOpen","useEffect","components","securitySchemes","authenticatorKeys","Object","keys","length","_authType","scheme","type","toLowerCase","generateTableRecords","tags","onTableChange","key","value","index","newTableData","map","item","tIndex","assign","items","id","tagName","name","_jsxs","className","styles","paramDescContainer","children","_jsx","Tooltip","allowHTML","disabled","_a","content","style","padding","arrowWithBorder","placement","delay","onShow","hide","jsxs","alignSelf","fontWeight","fontSize","substring","trigger","onCreate","instance","prev","editDescTooltipContent","editDescTooltipContent_header","TextArea","placeholder","onChange","regex","ASCII","test","maxLength","jsx","Button","editDescTooltipContent_btn","variant","size","onClick","trim","_b","editDescBtn","color","endIcon","SVGLoader","src","EditIcon","width","height","externalDocs","_c","_d","externalDocsLink","href","_f","_e","_j","_g","_h","indexOf","_l","_k","_o","_m","target","_p","textDecoration","pointerEvents","_s","_r","_t","_v","_u","_w","_x","restrictedCharsRegex","urlRegex","_y","_z","editExternalDocs","e","stopPropagation","_0","_2","_1","_3","paramDescContainer_separator","deleteParamBtn","DeleteIcon","handleDeleteClick","apiInfoForm","onSubmit","preventDefault","apiDocRow","Input","label","required","info","title","onClear","errorMsg","restrictedCharactersRegex","basic","version","paramsTable","TagsTable","data","headCells","tagsTableHeaders","saveNewRow","tag","oldTags","CommonDialog","status","textAlign","lineHeight","filter","_","i","text","fullWidth","onCancel","onClose","open","icon","DeleteOutlinedIcon"],"mappings":"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"}
1
+ {"version":3,"file":"InfoForm.js","sources":["../../../../src/components/InfoForm/InfoForm.tsx"],"sourcesContent":["import { useEffect, useState } from 'react'\n// @ts-ignore\nimport { useFormikContext } from 'formik'\nimport { Button, Input, TextArea } from 'digitinary-ui'\nimport styles from './InfoForm.module.scss'\nimport regex from '../../constants/regex'\nimport { TransformedOpenApi } from '../../types/transformedOpenApi'\nimport Tooltip from '../../components/Tooltip/Tooltip'\nimport { DeleteIcon, DeleteOutlinedIcon, EditIcon } from '../../assets/icons'\nimport SVGLoader from '../../components/SVGLoader/SVGLoader'\nimport CommonDialog from '../../components/dialog'\nimport { tagsTableHeaders } from '../../constants/index'\nimport TagsTable from '../../components/table/tags-table'\n\nconst InfoForm = ({ readOnly }: { readOnly?: boolean }) => {\n const [tableData, setTableData] = useState([])\n const [tableRecords, setTableRecords] = useState()\n const [authType, setAuthType] = useState('')\n const [description, setDescription] = useState('')\n const [url, setURL] = useState('')\n const { values, setFieldValue, errors } = useFormikContext<TransformedOpenApi>()\n const [externalTooltipRefs, setExternalTooltipRefs] = useState<{ [key: number]: any }>({})\n const [tooltipRefs, setTooltipRefs] = useState<{ [key: number]: any }>({})\n const [selectedTagIndex, setSelectedTagIndex] = useState<number | null>(null)\n const [selectedTagName, setSelectedTagName] = useState<string | null>(null)\n const [openDeleteDialog, setOpenDeleteDialog] = useState(false)\n const [isFormOpen, setIsFormOpen] = useState(false)\n\n useEffect(() => {\n if (values && values.components && values.components.securitySchemes) {\n const authenticatorKeys = Object.keys(values.components.securitySchemes)\n if (authenticatorKeys.length) {\n const _authType =\n values.components.securitySchemes[authenticatorKeys[0]].scheme ||\n values.components.securitySchemes[authenticatorKeys[0]].type\n\n setAuthType(_authType && _authType.toLowerCase() == 'public' ? 'Keyless' : _authType)\n }\n }\n }, [])\n\n useEffect(() => {\n setTableRecords(generateTableRecords(tableData))\n }, [tableData])\n\n useEffect(() => {\n if (values.tags && values.tags.length) {\n setTableData(values.tags)\n }\n }, [values.tags])\n\n const confirmDeleteTag = () => {\n if (selectedTagIndex !== null) {\n setTableData((prev) => prev.filter((_, i) => i !== selectedTagIndex))\n setFieldValue(\n `tags`,\n values.tags?.filter((_, i) => i !== selectedTagIndex)\n )\n }\n setOpenDeleteDialog(false)\n setSelectedTagIndex(null)\n }\n\n const capitalize = (str) => {\n if (!str) return ''\n return str.charAt(0).toUpperCase() + str.slice(1)\n }\n\n const onTableChange = (key, value, index) => {\n const newTableData = tableData.map((item, tIndex) => {\n if (tIndex === index) {\n return { ...item, [key]: value }\n } else {\n return item\n }\n })\n\n setTableData(newTableData)\n }\n\n const saveNewRow = (tag) => {\n setTableData([...tableData, tag])\n const oldTags = values.tags || []\n setFieldValue(`tags`, [...oldTags, tag])\n }\n\n const handleDeleteClick = (id: number, name: string) => {\n setSelectedTagIndex(id)\n setSelectedTagName(name)\n\n setOpenDeleteDialog(true)\n }\n\n const generateTableRecords = (items) => {\n return items.map((item, index) => ({\n id: index,\n tagName: item.name,\n description: (\n <div className={styles.paramDescContainer}>\n <Tooltip\n key={`${index}-description`}\n allowHTML\n disabled={values.tags[index].description?.length <= 12}\n content={<div style={{ padding: '0.625rem' }}>{values.tags[index].description}</div>}\n arrowWithBorder\n placement=\"bottom-end\"\n type=\"function\"\n delay={[0, 0]}\n onShow={() => tooltipRefs[index]?.hide()}\n >\n <p style={{ alignSelf: 'center', fontWeight: 600, fontSize: '1rem' }}>\n {values.tags[index].description\n ? values.tags[index].description.substring(0, 12)\n : readOnly && '-'}\n {values.tags[index].description && values.tags[index].description.length > 12\n ? '...'\n : ''}\n </p>\n </Tooltip>\n <Tooltip\n arrowWithBorder\n placement=\"bottom-end\"\n type=\"function\"\n trigger=\"click\"\n delay={[0, 0]}\n onCreate={(instance) =>\n setTooltipRefs((prev) => ({\n ...prev,\n [index]: instance,\n }))\n }\n content={\n <div className={styles.editDescTooltipContent}>\n <p className={styles.editDescTooltipContent_header}>Description</p>\n <TextArea\n placeholder=\"Describe tag...\"\n value={item.description}\n disabled={readOnly}\n onChange={(value) => {\n if (value === '' || regex.ASCII.test(value))\n onTableChange('description', value, index)\n }}\n maxLength={25}\n />\n {!readOnly && (\n <Button\n className={styles.editDescTooltipContent_btn}\n variant=\"outlined\"\n size=\"small\"\n onClick={() => {\n setFieldValue(`tags[${index}].description`, item.description?.trim())\n tooltipRefs[index]?.hide()\n }}\n disabled={!item.description?.trim()}\n >\n Apply\n </Button>\n )}\n </div>\n }\n >\n {readOnly || values.tags[index].description ? (\n <Button\n className={styles.editDescBtn}\n variant=\"link\"\n color=\"action\"\n endIcon={<SVGLoader src={EditIcon} width=\"1.5rem\" height=\"1.5rem\" />}\n ></Button>\n ) : (\n <Button\n className={styles.editDescBtn}\n variant=\"link\"\n color=\"action\"\n endIcon={<SVGLoader src={EditIcon} width=\"1.5rem\" height=\"1.5rem\" />}\n >\n {readOnly || values.tags[index].description\n ? 'View Description'\n : 'Add Description'}\n </Button>\n )}\n </Tooltip>\n </div>\n ),\n externalDocs: (\n <div className={styles.paramDescContainer}>\n {values.tags[index].externalDocs?.description && values.tags[index].externalDocs?.url && (\n <a\n className={styles.externalDocsLink}\n href={\n values.tags[index]?.externalDocs?.url &&\n values.tags[index]?.externalDocs?.url?.indexOf('http') > -1\n ? values.tags[index]?.externalDocs?.url\n : `https://${values.tags[index]?.externalDocs?.url}`\n }\n target=\"_blank\"\n style={\n !values.tags[index].externalDocs?.description\n ? { textDecoration: 'none', pointerEvents: 'none' }\n : {}\n }\n >\n {values.tags[index].externalDocs?.description\n ? values.tags[index].externalDocs?.description?.substring(0, 12)\n : readOnly && '-'}\n {values.tags[index].externalDocs?.description &&\n values.tags[index].externalDocs?.description?.length > 12\n ? '...'\n : ''}\n </a>\n )}\n\n <Tooltip\n arrowWithBorder\n placement=\"bottom-end\"\n type=\"function\"\n trigger=\"click\"\n delay={[0, 0]}\n onCreate={(instance) =>\n setExternalTooltipRefs((prev) => ({\n ...prev,\n [index]: instance,\n }))\n }\n content={\n <div className={styles.editDescTooltipContent}>\n <p className={styles.editDescTooltipContent_header}>External Docs Description</p>\n <TextArea\n placeholder=\"Describe External Doc...\"\n value={item.externalDocs?.description}\n disabled={readOnly}\n maxLength={25}\n onChange={(value) => {\n if (value === '' || regex.ASCII.test(value)) {\n onTableChange(\n 'externalDocs',\n { ...item.externalDocs, description: value },\n index\n )\n setDescription(value)\n }\n }}\n />\n <p className={styles.editDescTooltipContent_header}>External Docs Link</p>\n <TextArea\n placeholder=\"External Docs Link...\"\n value={item.externalDocs?.url}\n disabled={readOnly}\n maxLength={200}\n restrictedCharsRegex={regex.urlRegex}\n onChange={(value) => {\n if (value === '' || regex.ASCII.test(value)) {\n onTableChange('externalDocs', { ...item.externalDocs, url: value }, index)\n setURL(value)\n }\n }}\n />\n {!readOnly && (\n <Button\n className={styles.editDescTooltipContent_btn}\n variant=\"outlined\"\n size=\"small\"\n onClick={() => {\n setFieldValue(`tags[${index}].externalDocs`, {\n description: description?.trim(),\n url: url?.trim(),\n })\n setDescription('')\n setURL('')\n externalTooltipRefs[index]?.hide()\n }}\n disabled={\n !(\n (values.tags[index].externalDocs?.url && !url?.trim()) ||\n (url?.trim() && regex.urlRegex.test(url))\n )\n }\n >\n Apply\n </Button>\n )}\n </div>\n }\n >\n {readOnly || values.tags[index].externalDocs?.description ? (\n <div className={styles.editExternalDocs}>\n <SVGLoader\n src={EditIcon}\n width=\"1.5rem\"\n height=\"1.5rem\"\n onClick={(e) => {\n e?.stopPropagation()\n setDescription(item.externalDocs?.description)\n setURL(item.externalDocs?.url)\n }}\n />\n </div>\n ) : (\n <Button\n className={styles.editDescBtn}\n variant=\"link\"\n color=\"action\"\n endIcon={<SVGLoader src={EditIcon} width=\"1.5rem\" height=\"1.5rem\" />}\n onClick={() => {\n setDescription(item.externalDocs?.description)\n setURL(item.externalDocs?.url)\n }}\n >\n {readOnly ||\n (values.tags[index]?.externalDocs &&\n (values.tags[index]?.externalDocs?.url ||\n values.tags[index].externalDocs?.description))\n ? 'View '\n : 'Add '}{' '}\n External Docs Link\n </Button>\n )}\n </Tooltip>\n\n {!readOnly && <div className={styles.paramDescContainer_separator}></div>}\n\n {!readOnly && (\n <Button\n className={styles.deleteParamBtn}\n variant=\"link\"\n color=\"error\"\n endIcon={<SVGLoader src={DeleteIcon} width=\"1.125rem\" height=\"1.125rem\" />}\n onClick={() => handleDeleteClick(index, item.name)}\n ></Button>\n )}\n </div>\n ),\n }))\n }\n\n return (\n <form className={styles.apiInfoForm} onSubmit={(e) => e.preventDefault()}>\n <div className={styles.apiDocRow}>\n <Input\n size=\"large\"\n placeholder=\"e.g. Payments\"\n label=\"API Name\"\n required\n value={values?.info?.title}\n maxLength={35}\n onChange={(value) => {\n setFieldValue('info.title', value)\n }}\n onClear={() => {\n setFieldValue('info.title', '')\n }}\n errorMsg={errors?.info?.title}\n restrictedCharactersRegex={regex.basic}\n />\n <Input size=\"large\" label=\"Version\" required value={values?.info?.version} disabled />\n </div>\n <TextArea\n size=\"large\"\n placeholder=\"Enter a description of the API's functionality...\"\n label=\"Description\"\n value={values?.info?.description}\n maxLength={120}\n required\n onChange={(value: string) => {\n if (value === '' || regex.ASCII.test(value)) {\n setFieldValue('info.description', value)\n }\n }}\n onClear={() => {\n setFieldValue('info.description', '')\n }}\n errorMsg={errors?.info?.description}\n />\n <div className={styles.paramsTable}>\n <TagsTable\n id=\"paramter-table\"\n data={tableRecords}\n headCells={tagsTableHeaders}\n isFormOpen={isFormOpen}\n setIsFormOpen={setIsFormOpen}\n saveNewRow={saveNewRow}\n readOnly={readOnly}\n />\n </div>\n <CommonDialog\n status=\"error\"\n content={\n <p\n style={{\n textAlign: 'center',\n fontWeight: 400,\n fontSize: '1rem',\n lineHeight: '1.4375rem',\n }}\n className=\"delete-msg-container\"\n >\n Are you sure you want to delete\n <span className=\"plan-name\">\n {' '}\n Tag <strong>{selectedTagName}</strong>\n </span>\n ?\n </p>\n }\n onSubmit={{\n onClick: confirmDeleteTag,\n text: 'Delete',\n color: 'error',\n fullWidth: true,\n }}\n onCancel={{\n text: 'Cancel',\n color: 'action',\n fullWidth: true,\n variant: 'outlined',\n }}\n onClose={() => setOpenDeleteDialog(false)}\n open={openDeleteDialog}\n icon={<SVGLoader src={DeleteOutlinedIcon} width=\"4.0625rem\" height=\"4.0625rem\" />}\n />\n </form>\n )\n}\n\nexport default InfoForm\n"],"names":["InfoForm","readOnly","tableData","setTableData","useState","tableRecords","setTableRecords","authType","setAuthType","description","setDescription","url","setURL","values","setFieldValue","errors","useFormikContext","externalTooltipRefs","setExternalTooltipRefs","tooltipRefs","setTooltipRefs","selectedTagIndex","setSelectedTagIndex","selectedTagName","setSelectedTagName","openDeleteDialog","setOpenDeleteDialog","isFormOpen","setIsFormOpen","useEffect","components","securitySchemes","authenticatorKeys","Object","keys","length","_authType","scheme","type","toLowerCase","generateTableRecords","tags","onTableChange","key","value","index","newTableData","map","item","tIndex","assign","items","id","tagName","name","_jsxs","className","styles","paramDescContainer","children","_jsx","Tooltip","allowHTML","disabled","_a","content","style","padding","arrowWithBorder","placement","delay","onShow","hide","jsxs","alignSelf","fontWeight","fontSize","substring","trigger","onCreate","instance","prev","editDescTooltipContent","editDescTooltipContent_header","TextArea","placeholder","onChange","regex","ASCII","test","maxLength","jsx","Button","editDescTooltipContent_btn","variant","size","onClick","trim","_b","editDescBtn","color","endIcon","SVGLoader","src","EditIcon","width","height","externalDocs","_c","_d","externalDocsLink","href","_f","_e","_j","_g","_h","indexOf","_l","_k","_o","_m","target","_p","textDecoration","pointerEvents","_s","_r","_t","_v","_u","_w","_x","restrictedCharsRegex","urlRegex","_y","_z","editExternalDocs","e","stopPropagation","_0","_2","_1","_3","paramDescContainer_separator","deleteParamBtn","DeleteIcon","handleDeleteClick","apiInfoForm","onSubmit","preventDefault","apiDocRow","Input","label","required","info","title","onClear","errorMsg","restrictedCharactersRegex","basic","version","paramsTable","TagsTable","data","headCells","tagsTableHeaders","saveNewRow","tag","oldTags","CommonDialog","status","textAlign","lineHeight","filter","_","i","text","fullWidth","onCancel","onClose","open","icon","DeleteOutlinedIcon"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"JsonInput.js","sources":["../../../../src/components/JsonInput/JsonInput.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react'\nimport yaml from 'js-yaml'\nimport styles from './style.module.scss'\nimport regex from '../../constants/regex'\n\nconst errorMapping = {\n BOTH: 'Invalid JSON or YAML format',\n JSON: 'Invalid JSON format',\n YML: 'Invalid YAML format',\n}\n\nconst JsonInput = ({\n placeholder,\n label,\n value,\n onValidation,\n onChange,\n dataId,\n className = '',\n errorMessage,\n acceptType = 'BOTH',\n fieldIsDisabled,\n withFooter = true,\n}) => {\n const [isValid, setIsValid] = useState()\n const [disabledBeautify, setDisabledBeautify] = useState(true)\n\n const handlePrettify = (e) => {\n if (value === '') return\n e.preventDefault()\n try {\n let prettifiedData\n if ((acceptType === 'BOTH' || acceptType === 'JSON') && isValidJson(value)) {\n // If it's valid JSON, prettify JSON\n prettifiedData = JSON.stringify(JSON.parse(value), null, 2)\n } else if (acceptType === 'BOTH' || acceptType === 'YML') {\n // If it's not valid JSON, prettify YAML\n prettifiedData = yaml.dump(yaml.load(value), { indent: 0 })\n }\n onChange(prettifiedData)\n setIsValid(true) // Reset validity status\n } catch (error) {\n console.error(error)\n setIsValid(false)\n }\n }\n\n // Function to check if input is valid JSON\n const isValidJson = (str) => {\n try {\n JSON.parse(str)\n return true\n } catch (error) {\n return false\n }\n }\n\n const checkIsValid = () => {\n if (acceptType === 'BOTH' || acceptType === 'JSON') {\n return isValidJson(value)\n } else if (acceptType === 'BOTH' || acceptType === 'YML') {\n try {\n // Try parsing as YAML\n yaml.load(value)\n return true\n } catch (error) {\n console.error(error)\n return false\n }\n }\n }\n\n useEffect(() => {\n try {\n handlePrettify(value)\n } catch {}\n }, [])\n\n return (\n <div\n className={`${styles['json-editor-container']} ${className} ${\n fieldIsDisabled ? styles.disabled : ''\n }`}\n >\n {label && <p className={`${styles['json-editor-label']}`}>{label}</p>}\n <div\n className={`${styles['json-editor']} ${\n value !== '' && isValid === false ? styles.invalid : ''\n }`}\n >\n <textarea\n disabled={fieldIsDisabled}\n data-id={dataId}\n value={value}\n onChange={(e) => {\n if (fieldIsDisabled) return\n if (regex.ASCII.test(e.target.value)) {\n setIsValid(undefined)\n setDisabledBeautify(true)\n onChange(e.target.value)\n }\n }}\n onPaste={(e) => {\n if (fieldIsDisabled) return\n if (regex.ASCII.test(e.target.value)) {\n setIsValid(undefined)\n setDisabledBeautify(true)\n onChange(e.target.value)\n }\n }}\n min=\"1\"\n placeholder={placeholder}\n />\n {withFooter && (\n <div className={`${styles['actions-container']}`}>\n <button\n type=\"button\"\n className={styles.validate}\n onClick={() => {\n const valid = checkIsValid()\n setIsValid(valid)\n onValidation(valid)\n setDisabledBeautify(!checkIsValid())\n }}\n data-id={`${dataId}-VALIDATE-BUTTON`}\n disabled={value === ''}\n >\n Validate\n </button>\n <button\n type=\"button\"\n disabled={value === '' || disabledBeautify}\n data-id={`${dataId}-BEAUTIFY-BUTTON`}\n className={styles.beautify}\n onClick={handlePrettify}\n >\n Beautify\n </button>\n </div>\n )}\n </div>\n {(errorMessage || (value !== '' && isValid === false)) && (\n <p className={styles['error-message']}>{errorMessage || errorMapping[acceptType]}</p>\n )}\n </div>\n )\n}\n\nexport default JsonInput\n"],"names":["errorMapping","BOTH","JSON","YML","JsonInput","placeholder","label","value","onValidation","onChange","dataId","className","errorMessage","acceptType","fieldIsDisabled","withFooter","isValid","setIsValid","useState","disabledBeautify","setDisabledBeautify","handlePrettify","e","preventDefault","prettifiedData","isValidJson","yaml","dump","load","indent","stringify","parse","error","console","str","checkIsValid","useEffect","_a","_jsxs","jsxs","styles","disabled","children","_jsx","jsx","invalid","regex","ASCII","test","target","undefined","onPaste","min","type","validate","onClick","valid","beautify"],"mappings":"oPAKA,MAAMA,EAAe,CACnBC,KAAM,8BACNC,KAAM,sBACNC,IAAK,uBAGDC,EAAY,EAChBC,cACAC,QACAC,QACAC,eACAC,WACAC,SACAC,YAAY,GACZC,eACAC,aAAa,OACbC,kBACAC,cAAa,MAEb,MAAOC,EAASC,GAAcC,KACvBC,EAAkBC,GAAuBF,GAAS,GAEnDG,EAAkBC,IACtB,GAAc,KAAVf,EAAJ,CACAe,EAAEC,iBACF,IACE,IAAIC,EACgB,SAAfX,GAAwC,SAAfA,IAA0BY,EAAYlB,GAG1C,SAAfM,GAAwC,QAAfA,IAElCW,EAAiBE,EAAKC,KAAKD,EAAKE,KAAKrB,GAAQ,CAAEsB,OAAQ,KAHvDL,EAAiBtB,KAAK4B,UAAU5B,KAAK6B,MAAMxB,GAAQ,KAAM,GAK3DE,EAASe,GACTP,GAAW,EACZ,CAAC,MAAOe,GACPC,QAAQD,MAAMA,GACdf,GAAW,EACZ,CAhBuB,CAgBvB,EAIGQ,EAAeS,IACnB,IAEE,OADAhC,KAAK6B,MAAMG,IACJ,CACR,CAAC,MAAOF,GACP,OAAO,CACR,GAGGG,EAAe,KACnB,GAAmB,SAAftB,GAAwC,SAAfA,EAC3B,OAAOY,EAAYlB,GACd,GAAmB,SAAfM,GAAwC,QAAfA,EAClC,IAGE,OADAa,EAAKE,KAAKrB,IACH,CACR,CAAC,MAAOyB,GAEP,OADAC,QAAQD,MAAMA,IACP,CACR,CACF,EASH,OANAI,GAAU,KACR,IACEf,EAAed,EAChB,CAAC,MAAM8B,GAAE,IACT,IAGDC,EACEC,KAAA,MAAA,CAAA5B,UAAW,GAAG6B,EAAO,4BAA4B7B,KAC/CG,EAAkB0B,EAAOC,SAAW,KACpCC,SAAA,CAEDpC,GAASqC,EAAAC,IAAA,IAAA,CAAGjC,UAAW,GAAG6B,EAAO,gCAAyBlC,IAC3DgC,EACEC,KAAA,MAAA,CAAA5B,UAAW,GAAG6B,EAAO,kBACT,KAAVjC,IAA4B,IAAZS,EAAoBwB,EAAOK,QAAU,KAGvDH,SAAA,CAAAC,EAAAC,IAAA,WAAA,CACEH,SAAU3B,YACDJ,EACTH,MAAOA,EACPE,SAAWa,IACLR,GACAgC,EAAMC,MAAMC,KAAK1B,EAAE2B,OAAO1C,SAC5BU,OAAWiC,GACX9B,GAAoB,GACpBX,EAASa,EAAE2B,OAAO1C,OACnB,EAEH4C,QAAU7B,IACJR,GACAgC,EAAMC,MAAMC,KAAK1B,EAAE2B,OAAO1C,SAC5BU,OAAWiC,GACX9B,GAAoB,GACpBX,EAASa,EAAE2B,OAAO1C,OACnB,EAEH6C,IAAI,IACJ/C,YAAaA,IAEdU,GACCuB,EAAAA,KAAK,MAAA,CAAA3B,UAAW,GAAG6B,EAAO,uBAAsBE,SAAA,CAC9CC,EAAAA,IACE,SAAA,CAAAU,KAAK,SACL1C,UAAW6B,EAAOc,SAClBC,QAAS,KACP,MAAMC,EAAQrB,IACdlB,EAAWuC,GACXhD,EAAagD,GACbpC,GAAqBe,IAAe,YAE7B,GAAGzB,oBACZ+B,SAAoB,KAAVlC,wBAIZoC,EAAAC,IAAA,SAAA,CACES,KAAK,SACLZ,SAAoB,KAAVlC,GAAgBY,EAAgB,UACjC,GAAGT,oBACZC,UAAW6B,EAAOiB,SAClBF,QAASlC,EAGFqB,SAAA,oBAIb9B,GAA2B,KAAVL,IAA4B,IAAZS,IACjC2B,EAAGC,IAAA,IAAA,CAAAjC,UAAW6B,EAAO,0BAAmB5B,GAAgBZ,EAAaa,OAG1E"}
1
+ {"version":3,"file":"JsonInput.js","sources":["../../../../src/components/JsonInput/JsonInput.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react'\nimport yaml from 'js-yaml'\nimport styles from './style.module.scss'\nimport regex from '../../constants/regex'\n\nconst errorMapping = {\n BOTH: 'Invalid JSON or YAML format',\n JSON: 'Invalid JSON format',\n YML: 'Invalid YAML format',\n}\n\nconst JsonInput = ({\n placeholder,\n label,\n value,\n onValidation,\n onChange,\n dataId,\n className = '',\n errorMessage,\n acceptType = 'BOTH',\n fieldIsDisabled,\n withFooter = true,\n}) => {\n const [isValid, setIsValid] = useState()\n const [disabledBeautify, setDisabledBeautify] = useState(true)\n\n const handlePrettify = (e) => {\n if (value === '') return\n e.preventDefault()\n try {\n let prettifiedData\n if ((acceptType === 'BOTH' || acceptType === 'JSON') && isValidJson(value)) {\n // If it's valid JSON, prettify JSON\n prettifiedData = JSON.stringify(JSON.parse(value), null, 2)\n } else if (acceptType === 'BOTH' || acceptType === 'YML') {\n // If it's not valid JSON, prettify YAML\n prettifiedData = yaml.dump(yaml.load(value), { indent: 0 })\n }\n onChange(prettifiedData)\n setIsValid(true) // Reset validity status\n } catch (error) {\n console.error(error)\n setIsValid(false)\n }\n }\n\n // Function to check if input is valid JSON\n const isValidJson = (str) => {\n try {\n JSON.parse(str)\n return true\n } catch (error) {\n return false\n }\n }\n\n const checkIsValid = () => {\n if (acceptType === 'BOTH' || acceptType === 'JSON') {\n return isValidJson(value)\n } else if (acceptType === 'BOTH' || acceptType === 'YML') {\n try {\n // Try parsing as YAML\n yaml.load(value)\n return true\n } catch (error) {\n console.error(error)\n return false\n }\n }\n }\n\n useEffect(() => {\n try {\n handlePrettify(value)\n } catch {}\n }, [])\n\n return (\n <div\n className={`${styles['json-editor-container']} ${className} ${\n fieldIsDisabled ? styles.disabled : ''\n }`}\n >\n {label && <p className={`${styles['json-editor-label']}`}>{label}</p>}\n <div\n className={`${styles['json-editor']} ${\n value !== '' && isValid === false ? styles.invalid : ''\n }`}\n >\n <textarea\n disabled={fieldIsDisabled}\n data-id={dataId}\n value={value}\n onChange={(e) => {\n if (fieldIsDisabled) return\n if (regex.ASCII.test(e.target.value)) {\n setIsValid(undefined)\n setDisabledBeautify(true)\n onChange(e.target.value)\n }\n }}\n onPaste={(e) => {\n if (fieldIsDisabled) return\n if (regex.ASCII.test(e.target.value)) {\n setIsValid(undefined)\n setDisabledBeautify(true)\n onChange(e.target.value)\n }\n }}\n min=\"1\"\n placeholder={placeholder}\n />\n {withFooter && (\n <div className={`${styles['actions-container']}`}>\n <button\n type=\"button\"\n className={styles.validate}\n onClick={() => {\n const valid = checkIsValid()\n setIsValid(valid)\n onValidation(valid)\n setDisabledBeautify(!checkIsValid())\n }}\n data-id={`${dataId}-VALIDATE-BUTTON`}\n disabled={value === ''}\n >\n Validate\n </button>\n <button\n type=\"button\"\n disabled={value === '' || disabledBeautify}\n data-id={`${dataId}-BEAUTIFY-BUTTON`}\n className={styles.beautify}\n onClick={handlePrettify}\n >\n Beautify\n </button>\n </div>\n )}\n </div>\n {(errorMessage || (value !== '' && isValid === false)) && (\n <p className={styles['error-message']}>{errorMessage || errorMapping[acceptType]}</p>\n )}\n </div>\n )\n}\n\nexport default JsonInput\n"],"names":["errorMapping","BOTH","JSON","YML","JsonInput","placeholder","label","value","onValidation","onChange","dataId","className","errorMessage","acceptType","fieldIsDisabled","withFooter","isValid","setIsValid","useState","disabledBeautify","setDisabledBeautify","handlePrettify","e","preventDefault","prettifiedData","isValidJson","yaml","dump","load","indent","stringify","parse","error","console","str","checkIsValid","useEffect","_a","_jsxs","jsxs","styles","disabled","children","_jsx","jsx","invalid","regex","ASCII","test","target","undefined","onPaste","min","type","validate","onClick","valid","beautify"],"mappings":"oPAKA,MAAMA,EAAe,CACnBC,KAAM,8BACNC,KAAM,sBACNC,IAAK,uBAGDC,EAAY,EAChBC,cACAC,QACAC,QACAC,eACAC,WACAC,SACAC,YAAY,GACZC,eACAC,aAAa,OACbC,kBACAC,cAAa,MAEb,MAAOC,EAASC,GAAcC,KACvBC,EAAkBC,GAAuBF,GAAS,GAEnDG,EAAkBC,IACtB,GAAc,KAAVf,EAAJ,CACAe,EAAEC,iBACF,IACE,IAAIC,EACgB,SAAfX,GAAwC,SAAfA,IAA0BY,EAAYlB,GAG1C,SAAfM,GAAwC,QAAfA,IAElCW,EAAiBE,EAAKC,KAAKD,EAAKE,KAAKrB,GAAQ,CAAEsB,OAAQ,KAHvDL,EAAiBtB,KAAK4B,UAAU5B,KAAK6B,MAAMxB,GAAQ,KAAM,GAK3DE,EAASe,GACTP,GAAW,EACZ,CAAC,MAAOe,GACPC,QAAQD,MAAMA,GACdf,GAAW,EACZ,CAhBuB,GAoBpBQ,EAAeS,IACnB,IAEE,OADAhC,KAAK6B,MAAMG,IACJ,CACR,CAAC,MAAOF,GACP,OAAO,CACR,GAGGG,EAAe,KACnB,GAAmB,SAAftB,GAAwC,SAAfA,EAC3B,OAAOY,EAAYlB,GACd,GAAmB,SAAfM,GAAwC,QAAfA,EAClC,IAGE,OADAa,EAAKE,KAAKrB,IACH,CACR,CAAC,MAAOyB,GAEP,OADAC,QAAQD,MAAMA,IACP,CACR,GAUL,OANAI,GAAU,KACR,IACEf,EAAed,EAChB,CAAC,MAAM8B,GAAE,IACT,IAGDC,EACEC,KAAA,MAAA,CAAA5B,UAAW,GAAG6B,EAAO,4BAA4B7B,KAC/CG,EAAkB0B,EAAOC,SAAW,KACpCC,SAAA,CAEDpC,GAASqC,EAAAC,IAAA,IAAA,CAAGjC,UAAW,GAAG6B,EAAO,gCAAyBlC,IAC3DgC,EACEC,KAAA,MAAA,CAAA5B,UAAW,GAAG6B,EAAO,kBACT,KAAVjC,IAA4B,IAAZS,EAAoBwB,EAAOK,QAAU,KAGvDH,SAAA,CAAAC,EAAAC,IAAA,WAAA,CACEH,SAAU3B,YACDJ,EACTH,MAAOA,EACPE,SAAWa,IACLR,GACAgC,EAAMC,MAAMC,KAAK1B,EAAE2B,OAAO1C,SAC5BU,OAAWiC,GACX9B,GAAoB,GACpBX,EAASa,EAAE2B,OAAO1C,SAGtB4C,QAAU7B,IACJR,GACAgC,EAAMC,MAAMC,KAAK1B,EAAE2B,OAAO1C,SAC5BU,OAAWiC,GACX9B,GAAoB,GACpBX,EAASa,EAAE2B,OAAO1C,SAGtB6C,IAAI,IACJ/C,YAAaA,IAEdU,GACCuB,EAAAA,KAAK,MAAA,CAAA3B,UAAW,GAAG6B,EAAO,uBAAsBE,SAAA,CAC9CC,EAAAA,IACE,SAAA,CAAAU,KAAK,SACL1C,UAAW6B,EAAOc,SAClBC,QAAS,KACP,MAAMC,EAAQrB,IACdlB,EAAWuC,GACXhD,EAAagD,GACbpC,GAAqBe,gBAEd,GAAGzB,oBACZ+B,SAAoB,KAAVlC,wBAIZoC,EAAAC,IAAA,SAAA,CACES,KAAK,SACLZ,SAAoB,KAAVlC,GAAgBY,EAAgB,UACjC,GAAGT,oBACZC,UAAW6B,EAAOiB,SAClBF,QAASlC,EAGFqB,SAAA,oBAIb9B,GAA2B,KAAVL,IAA4B,IAAZS,IACjC2B,EAAGC,IAAA,IAAA,CAAAjC,UAAW6B,EAAO,0BAAmB5B,GAAgBZ,EAAaa"}
@@ -1 +1 @@
1
- {"version":3,"file":"LivePreview.js","sources":["../../../../src/components/LivePreview/LivePreview.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react'\nimport styles from './LivePreview.module.scss'\nimport SimpleLabelValue from '../../components/SimpleLabelValue'\nimport MethodsAccordion from '../../components/MethodAccordion/MethodAccordion'\nimport { TransformedOpenApi } from '../../types/transformedOpenApi'\nimport { useFormikContext } from 'formik'\nimport { methodColorMapping, tagsTableHeaders } from '../../constants/index'\nimport TagsTable from '../table/tags-table'\nimport { Accordion, Button, Chip } from 'digitinary-ui'\nimport Tooltip from '../../components/Tooltip/Tooltip'\nimport SVGLoader from '../../components/SVGLoader/SVGLoader'\nimport { DownArrowIcon } from '../../assets/icons'\n\ninterface LivePreviewProps {\n transformedData?: TransformedOpenApi\n openApiErrors?: any[]\n}\n\nconst LivePreview: React.FC<LivePreviewProps> = ({ transformedData, openApiErrors }) => {\n const [tableRecords, setTableRecords] = useState()\n const [tooltipRefs, setTooltipRefs] = useState<{ [key: number]: any }>({})\n const [tableData, setTableData] = useState([])\n const [externalTooltipRefs, setExternalTooltipRefs] = useState<{ [key: number]: any }>({})\n const [errorExpanded, setErrorExpanded] = useState(openApiErrors.length > 0)\n const { values } = useFormikContext<TransformedOpenApi>()\n const { info, components, tags } = values\n const { securitySchemes } = components\n const securityKey =\n securitySchemes && typeof securitySchemes == 'object' && Object.keys(securitySchemes).length\n ? Object.keys(securitySchemes)[0]\n : null\n\n useEffect(() => {\n if (values.tags) {\n setTableRecords(generateTableData(values.tags, true))\n setTableData(values.tags)\n }\n }, [values.tags])\n\n const generateTableData = (items, readOnly) => {\n return items.map((item, index) => ({\n id: index,\n tagName: item.name,\n description: (\n <Tooltip\n key={`${index}-description`}\n allowHTML\n disabled={item.description?.length <= 12}\n content={<div style={{ padding: '0.625rem' }}>{item.description}</div>}\n arrowWithBorder\n placement=\"bottom-end\"\n type=\"function\"\n delay={[0, 0]}\n >\n <div className={styles.paramDescContainer}>\n <p className={styles.editDescBtn}>\n {item.description ? item.description.substring(0, 12) : '-'}\n {item.description && item.description.length > 12 ? '...' : ''}\n </p>\n </div>\n </Tooltip>\n ),\n externalDocs: (\n <div className={styles.paramDescContainer}>\n {item.externalDocs && item.externalDocs.url && item.externalDocs.url != '-' ? (\n <a\n className={styles.editDescBtn}\n href={\n item.externalDocs?.url && item.externalDocs?.url.indexOf('http') > -1\n ? item.externalDocs?.url\n : `https://${item.externalDocs?.url}`\n }\n rel=\"noopener noreferrer\"\n target=\"_blank\"\n >\n {item?.externalDocs?.url && !item?.externalDocs?.description\n ? item?.externalDocs?.url\n : null}\n {item?.externalDocs?.description\n ? item?.externalDocs?.description?.substring(0, 12)\n : !item?.externalDocs?.url\n ? '-'\n : null}\n {item?.externalDocs?.description && item?.externalDocs?.description?.length > 12\n ? '...'\n : ''}\n </a>\n ) : (\n <Button className={styles.editDescBtn} variant=\"link\" color=\"action\">\n {item.externalDocs?.description\n ? item.externalDocs?.description.substring(0, 12)\n : '-'}\n {item.externalDocs?.description && item.externalDocs?.description.length > 12\n ? '...'\n : ''}\n </Button>\n )}\n\n {/* </Tooltip> */}\n\n {!readOnly && <div className={styles.paramDescContainer_separator}></div>}\n\n {!readOnly && (\n <Button\n className={styles.deleteParamBtn}\n variant=\"link\"\n color=\"error\"\n onClick={() => null}\n ></Button>\n )}\n </div>\n ),\n }))\n }\n\n const securityScheme = !!securityKey\n ? securitySchemes[securityKey].scheme || securitySchemes[securityKey].type\n : '-'\n\n return (\n <div className={styles.livePreviewContainer}>\n {!!openApiErrors && openApiErrors.length > 0 && (\n <div className=\"row\">\n <div className=\"col-md-12\">\n <Accordion\n expanded={errorExpanded}\n onChange={() => null}\n className={styles.responseAccordion}\n summary={\n <span\n className={styles.responseAccordionSummary}\n onClick={() => setErrorExpanded((prev) => !errorExpanded)}\n >\n <div className={styles.responseAccordionSummary_title}>Errors</div>\n <SVGLoader\n className={errorExpanded ? styles.expanded : ''}\n src={DownArrowIcon}\n width=\"2rem\"\n height=\"2rem\"\n />\n </span>\n }\n children={\n <div className={styles.accordionContent}>\n <span>\n Failed to update the OpenAPI documentation. Please resolve the following issues:\n </span>\n <br />\n <ol>\n {openApiErrors.map((errItem) => (\n <li key={errItem}>{errItem}</li>\n ))}\n </ol>\n </div>\n }\n />\n </div>\n </div>\n )}\n <div className=\"row\">\n <div className=\"col-md-12\">\n <div className={styles.titleContainer}>\n <p className={styles.apiName}>{info?.title?.trim() || '-'}</p>\n <Chip className={styles.livePreviewChip}>Live Preview</Chip>\n </div>\n <SimpleLabelValue key={'version'} label={'Version: '} value={info?.version || '-'} />\n <SimpleLabelValue\n key={'description'}\n label={'Description: '}\n className={styles.description_preview}\n value={info?.description?.trim() || '-'}\n />\n\n <SimpleLabelValue key={'tags'} label={'Tags: '} />\n <TagsTable\n id=\"tags-table\"\n data={tableRecords}\n headCells={tagsTableHeaders}\n isFormOpen={false}\n setIsFormOpen={() => null}\n saveNewRow={() => null}\n readOnly={true}\n />\n\n <SimpleLabelValue key={'endpoints'} label={'Endpoints '} />\n {values.paths.map((path) => (\n <div className={styles.methodsContainer} key={path.path}>\n {Object.entries(\n path.methods\n .sort(\n (a, b) => methodColorMapping[a.type].order + methodColorMapping[b.type].order\n )\n .reduce((groupedMethods, method) => {\n // Handle methods without tags\n const tags = method.tags?.length ? method?.tags : ['default']\n\n tags.forEach((tag) => {\n if (!groupedMethods[tag]) {\n groupedMethods[tag] = []\n }\n groupedMethods[tag].push(method)\n })\n\n return groupedMethods\n }, {})\n ).map(([tag, methods]) => (\n <div key={tag}>\n <h3>{tag}</h3>\n {methods?.map((method, methodIndex) => (\n <MethodsAccordion\n readOnly\n method={method}\n path={path.path}\n tags={values.tags}\n />\n ))}\n </div>\n ))}\n </div>\n ))}\n </div>\n </div>\n </div>\n )\n}\n\nexport default LivePreview\n"],"names":["LivePreview","transformedData","openApiErrors","tableRecords","setTableRecords","useState","tableData","setTableData","errorExpanded","setErrorExpanded","length","values","useFormikContext","info","components","tags","securitySchemes","securityKey","Object","keys","useEffect","generateTableData","items","readOnly","map","item","index","id","tagName","name","description","_jsx","jsx","Tooltip","allowHTML","disabled","_a","content","style","padding","children","arrowWithBorder","placement","type","delay","className","styles","paramDescContainer","_jsxs","jsxs","editDescBtn","substring","externalDocs","url","href","_b","_c","indexOf","_d","_e","rel","target","_f","_g","_h","_j","_l","_k","_m","_o","_q","_p","Button","variant","color","_r","_s","_t","_u","paramDescContainer_separator","deleteParamBtn","onClick","scheme","livePreviewContainer","Accordion","expanded","onChange","responseAccordion","summary","responseAccordionSummary","prev","responseAccordionSummary_title","SVGLoader","src","DownArrowIcon","width","height","accordionContent","errItem","titleContainer","apiName","title","trim","Chip","livePreviewChip","SimpleLabelValue","label","value","version","description_preview","TagsTable","data","headCells","tagsTableHeaders","isFormOpen","setIsFormOpen","saveNewRow","paths","path","methodsContainer","entries","methods","sort","a","b","methodColorMapping","order","reduce","groupedMethods","method","forEach","tag","push","methodIndex","MethodsAccordion"],"mappings":"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"}
1
+ {"version":3,"file":"LivePreview.js","sources":["../../../../src/components/LivePreview/LivePreview.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react'\nimport styles from './LivePreview.module.scss'\nimport SimpleLabelValue from '../../components/SimpleLabelValue'\nimport MethodsAccordion from '../../components/MethodAccordion/MethodAccordion'\nimport { TransformedOpenApi } from '../../types/transformedOpenApi'\nimport { useFormikContext } from 'formik'\nimport { methodColorMapping, tagsTableHeaders } from '../../constants/index'\nimport TagsTable from '../table/tags-table'\nimport { Accordion, Button, Chip } from 'digitinary-ui'\nimport Tooltip from '../../components/Tooltip/Tooltip'\nimport SVGLoader from '../../components/SVGLoader/SVGLoader'\nimport { DownArrowIcon } from '../../assets/icons'\n\ninterface LivePreviewProps {\n transformedData?: TransformedOpenApi\n openApiErrors?: any[]\n}\n\nconst LivePreview: React.FC<LivePreviewProps> = ({ transformedData, openApiErrors }) => {\n const [tableRecords, setTableRecords] = useState()\n const [tooltipRefs, setTooltipRefs] = useState<{ [key: number]: any }>({})\n const [tableData, setTableData] = useState([])\n const [externalTooltipRefs, setExternalTooltipRefs] = useState<{ [key: number]: any }>({})\n const [errorExpanded, setErrorExpanded] = useState(openApiErrors.length > 0)\n const { values } = useFormikContext<TransformedOpenApi>()\n const { info, components, tags } = values\n const { securitySchemes } = components\n const securityKey =\n securitySchemes && typeof securitySchemes == 'object' && Object.keys(securitySchemes).length\n ? Object.keys(securitySchemes)[0]\n : null\n\n useEffect(() => {\n if (values.tags) {\n setTableRecords(generateTableData(values.tags, true))\n setTableData(values.tags)\n }\n }, [values.tags])\n\n const generateTableData = (items, readOnly) => {\n return items.map((item, index) => ({\n id: index,\n tagName: item.name,\n description: (\n <Tooltip\n key={`${index}-description`}\n allowHTML\n disabled={item.description?.length <= 12}\n content={<div style={{ padding: '0.625rem' }}>{item.description}</div>}\n arrowWithBorder\n placement=\"bottom-end\"\n type=\"function\"\n delay={[0, 0]}\n >\n <div className={styles.paramDescContainer}>\n <p className={styles.editDescBtn}>\n {item.description ? item.description.substring(0, 12) : '-'}\n {item.description && item.description.length > 12 ? '...' : ''}\n </p>\n </div>\n </Tooltip>\n ),\n externalDocs: (\n <div className={styles.paramDescContainer}>\n {item.externalDocs && item.externalDocs.url && item.externalDocs.url != '-' ? (\n <a\n className={styles.editDescBtn}\n href={\n item.externalDocs?.url && item.externalDocs?.url.indexOf('http') > -1\n ? item.externalDocs?.url\n : `https://${item.externalDocs?.url}`\n }\n rel=\"noopener noreferrer\"\n target=\"_blank\"\n >\n {item?.externalDocs?.url && !item?.externalDocs?.description\n ? item?.externalDocs?.url\n : null}\n {item?.externalDocs?.description\n ? item?.externalDocs?.description?.substring(0, 12)\n : !item?.externalDocs?.url\n ? '-'\n : null}\n {item?.externalDocs?.description && item?.externalDocs?.description?.length > 12\n ? '...'\n : ''}\n </a>\n ) : (\n <Button className={styles.editDescBtn} variant=\"link\" color=\"action\">\n {item.externalDocs?.description\n ? item.externalDocs?.description.substring(0, 12)\n : '-'}\n {item.externalDocs?.description && item.externalDocs?.description.length > 12\n ? '...'\n : ''}\n </Button>\n )}\n\n {/* </Tooltip> */}\n\n {!readOnly && <div className={styles.paramDescContainer_separator}></div>}\n\n {!readOnly && (\n <Button\n className={styles.deleteParamBtn}\n variant=\"link\"\n color=\"error\"\n onClick={() => null}\n ></Button>\n )}\n </div>\n ),\n }))\n }\n\n const securityScheme = !!securityKey\n ? securitySchemes[securityKey].scheme || securitySchemes[securityKey].type\n : '-'\n\n return (\n <div className={styles.livePreviewContainer}>\n {!!openApiErrors && openApiErrors.length > 0 && (\n <div className=\"row\">\n <div className=\"col-md-12\">\n <Accordion\n expanded={errorExpanded}\n onChange={() => null}\n className={styles.responseAccordion}\n summary={\n <span\n className={styles.responseAccordionSummary}\n onClick={() => setErrorExpanded((prev) => !errorExpanded)}\n >\n <div className={styles.responseAccordionSummary_title}>Errors</div>\n <SVGLoader\n className={errorExpanded ? styles.expanded : ''}\n src={DownArrowIcon}\n width=\"2rem\"\n height=\"2rem\"\n />\n </span>\n }\n children={\n <div className={styles.accordionContent}>\n <span>\n Failed to update the OpenAPI documentation. Please resolve the following issues:\n </span>\n <br />\n <ol>\n {openApiErrors.map((errItem) => (\n <li key={errItem}>{errItem}</li>\n ))}\n </ol>\n </div>\n }\n />\n </div>\n </div>\n )}\n <div className=\"row\">\n <div className=\"col-md-12\">\n <div className={styles.titleContainer}>\n <p className={styles.apiName}>{info?.title?.trim() || '-'}</p>\n <Chip className={styles.livePreviewChip}>Live Preview</Chip>\n </div>\n <SimpleLabelValue key={'version'} label={'Version: '} value={info?.version || '-'} />\n <SimpleLabelValue\n key={'description'}\n label={'Description: '}\n className={styles.description_preview}\n value={info?.description?.trim() || '-'}\n />\n\n <SimpleLabelValue key={'tags'} label={'Tags: '} />\n <TagsTable\n id=\"tags-table\"\n data={tableRecords}\n headCells={tagsTableHeaders}\n isFormOpen={false}\n setIsFormOpen={() => null}\n saveNewRow={() => null}\n readOnly={true}\n />\n\n <SimpleLabelValue key={'endpoints'} label={'Endpoints '} />\n {values.paths.map((path) => (\n <div className={styles.methodsContainer} key={path.path}>\n {Object.entries(\n path.methods\n .sort(\n (a, b) => methodColorMapping[a.type].order + methodColorMapping[b.type].order\n )\n .reduce((groupedMethods, method) => {\n // Handle methods without tags\n const tags = method.tags?.length ? method?.tags : ['default']\n\n tags.forEach((tag) => {\n if (!groupedMethods[tag]) {\n groupedMethods[tag] = []\n }\n groupedMethods[tag].push(method)\n })\n\n return groupedMethods\n }, {})\n ).map(([tag, methods]) => (\n <div key={tag}>\n <h3>{tag}</h3>\n {methods?.map((method, methodIndex) => (\n <MethodsAccordion\n readOnly\n method={method}\n path={path.path}\n tags={values.tags}\n />\n ))}\n </div>\n ))}\n </div>\n ))}\n </div>\n </div>\n </div>\n )\n}\n\nexport default LivePreview\n"],"names":["LivePreview","transformedData","openApiErrors","tableRecords","setTableRecords","useState","tableData","setTableData","errorExpanded","setErrorExpanded","length","values","useFormikContext","info","components","tags","securitySchemes","securityKey","Object","keys","useEffect","generateTableData","items","readOnly","map","item","index","id","tagName","name","description","_jsx","jsx","Tooltip","allowHTML","disabled","_a","content","style","padding","children","arrowWithBorder","placement","type","delay","className","styles","paramDescContainer","_jsxs","jsxs","editDescBtn","substring","externalDocs","url","href","_b","_c","indexOf","_d","_e","rel","target","_f","_g","_h","_j","_l","_k","_m","_o","_q","_p","Button","variant","color","_r","_s","_t","_u","paramDescContainer_separator","deleteParamBtn","onClick","scheme","livePreviewContainer","Accordion","expanded","onChange","responseAccordion","summary","responseAccordionSummary","prev","responseAccordionSummary_title","SVGLoader","src","DownArrowIcon","width","height","accordionContent","errItem","titleContainer","apiName","title","trim","Chip","livePreviewChip","SimpleLabelValue","label","value","version","description_preview","TagsTable","data","headCells","tagsTableHeaders","isFormOpen","setIsFormOpen","saveNewRow","paths","path","methodsContainer","entries","methods","sort","a","b","methodColorMapping","order","reduce","groupedMethods","method","forEach","tag","push","methodIndex","MethodsAccordion"],"mappings":"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"}