(false);\n\n const handleMouseLeave = useCallback(\n debounce(() => {\n setAnchorEl(null);\n setOpen(false);\n }, 300),\n []\n );\n\n const handleMouseEnter = useCallback(() => {\n handleMouseLeave.cancel();\n setOpen(true);\n }, [handleMouseLeave]);\n\n return (\n <>\n {\n setAnchorEl(event.currentTarget);\n handleMouseEnter();\n onFirstOpen();\n }}\n onMouseLeave={handleMouseLeave}\n >\n {anchor}\n \n {displayPopover && open && (\n \n )}\n >\n );\n};\n","export const zuoraObjectsList = {\n zobjects: [\n \"Account\",\n \"AccountingCode\",\n \"AccountingPeriod\",\n \"AccountingPeriodOrgMap\",\n \"Amendment\",\n \"ApplicationGroup\",\n \"ARTransaction\",\n \"BillingPreviewRunResult\",\n \"BillingRun\",\n \"BillingRunOrgMap\",\n \"BillingTransaction\",\n \"BookingTransaction\",\n \"ChargeMetrics\",\n \"ConsolidatedTransaction\",\n \"Contact\",\n \"ContactSnapshot\",\n \"Country\",\n \"CreditBalanceAdjustment\",\n \"CreditBalanceAdjustmentFxData\",\n \"CreditMemo\",\n \"CreditMemoApplication\",\n \"CreditMemoApplicationFxData\",\n \"CreditMemoApplicationItem\",\n \"CreditMemoApplicationItemFxData\",\n \"CreditMemoFxData\",\n \"CreditMemoItem\",\n \"CreditMemoItemFxData\",\n \"CreditMemoPart\",\n \"CreditMemoPartFxData\",\n \"CreditMemoPartItem\",\n \"CreditMemoPartItemFxData\",\n \"CreditTaxationItem\",\n \"CreditTaxationItemFxData\",\n \"CustomObjects\",\n \"DailyConsumptionSummary\",\n \"DATAQUALITYLOGS\",\n \"DebitMemo\",\n \"DebitMemoFxData\",\n \"DebitMemoItem\",\n \"DebitMemoItemFxData\",\n \"DebitTaxationItem\",\n \"DebitTaxationItemFxData\",\n \"Feature\",\n \"FXCustomRate\",\n \"GuidedUsage\",\n \"Invoice\",\n \"InvoiceAdjustment\",\n \"InvoiceAdjustmentFxData\",\n \"InvoiceFxData\",\n \"InvoiceHistory\",\n \"InvoiceItem\",\n \"InvoiceItemAdjustment\",\n \"InvoiceItemAdjustmentFxData\",\n \"InvoiceItemFxData\",\n \"InvoicePayment\",\n \"InvoicePaymentFxData\",\n \"JournalEntry\",\n \"JournalEntryItem\",\n \"JournalRun\",\n \"JournalRunOrgMap\",\n \"MinCommitPeriod\",\n \"MinCommitTransaction\",\n \"NonSubscriptionInvoiceItem\",\n \"OrderAction\",\n \"OrderActionRatePlan\",\n \"OrderContact\",\n \"OrderDeltaMrr\",\n \"OrderDeltaTcb\",\n \"OrderDeltaTcv\",\n \"OrderElp\",\n \"OrderItem\",\n \"OrderLineItem\",\n \"OrderMrr\",\n \"OrderQuantity\",\n \"Orders\",\n \"OrderTcb\",\n \"OrderTcv\",\n \"Organization\",\n \"Payment\",\n \"PaymentApplication\",\n \"PaymentApplicationFxData\",\n \"PaymentApplicationItem\",\n \"PaymentApplicationItemFxData\",\n \"PaymentFxData\",\n \"PaymentMethod\",\n \"PaymentMethodSnapshot\",\n \"PaymentMethodTransactionLog\",\n \"PaymentPart\",\n \"PaymentPartFxData\",\n \"PaymentPartItem\",\n \"PaymentPartItemFxData\",\n \"PaymentRun\",\n \"PaymentRunOrgMap\",\n \"PaymentSchedule\",\n \"PaymentScheduleItem\",\n \"PaymentTransactionLog\",\n \"PrepaidBalance\",\n \"PrepaidBalanceFund\",\n \"PrepaidBalanceTransaction\",\n \"ProcessedUsage\",\n \"Product\",\n \"ProductFeature\",\n \"ProductOrgMap\",\n \"ProductRatePlan\",\n \"ProductRatePlanCharge\",\n \"ProductRatePlanChargeOrgMap\",\n \"ProductRatePlanChargeTier\",\n \"ProductRatePlanChargeTierOrgMap\",\n \"ProductRatePlanOrgMap\",\n \"Ramp\",\n \"RampInterval\",\n \"RampIntervalDeltaMetrics\",\n \"RampIntervalDeltaMrr\",\n \"RampIntervalDeltaQuantity\",\n \"RampIntervalMetrics\",\n \"RampIntervalMrr\",\n \"RatePlan\",\n \"RatePlanCharge\",\n \"RatePlanChargeTier\",\n \"RatingResult\",\n \"RealTimeRatingProcessedUsage\",\n \"Refund\",\n \"RefundApplication\",\n \"RefundApplicationFxData\",\n \"RefundApplicationItem\",\n \"RefundApplicationItemFxData\",\n \"RefundFxData\",\n \"RefundInvoicePayment\",\n \"RefundInvoicePaymentFxData\",\n \"RefundPart\",\n \"RefundPartFxData\",\n \"RefundPartItem\",\n \"RefundPartItemFxData\",\n \"RefundTransactionLog\",\n \"REVENUEACCOUNTINGSUMMARY\",\n \"REVENUEBUNDLECONFIGURATION\",\n \"REVENUECALENDAR\",\n \"RevenueChargeSummary\",\n \"RevenueChargeSummaryItem\",\n \"REVENUECONTRACT\",\n \"REVENUECONTRACTACCOUNTINGENTRIES\",\n \"REVENUECONTRACTACCOUNTINGENTRIESDELETED\",\n \"REVENUECONTRACTACCOUNTINGSEGMENTS\",\n \"REVENUECONTRACTACCOUNTINGTYPE\",\n \"REVENUECONTRACTACTIONS\",\n \"REVENUECONTRACTAPPROVALS\",\n \"REVENUECONTRACTBILLSDIMENSIONS\",\n \"REVENUECONTRACTBILLSFACTS\",\n \"REVENUECONTRACTCOSTDIMENSIONS\",\n \"REVENUECONTRACTCOSTFACTS\",\n \"REVENUECONTRACTHOLDS\",\n \"REVENUECONTRACTLINESDIMENSIONS\",\n \"REVENUECONTRACTLINESFACTS\",\n \"REVENUECONTRACTMJENTRIESDIMENSIONS\",\n \"REVENUECONTRACTMJENTRIESFACTS\",\n \"REVENUECONTRACTMODIFICATIONDETAILS\",\n \"REVENUECONTRACTNETTINGSTATUS\",\n \"REVENUECONTRACTROLLFORWARD\",\n \"REVENUECONTRACTVCDIMENSIONS\",\n \"REVENUECONTRACTVCFACTS\",\n \"RevenueEvent\",\n \"RevenueEventCreditMemoItem\",\n \"RevenueEventDebitMemoItem\",\n \"RevenueEventInvoiceItem\",\n \"RevenueEventInvoiceItemAdjustment\",\n \"RevenueEventItem\",\n \"RevenueEventItemCreditMemoItem\",\n \"RevenueEventItemDebitMemoItem\",\n \"RevenueEventItemInvoiceItem\",\n \"RevenueEventItemInvoiceItemAdjustment\",\n \"RevenueEventType\",\n \"REVENUELINESTAGING\",\n \"REVENUELOOKUP\",\n \"REVENUEPERIODHISTORY\",\n \"REVENUEPERIODS\",\n \"RevenueSchedule\",\n \"RevenueScheduleCreditMemoItem\",\n \"RevenueScheduleDebitMemoItem\",\n \"RevenueScheduleInvoiceItem\",\n \"RevenueScheduleInvoiceItemAdjustment\",\n \"RevenueScheduleItem\",\n \"RevenueScheduleItemCreditMemoItem\",\n \"RevenueScheduleItemCreditMemoItemFxData\",\n \"RevenueScheduleItemDebitMemoItem\",\n \"RevenueScheduleItemDebitMemoItemFxData\",\n \"RevenueScheduleItemFxData\",\n \"RevenueScheduleItemInvoiceItem\",\n \"RevenueScheduleItemInvoiceItemAdjustment\",\n \"RevenueScheduleItemInvoiceItemAdjustmentFxData\",\n \"RevenueScheduleItemInvoiceItemFxData\",\n \"REVENUESSPBATCHDATA\",\n \"REVENUETNVLINESSP\",\n \"State\",\n \"Subscription\",\n \"SubscriptionProductFeature\",\n \"SubscriptionStatusHistory\",\n \"TaxationItem\",\n \"TaxationItemFxData\",\n \"UpdaterAccount\",\n \"UpdaterBatch\",\n \"UpdaterDetail\",\n \"Usage\",\n \"User\",\n \"ValidityPeriodSummary\",\n ],\n};\n","import React, { useEffect, useReducer, useState } from 'react';\nimport {\n ButtonSectionStyle,\n SnowflakeInputRowSectionStyle,\n SnowflakeInputSectionStyle,\n} from '../../styles';\nimport {\n Button,\n Card,\n Checkbox,\n TextField,\n Typography,\n Modal,\n Spinner,\n Tooltip,\n Icon,\n designTokens,\n Link,\n} from '@platform-ui/design-system';\nimport {\n initialState as configInitialState,\n reducer as configReducer,\n} from '../../stores/ConfigInfo';\nimport { Box } from '@mui/material';\nimport { useToast } from '../../../../../ToastProvider';\nimport Connect from '../../../../../Connect/Connect';\n\nconst ConfigInfo = () => {\n const { setToast } = useToast();\n const [configFormEditable, setConfigFormEditable] = useState(false);\n const [showConfirmCancelModal, setShowConfirmCancelModal] = useState(false);\n const [configFormState, configFormDispatch] = useReducer(\n configReducer,\n configInitialState,\n );\n const isLocal = window.location.host.includes('localhost');\n const proxyPath = `${isLocal ? 'http://localhost:8080' : ''}/platform/gateway-proxy-v2`;\n\n const hasErrors = (fieldName) => {\n const { fieldErrors } = configFormState;\n return fieldErrors.includes(fieldName);\n };\n\n const clearConfigErrors = () => {\n configFormDispatch({ type: 'clearErrors' });\n };\n\n const fetchConfigInfo = async () => {\n try {\n const response = await Connect.proxyCall(\n `${proxyPath}/shares/snowflakeconfig`,\n 'GET',\n undefined,\n { 'Accept': 'application/json', 'Content-Type': 'application/json' }\n );\n configFormDispatch({ type: 'loadConfigInfo', payload: await response.json() });\n } catch (error) {\n Connect.log(`Error fetching snowflake config info: ${error}`);\n }\n };\n\n const upsertConfigInfo = () => {\n configFormDispatch({ type: 'setSaving' });\n const {\n userName: username,\n password,\n role,\n warehouse,\n accountId,\n databaseName: database,\n } = configFormState;\n\n const body = {\n username,\n password,\n role,\n warehouse,\n accountId,\n database,\n poweredBySnowflake: configFormState.poweredBySnowflakeEnabled,\n };\n\n let response;\n if (configFormState.loadedConfigInfo.loaded) {\n response = Connect.proxyCall(\n `${proxyPath}/shares/snowflakeconfig`,\n 'PUT',\n body,\n { 'Accept': 'application/json', 'Content-Type': 'application/json' }\n );\n } else {\n response = Connect.proxyCall(\n `${proxyPath}/shares/snowflakeconfig`,\n 'POST',\n body,\n { 'Accept': 'application/json', 'Content-Type': 'application/json' }\n );\n }\n\n response.then(() => {\n configFormDispatch({ type: 'setSavingSucceeded' });\n setToast({\n message: 'The Snowflake configuration was successfully saved.',\n severity: 'success',\n keyRender: Date.now(),\n });\n setConfigFormEditable(!configFormEditable);\n\n //fetch config info to override the loaded values\n fetchConfigInfo();\n }).catch(() => {\n configFormDispatch({ type: 'setSavingFailed' });\n setToast({\n message: 'There was a problem saving the Snowflake configuration.',\n severity: 'error',\n keyRender: Date.now(),\n });\n });\n };\n\n const validateConfigInfo = async () => {\n configFormDispatch({ type: 'setValidating', payload: true });\n const {\n userName: username,\n password,\n role,\n warehouse,\n accountId,\n databaseName: database,\n } = configFormState;\n\n Connect.proxyCall(\n `${proxyPath}/shares/snowflakeconfig/validate`,\n 'POST',\n {\n username,\n password,\n role,\n warehouse,\n accountId,\n database,\n },\n { 'Accept': 'application/json', 'Content-Type': 'application/json' }\n )\n .then((response) => response.json())\n .then((data) => {\n if (!data.valid) {\n setToast({\n message: 'There were errors validating the supplied configuration.',\n severity: 'error',\n keyRender: Date.now(),\n });\n configFormDispatch({\n type: 'setFieldErrors',\n payload: data.reasons,\n });\n } else {\n configFormDispatch({ type: 'setValidating', payload: false });\n configFormDispatch({ type: 'togglePoweredBySnowflake' });\n }\n }).catch(() => {\n setToast({\n message: 'We encountered an error validating the supplied configuration.',\n severity: 'error',\n keyRender: Date.now(),\n });\n });\n };\n\n useEffect(() => {\n fetchConfigInfo();\n }, []);\n\n const refreshConfigInfoForm = () => {\n setConfigFormEditable(!configFormEditable);\n fetchConfigInfo();\n clearConfigErrors();\n };\n\n const configInfoHasChanges = () => {\n const {\n databaseName,\n accountId,\n userName,\n password,\n role,\n warehouse,\n poweredBySnowflakeEnabled,\n } = configFormState;\n const {\n databaseName: loadedDatabaseName,\n accountId: loadedAccountId,\n userName: loadedUserName,\n password: loadedPassword,\n role: loadedRole,\n warehouse: loadedWarehouse,\n poweredBySnowflakeEnabled: loadedPoweredBySnowflakeEnabled,\n } = configFormState.loadedConfigInfo;\n\n if (\n databaseName !== loadedDatabaseName ||\n accountId !== loadedAccountId ||\n userName !== loadedUserName ||\n password !== loadedPassword ||\n role !== loadedRole ||\n warehouse !== loadedWarehouse ||\n poweredBySnowflakeEnabled !== loadedPoweredBySnowflakeEnabled\n ) {\n return true;\n }\n return false;\n };\n\n const configInfoHasEmptyFields = () => {\n const { databaseName, accountId, userName, password, role, warehouse } =\n configFormState;\n\n return (\n !databaseName ||\n !accountId ||\n !userName ||\n !password ||\n !role ||\n !warehouse\n );\n };\n\n const buttonSection = configFormEditable ? (\n \n \n \n \n \n \n ) : (\n <>>\n );\n\n const configFormEditButton = !configFormEditable ? (\n \n ) : (\n <>>\n );\n\n const getConfirmCancelModalContent = () => {\n return (\n \n Are you sure you want to cancel? Your updates will be lost.\n \n \n \n \n \n \n \n );\n };\n\n const getModalContent = (message) => {\n return (\n \n {message}\n \n \n );\n };\n\n const content = (\n <>\n \n \n This option gives Zuora applications (Zuora Reporting, Zuora Data Query, AQuA, Data Source Exports, and Finance Trial Balance reports) \n the option to use Snowflake Compute resources from your Snowflake account\n (Snowflake fees apply) to run queries and reports faster and at higher scale.\n \n
\n \n \n \n {\n configFormDispatch({\n type: 'setDatabaseName',\n payload: target.value,\n });\n }}\n value={configFormState.databaseName}\n />\n \n {}}\n dsOnOpen={() => {}}\n e2e=\"\"\n title={}\n >\n <>\n \n >\n \n \n \n
\n \n \n \n \n {\n configFormDispatch({\n type: 'setAccountId',\n payload: target.value,\n });\n }}\n value={configFormState.accountId}\n />\n \n \n \n preferred format\n \n \n \n
\n \n \n \n {\n configFormDispatch({\n type: 'setUserName',\n payload: target.value,\n });\n }}\n value={configFormState.userName}\n />\n \n \n {\n configFormDispatch({\n type: 'setPassword',\n payload: target.value,\n });\n }}\n value={configFormState.password}\n />\n \n \n \n \n {\n configFormDispatch({\n type: 'setRole',\n payload: target.value,\n });\n }}\n value={configFormState.role}\n />\n \n \n {\n configFormDispatch({\n type: 'setWarehouse',\n payload: target.value,\n });\n }}\n value={configFormState.warehouse}\n />\n \n \n \n {\n if (!configFormState.poweredBySnowflakeEnabled) {\n validateConfigInfo();\n } else {\n configFormDispatch({ type: 'togglePoweredBySnowflake' });\n }\n }}\n />\n \n
\n {buttonSection}\n >\n );\n\n return (\n <>\n \n\n {}}\n body={getModalContent('Validating the Snowflake configuration.')}\n />\n {}}\n body={getModalContent('Saving the Snowflake configuration.')}\n />\n {}}\n body={getConfirmCancelModalContent()}\n />\n >\n );\n};\n\nexport default ConfigInfo;\n","import ConfigInfo from './ConfigInfo';\nexport default ConfigInfo;","export interface AccountInfoState {\n region: String;\n accountName: String;\n accountEdition: String;\n installerFirstName: String;\n installerLastName: String;\n installerEmail: String;\n installDate: Number;\n alreadyInstalled: boolean;\n validating: boolean;\n}\n\nconst initialState: AccountInfoState = {\n region: '',\n accountName: '',\n accountEdition: '',\n installerFirstName: '',\n installerLastName: '',\n installerEmail: '',\n installDate: 0,\n alreadyInstalled: false,\n validating: false,\n};\n\nconst reducer = (state: AccountInfoState, action) => {\n switch (action.type) {\n case 'setRegion':\n return { ...state, region: action.payload };\n case 'setAccountName':\n return { ...state, accountName: action.payload };\n case 'setAccountEdition':\n return { ...state, accountEdition: action.payload };\n case 'setInstallerFirstName':\n return { ...state, installerFirstName: action.payload };\n case 'setInstallerLastName':\n return { ...state, installerLastName: action.payload };\n case 'setInstallerEmail':\n return { ...state, installerEmail: action.payload };\n case 'setInstallDate':\n return { ...state, installDate: action.payload };\n case 'setAlreadyInstalled':\n return { ...state, alreadyInstalled: action.payload };\n case 'loadAccountInfo':\n return {\n ...state,\n region: action.payload.region,\n accountName: action.payload.accountName,\n accountEdition: action.payload.accountEdition,\n installerFirstName: action.payload.userFirstName,\n installerLastName: action.payload.userLastName,\n installerEmail: action.payload.userEmail,\n installDate: action.payload.installationDate,\n alreadyInstalled: Boolean(action.payload.installationDate),\n };\n case 'setValidating':\n return {\n ...state,\n validating: action.payload,\n };\n default:\n return state;\n }\n};\n\nexport { initialState, reducer };","const initialState = {\n databaseName: '',\n accountId: '',\n userName: '',\n password: '',\n role: '',\n warehouse: '',\n poweredBySnowflakeEnabled: false,\n validating: false,\n saving: false,\n savingSucceeded: true,\n loadedConfigInfo: {\n databaseName: '',\n accountId: '',\n userName: '',\n password: '',\n role: '',\n warehouse: '',\n poweredBySnowflakeEnabled: false,\n loaded: false,\n },\n fieldErrors: [],\n};\n\nconst reducer = (state, action) => {\n switch (action.type) {\n case 'setDatabaseName':\n return { ...state, databaseName: action.payload };\n case 'setAccountId':\n return { ...state, accountId: action.payload };\n case 'setUserName':\n return { ...state, userName: action.payload };\n case 'setPassword':\n return { ...state, password: action.payload };\n case 'setRole':\n return { ...state, role: action.payload };\n case 'setWarehouse':\n return { ...state, warehouse: action.payload };\n case 'togglePoweredBySnowflake':\n return {\n ...state,\n poweredBySnowflakeEnabled: !state.poweredBySnowflakeEnabled,\n };\n case 'loadConfigInfo':\n return {\n ...state,\n databaseName: action.payload.database,\n accountId: action.payload.accountId,\n userName: action.payload.username,\n password: action.payload.password,\n role: action.payload.role,\n warehouse: action.payload.warehouse,\n poweredBySnowflakeEnabled: action.payload.poweredBySnowflake,\n loadedConfigInfo: {\n databaseName: action.payload.database,\n accountId: action.payload.accountId,\n userName: action.payload.username,\n password: action.payload.password,\n role: action.payload.role,\n warehouse: action.payload.warehouse,\n poweredBySnowflakeEnabled: action.payload.poweredBySnowflake,\n loaded: !!action.payload.database,\n },\n };\n case 'setFieldErrors':\n return {\n ...state,\n fieldErrors: action.payload,\n validating: false,\n };\n case 'clearErrors':\n return {\n ...state,\n fieldErrors: [],\n };\n case 'setValidating':\n return {\n ...state,\n validating: action.payload,\n };\n case 'setSaving':\n return {\n ...state,\n saving: true,\n };\n case 'setSavingSucceeded':\n return {\n ...state,\n saving: false,\n savingSucceeded: true,\n };\n case 'setSavingFailed':\n return {\n ...state,\n saving: false,\n savingSucceeded: false,\n };\n default:\n return state;\n }\n};\n\nexport { initialState, reducer };","import styled from '@emotion/styled';\n\nexport const ContentPaddingStyle = styled.div`\n padding-top: 10px;\n`;\n\nexport const ButtonSectionStyle = styled.div`\n display: flex;\n justify-content: center;\n margin-top: 20px;\n`;\n\nexport const SnowflakeInputSectionStyle = styled.div`\n display: inline;\n margin-right: 20px;\n`;\n\nexport const SnowflakeInputRowSectionStyle = styled.div`\n margin-top: 20px;\n`;\n\nexport const TopMessageInProgress = styled.div`\n margin-top: -15px;\n margin-bottom: 15px;\n padding: 5px;\n`;\n\nexport const TopMessageCompleted = styled.div`\n margin-top: -15px;\n margin-bottom: 15px;\n padding: 5px;\n`;"],"names":["_ref","title","open","e2e","dsOnClose","dsOnOpen","children","placement","onOpen","onClose","style","display","concat","ConnectionSettings","hasPermission","useIdentity","snowflakeConfigEnabled","snowflakeConfigLoading","useFlipperHook","React","Alert","center","variant","severity","body","Card","id","Spinner","ContentPaddingStyle","AccountInfo","ConfigInfo","regions","setRegions","useState","setToast","useToast","provisionStatusMessage","setProvisionStatusMessage","objectsList","setObjectsList","selectedObjects","setSelectedObjects","provisionCompletionStatus","setProvisionCompletionStatus","confirmationModalOpen","setConfirmationModalOpen","accountInfoFormState","accountInfoFormDispatch","useReducer","accountInfoReducer","accountInfoInitialState","isClickedClosedIcon","setIsClickedClosedIcon","identity","zdsLocale","timezone","loadingProvisionStatus","setLoadingProvisionStatus","proxyPath","window","location","host","includes","control","register","formState","errors","useForm","fetchAccountInfo","async","response","Connect","proxyCall","undefined","Accept","tenantId","payload","json","status","type","error","log","message","keyRender","Date","now","useEffect","ok","Error","statusText","fetchRegions","fetchProvisionCompletionStatus","data","zobjects","map","objectName","index","zuoraObjectsList","fetchObjectsList","saveAccountInfo","region","snowflakeAccountRegion","accountName","snowflakeAccountName","accountEdition","snowflakeAccountEdition","installationUserFirstName","firstName","installationUserLastName","lastName","installationUserEmail","workEmail","then","businessCritical","shareObjects","length","serviceType","shareLatency","warehouse","catch","provisionTenantShare","hasMissingAccountInfo","InstallButtonSection","alreadyInstalled","ButtonSectionStyle","Button","disabled","dsOnClick","InstalledBySection","Typography","installerFirstName","installerLastName","installerEmail","getDatetime","datetime","locale","Intl","DateTimeFormat","day","month","year","hour","minute","second","timeZone","timeZoneName","format","Number","installDate","console","content","Grid","container","item","xs","direction","spacing","Select","label","labelPostfix","Icon","fontSize","color","Tooltip","arrow","placeholder","value","dsOnChange","e","target","sort","SelectItem","key","TextField","FormLabel","sx","designTokens","colors","coolGray400","ObjectsListModel","rows","onSelectionChange","selectedObjectNames","AllowInstallationModal","openInstallationModal","onInstallation","validateAccountInfo","connectionStatusChip","PopoverComp","transformOrigin","vertical","horizontal","anchorOrigin","onFirstOpen","anchor","Chip","Box","alignItems","gap","state","size","width","padding","justify","fontWeight","IconButton","onClick","opacity","displayPopover","popoverId","header","Modal","maxWidth","fullWidth","ModalTitle","icon","validating","marginRight","justifyContent","pb","footer","ModalActions","allCurrentAndFutureModelsSelected","setAllCurrentAndFutureModelsSelected","rowSelectionModel","setRowSelectionModel","prevRowSelection","setPrevRowSelectionModel","modalOpen","setModalOpen","paginationModel","setPaginationModel","page","pageSize","handleRowSelectionChange","newRowSelectionModel","find","row","filter","Boolean","Controller","name","render","marginBottom","red500","Object","assign","validate","formValues","subtitle","DataGrid","disableRowSelectionOnClick","pagination","pageSizeOptions","onPaginationModelChange","isRowSelectable","margin","disableColumnFilter","checkboxSelection","disableColumnSelector","disableDensitySelector","disableColumnMenu","slots","toolbar","GridToolbar","slotProps","showQuickFilter","csvOptions","disableToolbarButton","printOptions","filterPanel","disableAddFilterButton","onRowSelectionModelChange","columns","field","headerName","sortable","FormGroup","Checkbox","checked","Array","from","_","coolGray300","_templateObject","StyledPopover","$emphasis","contextHigh","_ref2","$pointerEventsNone","_ref3","$arrow","$theme","_getArrowPosition","calcPosition","origin","position","getArrowPosition","arrowStyle","palette","background","paper","_ref4","a11yId","className","disableRestoreFocus","_ref4$anchorEl","anchorEl","_ref4$anchorOrigin","_ref4$transformOrigin","paperProps","_ref4$arrow","_ref4$pointerEventsNo","pointerEventsNone","_ref4$disablePortal","disablePortal","theme","useTheme","themeTokens","PaperProps","paddingTop","paddingBottom","paddingLeft","paddingRight","pointerEvents","AnchorWrapper","styled","div","customStyle","cursor","anchorStyle","setAnchorEl","setOpen","handleMouseLeave","useCallback","debounce","handleMouseEnter","cancel","onMouseEnter","event","currentTarget","onMouseLeave","Popover","configFormEditable","setConfigFormEditable","showConfirmCancelModal","setShowConfirmCancelModal","configFormState","configFormDispatch","configReducer","configInitialState","hasErrors","fieldName","fieldErrors","fetchConfigInfo","refreshConfigInfoForm","configInfoHasChanges","databaseName","accountId","userName","password","role","poweredBySnowflakeEnabled","loadedDatabaseName","loadedAccountId","loadedUserName","loadedPassword","loadedRole","loadedWarehouse","loadedPoweredBySnowflakeEnabled","loadedConfigInfo","configInfoHasEmptyFields","buttonSection","upsertConfigInfo","username","database","poweredBySnowflake","loaded","marginLeft","configFormEditButton","getModalContent","flexDirection","SnowflakeInputRowSectionStyle","required","alignSelf","SnowflakeInputSectionStyle","Link","href","underline","navy600","valid","reasons","validateConfigInfo","headerAction","saving","initialState","reducer","action","userFirstName","userLastName","userEmail","installationDate","savingSucceeded"],"sourceRoot":""}