Skip to content

Commit

Permalink
fix Create StorageClass form
Browse files Browse the repository at this point in the history
  • Loading branch information
SanjalKatiyar authored and openshift-cherrypick-robot committed Sep 26, 2023
1 parent c6aa7d3 commit 198e799
Showing 1 changed file with 19 additions and 10 deletions.
29 changes: 19 additions & 10 deletions packages/ocs/storage-class/sc-form.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -79,12 +79,16 @@ import { CreateBlockPoolModal } from '../modals/block-pool/create-block-pool-mod
import { StoragePoolKind } from '../types';
import './sc-form.scss';

type OnParamChange = (id: string, paramName: string, checkbox: boolean) => void;

export const CephFsNameComponent: React.FC<ProvisionerProps> = ({
parameterKey,
parameterValue,
onParamChange,
}) => {
const { t } = useCustomTranslation();
const onParamChangeRef = React.useRef<OnParamChange>();
onParamChangeRef.current = onParamChange;

const isExternal = useFlag(OCS_INDEPENDENT_FLAG);
const scName = `${
Expand All @@ -99,10 +103,10 @@ export const CephFsNameComponent: React.FC<ProvisionerProps> = ({
if (scLoaded && !scLoadError) {
const fsName = sc?.parameters?.fsName;
if (fsName) {
onParamChange(parameterKey, fsName, false);
onParamChangeRef.current(parameterKey, fsName, false);
}
}
}, [sc, scLoaded, scLoadError, parameterKey, onParamChange]);
}, [sc, scLoaded, scLoadError, parameterKey]);

if (scLoaded && !scLoadError) {
return (
Expand Down Expand Up @@ -511,6 +515,8 @@ export const StorageClassEncryptionKMSID: React.FC<ProvisionerProps> = ({
onParamChange,
}) => {
const { t } = useCustomTranslation();
const onParamChangeRef = React.useRef<OnParamChange>();
onParamChangeRef.current = onParamChange;

const [state, dispatch] = React.useReducer(reducer, initialState);
const [isExistingKms, setIsExistingKms] = React.useState<boolean>(true);
Expand Down Expand Up @@ -546,18 +552,21 @@ export const StorageClassEncryptionKMSID: React.FC<ProvisionerProps> = ({
const setEncryptionId = React.useCallback(
(encryptionId: string) => {
setServiceName(encryptionId);
onParamChange(parameterKey, encryptionId, false);
onParamChangeRef.current(parameterKey, encryptionId, false);
},
[onParamChange, parameterKey]
[parameterKey]
);

/** When user selects a connection from the dropdown, but, then un-checks the encryption checkbox,
* and checks it back again. Component will be re-mounted, still Redux state will still
* have previously selected parameterValue. This useEffect is to clean that up.
*/
React.useEffect(() => {
// ToDo (Sanjal): "StorageClassForm" got refactored to a FC (https://github.com/openshift/console/pull/13036).
// If any "parameter" specific "Component" in un-mounting, it do not have access to latest "onParamChange" (having latest "newStorageClass" object).
// Talk to OCP team, maybe we can pass "onParamChange" as a "useRef" object, which can resolve this issue.

// When user selects a connection from the dropdown, but, then un-checks the encryption checkbox,
// and checks it back again. Component will be re-mounted, still Redux state will still
// have previously selected parameterValue. This useEffect is to clean that up.
/* React.useEffect(() => {
return () => setEncryptionId('');
}, [setEncryptionId]);
}, [setEncryptionId]); */

/** When csiConfigMap is deleted from another tab, "csiConfigMapLoadError" == true (404 Not Found), but,
* "csiConfigMap" still contains same old object that was present before the deletion of the configMap.
Expand Down

0 comments on commit 198e799

Please sign in to comment.