@digi-frontend/dgate-api-documentation 1.4.7 → 1.4.9

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 (70) hide show
  1. package/dist/src/components/InfoForm/InfoForm.js +1 -1
  2. package/dist/src/components/InfoForm/InfoForm.js.map +1 -1
  3. package/dist/src/components/InfoForm/InfoForm.module.scss.js +1 -1
  4. package/dist/src/components/JsonInput/JsonInput.js +1 -1
  5. package/dist/src/components/JsonInput/JsonInput.js.map +1 -1
  6. package/dist/src/components/JsonInput/style.module.scss.js +1 -1
  7. package/dist/src/components/LivePreview/LivePreview.js +1 -1
  8. package/dist/src/components/LivePreview/LivePreview.js.map +1 -1
  9. package/dist/src/components/LivePreview/LivePreview.module.scss.js +1 -1
  10. package/dist/src/components/MethodAccordion/MethodAccordion.js +1 -1
  11. package/dist/src/components/MethodAccordion/MethodAccordion.js.map +1 -1
  12. package/dist/src/components/MethodAccordion/MethodAccordion.module.scss.js +1 -1
  13. package/dist/src/components/SVGLoader/SVGLoader.js +1 -1
  14. package/dist/src/components/SVGLoader/SVGLoader.js.map +1 -1
  15. package/dist/src/components/SectionHead/SectionHead.js +1 -1
  16. package/dist/src/components/SectionHead/SectionHead.js.map +1 -1
  17. package/dist/src/components/SimpleLabelValue/SimpleLabelValue.js +1 -1
  18. package/dist/src/components/SimpleLabelValue/SimpleLabelValue.js.map +1 -1
  19. package/dist/src/components/Tooltip/Tooltip.js +1 -1
  20. package/dist/src/components/Tooltip/Tooltip.js.map +1 -1
  21. package/dist/src/components/dialog/index.js +1 -1
  22. package/dist/src/components/dialog/index.js.map +1 -1
  23. package/dist/src/components/table/table.js +1 -1
  24. package/dist/src/components/table/table.js.map +1 -1
  25. package/dist/src/components/table/tags-table.js +1 -1
  26. package/dist/src/components/table/tags-table.js.map +1 -1
  27. package/dist/src/context/SectionToggleContext.js +1 -1
  28. package/dist/src/context/SectionToggleContext.js.map +1 -1
  29. package/dist/src/layout/docsComponents/Codebox/Codebox.js +1 -1
  30. package/dist/src/layout/docsComponents/Codebox/Codebox.js.map +1 -1
  31. package/dist/src/layout/docsComponents/Codebox/style.module.scss.js +1 -1
  32. package/dist/src/layout/docsComponents/DocsAside/DocsAside.js +1 -1
  33. package/dist/src/layout/docsComponents/DocsAside/DocsAside.js.map +1 -1
  34. package/dist/src/layout/docsComponents/DocsAside/style.module.scss.js +1 -1
  35. package/dist/src/layout/docsComponents/DocsContent/DocsContent.js +1 -1
  36. package/dist/src/layout/docsComponents/DocsContent/DocsContent.js.map +1 -1
  37. package/dist/src/layout/docsComponents/DocsContent/EndpointPage/index.js +1 -1
  38. package/dist/src/layout/docsComponents/DocsContent/EndpointPage/index.js.map +1 -1
  39. package/dist/src/layout/docsComponents/DocsContent/OverviewPage/index.js +1 -1
  40. package/dist/src/layout/docsComponents/DocsContent/OverviewPage/index.js.map +1 -1
  41. package/dist/src/layout/docsComponents/DocsHeader/DocsHeader.js +1 -1
  42. package/dist/src/layout/docsComponents/DocsHeader/DocsHeader.js.map +1 -1
  43. package/dist/src/layout/docsComponents/DocsHeader/DocsHeader.module.scss.js +1 -1
  44. package/dist/src/layout/docsComponents/DocsSideMenuTree/DocsSideMenuTree.js +1 -1
  45. package/dist/src/layout/docsComponents/DocsSideMenuTree/DocsSideMenuTree.js.map +1 -1
  46. package/dist/src/layout/docsComponents/index.js +1 -1
  47. package/dist/src/layout/docsComponents/index.js.map +1 -1
  48. package/dist/src/layout/docsLayout.js +1 -1
  49. package/dist/src/layout/docsLayout.js.map +1 -1
  50. package/dist/src/layout/layout.js +1 -1
  51. package/dist/src/layout/layout.js.map +1 -1
  52. package/dist/types/components/Chips/Chips.d.ts +2 -1
  53. package/dist/types/components/InfoForm/InfoForm.d.ts +1 -1
  54. package/dist/types/components/JsonInput/JsonInput.d.ts +2 -1
  55. package/dist/types/components/MethodAccordion/MethodAccordion.d.ts +1 -1
  56. package/dist/types/components/dialog/index.d.ts +2 -1
  57. package/dist/types/components/table/table.d.ts +2 -1
  58. package/dist/types/components/table/tags-table.d.ts +1 -1
  59. package/dist/types/context/SectionToggleContext.d.ts +2 -2
  60. package/dist/types/index.d.ts +2 -27
  61. package/dist/types/layout/docsComponents/Codebox/Codebox.d.ts +2 -1
  62. package/dist/types/layout/docsComponents/DocsAside/DocsAside.d.ts +2 -1
  63. package/dist/types/layout/docsComponents/DocsContent/DocsContent.d.ts +1 -1
  64. package/dist/types/layout/docsComponents/DocsContent/EndpointPage/index.d.ts +1 -1
  65. package/dist/types/layout/docsComponents/DocsContent/OverviewPage/index.d.ts +1 -1
  66. package/dist/types/layout/docsComponents/DocsHeader/DocsHeader.d.ts +2 -1
  67. package/dist/types/layout/docsComponents/DocsSideMenuTree/DocsSideMenuTree.d.ts +1 -1
  68. package/package.json +1 -1
  69. package/rollup.config.js +39 -4
  70. package/tsconfig.json +0 -1
@@ -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 activeAccordionRef = useRef<HTMLDivElement | null>(null)\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 useEffect(() => {\n if (isOpen && activeAccordionRef.current) {\n activeAccordionRef.current.scrollIntoView({ behavior: 'smooth', block: 'start' })\n }\n }, [isOpen])\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 ref={activeAccordionRef}>\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 className={styles.multiLineText}\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","activeAccordionRef","useRef","currentResponse","responses","find","res","Number","indexRef","onTableChange","key","index","newTableData","item","tIndex","Object","assign","useEffect","current","scrollIntoView","behavior","block","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","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","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","ref","Accordion","expanded","methodAccordion","summary","methodSummaryContainer","methodSummary","methodColorMapping","methodLabel","methodPath","methodExpandArrowContainer","DownArrowIcon","methodAccordionContent","SimpleLabelValue","methodDesc","onClear","errorMsg","SelectGroup","i","options","list","isMultiple","withSearch","multiLineText","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 activeAccordionRef = useRef<HTMLDivElement | null>(null)\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 useEffect(() => {\n if (isOpen && activeAccordionRef.current) {\n activeAccordionRef.current.scrollIntoView({ behavior: 'smooth', block: 'start' })\n }\n }, [isOpen])\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 ref={activeAccordionRef}>\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 className={styles.multiLineText}\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","React","createElement","className","styles","statusCodeOptionContainer","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","activeAccordionRef","useRef","currentResponse","responses","find","res","Number","indexRef","onTableChange","key","index","newTableData","item","tIndex","Object","assign","useEffect","current","scrollIntoView","behavior","block","generateResponseTableData","headersObj","responseIndex","keys","data","id","paramName","paramType","capitalize","schemaType","schema","_a","type","_c","_b","toLowerCase","_d","items","_f","_e","_h","_g","required","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","Button","editDescTooltipContent_btn","variant","size","trim","_k","_l","editDescBtn","color","endIcon","SVGLoader","src","EditIcon","width","height","paramDescContainer_separator","deleteParamBtn","DeleteIcon","handleDeleteResponseHeader","enum","_m","_o","join","isComplex","enumList","enumVal","enumIndex","Input","clearable","PlusSquare","some","val","PlusIcon","handleDeleteClick","name","in","parameters","_p","_s","_q","_w","_u","_v","_y","_x","_z","_2","_1","_0","_4","_3","_6","_5","_9","_8","_7","_index","filter","_11","_10","_14","_12","_13","_17","_16","_15","_18","_19","_22","_20","_25","_23","findIndex","_r","toString","clonedResponses","structuredClone","push","contentType","filteredArray","self","t","ref","Accordion","expanded","methodAccordion","summary","methodSummaryContainer","methodSummary","methodColorMapping","methodLabel","methodPath","methodExpandArrowContainer","DownArrowIcon","children","methodAccordionContent","SimpleLabelValue","methodDesc","onClear","errorMsg","SelectGroup","i","options","list","isMultiple","withSearch","multiLineText","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,2 +1,2 @@
1
- const t="";export{t as default};
1
+ var o={methodAccordion:"MethodAccordion-module_methodAccordion__Gu2EL",methodSummaryContainer:"MethodAccordion-module_methodSummaryContainer__X57mG",methodSummary:"MethodAccordion-module_methodSummary__n5n20",methodLabel:"MethodAccordion-module_methodLabel__SZ0WZ",methodPath:"MethodAccordion-module_methodPath__aotss",methodExpandArrowContainer:"MethodAccordion-module_methodExpandArrowContainer__bHenL",expanded:"MethodAccordion-module_expanded__V-zBL",methodAccordionContent:"MethodAccordion-module_methodAccordionContent__OxP9P",multiLineText:"MethodAccordion-module_multiLineText__NqNh8",methodDesc:"MethodAccordion-module_methodDesc__vRJ-C",paramsTable:"MethodAccordion-module_paramsTable__ud3y3",paramsTableBodyHead:"MethodAccordion-module_paramsTableBodyHead__fVIge",responseHeader:"MethodAccordion-module_responseHeader__pcilb",statusCodeOptionContainer:"MethodAccordion-module_statusCodeOptionContainer__6XZjS",statusCodeOptionCircle:"MethodAccordion-module_statusCodeOptionCircle__GXKaK",paramDescContainer:"MethodAccordion-module_paramDescContainer__3e67r",paramDescContainer_separator:"MethodAccordion-module_paramDescContainer_separator__kMO4G",editDescBtn:"MethodAccordion-module_editDescBtn__A7HJn",deleteParamBtn:"MethodAccordion-module_deleteParamBtn__ot1Eq",editDescTooltipContent:"MethodAccordion-module_editDescTooltipContent__cdL-s",editDescTooltipContent_header:"MethodAccordion-module_editDescTooltipContent_header__n8OS6",requestAccordion:"MethodAccordion-module_requestAccordion__rJP92",responseAccordion:"MethodAccordion-module_responseAccordion__gFVeZ",requestAccordionSummary:"MethodAccordion-module_requestAccordionSummary__8RCHC",responseAccordionSummary:"MethodAccordion-module_responseAccordionSummary__xXxH8",responseAccordionSummary_title:"MethodAccordion-module_responseAccordionSummary_title__J744B",requestAccordionSummary_title:"MethodAccordion-module_requestAccordionSummary_title__m3bRC",readOnly:"MethodAccordion-module_readOnly__0-wNY"};export{o as default};
2
2
  //# sourceMappingURL=MethodAccordion.module.scss.js.map
@@ -1,2 +1,2 @@
1
- import{__rest as e,__awaiter as r}from"../../../node_modules/tslib/tslib.es6.js";import{j as t}from"../../../_virtual/jsx-runtime.js";import i,{useState as s,useEffect as o}from"react";import n from"../../../node_modules/html-react-parser/esm/index.mjs.js";const c=c=>{var{src:l,cache:a=!0}=c,d=e(c,["src","cache"]);const[m,f]=s(null);if(o(()=>{if(!l)return;"string"!=typeof l&&console.log({src:l});const e=l.startsWith("http")||l.startsWith("/"),t="svg-cache";r(void 0,void 0,void 0,function*(){try{let r=null;if(a&&e&&"caches"in window){const e=yield caches.open(t),i=yield e.match(l);if(i&&i.ok)return r=yield i.text(),void f(r)}if(e){const e=yield fetch(l),i=e.clone();if(r=yield e.text(),a&&"caches"in window){const e=yield caches.open(t);yield e.put(l,i)}}else r=l;if(r){const e=(e=>(new DOMParser).parseFromString(e,"image/svg+xml").querySelector("svg"))(r);if(e){const r=(new XMLSerializer).serializeToString(e);f(r)}}}catch(e){console.error("Error loading SVG:",e)}})},[l,d]),!m)return null;const h=n(m),u=Array.isArray(h)?h.find(e=>i.isValidElement(e)):h,p=i.cloneElement(u,d);return t.jsx(t.Fragment,{children:p})};export{c as default};
1
+ import{__rest as e,__awaiter as t}from"../../../node_modules/tslib/tslib.es6.js";import r,{useState as i,useEffect as o}from"react";import n from"../../../node_modules/html-react-parser/esm/index.mjs.js";const s=s=>{var{src:c,cache:l=!0}=s,a=e(s,["src","cache"]);const[d,m]=i(null);if(o(()=>{if(!c)return;"string"!=typeof c&&console.log({src:c});const e=c.startsWith("http")||c.startsWith("/"),r="svg-cache";t(void 0,void 0,void 0,function*(){try{let t=null;if(l&&e&&"caches"in window){const e=yield caches.open(r),i=yield e.match(c);if(i&&i.ok)return t=yield i.text(),void m(t)}if(e){const e=yield fetch(c),i=e.clone();if(t=yield e.text(),l&&"caches"in window){const e=yield caches.open(r);yield e.put(c,i)}}else t=c;if(t){const e=(e=>(new DOMParser).parseFromString(e,"image/svg+xml").querySelector("svg"))(t);if(e){const t=(new XMLSerializer).serializeToString(e);m(t)}}}catch(e){console.error("Error loading SVG:",e)}})},[c,a]),!d)return null;const f=n(d),h=Array.isArray(f)?f.find(e=>r.isValidElement(e)):f,u=r.cloneElement(h,a);return r.createElement(r.Fragment,null,u)};export{s as default};
2
2
  //# sourceMappingURL=SVGLoader.js.map
@@ -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,EAAU,KACR,IAAKP,EAAK,OACS,iBAARA,GAAkBQ,QAAQC,IAAI,CAAET,QAC3C,MAAMU,EAAQV,EAAIW,WAAW,SAAWX,EAAIW,WAAW,KAEjDC,EAAY,YAEUC,OAAA,OAAA,OAAA,EAAA,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,IAGC,CAACpC,EAAKE,KAEJE,EAAW,OAAO,KAGvB,MAAMiC,EAAYC,EAAMlC,GAElBmC,EAAoBC,MAAMC,QAAQJ,GACpCA,EAAUK,KAAMC,GAASC,EAAMC,eAAeF,IAC9CN,EAEES,EAAYF,EAAMG,aAAaR,EAAyCrC,GAE9E,OAAO8C,EAAAC,IAAAC,EAAAC,SAAA,CAAAC,SAAGN"}
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","createElement","Fragment"],"mappings":"4MAIA,MAcMA,EAA6CC,QAAAC,IAAEA,EAAGC,MAAEA,GAAQ,KAASC,EAAxBC,EAAAJ,EAAA,CAAA,MAAA,UACjD,MAAOK,EAAWC,GAAgBC,EAAwB,MA8D1D,GA5DAC,EAAU,KACR,IAAKP,EAAK,OACS,iBAARA,GAAkBQ,QAAQC,IAAI,CAAET,QAC3C,MAAMU,EAAQV,EAAIW,WAAW,SAAWX,EAAIW,WAAW,KAEjDC,EAAY,YAEUC,OAAA,OAAA,OAAA,EAAA,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,IAGC,CAACpC,EAAKE,KAEJE,EAAW,OAAO,KAGvB,MAAMiC,EAAYC,EAAMlC,GAElBmC,EAAoBC,MAAMC,QAAQJ,GACpCA,EAAUK,KAAMC,GAASC,EAAMC,eAAeF,IAC9CN,EAEES,EAAYF,EAAMG,aAAaR,EAAyCrC,GAE9E,OAAO0C,EAAAI,cAAAJ,EAAAK,SAAA,KAAGH"}
@@ -1,2 +1,2 @@
1
- import{j as e}from"../../../_virtual/jsx-runtime.js";import r from"../SVGLoader/SVGLoader.js";const a=({text:a,closeFunction:i,children:s,className:l=""})=>{var o,t;return e.jsxs("div",{className:`containerTitleDrawer ${l}`,children:[e.jsx("span",{"data-id":`${null===(t=null===(o=String(a))||void 0===o?void 0:o.toUpperCase())||void 0===t?void 0:t.replaceAll(" ","_")}_ID`,children:a}),s,i&&e.jsx(r,{className:"closeIcon",onClick:i,width:"1.5rem",height:"1.5rem"})]})};export{a as default};
1
+ import e from"react";import r from"../SVGLoader/SVGLoader.js";const t=({text:t,closeFunction:a,children:l,className:o=""})=>{var c,i;return e.createElement("div",{className:`containerTitleDrawer ${o}`},e.createElement("span",{"data-id":`${null===(i=null===(c=String(t))||void 0===c?void 0:c.toUpperCase())||void 0===i?void 0:i.replaceAll(" ","_")}_ID`},t),l,a&&e.createElement(r,{className:"closeIcon",onClick:a,width:"1.5rem",height:"1.5rem"}))};export{t as default};
2
2
  //# sourceMappingURL=SectionHead.js.map
@@ -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"}
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","React","createElement","_a","String","toUpperCase","replaceAll","SVGLoader","onClick","width","height"],"mappings":"8DAWA,MAAMA,EAA0C,EAAGC,OAAMC,gBAAeC,WAAUC,YAAY,eAC5F,OACEC,EAAKC,cAAA,MAAA,CAAAF,UAAW,wBAAwBA,KACtCC,EAAeC,cAAA,OAAA,CAAA,UAAA,qBAAGC,EAAAC,OAAOP,yBAAOQ,oCAAeC,WAAW,IAAK,WAAYT,GAC1EE,EAEAD,GAAiBG,gBAACM,EAAS,CAACP,UAAU,YAAYQ,QAASV,EAAeW,MAAM,SAASC,OAAO"}
@@ -1,2 +1,2 @@
1
- import{j as a}from"../../../_virtual/jsx-runtime.js";const e=({label:e,value:l,color:s,className:r="",dataId:t})=>{var o;const i="string"==typeof e?(null===(o=null==e?void 0:e.toUpperCase())||void 0===o?void 0:o.replaceAll(" ","_"))+"_LABEL_ID":t;return a.jsxs("div",{className:`drawerItemContainer ${r}`,children:[a.jsx("span",{className:"title","data-id":i,children:e}),a.jsx("span",{className:"text "+(s?`color-${s}`:""),children:l})]})};export{e as default};
1
+ import e from"react";const a=({label:a,value:t,color:l,className:r="",dataId:o})=>{var s;const c="string"==typeof a?(null===(s=null==a?void 0:a.toUpperCase())||void 0===s?void 0:s.replaceAll(" ","_"))+"_LABEL_ID":o;return e.createElement("div",{className:`drawerItemContainer ${r}`},e.createElement("span",{className:"title","data-id":c},a),e.createElement("span",{className:"text "+(l?`color-${l}`:"")},t))};export{a as default};
2
2
  //# sourceMappingURL=SimpleLabelValue.js.map
@@ -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"}
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","React","createElement"],"mappings":"qBAWA,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,EAAKC,cAAA,MAAA,CAAAP,UAAW,uBAAuBA,KACrCM,EAAAC,cAAA,OAAA,CAAMP,UAAU,kBAAiBE,GAC9BL,GAEHS,EAAMC,cAAA,OAAA,CAAAP,UAAW,SAAQD,EAAQ,SAASA,IAAU,KAAOD"}
@@ -1,2 +1,2 @@
1
- import{__rest as e}from"../../../node_modules/tslib/tslib.es6.js";import{j as t}from"../../../_virtual/jsx-runtime.js";import{useState as o,useEffect as s}from"react";import a from"../../../node_modules/@tippyjs/react/dist/tippy-react.esm.js";const i=i=>{var{children:n,content:r,success:l,onMouseEnter:c,onMouseLeave:d,visible:p,delay:m=[200,400],type:u="info",maxWidth:v=390,className:w,arrowWithBorder:b,disabled:h}=i,j=e(i,["children","content","success","onMouseEnter","onMouseLeave","visible","delay","type","maxWidth","className","arrowWithBorder","disabled"]);const[f,y]=o(16);return s(()=>{const e=e=>{y(t=>t!==e?e:t)};window.applicationUIScaling&&"function"==typeof window.applicationUIScaling.addEventHandler&&window.applicationUIScaling.addEventHandler(e)},[]),t.jsx(a,Object.assign({visible:p,allowHTML:"string"!=typeof r,interactive:!0,maxWidth:v/16*f,delay:m,content:r,placement:"bottom-start",className:`${l?"success":""} ${u} ${w||""} ${b?"arrow-with-border":""}`,disabled:h},j,{children:t.jsx("div",{className:"tooltip-custom-wrapper",onMouseEnter:c,onMouseLeave:d,children:t.jsx("div",{className:"tooltip-custom-wrapper",onMouseEnter:c,onMouseLeave:d,children:n})})}))};export{i as default};
1
+ import{__rest as e}from"../../../node_modules/tslib/tslib.es6.js";import t,{useState as o,useEffect as a}from"react";import s from"../../../node_modules/@tippyjs/react/dist/tippy-react.esm.js";const n=n=>{var{children:i,content:r,success:c,onMouseEnter:l,onMouseLeave:d,visible:p,delay:m=[200,400],type:u="info",maxWidth:v=390,className:w,arrowWithBorder:b,disabled:y}=n,E=e(n,["children","content","success","onMouseEnter","onMouseLeave","visible","delay","type","maxWidth","className","arrowWithBorder","disabled"]);const[M,f]=o(16);return a(()=>{const e=e=>{f(t=>t!==e?e:t)};window.applicationUIScaling&&"function"==typeof window.applicationUIScaling.addEventHandler&&window.applicationUIScaling.addEventHandler(e)},[]),t.createElement(s,Object.assign({visible:p,allowHTML:"string"!=typeof r,interactive:!0,maxWidth:v/16*M,delay:m,content:r,placement:"bottom-start",className:`${c?"success":""} ${u} ${w||""} ${b?"arrow-with-border":""}`,disabled:y},E),t.createElement("div",{className:"tooltip-custom-wrapper",onMouseEnter:l,onMouseLeave:d},t.createElement("div",{className:"tooltip-custom-wrapper",onMouseEnter:l,onMouseLeave:d},i)))};export{n as default};
2
2
  //# sourceMappingURL=Tooltip.js.map
@@ -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":"mPAmBA,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,EAAU,KACR,MAAMC,EAAwBC,IAC5BJ,EAAiBK,GAAUA,IAASD,EAAWA,EAAWC,IAK1DC,OAAOC,sBAEgD,mBAAhDD,OAAOC,qBAAqBC,iBAGnCF,OAAOC,qBAAqBC,gBAAgBL,IAE7C,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
+ {"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","React","createElement","Tippy","Object","assign","allowHTML","interactive","placement"],"mappings":"iMAmBA,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,EAAU,KACR,MAAMC,EAAwBC,IAC5BJ,EAAiBK,GAAUA,IAASD,EAAWA,EAAWC,IAK1DC,OAAOC,sBAEgD,mBAAhDD,OAAOC,qBAAqBC,iBAGnCF,OAAOC,qBAAqBC,gBAAgBL,IAE7C,IAGDM,EAAAC,cAACC,EAAKC,OAAAC,OAAA,CACJvB,QAASA,EACTwB,UAA8B,iBAAZ5B,EAClB6B,aAAW,EACXtB,SAAWA,EAAW,GAAMM,EAC5BR,MAAOA,EACPL,QAASA,EACT8B,UAAU,eACVtB,UAAW,GAAGP,EAAU,UAAY,MAAMK,KAAQE,GAAa,MAC7DC,EAAkB,oBAAsB,KAE1CC,SAAUA,GACNC,GAEJY,EACEC,cAAA,MAAA,CAAAhB,UAAU,yBACVN,aAAcA,EACdC,aAAcA,GAEdoB,EAAAC,cAAA,MAAA,CACEhB,UAAU,yBACVN,aAAcA,EACdC,aAAcA,GAEbJ"}
@@ -1,2 +1,2 @@
1
- import{j as o}from"../../../_virtual/jsx-runtime.js";import{d as s}from"../../../_virtual/index.js";import i from"../SVGLoader/SVGLoader.js";import n from"../../assets/icons/close-circle.svg.js";import e from"../../assets/icons/infoIcon.svg.js";const r=({status:r="info",content:t,onSubmit:c,onCancel:a,onClose:l,open:m,size:d="xs",icon:j=o.jsx(o.Fragment,{children:o.jsx(i,{src:e,width:"4.0625rem",height:"4.0625rem"})}),noActions:x=!1,closeIcon:h})=>{const g=()=>{l(),a&&a.onClick&&a.onClick()},u=o.jsxs("div",{className:"common-dialog",children:[j&&o.jsx("div",{className:"confirmation-dialog-header",children:o.jsx("div",{className:`icon ${r}`,children:j})}),o.jsx("div",{className:"close-icon",children:null!=h?h:o.jsx(i,{src:n,width:"1.5rem",height:"1.5rem",onClick:g})}),t,x?null:o.jsxs("div",{className:"confirmation-dialog-footer",style:{marginBottom:a||c?"1.5rem":"1rem"},children:[a&&o.jsx(s.Button,Object.assign({},a,{onClick:g,variant:a.variant||"outlined",color:a.color||"normal",children:a.text})),c&&o.jsx(s.Button,Object.assign({},c,{variant:c.variant||"contained",color:c.color||"secondary",children:c.text}))]})]});return o.jsx(s.Dialog,{open:m,onClose:g,content:u,fullWidth:!1,size:d,id:"common-dialog"})};export{r as default};
1
+ import e from"react";import{d as o}from"../../../_virtual/index.js";import t from"../SVGLoader/SVGLoader.js";import n from"../../assets/icons/close-circle.svg.js";import a from"../../assets/icons/infoIcon.svg.js";const c=({status:c="info",content:r,onSubmit:i,onCancel:l,onClose:s,open:m,size:d="xs",icon:g=e.createElement(e.Fragment,null,e.createElement(t,{src:a,width:"4.0625rem",height:"4.0625rem"})),noActions:f=!1,closeIcon:u})=>{const v=()=>{s(),l&&l.onClick&&l.onClick()},E=e.createElement("div",{className:"common-dialog"},g&&e.createElement("div",{className:"confirmation-dialog-header"},e.createElement("div",{className:`icon ${c}`},g)),e.createElement("div",{className:"close-icon"},null!=u?u:e.createElement(t,{src:n,width:"1.5rem",height:"1.5rem",onClick:v})),r,f?null:e.createElement("div",{className:"confirmation-dialog-footer",style:{marginBottom:l||i?"1.5rem":"1rem"}},l&&e.createElement(o.Button,Object.assign({},l,{onClick:v,variant:l.variant||"outlined",color:l.color||"normal"}),l.text),i&&e.createElement(o.Button,Object.assign({},i,{variant:i.variant||"contained",color:i.color||"secondary"}),i.text)));return e.createElement(o.Dialog,{open:m,onClose:v,content:E,fullWidth:!1,size:d,id:"common-dialog"})};export{c as default};
2
2
  //# sourceMappingURL=index.js.map
@@ -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,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
+ {"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","React","createElement","Fragment","SVGLoader","src","InfoIcon","width","height","noActions","closeIcon","handleClose","onClick","body","className","Closecircle","style","marginBottom","Button","Object","assign","variant","color","text","Dialog","fullWidth","id"],"mappings":"qNAQM,MAAAA,EAAe,EACnBC,SAAS,OACTC,UACAC,WACAC,WACAC,UACAC,OACAC,OAAO,KACPC,OACEC,EAAAC,cAAAD,EAAAE,SAAA,KACEF,EAACC,cAAAE,EAAU,CAAAC,IAAKC,EAAUC,MAAM,YAAYC,OAAO,eAGvDC,aAAY,EACZC,gBAEA,MAAMC,EAAc,KAClBd,IAEID,GAAYA,EAASgB,SACvBhB,EAASgB,WAIPC,EACJZ,EAAKC,cAAA,MAAA,CAAAY,UAAU,iBACZd,GACCC,EAAKC,cAAA,MAAA,CAAAY,UAAU,8BACbb,EAAKC,cAAA,MAAA,CAAAY,UAAW,QAAQrB,KAAWO,IAGvCC,EAAAC,cAAA,MAAA,CAAKY,UAAU,cACZJ,QAAAA,EACCT,EAAAC,cAACE,EAAU,CAAAC,IAAKU,EAAaR,MAAO,SAAUC,OAAQ,SAAUI,QAASD,KAI5EjB,EACEe,EAAY,KACbR,EACEC,cAAA,MAAA,CAAAY,UAAU,6BACVE,MAAO,CAAEC,aAAcrB,GAAYD,EAAW,SAAW,SAExDC,GACCK,EAACC,cAAAgB,SACKC,OAAAC,OAAA,GAAAxB,EACJ,CAAAgB,QAASD,EACTU,QAASzB,EAASyB,SAAW,WAC7BC,MAAO1B,EAAS0B,OAAS,WAExB1B,EAAS2B,MAGb5B,GACCM,EAACC,cAAAgB,EAAAA,wBACKvB,EAAQ,CACZ0B,QAAS1B,EAAS0B,SAAW,YAC7BC,MAAO3B,EAAS2B,OAAS,cAExB3B,EAAS4B,QAQtB,OACEtB,EAAAC,cAACsB,EAAMA,OAAA,CACL1B,KAAMA,EACND,QAASc,EACTjB,QAASmB,EACTY,WAAW,EACX1B,KAAMA,EACN2B,GAAG"}
@@ -1,2 +1,2 @@
1
- import{j as e}from"../../../_virtual/jsx-runtime.js";import{useState as a}from"react";import{d as l}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 o from"../../assets/icons/EditIcon.svg.js";import d from"../../assets/icons/AddRow.svg.js";import n 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:C,isFormOpen:N,setIsFormOpen:g,saveNewRow:w,readOnly:T,isRequest:f=!0})=>{var D,I,E,S,q,B,k,L,_,A,P,O,R,F,M,V,W,X,G,z,H,U,$,K,Q,Y,Z;const[J,ee]=a(""),[ae,le]=a(null),[ie,te]=a(null),[se,oe]=a([]),{values:de,errors:ne,setFieldValue:re,isValid:ce,submitForm:me,resetForm:ue}=m({validateOnMount:!0,initialValues:{name:"",in:f?"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 a,l,i,t;e&&!(null===(l=null===(a=null==e?void 0:e.schema)||void 0===a?void 0:a.items)||void 0===l?void 0:l.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(a=>e.jsx("th",{className:`tableHeadCell ${a.classes||""}`,style:{width:a.width,minWidth:a.minWidth},children:e.jsx("div",{className:"headContainer","data-id":`${"string"==typeof a.label?a.label.toUpperCase().replace(/[^a-zA-Z0-9]+/g,"_"):"UNKNOWN_LABEL"}_COLUMN`,children:a.label})},a.id))})}),e.jsxs("tbody",{className:"tableBody","data-id":"TABLE_BODY",children:[null==C?void 0:C.map((a,l)=>e.jsx("tr",{"data-i":l,className:"row",children:null==y?void 0:y.map(l=>{const i="_"!==a[l.id]&&e.jsx("div",{"data-id":"TEXT_DESCRIPTION",className:"tableData",style:{width:l.width,minWidth:l.minWidth},children:a[l.id]});return e.jsx("td",{style:{width:l.width,minWidth:l.minWidth},children:i},l.id)})},l)),0===(null==C?void 0:C.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"})})})}),N&&!T?e.jsxs("tr",{className:"row",children:[e.jsx("td",{children:e.jsx("div",{"data-id":"TEXT_DESCRIPTION",className:"tableData",children:e.jsx(l.Input,{placeholder:"Parameter name",size:"large",type:"text",onChange:e=>{(""===e||j.ASCII.test(e))&&re("name",e)},value:de.name,disabled:T})})},"Parameter name"),e.jsx("td",{children:e.jsxs("div",{"data-id":"TEXT_DESCRIPTION",className:"tableData",children:[e.jsx(l.SelectGroupV2,{disabled:T,value:{label:b(de.in),value:de.in},onChange:e=>{var a;re("in",null===(a=null==e?void 0:e.value)||void 0===a?void 0:a.toLowerCase()),"in"==(null==e?void 0:e.value)&&re("required",!0)},options:[{list:f?[{label:"Query",value:"query"},{label:"Header",value:"header"},{label:"Path",value:"path"}]:[{label:"Header",value:"header"}]}],errorMsg:!!ne.in&&ne.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(l.SelectGroupV2,{disabled:T,clearable:!1,value:{label:b(null===(D=null==de?void 0:de.schema)||void 0===D?void 0:D.type),value:null===(I=null==de?void 0:de.schema)||void 0===I?void 0:I.type},errorMsg:!!ne.schema&&ne.schema,onChange:e=>{var a,l,i;if(re("schema.type",null===(a=null==e?void 0:e.value)||void 0===a?void 0:a.toLowerCase()),"array"!=(null===(l=e.value)||void 0===l?void 0:l.toLowerCase())||de.schema.items||re("schema.items",{}),"array"!=(null===(i=e.value)||void 0===i?void 0:i.toLowerCase())&&de.schema.items){const e=Object.assign({},de.schema);delete e.items,re("schema",e)}},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==de?void 0:de.schema)||void 0===E?void 0:E.type)&&"array"===(null===(S=null==de?void 0:de.schema)||void 0===S?void 0:S.type.toLowerCase())?e.jsx(l.SelectGroupV2,{disabled:T,clearable:!1,value:{label:b(null===(B=null===(q=null==de?void 0:de.schema)||void 0===q?void 0:q.items)||void 0===B?void 0:B.type),value:null===(L=null===(k=de.schema)||void 0===k?void 0:k.items)||void 0===L?void 0:L.type},errorMsg:!!(null===(A=null===(_=null==ne?void 0:ne.schema)||void 0===_?void 0:_.items)||void 0===A?void 0:A.type)&&(null===(O=null===(P=null==ne?void 0:ne.schema)||void 0===P?void 0:P.items)||void 0===O?void 0:O.type),onChange:e=>{var a,l,i,t,s;if(re("schema.items.type",null===(a=null==e?void 0:e.value)||void 0===a?void 0:a.toLowerCase()),"array"!=(null===(l=e.value)||void 0===l?void 0:l.toLowerCase())||(null===(i=de.schema.items)||void 0===i?void 0:i.items)||re("schema.items.items",{}),"array"!=(null===(t=e.value)||void 0===t?void 0:t.toLowerCase())&&(null===(s=de.schema.items)||void 0===s?void 0:s.items)){const e=Object.assign({},de.schema.items);null==e||delete e.items,re("schema.items",e)}},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.jsx("div",{"data-id":"TEXT_DESCRIPTION",className:"tableData",children:e.jsx(i,{disabled:"array"==(null===(F=null===(R=null==de?void 0:de.schema)||void 0===R?void 0:R.type)||void 0===F?void 0:F.toLowerCase())||"object"==(null===(V=null===(M=null==de?void 0:de.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=>te(e),content:e.jsxs("div",{className:c.editDescTooltipContent,children:[e.jsx("p",{className:c.editDescTooltipContent_header,children:"Enum"}),!!(null===(W=null==de?void 0:de.schema)||void 0===W?void 0:W.enum)&&!!(null===(X=null==de?void 0:de.schema)||void 0===X?void 0:X.enum.length)&&(null===(z=null===(G=null==de?void 0:de.schema)||void 0===G?void 0:G.enum)||void 0===z?void 0:z.map((a,i)=>e.jsx(l.Input,{className:"methodDescForEnum",required:!0,clearable:!1,placeholder:"Enter Enum value...",value:a,onChange:e=>{re(`schema.enum[${i}]`,e)}},i))),se&&(null==se?void 0:se.map((a,i)=>e.jsx(l.Input,{className:"methodDescForEnum",required:!0,clearable:!1,placeholder:"Enter Enum value...",value:a,onChange:e=>{let a=[...se];a[i]=e,oe(a)}},i))),e.jsxs("p",{className:"addEnumButton",onClick:()=>{oe(e=>[...e,""])},children:[e.jsx(t,{src:r}),"Add New Enum"]}),!T&&e.jsx(l.Button,{className:c.editDescTooltipContent_btn,variant:"outlined",size:"small",type:"button",onClick:()=>{var e;re("schema.enum",[...null===(e=null==de?void 0:de.schema)||void 0===e?void 0:e.enum,...se]),oe([]),null==ie||ie.hide()},disabled:se.length>0&&(null==se?void 0:se.filter(e=>!e).length)||(null===(H=null==de?void 0:de.schema)||void 0===H?void 0:H.enum.length)>0&&(null===($=null===(U=null==de?void 0:de.schema)||void 0===U?void 0:U.enum)||void 0===$?void 0:$.filter(e=>!e).length),children:"Apply"})]}),children:e.jsx(l.Button,{className:c.editDescBtn,id:"EnumButton",variant:"link",color:"action",disabled:"array"==(null===(Q=null===(K=null==de?void 0:de.schema)||void 0===K?void 0:K.type)||void 0===Q?void 0:Q.toLowerCase())||"object"==(null===(Z=null===(Y=null==de?void 0:de.schema)||void 0===Y?void 0:Y.type)||void 0===Z?void 0:Z.toLowerCase()),endIcon:e.jsx(t,{id:"enumIcon",src:n,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:de.required?"True":"False"}):e.jsx(l.Switch,{checked:!(!de||!de.in||"path"!=de.in.toLowerCase())||de.required,disabled:de&&de.in&&"path"==de.in.toLowerCase(),onClick:()=>{T||re("required",!de.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=>le(e),content:e.jsxs("div",{className:c.editDescTooltipContent,children:[e.jsx("p",{className:c.editDescTooltipContent_header,children:"Description"}),e.jsx(l.TextArea,{value:J||de.description,onChange:e=>{(""===e||j.ASCII.test(e))&&ee(e)},disabled:T,placeholder:"Describe parameter...",maxLength:120}),!T&&e.jsx(l.Button,{className:c.editDescTooltipContent_btn,variant:"outlined",size:"small",onClick:()=>{re("description",null==J?void 0:J.trim()),null==ae||ae.hide()},disabled:""===(null==J?void 0:J.trim()),children:"Apply"})]}),children:e.jsxs(l.Button,{className:c.editDescBtn,variant:"link",color:"action",endIcon:e.jsx(t,{src:o,width:"1.5rem",height:"1.5rem"}),children:[T?"View ":"Add "," Description"]})}),e.jsx("div",{className:c.paramDescContainer_separator}),!T&&e.jsx(l.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:!!de.name.trim(),content:"Parameter name can't be empty ",children:e.jsx(l.Button,{className:c.deleteParamBtn,variant:"link",color:"success",disabled:!de.name.trim(),endIcon:e.jsx(t,{src:d,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:6,children:e.jsx(l.Button,{variant:"link",color:"primary",onClick:()=>{g(e=>e?void 0:f?"Req":"Res")},children:"+ Add Parameter"})})},"addNew")})]})]})})})};export{x as default};
1
+ import e,{useState as a}from"react";import{d as t}from"../../../_virtual/index.js";import l from"../Tooltip/Tooltip.js";import i from"../SVGLoader/SVGLoader.js";import n from"../../assets/icons/DeleteIcon.svg.js";import o from"../../assets/icons/EditIcon.svg.js";import r from"../../assets/icons/AddRow.svg.js";import d from"../../assets/icons/Plus.svg.js";import s from"../../assets/icons/PlusSquare.svg.js";import m from"../MethodAccordion/MethodAccordion.module.scss.js";import{useFormik as c}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 E from"../../constants/regex.js";const y=({id:y,headCells:C,data:N,isFormOpen:g,setIsFormOpen:w,saveNewRow:k,readOnly:T,isRequest:f=!0})=>{var D,I,S,q,j,B,L,A,P,_,O,R,F,M,x,V,W,X,G,z,H,U,$,K,Q,Y,Z;const[J,ee]=a(""),[ae,te]=a(null),[le,ie]=a(null),[ne,oe]=a([]),{values:re,errors:de,setFieldValue:se,isValid:me,submitForm:ce,resetForm:ue}=c({validateOnMount:!0,initialValues:{name:"",in:f?"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 a,t,l,i;e&&!(null===(t=null===(a=null==e?void 0:e.schema)||void 0===a?void 0:a.items)||void 0===t?void 0:t.type)&&(null===(i=null===(l=null==e?void 0:e.schema)||void 0===l?void 0:l.items)||void 0===i||delete i.type),k(e),w(void 0),ee(""),ue()}});return e.createElement("div",{className:"tableSectionContainer"},e.createElement("div",{className:"tableContainer"},e.createElement("table",{id:y||"",className:"table borderRadiusTop borderRadiusBottom"},e.createElement("thead",{className:"tableHead"},e.createElement("tr",null,null==C?void 0:C.map(a=>e.createElement("th",{key:a.id,className:`tableHeadCell ${a.classes||""}`,style:{width:a.width,minWidth:a.minWidth}},e.createElement("div",{className:"headContainer","data-id":`${"string"==typeof a.label?a.label.toUpperCase().replace(/[^a-zA-Z0-9]+/g,"_"):"UNKNOWN_LABEL"}_COLUMN`},a.label))))),e.createElement("tbody",{className:"tableBody","data-id":"TABLE_BODY"},null==N?void 0:N.map((a,t)=>e.createElement("tr",{key:t,"data-i":t,className:"row"},null==C?void 0:C.map(t=>{const l="_"!==a[t.id]&&e.createElement("div",{"data-id":"TEXT_DESCRIPTION",className:"tableData",style:{width:t.width,minWidth:t.minWidth}},a[t.id]);return e.createElement("td",{key:t.id,style:{width:t.width,minWidth:t.minWidth}},l)}))),0===(null==N?void 0:N.length)&&T&&e.createElement("tr",{className:"fallbackTableRow"},e.createElement("td",{className:"fallbackContainer",colSpan:null==C?void 0:C.length},e.createElement("div",{className:"fallbackTextContainer"},e.createElement("span",{className:"fallbackText"}," No Data Available")))),g&&!T?e.createElement("tr",{className:"row"},e.createElement("td",{key:"Parameter name"},e.createElement("div",{"data-id":"TEXT_DESCRIPTION",className:"tableData"},e.createElement(t.Input,{placeholder:"Parameter name",size:"large",type:"text",onChange:e=>{(""===e||E.ASCII.test(e))&&se("name",e)},value:re.name,disabled:T}))),e.createElement("td",{key:"parameter in"},e.createElement("div",{"data-id":"TEXT_DESCRIPTION",className:"tableData"},e.createElement(t.SelectGroupV2,{disabled:T,value:{label:b(re.in),value:re.in},onChange:e=>{var a;se("in",null===(a=null==e?void 0:e.value)||void 0===a?void 0:a.toLowerCase()),"in"==(null==e?void 0:e.value)&&se("required",!0)},options:[{list:f?[{label:"Query",value:"query"},{label:"Header",value:"header"},{label:"Path",value:"path"}]:[{label:"Header",value:"header"}]}],errorMsg:!!de.in&&de.in,isMultiple:!1,withSearch:!1,clearable:!1})," ")),e.createElement("td",{key:"parameter schema type"},e.createElement("div",{"data-id":"TEXT_DESCRIPTION",className:"tableData select-inputs"},e.createElement(t.SelectGroupV2,{disabled:T,clearable:!1,value:{label:b(null===(D=null==re?void 0:re.schema)||void 0===D?void 0:D.type),value:null===(I=null==re?void 0:re.schema)||void 0===I?void 0:I.type},errorMsg:!!de.schema&&de.schema,onChange:e=>{var a,t,l;if(se("schema.type",null===(a=null==e?void 0:e.value)||void 0===a?void 0:a.toLowerCase()),"array"!=(null===(t=e.value)||void 0===t?void 0:t.toLowerCase())||re.schema.items||se("schema.items",{}),"array"!=(null===(l=e.value)||void 0===l?void 0:l.toLowerCase())&&re.schema.items){const e=Object.assign({},re.schema);delete e.items,se("schema",e)}},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===(S=null==re?void 0:re.schema)||void 0===S?void 0:S.type)&&"array"===(null===(q=null==re?void 0:re.schema)||void 0===q?void 0:q.type.toLowerCase())?e.createElement(t.SelectGroupV2,{disabled:T,clearable:!1,value:{label:b(null===(B=null===(j=null==re?void 0:re.schema)||void 0===j?void 0:j.items)||void 0===B?void 0:B.type),value:null===(A=null===(L=re.schema)||void 0===L?void 0:L.items)||void 0===A?void 0:A.type},errorMsg:!!(null===(_=null===(P=null==de?void 0:de.schema)||void 0===P?void 0:P.items)||void 0===_?void 0:_.type)&&(null===(R=null===(O=null==de?void 0:de.schema)||void 0===O?void 0:O.items)||void 0===R?void 0:R.type),onChange:e=>{var a,t,l,i,n;if(se("schema.items.type",null===(a=null==e?void 0:e.value)||void 0===a?void 0:a.toLowerCase()),"array"!=(null===(t=e.value)||void 0===t?void 0:t.toLowerCase())||(null===(l=re.schema.items)||void 0===l?void 0:l.items)||se("schema.items.items",{}),"array"!=(null===(i=e.value)||void 0===i?void 0:i.toLowerCase())&&(null===(n=re.schema.items)||void 0===n?void 0:n.items)){const e=Object.assign({},re.schema.items);null==e||delete e.items,se("schema.items",e)}},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}):"")),e.createElement("td",{key:"parameter enum"},e.createElement("div",{"data-id":"TEXT_DESCRIPTION",className:"tableData"},e.createElement(l,{disabled:"array"==(null===(M=null===(F=null==re?void 0:re.schema)||void 0===F?void 0:F.type)||void 0===M?void 0:M.toLowerCase())||"object"==(null===(V=null===(x=null==re?void 0:re.schema)||void 0===x?void 0:x.type)||void 0===V?void 0:V.toLowerCase()),arrowWithBorder:!0,placement:"bottom-end",type:"function",trigger:"click",delay:[0,0],onCreate:e=>ie(e),content:e.createElement("div",{className:m.editDescTooltipContent},e.createElement("p",{className:m.editDescTooltipContent_header},"Enum"),!!(null===(W=null==re?void 0:re.schema)||void 0===W?void 0:W.enum)&&!!(null===(X=null==re?void 0:re.schema)||void 0===X?void 0:X.enum.length)&&(null===(z=null===(G=null==re?void 0:re.schema)||void 0===G?void 0:G.enum)||void 0===z?void 0:z.map((a,l)=>e.createElement(t.Input,{key:l,className:"methodDescForEnum",required:!0,clearable:!1,placeholder:"Enter Enum value...",value:a,onChange:e=>{se(`schema.enum[${l}]`,e)}}))),ne&&(null==ne?void 0:ne.map((a,l)=>e.createElement(t.Input,{key:l,className:"methodDescForEnum",required:!0,clearable:!1,placeholder:"Enter Enum value...",value:a,onChange:e=>{let a=[...ne];a[l]=e,oe(a)}}))),e.createElement("p",{className:"addEnumButton",onClick:()=>{oe(e=>[...e,""])}},e.createElement(i,{src:s}),"Add New Enum"),!T&&e.createElement(t.Button,{className:m.editDescTooltipContent_btn,variant:"outlined",size:"small",type:"button",onClick:()=>{var e;se("schema.enum",[...null===(e=null==re?void 0:re.schema)||void 0===e?void 0:e.enum,...ne]),oe([]),null==le||le.hide()},disabled:ne.length>0&&(null==ne?void 0:ne.filter(e=>!e).length)||(null===(H=null==re?void 0:re.schema)||void 0===H?void 0:H.enum.length)>0&&(null===($=null===(U=null==re?void 0:re.schema)||void 0===U?void 0:U.enum)||void 0===$?void 0:$.filter(e=>!e).length)},"Apply"))},e.createElement(t.Button,{className:m.editDescBtn,id:"EnumButton",variant:"link",color:"action",disabled:"array"==(null===(Q=null===(K=null==re?void 0:re.schema)||void 0===K?void 0:K.type)||void 0===Q?void 0:Q.toLowerCase())||"object"==(null===(Z=null===(Y=null==re?void 0:re.schema)||void 0===Y?void 0:Y.type)||void 0===Z?void 0:Z.toLowerCase()),endIcon:e.createElement(i,{id:"enumIcon",src:d,width:"1.5rem",height:"1.5rem"})},"Add")))),e.createElement("td",{key:"parameter required"},e.createElement("div",{"data-id":"is required",className:"tableData"},T?e.createElement(e.Fragment,null,re.required?"True":"False"):e.createElement(t.Switch,{checked:!(!re||!re.in||"path"!=re.in.toLowerCase())||re.required,disabled:re&&re.in&&"path"==re.in.toLowerCase(),onClick:()=>{T||se("required",!re.required)}}))),e.createElement("td",{key:"parameter schema desc"},e.createElement("div",{"data-id":"TEXT_DESCRIPTION",className:"tableData"},e.createElement("div",{className:m.paramDescContainer},e.createElement(l,{arrowWithBorder:!0,placement:"bottom-end",type:"function",trigger:"click",delay:[0,0],onCreate:e=>te(e),content:e.createElement("div",{className:m.editDescTooltipContent},e.createElement("p",{className:m.editDescTooltipContent_header},"Description"),e.createElement(t.TextArea,{value:J||re.description,onChange:e=>{(""===e||E.ASCII.test(e))&&ee(e)},disabled:T,placeholder:"Describe parameter...",maxLength:120}),!T&&e.createElement(t.Button,{className:m.editDescTooltipContent_btn,variant:"outlined",size:"small",onClick:()=>{se("description",null==J?void 0:J.trim()),null==ae||ae.hide()},disabled:""===(null==J?void 0:J.trim())},"Apply"))},e.createElement(t.Button,{className:m.editDescBtn,variant:"link",color:"action",endIcon:e.createElement(i,{src:o,width:"1.5rem",height:"1.5rem"})},T?"View ":"Add "," Description")),e.createElement("div",{className:m.paramDescContainer_separator}),!T&&e.createElement(t.Button,{className:m.deleteParamBtn,variant:"link",color:"error",endIcon:e.createElement(i,{src:n,width:"1.125rem",height:"1.125rem"}),onClick:()=>{ue(),ee(""),w(void 0)}}),!T&&e.createElement(l,{disabled:!!re.name.trim(),content:"Parameter name can't be empty "},e.createElement(t.Button,{className:m.deleteParamBtn,variant:"link",color:"success",disabled:!re.name.trim(),endIcon:e.createElement(i,{src:r,width:"0.125rem",height:"0.125rem"}),onClick:()=>{ee(""),ce()}})))," "))):e.createElement(e.Fragment,null,!T&&e.createElement("tr",{key:"addNew","data-i":"addNew",className:"row"},e.createElement("td",{colSpan:6},e.createElement(t.Button,{variant:"link",color:"primary",onClick:()=>{w(e=>e?void 0:f?"Req":"Res")}},"+ Add Parameter"))))))))};export{y as default};
2
2
  //# sourceMappingURL=table.js.map