@kuadrant/kuadrant-backstage-plugin-frontend 0.0.2-dev-3d7caf4 → 0.0.2-dev-24d0757
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.
- package/dist/assets/empty-state-illustration.png +0 -0
- package/dist/components/ApiKeyManagementTab/ApiKeyManagementTab.esm.js +6 -1
- package/dist/components/ApiKeyManagementTab/ApiKeyManagementTab.esm.js.map +1 -1
- package/dist/components/ApiProductDetailPage/ApiProductDetailPage.esm.js +248 -0
- package/dist/components/ApiProductDetailPage/ApiProductDetailPage.esm.js.map +1 -0
- package/dist/components/ApiProductDetailPage/index.esm.js +2 -0
- package/dist/components/ApiProductDetailPage/index.esm.js.map +1 -0
- package/dist/components/ApiProductDetails/ApiProductDetails.esm.js +86 -0
- package/dist/components/ApiProductDetails/ApiProductDetails.esm.js.map +1 -0
- package/dist/components/ApiProductInfoCard/ApiProductInfoCard.esm.js +24 -43
- package/dist/components/ApiProductInfoCard/ApiProductInfoCard.esm.js.map +1 -1
- package/dist/components/ApprovalQueueTable/ApprovalQueueTable.esm.js +2 -1
- package/dist/components/ApprovalQueueTable/ApprovalQueueTable.esm.js.map +1 -1
- package/dist/components/CreateAPIProductDialog/CreateAPIProductDialog.esm.js +148 -134
- package/dist/components/CreateAPIProductDialog/CreateAPIProductDialog.esm.js.map +1 -1
- package/dist/components/EditAPIProductDialog/EditAPIProductDialog.esm.js +104 -128
- package/dist/components/EditAPIProductDialog/EditAPIProductDialog.esm.js.map +1 -1
- package/dist/components/KuadrantPage/KuadrantPage.esm.js +328 -125
- package/dist/components/KuadrantPage/KuadrantPage.esm.js.map +1 -1
- package/dist/components/MyApiKeysTable/MyApiKeysTable.esm.js +8 -2
- package/dist/components/MyApiKeysTable/MyApiKeysTable.esm.js.map +1 -1
- package/dist/index.d.ts +2 -1
- package/dist/index.esm.js +1 -1
- package/dist/plugin.esm.js +8 -1
- package/dist/plugin.esm.js.map +1 -1
- package/dist/utils/validation.esm.js +1 -11
- package/dist/utils/validation.esm.js.map +1 -1
- package/dist-scalprum/{internal.plugin-kuadrant.793ab10dddb55e70abe2.js → internal.plugin-kuadrant.95817f34e88db81b5e8f.js} +2 -2
- package/dist-scalprum/internal.plugin-kuadrant.95817f34e88db81b5e8f.js.map +1 -0
- package/dist-scalprum/plugin-manifest.json +2 -2
- package/dist-scalprum/static/2759.fceb317f.chunk.js +2 -0
- package/dist-scalprum/static/2759.fceb317f.chunk.js.map +1 -0
- package/dist-scalprum/static/2928.4303c12e.chunk.js +3 -0
- package/dist-scalprum/static/2928.4303c12e.chunk.js.map +1 -0
- package/dist-scalprum/static/2967.ac3a4bee.chunk.js +2 -0
- package/dist-scalprum/static/2967.ac3a4bee.chunk.js.map +1 -0
- package/dist-scalprum/static/{6979.9699b350.chunk.js → 2987.1da15560.chunk.js} +2 -2
- package/dist-scalprum/static/2987.1da15560.chunk.js.map +1 -0
- package/dist-scalprum/static/3459.5c90b5a3.chunk.js +2 -0
- package/dist-scalprum/static/3459.5c90b5a3.chunk.js.map +1 -0
- package/dist-scalprum/static/3503.66b6e510.chunk.js +2 -0
- package/dist-scalprum/static/3503.66b6e510.chunk.js.map +1 -0
- package/dist-scalprum/static/{3650.aa8552f3.chunk.js → 3650.515c743a.chunk.js} +2 -2
- package/dist-scalprum/static/3650.515c743a.chunk.js.map +1 -0
- package/dist-scalprum/static/4682.6959fcd1.chunk.js +2 -0
- package/dist-scalprum/static/4682.6959fcd1.chunk.js.map +1 -0
- package/dist-scalprum/static/5010.a4aa0f8e.chunk.js +3 -0
- package/dist-scalprum/static/5010.a4aa0f8e.chunk.js.map +1 -0
- package/dist-scalprum/static/5453.280127dd.chunk.js +2 -0
- package/dist-scalprum/static/5453.280127dd.chunk.js.map +1 -0
- package/dist-scalprum/static/6422.97baf774.chunk.js +2 -0
- package/dist-scalprum/static/6422.97baf774.chunk.js.map +1 -0
- package/dist-scalprum/static/7791.12162a71.chunk.js +2 -0
- package/dist-scalprum/static/7791.12162a71.chunk.js.map +1 -0
- package/dist-scalprum/static/8799.7c749838.chunk.js +2 -0
- package/dist-scalprum/static/8799.7c749838.chunk.js.map +1 -0
- package/dist-scalprum/static/empty-state-illustration.7e3ad5a9..png +0 -0
- package/dist-scalprum/static/exposed-PluginRoot.a5792fb2.chunk.js +2 -0
- package/dist-scalprum/static/exposed-PluginRoot.a5792fb2.chunk.js.map +1 -0
- package/package.json +1 -1
- package/dist-scalprum/internal.plugin-kuadrant.793ab10dddb55e70abe2.js.map +0 -1
- package/dist-scalprum/static/2120.44884438.chunk.js +0 -3
- package/dist-scalprum/static/2120.44884438.chunk.js.map +0 -1
- package/dist-scalprum/static/2967.c684efaf.chunk.js +0 -2
- package/dist-scalprum/static/2967.c684efaf.chunk.js.map +0 -1
- package/dist-scalprum/static/3650.aa8552f3.chunk.js.map +0 -1
- package/dist-scalprum/static/5010.acf9a415.chunk.js +0 -3
- package/dist-scalprum/static/5010.acf9a415.chunk.js.map +0 -1
- package/dist-scalprum/static/5453.c1f90bdf.chunk.js +0 -2
- package/dist-scalprum/static/5453.c1f90bdf.chunk.js.map +0 -1
- package/dist-scalprum/static/6813.036a322f.chunk.js +0 -2
- package/dist-scalprum/static/6813.036a322f.chunk.js.map +0 -1
- package/dist-scalprum/static/6979.9699b350.chunk.js.map +0 -1
- package/dist-scalprum/static/7684.3d1fc1a1.chunk.js +0 -2
- package/dist-scalprum/static/7684.3d1fc1a1.chunk.js.map +0 -1
- package/dist-scalprum/static/8416.3604a311.chunk.js +0 -2
- package/dist-scalprum/static/8416.3604a311.chunk.js.map +0 -1
- package/dist-scalprum/static/exposed-PluginRoot.16bf7897.chunk.js +0 -2
- package/dist-scalprum/static/exposed-PluginRoot.16bf7897.chunk.js.map +0 -1
- /package/dist-scalprum/static/{2120.44884438.chunk.js.LICENSE.txt → 2928.4303c12e.chunk.js.LICENSE.txt} +0 -0
- /package/dist-scalprum/static/{5010.acf9a415.chunk.js.LICENSE.txt → 5010.a4aa0f8e.chunk.js.LICENSE.txt} +0 -0
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"static/6813.036a322f.chunk.js","mappings":"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","sources":["webpack://internal.plugin-kuadrant/../../node_modules/react-use/lib/useAsyncFn.js","webpack://internal.plugin-kuadrant/../../node_modules/react-use/lib/useMountedState.js","webpack://internal.plugin-kuadrant/./src/components/FilterPanel/FilterPanel.tsx","webpack://internal.plugin-kuadrant/./src/components/MyApiKeysTable/MyApiKeysTable.tsx","webpack://internal.plugin-kuadrant/./src/components/ApprovalQueueTable/ApprovalQueueTable.tsx","webpack://internal.plugin-kuadrant/./src/components/ApiKeysPage/ApiKeysPage.tsx","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/icons/ExpandLess.js","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/icons/BrokenImage.js","webpack://internal.plugin-kuadrant/./src/components/PermissionGate/PermissionGate.tsx","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/icons/Delete.js","webpack://internal.plugin-kuadrant/./node_modules/@backstage/core-components/dist/hooks/useSupportConfig.esm.js","webpack://internal.plugin-kuadrant/./node_modules/@backstage/core-components/dist/icons/icons.esm.js","webpack://internal.plugin-kuadrant/./node_modules/@backstage/core-components/dist/components/SupportButton/SupportButton.esm.js","webpack://internal.plugin-kuadrant/./src/utils/styles.ts","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/icons/CheckCircle.js","webpack://internal.plugin-kuadrant/../../node_modules/react-use/lib/useAsync.js"],"sourcesContent":["\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar react_1 = require(\"react\");\nvar useMountedState_1 = tslib_1.__importDefault(require(\"./useMountedState\"));\nfunction useAsyncFn(fn, deps, initialState) {\n if (deps === void 0) { deps = []; }\n if (initialState === void 0) { initialState = { loading: false }; }\n var lastCallId = react_1.useRef(0);\n var isMounted = useMountedState_1.default();\n var _a = react_1.useState(initialState), state = _a[0], set = _a[1];\n var callback = react_1.useCallback(function () {\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n var callId = ++lastCallId.current;\n if (!state.loading) {\n set(function (prevState) { return (tslib_1.__assign(tslib_1.__assign({}, prevState), { loading: true })); });\n }\n return fn.apply(void 0, args).then(function (value) {\n isMounted() && callId === lastCallId.current && set({ value: value, loading: false });\n return value;\n }, function (error) {\n isMounted() && callId === lastCallId.current && set({ error: error, loading: false });\n return error;\n });\n }, deps);\n return [state, callback];\n}\nexports.default = useAsyncFn;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar react_1 = require(\"react\");\nfunction useMountedState() {\n var mountedRef = react_1.useRef(false);\n var get = react_1.useCallback(function () { return mountedRef.current; }, []);\n react_1.useEffect(function () {\n mountedRef.current = true;\n return function () {\n mountedRef.current = false;\n };\n }, []);\n return get;\n}\nexports.default = useMountedState;\n","import React from 'react';\nimport {\n Box,\n Typography,\n Checkbox,\n FormControlLabel,\n FormGroup,\n Divider,\n Button,\n Collapse,\n makeStyles,\n} from '@material-ui/core';\nimport ExpandMoreIcon from '@material-ui/icons/ExpandMore';\nimport ExpandLessIcon from '@material-ui/icons/ExpandLess';\n\nconst useStyles = makeStyles(theme => ({\n root: {\n width: 240,\n minWidth: 240,\n padding: theme.spacing(2),\n borderRight: `1px solid ${theme.palette.divider}`,\n backgroundColor: theme.palette.background.paper,\n height: '100%',\n overflowY: 'auto',\n },\n sectionTitle: {\n fontWeight: 600,\n fontSize: '0.75rem',\n textTransform: 'uppercase',\n letterSpacing: '0.05em',\n color: theme.palette.text.secondary,\n marginBottom: theme.spacing(1),\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'space-between',\n cursor: 'pointer',\n userSelect: 'none',\n },\n filterSection: {\n marginBottom: theme.spacing(2),\n },\n checkbox: {\n padding: theme.spacing(0.5),\n },\n checkboxLabel: {\n fontSize: '0.875rem',\n },\n clearButton: {\n marginTop: theme.spacing(2),\n },\n count: {\n fontSize: '0.75rem',\n color: theme.palette.text.secondary,\n marginLeft: theme.spacing(1),\n },\n}));\n\nexport interface FilterOption {\n value: string;\n label: string;\n count?: number;\n}\n\nexport interface FilterSection {\n id: string;\n title: string;\n options: FilterOption[];\n collapsed?: boolean;\n}\n\nexport interface FilterState {\n [sectionId: string]: string[];\n}\n\ninterface FilterPanelProps {\n sections: FilterSection[];\n filters: FilterState;\n onChange: (filters: FilterState) => void;\n onClear?: () => void;\n}\n\nexport const FilterPanel = ({\n sections,\n filters,\n onChange,\n onClear,\n}: FilterPanelProps) => {\n const classes = useStyles();\n const [collapsedSections, setCollapsedSections] = React.useState<Set<string>>(\n new Set(sections.filter(s => s.collapsed).map(s => s.id)),\n );\n\n const toggleSection = (sectionId: string) => {\n setCollapsedSections(prev => {\n const next = new Set(prev);\n if (next.has(sectionId)) {\n next.delete(sectionId);\n } else {\n next.add(sectionId);\n }\n return next;\n });\n };\n\n const handleCheckboxChange = (sectionId: string, value: string) => {\n const currentValues = filters[sectionId] || [];\n const newValues = currentValues.includes(value)\n ? currentValues.filter(v => v !== value)\n : [...currentValues, value];\n\n onChange({\n ...filters,\n [sectionId]: newValues,\n });\n };\n\n const hasActiveFilters = Object.values(filters).some(\n values => values.length > 0,\n );\n\n const handleClear = () => {\n const clearedFilters: FilterState = {};\n sections.forEach(section => {\n clearedFilters[section.id] = [];\n });\n onChange(clearedFilters);\n onClear?.();\n };\n\n return (\n <Box className={classes.root}>\n <Box display=\"flex\" justifyContent=\"space-between\" alignItems=\"center\" mb={2}>\n <Typography variant=\"subtitle2\">Filters</Typography>\n {hasActiveFilters && (\n <Button\n size=\"small\"\n color=\"primary\"\n onClick={handleClear}\n >\n Clear all\n </Button>\n )}\n </Box>\n\n <Divider />\n\n {sections.map(section => {\n const isCollapsed = collapsedSections.has(section.id);\n const selectedCount = (filters[section.id] || []).length;\n\n return (\n <Box key={section.id} className={classes.filterSection} mt={2}>\n <Box\n className={classes.sectionTitle}\n onClick={() => toggleSection(section.id)}\n >\n <Box display=\"flex\" alignItems=\"center\">\n <span>{section.title}</span>\n {selectedCount > 0 && (\n <span className={classes.count}>({selectedCount})</span>\n )}\n </Box>\n {isCollapsed ? (\n <ExpandMoreIcon fontSize=\"small\" />\n ) : (\n <ExpandLessIcon fontSize=\"small\" />\n )}\n </Box>\n\n <Collapse in={!isCollapsed}>\n <FormGroup>\n {section.options.map(option => (\n <FormControlLabel\n key={option.value}\n control={\n <Checkbox\n checked={(filters[section.id] || []).includes(option.value)}\n onChange={() =>\n handleCheckboxChange(section.id, option.value)\n }\n size=\"small\"\n className={classes.checkbox}\n color=\"primary\"\n />\n }\n label={\n <Box display=\"flex\" alignItems=\"center\">\n <span className={classes.checkboxLabel}>\n {option.label}\n </span>\n {option.count !== undefined && (\n <span className={classes.count}>({option.count})</span>\n )}\n </Box>\n }\n />\n ))}\n </FormGroup>\n </Collapse>\n </Box>\n );\n })}\n </Box>\n );\n};\n","import React, { useState, useMemo } from \"react\";\nimport { useNavigate } from \"react-router-dom\";\nimport {\n Table,\n TableColumn,\n Link,\n Progress,\n ResponseErrorPanel,\n} from \"@backstage/core-components\";\nimport {\n useApi,\n configApiRef,\n fetchApiRef,\n alertApiRef,\n} from \"@backstage/core-plugin-api\";\nimport useAsync from \"react-use/lib/useAsync\";\nimport {\n Box,\n Chip,\n Typography,\n IconButton,\n Tooltip,\n Menu,\n MenuItem,\n CircularProgress,\n Dialog,\n DialogTitle,\n DialogContent,\n DialogActions,\n Button,\n makeStyles,\n} from \"@material-ui/core\";\nimport VisibilityIcon from \"@material-ui/icons/Visibility\";\nimport VisibilityOffIcon from \"@material-ui/icons/VisibilityOff\";\nimport FileCopyIcon from \"@material-ui/icons/FileCopy\";\nimport WarningIcon from \"@material-ui/icons/Warning\";\nimport DeleteIcon from \"@material-ui/icons/Delete\";\nimport { EditAPIKeyDialog } from \"../EditAPIKeyDialog\";\nimport { ConfirmDeleteDialog } from \"../ConfirmDeleteDialog\";\nimport { FilterPanel, FilterSection, FilterState } from \"../FilterPanel\";\nimport { APIKey, APIProduct } from \"../../types/api-management\";\nimport { getStatusChipStyle } from \"../../utils/styles\";\n\nconst useStyles = makeStyles((theme) => ({\n container: {\n display: \"flex\",\n height: \"100%\",\n minHeight: 400,\n },\n tableContainer: {\n flex: 1,\n overflow: \"auto\",\n },\n useCasePanel: {\n padding: theme.spacing(2),\n backgroundColor: theme.palette.background.default,\n },\n useCaseLabel: {\n fontWeight: 600,\n marginBottom: theme.spacing(1),\n color: theme.palette.text.secondary,\n textTransform: \"uppercase\",\n fontSize: \"0.75rem\",\n },\n rejectedBanner: {\n backgroundColor: theme.palette.error.light,\n border: `1px solid ${theme.palette.error.main}`,\n borderRadius: theme.shape.borderRadius,\n padding: theme.spacing(1.5, 2),\n marginBottom: theme.spacing(2),\n display: \"flex\",\n alignItems: \"center\",\n gap: theme.spacing(1),\n },\n}));\n\ninterface ExpandedRowProps {\n request: APIKey;\n}\n\nconst ExpandedRowContent = ({ request }: ExpandedRowProps) => {\n const classes = useStyles();\n const isRejected = request.status?.phase === \"Rejected\";\n const apiProductName = request.spec.apiProductRef?.name || \"unknown\";\n\n return (\n <Box className={classes.useCasePanel} onClick={(e) => e.stopPropagation()}>\n {isRejected && (\n <Box className={classes.rejectedBanner}>\n <WarningIcon color=\"error\" fontSize=\"small\" />\n <Typography variant=\"body2\">\n This API key was rejected.{\" \"}\n <Link to={`/catalog/default/api/${apiProductName}/api-keys`}>\n Request a new API key\n </Link>\n </Typography>\n </Box>\n )}\n <Typography className={classes.useCaseLabel}>Use Case</Typography>\n <Typography variant=\"body2\">\n {request.spec.useCase || \"No use case provided\"}\n </Typography>\n </Box>\n );\n};\n\nexport const MyApiKeysTable = () => {\n const classes = useStyles();\n const navigate = useNavigate();\n const config = useApi(configApiRef);\n const fetchApi = useApi(fetchApiRef);\n const alertApi = useApi(alertApiRef);\n const backendUrl = config.getString(\"backend.baseUrl\");\n\n const [visibleKeys, setVisibleKeys] = useState<Set<string>>(new Set());\n const [menuAnchor, setMenuAnchor] = useState<{\n top: number;\n left: number;\n } | null>(null);\n const [menuRequest, setMenuRequest] = useState<APIKey | null>(null);\n const [editDialogState, setEditDialogState] = useState<{\n open: boolean;\n request: APIKey | null;\n plans: any[];\n }>({ open: false, request: null, plans: [] });\n const [refresh, setRefresh] = useState(0);\n const [deleting, setDeleting] = useState<string | null>(null);\n const [deleteDialogState, setDeleteDialogState] = useState<{\n open: boolean;\n request: APIKey | null;\n }>({ open: false, request: null });\n const [apiKeyValues, setApiKeyValues] = useState<Map<string, string>>(\n new Map(),\n );\n const [apiKeyLoading, setApiKeyLoading] = useState<Set<string>>(new Set());\n const [alreadyReadKeys, setAlreadyReadKeys] = useState<Set<string>>(\n new Set(),\n );\n const [showOnceWarningOpen, setShowOnceWarningOpen] = useState(false);\n const [pendingKeyReveal, setPendingKeyReveal] = useState<{\n namespace: string;\n name: string;\n } | null>(null);\n const [optimisticallyDeleted, setOptimisticallyDeleted] = useState<\n Set<string>\n >(new Set());\n\n const [filters, setFilters] = useState<FilterState>({\n status: [],\n apiProduct: [],\n tier: [],\n });\n\n const {\n value: data,\n loading,\n error,\n } = useAsync(async () => {\n const [requestsResponse, productsResponse] = await Promise.all([\n fetchApi.fetch(`${backendUrl}/api/kuadrant/requests/my`),\n fetchApi.fetch(`${backendUrl}/api/kuadrant/apiproducts`),\n ]);\n\n if (!requestsResponse.ok) {\n throw new Error(\"failed to fetch requests\");\n }\n\n const requestsData = await requestsResponse.json();\n const requests: APIKey[] = requestsData.items || [];\n\n let products: APIProduct[] = [];\n if (productsResponse.ok) {\n const productsData = await productsResponse.json();\n products = productsData.items || [];\n }\n\n // build owner map from products\n const ownerMap = new Map<string, string>();\n products.forEach((p) => {\n const key = `${p.metadata.namespace}/${p.metadata.name}`;\n const owner = p.metadata.annotations?.[\"backstage.io/owner\"] || \"unknown\";\n ownerMap.set(key, owner);\n });\n\n return { requests, products, ownerMap };\n }, [backendUrl, fetchApi, refresh]);\n\n const allRequests = useMemo(() => {\n if (!data?.requests) return [];\n return data.requests.filter(\n (r: APIKey) => !optimisticallyDeleted.has(r.metadata.name),\n );\n }, [data?.requests, optimisticallyDeleted]);\n\n // filter options from data\n const filterSections: FilterSection[] = useMemo(() => {\n const statusCounts = { Approved: 0, Pending: 0, Rejected: 0 };\n const apiProductCounts = new Map<string, number>();\n const tierCounts = new Map<string, number>();\n\n allRequests.forEach((r: APIKey) => {\n const status = r.status?.phase || \"Pending\";\n statusCounts[status as keyof typeof statusCounts]++;\n\n const apiProduct = r.spec.apiProductRef?.name || \"unknown\";\n apiProductCounts.set(\n apiProduct,\n (apiProductCounts.get(apiProduct) || 0) + 1,\n );\n\n const tier = r.spec.planTier || \"unknown\";\n tierCounts.set(tier, (tierCounts.get(tier) || 0) + 1);\n });\n\n return [\n {\n id: \"status\",\n title: \"Status\",\n options: [\n { value: \"Approved\", label: \"Active\", count: statusCounts.Approved },\n { value: \"Pending\", label: \"Pending\", count: statusCounts.Pending },\n {\n value: \"Rejected\",\n label: \"Rejected\",\n count: statusCounts.Rejected,\n },\n ],\n },\n {\n id: \"apiProduct\",\n title: \"API Product\",\n options: Array.from(apiProductCounts.entries()).map(\n ([name, count]) => ({\n value: name,\n label: name,\n count,\n }),\n ),\n collapsed: apiProductCounts.size > 5,\n },\n {\n id: \"tier\",\n title: \"Tier\",\n options: Array.from(tierCounts.entries()).map(([tier, count]) => ({\n value: tier,\n label: tier.charAt(0).toUpperCase() + tier.slice(1),\n count,\n })),\n },\n ];\n }, [allRequests]);\n\n // filtered requests\n const filteredRequests = useMemo(() => {\n return allRequests.filter((r: APIKey) => {\n // status filter\n if (filters.status.length > 0) {\n const status = r.status?.phase || \"Pending\";\n if (!filters.status.includes(status)) return false;\n }\n\n // api product filter\n if (filters.apiProduct.length > 0) {\n const apiProduct = r.spec.apiProductRef?.name || \"unknown\";\n if (!filters.apiProduct.includes(apiProduct)) return false;\n }\n\n // tier filter\n if (filters.tier.length > 0) {\n const tier = r.spec.planTier || \"unknown\";\n if (!filters.tier.includes(tier)) return false;\n }\n\n return true;\n });\n }, [allRequests, filters]);\n\n const toggleKeyVisibility = (keyName: string) => {\n setVisibleKeys((prev) => {\n const newSet = new Set(prev);\n if (newSet.has(keyName)) {\n newSet.delete(keyName);\n } else {\n newSet.add(keyName);\n }\n return newSet;\n });\n };\n\n const fetchApiKeyFromSecret = async (\n requestNamespace: string,\n requestName: string,\n ) => {\n const key = `${requestNamespace}/${requestName}`;\n if (apiKeyLoading.has(key)) return;\n\n setApiKeyLoading((prev) => new Set(prev).add(key));\n try {\n const response = await fetchApi.fetch(\n `${backendUrl}/api/kuadrant/apikeys/${requestNamespace}/${requestName}/secret`,\n );\n if (response.ok) {\n const result = await response.json();\n setApiKeyValues((prev) => new Map(prev).set(key, result.apiKey));\n setAlreadyReadKeys((prev) => new Set(prev).add(key));\n } else if (response.status === 403) {\n setAlreadyReadKeys((prev) => new Set(prev).add(key));\n alertApi.post({\n message:\n \"This API key has already been viewed and cannot be retrieved again.\",\n severity: \"warning\",\n display: \"transient\",\n });\n }\n } catch (err) {\n console.error(\"failed to fetch api key:\", err);\n } finally {\n setApiKeyLoading((prev) => {\n const next = new Set(prev);\n next.delete(key);\n return next;\n });\n }\n };\n\n const clearApiKeyValue = (requestNamespace: string, requestName: string) => {\n const key = `${requestNamespace}/${requestName}`;\n setApiKeyValues((prev) => {\n const next = new Map(prev);\n next.delete(key);\n return next;\n });\n };\n\n const handleMenuClose = () => {\n setMenuAnchor(null);\n setMenuRequest(null);\n };\n\n const handleEdit = async () => {\n if (!menuRequest) return;\n\n const request = menuRequest;\n handleMenuClose();\n\n try {\n const apiProductName = request.spec.apiProductRef?.name;\n const apiProductNamespace = request.metadata.namespace;\n const apiProductResponse = await fetchApi.fetch(\n `${backendUrl}/api/kuadrant/apiproducts/${apiProductNamespace}/${apiProductName}`,\n );\n\n if (apiProductResponse.ok) {\n const apiProduct = await apiProductResponse.json();\n const plans = apiProduct.spec?.plans || [];\n setEditDialogState({ open: true, request, plans });\n } else {\n setEditDialogState({ open: true, request, plans: [] });\n }\n } catch (err) {\n console.error(\"Error fetching plans:\", err);\n setEditDialogState({ open: true, request, plans: [] });\n }\n };\n\n const handleDeleteClick = () => {\n if (!menuRequest) return;\n const request = menuRequest;\n handleMenuClose();\n setDeleteDialogState({ open: true, request });\n };\n\n const handleDeleteConfirm = async () => {\n if (!deleteDialogState.request) return;\n\n const request = deleteDialogState.request;\n const requestName = request.metadata.name;\n\n setOptimisticallyDeleted((prev) => new Set(prev).add(requestName));\n setDeleting(requestName);\n\n try {\n const response = await fetchApi.fetch(\n `${backendUrl}/api/kuadrant/requests/${request.metadata.namespace}/${request.metadata.name}`,\n { method: \"DELETE\" },\n );\n\n if (!response.ok) {\n throw new Error(\"Failed to delete request\");\n }\n\n setRefresh((r) => r + 1);\n alertApi.post({\n message: \"API key deleted\",\n severity: \"success\",\n display: \"transient\",\n });\n setDeleteDialogState({ open: false, request: null });\n } catch (err) {\n console.error(\"Error deleting request:\", err);\n setOptimisticallyDeleted((prev) => {\n const next = new Set(prev);\n next.delete(requestName);\n return next;\n });\n alertApi.post({\n message: \"Failed to delete API key\",\n severity: \"error\",\n display: \"transient\",\n });\n } finally {\n setDeleting(null);\n }\n };\n\n const handleDeleteCancel = () => {\n setDeleteDialogState({ open: false, request: null });\n };\n\n const columns: TableColumn<APIKey>[] = [\n {\n title: \"API Product\",\n field: \"spec.apiProductRef.name\",\n render: (row: APIKey) => {\n const apiProductName = row.spec.apiProductRef?.name || \"unknown\";\n return (\n <Link to={`/catalog/default/api/${apiProductName}/api-keys`}>\n <strong>{apiProductName}</strong>\n </Link>\n );\n },\n },\n {\n title: \"Owner\",\n field: \"owner\",\n render: (row: APIKey) => {\n const key = `${row.metadata.namespace}/${row.spec.apiProductRef?.name}`;\n const owner = data?.ownerMap?.get(key) || \"unknown\";\n // strip 'user:default/' prefix if present\n const displayOwner = owner.replace(/^user:default\\//, \"\");\n return <Typography variant=\"body2\">{displayOwner}</Typography>;\n },\n },\n {\n title: \"Status\",\n field: \"status.phase\",\n render: (row: APIKey) => {\n const phase = row.status?.phase || \"Pending\";\n const label = phase === \"Approved\" ? \"Active\" : phase;\n return (\n <Chip label={label} size=\"small\" style={getStatusChipStyle(phase)} />\n );\n },\n },\n {\n title: \"Tier\",\n field: \"spec.planTier\",\n render: (row: APIKey) => (\n <Chip label={row.spec.planTier} size=\"small\" variant=\"outlined\" />\n ),\n },\n {\n title: \"API Key\",\n field: \"status.secretRef\",\n filtering: false,\n render: (row: APIKey) => {\n if (row.status?.phase !== \"Approved\") {\n return (\n <Typography variant=\"body2\" color=\"textSecondary\">\n -\n </Typography>\n );\n }\n\n const key = `${row.metadata.namespace}/${row.metadata.name}`;\n const hasSecretRef = row.status?.secretRef?.name;\n const isVisible = visibleKeys.has(row.metadata.name);\n const isLoading = apiKeyLoading.has(key);\n const apiKeyValue = apiKeyValues.get(key);\n const canReadSecret = row.status?.canReadSecret !== false;\n const isAlreadyRead = alreadyReadKeys.has(key) || !canReadSecret;\n\n if (!hasSecretRef) {\n return (\n <Typography variant=\"body2\" color=\"textSecondary\">\n Awaiting secret...\n </Typography>\n );\n }\n\n if (isAlreadyRead && !apiKeyValue) {\n return (\n <Tooltip title=\"This API key has already been viewed and cannot be retrieved again\">\n <Box display=\"flex\" alignItems=\"center\">\n <Typography\n variant=\"body2\"\n color=\"textSecondary\"\n style={{ fontFamily: \"monospace\", marginRight: 8 }}\n >\n Already viewed\n </Typography>\n <VisibilityOffIcon fontSize=\"small\" color=\"disabled\" />\n </Box>\n </Tooltip>\n );\n }\n\n const handleRevealClick = () => {\n if (isVisible) {\n clearApiKeyValue(row.metadata.namespace, row.metadata.name);\n toggleKeyVisibility(row.metadata.name);\n } else if (!isAlreadyRead) {\n setPendingKeyReveal({\n namespace: row.metadata.namespace,\n name: row.metadata.name,\n });\n setShowOnceWarningOpen(true);\n }\n };\n\n const handleCopy = async () => {\n if (apiKeyValue) {\n await navigator.clipboard.writeText(apiKeyValue);\n alertApi.post({\n message: \"API key copied to clipboard\",\n severity: \"success\",\n display: \"transient\",\n });\n }\n };\n\n return (\n <Box display=\"flex\" alignItems=\"center\" style={{ gap: 8 }}>\n <Box fontFamily=\"monospace\" fontSize=\"0.875rem\">\n {isLoading\n ? \"Loading...\"\n : isVisible && apiKeyValue\n ? apiKeyValue\n : \"•\".repeat(20) + \"...\"}\n </Box>\n {isVisible && apiKeyValue && (\n <Tooltip title=\"Copy to clipboard\">\n <IconButton size=\"small\" onClick={handleCopy}>\n <FileCopyIcon fontSize=\"small\" />\n </IconButton>\n </Tooltip>\n )}\n <Tooltip\n title={\n isVisible ? \"Hide API key\" : \"Reveal API key (one-time only)\"\n }\n >\n <span>\n <IconButton\n size=\"small\"\n onClick={handleRevealClick}\n disabled={isLoading || (isAlreadyRead && !apiKeyValue)}\n >\n {isVisible ? (\n <VisibilityOffIcon fontSize=\"small\" />\n ) : (\n <VisibilityIcon fontSize=\"small\" />\n )}\n </IconButton>\n </span>\n </Tooltip>\n </Box>\n );\n },\n },\n {\n title: \"Requested\",\n field: \"metadata.creationTimestamp\",\n render: (row: APIKey) => {\n if (!row.metadata.creationTimestamp) {\n return <Typography variant=\"body2\">-</Typography>;\n }\n const date = new Date(row.metadata.creationTimestamp);\n return (\n <Typography variant=\"body2\">{date.toLocaleDateString()}</Typography>\n );\n },\n },\n {\n title: \"Actions\",\n filtering: false,\n width: \"100px\",\n render: (row: APIKey) => {\n const isDeleting = deleting === row.metadata.name;\n if (isDeleting) {\n return <CircularProgress size={20} />;\n }\n return (\n <Box display=\"flex\" style={{ gap: 4 }}>\n <Tooltip title=\"View details\">\n <IconButton\n size=\"small\"\n onClick={(e) => {\n e.stopPropagation();\n navigate(\n `/kuadrant/api-keys/${row.metadata.namespace}/${row.metadata.name}`,\n );\n }}\n >\n <VisibilityIcon fontSize=\"small\" />\n </IconButton>\n </Tooltip>\n <Tooltip title=\"Delete\">\n <IconButton\n size=\"small\"\n onClick={(e) => {\n e.stopPropagation();\n setDeleteDialogState({ open: true, request: row });\n }}\n >\n <DeleteIcon fontSize=\"small\" />\n </IconButton>\n </Tooltip>\n </Box>\n );\n },\n },\n ];\n\n const detailPanelConfig = useMemo(\n () => [\n {\n render: (data: any) => {\n const request = data.rowData as APIKey;\n if (!request?.metadata?.name) {\n return <Box />;\n }\n return <ExpandedRowContent request={request} />;\n },\n },\n ],\n [],\n );\n\n if (loading) {\n return <Progress />;\n }\n\n if (error) {\n return <ResponseErrorPanel error={error} />;\n }\n\n const isPending = (row: APIKey) =>\n !row.status || row.status.phase === \"Pending\";\n\n return (\n <>\n <Box className={classes.container}>\n <FilterPanel\n sections={filterSections}\n filters={filters}\n onChange={setFilters}\n />\n <Box className={classes.tableContainer}>\n {filteredRequests.length === 0 ? (\n <Box p={4} textAlign=\"center\">\n <Typography variant=\"body1\" color=\"textSecondary\">\n {allRequests.length === 0\n ? \"No API keys found. Request access to an API to get started.\"\n : \"No API keys match the selected filters.\"}\n </Typography>\n </Box>\n ) : (\n <Table\n options={{\n paging: filteredRequests.length > 10,\n pageSize: 20,\n search: true,\n filtering: false,\n debounceInterval: 300,\n toolbar: true,\n emptyRowsWhenPaging: false,\n }}\n columns={columns}\n data={filteredRequests.map((item: APIKey) => ({\n ...item,\n id: item.metadata.name,\n }))}\n detailPanel={detailPanelConfig}\n />\n )}\n </Box>\n </Box>\n\n <Menu\n id=\"myapikeys-menu\"\n open={Boolean(menuAnchor)}\n onClose={handleMenuClose}\n anchorReference=\"anchorPosition\"\n anchorPosition={menuAnchor || { top: 0, left: 0 }}\n >\n {menuRequest &&\n (() => {\n const items = [];\n items.push(\n <MenuItem\n key=\"view\"\n onClick={() => {\n navigate(\n `/kuadrant/api-keys/${menuRequest.metadata.namespace}/${menuRequest.metadata.name}`,\n );\n handleMenuClose();\n }}\n >\n View Details\n </MenuItem>,\n );\n if (isPending(menuRequest)) {\n items.push(\n <MenuItem key=\"edit\" onClick={handleEdit}>\n Edit\n </MenuItem>,\n );\n }\n items.push(\n <MenuItem key=\"delete\" onClick={handleDeleteClick}>\n Delete\n </MenuItem>,\n );\n return items;\n })()}\n </Menu>\n\n {editDialogState.request && (\n <EditAPIKeyDialog\n open={editDialogState.open}\n request={editDialogState.request}\n availablePlans={editDialogState.plans}\n onClose={() =>\n setEditDialogState({ open: false, request: null, plans: [] })\n }\n onSuccess={() => {\n setEditDialogState({ open: false, request: null, plans: [] });\n setRefresh((r) => r + 1);\n }}\n />\n )}\n\n <ConfirmDeleteDialog\n open={deleteDialogState.open}\n title=\"Delete API Key\"\n description={`Are you sure you want to delete this API key for ${deleteDialogState.request?.spec.apiProductRef?.name || \"this API\"}?`}\n deleting={deleting !== null}\n onConfirm={handleDeleteConfirm}\n onCancel={handleDeleteCancel}\n />\n\n <Dialog\n open={showOnceWarningOpen}\n onClose={() => {\n setShowOnceWarningOpen(false);\n setPendingKeyReveal(null);\n }}\n maxWidth=\"sm\"\n >\n <DialogTitle>\n <Box display=\"flex\" alignItems=\"center\">\n <WarningIcon color=\"primary\" style={{ marginRight: 8 }} />\n View API Key\n </Box>\n </DialogTitle>\n <DialogContent>\n <Typography variant=\"body1\" paragraph>\n This API key can only be viewed <strong>once</strong>. After you\n reveal it, you will not be able to retrieve it again.\n </Typography>\n <Typography variant=\"body2\" color=\"textSecondary\">\n Make sure to copy and store it securely before closing this view.\n </Typography>\n </DialogContent>\n <DialogActions>\n <Button\n onClick={() => {\n setShowOnceWarningOpen(false);\n setPendingKeyReveal(null);\n }}\n >\n Cancel\n </Button>\n <Button\n variant=\"contained\"\n color=\"primary\"\n onClick={() => {\n if (pendingKeyReveal) {\n fetchApiKeyFromSecret(\n pendingKeyReveal.namespace,\n pendingKeyReveal.name,\n );\n toggleKeyVisibility(pendingKeyReveal.name);\n }\n setShowOnceWarningOpen(false);\n setPendingKeyReveal(null);\n }}\n >\n Reveal API Key\n </Button>\n </DialogActions>\n </Dialog>\n </>\n );\n};\n","import React, { useState, useMemo } from \"react\";\nimport {\n useApi,\n fetchApiRef,\n identityApiRef,\n configApiRef,\n alertApiRef,\n} from \"@backstage/core-plugin-api\";\nimport { useAsync } from \"react-use\";\nimport {\n Table,\n TableColumn,\n Progress,\n ResponseErrorPanel,\n Link,\n} from \"@backstage/core-components\";\nimport {\n kuadrantApiKeyUpdateAllPermission,\n kuadrantApiKeyUpdateOwnPermission,\n} from \"../../permissions\";\nimport { useKuadrantPermission } from \"../../utils/permissions\";\nimport {\n Button,\n Dialog,\n DialogTitle,\n DialogContent,\n DialogActions,\n Chip,\n Typography,\n Box,\n CircularProgress,\n TextField,\n makeStyles,\n} from \"@material-ui/core\";\nimport CheckCircleIcon from \"@material-ui/icons/CheckCircle\";\nimport CancelIcon from \"@material-ui/icons/Cancel\";\nimport { FilterPanel, FilterSection, FilterState } from \"../FilterPanel\";\nimport { APIKey } from \"../../types/api-management\";\nimport { getStatusChipStyle } from \"../../utils/styles\";\n\nconst useStyles = makeStyles((theme) => ({\n container: {\n display: \"flex\",\n height: \"100%\",\n minHeight: 400,\n },\n tableContainer: {\n flex: 1,\n overflow: \"auto\",\n },\n useCasePanel: {\n padding: theme.spacing(2),\n backgroundColor: theme.palette.background.default,\n },\n useCaseLabel: {\n fontWeight: 600,\n marginBottom: theme.spacing(1),\n color: theme.palette.text.secondary,\n textTransform: \"uppercase\",\n fontSize: \"0.75rem\",\n },\n bulkActions: {\n padding: theme.spacing(2),\n backgroundColor: theme.palette.background.default,\n borderBottom: `1px solid ${theme.palette.divider}`,\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"space-between\",\n },\n}));\n\ninterface ApprovalDialogProps {\n open: boolean;\n request: APIKey | null;\n action: \"approve\" | \"reject\";\n processing: boolean;\n onClose: () => void;\n onConfirm: () => void;\n}\n\nconst ApprovalDialog = ({\n open,\n request,\n action,\n processing,\n onClose,\n onConfirm,\n}: ApprovalDialogProps) => {\n const [confirmInput, setConfirmInput] = React.useState(\"\");\n const actionLabel = action === \"approve\" ? \"Approve\" : \"Reject\";\n const processingLabel =\n action === \"approve\" ? \"Approving...\" : \"Rejecting...\";\n\n const isReject = action === \"reject\";\n const confirmText = request?.spec.requestedBy?.userId || \"\";\n const canConfirm = isReject ? confirmInput === confirmText : true;\n\n // reset input when dialog closes\n React.useEffect(() => {\n if (!open) {\n setConfirmInput(\"\");\n }\n }, [open]);\n\n return (\n <Dialog\n open={open}\n onClose={processing ? undefined : onClose}\n maxWidth=\"sm\"\n fullWidth\n >\n <DialogTitle>\n {isReject ? (\n <Box display=\"flex\" alignItems=\"center\" style={{ gap: 8 }}>\n <CancelIcon color=\"error\" />\n <span>{actionLabel} API Key</span>\n </Box>\n ) : (\n <span>{actionLabel} API Key</span>\n )}\n </DialogTitle>\n <DialogContent>\n {request && (\n <>\n <p>\n <strong>User:</strong> {request.spec.requestedBy.userId}\n </p>\n <p>\n <strong>API:</strong>{\" \"}\n {request.spec.apiProductRef?.name || \"unknown\"}\n </p>\n <p>\n <strong>Tier:</strong> {request.spec.planTier}\n </p>\n <Box mb={2}>\n <Typography\n variant=\"body2\"\n component=\"span\"\n style={{ fontWeight: \"bold\" }}\n >\n Use Case:\n </Typography>{\" \"}\n <Typography\n variant=\"body2\"\n component=\"span\"\n style={{ whiteSpace: \"pre-wrap\" }}\n >\n {request.spec.useCase || \"-\"}\n </Typography>\n </Box>\n {isReject && (\n <Box mt={2}>\n <Typography variant=\"body2\" color=\"textSecondary\" gutterBottom>\n Type <strong>{confirmText}</strong> to confirm rejection:\n </Typography>\n <TextField\n fullWidth\n variant=\"outlined\"\n size=\"small\"\n value={confirmInput}\n onChange={(e) => setConfirmInput(e.target.value)}\n disabled={processing}\n autoFocus\n placeholder={confirmText}\n />\n </Box>\n )}\n </>\n )}\n </DialogContent>\n <DialogActions>\n <Button onClick={onClose} disabled={processing}>\n Cancel\n </Button>\n <Button\n onClick={onConfirm}\n color={action === \"approve\" ? \"primary\" : \"secondary\"}\n variant=\"contained\"\n disabled={processing || !canConfirm}\n startIcon={\n processing ? (\n <CircularProgress size={16} color=\"inherit\" />\n ) : undefined\n }\n >\n {processing ? processingLabel : actionLabel}\n </Button>\n </DialogActions>\n </Dialog>\n );\n};\n\ninterface BulkActionDialogProps {\n open: boolean;\n requests: APIKey[];\n action: \"approve\" | \"reject\";\n processing: boolean;\n onClose: () => void;\n onConfirm: () => void;\n}\n\nconst BulkActionDialog = ({\n open,\n requests,\n action,\n processing,\n onClose,\n onConfirm,\n}: BulkActionDialogProps) => {\n const isApprove = action === \"approve\";\n const actionLabel = isApprove ? \"Approve All\" : \"Reject All\";\n const processingLabel = isApprove ? \"Approving...\" : \"Rejecting...\";\n\n return (\n <Dialog\n open={open}\n onClose={processing ? undefined : onClose}\n maxWidth=\"md\"\n fullWidth\n >\n <DialogTitle>\n {isApprove ? \"Approve\" : \"Reject\"} {requests.length} API Keys\n </DialogTitle>\n <DialogContent>\n <Typography variant=\"body2\" paragraph>\n You are about to {isApprove ? \"approve\" : \"reject\"} the following API\n keys:\n </Typography>\n <Box mb={2} maxHeight={200} overflow=\"auto\">\n {requests.map((request) => (\n <Box\n key={`${request.metadata.namespace}/${request.metadata.name}`}\n mb={1}\n p={1}\n bgcolor=\"background.default\"\n >\n <Typography variant=\"body2\">\n <strong>{request.spec.requestedBy.userId}</strong> -{\" \"}\n {request.spec.apiProductRef?.name || \"unknown\"} (\n {request.spec.planTier})\n </Typography>\n </Box>\n ))}\n </Box>\n </DialogContent>\n <DialogActions>\n <Button onClick={onClose} disabled={processing}>\n Cancel\n </Button>\n <Button\n onClick={onConfirm}\n color={isApprove ? \"primary\" : \"secondary\"}\n variant=\"contained\"\n disabled={processing}\n startIcon={\n processing ? (\n <CircularProgress size={16} color=\"inherit\" />\n ) : undefined\n }\n >\n {processing ? processingLabel : actionLabel}\n </Button>\n </DialogActions>\n </Dialog>\n );\n};\n\ninterface ExpandedRowProps {\n request: APIKey;\n}\n\nconst ExpandedRowContent = ({ request }: ExpandedRowProps) => {\n const classes = useStyles();\n\n return (\n <Box className={classes.useCasePanel} onClick={(e) => e.stopPropagation()}>\n <Typography className={classes.useCaseLabel}>Use Case</Typography>\n <Typography variant=\"body2\">\n {request.spec.useCase || \"No use case provided\"}\n </Typography>\n </Box>\n );\n};\n\nexport const ApprovalQueueTable = () => {\n const classes = useStyles();\n const config = useApi(configApiRef);\n const fetchApi = useApi(fetchApiRef);\n const identityApi = useApi(identityApiRef);\n const alertApi = useApi(alertApiRef);\n const backendUrl = config.getString(\"backend.baseUrl\");\n const [refresh, setRefresh] = useState(0);\n const [selectedRequests, setSelectedRequests] = useState<APIKey[]>([]);\n const [dialogState, setDialogState] = useState<{\n open: boolean;\n request: APIKey | null;\n action: \"approve\" | \"reject\";\n processing: boolean;\n }>({\n open: false,\n request: null,\n action: \"approve\",\n processing: false,\n });\n const [bulkDialogState, setBulkDialogState] = useState<{\n open: boolean;\n requests: APIKey[];\n action: \"approve\" | \"reject\";\n processing: boolean;\n }>({\n open: false,\n requests: [],\n action: \"approve\",\n processing: false,\n });\n const [filters, setFilters] = useState<FilterState>({\n status: [],\n apiProduct: [],\n tier: [],\n });\n\n const {\n allowed: canUpdateAllRequests,\n loading: updateAllPermissionLoading,\n error: updateAllPermissionError,\n } = useKuadrantPermission(kuadrantApiKeyUpdateAllPermission);\n\n const {\n allowed: canUpdateOwnRequests,\n loading: updateOwnPermissionLoading,\n error: updateOwnPermissionError,\n } = useKuadrantPermission(kuadrantApiKeyUpdateOwnPermission);\n\n const updatePermissionLoading =\n updateAllPermissionLoading || updateOwnPermissionLoading;\n const updatePermissionError =\n updateAllPermissionError || updateOwnPermissionError;\n\n const { value, loading, error } = useAsync(async () => {\n const identity = await identityApi.getBackstageIdentity();\n const reviewedBy = identity.userEntityRef;\n\n const [requestsResponse, apiProductsResponse] = await Promise.all([\n fetchApi.fetch(`${backendUrl}/api/kuadrant/requests`),\n fetchApi.fetch(`${backendUrl}/api/kuadrant/apiproducts`),\n ]);\n\n if (!requestsResponse.ok) {\n return {\n allRequests: [] as APIKey[],\n reviewedBy,\n ownedApiProducts: new Set<string>(),\n };\n }\n\n const contentType = requestsResponse.headers.get(\"content-type\");\n if (!contentType?.includes(\"application/json\")) {\n alertApi.post({\n message: \"Unexpected content-type from the server response.\",\n display: \"transient\",\n severity: \"warning\",\n });\n return {\n allRequests: [] as APIKey[],\n reviewedBy,\n ownedApiProducts: new Set<string>(),\n };\n }\n\n const data = await requestsResponse.json();\n const allRequests = data.items || [];\n\n const ownedApiProducts = new Set<string>();\n if (apiProductsResponse.ok) {\n const apiProductsData = await apiProductsResponse.json();\n for (const product of apiProductsData.items || []) {\n const owner = product.metadata?.annotations?.[\"backstage.io/owner\"];\n if (owner === reviewedBy) {\n ownedApiProducts.add(\n `${product.metadata.namespace}/${product.metadata.name}`,\n );\n }\n }\n }\n\n return { allRequests, reviewedBy, ownedApiProducts };\n }, [backendUrl, fetchApi, identityApi, refresh]);\n\n const filterSections: FilterSection[] = useMemo(() => {\n if (!value?.allRequests) return [];\n\n const statusCounts = { Approved: 0, Pending: 0, Rejected: 0 };\n const apiProductCounts = new Map<string, number>();\n const tierCounts = new Map<string, number>();\n\n value.allRequests.forEach((r: APIKey) => {\n const status = r.status?.phase || \"Pending\";\n statusCounts[status as keyof typeof statusCounts]++;\n\n const apiProduct = r.spec.apiProductRef?.name || \"unknown\";\n apiProductCounts.set(\n apiProduct,\n (apiProductCounts.get(apiProduct) || 0) + 1,\n );\n\n const tier = r.spec.planTier || \"unknown\";\n tierCounts.set(tier, (tierCounts.get(tier) || 0) + 1);\n });\n\n return [\n {\n id: \"status\",\n title: \"Status\",\n options: [\n { value: \"Pending\", label: \"Pending\", count: statusCounts.Pending },\n {\n value: \"Approved\",\n label: \"Approved\",\n count: statusCounts.Approved,\n },\n {\n value: \"Rejected\",\n label: \"Rejected\",\n count: statusCounts.Rejected,\n },\n ],\n },\n {\n id: \"apiProduct\",\n title: \"API Product\",\n options: Array.from(apiProductCounts.entries()).map(\n ([name, count]) => ({\n value: name,\n label: name,\n count,\n }),\n ),\n collapsed: apiProductCounts.size > 5,\n },\n {\n id: \"tier\",\n title: \"Tier\",\n options: Array.from(tierCounts.entries()).map(([tier, count]) => ({\n value: tier,\n label: tier.charAt(0).toUpperCase() + tier.slice(1),\n count,\n })),\n },\n ];\n }, [value?.allRequests]);\n\n const filteredRequests = useMemo(() => {\n if (!value?.allRequests) return [];\n\n return value.allRequests.filter((r: APIKey) => {\n if (filters.status.length > 0) {\n const status = r.status?.phase || \"Pending\";\n if (!filters.status.includes(status)) return false;\n }\n if (filters.apiProduct.length > 0) {\n const apiProduct = r.spec.apiProductRef?.name || \"unknown\";\n if (!filters.apiProduct.includes(apiProduct)) return false;\n }\n if (filters.tier.length > 0) {\n const tier = r.spec.planTier || \"unknown\";\n if (!filters.tier.includes(tier)) return false;\n }\n return true;\n });\n }, [value?.allRequests, filters]);\n\n const handleApprove = (request: APIKey) => {\n setDialogState({\n open: true,\n request,\n action: \"approve\",\n processing: false,\n });\n };\n\n const handleReject = (request: APIKey) => {\n setDialogState({\n open: true,\n request,\n action: \"reject\",\n processing: false,\n });\n };\n\n const handleConfirm = async () => {\n if (!dialogState.request || !value) return;\n\n setDialogState((prev) => ({ ...prev, processing: true }));\n\n const endpoint =\n dialogState.action === \"approve\"\n ? `${backendUrl}/api/kuadrant/requests/${dialogState.request.metadata.namespace}/${dialogState.request.metadata.name}/approve`\n : `${backendUrl}/api/kuadrant/requests/${dialogState.request.metadata.namespace}/${dialogState.request.metadata.name}/reject`;\n\n try {\n const response = await fetchApi.fetch(endpoint, {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({ reviewedBy: value.reviewedBy }),\n });\n\n if (!response.ok) {\n throw new Error(`failed to ${dialogState.action} request`);\n }\n\n setDialogState({\n open: false,\n request: null,\n action: \"approve\",\n processing: false,\n });\n // remove the processed request from selection\n setSelectedRequests((prev) =>\n prev.filter(\n (r) =>\n r.metadata.name !== dialogState.request?.metadata.name ||\n r.metadata.namespace !== dialogState.request?.metadata.namespace,\n ),\n );\n setRefresh((r) => r + 1);\n const action = dialogState.action === \"approve\" ? \"approved\" : \"rejected\";\n alertApi.post({\n message: `API key ${action}`,\n severity: \"success\",\n display: \"transient\",\n });\n } catch (err) {\n console.error(`error ${dialogState.action}ing request:`, err);\n setDialogState((prev) => ({ ...prev, processing: false }));\n alertApi.post({\n message: `Failed to ${dialogState.action} API key`,\n severity: \"error\",\n display: \"transient\",\n });\n }\n };\n\n const handleBulkApprove = () => {\n if (selectedRequests.length === 0) return;\n setBulkDialogState({\n open: true,\n requests: selectedRequests,\n action: \"approve\",\n processing: false,\n });\n };\n\n const handleBulkReject = () => {\n if (selectedRequests.length === 0) return;\n setBulkDialogState({\n open: true,\n requests: selectedRequests,\n action: \"reject\",\n processing: false,\n });\n };\n\n const handleBulkConfirm = async () => {\n if (!value || bulkDialogState.requests.length === 0) return;\n\n setBulkDialogState((prev) => ({ ...prev, processing: true }));\n\n const isApprove = bulkDialogState.action === \"approve\";\n const endpoint = isApprove\n ? `${backendUrl}/api/kuadrant/requests/bulk-approve`\n : `${backendUrl}/api/kuadrant/requests/bulk-reject`;\n\n try {\n const response = await fetchApi.fetch(endpoint, {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({\n requests: bulkDialogState.requests.map((r) => ({\n namespace: r.metadata.namespace,\n name: r.metadata.name,\n })),\n reviewedBy: value.reviewedBy,\n }),\n });\n\n if (!response.ok) {\n throw new Error(`failed to bulk ${bulkDialogState.action} requests`);\n }\n\n const count = bulkDialogState.requests.length;\n const action = isApprove ? \"approved\" : \"rejected\";\n setBulkDialogState({\n open: false,\n requests: [],\n action: \"approve\",\n processing: false,\n });\n setSelectedRequests([]);\n setRefresh((r) => r + 1);\n alertApi.post({\n message: `${count} API keys ${action}`,\n severity: \"success\",\n display: \"transient\",\n });\n } catch (err) {\n console.error(`error bulk ${bulkDialogState.action}ing requests:`, err);\n setBulkDialogState((prev) => ({ ...prev, processing: false }));\n alertApi.post({\n message: `Failed to bulk ${bulkDialogState.action} API keys`,\n severity: \"error\",\n display: \"transient\",\n });\n }\n };\n\n const formatDate = (dateString: string) => {\n const date = new Date(dateString);\n return date.toLocaleDateString(\"en-GB\", {\n year: \"numeric\",\n month: \"short\",\n day: \"numeric\",\n });\n };\n\n const columns: TableColumn<APIKey>[] = [\n {\n title: \"Requester\",\n field: \"spec.requestedBy.userId\",\n render: (row) => (\n <Typography variant=\"body2\">{row.spec.requestedBy.userId}</Typography>\n ),\n },\n {\n title: \"API Product\",\n field: \"spec.apiProductRef.name\",\n render: (row) => {\n const name = row.spec.apiProductRef?.name || \"unknown\";\n return (\n <Link to={`/catalog/default/api/${name}`}>\n <strong>{name}</strong>\n </Link>\n );\n },\n },\n {\n title: \"Status\",\n field: \"status.phase\",\n render: (row) => {\n const phase = row.status?.phase || \"Pending\";\n return (\n <Chip label={phase} size=\"small\" style={getStatusChipStyle(phase)} />\n );\n },\n },\n {\n title: \"Tier\",\n field: \"spec.planTier\",\n render: (row) => (\n <Chip label={row.spec.planTier} size=\"small\" variant=\"outlined\" />\n ),\n },\n {\n title: \"Requested\",\n field: \"metadata.creationTimestamp\",\n render: (row) => (\n <Typography variant=\"body2\">\n {row.metadata.creationTimestamp\n ? formatDate(row.metadata.creationTimestamp)\n : \"-\"}\n </Typography>\n ),\n },\n {\n title: \"Reviewed By\",\n field: \"status.reviewedBy\",\n render: (row) => {\n if (!row.status?.reviewedBy)\n return (\n <Typography variant=\"body2\" color=\"textSecondary\">\n -\n </Typography>\n );\n const reviewer = row.status.reviewedBy.replace(/^user:default\\//, \"\");\n const isAutomatic = reviewer === \"system\";\n return (\n <Box>\n <Typography variant=\"body2\">\n {isAutomatic ? \"Automatic\" : reviewer}\n </Typography>\n {row.status.reviewedAt && (\n <Typography variant=\"caption\" color=\"textSecondary\">\n {formatDate(row.status.reviewedAt)}\n </Typography>\n )}\n </Box>\n );\n },\n },\n {\n title: \"Actions\",\n filtering: false,\n render: (row) => {\n const phase = row.status?.phase || \"Pending\";\n if (phase !== \"Pending\") return null;\n\n const apiProductKey = `${row.metadata.namespace}/${row.spec.apiProductRef?.name || \"unknown\"}`;\n const ownsApiProduct =\n value?.ownedApiProducts?.has(apiProductKey) ?? false;\n const canUpdate =\n canUpdateAllRequests || (canUpdateOwnRequests && ownsApiProduct);\n if (!canUpdate) return null;\n\n return (\n <Box display=\"flex\" style={{ gap: 8 }}>\n <Button\n size=\"small\"\n startIcon={<CheckCircleIcon />}\n onClick={() => handleApprove(row)}\n color=\"primary\"\n variant=\"outlined\"\n >\n Approve\n </Button>\n <Button\n size=\"small\"\n startIcon={<CancelIcon />}\n onClick={() => handleReject(row)}\n color=\"secondary\"\n variant=\"outlined\"\n >\n Reject\n </Button>\n </Box>\n );\n },\n },\n ];\n\n const detailPanelConfig = useMemo(\n () => [\n {\n render: (data: any) => {\n const request = data.rowData as APIKey;\n if (!request?.metadata?.name) {\n return <Box />;\n }\n return <ExpandedRowContent request={request} />;\n },\n },\n ],\n [],\n );\n\n if (loading || updatePermissionLoading) {\n return <Progress />;\n }\n\n if (error) {\n return <ResponseErrorPanel error={error} />;\n }\n\n if (updatePermissionError) {\n return (\n <Box p={2}>\n <Typography color=\"error\">\n Unable to check permissions: {updatePermissionError.message}\n </Typography>\n </Box>\n );\n }\n\n const canSelectRows = canUpdateAllRequests || canUpdateOwnRequests;\n\n return (\n <>\n <Box className={classes.container}>\n <FilterPanel\n sections={filterSections}\n filters={filters}\n onChange={setFilters}\n />\n <Box className={classes.tableContainer}>\n {selectedRequests.length > 0 && (\n <Box className={classes.bulkActions}>\n <Typography variant=\"body2\">\n {selectedRequests.length} request\n {selectedRequests.length !== 1 ? \"s\" : \"\"} selected\n </Typography>\n <Box display=\"flex\" style={{ gap: 8 }}>\n <Button\n size=\"small\"\n variant=\"contained\"\n color=\"primary\"\n startIcon={<CheckCircleIcon />}\n onClick={handleBulkApprove}\n >\n Approve Selected\n </Button>\n <Button\n size=\"small\"\n variant=\"contained\"\n color=\"secondary\"\n startIcon={<CancelIcon />}\n onClick={handleBulkReject}\n >\n Reject Selected\n </Button>\n </Box>\n </Box>\n )}\n\n {filteredRequests.length === 0 ? (\n <Box p={4} textAlign=\"center\">\n <Typography variant=\"body1\" color=\"textSecondary\">\n {value?.allRequests?.length === 0\n ? \"No API keys found.\"\n : \"No API keys match the selected filters.\"}\n </Typography>\n </Box>\n ) : (\n <Table\n options={{\n selection: canSelectRows,\n showSelectAllCheckbox: filteredRequests.some(\n (r: APIKey) =>\n !r.status?.phase || r.status.phase === \"Pending\",\n ),\n selectionProps: (row: APIKey) => ({\n disabled:\n row.status?.phase !== \"Pending\" &&\n row.status?.phase !== undefined,\n }),\n paging: filteredRequests.length > 10,\n pageSize: 20,\n search: true,\n filtering: false,\n debounceInterval: 300,\n showTextRowsSelected: false,\n toolbar: true,\n emptyRowsWhenPaging: false,\n }}\n columns={columns}\n data={filteredRequests.map((item: APIKey) => {\n const isSelected = selectedRequests.some(\n (selected) =>\n selected.metadata.name === item.metadata.name &&\n selected.metadata.namespace === item.metadata.namespace,\n );\n return {\n ...item,\n id: item.metadata.name,\n tableData: { checked: isSelected },\n };\n })}\n onSelectionChange={(rows) => {\n // only allow selecting pending requests\n const pendingOnly = (rows as APIKey[]).filter(\n (r) => !r.status?.phase || r.status.phase === \"Pending\",\n );\n setSelectedRequests(pendingOnly);\n }}\n detailPanel={detailPanelConfig}\n />\n )}\n </Box>\n </Box>\n\n <ApprovalDialog\n open={dialogState.open}\n request={dialogState.request}\n action={dialogState.action}\n processing={dialogState.processing}\n onClose={() =>\n setDialogState({\n open: false,\n request: null,\n action: \"approve\",\n processing: false,\n })\n }\n onConfirm={handleConfirm}\n />\n <BulkActionDialog\n open={bulkDialogState.open}\n requests={bulkDialogState.requests}\n action={bulkDialogState.action}\n processing={bulkDialogState.processing}\n onClose={() =>\n setBulkDialogState({\n open: false,\n requests: [],\n action: \"approve\",\n processing: false,\n })\n }\n onConfirm={handleBulkConfirm}\n />\n </>\n );\n};\n","import React, { useState } from 'react';\nimport { Box, Tabs, Tab } from '@material-ui/core';\nimport {\n Header,\n Page,\n Content,\n SupportButton,\n} from '@backstage/core-components';\nimport { PermissionGate } from '../PermissionGate';\nimport { MyApiKeysTable } from '../MyApiKeysTable';\nimport { ApprovalQueueTable } from '../ApprovalQueueTable';\nimport {\n kuadrantApiKeyReadOwnPermission,\n kuadrantApiKeyApprovePermission,\n} from '../../permissions';\nimport { useKuadrantPermission } from '../../utils/permissions';\n\nconst ApiKeysContent = () => {\n const [selectedTab, setSelectedTab] = useState(0);\n\n const {\n allowed: canViewApprovalQueue,\n loading: approvalQueuePermissionLoading,\n } = useKuadrantPermission(kuadrantApiKeyApprovePermission);\n\n const handleTabChange = (_event: React.ChangeEvent<{}>, newValue: number) => {\n setSelectedTab(newValue);\n };\n\n return (\n <Page themeId=\"tool\">\n <Header title=\"API Keys\" subtitle=\"API keys management for Kubernetes\">\n <SupportButton>Manage your API keys and access requests</SupportButton>\n </Header>\n <Content>\n <Box mb={2}>\n <Tabs\n value={selectedTab}\n onChange={handleTabChange}\n indicatorColor=\"primary\"\n textColor=\"primary\"\n >\n <Tab label=\"My API keys\" data-testid=\"my-api-keys-tab\" />\n {!approvalQueuePermissionLoading && canViewApprovalQueue && (\n <Tab label=\"API keys approval\" data-testid=\"api-keys-approval-tab\" />\n )}\n </Tabs>\n </Box>\n\n {selectedTab === 0 && <MyApiKeysTable />}\n {selectedTab === 1 && canViewApprovalQueue && <ApprovalQueueTable />}\n </Content>\n </Page>\n );\n};\n\nexport const ApiKeysPage = () => {\n return (\n <PermissionGate\n permission={kuadrantApiKeyReadOwnPermission}\n errorMessage=\"you don't have permission to view the API Keys page\"\n >\n <ApiKeysContent />\n </PermissionGate>\n );\n};\n","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nvar _interopRequireWildcard = require(\"@babel/runtime/helpers/interopRequireWildcard\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar React = _interopRequireWildcard(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)( /*#__PURE__*/React.createElement(\"path\", {\n d: \"M12 8l-6 6 1.41 1.41L12 10.83l4.59 4.58L18 14z\"\n}), 'ExpandLess');\n\nexports.default = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nvar _interopRequireWildcard = require(\"@babel/runtime/helpers/interopRequireWildcard\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar React = _interopRequireWildcard(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)( /*#__PURE__*/React.createElement(\"path\", {\n d: \"M21 5v6.59l-3-3.01-4 4.01-4-4-4 4-3-3.01V5c0-1.1.9-2 2-2h14c1.1 0 2 .9 2 2zm-3 6.42l3 3.01V19c0 1.1-.9 2-2 2H5c-1.1 0-2-.9-2-2v-6.58l3 2.99 4-4 4 4 4-3.99z\"\n}), 'BrokenImage');\n\nexports.default = _default;","import React from 'react';\nimport { Typography, Box } from '@material-ui/core';\nimport { Progress } from '@backstage/core-components';\nimport { Permission } from '@backstage/plugin-permission-common';\nimport { useKuadrantPermission } from '../../utils/permissions';\n\ninterface PermissionGateProps {\n children: React.ReactNode;\n permission: Permission;\n fallback?: React.ReactNode;\n errorMessage?: string;\n}\n\nexport const PermissionGate = ({ children, permission, fallback, errorMessage }: PermissionGateProps) => {\n const { allowed, loading, error } = useKuadrantPermission(permission);\n\n if (loading) {\n return <Progress />;\n }\n\n if (error) {\n return (\n <Box p={4}>\n <Typography color=\"error\">\n Unable to check permissions: {error.message}\n </Typography>\n <Typography variant=\"body2\" color=\"textSecondary\">\n Please try again or contact your administrator\n </Typography>\n </Box>\n );\n }\n\n if (!allowed) {\n if (fallback) {\n return <>{fallback}</>;\n }\n return (\n <Box p={4}>\n <Typography color=\"textSecondary\">\n {errorMessage || 'You don\\'t have permission to view this page'}\n </Typography>\n <Box mt={1}>\n <Typography variant=\"caption\" color=\"textSecondary\">\n Required permission: {permission.name}\n </Typography>\n </Box>\n </Box>\n );\n }\n\n return <>{children}</>;\n};\n","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nvar _interopRequireWildcard = require(\"@babel/runtime/helpers/interopRequireWildcard\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar React = _interopRequireWildcard(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)( /*#__PURE__*/React.createElement(\"path\", {\n d: \"M6 19c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7H6v12zM19 4h-3.5l-1-1h-5l-1 1H5v2h14V4z\"\n}), 'Delete');\n\nexports.default = _default;","import { useApiHolder, configApiRef } from '@backstage/core-plugin-api';\nimport { coreComponentsTranslationRef } from '../translation.esm.js';\nimport { useTranslationRef } from '@backstage/core-plugin-api/alpha';\n\nconst useDefaultSupportConfig = () => {\n const { t } = useTranslationRef(coreComponentsTranslationRef);\n return {\n url: \"https://github.com/backstage/backstage/issues\",\n items: [\n {\n title: t(\"supportConfig.default.title\"),\n icon: \"warning\",\n links: [\n {\n // TODO: Update to dedicated support page on backstage.io/docs\n title: t(\"supportConfig.default.linkTitle\"),\n url: \"https://github.com/backstage/backstage/blob/master/app-config.yaml\"\n }\n ]\n }\n ]\n };\n};\nfunction useSupportConfig() {\n const apiHolder = useApiHolder();\n const config = apiHolder.get(configApiRef);\n const supportConfig = config?.getOptionalConfig(\"app.support\");\n const defaultSupportConfig = useDefaultSupportConfig();\n if (!supportConfig) {\n return defaultSupportConfig;\n }\n return {\n url: supportConfig.getString(\"url\"),\n items: supportConfig.getConfigArray(\"items\").flatMap((itemConf) => ({\n title: itemConf.getString(\"title\"),\n icon: itemConf.getOptionalString(\"icon\"),\n links: (itemConf.getOptionalConfigArray(\"links\") ?? []).flatMap(\n (linkConf) => ({\n url: linkConf.getString(\"url\"),\n title: linkConf.getOptionalString(\"title\") ?? \"\"\n })\n )\n }))\n };\n}\n\nexport { useSupportConfig };\n//# sourceMappingURL=useSupportConfig.esm.js.map\n","import { jsx } from 'react/jsx-runtime';\nimport { useApp } from '@backstage/core-plugin-api';\nimport MuiBrokenImageIcon from '@material-ui/icons/BrokenImage';\n\nfunction AppIcon(props) {\n const { id: key, Fallback = MuiBrokenImageIcon, ...rest } = props;\n const app = useApp();\n const Icon = app.getSystemIcon(key) ?? Fallback;\n return /* @__PURE__ */ jsx(Icon, { ...rest });\n}\nfunction BrokenImageIcon(props) {\n return /* @__PURE__ */ jsx(AppIcon, { id: \"brokenImage\", ...props });\n}\nfunction CatalogIcon(props) {\n return /* @__PURE__ */ jsx(AppIcon, { id: \"catalog\", ...props });\n}\nfunction ChatIcon(props) {\n return /* @__PURE__ */ jsx(AppIcon, { id: \"chat\", ...props });\n}\nfunction DashboardIcon(props) {\n return /* @__PURE__ */ jsx(AppIcon, { id: \"dashboard\", ...props });\n}\nfunction DocsIcon(props) {\n return /* @__PURE__ */ jsx(AppIcon, { id: \"docs\", ...props });\n}\nfunction EmailIcon(props) {\n return /* @__PURE__ */ jsx(AppIcon, { id: \"email\", ...props });\n}\nfunction GitHubIcon(props) {\n return /* @__PURE__ */ jsx(AppIcon, { id: \"github\", ...props });\n}\nfunction GroupIcon(props) {\n return /* @__PURE__ */ jsx(AppIcon, { id: \"group\", ...props });\n}\nfunction HelpIcon(props) {\n return /* @__PURE__ */ jsx(AppIcon, { id: \"help\", ...props });\n}\nfunction UserIcon(props) {\n return /* @__PURE__ */ jsx(AppIcon, { id: \"user\", ...props });\n}\nfunction WarningIcon(props) {\n return /* @__PURE__ */ jsx(AppIcon, { id: \"warning\", ...props });\n}\nfunction StarIcon(props) {\n return /* @__PURE__ */ jsx(AppIcon, { id: \"star\", ...props });\n}\nfunction UnstarredIcon(props) {\n return /* @__PURE__ */ jsx(AppIcon, { id: \"unstarred\", ...props });\n}\n\nexport { AppIcon, BrokenImageIcon, CatalogIcon, ChatIcon, DashboardIcon, DocsIcon, EmailIcon, GitHubIcon, GroupIcon, HelpIcon, StarIcon, UnstarredIcon, UserIcon, WarningIcon };\n//# sourceMappingURL=icons.esm.js.map\n","import { jsxs, Fragment, jsx } from 'react/jsx-runtime';\nimport { useApi, configApiRef, useApp } from '@backstage/core-plugin-api';\nimport Box from '@material-ui/core/Box';\nimport Button from '@material-ui/core/Button';\nimport DialogActions from '@material-ui/core/DialogActions';\nimport IconButton from '@material-ui/core/IconButton';\nimport ListItemIcon from '@material-ui/core/ListItemIcon';\nimport ListItemText from '@material-ui/core/ListItemText';\nimport MenuItem from '@material-ui/core/MenuItem';\nimport MenuList from '@material-ui/core/MenuList';\nimport Popover from '@material-ui/core/Popover';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Typography from '@material-ui/core/Typography';\nimport useMediaQuery from '@material-ui/core/useMediaQuery';\nimport { useState, Children } from 'react';\nimport 'lodash';\nimport 'qs';\nimport 'react-router-dom';\nimport '@react-hookz/web';\nimport { useSupportConfig } from '../../hooks/useSupportConfig.esm.js';\nimport { HelpIcon } from '../../icons/icons.esm.js';\nimport { Link } from '../Link/Link.esm.js';\nimport { coreComponentsTranslationRef } from '../../translation.esm.js';\nimport { useTranslationRef } from '@backstage/core-plugin-api/alpha';\n\nconst useStyles = makeStyles(\n {\n popoverList: {\n minWidth: 260,\n maxWidth: 400\n },\n menuItem: {\n whiteSpace: \"normal\"\n }\n },\n { name: \"BackstageSupportButton\" }\n);\nconst SupportIcon = ({ icon }) => {\n const app = useApp();\n const Icon = icon ? app.getSystemIcon(icon) ?? HelpIcon : HelpIcon;\n return /* @__PURE__ */ jsx(Icon, {});\n};\nconst SupportLink = ({ link }) => /* @__PURE__ */ jsx(Link, { to: link.url, children: link.title ?? link.url });\nconst SupportListItem = ({ item }) => {\n return /* @__PURE__ */ jsxs(MenuItem, { button: false, children: [\n /* @__PURE__ */ jsx(ListItemIcon, { children: /* @__PURE__ */ jsx(SupportIcon, { icon: item.icon }) }),\n /* @__PURE__ */ jsx(\n ListItemText,\n {\n primary: item.title,\n secondary: item.links?.reduce(\n (prev, link, idx) => [\n ...prev,\n idx > 0 && /* @__PURE__ */ jsx(\"br\", {}, idx),\n /* @__PURE__ */ jsx(SupportLink, { link }, link.url)\n ],\n []\n )\n }\n )\n ] });\n};\nfunction SupportButton(props) {\n const { t } = useTranslationRef(coreComponentsTranslationRef);\n const { title, items, children } = props;\n const { items: configItems } = useSupportConfig();\n const [popoverOpen, setPopoverOpen] = useState(false);\n const [anchorEl, setAnchorEl] = useState(null);\n const classes = useStyles();\n const supportConfig = useApi(configApiRef).getOptionalConfig(\"app.support\");\n const isSmallScreen = useMediaQuery(\n (theme) => theme.breakpoints.down(\"sm\")\n );\n const onClickHandler = (event) => {\n setAnchorEl(event.currentTarget);\n setPopoverOpen(true);\n };\n const popoverCloseHandler = () => {\n setPopoverOpen(false);\n };\n if (!supportConfig) {\n return null;\n }\n return /* @__PURE__ */ jsxs(Fragment, { children: [\n /* @__PURE__ */ jsx(Box, { display: \"flex\", ml: 1, children: isSmallScreen ? /* @__PURE__ */ jsx(\n IconButton,\n {\n color: \"primary\",\n size: \"small\",\n onClick: onClickHandler,\n \"data-testid\": \"support-button\",\n \"aria-label\": \"Support\",\n children: /* @__PURE__ */ jsx(HelpIcon, {})\n }\n ) : /* @__PURE__ */ jsx(\n Button,\n {\n \"data-testid\": \"support-button\",\n \"aria-label\": \"Support\",\n color: \"primary\",\n onClick: onClickHandler,\n startIcon: /* @__PURE__ */ jsx(HelpIcon, {}),\n children: t(\"supportButton.title\")\n }\n ) }),\n /* @__PURE__ */ jsxs(\n Popover,\n {\n \"data-testid\": \"support-button-popover\",\n open: popoverOpen,\n anchorEl,\n anchorOrigin: {\n vertical: \"bottom\",\n horizontal: \"right\"\n },\n transformOrigin: {\n vertical: \"top\",\n horizontal: \"right\"\n },\n onClose: popoverCloseHandler,\n children: [\n /* @__PURE__ */ jsxs(\n MenuList,\n {\n className: classes.popoverList,\n autoFocusItem: Boolean(anchorEl),\n children: [\n title && /* @__PURE__ */ jsx(\n MenuItem,\n {\n button: false,\n alignItems: \"flex-start\",\n className: classes.menuItem,\n children: /* @__PURE__ */ jsx(Typography, { variant: \"subtitle1\", children: title })\n }\n ),\n Children.map(children, (child, i) => /* @__PURE__ */ jsx(\n MenuItem,\n {\n button: false,\n alignItems: \"flex-start\",\n className: classes.menuItem,\n children: child\n },\n `child-${i}`\n )),\n (items ?? configItems).map((item, i) => /* @__PURE__ */ jsx(SupportListItem, { item }, `item-${i}`))\n ]\n }\n ),\n /* @__PURE__ */ jsx(DialogActions, { children: /* @__PURE__ */ jsx(\n Button,\n {\n color: \"primary\",\n onClick: popoverCloseHandler,\n \"aria-label\": \"Close\",\n children: t(\"supportButton.close\")\n }\n ) })\n ]\n }\n )\n ] });\n}\n\nexport { SupportButton };\n//# sourceMappingURL=SupportButton.esm.js.map\n","import { CSSProperties } from \"react\";\n\n/**\n * Returns inline styles for API key status chips.\n * Uses inline styles to ensure proper specificity with Material-UI Chip.\n */\nexport const getStatusChipStyle = (phase: string): CSSProperties => {\n const base = { border: \"none\" };\n switch (phase) {\n case \"Approved\":\n return { ...base, backgroundColor: \"#4caf50\", color: \"#fff\" };\n case \"Rejected\":\n return { ...base, backgroundColor: \"#f44336\", color: \"#fff\" };\n default:\n return { ...base, backgroundColor: \"#ff9800\", color: \"#fff\" };\n }\n};\n","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nvar _interopRequireWildcard = require(\"@babel/runtime/helpers/interopRequireWildcard\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar React = _interopRequireWildcard(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)( /*#__PURE__*/React.createElement(\"path\", {\n d: \"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm-2 15l-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8l-9 9z\"\n}), 'CheckCircle');\n\nexports.default = _default;","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar react_1 = require(\"react\");\nvar useAsyncFn_1 = tslib_1.__importDefault(require(\"./useAsyncFn\"));\nfunction useAsync(fn, deps) {\n if (deps === void 0) { deps = []; }\n var _a = useAsyncFn_1.default(fn, deps, {\n loading: true,\n }), state = _a[0], callback = _a[1];\n react_1.useEffect(function () {\n callback();\n }, [callback]);\n return state;\n}\nexports.default = useAsync;\n"],"names":["Object","defineProperty","exports","value","tslib_1","react_1","useMountedState_1","__importDefault","fn","deps","initialState","loading","lastCallId","useRef","isMounted","default","_a","useState","state","set","callback","useCallback","args","_i","arguments","length","callId","current","prevState","__assign","apply","then","error","mountedRef","get","useEffect","useStyles","makeStyles","theme","root","width","minWidth","padding","spacing","borderRight","palette","divider","backgroundColor","background","paper","height","overflowY","sectionTitle","fontWeight","fontSize","textTransform","letterSpacing","color","text","secondary","marginBottom","display","alignItems","justifyContent","cursor","userSelect","filterSection","checkbox","checkboxLabel","clearButton","marginTop","count","marginLeft","FilterPanel","sections","filters","onChange","onClear","classes","collapsedSections","setCollapsedSections","React","Set","filter","s","collapsed","map","id","hasActiveFilters","values","some","Box","className","mb","Typography","variant","Button","size","onClick","clearedFilters","forEach","section","Divider","isCollapsed","has","selectedCount","mt","toggleSection","sectionId","prev","next","delete","add","span","title","ExpandMoreIcon","ExpandLessIcon","Collapse","in","FormGroup","options","option","FormControlLabel","control","Checkbox","checked","includes","currentValues","newValues","v","handleCheckboxChange","label","undefined","container","minHeight","tableContainer","flex","overflow","useCasePanel","useCaseLabel","rejectedBanner","light","border","main","borderRadius","shape","gap","ExpandedRowContent","request","isRejected","status","phase","apiProductName","spec","apiProductRef","name","e","stopPropagation","WarningIcon","Link","to","useCase","MyApiKeysTable","deleteDialogState","navigate","useNavigate","config","useApi","configApiRef","fetchApi","fetchApiRef","alertApi","alertApiRef","backendUrl","getString","visibleKeys","setVisibleKeys","menuAnchor","setMenuAnchor","menuRequest","setMenuRequest","editDialogState","setEditDialogState","open","plans","refresh","setRefresh","deleting","setDeleting","setDeleteDialogState","apiKeyValues","setApiKeyValues","Map","apiKeyLoading","setApiKeyLoading","alreadyReadKeys","setAlreadyReadKeys","showOnceWarningOpen","setShowOnceWarningOpen","pendingKeyReveal","setPendingKeyReveal","optimisticallyDeleted","setOptimisticallyDeleted","setFilters","apiProduct","tier","data","useAsync","async","requestsResponse","productsResponse","Promise","all","fetch","ok","Error","requests","json","items","products","ownerMap","p","key","metadata","namespace","owner","annotations","allRequests","useMemo","r","filterSections","statusCounts","Approved","Pending","Rejected","apiProductCounts","tierCounts","planTier","Array","from","entries","charAt","toUpperCase","slice","filteredRequests","toggleKeyVisibility","keyName","newSet","handleMenuClose","handleEdit","apiProductNamespace","apiProductResponse","err","console","handleDeleteClick","columns","field","render","row","strong","displayOwner","replace","Chip","style","getStatusChipStyle","filtering","hasSecretRef","secretRef","isVisible","isLoading","apiKeyValue","canReadSecret","isAlreadyRead","Tooltip","fontFamily","marginRight","VisibilityOffIcon","repeat","IconButton","navigator","clipboard","writeText","post","message","severity","FileCopyIcon","requestNamespace","requestName","clearApiKeyValue","disabled","VisibilityIcon","creationTimestamp","date","Date","toLocaleDateString","CircularProgress","DeleteIcon","detailPanelConfig","rowData","Progress","ResponseErrorPanel","textAlign","Table","paging","pageSize","search","debounceInterval","toolbar","emptyRowsWhenPaging","item","detailPanel","Menu","Boolean","onClose","anchorReference","anchorPosition","top","left","push","MenuItem","EditAPIKeyDialog","availablePlans","onSuccess","ConfirmDeleteDialog","description","onConfirm","method","onCancel","Dialog","maxWidth","DialogTitle","DialogContent","paragraph","DialogActions","response","result","apiKey","fetchApiKeyFromSecret","bulkActions","borderBottom","ApprovalDialog","action","processing","confirmInput","setConfirmInput","actionLabel","processingLabel","isReject","confirmText","requestedBy","userId","canConfirm","fullWidth","CancelIcon","component","whiteSpace","gutterBottom","TextField","target","autoFocus","placeholder","startIcon","BulkActionDialog","isApprove","maxHeight","bgcolor","ApprovalQueueTable","identityApi","identityApiRef","selectedRequests","setSelectedRequests","dialogState","setDialogState","bulkDialogState","setBulkDialogState","allowed","canUpdateAllRequests","updateAllPermissionLoading","updateAllPermissionError","useKuadrantPermission","kuadrantApiKeyUpdateAllPermission","canUpdateOwnRequests","updateOwnPermissionLoading","updateOwnPermissionError","kuadrantApiKeyUpdateOwnPermission","updatePermissionLoading","updatePermissionError","reviewedBy","getBackstageIdentity","userEntityRef","apiProductsResponse","ownedApiProducts","contentType","headers","apiProductsData","product","formatDate","dateString","year","month","day","reviewer","isAutomatic","reviewedAt","apiProductKey","ownsApiProduct","CheckCircleIcon","canSelectRows","selection","showSelectAllCheckbox","selectionProps","showTextRowsSelected","isSelected","selected","tableData","onSelectionChange","rows","pendingOnly","endpoint","body","JSON","stringify","ApiKeysContent","selectedTab","setSelectedTab","canViewApprovalQueue","approvalQueuePermissionLoading","kuadrantApiKeyApprovePermission","Page","themeId","Header","subtitle","SupportButton","Content","Tabs","_event","newValue","indicatorColor","textColor","Tab","data-testid","ApiKeysPage","PermissionGate","permission","kuadrantApiKeyReadOwnPermission","errorMessage","_interopRequireDefault","_interopRequireWildcard","_default","createElement","d","children","fallback","useDefaultSupportConfig","t","url","icon","links","AppIcon","props","Fallback","rest","Icon","useApp","getSystemIcon","jsx","HelpIcon","popoverList","menuItem","SupportIcon","app","SupportLink","link","SupportListItem","jsxs","button","ListItemIcon","ListItemText","primary","reduce","idx","configItems","useApiHolder","supportConfig","getOptionalConfig","defaultSupportConfig","getConfigArray","flatMap","itemConf","getOptionalString","getOptionalConfigArray","linkConf","useSupportConfig","popoverOpen","setPopoverOpen","anchorEl","setAnchorEl","isSmallScreen","useMediaQuery","breakpoints","down","onClickHandler","event","currentTarget","popoverCloseHandler","Fragment","ml","Popover","anchorOrigin","vertical","horizontal","transformOrigin","MenuList","autoFocusItem","Children","child","i","base","useAsyncFn_1"],"sourceRoot":""}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"static/6979.9699b350.chunk.js","mappings":"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","sources":["webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/core/esm/Fade/Fade.js","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/core/esm/utils/scrollLeft.js","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/core/esm/internal/animate.js","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/core/esm/Tabs/ScrollbarSize.js","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/core/esm/Tabs/TabIndicator.js","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/core/esm/Tabs/Tabs.js","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/core/esm/Tab/Tab.js","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/core/esm/TabScrollButton/TabScrollButton.js","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/core/esm/DialogContent/DialogContent.js","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/core/esm/internal/svg-icons/KeyboardArrowLeft.js","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/core/esm/internal/svg-icons/KeyboardArrowRight.js","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/core/esm/styles/makeStyles.js","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/core/esm/DialogTitle/DialogTitle.js","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/core/esm/Backdrop/Backdrop.js","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/core/esm/Dialog/Dialog.js","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/core/esm/DialogActions/DialogActions.js"],"sourcesContent":["import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _slicedToArray from \"@babel/runtime/helpers/esm/slicedToArray\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport { Transition } from 'react-transition-group';\nimport { duration } from '../styles/transitions';\nimport useTheme from '../styles/useTheme';\nimport { reflow, getTransitionProps } from '../transitions/utils';\nimport useForkRef from '../utils/useForkRef';\nvar styles = {\n entering: {\n opacity: 1\n },\n entered: {\n opacity: 1\n }\n};\nvar defaultTimeout = {\n enter: duration.enteringScreen,\n exit: duration.leavingScreen\n};\n/**\n * The Fade transition is used by the [Modal](/components/modal/) component.\n * It uses [react-transition-group](https://github.com/reactjs/react-transition-group) internally.\n */\n\nvar Fade = /*#__PURE__*/React.forwardRef(function Fade(props, ref) {\n var children = props.children,\n _props$disableStrictM = props.disableStrictModeCompat,\n disableStrictModeCompat = _props$disableStrictM === void 0 ? false : _props$disableStrictM,\n inProp = props.in,\n onEnter = props.onEnter,\n onEntered = props.onEntered,\n onEntering = props.onEntering,\n onExit = props.onExit,\n onExited = props.onExited,\n onExiting = props.onExiting,\n style = props.style,\n _props$TransitionComp = props.TransitionComponent,\n TransitionComponent = _props$TransitionComp === void 0 ? Transition : _props$TransitionComp,\n _props$timeout = props.timeout,\n timeout = _props$timeout === void 0 ? defaultTimeout : _props$timeout,\n other = _objectWithoutProperties(props, [\"children\", \"disableStrictModeCompat\", \"in\", \"onEnter\", \"onEntered\", \"onEntering\", \"onExit\", \"onExited\", \"onExiting\", \"style\", \"TransitionComponent\", \"timeout\"]);\n\n var theme = useTheme();\n var enableStrictModeCompat = theme.unstable_strictMode && !disableStrictModeCompat;\n var nodeRef = React.useRef(null);\n var foreignRef = useForkRef(children.ref, ref);\n var handleRef = useForkRef(enableStrictModeCompat ? nodeRef : undefined, foreignRef);\n\n var normalizedTransitionCallback = function normalizedTransitionCallback(callback) {\n return function (nodeOrAppearing, maybeAppearing) {\n if (callback) {\n var _ref = enableStrictModeCompat ? [nodeRef.current, nodeOrAppearing] : [nodeOrAppearing, maybeAppearing],\n _ref2 = _slicedToArray(_ref, 2),\n node = _ref2[0],\n isAppearing = _ref2[1]; // onEnterXxx and onExitXxx callbacks have a different arguments.length value.\n\n\n if (isAppearing === undefined) {\n callback(node);\n } else {\n callback(node, isAppearing);\n }\n }\n };\n };\n\n var handleEntering = normalizedTransitionCallback(onEntering);\n var handleEnter = normalizedTransitionCallback(function (node, isAppearing) {\n reflow(node); // So the animation always start from the start.\n\n var transitionProps = getTransitionProps({\n style: style,\n timeout: timeout\n }, {\n mode: 'enter'\n });\n node.style.webkitTransition = theme.transitions.create('opacity', transitionProps);\n node.style.transition = theme.transitions.create('opacity', transitionProps);\n\n if (onEnter) {\n onEnter(node, isAppearing);\n }\n });\n var handleEntered = normalizedTransitionCallback(onEntered);\n var handleExiting = normalizedTransitionCallback(onExiting);\n var handleExit = normalizedTransitionCallback(function (node) {\n var transitionProps = getTransitionProps({\n style: style,\n timeout: timeout\n }, {\n mode: 'exit'\n });\n node.style.webkitTransition = theme.transitions.create('opacity', transitionProps);\n node.style.transition = theme.transitions.create('opacity', transitionProps);\n\n if (onExit) {\n onExit(node);\n }\n });\n var handleExited = normalizedTransitionCallback(onExited);\n return /*#__PURE__*/React.createElement(TransitionComponent, _extends({\n appear: true,\n in: inProp,\n nodeRef: enableStrictModeCompat ? nodeRef : undefined,\n onEnter: handleEnter,\n onEntered: handleEntered,\n onEntering: handleEntering,\n onExit: handleExit,\n onExited: handleExited,\n onExiting: handleExiting,\n timeout: timeout\n }, other), function (state, childProps) {\n return /*#__PURE__*/React.cloneElement(children, _extends({\n style: _extends({\n opacity: 0,\n visibility: state === 'exited' && !inProp ? 'hidden' : undefined\n }, styles[state], style, children.props.style),\n ref: handleRef\n }, childProps));\n });\n});\nprocess.env.NODE_ENV !== \"production\" ? Fade.propTypes = {\n // ----------------------------- Warning --------------------------------\n // | These PropTypes are generated from the TypeScript type definitions |\n // | To update them edit the d.ts file and run \"yarn proptypes\" |\n // ----------------------------------------------------------------------\n\n /**\n * A single child content element.\n */\n children: PropTypes.element,\n\n /**\n * Enable this prop if you encounter 'Function components cannot be given refs',\n * use `unstable_createStrictModeTheme`,\n * and can't forward the ref in the child component.\n */\n disableStrictModeCompat: PropTypes.bool,\n\n /**\n * If `true`, the component will transition in.\n */\n in: PropTypes.bool,\n\n /**\n * @ignore\n */\n onEnter: PropTypes.func,\n\n /**\n * @ignore\n */\n onEntered: PropTypes.func,\n\n /**\n * @ignore\n */\n onEntering: PropTypes.func,\n\n /**\n * @ignore\n */\n onExit: PropTypes.func,\n\n /**\n * @ignore\n */\n onExited: PropTypes.func,\n\n /**\n * @ignore\n */\n onExiting: PropTypes.func,\n\n /**\n * @ignore\n */\n style: PropTypes.object,\n\n /**\n * The duration for the transition, in milliseconds.\n * You may specify a single timeout for all transitions, or individually with an object.\n */\n timeout: PropTypes.oneOfType([PropTypes.number, PropTypes.shape({\n appear: PropTypes.number,\n enter: PropTypes.number,\n exit: PropTypes.number\n })])\n} : void 0;\nexport default Fade;","// Source from https://github.com/alitaheri/normalize-scroll-left\nvar cachedType;\n/**\n * Based on the jquery plugin https://github.com/othree/jquery.rtl-scroll-type\n *\n * Types of scrollLeft, assuming scrollWidth=100 and direction is rtl.\n *\n * Type | <- Most Left | Most Right -> | Initial\n * ---------------- | ------------ | ------------- | -------\n * default | 0 | 100 | 100\n * negative (spec*) | -100 | 0 | 0\n * reverse | 100 | 0 | 0\n *\n * Edge 85: default\n * Safari 14: negative\n * Chrome 85: negative\n * Firefox 81: negative\n * IE 11: reverse\n *\n * spec* https://drafts.csswg.org/cssom-view/#dom-window-scroll\n */\n\nexport function detectScrollType() {\n if (cachedType) {\n return cachedType;\n }\n\n var dummy = document.createElement('div');\n var container = document.createElement('div');\n container.style.width = '10px';\n container.style.height = '1px';\n dummy.appendChild(container);\n dummy.dir = 'rtl';\n dummy.style.fontSize = '14px';\n dummy.style.width = '4px';\n dummy.style.height = '1px';\n dummy.style.position = 'absolute';\n dummy.style.top = '-1000px';\n dummy.style.overflow = 'scroll';\n document.body.appendChild(dummy);\n cachedType = 'reverse';\n\n if (dummy.scrollLeft > 0) {\n cachedType = 'default';\n } else {\n dummy.scrollLeft = 1;\n\n if (dummy.scrollLeft === 0) {\n cachedType = 'negative';\n }\n }\n\n document.body.removeChild(dummy);\n return cachedType;\n} // Based on https://stackoverflow.com/a/24394376\n\nexport function getNormalizedScrollLeft(element, direction) {\n var scrollLeft = element.scrollLeft; // Perform the calculations only when direction is rtl to avoid messing up the ltr bahavior\n\n if (direction !== 'rtl') {\n return scrollLeft;\n }\n\n var type = detectScrollType();\n\n switch (type) {\n case 'negative':\n return element.scrollWidth - element.clientWidth + scrollLeft;\n\n case 'reverse':\n return element.scrollWidth - element.clientWidth - scrollLeft;\n\n default:\n return scrollLeft;\n }\n}","function easeInOutSin(time) {\n return (1 + Math.sin(Math.PI * time - Math.PI / 2)) / 2;\n}\n\nexport default function animate(property, element, to) {\n var options = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};\n var cb = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : function () {};\n var _options$ease = options.ease,\n ease = _options$ease === void 0 ? easeInOutSin : _options$ease,\n _options$duration = options.duration,\n duration = _options$duration === void 0 ? 300 : _options$duration;\n var start = null;\n var from = element[property];\n var cancelled = false;\n\n var cancel = function cancel() {\n cancelled = true;\n };\n\n var step = function step(timestamp) {\n if (cancelled) {\n cb(new Error('Animation cancelled'));\n return;\n }\n\n if (start === null) {\n start = timestamp;\n }\n\n var time = Math.min(1, (timestamp - start) / duration);\n element[property] = ease(time) * (to - from) + from;\n\n if (time >= 1) {\n requestAnimationFrame(function () {\n cb(null);\n });\n return;\n }\n\n requestAnimationFrame(step);\n };\n\n if (from === to) {\n cb(new Error('Element already at target position'));\n return cancel;\n }\n\n requestAnimationFrame(step);\n return cancel;\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport debounce from '../utils/debounce';\nvar styles = {\n width: 99,\n height: 99,\n position: 'absolute',\n top: -9999,\n overflow: 'scroll'\n};\n/**\n * @ignore - internal component.\n * The component originates from https://github.com/STORIS/react-scrollbar-size.\n * It has been moved into the core in order to minimize the bundle size.\n */\n\nexport default function ScrollbarSize(props) {\n var onChange = props.onChange,\n other = _objectWithoutProperties(props, [\"onChange\"]);\n\n var scrollbarHeight = React.useRef();\n var nodeRef = React.useRef(null);\n\n var setMeasurements = function setMeasurements() {\n scrollbarHeight.current = nodeRef.current.offsetHeight - nodeRef.current.clientHeight;\n };\n\n React.useEffect(function () {\n var handleResize = debounce(function () {\n var prevHeight = scrollbarHeight.current;\n setMeasurements();\n\n if (prevHeight !== scrollbarHeight.current) {\n onChange(scrollbarHeight.current);\n }\n });\n window.addEventListener('resize', handleResize);\n return function () {\n handleResize.clear();\n window.removeEventListener('resize', handleResize);\n };\n }, [onChange]);\n React.useEffect(function () {\n setMeasurements();\n onChange(scrollbarHeight.current);\n }, [onChange]);\n return /*#__PURE__*/React.createElement(\"div\", _extends({\n style: styles,\n ref: nodeRef\n }, other));\n}\nprocess.env.NODE_ENV !== \"production\" ? ScrollbarSize.propTypes = {\n onChange: PropTypes.func.isRequired\n} : void 0;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport capitalize from '../utils/capitalize';\nexport var styles = function styles(theme) {\n return {\n root: {\n position: 'absolute',\n height: 2,\n bottom: 0,\n width: '100%',\n transition: theme.transitions.create()\n },\n colorPrimary: {\n backgroundColor: theme.palette.primary.main\n },\n colorSecondary: {\n backgroundColor: theme.palette.secondary.main\n },\n vertical: {\n height: '100%',\n width: 2,\n right: 0\n }\n };\n};\n/**\n * @ignore - internal component.\n */\n\nvar TabIndicator = /*#__PURE__*/React.forwardRef(function TabIndicator(props, ref) {\n var classes = props.classes,\n className = props.className,\n color = props.color,\n orientation = props.orientation,\n other = _objectWithoutProperties(props, [\"classes\", \"className\", \"color\", \"orientation\"]);\n\n return /*#__PURE__*/React.createElement(\"span\", _extends({\n className: clsx(classes.root, classes[\"color\".concat(capitalize(color))], className, orientation === 'vertical' && classes.vertical),\n ref: ref\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? TabIndicator.propTypes = {\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * @ignore\n * The color of the tab indicator.\n */\n color: PropTypes.oneOf(['primary', 'secondary']).isRequired,\n\n /**\n * The tabs orientation (layout flow direction).\n */\n orientation: PropTypes.oneOf(['horizontal', 'vertical']).isRequired\n} : void 0;\nexport default withStyles(styles, {\n name: 'PrivateTabIndicator'\n})(TabIndicator);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport _defineProperty from \"@babel/runtime/helpers/esm/defineProperty\";\nimport * as React from 'react';\nimport { isFragment } from 'react-is';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { refType } from '@material-ui/utils';\nimport debounce from '../utils/debounce';\nimport ownerWindow from '../utils/ownerWindow';\nimport { getNormalizedScrollLeft, detectScrollType } from '../utils/scrollLeft';\nimport animate from '../internal/animate';\nimport ScrollbarSize from './ScrollbarSize';\nimport withStyles from '../styles/withStyles';\nimport TabIndicator from './TabIndicator';\nimport TabScrollButton from '../TabScrollButton';\nimport useEventCallback from '../utils/useEventCallback';\nimport useTheme from '../styles/useTheme';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n overflow: 'hidden',\n minHeight: 48,\n WebkitOverflowScrolling: 'touch',\n // Add iOS momentum scrolling.\n display: 'flex'\n },\n\n /* Styles applied to the root element if `orientation=\"vertical\"`. */\n vertical: {\n flexDirection: 'column'\n },\n\n /* Styles applied to the flex container element. */\n flexContainer: {\n display: 'flex'\n },\n\n /* Styles applied to the flex container element if `orientation=\"vertical\"`. */\n flexContainerVertical: {\n flexDirection: 'column'\n },\n\n /* Styles applied to the flex container element if `centered={true}` & `!variant=\"scrollable\"`. */\n centered: {\n justifyContent: 'center'\n },\n\n /* Styles applied to the tablist element. */\n scroller: {\n position: 'relative',\n display: 'inline-block',\n flex: '1 1 auto',\n whiteSpace: 'nowrap'\n },\n\n /* Styles applied to the tablist element if `!variant=\"scrollable\"`\b\b\b. */\n fixed: {\n overflowX: 'hidden',\n width: '100%'\n },\n\n /* Styles applied to the tablist element if `variant=\"scrollable\"`. */\n scrollable: {\n overflowX: 'scroll',\n // Hide dimensionless scrollbar on MacOS\n scrollbarWidth: 'none',\n // Firefox\n '&::-webkit-scrollbar': {\n display: 'none' // Safari + Chrome\n\n }\n },\n\n /* Styles applied to the `ScrollButtonComponent` component. */\n scrollButtons: {},\n\n /* Styles applied to the `ScrollButtonComponent` component if `scrollButtons=\"auto\"` or scrollButtons=\"desktop\"`. */\n scrollButtonsDesktop: _defineProperty({}, theme.breakpoints.down('xs'), {\n display: 'none'\n }),\n\n /* Styles applied to the `TabIndicator` component. */\n indicator: {}\n };\n};\nvar Tabs = /*#__PURE__*/React.forwardRef(function Tabs(props, ref) {\n var ariaLabel = props['aria-label'],\n ariaLabelledBy = props['aria-labelledby'],\n action = props.action,\n _props$centered = props.centered,\n centered = _props$centered === void 0 ? false : _props$centered,\n childrenProp = props.children,\n classes = props.classes,\n className = props.className,\n _props$component = props.component,\n Component = _props$component === void 0 ? 'div' : _props$component,\n _props$indicatorColor = props.indicatorColor,\n indicatorColor = _props$indicatorColor === void 0 ? 'secondary' : _props$indicatorColor,\n onChange = props.onChange,\n _props$orientation = props.orientation,\n orientation = _props$orientation === void 0 ? 'horizontal' : _props$orientation,\n _props$ScrollButtonCo = props.ScrollButtonComponent,\n ScrollButtonComponent = _props$ScrollButtonCo === void 0 ? TabScrollButton : _props$ScrollButtonCo,\n _props$scrollButtons = props.scrollButtons,\n scrollButtons = _props$scrollButtons === void 0 ? 'auto' : _props$scrollButtons,\n selectionFollowsFocus = props.selectionFollowsFocus,\n _props$TabIndicatorPr = props.TabIndicatorProps,\n TabIndicatorProps = _props$TabIndicatorPr === void 0 ? {} : _props$TabIndicatorPr,\n TabScrollButtonProps = props.TabScrollButtonProps,\n _props$textColor = props.textColor,\n textColor = _props$textColor === void 0 ? 'inherit' : _props$textColor,\n value = props.value,\n _props$variant = props.variant,\n variant = _props$variant === void 0 ? 'standard' : _props$variant,\n other = _objectWithoutProperties(props, [\"aria-label\", \"aria-labelledby\", \"action\", \"centered\", \"children\", \"classes\", \"className\", \"component\", \"indicatorColor\", \"onChange\", \"orientation\", \"ScrollButtonComponent\", \"scrollButtons\", \"selectionFollowsFocus\", \"TabIndicatorProps\", \"TabScrollButtonProps\", \"textColor\", \"value\", \"variant\"]);\n\n var theme = useTheme();\n var scrollable = variant === 'scrollable';\n var isRtl = theme.direction === 'rtl';\n var vertical = orientation === 'vertical';\n var scrollStart = vertical ? 'scrollTop' : 'scrollLeft';\n var start = vertical ? 'top' : 'left';\n var end = vertical ? 'bottom' : 'right';\n var clientSize = vertical ? 'clientHeight' : 'clientWidth';\n var size = vertical ? 'height' : 'width';\n\n if (process.env.NODE_ENV !== 'production') {\n if (centered && scrollable) {\n console.error('Material-UI: You can not use the `centered={true}` and `variant=\"scrollable\"` properties ' + 'at the same time on a `Tabs` component.');\n }\n }\n\n var _React$useState = React.useState(false),\n mounted = _React$useState[0],\n setMounted = _React$useState[1];\n\n var _React$useState2 = React.useState({}),\n indicatorStyle = _React$useState2[0],\n setIndicatorStyle = _React$useState2[1];\n\n var _React$useState3 = React.useState({\n start: false,\n end: false\n }),\n displayScroll = _React$useState3[0],\n setDisplayScroll = _React$useState3[1];\n\n var _React$useState4 = React.useState({\n overflow: 'hidden',\n marginBottom: null\n }),\n scrollerStyle = _React$useState4[0],\n setScrollerStyle = _React$useState4[1];\n\n var valueToIndex = new Map();\n var tabsRef = React.useRef(null);\n var tabListRef = React.useRef(null);\n\n var getTabsMeta = function getTabsMeta() {\n var tabsNode = tabsRef.current;\n var tabsMeta;\n\n if (tabsNode) {\n var rect = tabsNode.getBoundingClientRect(); // create a new object with ClientRect class props + scrollLeft\n\n tabsMeta = {\n clientWidth: tabsNode.clientWidth,\n scrollLeft: tabsNode.scrollLeft,\n scrollTop: tabsNode.scrollTop,\n scrollLeftNormalized: getNormalizedScrollLeft(tabsNode, theme.direction),\n scrollWidth: tabsNode.scrollWidth,\n top: rect.top,\n bottom: rect.bottom,\n left: rect.left,\n right: rect.right\n };\n }\n\n var tabMeta;\n\n if (tabsNode && value !== false) {\n var _children = tabListRef.current.children;\n\n if (_children.length > 0) {\n var tab = _children[valueToIndex.get(value)];\n\n if (process.env.NODE_ENV !== 'production') {\n if (!tab) {\n console.error([\"Material-UI: The value provided to the Tabs component is invalid.\", \"None of the Tabs' children match with `\".concat(value, \"`.\"), valueToIndex.keys ? \"You can provide one of the following values: \".concat(Array.from(valueToIndex.keys()).join(', '), \".\") : null].join('\\n'));\n }\n }\n\n tabMeta = tab ? tab.getBoundingClientRect() : null;\n }\n }\n\n return {\n tabsMeta: tabsMeta,\n tabMeta: tabMeta\n };\n };\n\n var updateIndicatorState = useEventCallback(function () {\n var _newIndicatorStyle;\n\n var _getTabsMeta = getTabsMeta(),\n tabsMeta = _getTabsMeta.tabsMeta,\n tabMeta = _getTabsMeta.tabMeta;\n\n var startValue = 0;\n\n if (tabMeta && tabsMeta) {\n if (vertical) {\n startValue = tabMeta.top - tabsMeta.top + tabsMeta.scrollTop;\n } else {\n var correction = isRtl ? tabsMeta.scrollLeftNormalized + tabsMeta.clientWidth - tabsMeta.scrollWidth : tabsMeta.scrollLeft;\n startValue = tabMeta.left - tabsMeta.left + correction;\n }\n }\n\n var newIndicatorStyle = (_newIndicatorStyle = {}, _defineProperty(_newIndicatorStyle, start, startValue), _defineProperty(_newIndicatorStyle, size, tabMeta ? tabMeta[size] : 0), _newIndicatorStyle);\n\n if (isNaN(indicatorStyle[start]) || isNaN(indicatorStyle[size])) {\n setIndicatorStyle(newIndicatorStyle);\n } else {\n var dStart = Math.abs(indicatorStyle[start] - newIndicatorStyle[start]);\n var dSize = Math.abs(indicatorStyle[size] - newIndicatorStyle[size]);\n\n if (dStart >= 1 || dSize >= 1) {\n setIndicatorStyle(newIndicatorStyle);\n }\n }\n });\n\n var scroll = function scroll(scrollValue) {\n animate(scrollStart, tabsRef.current, scrollValue);\n };\n\n var moveTabsScroll = function moveTabsScroll(delta) {\n var scrollValue = tabsRef.current[scrollStart];\n\n if (vertical) {\n scrollValue += delta;\n } else {\n scrollValue += delta * (isRtl ? -1 : 1); // Fix for Edge\n\n scrollValue *= isRtl && detectScrollType() === 'reverse' ? -1 : 1;\n }\n\n scroll(scrollValue);\n };\n\n var handleStartScrollClick = function handleStartScrollClick() {\n moveTabsScroll(-tabsRef.current[clientSize]);\n };\n\n var handleEndScrollClick = function handleEndScrollClick() {\n moveTabsScroll(tabsRef.current[clientSize]);\n };\n\n var handleScrollbarSizeChange = React.useCallback(function (scrollbarHeight) {\n setScrollerStyle({\n overflow: null,\n marginBottom: -scrollbarHeight\n });\n }, []);\n\n var getConditionalElements = function getConditionalElements() {\n var conditionalElements = {};\n conditionalElements.scrollbarSizeListener = scrollable ? /*#__PURE__*/React.createElement(ScrollbarSize, {\n className: classes.scrollable,\n onChange: handleScrollbarSizeChange\n }) : null;\n var scrollButtonsActive = displayScroll.start || displayScroll.end;\n var showScrollButtons = scrollable && (scrollButtons === 'auto' && scrollButtonsActive || scrollButtons === 'desktop' || scrollButtons === 'on');\n conditionalElements.scrollButtonStart = showScrollButtons ? /*#__PURE__*/React.createElement(ScrollButtonComponent, _extends({\n orientation: orientation,\n direction: isRtl ? 'right' : 'left',\n onClick: handleStartScrollClick,\n disabled: !displayScroll.start,\n className: clsx(classes.scrollButtons, scrollButtons !== 'on' && classes.scrollButtonsDesktop)\n }, TabScrollButtonProps)) : null;\n conditionalElements.scrollButtonEnd = showScrollButtons ? /*#__PURE__*/React.createElement(ScrollButtonComponent, _extends({\n orientation: orientation,\n direction: isRtl ? 'left' : 'right',\n onClick: handleEndScrollClick,\n disabled: !displayScroll.end,\n className: clsx(classes.scrollButtons, scrollButtons !== 'on' && classes.scrollButtonsDesktop)\n }, TabScrollButtonProps)) : null;\n return conditionalElements;\n };\n\n var scrollSelectedIntoView = useEventCallback(function () {\n var _getTabsMeta2 = getTabsMeta(),\n tabsMeta = _getTabsMeta2.tabsMeta,\n tabMeta = _getTabsMeta2.tabMeta;\n\n if (!tabMeta || !tabsMeta) {\n return;\n }\n\n if (tabMeta[start] < tabsMeta[start]) {\n // left side of button is out of view\n var nextScrollStart = tabsMeta[scrollStart] + (tabMeta[start] - tabsMeta[start]);\n scroll(nextScrollStart);\n } else if (tabMeta[end] > tabsMeta[end]) {\n // right side of button is out of view\n var _nextScrollStart = tabsMeta[scrollStart] + (tabMeta[end] - tabsMeta[end]);\n\n scroll(_nextScrollStart);\n }\n });\n var updateScrollButtonState = useEventCallback(function () {\n if (scrollable && scrollButtons !== 'off') {\n var _tabsRef$current = tabsRef.current,\n scrollTop = _tabsRef$current.scrollTop,\n scrollHeight = _tabsRef$current.scrollHeight,\n clientHeight = _tabsRef$current.clientHeight,\n scrollWidth = _tabsRef$current.scrollWidth,\n clientWidth = _tabsRef$current.clientWidth;\n var showStartScroll;\n var showEndScroll;\n\n if (vertical) {\n showStartScroll = scrollTop > 1;\n showEndScroll = scrollTop < scrollHeight - clientHeight - 1;\n } else {\n var scrollLeft = getNormalizedScrollLeft(tabsRef.current, theme.direction); // use 1 for the potential rounding error with browser zooms.\n\n showStartScroll = isRtl ? scrollLeft < scrollWidth - clientWidth - 1 : scrollLeft > 1;\n showEndScroll = !isRtl ? scrollLeft < scrollWidth - clientWidth - 1 : scrollLeft > 1;\n }\n\n if (showStartScroll !== displayScroll.start || showEndScroll !== displayScroll.end) {\n setDisplayScroll({\n start: showStartScroll,\n end: showEndScroll\n });\n }\n }\n });\n React.useEffect(function () {\n var handleResize = debounce(function () {\n updateIndicatorState();\n updateScrollButtonState();\n });\n var win = ownerWindow(tabsRef.current);\n win.addEventListener('resize', handleResize);\n return function () {\n handleResize.clear();\n win.removeEventListener('resize', handleResize);\n };\n }, [updateIndicatorState, updateScrollButtonState]);\n var handleTabsScroll = React.useCallback(debounce(function () {\n updateScrollButtonState();\n }));\n React.useEffect(function () {\n return function () {\n handleTabsScroll.clear();\n };\n }, [handleTabsScroll]);\n React.useEffect(function () {\n setMounted(true);\n }, []);\n React.useEffect(function () {\n updateIndicatorState();\n updateScrollButtonState();\n });\n React.useEffect(function () {\n scrollSelectedIntoView();\n }, [scrollSelectedIntoView, indicatorStyle]);\n React.useImperativeHandle(action, function () {\n return {\n updateIndicator: updateIndicatorState,\n updateScrollButtons: updateScrollButtonState\n };\n }, [updateIndicatorState, updateScrollButtonState]);\n var indicator = /*#__PURE__*/React.createElement(TabIndicator, _extends({\n className: classes.indicator,\n orientation: orientation,\n color: indicatorColor\n }, TabIndicatorProps, {\n style: _extends({}, indicatorStyle, TabIndicatorProps.style)\n }));\n var childIndex = 0;\n var children = React.Children.map(childrenProp, function (child) {\n if (! /*#__PURE__*/React.isValidElement(child)) {\n return null;\n }\n\n if (process.env.NODE_ENV !== 'production') {\n if (isFragment(child)) {\n console.error([\"Material-UI: The Tabs component doesn't accept a Fragment as a child.\", 'Consider providing an array instead.'].join('\\n'));\n }\n }\n\n var childValue = child.props.value === undefined ? childIndex : child.props.value;\n valueToIndex.set(childValue, childIndex);\n var selected = childValue === value;\n childIndex += 1;\n return /*#__PURE__*/React.cloneElement(child, {\n fullWidth: variant === 'fullWidth',\n indicator: selected && !mounted && indicator,\n selected: selected,\n selectionFollowsFocus: selectionFollowsFocus,\n onChange: onChange,\n textColor: textColor,\n value: childValue\n });\n });\n\n var handleKeyDown = function handleKeyDown(event) {\n var target = event.target; // Keyboard navigation assumes that [role=\"tab\"] are siblings\n // though we might warn in the future about nested, interactive elements\n // as a a11y violation\n\n var role = target.getAttribute('role');\n\n if (role !== 'tab') {\n return;\n }\n\n var newFocusTarget = null;\n var previousItemKey = orientation !== \"vertical\" ? 'ArrowLeft' : 'ArrowUp';\n var nextItemKey = orientation !== \"vertical\" ? 'ArrowRight' : 'ArrowDown';\n\n if (orientation !== \"vertical\" && theme.direction === 'rtl') {\n // swap previousItemKey with nextItemKey\n previousItemKey = 'ArrowRight';\n nextItemKey = 'ArrowLeft';\n }\n\n switch (event.key) {\n case previousItemKey:\n newFocusTarget = target.previousElementSibling || tabListRef.current.lastChild;\n break;\n\n case nextItemKey:\n newFocusTarget = target.nextElementSibling || tabListRef.current.firstChild;\n break;\n\n case 'Home':\n newFocusTarget = tabListRef.current.firstChild;\n break;\n\n case 'End':\n newFocusTarget = tabListRef.current.lastChild;\n break;\n\n default:\n break;\n }\n\n if (newFocusTarget !== null) {\n newFocusTarget.focus();\n event.preventDefault();\n }\n };\n\n var conditionalElements = getConditionalElements();\n return /*#__PURE__*/React.createElement(Component, _extends({\n className: clsx(classes.root, className, vertical && classes.vertical),\n ref: ref\n }, other), conditionalElements.scrollButtonStart, conditionalElements.scrollbarSizeListener, /*#__PURE__*/React.createElement(\"div\", {\n className: clsx(classes.scroller, scrollable ? classes.scrollable : classes.fixed),\n style: scrollerStyle,\n ref: tabsRef,\n onScroll: handleTabsScroll\n }, /*#__PURE__*/React.createElement(\"div\", {\n \"aria-label\": ariaLabel,\n \"aria-labelledby\": ariaLabelledBy,\n className: clsx(classes.flexContainer, vertical && classes.flexContainerVertical, centered && !scrollable && classes.centered),\n onKeyDown: handleKeyDown,\n ref: tabListRef,\n role: \"tablist\"\n }, children), mounted && indicator), conditionalElements.scrollButtonEnd);\n});\nprocess.env.NODE_ENV !== \"production\" ? Tabs.propTypes = {\n // ----------------------------- Warning --------------------------------\n // | These PropTypes are generated from the TypeScript type definitions |\n // | To update them edit the d.ts file and run \"yarn proptypes\" |\n // ----------------------------------------------------------------------\n\n /**\n * Callback fired when the component mounts.\n * This is useful when you want to trigger an action programmatically.\n * It supports two actions: `updateIndicator()` and `updateScrollButtons()`\n *\n * @param {object} actions This object contains all possible actions\n * that can be triggered programmatically.\n */\n action: refType,\n\n /**\n * The label for the Tabs as a string.\n */\n 'aria-label': PropTypes.string,\n\n /**\n * An id or list of ids separated by a space that label the Tabs.\n */\n 'aria-labelledby': PropTypes.string,\n\n /**\n * If `true`, the tabs will be centered.\n * This property is intended for large views.\n */\n centered: PropTypes.bool,\n\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The component used for the root node.\n * Either a string to use a HTML element or a component.\n */\n component: PropTypes\n /* @typescript-to-proptypes-ignore */\n .elementType,\n\n /**\n * Determines the color of the indicator.\n */\n indicatorColor: PropTypes.oneOf(['primary', 'secondary']),\n\n /**\n * Callback fired when the value changes.\n *\n * @param {object} event The event source of the callback\n * @param {any} value We default to the index of the child (number)\n */\n onChange: PropTypes.func,\n\n /**\n * The tabs orientation (layout flow direction).\n */\n orientation: PropTypes.oneOf(['horizontal', 'vertical']),\n\n /**\n * The component used to render the scroll buttons.\n */\n ScrollButtonComponent: PropTypes.elementType,\n\n /**\n * Determine behavior of scroll buttons when tabs are set to scroll:\n *\n * - `auto` will only present them when not all the items are visible.\n * - `desktop` will only present them on medium and larger viewports.\n * - `on` will always present them.\n * - `off` will never present them.\n */\n scrollButtons: PropTypes.oneOf(['auto', 'desktop', 'off', 'on']),\n\n /**\n * If `true` the selected tab changes on focus. Otherwise it only\n * changes on activation.\n */\n selectionFollowsFocus: PropTypes.bool,\n\n /**\n * Props applied to the tab indicator element.\n */\n TabIndicatorProps: PropTypes.object,\n\n /**\n * Props applied to the [`TabScrollButton`](/api/tab-scroll-button/) element.\n */\n TabScrollButtonProps: PropTypes.object,\n\n /**\n * Determines the color of the `Tab`.\n */\n textColor: PropTypes.oneOf(['inherit', 'primary', 'secondary']),\n\n /**\n * The value of the currently selected `Tab`.\n * If you don't want any selected `Tab`, you can set this property to `false`.\n */\n value: PropTypes.any,\n\n /**\n * Determines additional display behavior of the tabs:\n *\n * - `scrollable` will invoke scrolling properties and allow for horizontally\n * scrolling (or swiping) of the tab bar.\n * -`fullWidth` will make the tabs grow to use all the available space,\n * which should be used for small views, like on mobile.\n * - `standard` will render the default state.\n */\n variant: PropTypes.oneOf(['fullWidth', 'scrollable', 'standard'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiTabs'\n})(Tabs);","import _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport _defineProperty from \"@babel/runtime/helpers/esm/defineProperty\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport ButtonBase from '../ButtonBase';\nimport capitalize from '../utils/capitalize';\nimport unsupportedProp from '../utils/unsupportedProp';\nexport var styles = function styles(theme) {\n var _extends2;\n\n return {\n /* Styles applied to the root element. */\n root: _extends({}, theme.typography.button, (_extends2 = {\n maxWidth: 264,\n minWidth: 72,\n position: 'relative',\n boxSizing: 'border-box',\n minHeight: 48,\n flexShrink: 0,\n padding: '6px 12px'\n }, _defineProperty(_extends2, theme.breakpoints.up('sm'), {\n padding: '6px 24px'\n }), _defineProperty(_extends2, \"overflow\", 'hidden'), _defineProperty(_extends2, \"whiteSpace\", 'normal'), _defineProperty(_extends2, \"textAlign\", 'center'), _defineProperty(_extends2, theme.breakpoints.up('sm'), {\n minWidth: 160\n }), _extends2)),\n\n /* Styles applied to the root element if both `icon` and `label` are provided. */\n labelIcon: {\n minHeight: 72,\n paddingTop: 9,\n '& $wrapper > *:first-child': {\n marginBottom: 6\n }\n },\n\n /* Styles applied to the root element if the parent [`Tabs`](/api/tabs/) has `textColor=\"inherit\"`. */\n textColorInherit: {\n color: 'inherit',\n opacity: 0.7,\n '&$selected': {\n opacity: 1\n },\n '&$disabled': {\n opacity: 0.5\n }\n },\n\n /* Styles applied to the root element if the parent [`Tabs`](/api/tabs/) has `textColor=\"primary\"`. */\n textColorPrimary: {\n color: theme.palette.text.secondary,\n '&$selected': {\n color: theme.palette.primary.main\n },\n '&$disabled': {\n color: theme.palette.text.disabled\n }\n },\n\n /* Styles applied to the root element if the parent [`Tabs`](/api/tabs/) has `textColor=\"secondary\"`. */\n textColorSecondary: {\n color: theme.palette.text.secondary,\n '&$selected': {\n color: theme.palette.secondary.main\n },\n '&$disabled': {\n color: theme.palette.text.disabled\n }\n },\n\n /* Pseudo-class applied to the root element if `selected={true}` (controlled by the Tabs component). */\n selected: {},\n\n /* Pseudo-class applied to the root element if `disabled={true}` (controlled by the Tabs component). */\n disabled: {},\n\n /* Styles applied to the root element if `fullWidth={true}` (controlled by the Tabs component). */\n fullWidth: {\n flexShrink: 1,\n flexGrow: 1,\n flexBasis: 0,\n maxWidth: 'none'\n },\n\n /* Styles applied to the root element if `wrapped={true}`. */\n wrapped: {\n fontSize: theme.typography.pxToRem(12),\n lineHeight: 1.5\n },\n\n /* Styles applied to the `icon` and `label`'s wrapper element. */\n wrapper: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '100%',\n flexDirection: 'column'\n }\n };\n};\nvar Tab = /*#__PURE__*/React.forwardRef(function Tab(props, ref) {\n var classes = props.classes,\n className = props.className,\n _props$disabled = props.disabled,\n disabled = _props$disabled === void 0 ? false : _props$disabled,\n _props$disableFocusRi = props.disableFocusRipple,\n disableFocusRipple = _props$disableFocusRi === void 0 ? false : _props$disableFocusRi,\n fullWidth = props.fullWidth,\n icon = props.icon,\n indicator = props.indicator,\n label = props.label,\n onChange = props.onChange,\n onClick = props.onClick,\n onFocus = props.onFocus,\n selected = props.selected,\n selectionFollowsFocus = props.selectionFollowsFocus,\n _props$textColor = props.textColor,\n textColor = _props$textColor === void 0 ? 'inherit' : _props$textColor,\n value = props.value,\n _props$wrapped = props.wrapped,\n wrapped = _props$wrapped === void 0 ? false : _props$wrapped,\n other = _objectWithoutProperties(props, [\"classes\", \"className\", \"disabled\", \"disableFocusRipple\", \"fullWidth\", \"icon\", \"indicator\", \"label\", \"onChange\", \"onClick\", \"onFocus\", \"selected\", \"selectionFollowsFocus\", \"textColor\", \"value\", \"wrapped\"]);\n\n var handleClick = function handleClick(event) {\n if (onChange) {\n onChange(event, value);\n }\n\n if (onClick) {\n onClick(event);\n }\n };\n\n var handleFocus = function handleFocus(event) {\n if (selectionFollowsFocus && !selected && onChange) {\n onChange(event, value);\n }\n\n if (onFocus) {\n onFocus(event);\n }\n };\n\n return /*#__PURE__*/React.createElement(ButtonBase, _extends({\n focusRipple: !disableFocusRipple,\n className: clsx(classes.root, classes[\"textColor\".concat(capitalize(textColor))], className, disabled && classes.disabled, selected && classes.selected, label && icon && classes.labelIcon, fullWidth && classes.fullWidth, wrapped && classes.wrapped),\n ref: ref,\n role: \"tab\",\n \"aria-selected\": selected,\n disabled: disabled,\n onClick: handleClick,\n onFocus: handleFocus,\n tabIndex: selected ? 0 : -1\n }, other), /*#__PURE__*/React.createElement(\"span\", {\n className: classes.wrapper\n }, icon, label), indicator);\n});\nprocess.env.NODE_ENV !== \"production\" ? Tab.propTypes = {\n /**\n * This prop isn't supported.\n * Use the `component` prop if you need to change the children structure.\n */\n children: unsupportedProp,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * If `true`, the tab will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the keyboard focus ripple will be disabled.\n */\n disableFocusRipple: PropTypes.bool,\n\n /**\n * If `true`, the ripple effect will be disabled.\n */\n disableRipple: PropTypes.bool,\n\n /**\n * @ignore\n */\n fullWidth: PropTypes.bool,\n\n /**\n * The icon element.\n */\n icon: PropTypes.node,\n\n /**\n * @ignore\n * For server-side rendering consideration, we let the selected tab\n * render the indicator.\n */\n indicator: PropTypes.node,\n\n /**\n * The label element.\n */\n label: PropTypes.node,\n\n /**\n * @ignore\n */\n onChange: PropTypes.func,\n\n /**\n * @ignore\n */\n onClick: PropTypes.func,\n\n /**\n * @ignore\n */\n onFocus: PropTypes.func,\n\n /**\n * @ignore\n */\n selected: PropTypes.bool,\n\n /**\n * @ignore\n */\n selectionFollowsFocus: PropTypes.bool,\n\n /**\n * @ignore\n */\n textColor: PropTypes.oneOf(['secondary', 'primary', 'inherit']),\n\n /**\n * You can provide your own value. Otherwise, we fallback to the child position index.\n */\n value: PropTypes.any,\n\n /**\n * Tab labels appear in a single row.\n * They can use a second line if needed.\n */\n wrapped: PropTypes.bool\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiTab'\n})(Tab);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\n\n/* eslint-disable jsx-a11y/aria-role */\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport KeyboardArrowLeft from '../internal/svg-icons/KeyboardArrowLeft';\nimport KeyboardArrowRight from '../internal/svg-icons/KeyboardArrowRight';\nimport withStyles from '../styles/withStyles';\nimport ButtonBase from '../ButtonBase';\nexport var styles = {\n /* Styles applied to the root element. */\n root: {\n width: 40,\n flexShrink: 0,\n opacity: 0.8,\n '&$disabled': {\n opacity: 0\n }\n },\n\n /* Styles applied to the root element if `orientation=\"vertical\"`. */\n vertical: {\n width: '100%',\n height: 40,\n '& svg': {\n transform: 'rotate(90deg)'\n }\n },\n\n /* Pseudo-class applied to the root element if `disabled={true}`. */\n disabled: {}\n};\n\nvar _ref = /*#__PURE__*/React.createElement(KeyboardArrowLeft, {\n fontSize: \"small\"\n});\n\nvar _ref2 = /*#__PURE__*/React.createElement(KeyboardArrowRight, {\n fontSize: \"small\"\n});\n\nvar TabScrollButton = /*#__PURE__*/React.forwardRef(function TabScrollButton(props, ref) {\n var classes = props.classes,\n classNameProp = props.className,\n direction = props.direction,\n orientation = props.orientation,\n disabled = props.disabled,\n other = _objectWithoutProperties(props, [\"classes\", \"className\", \"direction\", \"orientation\", \"disabled\"]);\n\n return /*#__PURE__*/React.createElement(ButtonBase, _extends({\n component: \"div\",\n className: clsx(classes.root, classNameProp, disabled && classes.disabled, orientation === 'vertical' && classes.vertical),\n ref: ref,\n role: null,\n tabIndex: null\n }, other), direction === 'left' ? _ref : _ref2);\n});\nprocess.env.NODE_ENV !== \"production\" ? TabScrollButton.propTypes = {\n // ----------------------------- Warning --------------------------------\n // | These PropTypes are generated from the TypeScript type definitions |\n // | To update them edit the d.ts file and run \"yarn proptypes\" |\n // ----------------------------------------------------------------------\n\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * Which direction should the button indicate?\n */\n direction: PropTypes.oneOf(['left', 'right']).isRequired,\n\n /**\n * If `true`, the element will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * The tabs orientation (layout flow direction).\n */\n orientation: PropTypes.oneOf(['horizontal', 'vertical']).isRequired\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiTabScrollButton'\n})(TabScrollButton);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n flex: '1 1 auto',\n WebkitOverflowScrolling: 'touch',\n // Add iOS momentum scrolling.\n overflowY: 'auto',\n padding: '8px 24px',\n '&:first-child': {\n // dialog without title\n paddingTop: 20\n }\n },\n\n /* Styles applied to the root element if `dividers={true}`. */\n dividers: {\n padding: '16px 24px',\n borderTop: \"1px solid \".concat(theme.palette.divider),\n borderBottom: \"1px solid \".concat(theme.palette.divider)\n }\n };\n};\nvar DialogContent = /*#__PURE__*/React.forwardRef(function DialogContent(props, ref) {\n var classes = props.classes,\n className = props.className,\n _props$dividers = props.dividers,\n dividers = _props$dividers === void 0 ? false : _props$dividers,\n other = _objectWithoutProperties(props, [\"classes\", \"className\", \"dividers\"]);\n\n return /*#__PURE__*/React.createElement(\"div\", _extends({\n className: clsx(classes.root, className, dividers && classes.dividers),\n ref: ref\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? DialogContent.propTypes = {\n // ----------------------------- Warning --------------------------------\n // | These PropTypes are generated from the TypeScript type definitions |\n // | To update them edit the d.ts file and run \"yarn proptypes\" |\n // ----------------------------------------------------------------------\n\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * Display the top and bottom dividers.\n */\n dividers: PropTypes.bool\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiDialogContent'\n})(DialogContent);","import * as React from 'react';\nimport createSvgIcon from '../../utils/createSvgIcon';\n/**\n * @ignore - internal component.\n */\n\nexport default createSvgIcon( /*#__PURE__*/React.createElement(\"path\", {\n d: \"M15.41 16.09l-4.58-4.59 4.58-4.59L14 5.5l-6 6 6 6z\"\n}), 'KeyboardArrowLeft');","import * as React from 'react';\nimport createSvgIcon from '../../utils/createSvgIcon';\n/**\n * @ignore - internal component.\n */\n\nexport default createSvgIcon( /*#__PURE__*/React.createElement(\"path\", {\n d: \"M8.59 16.34l4.58-4.59-4.58-4.59L10 5.75l6 6-6 6z\"\n}), 'KeyboardArrowRight');","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { makeStyles as makeStylesWithoutDefault } from '@material-ui/styles';\nimport defaultTheme from './defaultTheme';\n\nfunction makeStyles(stylesOrCreator) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n return makeStylesWithoutDefault(stylesOrCreator, _extends({\n defaultTheme: defaultTheme\n }, options));\n}\n\nexport default makeStyles;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport Typography from '../Typography';\nexport var styles = {\n /* Styles applied to the root element. */\n root: {\n margin: 0,\n padding: '16px 24px',\n flex: '0 0 auto'\n }\n};\nvar DialogTitle = /*#__PURE__*/React.forwardRef(function DialogTitle(props, ref) {\n var children = props.children,\n classes = props.classes,\n className = props.className,\n _props$disableTypogra = props.disableTypography,\n disableTypography = _props$disableTypogra === void 0 ? false : _props$disableTypogra,\n other = _objectWithoutProperties(props, [\"children\", \"classes\", \"className\", \"disableTypography\"]);\n\n return /*#__PURE__*/React.createElement(\"div\", _extends({\n className: clsx(classes.root, className),\n ref: ref\n }, other), disableTypography ? children : /*#__PURE__*/React.createElement(Typography, {\n component: \"h2\",\n variant: \"h6\"\n }, children));\n});\nprocess.env.NODE_ENV !== \"production\" ? DialogTitle.propTypes = {\n // ----------------------------- Warning --------------------------------\n // | These PropTypes are generated from the TypeScript type definitions |\n // | To update them edit the d.ts file and run \"yarn proptypes\" |\n // ----------------------------------------------------------------------\n\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * If `true`, the children won't be wrapped by a typography component.\n * For instance, this can be useful to render an h4 instead of the default h2.\n */\n disableTypography: PropTypes.bool\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiDialogTitle'\n})(DialogTitle);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport Fade from '../Fade';\nexport var styles = {\n /* Styles applied to the root element. */\n root: {\n // Improve scrollable dialog support.\n zIndex: -1,\n position: 'fixed',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n right: 0,\n bottom: 0,\n top: 0,\n left: 0,\n backgroundColor: 'rgba(0, 0, 0, 0.5)',\n WebkitTapHighlightColor: 'transparent'\n },\n\n /* Styles applied to the root element if `invisible={true}`. */\n invisible: {\n backgroundColor: 'transparent'\n }\n};\nvar Backdrop = /*#__PURE__*/React.forwardRef(function Backdrop(props, ref) {\n var children = props.children,\n classes = props.classes,\n className = props.className,\n _props$invisible = props.invisible,\n invisible = _props$invisible === void 0 ? false : _props$invisible,\n open = props.open,\n transitionDuration = props.transitionDuration,\n _props$TransitionComp = props.TransitionComponent,\n TransitionComponent = _props$TransitionComp === void 0 ? Fade : _props$TransitionComp,\n other = _objectWithoutProperties(props, [\"children\", \"classes\", \"className\", \"invisible\", \"open\", \"transitionDuration\", \"TransitionComponent\"]);\n\n return /*#__PURE__*/React.createElement(TransitionComponent, _extends({\n in: open,\n timeout: transitionDuration\n }, other), /*#__PURE__*/React.createElement(\"div\", {\n className: clsx(classes.root, className, invisible && classes.invisible),\n \"aria-hidden\": true,\n ref: ref\n }, children));\n});\nprocess.env.NODE_ENV !== \"production\" ? Backdrop.propTypes = {\n // ----------------------------- Warning --------------------------------\n // | These PropTypes are generated from the TypeScript type definitions |\n // | To update them edit the d.ts file and run \"yarn proptypes\" |\n // ----------------------------------------------------------------------\n\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * If `true`, the backdrop is invisible.\n * It can be used when rendering a popover or a custom select component.\n */\n invisible: PropTypes.bool,\n\n /**\n * If `true`, the backdrop is open.\n */\n open: PropTypes.bool.isRequired,\n\n /**\n * The duration for the transition, in milliseconds.\n * You may specify a single timeout for all transitions, or individually with an object.\n */\n transitionDuration: PropTypes.oneOfType([PropTypes.number, PropTypes.shape({\n appear: PropTypes.number,\n enter: PropTypes.number,\n exit: PropTypes.number\n })])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiBackdrop'\n})(Backdrop);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport _defineProperty from \"@babel/runtime/helpers/esm/defineProperty\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport capitalize from '../utils/capitalize';\nimport deprecatedPropType from '../utils/deprecatedPropType';\nimport Modal from '../Modal';\nimport Backdrop from '../Backdrop';\nimport Fade from '../Fade';\nimport { duration } from '../styles/transitions';\nimport Paper from '../Paper';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n '@media print': {\n // Use !important to override the Modal inline-style.\n position: 'absolute !important'\n }\n },\n\n /* Styles applied to the container element if `scroll=\"paper\"`. */\n scrollPaper: {\n display: 'flex',\n justifyContent: 'center',\n alignItems: 'center'\n },\n\n /* Styles applied to the container element if `scroll=\"body\"`. */\n scrollBody: {\n overflowY: 'auto',\n overflowX: 'hidden',\n textAlign: 'center',\n '&:after': {\n content: '\"\"',\n display: 'inline-block',\n verticalAlign: 'middle',\n height: '100%',\n width: '0'\n }\n },\n\n /* Styles applied to the container element. */\n container: {\n height: '100%',\n '@media print': {\n height: 'auto'\n },\n // We disable the focus ring for mouse, touch and keyboard users.\n outline: 0\n },\n\n /* Styles applied to the `Paper` component. */\n paper: {\n margin: 32,\n position: 'relative',\n overflowY: 'auto',\n // Fix IE 11 issue, to remove at some point.\n '@media print': {\n overflowY: 'visible',\n boxShadow: 'none'\n }\n },\n\n /* Styles applied to the `Paper` component if `scroll=\"paper\"`. */\n paperScrollPaper: {\n display: 'flex',\n flexDirection: 'column',\n maxHeight: 'calc(100% - 64px)'\n },\n\n /* Styles applied to the `Paper` component if `scroll=\"body\"`. */\n paperScrollBody: {\n display: 'inline-block',\n verticalAlign: 'middle',\n textAlign: 'left' // 'initial' doesn't work on IE 11\n\n },\n\n /* Styles applied to the `Paper` component if `maxWidth=false`. */\n paperWidthFalse: {\n maxWidth: 'calc(100% - 64px)'\n },\n\n /* Styles applied to the `Paper` component if `maxWidth=\"xs\"`. */\n paperWidthXs: {\n maxWidth: Math.max(theme.breakpoints.values.xs, 444),\n '&$paperScrollBody': _defineProperty({}, theme.breakpoints.down(Math.max(theme.breakpoints.values.xs, 444) + 32 * 2), {\n maxWidth: 'calc(100% - 64px)'\n })\n },\n\n /* Styles applied to the `Paper` component if `maxWidth=\"sm\"`. */\n paperWidthSm: {\n maxWidth: theme.breakpoints.values.sm,\n '&$paperScrollBody': _defineProperty({}, theme.breakpoints.down(theme.breakpoints.values.sm + 32 * 2), {\n maxWidth: 'calc(100% - 64px)'\n })\n },\n\n /* Styles applied to the `Paper` component if `maxWidth=\"md\"`. */\n paperWidthMd: {\n maxWidth: theme.breakpoints.values.md,\n '&$paperScrollBody': _defineProperty({}, theme.breakpoints.down(theme.breakpoints.values.md + 32 * 2), {\n maxWidth: 'calc(100% - 64px)'\n })\n },\n\n /* Styles applied to the `Paper` component if `maxWidth=\"lg\"`. */\n paperWidthLg: {\n maxWidth: theme.breakpoints.values.lg,\n '&$paperScrollBody': _defineProperty({}, theme.breakpoints.down(theme.breakpoints.values.lg + 32 * 2), {\n maxWidth: 'calc(100% - 64px)'\n })\n },\n\n /* Styles applied to the `Paper` component if `maxWidth=\"xl\"`. */\n paperWidthXl: {\n maxWidth: theme.breakpoints.values.xl,\n '&$paperScrollBody': _defineProperty({}, theme.breakpoints.down(theme.breakpoints.values.xl + 32 * 2), {\n maxWidth: 'calc(100% - 64px)'\n })\n },\n\n /* Styles applied to the `Paper` component if `fullWidth={true}`. */\n paperFullWidth: {\n width: 'calc(100% - 64px)'\n },\n\n /* Styles applied to the `Paper` component if `fullScreen={true}`. */\n paperFullScreen: {\n margin: 0,\n width: '100%',\n maxWidth: '100%',\n height: '100%',\n maxHeight: 'none',\n borderRadius: 0,\n '&$paperScrollBody': {\n margin: 0,\n maxWidth: '100%'\n }\n }\n };\n};\nvar defaultTransitionDuration = {\n enter: duration.enteringScreen,\n exit: duration.leavingScreen\n};\n/**\n * Dialogs are overlaid modal paper based components with a backdrop.\n */\n\nvar Dialog = /*#__PURE__*/React.forwardRef(function Dialog(props, ref) {\n var BackdropProps = props.BackdropProps,\n children = props.children,\n classes = props.classes,\n className = props.className,\n _props$disableBackdro = props.disableBackdropClick,\n disableBackdropClick = _props$disableBackdro === void 0 ? false : _props$disableBackdro,\n _props$disableEscapeK = props.disableEscapeKeyDown,\n disableEscapeKeyDown = _props$disableEscapeK === void 0 ? false : _props$disableEscapeK,\n _props$fullScreen = props.fullScreen,\n fullScreen = _props$fullScreen === void 0 ? false : _props$fullScreen,\n _props$fullWidth = props.fullWidth,\n fullWidth = _props$fullWidth === void 0 ? false : _props$fullWidth,\n _props$maxWidth = props.maxWidth,\n maxWidth = _props$maxWidth === void 0 ? 'sm' : _props$maxWidth,\n onBackdropClick = props.onBackdropClick,\n onClose = props.onClose,\n onEnter = props.onEnter,\n onEntered = props.onEntered,\n onEntering = props.onEntering,\n onEscapeKeyDown = props.onEscapeKeyDown,\n onExit = props.onExit,\n onExited = props.onExited,\n onExiting = props.onExiting,\n open = props.open,\n _props$PaperComponent = props.PaperComponent,\n PaperComponent = _props$PaperComponent === void 0 ? Paper : _props$PaperComponent,\n _props$PaperProps = props.PaperProps,\n PaperProps = _props$PaperProps === void 0 ? {} : _props$PaperProps,\n _props$scroll = props.scroll,\n scroll = _props$scroll === void 0 ? 'paper' : _props$scroll,\n _props$TransitionComp = props.TransitionComponent,\n TransitionComponent = _props$TransitionComp === void 0 ? Fade : _props$TransitionComp,\n _props$transitionDura = props.transitionDuration,\n transitionDuration = _props$transitionDura === void 0 ? defaultTransitionDuration : _props$transitionDura,\n TransitionProps = props.TransitionProps,\n ariaDescribedby = props['aria-describedby'],\n ariaLabelledby = props['aria-labelledby'],\n other = _objectWithoutProperties(props, [\"BackdropProps\", \"children\", \"classes\", \"className\", \"disableBackdropClick\", \"disableEscapeKeyDown\", \"fullScreen\", \"fullWidth\", \"maxWidth\", \"onBackdropClick\", \"onClose\", \"onEnter\", \"onEntered\", \"onEntering\", \"onEscapeKeyDown\", \"onExit\", \"onExited\", \"onExiting\", \"open\", \"PaperComponent\", \"PaperProps\", \"scroll\", \"TransitionComponent\", \"transitionDuration\", \"TransitionProps\", \"aria-describedby\", \"aria-labelledby\"]);\n\n var mouseDownTarget = React.useRef();\n\n var handleMouseDown = function handleMouseDown(event) {\n mouseDownTarget.current = event.target;\n };\n\n var handleBackdropClick = function handleBackdropClick(event) {\n // Ignore the events not coming from the \"backdrop\"\n // We don't want to close the dialog when clicking the dialog content.\n if (event.target !== event.currentTarget) {\n return;\n } // Make sure the event starts and ends on the same DOM element.\n\n\n if (event.target !== mouseDownTarget.current) {\n return;\n }\n\n mouseDownTarget.current = null;\n\n if (onBackdropClick) {\n onBackdropClick(event);\n }\n\n if (!disableBackdropClick && onClose) {\n onClose(event, 'backdropClick');\n }\n };\n\n return /*#__PURE__*/React.createElement(Modal, _extends({\n className: clsx(classes.root, className),\n BackdropComponent: Backdrop,\n BackdropProps: _extends({\n transitionDuration: transitionDuration\n }, BackdropProps),\n closeAfterTransition: true\n }, disableBackdropClick ? {\n disableBackdropClick: disableBackdropClick\n } : {}, {\n disableEscapeKeyDown: disableEscapeKeyDown,\n onEscapeKeyDown: onEscapeKeyDown,\n onClose: onClose,\n open: open,\n ref: ref\n }, other), /*#__PURE__*/React.createElement(TransitionComponent, _extends({\n appear: true,\n in: open,\n timeout: transitionDuration,\n onEnter: onEnter,\n onEntering: onEntering,\n onEntered: onEntered,\n onExit: onExit,\n onExiting: onExiting,\n onExited: onExited,\n role: \"none presentation\"\n }, TransitionProps), /*#__PURE__*/React.createElement(\"div\", {\n className: clsx(classes.container, classes[\"scroll\".concat(capitalize(scroll))]),\n onMouseUp: handleBackdropClick,\n onMouseDown: handleMouseDown\n }, /*#__PURE__*/React.createElement(PaperComponent, _extends({\n elevation: 24,\n role: \"dialog\",\n \"aria-describedby\": ariaDescribedby,\n \"aria-labelledby\": ariaLabelledby\n }, PaperProps, {\n className: clsx(classes.paper, classes[\"paperScroll\".concat(capitalize(scroll))], classes[\"paperWidth\".concat(capitalize(String(maxWidth)))], PaperProps.className, fullScreen && classes.paperFullScreen, fullWidth && classes.paperFullWidth)\n }), children))));\n});\nprocess.env.NODE_ENV !== \"production\" ? Dialog.propTypes = {\n // ----------------------------- Warning --------------------------------\n // | These PropTypes are generated from the TypeScript type definitions |\n // | To update them edit the d.ts file and run \"yarn proptypes\" |\n // ----------------------------------------------------------------------\n\n /**\n * The id(s) of the element(s) that describe the dialog.\n */\n 'aria-describedby': PropTypes.string,\n\n /**\n * The id(s) of the element(s) that label the dialog.\n */\n 'aria-labelledby': PropTypes.string,\n\n /**\n * @ignore\n */\n BackdropProps: PropTypes.object,\n\n /**\n * Dialog children, usually the included sub-components.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * If `true`, clicking the backdrop will not fire the `onClose` callback.\n * @deprecated Use the onClose prop with the `reason` argument to filter the `backdropClick` events.\n */\n disableBackdropClick: deprecatedPropType(PropTypes.bool, 'Use the onClose prop with the `reason` argument to filter the `backdropClick` events.'),\n\n /**\n * If `true`, hitting escape will not fire the `onClose` callback.\n */\n disableEscapeKeyDown: PropTypes.bool,\n\n /**\n * If `true`, the dialog will be full-screen\n */\n fullScreen: PropTypes.bool,\n\n /**\n * If `true`, the dialog stretches to `maxWidth`.\n *\n * Notice that the dialog width grow is limited by the default margin.\n */\n fullWidth: PropTypes.bool,\n\n /**\n * Determine the max-width of the dialog.\n * The dialog width grows with the size of the screen.\n * Set to `false` to disable `maxWidth`.\n */\n maxWidth: PropTypes.oneOf(['lg', 'md', 'sm', 'xl', 'xs', false]),\n\n /**\n * Callback fired when the backdrop is clicked.\n * @deprecated Use the onClose prop with the `reason` argument to handle the `backdropClick` events.\n */\n onBackdropClick: deprecatedPropType(PropTypes.func, 'Use the onClose prop with the `reason` argument to handle the `backdropClick` events.'),\n\n /**\n * Callback fired when the component requests to be closed.\n *\n * @param {object} event The event source of the callback.\n * @param {string} reason Can be: `\"escapeKeyDown\"`, `\"backdropClick\"`.\n */\n onClose: PropTypes.func,\n\n /**\n * Callback fired before the dialog enters.\n * @deprecated Use the `TransitionProps` prop instead.\n */\n onEnter: deprecatedPropType(PropTypes.func, 'Use the `TransitionProps` prop instead.'),\n\n /**\n * Callback fired when the dialog has entered.\n * @deprecated Use the `TransitionProps` prop instead.\n */\n onEntered: deprecatedPropType(PropTypes.func, 'Use the `TransitionProps` prop instead.'),\n\n /**\n * Callback fired when the dialog is entering.\n * @deprecated Use the `TransitionProps` prop instead.\n */\n onEntering: deprecatedPropType(PropTypes.func, 'Use the `TransitionProps` prop instead.'),\n\n /**\n * Callback fired when the escape key is pressed,\n * `disableKeyboard` is false and the modal is in focus.\n * @deprecated Use the onClose prop with the `reason` argument to handle the `escapeKeyDown` events.\n */\n onEscapeKeyDown: deprecatedPropType(PropTypes.func, 'Use the onClose prop with the `reason` argument to handle the `escapeKeyDown` events.'),\n\n /**\n * Callback fired before the dialog exits.\n * @deprecated Use the `TransitionProps` prop instead.\n */\n onExit: deprecatedPropType(PropTypes.func, 'Use the `TransitionProps` prop instead.'),\n\n /**\n * Callback fired when the dialog has exited.\n * @deprecated Use the `TransitionProps` prop instead.\n */\n onExited: deprecatedPropType(PropTypes.func, 'Use the `TransitionProps` prop instead.'),\n\n /**\n * Callback fired when the dialog is exiting.\n * @deprecated Use the `TransitionProps` prop instead.\n */\n onExiting: deprecatedPropType(PropTypes.func, 'Use the `TransitionProps` prop instead.'),\n\n /**\n * If `true`, the Dialog is open.\n */\n open: PropTypes.bool.isRequired,\n\n /**\n * The component used to render the body of the dialog.\n */\n PaperComponent: PropTypes.elementType,\n\n /**\n * Props applied to the [`Paper`](/api/paper/) element.\n */\n PaperProps: PropTypes.object,\n\n /**\n * Determine the container for scrolling the dialog.\n */\n scroll: PropTypes.oneOf(['body', 'paper']),\n\n /**\n * The component used for the transition.\n * [Follow this guide](/components/transitions/#transitioncomponent-prop) to learn more about the requirements for this component.\n */\n TransitionComponent: PropTypes.elementType,\n\n /**\n * The duration for the transition, in milliseconds.\n * You may specify a single timeout for all transitions, or individually with an object.\n */\n transitionDuration: PropTypes.oneOfType([PropTypes.number, PropTypes.shape({\n appear: PropTypes.number,\n enter: PropTypes.number,\n exit: PropTypes.number\n })]),\n\n /**\n * Props applied to the [`Transition`](http://reactcommunity.org/react-transition-group/transition#Transition-props) element.\n */\n TransitionProps: PropTypes.object\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiDialog'\n})(Dialog);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nexport var styles = {\n /* Styles applied to the root element. */\n root: {\n display: 'flex',\n alignItems: 'center',\n padding: 8,\n justifyContent: 'flex-end',\n flex: '0 0 auto'\n },\n\n /* Styles applied to the root element if `disableSpacing={false}`. */\n spacing: {\n '& > :not(:first-child)': {\n marginLeft: 8\n }\n }\n};\nvar DialogActions = /*#__PURE__*/React.forwardRef(function DialogActions(props, ref) {\n var _props$disableSpacing = props.disableSpacing,\n disableSpacing = _props$disableSpacing === void 0 ? false : _props$disableSpacing,\n classes = props.classes,\n className = props.className,\n other = _objectWithoutProperties(props, [\"disableSpacing\", \"classes\", \"className\"]);\n\n return /*#__PURE__*/React.createElement(\"div\", _extends({\n className: clsx(classes.root, className, !disableSpacing && classes.spacing),\n ref: ref\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? DialogActions.propTypes = {\n // ----------------------------- Warning --------------------------------\n // | These PropTypes are generated from the TypeScript type definitions |\n // | To update them edit the d.ts file and run \"yarn proptypes\" |\n // ----------------------------------------------------------------------\n\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * If `true`, the actions do not have additional margin.\n */\n disableSpacing: PropTypes.bool\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiDialogActions'\n})(DialogActions);"],"names":["styles","entering","opacity","entered","defaultTimeout","enter","enteringScreen","exit","leavingScreen","props","ref","children","_props$disableStrictM","disableStrictModeCompat","inProp","in","onEnter","onEntered","onEntering","onExit","onExited","onExiting","style","_props$TransitionComp","TransitionComponent","_props$timeout","timeout","other","theme","enableStrictModeCompat","unstable_strictMode","nodeRef","foreignRef","handleRef","undefined","normalizedTransitionCallback","callback","nodeOrAppearing","maybeAppearing","_ref","current","_ref2","node","isAppearing","handleEntering","handleEnter","transitionProps","mode","webkitTransition","transitions","create","transition","handleEntered","handleExiting","handleExit","handleExited","appear","state","childProps","visibility","cachedType","detectScrollType","dummy","document","createElement","container","width","height","appendChild","dir","fontSize","position","top","overflow","body","scrollLeft","removeChild","getNormalizedScrollLeft","element","direction","scrollWidth","clientWidth","easeInOutSin","time","Math","sin","PI","ScrollbarSize","onChange","scrollbarHeight","setMeasurements","offsetHeight","clientHeight","handleResize","debounce","prevHeight","window","addEventListener","clear","removeEventListener","TabIndicator","classes","className","color","orientation","root","concat","capitalize","vertical","withStyles","bottom","colorPrimary","backgroundColor","palette","primary","main","colorSecondary","secondary","right","name","Tabs","ariaLabel","ariaLabelledBy","action","_props$centered","centered","childrenProp","_props$component","component","Component","_props$indicatorColor","indicatorColor","_props$orientation","_props$ScrollButtonCo","ScrollButtonComponent","TabScrollButton","_props$scrollButtons","scrollButtons","selectionFollowsFocus","_props$TabIndicatorPr","TabIndicatorProps","TabScrollButtonProps","_props$textColor","textColor","value","_props$variant","variant","useTheme","scrollable","isRtl","scrollStart","start","end","clientSize","size","_React$useState","mounted","setMounted","_React$useState2","indicatorStyle","setIndicatorStyle","_React$useState3","displayScroll","setDisplayScroll","_React$useState4","marginBottom","scrollerStyle","setScrollerStyle","valueToIndex","Map","tabsRef","tabListRef","getTabsMeta","tabsMeta","tabMeta","tabsNode","rect","getBoundingClientRect","scrollTop","scrollLeftNormalized","left","_children","length","tab","get","updateIndicatorState","useEventCallback","_newIndicatorStyle","_getTabsMeta","startValue","correction","newIndicatorStyle","isNaN","dStart","abs","dSize","scroll","scrollValue","property","to","options","arguments","cb","_options$ease","ease","_options$duration","duration","from","cancelled","Error","requestAnimationFrame","step","timestamp","min","animate","moveTabsScroll","delta","handleStartScrollClick","handleEndScrollClick","handleScrollbarSizeChange","scrollSelectedIntoView","_getTabsMeta2","nextScrollStart","_nextScrollStart","updateScrollButtonState","showStartScroll","showEndScroll","_tabsRef$current","scrollHeight","win","ownerWindow","handleTabsScroll","updateIndicator","updateScrollButtons","indicator","childIndex","map","child","childValue","set","selected","fullWidth","conditionalElements","scrollbarSizeListener","scrollButtonsActive","showScrollButtons","scrollButtonStart","onClick","disabled","scrollButtonsDesktop","scrollButtonEnd","getConditionalElements","scroller","fixed","onScroll","flexContainer","flexContainerVertical","onKeyDown","event","target","getAttribute","newFocusTarget","previousItemKey","nextItemKey","key","previousElementSibling","lastChild","nextElementSibling","firstChild","focus","preventDefault","role","minHeight","WebkitOverflowScrolling","display","flexDirection","justifyContent","flex","whiteSpace","overflowX","scrollbarWidth","breakpoints","down","Tab","_props$disabled","_props$disableFocusRi","disableFocusRipple","icon","label","onFocus","_props$wrapped","wrapped","focusRipple","labelIcon","tabIndex","wrapper","_extends2","typography","button","maxWidth","minWidth","boxSizing","flexShrink","padding","up","paddingTop","textColorInherit","textColorPrimary","text","textColorSecondary","flexGrow","flexBasis","pxToRem","lineHeight","alignItems","classNameProp","transform","DialogContent","_props$dividers","dividers","overflowY","borderTop","divider","borderBottom","d","stylesOrCreator","makeStyles","defaultTheme","DialogTitle","_props$disableTypogra","disableTypography","margin","Backdrop","_props$invisible","invisible","open","transitionDuration","zIndex","WebkitTapHighlightColor","defaultTransitionDuration","Dialog","BackdropProps","_props$disableBackdro","disableBackdropClick","_props$disableEscapeK","disableEscapeKeyDown","_props$fullScreen","fullScreen","_props$fullWidth","_props$maxWidth","onBackdropClick","onClose","onEscapeKeyDown","_props$PaperComponent","PaperComponent","_props$PaperProps","PaperProps","_props$scroll","_props$transitionDura","TransitionProps","ariaDescribedby","ariaLabelledby","mouseDownTarget","BackdropComponent","closeAfterTransition","onMouseUp","currentTarget","onMouseDown","elevation","paper","String","paperFullScreen","paperFullWidth","scrollPaper","scrollBody","textAlign","content","verticalAlign","outline","boxShadow","paperScrollPaper","maxHeight","paperScrollBody","paperWidthFalse","paperWidthXs","max","values","xs","paperWidthSm","sm","paperWidthMd","md","paperWidthLg","lg","paperWidthXl","xl","borderRadius","DialogActions","_props$disableSpacing","disableSpacing","spacing","marginLeft"],"sourceRoot":""}
|