diff --git a/packages/frontend/src/components/projects/project/deployments/DeploymentDetailsCard.tsx b/packages/frontend/src/components/projects/project/deployments/DeploymentDetailsCard.tsx
index c4940ba..3c96434 100644
--- a/packages/frontend/src/components/projects/project/deployments/DeploymentDetailsCard.tsx
+++ b/packages/frontend/src/components/projects/project/deployments/DeploymentDetailsCard.tsx
@@ -1,4 +1,4 @@
-import React from 'react';
+import React, { useCallback } from 'react';
import {
Deployment,
DeploymentStatus,
@@ -60,85 +60,114 @@ const DeploymentDetailsCard = ({
}
};
- return (
-
-
- {/* DEPLOYMENT URL */}
- {deployment.url && (
-
-
- {deployment.url}
-
-
- )}
-
- {deployment.environment === Environment.Production
- ? `Production ${deployment.isCurrent ? '(Current)' : ''}`
- : 'Preview'}
-
-
-
- {/* DEPLOYMENT STATUS */}
-
-
- {deployment.status}
-
-
-
- {/* DEPLOYMENT COMMIT DETAILS */}
-
-
-
- {deployment.branch}
-
-
-
-
- {deployment.commitHash.substring(0, SHORT_COMMIT_HASH_LENGTH)}{' '}
- {deployment.commitMessage}
-
-
-
-
- {/* DEPLOYMENT INFOs */}
-
-
-
-
- {relativeTimeMs(deployment.createdAt)}
-
-
-
-
- {formatAddress(deployment.createdBy.name ?? '')}
-
-
+ const renderDeploymentMenu = useCallback(
+ (className?: string) => {
+ return (
+ );
+ },
+ [deployment, currentDeployment, onUpdate, project, prodBranchDomains],
+ );
+
+ const renderDeploymentStatus = useCallback(
+ (className?: string) => {
+ return (
+
+
+ {deployment.status}
+
+
+ );
+ },
+ [deployment.status, deployment.commitHash],
+ );
+
+ return (
+
+
+
+ {/* DEPLOYMENT URL */}
+ {deployment.url && (
+
+
+ {deployment.url}
+
+
+ )}
+
+ {deployment.environment === Environment.Production
+ ? `Production ${deployment.isCurrent ? '(Current)' : ''}`
+ : 'Preview'}
+
+
+ {/* MENU ON MOBILE */}
+ {renderDeploymentMenu('flex md:hidden ml-auto')}
+
+
+ {/* DEPLOYMENT STATUS */}
+ {renderDeploymentStatus('w-[10%] max-w-[110px] hidden md:flex h-fit')}
+
+ {/* DEPLOYMENT COMMIT DETAILS */}
+
+
+
+
+
+ {deployment.branch}
+
+
+
+
+
+ {deployment.commitHash.substring(0, SHORT_COMMIT_HASH_LENGTH)}{' '}
+ {deployment.commitMessage}
+
+
+
+ {renderDeploymentStatus('flex md:hidden h-fit')}
+
+
+ {/* DEPLOYMENT INFOs */}
+
+
+
+
+
+ {relativeTimeMs(deployment.createdAt)}
+
+
+
+
+
+ {formatAddress(deployment.createdBy.name ?? '')}
+
+
+
+ {renderDeploymentMenu('ml-auto hidden md:flex')}
);