@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 +1 @@
1
- {"version":3,"file":"MethodAccordion.js","sources":["../../../../src/components/MethodAccordion/MethodAccordion.tsx"],"sourcesContent":["import { useEffect, useRef, useState } from 'react'\nimport { Accordion, Button, Input, SelectGroup, Switch, TextArea } from 'digitinary-ui'\nimport SVGLoader from '../../components/SVGLoader/SVGLoader'\nimport {\n DeleteIcon,\n DownArrowIcon,\n EditIcon,\n DeleteOutlinedIcon,\n CloseIcon,\n} from '../../assets/icons'\nimport PlusIcon from '../../assets/icons/Plus.svg'\nimport PlusSquare from '../../assets/icons/PlusSquare.svg'\nimport { httpStatusCodes, methodColorMapping, paramsTableHeaders } from '../../constants/index'\nimport Tooltip from '../../components/Tooltip/Tooltip'\nimport { TransformedMethod } from '../../types/layout.type'\nimport SimpleLabelValue from '../../components/SimpleLabelValue'\nimport { capitalize, handleStatusColor } from '../../helpers/methodAccordion.helper'\nimport ParamterTable from '../table/table'\nimport CommonDialog from '../../components/dialog'\nimport JsonInput from '../../components/JsonInput/JsonInput'\nimport styles from './MethodAccordion.module.scss'\nimport { Tags } from '@entities/openApi'\nimport regex from '../../constants/regex'\n\nconst httpStatusCodeOptions = httpStatusCodes.map((code) => ({\n label: (\n <div className={styles.statusCodeOptionContainer}>\n <div\n className={styles.statusCodeOptionCircle}\n style={{ backgroundColor: handleStatusColor(code) }}\n ></div>\n <span>{code}</span>\n </div>\n ),\n value: code,\n}))\n\nconst MethodsAccordion = ({\n method,\n path,\n setFieldValue,\n readOnly,\n tags,\n isOpen,\n setIsOpen,\n errors,\n}: {\n method: TransformedMethod\n path: string\n setFieldValue?: (key: string, value: string | string[]) => void\n readOnly?: boolean\n tags: Tags[]\n isOpen: boolean\n setIsOpen: (open: boolean) => void\n errors?: string\n}) => {\n const [isExpanded, setIsExpanded] = useState({\n request: false,\n response: false,\n method: false,\n })\n const [isFormOpen, setIsFormOpen] = useState<boolean>(false)\n const [isHeaderFormOpen, setIsHeaderFormOpen] = useState<boolean>(false)\n const [tooltipRefs, setTooltipRefs] = useState<{ [key: number]: any }>({})\n const [tableData, setTableData] = useState([])\n const [tableResponseData, setTableResponseData] = useState([])\n const [openDeleteDialog, setOpenDeleteDialog] = useState(false)\n const [openHeaderDeleteDialog, setOpenHeaderDeleteDialog] = useState(false)\n const [selectedParamIndex, setSelectedParamIndex] = useState<number | null>(null)\n const [selectedHeaderIndex, setSelectedHeaderIndex] = useState<number | null>(null)\n const [selectedParamName, setSelectedParamName] = useState<string | null>(null)\n const [tableRecords, setTableRecords] = useState()\n const [tableResponseRecords, setTableResponseRecords] = useState([])\n const [selectionTags, setSelectionTags] = useState([])\n const [selectedStatusCode, setSelectedStatusCode] = useState(httpStatusCodeOptions[4])\n const [enumFields, setEnumFields] = useState([])\n const [tooltipEnumRef, setTooltipEnumRef] = useState(null)\n const [currentResponseIndex, setCurrentResponseIndex] = useState<number>(-1)\n const currentResponse =\n method.responses.find((res) => Number(res.code) === selectedStatusCode.value) || '{}'\n const indexRef = useRef(-1)\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 generateResponseTableData = (headersObj: any, responseIndex: number) => {\n const headersByName = Object.keys(headersObj)\n return headersByName.map((item, index) => {\n const data = headersObj[item]\n return {\n id: `header_${index}`,\n paramName: item,\n paramType: capitalize('header'),\n schemaType: `${capitalize(data?.schema?.type) || ''} ${\n data?.schema?.type?.toLowerCase() == 'array' &&\n data?.schema?.items &&\n data?.schema?.items?.type\n ? ` _ ${capitalize(data?.schema?.items?.type)}`\n : ''\n }`,\n required: (\n <>\n {readOnly ? (\n data.required ? (\n 'True'\n ) : (\n 'False'\n )\n ) : (\n <Switch\n checked={data.required}\n onClick={() => {\n if (readOnly) {\n return null\n }\n setFieldValue(\n `responses[${responseIndex}].headers[${item}].required`,\n !data.required\n )\n }}\n />\n )}\n </>\n ),\n description: (\n <div className={styles.paramDescContainer}>\n <Tooltip\n key={`${index}-description`}\n allowHTML\n disabled={method.responses[responseIndex].headers[item].description?.length <= 12}\n content={\n <div style={{ padding: '0.625rem' }}>\n {method.responses[responseIndex].headers[item].description}\n </div>\n }\n arrowWithBorder\n placement=\"bottom-end\"\n type=\"function\"\n delay={[0, 0]}\n onShow={() => tooltipRefs[index]?.hide()}\n >\n <p style={{ alignSelf: 'center' }}>\n {method.responses[responseIndex].headers[item].description\n ? method.responses[responseIndex].headers[item].description.substring(0, 12)\n : readOnly && '-'}\n {method.responses[responseIndex].headers[item].description &&\n method.responses[responseIndex].headers[item].description.length > 12\n ? '...'\n : ''}\n </p>\n </Tooltip>\n {!readOnly && (\n <Tooltip\n key={`${index}-add-edit-description`}\n allowHTML\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 parameter...\"\n value={data.description}\n disabled={readOnly}\n maxLength={120}\n onChange={(value) => {\n if (value === '' || regex.ASCII.test(value)) {\n setFieldValue(\n `responses[${indexRef.current}].headers[${item}].description`,\n value\n )\n }\n }}\n />\n {!readOnly && (\n <Button\n className={styles.editDescTooltipContent_btn}\n variant=\"outlined\"\n size=\"small\"\n onClick={() => {\n setFieldValue(\n `responses[${responseIndex}].headers[${item}].description`,\n data.description?.trim()\n )\n tooltipRefs[index]?.hide()\n }}\n disabled={!data.description?.trim()}\n >\n Apply\n </Button>\n )}\n </div>\n }\n >\n {readOnly ||\n method.responses[responseIndex].headers[item].description?.length > 0 ? (\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 ? 'View ' : 'Add '} Description\n </Button>\n )}\n </Tooltip>\n )}\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={() => handleDeleteResponseHeader(index, item)}\n ></Button>\n )}\n </div>\n ),\n enum: (\n <>\n {readOnly ? (\n <span className=\"enumText\">{data?.schema?.enum?.join('/\\u200B')}</span>\n ) : (\n <div data-id=\"TEXT_DESCRIPTION\" className=\"tableData\">\n {(() => {\n const schema = method?.responses[currentResponseIndex]?.headers[item]?.schema\n const schemaType = schema?.type?.toLowerCase()\n const isComplex = schemaType === 'array' || schemaType === 'object'\n const enumList = schema?.enum || []\n\n if (!schema || isComplex) return '-'\n\n return (\n <Tooltip\n disabled={isComplex}\n arrowWithBorder\n placement=\"bottom-end\"\n type=\"function\"\n trigger=\"click\"\n delay={[0, 0]}\n onCreate={(instance) => setTooltipEnumRef(instance)}\n content={\n <div className={styles.editDescTooltipContent}>\n <p className={styles.editDescTooltipContent_header}>Enum</p>\n\n {enumList.map((enumVal, enumIndex) => (\n <Input\n key={enumIndex}\n className=\"methodDescForEnum\"\n required\n clearable={false}\n placeholder=\"Enter Enum value...\"\n value={enumVal}\n onChange={(value) => {\n setFieldValue(\n `responses[${currentResponseIndex}].headers[\"${item}\"].schema.enum[${enumIndex}]`,\n value\n )\n }}\n />\n ))}\n\n <p\n className=\"addEnumButton\"\n onClick={() => {\n setFieldValue(\n `responses[${currentResponseIndex}].headers[\"${item}\"].schema.enum`,\n [...enumList, '']\n )\n }}\n >\n <SVGLoader src={PlusSquare} />\n Add New Enum\n </p>\n\n {!readOnly && (\n <Button\n className={styles.editDescTooltipContent_btn}\n variant=\"outlined\"\n size=\"small\"\n type=\"button\"\n onClick={() => {\n setFieldValue(\n `responses[${currentResponseIndex}].headers[\"${item}\"].schema.enum`,\n [...enumList]\n )\n setEnumFields([])\n tooltipEnumRef?.hide()\n }}\n disabled={enumList.length === 0 || enumList.some((val) => !val)}\n >\n Apply\n </Button>\n )}\n </div>\n }\n >\n {enumList.length > 0 ? (\n <span className=\"enumText\">{enumList.join('/\\u200B')}</span>\n ) : (\n <Button\n className={styles.editDescBtn}\n id=\"EnumButton\"\n variant=\"link\"\n color=\"action\"\n endIcon={\n <SVGLoader\n id=\"enumIcon\"\n src={PlusIcon}\n width=\"1.5rem\"\n height=\"1.5rem\"\n />\n }\n >\n Add\n </Button>\n )}\n </Tooltip>\n )\n })()}\n </div>\n )}\n </>\n ),\n }\n })\n }\n\n const generateTableData = (items, isForRequest?: boolean) => {\n return items?.map((item, index) => {\n return {\n id: index,\n paramName: item.name,\n paramType: capitalize(item.in),\n schemaType: `${capitalize(item?.schema?.type) || ''} ${\n item?.schema?.type?.toLowerCase() == 'array' &&\n item?.schema?.items &&\n item?.schema?.items?.type\n ? ` _ ${capitalize(item?.schema?.items?.type)}`\n : ''\n }`,\n required: (\n <>\n {readOnly ? (\n item.required ? (\n 'True'\n ) : (\n 'False'\n )\n ) : (\n <Switch\n checked={item.required}\n onClick={() => {\n if (readOnly) {\n return null\n }\n onTableChange('required', !item.required, index)\n setFieldValue(`parameters[${index}][required]`, !item.required)\n }}\n />\n )}\n </>\n ),\n description: (\n <div className={styles.paramDescContainer}>\n <Tooltip\n key={`${index}-description`}\n allowHTML\n disabled={method.parameters[index].description?.length <= 12}\n content={\n <div style={{ padding: '0.625rem' }}>{method.parameters[index].description}</div>\n }\n arrowWithBorder\n placement=\"bottom-end\"\n type=\"function\"\n delay={[0, 0]}\n onShow={() => tooltipRefs[index]?.hide()}\n >\n <p style={{ alignSelf: 'center' }}>\n {method.parameters[index].description\n ? method.parameters[index].description.substring(0, 12)\n : readOnly && '-'}\n {method.parameters[index].description &&\n method.parameters[index].description.length > 12\n ? '...'\n : ''}\n </p>\n </Tooltip>\n {!readOnly && (\n <Tooltip\n key={`${index}-add-edit-description`}\n allowHTML\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 parameter...\"\n value={item.description}\n disabled={readOnly}\n maxLength={120}\n onChange={(value) => {\n if (value === '' || regex.ASCII.test(value))\n onTableChange('description', value, index)\n }}\n />\n {!readOnly && (\n <Button\n className={styles.editDescTooltipContent_btn}\n variant=\"outlined\"\n size=\"small\"\n onClick={() => {\n setFieldValue(\n `parameters[${index}].description`,\n item.description?.trim()\n )\n tooltipRefs[index]?.hide()\n }}\n disabled={!item.description?.trim()}\n >\n Apply\n </Button>\n )}\n </div>\n }\n >\n {readOnly || method.parameters[index].description?.length > 0 ? (\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 ? 'View ' : 'Add '} Description\n </Button>\n )}\n </Tooltip>\n )}\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 enum: (\n <>\n {readOnly ? (\n <span className=\"enumText\">{item?.schema?.enum?.join('/\\u200B')}</span>\n ) : (\n <div data-id=\"TEXT_DESCRIPTION\" className=\"tableData\">\n {method.parameters[index]?.schema &&\n method.parameters[index]?.schema?.type?.toLowerCase() != 'array' &&\n method.parameters[index]?.schema?.type?.toLowerCase() != 'object' ? (\n <Tooltip\n disabled={\n method.parameters[index]?.schema?.type?.toLowerCase() == 'array' ||\n method.parameters[index]?.schema?.type?.toLowerCase() == 'object'\n }\n arrowWithBorder\n placement=\"bottom-end\"\n type=\"function\"\n trigger=\"click\"\n delay={[0, 0]}\n onCreate={(instance) => setTooltipEnumRef(instance)}\n content={\n <div className={styles.editDescTooltipContent}>\n <p className={styles.editDescTooltipContent_header}>Enum</p>\n {!!method.parameters[index]?.schema?.enum &&\n !!method.parameters[index]?.schema?.enum.length &&\n method.parameters[index]?.schema?.enum?.map((item, _index) => (\n <Input\n key={index}\n className={'methodDescForEnum'}\n required\n clearable={false}\n placeholder=\"Enter Enum value...\"\n value={item}\n onChange={(value) => {\n setFieldValue(`parameters[${index}].schema.enum[${_index}]`, value)\n }}\n />\n ))}\n <p\n className={'addEnumButton'}\n onClick={() => {\n setFieldValue(`parameters[${index}].schema.enum`, [\n ...method.parameters[index]?.schema?.enum,\n '',\n ])\n }}\n >\n <SVGLoader src={PlusSquare} />\n Add New Enum\n </p>\n {!readOnly && (\n <Button\n className={styles.editDescTooltipContent_btn}\n variant=\"outlined\"\n size=\"small\"\n type=\"button\"\n onClick={() => {\n setFieldValue(`parameters[${index}].schema.enum`, [\n ...method.parameters[index].schema.enum,\n ])\n setEnumFields([])\n tooltipEnumRef?.hide()\n }}\n disabled={\n (enumFields.length > 0 &&\n enumFields?.filter((item) => !item).length) ||\n (method?.parameters[index]?.schema?.enum &&\n method?.parameters[index]?.schema?.enum?.length > 0 &&\n method?.parameters[index]?.schema?.enum?.filter((item) => !item)\n .length)\n }\n >\n Apply\n </Button>\n )}\n </div>\n }\n >\n {method.parameters[index]?.schema?.enum &&\n method.parameters[index]?.schema?.enum?.length > 0 ? (\n <span className={'enumText'}>\n {method.parameters[index]?.schema?.enum?.join('/\\u200B')}\n </span>\n ) : (\n <Button\n className={styles.editDescBtn}\n id=\"EnumButton\"\n variant=\"link\"\n color=\"action\"\n endIcon={\n <SVGLoader id=\"enumIcon\" src={PlusIcon} width=\"1.5rem\" height=\"1.5rem\" />\n }\n >\n Add\n </Button>\n )}\n </Tooltip>\n ) : (\n '-'\n )}{' '}\n </div>\n )}\n </>\n ),\n }\n })\n }\n\n const confirmDeleteParameter = () => {\n if (selectedParamIndex !== null) {\n setTableData((prev) => prev.filter((_, i) => i !== selectedParamIndex))\n setFieldValue(\n `parameters`,\n method?.parameters?.filter((_, i) => i !== selectedParamIndex)\n )\n }\n setOpenDeleteDialog(false)\n setSelectedParamIndex(null)\n }\n\n const confirmDeleteHeader = () => {\n if (setSelectedHeaderIndex !== null) {\n let headers = Object.fromEntries(\n Object.entries(method.responses[indexRef.current].headers).filter(\n ([key]) => key != selectedParamName\n )\n )\n setFieldValue(`responses[${indexRef.current}].headers`, headers)\n }\n setOpenHeaderDeleteDialog(false)\n setSelectedHeaderIndex(null)\n }\n\n const handleDeleteClick = (id: number, name: string) => {\n setSelectedParamIndex(id)\n setSelectedParamName(name)\n\n setOpenDeleteDialog(true)\n }\n\n const handleDeleteResponseHeader = (index, name) => {\n setSelectedHeaderIndex(index)\n setSelectedParamName(name)\n\n setOpenHeaderDeleteDialog(true)\n }\n\n const saveNewRow = (values) => {\n setTableData([...tableData, values])\n setFieldValue(`parameters`, [...method.parameters, values])\n }\n\n const saveNewResponseRow = (value) => {\n setFieldValue(`responses[${indexRef.current}].headers[${value.name}]`, value)\n }\n\n useEffect(() => {\n setTableRecords(generateTableData(tableData, true))\n }, [tableData])\n\n useEffect(() => {\n if (method?.parameters) {\n setTableData(method.parameters)\n }\n }, [method, path])\n\n useEffect(() => {\n if (selectedStatusCode && method.responses) {\n let responseIndex = method.responses.findIndex(\n (_r) => _r.code.toString() == selectedStatusCode.value.toString()\n )\n if (responseIndex < 0) {\n const clonedResponses = structuredClone(method.responses)\n\n clonedResponses.push({\n code: selectedStatusCode.value.toString(),\n content: {\n contentType: 'application/json',\n schema: {},\n },\n headers: {},\n })\n\n if (setFieldValue) {\n setFieldValue('responses', clonedResponses)\n responseIndex = 0\n }\n }\n setCurrentResponseIndex(responseIndex)\n indexRef.current = responseIndex\n if (responseIndex >= 0) {\n setTableResponseRecords(\n generateResponseTableData(method.responses[responseIndex].headers, responseIndex)\n )\n }\n }\n }, [selectedStatusCode, method.responses, setFieldValue])\n\n useEffect(() => {\n if (indexRef.current && indexRef.current > -1) {\n setTableResponseRecords(\n generateResponseTableData(method.responses[indexRef.current].headers, indexRef.current)\n )\n }\n }, [method.responses, indexRef.current])\n\n useEffect(() => {\n // prepare tags selection list\n if (method?.tags.length || tags?.length) {\n const convertedStringArray = (method?.tags || [])?.map((item) => ({\n label: capitalize(item),\n value: item,\n }))\n const mergedArray = [\n ...convertedStringArray,\n ...(tags || []).map((item) => ({ label: capitalize(item.name), value: item.name })),\n ]\n\n const filteredArray = mergedArray.filter(\n (value, index, self) => index === self.findIndex((t) => t.value === value.value)\n )\n\n setSelectionTags(filteredArray)\n }\n }, [tags, method])\n\n return (\n <div>\n <Accordion\n expanded={isOpen}\n onChange={() => setIsOpen(!isOpen)}\n className={`${styles.methodAccordion} ${readOnly ? styles.readOnly : ''}`}\n summary={\n <div className={styles.methodSummaryContainer}>\n <div className={styles.methodSummary}>\n <span\n style={{\n backgroundColor: methodColorMapping?.[method?.type]?.color || '#3A6CD1',\n }}\n className={styles.methodLabel}\n >\n {methodColorMapping?.[method?.type]?.label || method?.type}\n </span>\n <span className={styles.methodPath}>{path}</span>\n </div>\n <div\n className={`${styles.methodExpandArrowContainer} ${isOpen ? styles.expanded : ''}`}\n >\n <SVGLoader src={DownArrowIcon} width=\"2rem\" height=\"2rem\" />\n </div>\n </div>\n }\n children={\n <div className={styles.methodAccordionContent}>\n {!readOnly ? (\n <Input\n className={styles.methodDesc}\n label=\"Endpoint Name\"\n required\n placeholder=\"Endpoint name...\"\n value={method?.summary}\n onChange={(value) => {\n value = value || ''\n if (value === '' || regex.ASCII.test(value)) {\n setFieldValue('summary', value)\n }\n }}\n onClear={() => {\n setFieldValue('summary', '')\n }}\n errorMsg={errors?.summary}\n />\n ) : (\n <SimpleLabelValue\n key={'summary'}\n label={'Endpoint Name: '}\n value={method?.summary || '-'}\n />\n )}\n <SelectGroup\n className={styles.methodDesc}\n disabled={readOnly}\n placeholder=\"Select Tags\"\n label=\"Tags\"\n value={method.tags?.map((t) => ({\n label: capitalize(t),\n value: t,\n }))}\n onChange={(item) => {\n setFieldValue(\n 'tags',\n item.map((i) => i.value)\n )\n }}\n options={[\n {\n list: selectionTags,\n },\n ]}\n isMultiple={true}\n withSearch={false}\n clearable={false}\n />\n {!readOnly ? (\n <TextArea\n className={styles.methodDesc}\n label=\"Description\"\n placeholder=\"Describe the method's purpose and functionality...\"\n maxLength={120}\n value={method?.description}\n onChange={(value) => {\n if (value === '' || regex.ASCII.test(value)) setFieldValue('description', value)\n }}\n />\n ) : (\n <SimpleLabelValue\n key={'description'}\n label={'Description: '}\n value={method?.description || '-'}\n />\n )}\n <div className={styles.paramsTable}>\n <h4 className={styles.paramsTableBodyHead}>Request Details</h4>\n <ParamterTable\n id=\"paramter-request-table\"\n data={tableRecords}\n headCells={paramsTableHeaders}\n isFormOpen={isFormOpen}\n setIsFormOpen={setIsFormOpen}\n saveNewRow={saveNewRow}\n readOnly={readOnly}\n isRequest={true}\n />\n {method?.type !== 'get' && method?.type !== 'delete' && (\n <Accordion\n expanded={isExpanded.request}\n onChange={() => null}\n className={styles.requestAccordion}\n summary={\n <span className={styles.requestAccordionSummary}>\n <div\n className={styles.requestAccordionSummary_title}\n onClick={() =>\n setIsExpanded((prev) => ({\n ...prev,\n request: !prev.request,\n }))\n }\n >\n <SVGLoader\n className={isExpanded.request ? styles.expanded : ''}\n src={DownArrowIcon}\n width=\"2rem\"\n height=\"2rem\"\n />\n Request\n {method?.type !== 'delete' && <span style={{ color: 'red' }}>*</span>}\n </div>\n </span>\n }\n children={\n <JsonInput\n acceptType=\"JSON\"\n withFooter={!readOnly}\n className={'jsonField'}\n placeholder=\"Enter your request body as a JSON object....\"\n fieldIsDisabled={readOnly}\n value={method?.requestBody?.content?.schema?.properties || '{}'}\n onChange={(value: string) => {\n setFieldValue('requestBody.content.schema.properties', value)\n }}\n onValidation={() => null}\n />\n }\n />\n )}\n </div>\n <div className={styles.paramsTable}>\n <div className={styles.responseHeader}>\n <h4 className={styles.paramsTableBodyHead}>Response Details</h4>\n <SelectGroup\n withSearch={false}\n isMultiple={false}\n clearable={false}\n placeholder=\"200\"\n options={[\n {\n list: httpStatusCodeOptions,\n },\n ]}\n value={selectedStatusCode}\n onChange={(value) => {\n setSelectedStatusCode(value)\n }}\n />\n </div>\n <ParamterTable\n id=\"paramter-response-table\"\n data={tableResponseRecords}\n headCells={paramsTableHeaders}\n isFormOpen={isHeaderFormOpen}\n setIsFormOpen={setIsHeaderFormOpen}\n saveNewRow={saveNewResponseRow}\n readOnly={readOnly}\n isRequest={false}\n />\n <Accordion\n expanded={isExpanded.response}\n onChange={() => null}\n className={styles.responseAccordion}\n summary={\n <span className={styles.responseAccordionSummary}>\n <div\n className={styles.responseAccordionSummary_title}\n onClick={() =>\n setIsExpanded((prev) => ({\n ...prev,\n response: !prev.response,\n }))\n }\n >\n <SVGLoader\n className={isExpanded.response ? styles.expanded : ''}\n src={DownArrowIcon}\n width=\"2rem\"\n height=\"2rem\"\n />\n Response<span style={{ color: 'red' }}>*</span>\n </div>\n </span>\n }\n children={\n <JsonInput\n acceptType=\"JSON\"\n withFooter={!readOnly}\n className={'jsonField'}\n placeholder=\"Enter your response as a JSON object...\"\n fieldIsDisabled={readOnly}\n value={currentResponse?.content?.schema?.properties || '{}'}\n onChange={(value) => {\n const currentResIndex = method.responses.findIndex(\n (res) => res.code === currentResponse.code\n )\n if (currentResIndex !== -1) {\n setFieldValue(\n `responses[${currentResIndex}].content.schema.properties`,\n value\n )\n } else {\n const clonedResponses = structuredClone(method.responses)\n\n clonedResponses.push({\n code: selectedStatusCode.value.toString(),\n content: {\n contentType: 'application/json',\n schema: {\n type: 'object',\n properties: value,\n },\n },\n })\n\n setFieldValue('responses', clonedResponses)\n }\n }}\n onValidation={(valid) => null}\n />\n }\n />\n </div>\n </div>\n }\n />\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 Parameter <strong>{selectedParamName}</strong>\n </span>\n ?\n </p>\n }\n onSubmit={{\n onClick: confirmDeleteParameter,\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 closeIcon={\n <SVGLoader\n src={CloseIcon}\n width=\"1.5rem\"\n height=\"1.5rem\"\n onClick={() => setOpenDeleteDialog(false)}\n />\n }\n />\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 Header <strong>{selectedParamName}</strong>\n </span>\n ?\n </p>\n }\n onSubmit={{\n onClick: confirmDeleteHeader,\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={() => setOpenHeaderDeleteDialog(false)}\n open={openHeaderDeleteDialog}\n icon={<SVGLoader src={DeleteOutlinedIcon} width=\"4.0625rem\" height=\"4.0625rem\" />}\n closeIcon={\n <SVGLoader\n src={CloseIcon}\n width=\"1.5rem\"\n height=\"1.5rem\"\n onClick={() => setOpenDeleteDialog(false)}\n />\n }\n />\n </div>\n )\n}\n\nexport default MethodsAccordion\n"],"names":["httpStatusCodeOptions","httpStatusCodes","map","code","label","_jsxs","className","styles","statusCodeOptionContainer","children","_jsx","statusCodeOptionCircle","style","backgroundColor","handleStatusColor","value","MethodsAccordion","method","path","setFieldValue","readOnly","tags","isOpen","setIsOpen","errors","isExpanded","setIsExpanded","useState","request","response","isFormOpen","setIsFormOpen","isHeaderFormOpen","setIsHeaderFormOpen","tooltipRefs","setTooltipRefs","tableData","setTableData","openDeleteDialog","setOpenDeleteDialog","openHeaderDeleteDialog","setOpenHeaderDeleteDialog","selectedParamIndex","setSelectedParamIndex","selectedHeaderIndex","setSelectedHeaderIndex","selectedParamName","setSelectedParamName","tableRecords","setTableRecords","tableResponseRecords","setTableResponseRecords","selectionTags","setSelectionTags","selectedStatusCode","setSelectedStatusCode","enumFields","setEnumFields","tooltipEnumRef","setTooltipEnumRef","currentResponseIndex","setCurrentResponseIndex","currentResponse","responses","find","res","Number","indexRef","useRef","onTableChange","key","index","newTableData","item","tIndex","Object","assign","generateResponseTableData","headersObj","responseIndex","keys","data","id","paramName","paramType","capitalize","schemaType","schema","_a","type","_c","_b","toLowerCase","_d","items","_f","_e","_h","_g","required","jsx","_Fragment","Switch","checked","onClick","description","paramDescContainer","Tooltip","allowHTML","disabled","_j","headers","length","content","padding","arrowWithBorder","placement","delay","onShow","hide","alignSelf","substring","trigger","onCreate","instance","prev","editDescTooltipContent","editDescTooltipContent_header","TextArea","placeholder","maxLength","onChange","regex","ASCII","test","current","Button","editDescTooltipContent_btn","variant","size","trim","_k","editDescBtn","color","endIcon","SVGLoader","src","EditIcon","width","height","paramDescContainer_separator","deleteParamBtn","DeleteIcon","handleDeleteResponseHeader","enum","_m","_o","join","isComplex","enumList","enumVal","enumIndex","Input","clearable","jsxs","PlusSquare","some","val","PlusIcon","handleDeleteClick","name","useEffect","in","parameters","_l","_p","_s","_q","_w","_u","_v","_y","_x","_z","_1","_0","_2","_4","_3","_6","_5","_9","_8","_7","_index","filter","_11","_10","_14","_12","_13","_17","_16","_15","_18","_19","_22","_20","_25","_24","_23","findIndex","_r","toString","clonedResponses","structuredClone","push","contentType","filteredArray","self","t","Accordion","expanded","methodAccordion","summary","methodSummaryContainer","methodSummary","methodColorMapping","methodLabel","methodPath","methodExpandArrowContainer","DownArrowIcon","methodAccordionContent","SimpleLabelValue","methodDesc","onClear","errorMsg","SelectGroup","i","options","list","isMultiple","withSearch","paramsTable","paramsTableBodyHead","ParamterTable","headCells","paramsTableHeaders","saveNewRow","values","isRequest","requestAccordion","requestAccordionSummary","requestAccordionSummary_title","JsonInput","acceptType","withFooter","fieldIsDisabled","requestBody","properties","onValidation","responseHeader","responseAccordion","responseAccordionSummary","responseAccordionSummary_title","currentResIndex","valid","CommonDialog","status","textAlign","fontWeight","fontSize","lineHeight","onSubmit","_","text","fullWidth","onCancel","onClose","open","icon","DeleteOutlinedIcon","closeIcon","CloseIcon","fromEntries","entries"],"mappings":"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"}
1
+ {"version":3,"file":"MethodAccordion.js","sources":["../../../../src/components/MethodAccordion/MethodAccordion.tsx"],"sourcesContent":["import { useEffect, useRef, useState } from 'react'\nimport { Accordion, Button, Input, SelectGroup, Switch, TextArea } from 'digitinary-ui'\nimport SVGLoader from '../../components/SVGLoader/SVGLoader'\nimport {\n DeleteIcon,\n DownArrowIcon,\n EditIcon,\n DeleteOutlinedIcon,\n CloseIcon,\n} from '../../assets/icons'\nimport PlusIcon from '../../assets/icons/Plus.svg'\nimport PlusSquare from '../../assets/icons/PlusSquare.svg'\nimport { httpStatusCodes, methodColorMapping, paramsTableHeaders } from '../../constants/index'\nimport Tooltip from '../../components/Tooltip/Tooltip'\nimport { TransformedMethod } from '../../types/layout.type'\nimport SimpleLabelValue from '../../components/SimpleLabelValue'\nimport { capitalize, handleStatusColor } from '../../helpers/methodAccordion.helper'\nimport ParamterTable from '../table/table'\nimport CommonDialog from '../../components/dialog'\nimport JsonInput from '../../components/JsonInput/JsonInput'\nimport styles from './MethodAccordion.module.scss'\nimport { Tags } from '@entities/openApi'\nimport regex from '../../constants/regex'\n\nconst httpStatusCodeOptions = httpStatusCodes.map((code) => ({\n label: (\n <div className={styles.statusCodeOptionContainer}>\n <div\n className={styles.statusCodeOptionCircle}\n style={{ backgroundColor: handleStatusColor(code) }}\n ></div>\n <span>{code}</span>\n </div>\n ),\n value: code,\n}))\n\nconst MethodsAccordion = ({\n method,\n path,\n setFieldValue,\n readOnly,\n tags,\n isOpen,\n setIsOpen,\n errors,\n}: {\n method: TransformedMethod\n path: string\n setFieldValue?: (key: string, value: string | string[]) => void\n readOnly?: boolean\n tags: Tags[]\n isOpen: boolean\n setIsOpen: (open: boolean) => void\n errors?: string\n}) => {\n const [isExpanded, setIsExpanded] = useState({\n request: false,\n response: false,\n method: false,\n })\n const [isFormOpen, setIsFormOpen] = useState<boolean>(false)\n const [isHeaderFormOpen, setIsHeaderFormOpen] = useState<boolean>(false)\n const [tooltipRefs, setTooltipRefs] = useState<{ [key: number]: any }>({})\n const [tableData, setTableData] = useState([])\n const [tableResponseData, setTableResponseData] = useState([])\n const [openDeleteDialog, setOpenDeleteDialog] = useState(false)\n const [openHeaderDeleteDialog, setOpenHeaderDeleteDialog] = useState(false)\n const [selectedParamIndex, setSelectedParamIndex] = useState<number | null>(null)\n const [selectedHeaderIndex, setSelectedHeaderIndex] = useState<number | null>(null)\n const [selectedParamName, setSelectedParamName] = useState<string | null>(null)\n const [tableRecords, setTableRecords] = useState()\n const [tableResponseRecords, setTableResponseRecords] = useState([])\n const [selectionTags, setSelectionTags] = useState([])\n const [selectedStatusCode, setSelectedStatusCode] = useState(httpStatusCodeOptions[4])\n const [enumFields, setEnumFields] = useState([])\n const [tooltipEnumRef, setTooltipEnumRef] = useState(null)\n const [currentResponseIndex, setCurrentResponseIndex] = useState<number>(-1)\n const currentResponse =\n method.responses.find((res) => Number(res.code) === selectedStatusCode.value) || '{}'\n const indexRef = useRef(-1)\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 generateResponseTableData = (headersObj: any, responseIndex: number) => {\n const headersByName = Object.keys(headersObj)\n return headersByName.map((item, index) => {\n const data = headersObj[item]\n return {\n id: `header_${index}`,\n paramName: item,\n paramType: capitalize('header'),\n schemaType: `${capitalize(data?.schema?.type) || ''} ${\n data?.schema?.type?.toLowerCase() == 'array' &&\n data?.schema?.items &&\n data?.schema?.items?.type\n ? ` _ ${capitalize(data?.schema?.items?.type)}`\n : ''\n }`,\n required: (\n <>\n {readOnly ? (\n data.required ? (\n 'True'\n ) : (\n 'False'\n )\n ) : (\n <Switch\n checked={data.required}\n onClick={() => {\n if (readOnly) {\n return null\n }\n setFieldValue(\n `responses[${responseIndex}].headers[${item}].required`,\n !data.required\n )\n }}\n />\n )}\n </>\n ),\n description: (\n <div className={styles.paramDescContainer}>\n <Tooltip\n key={`${index}-description`}\n allowHTML\n disabled={method.responses[responseIndex].headers[item].description?.length <= 12}\n content={\n <div style={{ padding: '0.625rem' }}>\n {method.responses[responseIndex].headers[item].description}\n </div>\n }\n arrowWithBorder\n placement=\"bottom-end\"\n type=\"function\"\n delay={[0, 0]}\n onShow={() => tooltipRefs[index]?.hide()}\n >\n <p style={{ alignSelf: 'center' }}>\n {method.responses[responseIndex].headers[item].description\n ? method.responses[responseIndex].headers[item].description.substring(0, 12)\n : readOnly && '-'}\n {method.responses[responseIndex].headers[item].description &&\n method.responses[responseIndex].headers[item].description.length > 12\n ? '...'\n : ''}\n </p>\n </Tooltip>\n {!readOnly && (\n <Tooltip\n key={`${index}-add-edit-description`}\n allowHTML\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 parameter...\"\n value={data.description}\n disabled={readOnly}\n maxLength={120}\n onChange={(value) => {\n if (value === '' || regex.ASCII.test(value)) {\n setFieldValue(\n `responses[${indexRef.current}].headers[${item}].description`,\n value\n )\n }\n }}\n />\n {!readOnly && (\n <Button\n className={styles.editDescTooltipContent_btn}\n variant=\"outlined\"\n size=\"small\"\n onClick={() => {\n setFieldValue(\n `responses[${responseIndex}].headers[${item}].description`,\n data.description?.trim()\n )\n tooltipRefs[index]?.hide()\n }}\n disabled={!data.description?.trim()}\n >\n Apply\n </Button>\n )}\n </div>\n }\n >\n {readOnly ||\n method.responses[responseIndex].headers[item].description?.length > 0 ? (\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 ? 'View ' : 'Add '} Description\n </Button>\n )}\n </Tooltip>\n )}\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={() => handleDeleteResponseHeader(index, item)}\n ></Button>\n )}\n </div>\n ),\n enum: (\n <>\n {readOnly ? (\n <span className=\"enumText\">{data?.schema?.enum?.join('/\\u200B')}</span>\n ) : (\n <div data-id=\"TEXT_DESCRIPTION\" className=\"tableData\">\n {(() => {\n const schema = method?.responses[currentResponseIndex]?.headers[item]?.schema\n const schemaType = schema?.type?.toLowerCase()\n const isComplex = schemaType === 'array' || schemaType === 'object'\n const enumList = schema?.enum || []\n\n if (!schema || isComplex) return '-'\n\n return (\n <Tooltip\n disabled={isComplex}\n arrowWithBorder\n placement=\"bottom-end\"\n type=\"function\"\n trigger=\"click\"\n delay={[0, 0]}\n onCreate={(instance) => setTooltipEnumRef(instance)}\n content={\n <div className={styles.editDescTooltipContent}>\n <p className={styles.editDescTooltipContent_header}>Enum</p>\n\n {enumList.map((enumVal, enumIndex) => (\n <Input\n key={enumIndex}\n className=\"methodDescForEnum\"\n required\n clearable={false}\n placeholder=\"Enter Enum value...\"\n value={enumVal}\n onChange={(value) => {\n setFieldValue(\n `responses[${currentResponseIndex}].headers[\"${item}\"].schema.enum[${enumIndex}]`,\n value\n )\n }}\n />\n ))}\n\n <p\n className=\"addEnumButton\"\n onClick={() => {\n setFieldValue(\n `responses[${currentResponseIndex}].headers[\"${item}\"].schema.enum`,\n [...enumList, '']\n )\n }}\n >\n <SVGLoader src={PlusSquare} />\n Add New Enum\n </p>\n\n {!readOnly && (\n <Button\n className={styles.editDescTooltipContent_btn}\n variant=\"outlined\"\n size=\"small\"\n type=\"button\"\n onClick={() => {\n setFieldValue(\n `responses[${currentResponseIndex}].headers[\"${item}\"].schema.enum`,\n [...enumList]\n )\n setEnumFields([])\n tooltipEnumRef?.hide()\n }}\n disabled={enumList.length === 0 || enumList.some((val) => !val)}\n >\n Apply\n </Button>\n )}\n </div>\n }\n >\n {enumList.length > 0 ? (\n <span className=\"enumText\">{enumList.join('/\\u200B')}</span>\n ) : (\n <Button\n className={styles.editDescBtn}\n id=\"EnumButton\"\n variant=\"link\"\n color=\"action\"\n endIcon={\n <SVGLoader\n id=\"enumIcon\"\n src={PlusIcon}\n width=\"1.5rem\"\n height=\"1.5rem\"\n />\n }\n >\n Add\n </Button>\n )}\n </Tooltip>\n )\n })()}\n </div>\n )}\n </>\n ),\n }\n })\n }\n\n const generateTableData = (items, isForRequest?: boolean) => {\n return items?.map((item, index) => {\n return {\n id: index,\n paramName: item.name,\n paramType: capitalize(item.in),\n schemaType: `${capitalize(item?.schema?.type) || ''} ${\n item?.schema?.type?.toLowerCase() == 'array' &&\n item?.schema?.items &&\n item?.schema?.items?.type\n ? ` _ ${capitalize(item?.schema?.items?.type)}`\n : ''\n }`,\n required: (\n <>\n {readOnly ? (\n item.required ? (\n 'True'\n ) : (\n 'False'\n )\n ) : (\n <Switch\n checked={item.required}\n onClick={() => {\n if (readOnly) {\n return null\n }\n onTableChange('required', !item.required, index)\n setFieldValue(`parameters[${index}][required]`, !item.required)\n }}\n />\n )}\n </>\n ),\n description: (\n <div className={styles.paramDescContainer}>\n <Tooltip\n key={`${index}-description`}\n allowHTML\n disabled={method.parameters[index].description?.length <= 12}\n content={\n <div style={{ padding: '0.625rem' }}>{method.parameters[index].description}</div>\n }\n arrowWithBorder\n placement=\"bottom-end\"\n type=\"function\"\n delay={[0, 0]}\n onShow={() => tooltipRefs[index]?.hide()}\n >\n <p style={{ alignSelf: 'center' }}>\n {method.parameters[index].description\n ? method.parameters[index].description.substring(0, 12)\n : readOnly && '-'}\n {method.parameters[index].description &&\n method.parameters[index].description.length > 12\n ? '...'\n : ''}\n </p>\n </Tooltip>\n {!readOnly && (\n <Tooltip\n key={`${index}-add-edit-description`}\n allowHTML\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 parameter...\"\n value={item.description}\n disabled={readOnly}\n maxLength={120}\n onChange={(value) => {\n if (value === '' || regex.ASCII.test(value))\n onTableChange('description', value, index)\n }}\n />\n {!readOnly && (\n <Button\n className={styles.editDescTooltipContent_btn}\n variant=\"outlined\"\n size=\"small\"\n onClick={() => {\n setFieldValue(\n `parameters[${index}].description`,\n item.description?.trim()\n )\n tooltipRefs[index]?.hide()\n }}\n disabled={!item.description?.trim()}\n >\n Apply\n </Button>\n )}\n </div>\n }\n >\n {readOnly || method.parameters[index].description?.length > 0 ? (\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 ? 'View ' : 'Add '} Description\n </Button>\n )}\n </Tooltip>\n )}\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 enum: (\n <>\n {readOnly ? (\n <span className=\"enumText\">{item?.schema?.enum?.join('/\\u200B')}</span>\n ) : (\n <div data-id=\"TEXT_DESCRIPTION\" className=\"tableData\">\n {method.parameters[index]?.schema &&\n method.parameters[index]?.schema?.type?.toLowerCase() != 'array' &&\n method.parameters[index]?.schema?.type?.toLowerCase() != 'object' ? (\n <Tooltip\n disabled={\n method.parameters[index]?.schema?.type?.toLowerCase() == 'array' ||\n method.parameters[index]?.schema?.type?.toLowerCase() == 'object'\n }\n arrowWithBorder\n placement=\"bottom-end\"\n type=\"function\"\n trigger=\"click\"\n delay={[0, 0]}\n onCreate={(instance) => setTooltipEnumRef(instance)}\n content={\n <div className={styles.editDescTooltipContent}>\n <p className={styles.editDescTooltipContent_header}>Enum</p>\n {!!method.parameters[index]?.schema?.enum &&\n !!method.parameters[index]?.schema?.enum.length &&\n method.parameters[index]?.schema?.enum?.map((item, _index) => (\n <Input\n key={index}\n className={'methodDescForEnum'}\n required\n clearable={false}\n placeholder=\"Enter Enum value...\"\n value={item}\n onChange={(value) => {\n setFieldValue(`parameters[${index}].schema.enum[${_index}]`, value)\n }}\n />\n ))}\n <p\n className={'addEnumButton'}\n onClick={() => {\n setFieldValue(`parameters[${index}].schema.enum`, [\n ...method.parameters[index]?.schema?.enum,\n '',\n ])\n }}\n >\n <SVGLoader src={PlusSquare} />\n Add New Enum\n </p>\n {!readOnly && (\n <Button\n className={styles.editDescTooltipContent_btn}\n variant=\"outlined\"\n size=\"small\"\n type=\"button\"\n onClick={() => {\n setFieldValue(`parameters[${index}].schema.enum`, [\n ...method.parameters[index].schema.enum,\n ])\n setEnumFields([])\n tooltipEnumRef?.hide()\n }}\n disabled={\n (enumFields.length > 0 &&\n enumFields?.filter((item) => !item).length) ||\n (method?.parameters[index]?.schema?.enum &&\n method?.parameters[index]?.schema?.enum?.length > 0 &&\n method?.parameters[index]?.schema?.enum?.filter((item) => !item)\n .length)\n }\n >\n Apply\n </Button>\n )}\n </div>\n }\n >\n {method.parameters[index]?.schema?.enum &&\n method.parameters[index]?.schema?.enum?.length > 0 ? (\n <span className={'enumText'}>\n {method.parameters[index]?.schema?.enum?.join('/\\u200B')}\n </span>\n ) : (\n <Button\n className={styles.editDescBtn}\n id=\"EnumButton\"\n variant=\"link\"\n color=\"action\"\n endIcon={\n <SVGLoader id=\"enumIcon\" src={PlusIcon} width=\"1.5rem\" height=\"1.5rem\" />\n }\n >\n Add\n </Button>\n )}\n </Tooltip>\n ) : (\n '-'\n )}{' '}\n </div>\n )}\n </>\n ),\n }\n })\n }\n\n const confirmDeleteParameter = () => {\n if (selectedParamIndex !== null) {\n setTableData((prev) => prev.filter((_, i) => i !== selectedParamIndex))\n setFieldValue(\n `parameters`,\n method?.parameters?.filter((_, i) => i !== selectedParamIndex)\n )\n }\n setOpenDeleteDialog(false)\n setSelectedParamIndex(null)\n }\n\n const confirmDeleteHeader = () => {\n if (setSelectedHeaderIndex !== null) {\n let headers = Object.fromEntries(\n Object.entries(method.responses[indexRef.current].headers).filter(\n ([key]) => key != selectedParamName\n )\n )\n setFieldValue(`responses[${indexRef.current}].headers`, headers)\n }\n setOpenHeaderDeleteDialog(false)\n setSelectedHeaderIndex(null)\n }\n\n const handleDeleteClick = (id: number, name: string) => {\n setSelectedParamIndex(id)\n setSelectedParamName(name)\n\n setOpenDeleteDialog(true)\n }\n\n const handleDeleteResponseHeader = (index, name) => {\n setSelectedHeaderIndex(index)\n setSelectedParamName(name)\n\n setOpenHeaderDeleteDialog(true)\n }\n\n const saveNewRow = (values) => {\n setTableData([...tableData, values])\n setFieldValue(`parameters`, [...method.parameters, values])\n }\n\n const saveNewResponseRow = (value) => {\n setFieldValue(`responses[${indexRef.current}].headers[${value.name}]`, value)\n }\n\n useEffect(() => {\n setTableRecords(generateTableData(tableData, true))\n }, [tableData])\n\n useEffect(() => {\n if (method?.parameters) {\n setTableData(method.parameters)\n }\n }, [method, path])\n\n useEffect(() => {\n if (selectedStatusCode && method.responses) {\n let responseIndex = method.responses.findIndex(\n (_r) => _r.code.toString() == selectedStatusCode.value.toString()\n )\n if (responseIndex < 0) {\n const clonedResponses = structuredClone(method.responses)\n\n clonedResponses.push({\n code: selectedStatusCode.value.toString(),\n content: {\n contentType: 'application/json',\n schema: {},\n },\n headers: {},\n })\n\n if (setFieldValue) {\n setFieldValue('responses', clonedResponses)\n responseIndex = 0\n }\n }\n setCurrentResponseIndex(responseIndex)\n indexRef.current = responseIndex\n if (responseIndex >= 0) {\n setTableResponseRecords(\n generateResponseTableData(method.responses[responseIndex].headers, responseIndex)\n )\n }\n }\n }, [selectedStatusCode, method.responses, setFieldValue])\n\n useEffect(() => {\n if (indexRef.current && indexRef.current > -1) {\n setTableResponseRecords(\n generateResponseTableData(method.responses[indexRef.current].headers, indexRef.current)\n )\n }\n }, [method.responses, indexRef.current])\n\n useEffect(() => {\n // prepare tags selection list\n if (method?.tags.length || tags?.length) {\n const convertedStringArray = (method?.tags || [])?.map((item) => ({\n label: capitalize(item),\n value: item,\n }))\n const mergedArray = [\n ...convertedStringArray,\n ...(tags || []).map((item) => ({ label: capitalize(item.name), value: item.name })),\n ]\n\n const filteredArray = mergedArray.filter(\n (value, index, self) => index === self.findIndex((t) => t.value === value.value)\n )\n\n setSelectionTags(filteredArray)\n }\n }, [tags, method])\n\n return (\n <div>\n <Accordion\n expanded={isOpen}\n onChange={() => setIsOpen(!isOpen)}\n className={`${styles.methodAccordion} ${readOnly ? styles.readOnly : ''}`}\n summary={\n <div className={styles.methodSummaryContainer}>\n <div className={styles.methodSummary}>\n <span\n style={{\n backgroundColor: methodColorMapping?.[method?.type]?.color || '#3A6CD1',\n }}\n className={styles.methodLabel}\n >\n {methodColorMapping?.[method?.type]?.label || method?.type}\n </span>\n <span className={styles.methodPath}>{path}</span>\n </div>\n <div\n className={`${styles.methodExpandArrowContainer} ${isOpen ? styles.expanded : ''}`}\n >\n <SVGLoader src={DownArrowIcon} width=\"2rem\" height=\"2rem\" />\n </div>\n </div>\n }\n children={\n <div className={styles.methodAccordionContent}>\n {!readOnly ? (\n <Input\n className={styles.methodDesc}\n label=\"Endpoint Name\"\n required\n placeholder=\"Endpoint name...\"\n value={method?.summary}\n onChange={(value) => {\n value = value || ''\n if (value === '' || regex.ASCII.test(value)) {\n setFieldValue('summary', value)\n }\n }}\n onClear={() => {\n setFieldValue('summary', '')\n }}\n errorMsg={errors?.summary}\n />\n ) : (\n <SimpleLabelValue\n key={'summary'}\n label={'Endpoint Name: '}\n value={method?.summary || '-'}\n />\n )}\n <SelectGroup\n className={styles.methodDesc}\n disabled={readOnly}\n placeholder=\"Select Tags\"\n label=\"Tags\"\n value={method.tags?.map((t) => ({\n label: capitalize(t),\n value: t,\n }))}\n onChange={(item) => {\n setFieldValue(\n 'tags',\n item.map((i) => i.value)\n )\n }}\n options={[\n {\n list: selectionTags,\n },\n ]}\n isMultiple={true}\n withSearch={false}\n clearable={false}\n />\n {!readOnly ? (\n <TextArea\n className={styles.methodDesc}\n label=\"Description\"\n placeholder=\"Describe the method's purpose and functionality...\"\n maxLength={120}\n value={method?.description}\n onChange={(value) => {\n if (value === '' || regex.ASCII.test(value)) setFieldValue('description', value)\n }}\n />\n ) : (\n <SimpleLabelValue\n key={'description'}\n label={'Description: '}\n value={method?.description || '-'}\n />\n )}\n <div className={styles.paramsTable}>\n <h4 className={styles.paramsTableBodyHead}>Request Details</h4>\n <ParamterTable\n id=\"paramter-request-table\"\n data={tableRecords}\n headCells={paramsTableHeaders}\n isFormOpen={isFormOpen}\n setIsFormOpen={setIsFormOpen}\n saveNewRow={saveNewRow}\n readOnly={readOnly}\n isRequest={true}\n />\n {method?.type !== 'get' && method?.type !== 'delete' && (\n <Accordion\n expanded={isExpanded.request}\n onChange={() => null}\n className={styles.requestAccordion}\n summary={\n <span className={styles.requestAccordionSummary}>\n <div\n className={styles.requestAccordionSummary_title}\n onClick={() =>\n setIsExpanded((prev) => ({\n ...prev,\n request: !prev.request,\n }))\n }\n >\n <SVGLoader\n className={isExpanded.request ? styles.expanded : ''}\n src={DownArrowIcon}\n width=\"2rem\"\n height=\"2rem\"\n />\n Request\n {method?.type !== 'delete' && <span style={{ color: 'red' }}>*</span>}\n </div>\n </span>\n }\n children={\n <JsonInput\n acceptType=\"JSON\"\n withFooter={!readOnly}\n className={'jsonField'}\n placeholder=\"Enter your request body as a JSON object....\"\n fieldIsDisabled={readOnly}\n value={method?.requestBody?.content?.schema?.properties || '{}'}\n onChange={(value: string) => {\n setFieldValue('requestBody.content.schema.properties', value)\n }}\n onValidation={() => null}\n />\n }\n />\n )}\n </div>\n <div className={styles.paramsTable}>\n <div className={styles.responseHeader}>\n <h4 className={styles.paramsTableBodyHead}>Response Details</h4>\n <SelectGroup\n withSearch={false}\n isMultiple={false}\n clearable={false}\n placeholder=\"200\"\n options={[\n {\n list: httpStatusCodeOptions,\n },\n ]}\n value={selectedStatusCode}\n onChange={(value) => {\n setSelectedStatusCode(value)\n }}\n />\n </div>\n <ParamterTable\n id=\"paramter-response-table\"\n data={tableResponseRecords}\n headCells={paramsTableHeaders}\n isFormOpen={isHeaderFormOpen}\n setIsFormOpen={setIsHeaderFormOpen}\n saveNewRow={saveNewResponseRow}\n readOnly={readOnly}\n isRequest={false}\n />\n <Accordion\n expanded={isExpanded.response}\n onChange={() => null}\n className={styles.responseAccordion}\n summary={\n <span className={styles.responseAccordionSummary}>\n <div\n className={styles.responseAccordionSummary_title}\n onClick={() =>\n setIsExpanded((prev) => ({\n ...prev,\n response: !prev.response,\n }))\n }\n >\n <SVGLoader\n className={isExpanded.response ? styles.expanded : ''}\n src={DownArrowIcon}\n width=\"2rem\"\n height=\"2rem\"\n />\n Response<span style={{ color: 'red' }}>*</span>\n </div>\n </span>\n }\n children={\n <JsonInput\n acceptType=\"JSON\"\n withFooter={!readOnly}\n className={'jsonField'}\n placeholder=\"Enter your response as a JSON object...\"\n fieldIsDisabled={readOnly}\n value={currentResponse?.content?.schema?.properties || '{}'}\n onChange={(value) => {\n const currentResIndex = method.responses.findIndex(\n (res) => res.code === currentResponse.code\n )\n if (currentResIndex !== -1) {\n setFieldValue(\n `responses[${currentResIndex}].content.schema.properties`,\n value\n )\n } else {\n const clonedResponses = structuredClone(method.responses)\n\n clonedResponses.push({\n code: selectedStatusCode.value.toString(),\n content: {\n contentType: 'application/json',\n schema: {\n type: 'object',\n properties: value,\n },\n },\n })\n\n setFieldValue('responses', clonedResponses)\n }\n }}\n onValidation={(valid) => null}\n />\n }\n />\n </div>\n </div>\n }\n />\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 Parameter <strong>{selectedParamName}</strong>\n </span>\n ?\n </p>\n }\n onSubmit={{\n onClick: confirmDeleteParameter,\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 closeIcon={\n <SVGLoader\n src={CloseIcon}\n width=\"1.5rem\"\n height=\"1.5rem\"\n onClick={() => setOpenDeleteDialog(false)}\n />\n }\n />\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 Header <strong>{selectedParamName}</strong>\n </span>\n ?\n </p>\n }\n onSubmit={{\n onClick: confirmDeleteHeader,\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={() => setOpenHeaderDeleteDialog(false)}\n open={openHeaderDeleteDialog}\n icon={<SVGLoader src={DeleteOutlinedIcon} width=\"4.0625rem\" height=\"4.0625rem\" />}\n closeIcon={\n <SVGLoader\n src={CloseIcon}\n width=\"1.5rem\"\n height=\"1.5rem\"\n onClick={() => setOpenDeleteDialog(false)}\n />\n }\n />\n </div>\n )\n}\n\nexport default MethodsAccordion\n"],"names":["httpStatusCodeOptions","httpStatusCodes","map","code","label","_jsxs","className","styles","statusCodeOptionContainer","children","_jsx","statusCodeOptionCircle","style","backgroundColor","handleStatusColor","value","MethodsAccordion","method","path","setFieldValue","readOnly","tags","isOpen","setIsOpen","errors","isExpanded","setIsExpanded","useState","request","response","isFormOpen","setIsFormOpen","isHeaderFormOpen","setIsHeaderFormOpen","tooltipRefs","setTooltipRefs","tableData","setTableData","openDeleteDialog","setOpenDeleteDialog","openHeaderDeleteDialog","setOpenHeaderDeleteDialog","selectedParamIndex","setSelectedParamIndex","selectedHeaderIndex","setSelectedHeaderIndex","selectedParamName","setSelectedParamName","tableRecords","setTableRecords","tableResponseRecords","setTableResponseRecords","selectionTags","setSelectionTags","selectedStatusCode","setSelectedStatusCode","enumFields","setEnumFields","tooltipEnumRef","setTooltipEnumRef","currentResponseIndex","setCurrentResponseIndex","currentResponse","responses","find","res","Number","indexRef","useRef","onTableChange","key","index","newTableData","item","tIndex","Object","assign","generateResponseTableData","headersObj","responseIndex","keys","data","id","paramName","paramType","capitalize","schemaType","schema","_a","type","_c","_b","toLowerCase","_d","items","_f","_e","_h","_g","required","jsx","_Fragment","Switch","checked","onClick","description","paramDescContainer","Tooltip","allowHTML","disabled","_j","headers","length","content","padding","arrowWithBorder","placement","delay","onShow","hide","alignSelf","substring","trigger","onCreate","instance","prev","editDescTooltipContent","editDescTooltipContent_header","TextArea","placeholder","maxLength","onChange","regex","ASCII","test","current","Button","editDescTooltipContent_btn","variant","size","trim","_k","editDescBtn","color","endIcon","SVGLoader","src","EditIcon","width","height","paramDescContainer_separator","deleteParamBtn","DeleteIcon","handleDeleteResponseHeader","enum","_m","_o","join","isComplex","enumList","enumVal","enumIndex","Input","clearable","jsxs","PlusSquare","some","val","PlusIcon","handleDeleteClick","name","useEffect","in","parameters","_l","_p","_s","_q","_w","_u","_v","_y","_x","_z","_1","_0","_2","_4","_3","_6","_5","_9","_8","_7","_index","filter","_11","_10","_14","_12","_13","_17","_16","_15","_18","_19","_22","_20","_25","_24","_23","findIndex","_r","toString","clonedResponses","structuredClone","push","contentType","filteredArray","self","t","Accordion","expanded","methodAccordion","summary","methodSummaryContainer","methodSummary","methodColorMapping","methodLabel","methodPath","methodExpandArrowContainer","DownArrowIcon","methodAccordionContent","SimpleLabelValue","methodDesc","onClear","errorMsg","SelectGroup","i","options","list","isMultiple","withSearch","paramsTable","paramsTableBodyHead","ParamterTable","headCells","paramsTableHeaders","saveNewRow","values","isRequest","requestAccordion","requestAccordionSummary","requestAccordionSummary_title","JsonInput","acceptType","withFooter","fieldIsDisabled","requestBody","properties","onValidation","responseHeader","responseAccordion","responseAccordionSummary","responseAccordionSummary_title","currentResIndex","valid","CommonDialog","status","textAlign","fontWeight","fontSize","lineHeight","onSubmit","_","text","fullWidth","onCancel","onClose","open","icon","DeleteOutlinedIcon","closeIcon","CloseIcon","fromEntries","entries"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"SVGLoader.js","sources":["../../../../src/components/SVGLoader/SVGLoader.tsx"],"sourcesContent":["import React, { useState, useEffect } from 'react'\nimport parse from 'html-react-parser'\n\n// Utility function to create an SVG element from a string\nconst createSvgElement = (svgString: string): SVGSVGElement | null => {\n const parser = new DOMParser()\n const doc = parser.parseFromString(svgString, 'image/svg+xml')\n return doc.querySelector('svg')\n}\n\n// Define the type for SVG attributes\ntype SVGAttributes = React.SVGProps<SVGSVGElement>\n\ninterface SVGLoaderProps extends SVGAttributes {\n src: string\n cache?: boolean\n}\n\nconst SVGLoader: React.FC<SVGLoaderProps> | any = ({ src, cache = true, ...props }) => {\n const [svgMarkup, setSvgMarkup] = useState<string | null>(null)\n\n useEffect(() => {\n if (!src) return\n if (typeof src !== 'string') console.log({ src })\n const isUrl = src.startsWith('http') || src.startsWith('/')\n\n const cacheName = 'svg-cache'\n\n const fetchSvg = async () => {\n try {\n let svgString: string | null = null\n\n // Use the Cache API if caching is enabled\n if (cache && isUrl && 'caches' in window) {\n const cacheStorage = await caches.open(cacheName)\n const cachedResponse = await cacheStorage.match(src)\n\n // If SVG is found in cache, use it\n if (cachedResponse && cachedResponse.ok) {\n svgString = await cachedResponse.text()\n setSvgMarkup(svgString)\n return\n }\n }\n\n // If not cached, fetch from URL\n if (isUrl) {\n const response = await fetch(src)\n\n // Clone the response before consuming it\n const responseClone = response.clone()\n\n // Consume the response body for the SVG content\n svgString = await response.text()\n\n // Store the cloned response in the cache\n if (cache && 'caches' in window) {\n const cacheStorage = await caches.open(cacheName)\n await cacheStorage.put(src, responseClone)\n }\n } else {\n // If it's not a URL (it's inline), just use the source string\n svgString = src\n }\n\n // If we have valid SVG content, set it\n if (svgString) {\n const svg = createSvgElement(svgString)\n if (svg) {\n const svgStringWithProps = new XMLSerializer().serializeToString(svg)\n setSvgMarkup(svgStringWithProps)\n }\n }\n } catch (error) {\n console.error('Error loading SVG:', error)\n }\n }\n\n fetchSvg()\n }, [src, props])\n\n if (!svgMarkup) return null\n\n // Parse the SVG string and return it as JSX\n const parsedSvg = parse(svgMarkup)\n // Sometimes parse returns an array which includes the element\n const toBeClonedElement = Array.isArray(parsedSvg)\n ? parsedSvg.find((item) => React.isValidElement(item))\n : parsedSvg\n // Clone the parsed SVG element to apply the props\n const clonedSvg = React.cloneElement(toBeClonedElement as React.ReactElement, props)\n\n return <>{clonedSvg}</>\n}\n\nexport default SVGLoader\n"],"names":["SVGLoader","_a","src","cache","props","__rest","svgMarkup","setSvgMarkup","useState","useEffect","console","log","isUrl","startsWith","cacheName","__awaiter","svgString","window","cacheStorage","caches","open","cachedResponse","match","ok","text","response","fetch","responseClone","clone","put","svg","DOMParser","parseFromString","querySelector","createSvgElement","svgStringWithProps","XMLSerializer","serializeToString","error","parsedSvg","parse","toBeClonedElement","Array","isArray","find","item","React","isValidElement","clonedSvg","cloneElement","_jsx","jsx","_Fragment","Fragment","children"],"mappings":"iQAIA,MAcMA,EAA6CC,QAAAC,IAAEA,EAAGC,MAAEA,GAAQ,KAASC,EAAxBC,EAAAJ,EAAA,CAAA,MAAA,UACjD,MAAOK,EAAWC,GAAgBC,EAAwB,MA8D1D,GA5DAC,GAAU,KACR,IAAKP,EAAK,OACS,iBAARA,GAAkBQ,QAAQC,IAAI,CAAET,QAC3C,MAAMU,EAAQV,EAAIW,WAAW,SAAWX,EAAIW,WAAW,KAEjDC,EAAY,YAEUC,OAAA,OAAA,OAAA,GAAA,YAC1B,IACE,IAAIC,EAA2B,KAG/B,GAAIb,GAASS,GAAS,WAAYK,OAAQ,CACxC,MAAMC,QAAqBC,OAAOC,KAAKN,GACjCO,QAAuBH,EAAaI,MAAMpB,GAGhD,GAAImB,GAAkBA,EAAeE,GAGnC,OAFAP,QAAkBK,EAAeG,YACjCjB,EAAaS,EAGhB,CAGD,GAAIJ,EAAO,CACT,MAAMa,QAAiBC,MAAMxB,GAGvByB,EAAgBF,EAASG,QAM/B,GAHAZ,QAAkBS,EAASD,OAGvBrB,GAAS,WAAYc,OAAQ,CAC/B,MAAMC,QAAqBC,OAAOC,KAAKN,SACjCI,EAAaW,IAAI3B,EAAKyB,EAC7B,CACF,MAECX,EAAYd,EAId,GAAIc,EAAW,CACb,MAAMc,EA/DS,CAACd,IACT,IAAIe,WACAC,gBAAgBhB,EAAW,iBACnCiB,cAAc,OA4DLC,CAAiBlB,GAC7B,GAAIc,EAAK,CACP,MAAMK,GAAqB,IAAIC,eAAgBC,kBAAkBP,GACjEvB,EAAa4B,EACd,CACF,CACF,CAAC,MAAOG,GACP5B,QAAQ4B,MAAM,qBAAsBA,EACrC,CACH,GAEU,GACT,CAACpC,EAAKE,KAEJE,EAAW,OAAO,KAGvB,MAAMiC,EAAYC,EAAMlC,GAElBmC,EAAoBC,MAAMC,QAAQJ,GACpCA,EAAUK,MAAMC,GAASC,EAAMC,eAAeF,KAC9CN,EAEES,EAAYF,EAAMG,aAAaR,EAAyCrC,GAE9E,OAAO8C,EAAAC,IAAAC,EAAAC,SAAA,CAAAC,SAAGN,GAAa"}
1
+ {"version":3,"file":"SVGLoader.js","sources":["../../../../src/components/SVGLoader/SVGLoader.tsx"],"sourcesContent":["import React, { useState, useEffect } from 'react'\nimport parse from 'html-react-parser'\n\n// Utility function to create an SVG element from a string\nconst createSvgElement = (svgString: string): SVGSVGElement | null => {\n const parser = new DOMParser()\n const doc = parser.parseFromString(svgString, 'image/svg+xml')\n return doc.querySelector('svg')\n}\n\n// Define the type for SVG attributes\ntype SVGAttributes = React.SVGProps<SVGSVGElement>\n\ninterface SVGLoaderProps extends SVGAttributes {\n src: string\n cache?: boolean\n}\n\nconst SVGLoader: React.FC<SVGLoaderProps> | any = ({ src, cache = true, ...props }) => {\n const [svgMarkup, setSvgMarkup] = useState<string | null>(null)\n\n useEffect(() => {\n if (!src) return\n if (typeof src !== 'string') console.log({ src })\n const isUrl = src.startsWith('http') || src.startsWith('/')\n\n const cacheName = 'svg-cache'\n\n const fetchSvg = async () => {\n try {\n let svgString: string | null = null\n\n // Use the Cache API if caching is enabled\n if (cache && isUrl && 'caches' in window) {\n const cacheStorage = await caches.open(cacheName)\n const cachedResponse = await cacheStorage.match(src)\n\n // If SVG is found in cache, use it\n if (cachedResponse && cachedResponse.ok) {\n svgString = await cachedResponse.text()\n setSvgMarkup(svgString)\n return\n }\n }\n\n // If not cached, fetch from URL\n if (isUrl) {\n const response = await fetch(src)\n\n // Clone the response before consuming it\n const responseClone = response.clone()\n\n // Consume the response body for the SVG content\n svgString = await response.text()\n\n // Store the cloned response in the cache\n if (cache && 'caches' in window) {\n const cacheStorage = await caches.open(cacheName)\n await cacheStorage.put(src, responseClone)\n }\n } else {\n // If it's not a URL (it's inline), just use the source string\n svgString = src\n }\n\n // If we have valid SVG content, set it\n if (svgString) {\n const svg = createSvgElement(svgString)\n if (svg) {\n const svgStringWithProps = new XMLSerializer().serializeToString(svg)\n setSvgMarkup(svgStringWithProps)\n }\n }\n } catch (error) {\n console.error('Error loading SVG:', error)\n }\n }\n\n fetchSvg()\n }, [src, props])\n\n if (!svgMarkup) return null\n\n // Parse the SVG string and return it as JSX\n const parsedSvg = parse(svgMarkup)\n // Sometimes parse returns an array which includes the element\n const toBeClonedElement = Array.isArray(parsedSvg)\n ? parsedSvg.find((item) => React.isValidElement(item))\n : parsedSvg\n // Clone the parsed SVG element to apply the props\n const clonedSvg = React.cloneElement(toBeClonedElement as React.ReactElement, props)\n\n return <>{clonedSvg}</>\n}\n\nexport default SVGLoader\n"],"names":["SVGLoader","_a","src","cache","props","__rest","svgMarkup","setSvgMarkup","useState","useEffect","console","log","isUrl","startsWith","cacheName","__awaiter","svgString","window","cacheStorage","caches","open","cachedResponse","match","ok","text","response","fetch","responseClone","clone","put","svg","DOMParser","parseFromString","querySelector","createSvgElement","svgStringWithProps","XMLSerializer","serializeToString","error","parsedSvg","parse","toBeClonedElement","Array","isArray","find","item","React","isValidElement","clonedSvg","cloneElement","_jsx","jsx","_Fragment","Fragment","children"],"mappings":"iQAIA,MAcMA,EAA6CC,QAAAC,IAAEA,EAAGC,MAAEA,GAAQ,KAASC,EAAxBC,EAAAJ,EAAA,CAAA,MAAA,UACjD,MAAOK,EAAWC,GAAgBC,EAAwB,MA8D1D,GA5DAC,GAAU,KACR,IAAKP,EAAK,OACS,iBAARA,GAAkBQ,QAAQC,IAAI,CAAET,QAC3C,MAAMU,EAAQV,EAAIW,WAAW,SAAWX,EAAIW,WAAW,KAEjDC,EAAY,YAEUC,OAAA,OAAA,OAAA,GAAA,YAC1B,IACE,IAAIC,EAA2B,KAG/B,GAAIb,GAASS,GAAS,WAAYK,OAAQ,CACxC,MAAMC,QAAqBC,OAAOC,KAAKN,GACjCO,QAAuBH,EAAaI,MAAMpB,GAGhD,GAAImB,GAAkBA,EAAeE,GAGnC,OAFAP,QAAkBK,EAAeG,YACjCjB,EAAaS,EAGhB,CAGD,GAAIJ,EAAO,CACT,MAAMa,QAAiBC,MAAMxB,GAGvByB,EAAgBF,EAASG,QAM/B,GAHAZ,QAAkBS,EAASD,OAGvBrB,GAAS,WAAYc,OAAQ,CAC/B,MAAMC,QAAqBC,OAAOC,KAAKN,SACjCI,EAAaW,IAAI3B,EAAKyB,EAC7B,CACF,MAECX,EAAYd,EAId,GAAIc,EAAW,CACb,MAAMc,EA/DS,CAACd,IACT,IAAIe,WACAC,gBAAgBhB,EAAW,iBACnCiB,cAAc,OA4DLC,CAAiBlB,GAC7B,GAAIc,EAAK,CACP,MAAMK,GAAqB,IAAIC,eAAgBC,kBAAkBP,GACjEvB,EAAa4B,EACd,CACF,CACF,CAAC,MAAOG,GACP5B,QAAQ4B,MAAM,qBAAsBA,EACrC,CACH,MAGC,CAACpC,EAAKE,KAEJE,EAAW,OAAO,KAGvB,MAAMiC,EAAYC,EAAMlC,GAElBmC,EAAoBC,MAAMC,QAAQJ,GACpCA,EAAUK,MAAMC,GAASC,EAAMC,eAAeF,KAC9CN,EAEES,EAAYF,EAAMG,aAAaR,EAAyCrC,GAE9E,OAAO8C,EAAAC,IAAAC,EAAAC,SAAA,CAAAC,SAAGN"}
@@ -1 +1 @@
1
- {"version":3,"file":"SectionHead.js","sources":["../../../../src/components/SectionHead/SectionHead.tsx"],"sourcesContent":["import React, { type JSX } from 'react'\nimport './SectionHead.scss'\nimport SVGLoader from '../SVGLoader/SVGLoader'\n\ntype SectionHeadProps = {\n text: string | JSX.Element\n closeFunction?: () => void\n children?: JSX.Element\n className?: string\n}\n\nconst SectionHead: React.FC<SectionHeadProps> = ({ text, closeFunction, children, className = '' }: SectionHeadProps): any => {\n return (\n <div className={`containerTitleDrawer ${className}`}>\n <span data-id={`${String(text)?.toUpperCase()?.replaceAll(' ', '_')}_ID`}>{text}</span>\n {children}\n\n {closeFunction && <SVGLoader className='closeIcon' onClick={closeFunction} width='1.5rem' height='1.5rem' />}\n </div>\n )\n}\nexport default SectionHead\n"],"names":["SectionHead","text","closeFunction","children","className","_jsxs","jsxs","_jsx","_b","_a","String","toUpperCase","replaceAll","SVGLoader","onClick","width","height"],"mappings":"8FAWA,MAAMA,EAA0C,EAAGC,OAAMC,gBAAeC,WAAUC,YAAY,eAC5F,OACEC,EAAKC,KAAA,MAAA,CAAAF,UAAW,wBAAwBA,IACtCD,SAAA,CAAAI,EAAAA,IAAA,OAAA,CAAA,UAAe,GAA8B,QAA3BC,EAAc,QAAdC,EAAAC,OAAOT,UAAO,IAAAQ,OAAA,EAAAA,EAAAE,qBAAa,IAAAH,OAAA,EAAAA,EAAEI,WAAW,IAAK,UAAST,SAAGF,IAC1EE,EAEAD,GAAiBK,EAAAA,IAACM,EAAU,CAAAT,UAAU,YAAYU,QAASZ,EAAea,MAAM,SAASC,OAAO,aAEpG"}
1
+ {"version":3,"file":"SectionHead.js","sources":["../../../../src/components/SectionHead/SectionHead.tsx"],"sourcesContent":["import React, { type JSX } from 'react'\nimport './SectionHead.scss'\nimport SVGLoader from '../SVGLoader/SVGLoader'\n\ntype SectionHeadProps = {\n text: string | JSX.Element\n closeFunction?: () => void\n children?: JSX.Element\n className?: string\n}\n\nconst SectionHead: React.FC<SectionHeadProps> = ({ text, closeFunction, children, className = '' }: SectionHeadProps): any => {\n return (\n <div className={`containerTitleDrawer ${className}`}>\n <span data-id={`${String(text)?.toUpperCase()?.replaceAll(' ', '_')}_ID`}>{text}</span>\n {children}\n\n {closeFunction && <SVGLoader className='closeIcon' onClick={closeFunction} width='1.5rem' height='1.5rem' />}\n </div>\n )\n}\nexport default SectionHead\n"],"names":["SectionHead","text","closeFunction","children","className","_jsxs","jsxs","_jsx","_b","_a","String","toUpperCase","replaceAll","SVGLoader","onClick","width","height"],"mappings":"8FAWA,MAAMA,EAA0C,EAAGC,OAAMC,gBAAeC,WAAUC,YAAY,eAC5F,OACEC,EAAKC,KAAA,MAAA,CAAAF,UAAW,wBAAwBA,IACtCD,SAAA,CAAAI,EAAAA,IAAA,OAAA,CAAA,UAAe,GAA8B,QAA3BC,EAAc,QAAdC,EAAAC,OAAOT,UAAO,IAAAQ,OAAA,EAAAA,EAAAE,qBAAa,IAAAH,OAAA,EAAAA,EAAEI,WAAW,IAAK,UAAST,SAAGF,IAC1EE,EAEAD,GAAiBK,EAAAA,IAACM,EAAU,CAAAT,UAAU,YAAYU,QAASZ,EAAea,MAAM,SAASC,OAAO"}
@@ -1 +1 @@
1
- {"version":3,"file":"SimpleLabelValue.js","sources":["../../../../src/components/SimpleLabelValue/SimpleLabelValue.tsx"],"sourcesContent":["import React from 'react'\nimport './style.scss'\n\ntype SimpleLabelValueProps = {\n label?: string | JSX.Element\n value?: string | number | JSX.Element | JSX.Element[]\n color?: string\n className?: string\n dataId?: string\n}\n\nconst SimpleLabelValue: React.FC<SimpleLabelValueProps> = ({\n label,\n value,\n color,\n className = '',\n dataId,\n}: SimpleLabelValueProps) => {\n const dataIdLabel =\n typeof label === 'string' ? label?.toUpperCase()?.replaceAll(' ', '_') + '_LABEL_ID' : dataId\n return (\n <div className={`drawerItemContainer ${className}`}>\n <span className=\"title\" data-id={dataIdLabel}>\n {label}\n </span>\n <span className={`text ${color ? `color-${color}` : ''}`}>{value}</span>\n </div>\n )\n}\n\nexport default SimpleLabelValue\n"],"names":["SimpleLabelValue","label","value","color","className","dataId","dataIdLabel","_a","toUpperCase","replaceAll","_jsxs","children","_jsx","jsx"],"mappings":"qDAWA,MAAMA,EAAoD,EACxDC,QACAC,QACAC,QACAC,YAAY,GACZC,mBAEA,MAAMC,EACa,iBAAVL,GAAyC,QAApBM,EAAAN,aAAA,EAAAA,EAAOO,qBAAa,IAAAD,OAAA,EAAAA,EAAEE,WAAW,IAAK,MAAO,YAAcJ,EACzF,OACEK,EAAAA,KAAK,MAAA,CAAAN,UAAW,uBAAuBA,IAAWO,SAAA,CAChDC,EAAMC,IAAA,OAAA,CAAAT,UAAU,QAAO,UAAUE,EAC9BK,SAAAV,IAEHW,EAAAA,IAAA,OAAA,CAAMR,UAAW,SAAQD,EAAQ,SAASA,IAAU,IAAIQ,SAAGT,MAE9D"}
1
+ {"version":3,"file":"SimpleLabelValue.js","sources":["../../../../src/components/SimpleLabelValue/SimpleLabelValue.tsx"],"sourcesContent":["import React from 'react'\nimport './style.scss'\n\ntype SimpleLabelValueProps = {\n label?: string | JSX.Element\n value?: string | number | JSX.Element | JSX.Element[]\n color?: string\n className?: string\n dataId?: string\n}\n\nconst SimpleLabelValue: React.FC<SimpleLabelValueProps> = ({\n label,\n value,\n color,\n className = '',\n dataId,\n}: SimpleLabelValueProps) => {\n const dataIdLabel =\n typeof label === 'string' ? label?.toUpperCase()?.replaceAll(' ', '_') + '_LABEL_ID' : dataId\n return (\n <div className={`drawerItemContainer ${className}`}>\n <span className=\"title\" data-id={dataIdLabel}>\n {label}\n </span>\n <span className={`text ${color ? `color-${color}` : ''}`}>{value}</span>\n </div>\n )\n}\n\nexport default SimpleLabelValue\n"],"names":["SimpleLabelValue","label","value","color","className","dataId","dataIdLabel","_a","toUpperCase","replaceAll","_jsxs","children","_jsx","jsx"],"mappings":"qDAWA,MAAMA,EAAoD,EACxDC,QACAC,QACAC,QACAC,YAAY,GACZC,mBAEA,MAAMC,EACa,iBAAVL,GAAyC,QAApBM,EAAAN,aAAA,EAAAA,EAAOO,qBAAa,IAAAD,OAAA,EAAAA,EAAEE,WAAW,IAAK,MAAO,YAAcJ,EACzF,OACEK,EAAAA,KAAK,MAAA,CAAAN,UAAW,uBAAuBA,IAAWO,SAAA,CAChDC,EAAMC,IAAA,OAAA,CAAAT,UAAU,QAAO,UAAUE,EAC9BK,SAAAV,IAEHW,EAAAA,IAAA,OAAA,CAAMR,UAAW,SAAQD,EAAQ,SAASA,IAAU,IAAIQ,SAAGT"}
@@ -1 +1 @@
1
- {"version":3,"file":"Tooltip.js","sources":["../../../../src/components/Tooltip/Tooltip.tsx"],"sourcesContent":["import React, { useState, useEffect, ReactNode } from 'react'\nimport Tippy, { TippyProps } from '@tippyjs/react'\nimport 'tippy.js/dist/tippy.css'\nimport './Tooltip.scss'\n\ninterface TooltipProps extends TippyProps {\n content: ReactNode\n success?: boolean\n onMouseEnter?: (event: React.MouseEvent<HTMLDivElement>) => void\n onMouseLeave?: (event: React.MouseEvent<HTMLDivElement>) => void\n visible?: boolean\n delay?: [number, number]\n type?: 'info' | 'function'\n maxWidth?: number\n className?: string\n arrowWithBorder?: boolean\n disabled?: boolean\n}\n\nconst Tooltip: React.FC<TooltipProps> = ({\n children,\n content,\n success,\n onMouseEnter,\n onMouseLeave,\n visible,\n delay = [200, 400],\n type = 'info',\n maxWidth = 390,\n className,\n arrowWithBorder,\n disabled,\n ...props\n}) => {\n const [rootFontSize, setRootFontSize] = useState(16)\n\n useEffect(() => {\n const handleFontSizeChange = (fontSize: number) => {\n setRootFontSize((prev) => (prev !== fontSize ? fontSize : prev))\n }\n\n if (\n // @ts-ignore - Ignoring if `applicationUIScaling` doesn't exist\n window.applicationUIScaling &&\n // @ts-ignore - Ignoring if `applicationUIScaling` doesn't exist\n typeof window.applicationUIScaling.addEventHandler === 'function'\n ) {\n // @ts-ignore - Ignoring if `applicationUIScaling` doesn't exist\n window.applicationUIScaling.addEventHandler(handleFontSizeChange)\n }\n }, [])\n\n return (\n <Tippy\n visible={visible}\n allowHTML={typeof content !== 'string'}\n interactive\n maxWidth={(maxWidth / 16) * rootFontSize}\n delay={delay}\n content={content}\n placement=\"bottom-start\"\n className={`${success ? 'success' : ''} ${type} ${className || ''} ${\n arrowWithBorder ? 'arrow-with-border' : ''\n }`}\n disabled={disabled}\n {...props}\n >\n <div\n className=\"tooltip-custom-wrapper\"\n onMouseEnter={onMouseEnter}\n onMouseLeave={onMouseLeave}\n >\n <div\n className=\"tooltip-custom-wrapper\"\n onMouseEnter={onMouseEnter}\n onMouseLeave={onMouseLeave}\n >\n {children}\n </div>\n </div>\n </Tippy>\n )\n}\n\nexport default Tooltip\n"],"names":["Tooltip","_a","children","content","success","onMouseEnter","onMouseLeave","visible","delay","type","maxWidth","className","arrowWithBorder","disabled","props","__rest","rootFontSize","setRootFontSize","useState","useEffect","handleFontSizeChange","fontSize","prev","window","applicationUIScaling","addEventHandler","_jsx","Tippy","Object","assign","allowHTML","interactive","placement"],"mappings":"4SAmBA,MAAMA,EAAmCC,IAAA,IAAAC,SACvCA,EAAQC,QACRA,EAAOC,QACPA,EAAOC,aACPA,EAAYC,aACZA,EAAYC,QACZA,EAAOC,MACPA,EAAQ,CAAC,IAAK,KAAIC,KAClBA,EAAO,OAAMC,SACbA,EAAW,IAAGC,UACdA,EAASC,gBACTA,EAAeC,SACfA,GAAQZ,EACLa,EAAKC,EAAAd,EAb+B,6IAevC,MAAOe,EAAcC,GAAmBC,EAAS,IAkBjD,OAhBAC,GAAU,KACR,MAAMC,EAAwBC,IAC5BJ,GAAiBK,GAAUA,IAASD,EAAWA,EAAWC,GAAM,EAKhEC,OAAOC,sBAEgD,mBAAhDD,OAAOC,qBAAqBC,iBAGnCF,OAAOC,qBAAqBC,gBAAgBL,EAC7C,GACA,IAGDM,EAAAA,IAACC,EAAKC,OAAAC,OAAA,CACJtB,QAASA,EACTuB,UAA8B,iBAAZ3B,EAClB4B,aACA,EAAArB,SAAWA,EAAW,GAAMM,EAC5BR,MAAOA,EACPL,QAASA,EACT6B,UAAU,eACVrB,UAAW,GAAGP,EAAU,UAAY,MAAMK,KAAQE,GAAa,MAC7DC,EAAkB,oBAAsB,KAE1CC,SAAUA,GACNC,EAEJ,CAAAZ,SAAAwB,EAAAA,IAAA,MAAA,CACEf,UAAU,yBACVN,aAAcA,EACdC,aAAcA,WAEdoB,EAAAA,IACE,MAAA,CAAAf,UAAU,yBACVN,aAAcA,EACdC,aAAcA,EAAYJ,SAEzBA,QAIR"}
1
+ {"version":3,"file":"Tooltip.js","sources":["../../../../src/components/Tooltip/Tooltip.tsx"],"sourcesContent":["import React, { useState, useEffect, ReactNode } from 'react'\nimport Tippy, { TippyProps } from '@tippyjs/react'\nimport 'tippy.js/dist/tippy.css'\nimport './Tooltip.scss'\n\ninterface TooltipProps extends TippyProps {\n content: ReactNode\n success?: boolean\n onMouseEnter?: (event: React.MouseEvent<HTMLDivElement>) => void\n onMouseLeave?: (event: React.MouseEvent<HTMLDivElement>) => void\n visible?: boolean\n delay?: [number, number]\n type?: 'info' | 'function'\n maxWidth?: number\n className?: string\n arrowWithBorder?: boolean\n disabled?: boolean\n}\n\nconst Tooltip: React.FC<TooltipProps> = ({\n children,\n content,\n success,\n onMouseEnter,\n onMouseLeave,\n visible,\n delay = [200, 400],\n type = 'info',\n maxWidth = 390,\n className,\n arrowWithBorder,\n disabled,\n ...props\n}) => {\n const [rootFontSize, setRootFontSize] = useState(16)\n\n useEffect(() => {\n const handleFontSizeChange = (fontSize: number) => {\n setRootFontSize((prev) => (prev !== fontSize ? fontSize : prev))\n }\n\n if (\n // @ts-ignore - Ignoring if `applicationUIScaling` doesn't exist\n window.applicationUIScaling &&\n // @ts-ignore - Ignoring if `applicationUIScaling` doesn't exist\n typeof window.applicationUIScaling.addEventHandler === 'function'\n ) {\n // @ts-ignore - Ignoring if `applicationUIScaling` doesn't exist\n window.applicationUIScaling.addEventHandler(handleFontSizeChange)\n }\n }, [])\n\n return (\n <Tippy\n visible={visible}\n allowHTML={typeof content !== 'string'}\n interactive\n maxWidth={(maxWidth / 16) * rootFontSize}\n delay={delay}\n content={content}\n placement=\"bottom-start\"\n className={`${success ? 'success' : ''} ${type} ${className || ''} ${\n arrowWithBorder ? 'arrow-with-border' : ''\n }`}\n disabled={disabled}\n {...props}\n >\n <div\n className=\"tooltip-custom-wrapper\"\n onMouseEnter={onMouseEnter}\n onMouseLeave={onMouseLeave}\n >\n <div\n className=\"tooltip-custom-wrapper\"\n onMouseEnter={onMouseEnter}\n onMouseLeave={onMouseLeave}\n >\n {children}\n </div>\n </div>\n </Tippy>\n )\n}\n\nexport default Tooltip\n"],"names":["Tooltip","_a","children","content","success","onMouseEnter","onMouseLeave","visible","delay","type","maxWidth","className","arrowWithBorder","disabled","props","__rest","rootFontSize","setRootFontSize","useState","useEffect","handleFontSizeChange","fontSize","prev","window","applicationUIScaling","addEventHandler","_jsx","Tippy","Object","assign","allowHTML","interactive","placement"],"mappings":"4SAmBA,MAAMA,EAAmCC,IAAA,IAAAC,SACvCA,EAAQC,QACRA,EAAOC,QACPA,EAAOC,aACPA,EAAYC,aACZA,EAAYC,QACZA,EAAOC,MACPA,EAAQ,CAAC,IAAK,KAAIC,KAClBA,EAAO,OAAMC,SACbA,EAAW,IAAGC,UACdA,EAASC,gBACTA,EAAeC,SACfA,GAAQZ,EACLa,EAAKC,EAAAd,EAb+B,6IAevC,MAAOe,EAAcC,GAAmBC,EAAS,IAkBjD,OAhBAC,GAAU,KACR,MAAMC,EAAwBC,IAC5BJ,GAAiBK,GAAUA,IAASD,EAAWA,EAAWC,KAK1DC,OAAOC,sBAEgD,mBAAhDD,OAAOC,qBAAqBC,iBAGnCF,OAAOC,qBAAqBC,gBAAgBL,KAE7C,IAGDM,EAAAA,IAACC,EAAKC,OAAAC,OAAA,CACJtB,QAASA,EACTuB,UAA8B,iBAAZ3B,EAClB4B,aACA,EAAArB,SAAWA,EAAW,GAAMM,EAC5BR,MAAOA,EACPL,QAASA,EACT6B,UAAU,eACVrB,UAAW,GAAGP,EAAU,UAAY,MAAMK,KAAQE,GAAa,MAC7DC,EAAkB,oBAAsB,KAE1CC,SAAUA,GACNC,EAEJ,CAAAZ,SAAAwB,EAAAA,IAAA,MAAA,CACEf,UAAU,yBACVN,aAAcA,EACdC,aAAcA,WAEdoB,EAAAA,IACE,MAAA,CAAAf,UAAU,yBACVN,aAAcA,EACdC,aAAcA,EAAYJ,SAEzBA"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../../src/components/dialog/index.tsx"],"sourcesContent":["import React from 'react'\n// @ts-ignore\nimport { Dialog, Button } from 'digitinary-ui'\nimport SVGLoader from '../SVGLoader/SVGLoader'\nimport './style.scss'\nimport { CommonDialogProps } from './dialog'\nimport { Closecircle, InfoIcon } from './../../assets/icons'\n\nconst CommonDialog = ({\n status = 'info',\n content,\n onSubmit,\n onCancel,\n onClose,\n open,\n size = 'xs',\n icon = (\n <>\n <SVGLoader src={InfoIcon} width=\"4.0625rem\" height=\"4.0625rem\" />\n </>\n ),\n noActions = false,\n closeIcon,\n}: CommonDialogProps) => {\n const handleClose = () => {\n onClose() // Always close the dialog first\n\n if (onCancel && onCancel.onClick) {\n onCancel.onClick() // If onCancel.onClick is provided, invoke it after closing the dialog\n }\n }\n\n const body = (\n <div className=\"common-dialog\">\n {icon && (\n <div className=\"confirmation-dialog-header\">\n <div className={`icon ${status}`}>{icon}</div>\n </div>\n )}\n <div className=\"close-icon\">\n {closeIcon ?? (\n <SVGLoader src={Closecircle} width={'1.5rem'} height={'1.5rem'} onClick={handleClose} />\n )}\n </div>\n\n {content}\n {!!noActions ? null : (\n <div\n className=\"confirmation-dialog-footer\"\n style={{ marginBottom: onCancel || onSubmit ? '1.5rem' : '1rem' }}\n >\n {onCancel && (\n <Button\n {...onCancel}\n onClick={handleClose}\n variant={onCancel.variant || 'outlined'}\n color={onCancel.color || 'normal'}\n >\n {onCancel.text}\n </Button>\n )}\n {onSubmit && (\n <Button\n {...onSubmit}\n variant={onSubmit.variant || 'contained'}\n color={onSubmit.color || 'secondary'}\n >\n {onSubmit.text}\n </Button>\n )}\n </div>\n )}\n </div>\n )\n\n return (\n <Dialog\n open={open}\n onClose={handleClose}\n content={body}\n fullWidth={false}\n size={size}\n id=\"common-dialog\"\n />\n )\n}\n\nexport default CommonDialog\n"],"names":["CommonDialog","status","content","onSubmit","onCancel","onClose","open","size","icon","_jsx","jsx","SVGLoader","src","InfoIcon","width","height","noActions","closeIcon","handleClose","onClick","body","_jsxs","jsxs","className","children","Closecircle","style","marginBottom","Button","Object","assign","variant","color","text","Dialog","fullWidth","id"],"mappings":"qPAQM,MAAAA,EAAe,EACnBC,SAAS,OACTC,UACAC,WACAC,WACAC,UACAC,OACAC,OAAO,KACPC,OACEC,EAAAA,yBACEA,EAACC,IAAAC,EAAU,CAAAC,IAAKC,EAAUC,MAAM,YAAYC,OAAO,gBAGvDC,aAAY,EACZC,gBAEA,MAAMC,EAAc,KAClBb,IAEID,GAAYA,EAASe,SACvBf,EAASe,SACV,EAGGC,EACJC,EAAKC,KAAA,MAAA,CAAAC,UAAU,gBAAeC,SAAA,CAC3BhB,GACCC,EAAKC,IAAA,MAAA,CAAAa,UAAU,6BAA4BC,SACzCf,EAAAA,WAAKc,UAAW,QAAQtB,IAAWuB,SAAAhB,MAGvCC,EAAAC,IAAA,MAAA,CAAKa,UAAU,aACZC,SAAAP,QAAAA,EACCR,EAAAA,IAACE,GAAUC,IAAKa,EAAaX,MAAO,SAAUC,OAAQ,SAAUI,QAASD,MAI5EhB,EACEc,EAAY,KACbK,EAAAC,KAAA,MAAA,CACEC,UAAU,6BACVG,MAAO,CAAEC,aAAcvB,GAAYD,EAAW,SAAW,kBAExDC,GACCK,EAACC,IAAAkB,EAAMA,OACDC,OAAAC,OAAA,CAAA,EAAA1B,GACJe,QAASD,EACTa,QAAS3B,EAAS2B,SAAW,WAC7BC,MAAO5B,EAAS4B,OAAS,SAAQR,SAEhCpB,EAAS6B,QAGb9B,GACCM,EAAAC,IAACkB,EAAMA,OACDC,OAAAC,OAAA,CAAA,EAAA3B,GACJ4B,QAAS5B,EAAS4B,SAAW,YAC7BC,MAAO7B,EAAS6B,OAAS,YAAWR,SAEnCrB,EAAS8B,cAQtB,OACExB,EAAAA,IAACyB,EAAAA,OAAM,CACL5B,KAAMA,EACND,QAASa,EACThB,QAASkB,EACTe,WAAW,EACX5B,KAAMA,EACN6B,GAAG,iBAEN"}
1
+ {"version":3,"file":"index.js","sources":["../../../../src/components/dialog/index.tsx"],"sourcesContent":["import React from 'react'\n// @ts-ignore\nimport { Dialog, Button } from 'digitinary-ui'\nimport SVGLoader from '../SVGLoader/SVGLoader'\nimport './style.scss'\nimport { CommonDialogProps } from './dialog'\nimport { Closecircle, InfoIcon } from './../../assets/icons'\n\nconst CommonDialog = ({\n status = 'info',\n content,\n onSubmit,\n onCancel,\n onClose,\n open,\n size = 'xs',\n icon = (\n <>\n <SVGLoader src={InfoIcon} width=\"4.0625rem\" height=\"4.0625rem\" />\n </>\n ),\n noActions = false,\n closeIcon,\n}: CommonDialogProps) => {\n const handleClose = () => {\n onClose() // Always close the dialog first\n\n if (onCancel && onCancel.onClick) {\n onCancel.onClick() // If onCancel.onClick is provided, invoke it after closing the dialog\n }\n }\n\n const body = (\n <div className=\"common-dialog\">\n {icon && (\n <div className=\"confirmation-dialog-header\">\n <div className={`icon ${status}`}>{icon}</div>\n </div>\n )}\n <div className=\"close-icon\">\n {closeIcon ?? (\n <SVGLoader src={Closecircle} width={'1.5rem'} height={'1.5rem'} onClick={handleClose} />\n )}\n </div>\n\n {content}\n {!!noActions ? null : (\n <div\n className=\"confirmation-dialog-footer\"\n style={{ marginBottom: onCancel || onSubmit ? '1.5rem' : '1rem' }}\n >\n {onCancel && (\n <Button\n {...onCancel}\n onClick={handleClose}\n variant={onCancel.variant || 'outlined'}\n color={onCancel.color || 'normal'}\n >\n {onCancel.text}\n </Button>\n )}\n {onSubmit && (\n <Button\n {...onSubmit}\n variant={onSubmit.variant || 'contained'}\n color={onSubmit.color || 'secondary'}\n >\n {onSubmit.text}\n </Button>\n )}\n </div>\n )}\n </div>\n )\n\n return (\n <Dialog\n open={open}\n onClose={handleClose}\n content={body}\n fullWidth={false}\n size={size}\n id=\"common-dialog\"\n />\n )\n}\n\nexport default CommonDialog\n"],"names":["CommonDialog","status","content","onSubmit","onCancel","onClose","open","size","icon","_jsx","jsx","SVGLoader","src","InfoIcon","width","height","noActions","closeIcon","handleClose","onClick","body","_jsxs","jsxs","className","children","Closecircle","style","marginBottom","Button","Object","assign","variant","color","text","Dialog","fullWidth","id"],"mappings":"qPAQM,MAAAA,EAAe,EACnBC,SAAS,OACTC,UACAC,WACAC,WACAC,UACAC,OACAC,OAAO,KACPC,OACEC,EAAAA,yBACEA,EAACC,IAAAC,EAAU,CAAAC,IAAKC,EAAUC,MAAM,YAAYC,OAAO,gBAGvDC,aAAY,EACZC,gBAEA,MAAMC,EAAc,KAClBb,IAEID,GAAYA,EAASe,SACvBf,EAASe,WAIPC,EACJC,EAAKC,KAAA,MAAA,CAAAC,UAAU,gBAAeC,SAAA,CAC3BhB,GACCC,EAAKC,IAAA,MAAA,CAAAa,UAAU,6BAA4BC,SACzCf,EAAAA,WAAKc,UAAW,QAAQtB,IAAWuB,SAAAhB,MAGvCC,EAAAC,IAAA,MAAA,CAAKa,UAAU,aACZC,SAAAP,QAAAA,EACCR,EAAAA,IAACE,GAAUC,IAAKa,EAAaX,MAAO,SAAUC,OAAQ,SAAUI,QAASD,MAI5EhB,EACEc,EAAY,KACbK,EAAAC,KAAA,MAAA,CACEC,UAAU,6BACVG,MAAO,CAAEC,aAAcvB,GAAYD,EAAW,SAAW,kBAExDC,GACCK,EAACC,IAAAkB,EAAMA,OACDC,OAAAC,OAAA,CAAA,EAAA1B,GACJe,QAASD,EACTa,QAAS3B,EAAS2B,SAAW,WAC7BC,MAAO5B,EAAS4B,OAAS,SAAQR,SAEhCpB,EAAS6B,QAGb9B,GACCM,EAAAC,IAACkB,EAAMA,OACDC,OAAAC,OAAA,CAAA,EAAA3B,GACJ4B,QAAS5B,EAAS4B,SAAW,YAC7BC,MAAO7B,EAAS6B,OAAS,YAAWR,SAEnCrB,EAAS8B,cAQtB,OACExB,EAAAA,IAACyB,EAAAA,OAAM,CACL5B,KAAMA,EACND,QAASa,EACThB,QAASkB,EACTe,WAAW,EACX5B,KAAMA,EACN6B,GAAG"}
@@ -1,2 +1,2 @@
1
- import{j as e}from"../../../_virtual/jsx-runtime.js";import{useState as l}from"react";import{d as a}from"../../../_virtual/index.js";import i from"../Tooltip/Tooltip.js";import t from"../SVGLoader/SVGLoader.js";import s from"../../assets/icons/DeleteIcon.svg.js";import d from"../../assets/icons/EditIcon.svg.js";import n from"../../assets/icons/AddRow.svg.js";import o from"../../assets/icons/Plus.svg.js";import r from"../../assets/icons/PlusSquare.svg.js";import c from"../MethodAccordion/MethodAccordion.module.scss.js";import{useFormik as m}from"../../../node_modules/formik/dist/formik.esm.js";import{object as u,string as v,array as h,bool as p}from"../../../node_modules/yup/index.esm.js";import{capitalize as b}from"../../helpers/methodAccordion.helper.js";import j from"../../constants/regex.js";const x=({id:x,headCells:y,data:N,isFormOpen:C,setIsFormOpen:g,saveNewRow:w,readOnly:T,isRequest:D=!0})=>{var f,I,E,S,q,B,k,_,A,P,L,O,R,F,M,V,W,X,G,z,H,U,$,K,Q,Y,Z;const[J,ee]=l(""),[le,ae]=l(null),[ie,te]=l(null),[se,de]=l([]),{values:ne,errors:oe,setFieldValue:re,isValid:ce,submitForm:me,resetForm:ue}=m({validateOnMount:!0,initialValues:{name:"",in:D?"query":"header",schema:{type:"string",enum:[],items:{type:"string"}},required:!0,description:""},validationSchema:u().shape({name:v().default("").trim().required("Parameter name is required"),in:v().required("Paramter type is required"),schema:u().shape({type:v().required("Parameter schema type is required"),enum:h(v()).optional(),items:u().shape({type:v().optional()})}),required:p().when("in",{is:"path",then:e=>e.oneOf([!0],"Path parameters must be required."),otherwise:e=>e.optional()}),description:v().default("").trim().optional()}),onSubmit:e=>{var l,a,i,t;e&&!(null===(a=null===(l=null==e?void 0:e.schema)||void 0===l?void 0:l.items)||void 0===a?void 0:a.type)&&(null===(t=null===(i=null==e?void 0:e.schema)||void 0===i?void 0:i.items)||void 0===t||delete t.type),w(e),g(void 0),ee(""),ue()}});return e.jsx("div",{className:"tableSectionContainer",children:e.jsx("div",{className:"tableContainer",children:e.jsxs("table",{id:x||"",className:"table borderRadiusTop borderRadiusBottom",children:[e.jsx("thead",{className:"tableHead",children:e.jsx("tr",{children:null==y?void 0:y.map((l=>e.jsx("th",{className:`tableHeadCell ${l.classes||""}`,style:{width:l.width,minWidth:l.minWidth},children:e.jsx("div",{className:"headContainer","data-id":`${"string"==typeof l.label?l.label.toUpperCase().replace(/[^a-zA-Z0-9]+/g,"_"):"UNKNOWN_LABEL"}_COLUMN`,children:l.label})},l.id)))})}),e.jsxs("tbody",{className:"tableBody","data-id":"TABLE_BODY",children:[null==N?void 0:N.map(((l,a)=>e.jsx("tr",{"data-i":a,className:"row",children:null==y?void 0:y.map((a=>{const i="_"!==l[a.id]&&e.jsx("div",{"data-id":"TEXT_DESCRIPTION",className:"tableData",style:{width:a.width,minWidth:a.minWidth},children:l[a.id]});return e.jsx("td",{style:{width:a.width,minWidth:a.minWidth},children:i},a.id)}))},a))),0===(null==N?void 0:N.length)&&T&&e.jsx("tr",{className:"fallbackTableRow",children:e.jsx("td",{className:"fallbackContainer",colSpan:null==y?void 0:y.length,children:e.jsx("div",{className:"fallbackTextContainer",children:e.jsx("span",{className:"fallbackText",children:" No Data Available"})})})}),C&&!T?e.jsxs("tr",{className:"row",children:[e.jsx("td",{children:e.jsx("div",{"data-id":"TEXT_DESCRIPTION",className:"tableData",children:e.jsx(a.Input,{placeholder:"Parameter name",size:"large",type:"text",onChange:e=>{(""===e||j.ASCII.test(e))&&re("name",e)},value:ne.name,disabled:T})})},"Parameter name"),e.jsx("td",{children:e.jsxs("div",{"data-id":"TEXT_DESCRIPTION",className:"tableData",children:[e.jsx(a.SelectGroupV2,{disabled:T,value:{label:b(ne.in),value:ne.in},onChange:e=>{var l;re("in",null===(l=null==e?void 0:e.value)||void 0===l?void 0:l.toLowerCase()),"in"==(null==e?void 0:e.value)&&re("required",!0)},options:[{list:D?[{label:"Query",value:"query"},{label:"Header",value:"header"},{label:"Path",value:"path"},{label:"Body",value:"body"}]:[{label:"Header",value:"header"}]}],errorMsg:!!oe.in&&oe.in,isMultiple:!1,withSearch:!1,clearable:!1})," "]})},"parameter in"),e.jsx("td",{children:e.jsxs("div",{"data-id":"TEXT_DESCRIPTION",className:"tableData select-inputs",children:[e.jsx(a.SelectGroupV2,{disabled:T,clearable:!1,value:{label:b(null===(f=null==ne?void 0:ne.schema)||void 0===f?void 0:f.type),value:null===(I=null==ne?void 0:ne.schema)||void 0===I?void 0:I.type},errorMsg:!!oe.schema&&oe.schema,onChange:e=>{var l;return re("schema.type",null===(l=null==e?void 0:e.value)||void 0===l?void 0:l.toLowerCase())},options:[{list:[{label:"String",value:"string"},{label:"Integer",value:"integer"},{label:"Boolean",value:"boolean"},{label:"Object",value:"object"},{label:"Array",value:"array"},{label:"Number",value:"number"}]}],isMultiple:!1,withSearch:!1})," ",(null===(E=null==ne?void 0:ne.schema)||void 0===E?void 0:E.type)&&"array"===(null===(S=null==ne?void 0:ne.schema)||void 0===S?void 0:S.type.toLowerCase())?e.jsx(a.SelectGroupV2,{disabled:T,clearable:!1,value:{label:b(null===(B=null===(q=null==ne?void 0:ne.schema)||void 0===q?void 0:q.items)||void 0===B?void 0:B.type),value:null===(_=null===(k=ne.schema)||void 0===k?void 0:k.items)||void 0===_?void 0:_.type},errorMsg:!!(null===(P=null===(A=null==oe?void 0:oe.schema)||void 0===A?void 0:A.items)||void 0===P?void 0:P.type)&&(null===(O=null===(L=null==oe?void 0:oe.schema)||void 0===L?void 0:L.items)||void 0===O?void 0:O.type),onChange:e=>{var l;return re("schema.items.type",null===(l=null==e?void 0:e.value)||void 0===l?void 0:l.toLowerCase())},options:[{list:[{label:"String",value:"string"},{label:"Integer",value:"integer"},{label:"Boolean",value:"boolean"},{label:"Object",value:"object"},{label:"Array",value:"array"},{label:"Number",value:"number"}]}],isMultiple:!1,withSearch:!1}):""]})},"parameter schema type"),e.jsx("td",{children:e.jsxs("div",{"data-id":"TEXT_DESCRIPTION",className:"tableData",children:[(null==ne?void 0:ne.schema)&&"array"!=(null===(F=null===(R=null==ne?void 0:ne.schema)||void 0===R?void 0:R.type)||void 0===F?void 0:F.toLowerCase())&&"object"!=(null===(V=null===(M=null==ne?void 0:ne.schema)||void 0===M?void 0:M.type)||void 0===V?void 0:V.toLowerCase())?e.jsx(i,{disabled:"array"==(null===(X=null===(W=null==ne?void 0:ne.schema)||void 0===W?void 0:W.type)||void 0===X?void 0:X.toLowerCase())||"object"==(null===(z=null===(G=null==ne?void 0:ne.schema)||void 0===G?void 0:G.type)||void 0===z?void 0:z.toLowerCase()),arrowWithBorder:!0,placement:"bottom-end",type:"function",trigger:"click",delay:[0,0],onCreate:e=>te(e),content:e.jsxs("div",{className:c.editDescTooltipContent,children:[e.jsx("p",{className:c.editDescTooltipContent_header,children:"Enum"}),!!(null===(H=null==ne?void 0:ne.schema)||void 0===H?void 0:H.enum)&&!!(null===(U=null==ne?void 0:ne.schema)||void 0===U?void 0:U.enum.length)&&(null===(K=null===($=null==ne?void 0:ne.schema)||void 0===$?void 0:$.enum)||void 0===K?void 0:K.map(((l,i)=>e.jsx(a.Input,{className:"methodDescForEnum",required:!0,clearable:!1,placeholder:"Enter Enum value...",value:l,onChange:e=>{re(`schema.enum[${i}]`,e)}},i)))),se&&(null==se?void 0:se.map(((l,i)=>e.jsx(a.Input,{className:"methodDescForEnum",required:!0,clearable:!1,placeholder:"Enter Enum value...",value:l,onChange:e=>{let l=[...se];l[i]=e,de(l)}},i)))),e.jsxs("p",{className:"addEnumButton",onClick:()=>{de((e=>[...e,""]))},children:[e.jsx(t,{src:r}),"Add New Enum"]}),!T&&e.jsx(a.Button,{className:c.editDescTooltipContent_btn,variant:"outlined",size:"small",type:"button",onClick:()=>{var e;re("schema.enum",[...null===(e=null==ne?void 0:ne.schema)||void 0===e?void 0:e.enum,...se]),de([]),null==ie||ie.hide()},disabled:se.length>0&&(null==se?void 0:se.filter((e=>!e)).length)||(null===(Q=null==ne?void 0:ne.schema)||void 0===Q?void 0:Q.enum.length)>0&&(null===(Z=null===(Y=null==ne?void 0:ne.schema)||void 0===Y?void 0:Y.enum)||void 0===Z?void 0:Z.filter((e=>!e)).length),children:"Apply"})]}),children:e.jsx(a.Button,{className:c.editDescBtn,id:"EnumButton",variant:"link",color:"action",endIcon:e.jsx(t,{id:"enumIcon",src:o,width:"1.5rem",height:"1.5rem"}),children:"Add"})}):"-"," "]})},"parameter enum"),e.jsx("td",{children:e.jsx("div",{"data-id":"is required",className:"tableData",children:T?e.jsx(e.Fragment,{children:ne.required?"True":"False"}):e.jsx(a.Switch,{checked:!(!ne||!ne.in||"path"!=ne.in.toLowerCase())||ne.required,disabled:ne&&ne.in&&"path"==ne.in.toLowerCase(),onClick:()=>{T||re("required",!ne.required)}})})},"parameter required"),e.jsx("td",{children:e.jsxs("div",{"data-id":"TEXT_DESCRIPTION",className:"tableData",children:[e.jsxs("div",{className:c.paramDescContainer,children:[e.jsx(i,{arrowWithBorder:!0,placement:"bottom-end",type:"function",trigger:"click",delay:[0,0],onCreate:e=>ae(e),content:e.jsxs("div",{className:c.editDescTooltipContent,children:[e.jsx("p",{className:c.editDescTooltipContent_header,children:"Description"}),e.jsx(a.TextArea,{value:J||ne.description,onChange:e=>{(""===e||j.ASCII.test(e))&&ee(e)},disabled:T,placeholder:"Describe parameter...",maxLength:120}),!T&&e.jsx(a.Button,{className:c.editDescTooltipContent_btn,variant:"outlined",size:"small",onClick:()=>{re("description",null==J?void 0:J.trim()),null==le||le.hide()},disabled:""===(null==J?void 0:J.trim()),children:"Apply"})]}),children:e.jsxs(a.Button,{className:c.editDescBtn,variant:"link",color:"action",endIcon:e.jsx(t,{src:d,width:"1.5rem",height:"1.5rem"}),children:[T?"View ":"Add "," Description"]})}),e.jsx("div",{className:c.paramDescContainer_separator}),!T&&e.jsx(a.Button,{className:c.deleteParamBtn,variant:"link",color:"error",endIcon:e.jsx(t,{src:s,width:"1.125rem",height:"1.125rem"}),onClick:()=>{ue(),ee(""),g(void 0)}}),!T&&e.jsx(i,{disabled:!!ne.name.trim(),content:"Parameter name can't be empty ",children:e.jsx(a.Button,{className:c.deleteParamBtn,variant:"link",color:"success",disabled:!ne.name.trim(),endIcon:e.jsx(t,{src:n,width:"0.125rem",height:"0.125rem"}),onClick:()=>{ee(""),me()}})})]})," "]})},"parameter schema desc")]}):e.jsx(e.Fragment,{children:!T&&e.jsx("tr",{"data-i":"addNew",className:"row",children:e.jsx("td",{colSpan:5,children:e.jsx(a.Button,{variant:"link",color:"primary",onClick:()=>{g((e=>e?void 0:D?"Req":"Res"))},children:"+ Add Parameter"})})},"addNew")})]})]})})})};export{x as default};
1
+ import{j as e}from"../../../_virtual/jsx-runtime.js";import{useState as l}from"react";import{d as a}from"../../../_virtual/index.js";import i from"../Tooltip/Tooltip.js";import t from"../SVGLoader/SVGLoader.js";import s from"../../assets/icons/DeleteIcon.svg.js";import n from"../../assets/icons/EditIcon.svg.js";import d from"../../assets/icons/AddRow.svg.js";import r from"../../assets/icons/Plus.svg.js";import o from"../../assets/icons/PlusSquare.svg.js";import c from"../MethodAccordion/MethodAccordion.module.scss.js";import{useFormik as m}from"../../../node_modules/formik/dist/formik.esm.js";import{object as u,string as v,array as h,bool as p}from"../../../node_modules/yup/index.esm.js";import{capitalize as b}from"../../helpers/methodAccordion.helper.js";import j from"../../constants/regex.js";const x=({id:x,headCells:N,data:y,isFormOpen:C,setIsFormOpen:g,saveNewRow:w,readOnly:T,isRequest:D=!0})=>{var f,I,E,S,q,B,k,_,A,P,O,L,R,F,M,V,W,X,G,z,H,U,$;const[K,Q]=l(""),[Y,Z]=l(null),[J,ee]=l(null),[le,ae]=l([]),{values:ie,errors:te,setFieldValue:se,isValid:ne,submitForm:de,resetForm:re}=m({validateOnMount:!0,initialValues:{name:"",in:D?"query":"header",schema:{type:"string",enum:[],items:{type:"string"}},required:!0,description:""},validationSchema:u().shape({name:v().default("").trim().required("Parameter name is required"),in:v().required("Paramter type is required"),schema:u().shape({type:v().required("Parameter schema type is required"),enum:h(v()).optional(),items:u().shape({type:v().optional()})}),required:p().when("in",{is:"path",then:e=>e.oneOf([!0],"Path parameters must be required."),otherwise:e=>e.optional()}),description:v().default("").trim().optional()}),onSubmit:e=>{var l,a,i,t;e&&!(null===(a=null===(l=null==e?void 0:e.schema)||void 0===l?void 0:l.items)||void 0===a?void 0:a.type)&&(null===(t=null===(i=null==e?void 0:e.schema)||void 0===i?void 0:i.items)||void 0===t||delete t.type),w(e),g(void 0),Q(""),re()}});return e.jsx("div",{className:"tableSectionContainer",children:e.jsx("div",{className:"tableContainer",children:e.jsxs("table",{id:x||"",className:"table borderRadiusTop borderRadiusBottom",children:[e.jsx("thead",{className:"tableHead",children:e.jsx("tr",{children:null==N?void 0:N.map((l=>e.jsx("th",{className:`tableHeadCell ${l.classes||""}`,style:{width:l.width,minWidth:l.minWidth},children:e.jsx("div",{className:"headContainer","data-id":`${"string"==typeof l.label?l.label.toUpperCase().replace(/[^a-zA-Z0-9]+/g,"_"):"UNKNOWN_LABEL"}_COLUMN`,children:l.label})},l.id)))})}),e.jsxs("tbody",{className:"tableBody","data-id":"TABLE_BODY",children:[null==y?void 0:y.map(((l,a)=>e.jsx("tr",{"data-i":a,className:"row",children:null==N?void 0:N.map((a=>{const i="_"!==l[a.id]&&e.jsx("div",{"data-id":"TEXT_DESCRIPTION",className:"tableData",style:{width:a.width,minWidth:a.minWidth},children:l[a.id]});return e.jsx("td",{style:{width:a.width,minWidth:a.minWidth},children:i},a.id)}))},a))),0===(null==y?void 0:y.length)&&T&&e.jsx("tr",{className:"fallbackTableRow",children:e.jsx("td",{className:"fallbackContainer",colSpan:null==N?void 0:N.length,children:e.jsx("div",{className:"fallbackTextContainer",children:e.jsx("span",{className:"fallbackText",children:" No Data Available"})})})}),C&&!T?e.jsxs("tr",{className:"row",children:[e.jsx("td",{children:e.jsx("div",{"data-id":"TEXT_DESCRIPTION",className:"tableData",children:e.jsx(a.Input,{placeholder:"Parameter name",size:"large",type:"text",onChange:e=>{(""===e||j.ASCII.test(e))&&se("name",e)},value:ie.name,disabled:T})})},"Parameter name"),e.jsx("td",{children:e.jsxs("div",{"data-id":"TEXT_DESCRIPTION",className:"tableData",children:[e.jsx(a.SelectGroupV2,{disabled:T,value:{label:b(ie.in),value:ie.in},onChange:e=>{var l;se("in",null===(l=null==e?void 0:e.value)||void 0===l?void 0:l.toLowerCase()),"in"==(null==e?void 0:e.value)&&se("required",!0)},options:[{list:D?[{label:"Query",value:"query"},{label:"Header",value:"header"},{label:"Path",value:"path"},{label:"Body",value:"body"}]:[{label:"Header",value:"header"}]}],errorMsg:!!te.in&&te.in,isMultiple:!1,withSearch:!1,clearable:!1})," "]})},"parameter in"),e.jsx("td",{children:e.jsxs("div",{"data-id":"TEXT_DESCRIPTION",className:"tableData select-inputs",children:[e.jsx(a.SelectGroupV2,{disabled:T,clearable:!1,value:{label:b(null===(f=null==ie?void 0:ie.schema)||void 0===f?void 0:f.type),value:null===(I=null==ie?void 0:ie.schema)||void 0===I?void 0:I.type},errorMsg:!!te.schema&&te.schema,onChange:e=>{var l;return se("schema.type",null===(l=null==e?void 0:e.value)||void 0===l?void 0:l.toLowerCase())},options:[{list:[{label:"String",value:"string"},{label:"Integer",value:"integer"},{label:"Boolean",value:"boolean"},{label:"Object",value:"object"},{label:"Array",value:"array"},{label:"Number",value:"number"}]}],isMultiple:!1,withSearch:!1})," ",(null===(E=null==ie?void 0:ie.schema)||void 0===E?void 0:E.type)&&"array"===(null===(S=null==ie?void 0:ie.schema)||void 0===S?void 0:S.type.toLowerCase())?e.jsx(a.SelectGroupV2,{disabled:T,clearable:!1,value:{label:b(null===(B=null===(q=null==ie?void 0:ie.schema)||void 0===q?void 0:q.items)||void 0===B?void 0:B.type),value:null===(_=null===(k=ie.schema)||void 0===k?void 0:k.items)||void 0===_?void 0:_.type},errorMsg:!!(null===(P=null===(A=null==te?void 0:te.schema)||void 0===A?void 0:A.items)||void 0===P?void 0:P.type)&&(null===(L=null===(O=null==te?void 0:te.schema)||void 0===O?void 0:O.items)||void 0===L?void 0:L.type),onChange:e=>{var l;return se("schema.items.type",null===(l=null==e?void 0:e.value)||void 0===l?void 0:l.toLowerCase())},options:[{list:[{label:"String",value:"string"},{label:"Integer",value:"integer"},{label:"Boolean",value:"boolean"},{label:"Object",value:"object"},{label:"Array",value:"array"},{label:"Number",value:"number"}]}],isMultiple:!1,withSearch:!1}):""]})},"parameter schema type"),e.jsx("td",{children:e.jsxs("div",{"data-id":"TEXT_DESCRIPTION",className:"tableData",children:[(null==ie?void 0:ie.schema)?e.jsx(i,{disabled:"array"==(null===(F=null===(R=null==ie?void 0:ie.schema)||void 0===R?void 0:R.type)||void 0===F?void 0:F.toLowerCase())||"object"==(null===(V=null===(M=null==ie?void 0:ie.schema)||void 0===M?void 0:M.type)||void 0===V?void 0:V.toLowerCase()),arrowWithBorder:!0,placement:"bottom-end",type:"function",trigger:"click",delay:[0,0],onCreate:e=>ee(e),content:e.jsxs("div",{className:c.editDescTooltipContent,children:[e.jsx("p",{className:c.editDescTooltipContent_header,children:"Enum"}),!!(null===(W=null==ie?void 0:ie.schema)||void 0===W?void 0:W.enum)&&!!(null===(X=null==ie?void 0:ie.schema)||void 0===X?void 0:X.enum.length)&&(null===(z=null===(G=null==ie?void 0:ie.schema)||void 0===G?void 0:G.enum)||void 0===z?void 0:z.map(((l,i)=>e.jsx(a.Input,{className:"methodDescForEnum",required:!0,clearable:!1,placeholder:"Enter Enum value...",value:l,onChange:e=>{se(`schema.enum[${i}]`,e)}},i)))),le&&(null==le?void 0:le.map(((l,i)=>e.jsx(a.Input,{className:"methodDescForEnum",required:!0,clearable:!1,placeholder:"Enter Enum value...",value:l,onChange:e=>{let l=[...le];l[i]=e,ae(l)}},i)))),e.jsxs("p",{className:"addEnumButton",onClick:()=>{ae((e=>[...e,""]))},children:[e.jsx(t,{src:o}),"Add New Enum"]}),!T&&e.jsx(a.Button,{className:c.editDescTooltipContent_btn,variant:"outlined",size:"small",type:"button",onClick:()=>{var e;se("schema.enum",[...null===(e=null==ie?void 0:ie.schema)||void 0===e?void 0:e.enum,...le]),ae([]),null==J||J.hide()},disabled:le.length>0&&(null==le?void 0:le.filter((e=>!e)).length)||(null===(H=null==ie?void 0:ie.schema)||void 0===H?void 0:H.enum.length)>0&&(null===($=null===(U=null==ie?void 0:ie.schema)||void 0===U?void 0:U.enum)||void 0===$?void 0:$.filter((e=>!e)).length),children:"Apply"})]}),children:e.jsx(a.Button,{className:c.editDescBtn,id:"EnumButton",variant:"link",color:"action",endIcon:e.jsx(t,{id:"enumIcon",src:r,width:"1.5rem",height:"1.5rem"}),children:"Add"})}):"-"," "]})},"parameter enum"),e.jsx("td",{children:e.jsx("div",{"data-id":"is required",className:"tableData",children:T?e.jsx(e.Fragment,{children:ie.required?"True":"False"}):e.jsx(a.Switch,{checked:!(!ie||!ie.in||"path"!=ie.in.toLowerCase())||ie.required,disabled:ie&&ie.in&&"path"==ie.in.toLowerCase(),onClick:()=>{T||se("required",!ie.required)}})})},"parameter required"),e.jsx("td",{children:e.jsxs("div",{"data-id":"TEXT_DESCRIPTION",className:"tableData",children:[e.jsxs("div",{className:c.paramDescContainer,children:[e.jsx(i,{arrowWithBorder:!0,placement:"bottom-end",type:"function",trigger:"click",delay:[0,0],onCreate:e=>Z(e),content:e.jsxs("div",{className:c.editDescTooltipContent,children:[e.jsx("p",{className:c.editDescTooltipContent_header,children:"Description"}),e.jsx(a.TextArea,{value:K||ie.description,onChange:e=>{(""===e||j.ASCII.test(e))&&Q(e)},disabled:T,placeholder:"Describe parameter...",maxLength:120}),!T&&e.jsx(a.Button,{className:c.editDescTooltipContent_btn,variant:"outlined",size:"small",onClick:()=>{se("description",null==K?void 0:K.trim()),null==Y||Y.hide()},disabled:""===(null==K?void 0:K.trim()),children:"Apply"})]}),children:e.jsxs(a.Button,{className:c.editDescBtn,variant:"link",color:"action",endIcon:e.jsx(t,{src:n,width:"1.5rem",height:"1.5rem"}),children:[T?"View ":"Add "," Description"]})}),e.jsx("div",{className:c.paramDescContainer_separator}),!T&&e.jsx(a.Button,{className:c.deleteParamBtn,variant:"link",color:"error",endIcon:e.jsx(t,{src:s,width:"1.125rem",height:"1.125rem"}),onClick:()=>{re(),Q(""),g(void 0)}}),!T&&e.jsx(i,{disabled:!!ie.name.trim(),content:"Parameter name can't be empty ",children:e.jsx(a.Button,{className:c.deleteParamBtn,variant:"link",color:"success",disabled:!ie.name.trim(),endIcon:e.jsx(t,{src:d,width:"0.125rem",height:"0.125rem"}),onClick:()=>{Q(""),de()}})})]})," "]})},"parameter schema desc")]}):e.jsx(e.Fragment,{children:!T&&e.jsx("tr",{"data-i":"addNew",className:"row",children:e.jsx("td",{colSpan:5,children:e.jsx(a.Button,{variant:"link",color:"primary",onClick:()=>{g((e=>e?void 0:D?"Req":"Res"))},children:"+ Add Parameter"})})},"addNew")})]})]})})})};export{x as default};
2
2
  //# sourceMappingURL=table.js.map