Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(platform): Delete variable from a project #600

Merged
merged 25 commits into from
Jan 11, 2025

Conversation

poswalsameer
Copy link
Contributor

@poswalsameer poswalsameer commented Dec 29, 2024

User description

Description

This PR adds the feature of deleting a variable from a project.

Fixes #560

Mentions

@kriptonian1

Screenshots of relevant screens

Screenshot 2024-12-30 015940
Screenshot 2024-12-30 015948

Developer's checklist

  • My PR follows the style guidelines of this project
  • I have performed a self-check on my work

If changes are made in the code:

  • I have followed the coding guidelines
  • My changes in code generate no new warnings
  • My changes are breaking another fix/feature of the project
  • I have added test cases to show that my feature works
  • I have added relevant screenshots in my PR
  • There are no UI/UX issues

Documentation Update

  • This PR requires an update to the documentation at docs.keyshade.xyz
  • I have made the necessary updates to the documentation, or no documentation changes are required.

PR Type

Enhancement, Documentation


Description

This PR implements the variable management feature in the project, including:

  • Added ability to create and delete variables within a project
  • Implemented variable listing with collapsible details showing environment values
  • Added confirmation dialog for variable deletion with proper error handling
  • Enhanced UI components:
    • New reusable Textarea component
    • Alert dialog for confirmations
    • Improved project creation form
  • Fixed type safety issues in API response parsing
  • Updated project navigation to use slugs instead of IDs
  • Added new SVG icons for improved UI
  • Implemented proper success/error toasts for user feedback

Changes walkthrough 📝

Relevant files
Enhancement
8 files
layout.tsx
Add variable creation and management functionality             
+294/-52
page.tsx
Implement variable listing and deletion feature                   
+249/-4 
alert-dialog.tsx
Add reusable alert dialog component                                           
+141/-0 
page.tsx
Update project creation form with textarea                             
+25/-12 
confirm-delete.tsx
Add confirmation dialog for variable deletion                       
+103/-0 
textarea.tsx
Add reusable textarea component                                                   
+22/-0   
index.tsx
Update project card link to use slug                                         
+2/-1     
index.ts
Add new SVG icon exports                                                                 
+9/-1     
Bug fix
1 files
response-parser.ts
Fix type casting in response parser                                           
+2/-2     
Additional files
4 files
collapsible.tsx +12/-0   
erDetails(userData) +0/-664 
t updateSelf = useCallback(async () => { +0/-664 

💡 PR-Agent usage: Comment /help "your question" on any pull request to receive relevant information

Copy link
Contributor

PR Reviewer Guide 🔍

Here are some key observations to aid the review process:

🎫 Ticket compliance analysis ✅

560 - PR Code Verified

Compliant requirements:

  • Implement variable deletion functionality for projects
  • Follow Figma design for UI implementation
  • Implement in apps/platform/src/app/(main)/project/[project]/@variable/page.tsx
  • Integrate with Bruno API for delete variable functionality

Requires further human verification:

  • Visual verification that UI matches Figma design
⏱️ Estimated effort to review: 4 🔵🔵🔵🔵⚪
🧪 No relevant tests
🔒 No security concerns identified
⚡ Recommended focus areas for review

Error Handling

The error handling in deleteVariable function only logs errors to console without showing user feedback, unlike success case which shows a toast. Consider showing error feedback to users.

if( error ){
  console.error(error)
}
State Management

The useEffect hook has allVariables in its dependency array which could cause infinite re-renders since allVariables is being set within the effect itself.

useEffect(() => {
  const getAllVariables = async () => {
    if (!currentProject) {
      return
    }

    const {
      success,
      error,
      data
    }: ClientResponse<GetAllVariablesOfProjectResponse> =
      await ControllerInstance.getInstance().variableController.getAllVariablesOfProject(
        { projectSlug: currentProject.slug },
        {}
      )

    if (success && data) {
      setAllVariables(data.items)
    } else {
      // eslint-disable-next-line no-console -- we need to log the error
      console.error(error)
    }
  }

  getAllVariables()
}, [currentProject, allVariables])

Copy link
Contributor

codiumai-pr-agent-free bot commented Dec 29, 2024

PR Code Suggestions ✨

Explore these optional code suggestions:

CategorySuggestion                                                                                                                                    Score
Possible issue
✅ Fix reference to undefined variable in useEffect dependency array

Fix the undefined 'open' variable usage in useEffect which could cause runtime
errors.

apps/platform/src/components/ui/confirm-delete.tsx [64-68]

 useEffect(() => {
-  if (!open) {
+  if (!isOpen) {
     cleanup()
   }
   return () => cleanup()
-}, [open, cleanup])
+}, [isOpen, cleanup])

[Suggestion has been applied]

Suggestion importance[1-10]: 9

Why: The suggestion fixes a critical bug where an undefined 'open' variable is used instead of the correct 'isOpen' prop, which could cause runtime errors.

9
Add proper validation and error handling for missing variable slugs before deletion

Add input validation before submitting the variable deletion request to prevent
potential errors from null/undefined variable slugs.

apps/platform/src/app/(main)/project/[project]/@variable/page.tsx [28-33]

 const deleteVariable = async () => {
-  if( variableSlug === null ){
+  if (!variableSlug) {
+    toast.error('Invalid variable selected', {
+      description: 'Cannot delete variable: No variable was selected'
+    })
+    onClose()
     return
   }
   const { success, error } = await ControllerInstance.getInstance().variableController.deleteVariable(
  • Apply this suggestion
Suggestion importance[1-10]: 7

Why: The suggestion adds important input validation with user feedback for null/undefined variable slugs, preventing potential runtime errors and improving error handling.

7
General
✅ Add user-facing error notifications when variable deletion fails instead of only logging to console

Add error handling for the case when variable deletion fails. Currently, errors are
only logged to console, but users should be notified when deletion fails.

apps/platform/src/app/(main)/project/[project]/@variable/page.tsx [40-52]

 if (success) {
   toast.success('Variable deleted successfully', {
     description: () => (
       <p className="text-xs text-emerald-300">
         The variable has been deleted.
       </p>
     )
   })
 }
-if( error ){
+if (error) {
+  toast.error('Failed to delete variable', {
+    description: () => (
+      <p className="text-xs text-red-300">
+        An error occurred while deleting the variable. Please try again.
+      </p>
+    )
+  })
   console.error(error)
 }

[Suggestion has been applied]

Suggestion importance[1-10]: 8

Why: The suggestion improves error handling by adding user-facing error notifications instead of just console logging, which significantly enhances user experience by providing clear feedback when operations fail.

8

@poswalsameer poswalsameer changed the title feat: Delete variable from a project feat(platform): Delete variable from a project Dec 30, 2024
Copy link
Contributor

@kriptonian1 kriptonian1 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@rajdip-b rajdip-b merged commit e64a738 into keyshade-xyz:develop Jan 11, 2025
3 checks passed
rajdip-b pushed a commit that referenced this pull request Jan 23, 2025
## [2.9.0](v2.8.0...v2.9.0) (2025-01-23)

### 🚀 Features

* **api-client:** Get all workspace invitation ([#619](#619)) ([8a23850](8a23850))
* **api,cli,api-client,schema:** Enhance permissions to allow filtering by environments through project roles ([#599](#599)) ([030b539](030b539))
* **api:** Add `ADMIN` authority for API keys ([#609](#609)) ([fb6aba7](fb6aba7))
* **api:** Add email template for inviting user to workspace ([#480](#480)) ([f5ddf7a](f5ddf7a))
* **api:** Add email template for sending OTP to the user ([#582](#582)) ([cb6bbcb](cb6bbcb))
* **api:** Add endpoint to fetch all workspace invitations for a user ([#586](#586)) ([d45417a](d45417a))
* **api:** Add logout endpoint to clear token cookie ([#581](#581)) ([27f81ba](27f81ba))
* **api:** Add slack integration ([#531](#531)) ([fe124d8](fe124d8))
* **cli:** Add CLI command to check version flag using `--version` or `-v` ([#650](#650)) ([31b5efe](31b5efe))
* **cli:** Add functionality to operate on Workspace Membership ([#589](#589)) ([0fde62b](0fde62b))
* **cli:** Add import sub commmand for project. ([#594](#594)) ([9896f27](9896f27))
* **cli:** Add List-invitation command ([#633](#633)) ([874f8c2](874f8c2))
* **cli:** Added keyshade command to cli ([cf260ae](cf260ae))
* **cli:** Api health probe ([#645](#645)) ([dd854f4](dd854f4))
* **cli:** Create basic README.md ([a1b74e9](a1b74e9))
* **cli:** Log publicKey, privacyKey, & accessLevel after project creation ([#623](#623)) ([5d5b329](5d5b329))
* **cli:** Supports to specify environment(s) and its optional description ([#634](#634)) ([62083b1](62083b1))
* **cli:** update README with feature and installation ([#644](#644)) ([a4d2a6a](a4d2a6a))
* **platform:** Add a new [secure] and added loader on project screen ([#603](#603)) ([c3a08cc](c3a08cc))
* **platform:** Add new variables to a project ([#593](#593)) ([d6c6252](d6c6252))
* **platform:** Delete variable from a project ([#600](#600)) ([e64a738](e64a738))
* **platform:** Edit existing variables in a project ([#602](#602)) ([bb48f6c](bb48f6c))
* **platform:** Show all the existing variables inside a project ([#591](#591)) ([5276bb8](5276bb8))
* **platofrm:** Added online/offline status detection in the platform ([#585](#585)) ([89aa84f](89aa84f))
* **schema:** Add workspace invitation schema ([#612](#612)) ([1a5721b](1a5721b))
* **web:** Add Google Analytics integration ([#649](#649)) ([397d6da](397d6da))

### 🐛 Bug Fixes

* **api:** Empty name `""` accepted as a valid name while creating environments ([#583](#583)) ([a33f4b5](a33f4b5))
* **api:** Enable global project access ([#580](#580)) ([b3a0309](b3a0309))
* **api:** Update build command ([0ddfa59](0ddfa59))
* **cli:** Add keywords for improved package discoverability ([#641](#641)) ([57ce10b](57ce10b))
* **cli:** Check for .keyshade dir if profile isn't found ([#636](#636)) ([a69665d](a69665d))
* **cli:** Create project --store-private-key option default value removed ([#638](#638)) ([20f16c6](20f16c6))
* **cli:** Fixed binary path in package.json ([e531af0](e531af0))
* **cli:** Fixed binary path in package.json ([81d674d](81d674d))
* **cli:** Incorrect message on listing projects ([#624](#624)) ([eeffa42](eeffa42))
* **cli:** Module errors ([d3432c5](d3432c5))
* **cli:** Module errors ([a639065](a639065))
* **cli:** Module errors ([a7742b1](a7742b1))
* **cli:** Module errors ([e96300e](e96300e))
* **cli:** Profile name now can use - and _ and updated error message ([#639](#639)) ([00dd66a](00dd66a))
* **cli:** Prompt users for all values if no option set and show default values ([#640](#640)) ([fe862ab](fe862ab))
* **docker:** Update build script ([40ef3e2](40ef3e2))
* **platform:** Check if `Env. Name` is left empty ([#646](#646)) ([5f3fac8](5f3fac8))
* **platform:** Clickable Workspaces combobox options ([#630](#630)) ([acc96f7](acc96f7))
* **platform:** Optimized user update request body ([#605](#605)) ([ee1adf0](ee1adf0))
* **platform:** Type error in navbar ([8199de8](8199de8))
* **README:** Update Discord badge ([6f9382e](6f9382e))
* **schema:** Add versions field to project [secure]s and variables response ([#590](#590)) ([755ea46](755ea46))

### 📚 Documentation

* **cli:** Update changelog to include missed out changes ([8910c5c](8910c5c))
* Updated alignment of pictures in API Testing page ([5d69223](5d69223))
* Updated alignment of pictures in API Testing page ([e31eeca](e31eeca))

### 🔧 Miscellaneous Chores

* Add Sentry and update CI ([#653](#653)) ([ca96862](ca96862))
* **ci:** Add CLI deployment script ([51de9d1](51de9d1))
* **ci:** Add internal package dependencies to existing workflows ([#592](#592)) ([a9fc39e](a9fc39e))
* **ci:** Add scope ([8ef89a8](8ef89a8))
* **ci:** Bug fix in workflow ([d583a46](d583a46))
* **ci:** Bug fix in workflow ([eb9d60f](eb9d60f))
* **ci:** Bump version to 2.2.0 ([951bd14](951bd14))
* **ci:** Deploy DB migrations ([ea1beed](ea1beed))
* **ci:** Fixed chaining and scripts ([6a009eb](6a009eb))
* **ci:** Fixed environment name ([172c348](172c348))
* **ci:** Fixed errors ([f28e3b5](f28e3b5))
* **ci:** Minor fixes ([c7f05a0](c7f05a0))
* **ci:** Push docker images of platform and API to ACR ([5f79dd7](5f79dd7))
* **ci:** Remove npm ci ([3d45a4c](3d45a4c))
* **ci:** Remove pnpm cache ([f45970c](f45970c))
* **ci:** Update app redeployment ([18cf765](18cf765))
* **ci:** Update web deployment to push to ACR ([26d4bed](26d4bed))
* **cli:** Bumped CLI to v2.4.0 ([09efcd9](09efcd9))
* **cli:** Rearranged dependency ([b6e344d](b6e344d))
* **cli:** Removed changeset ([6c436de](6c436de))
* **cli:** Update package name ([23552a1](23552a1))
* **cli:** Update package name ([480cf54](480cf54))
* **cli:** Update package.json ([871679a](871679a))
* **cli:** Updated build scripts ([2e2b42d](2e2b42d))
* **docker:** Update port of platform docker build ([c79d886](c79d886))
* Housekeeping ([2ed31c0](2ed31c0))
* **platoform:** Swapped all legacy API calls with `@keyshade/api-client` ([#584](#584)) ([c600db7](c600db7))
* Removed .postman folder ([4b2b675](4b2b675))
* Reverted back registry ([1699a89](1699a89))
* **schema:** Add describe blocks in tests for each kind of schema ([#577](#577)) ([c0763f3](c0763f3))
* Update npmrc ([9f7f495](9f7f495))
* Update pipelines; fixed api docker ([3f36a17](3f36a17))
* Update platform build command ([83a1851](83a1851))
* **web:** Fix CI ([d1bc740](d1bc740))
* **web:** Update dockerfile and ci to include google analytics env ([f2df4f4](f2df4f4))

### 🔨 Code Refactoring

* **cli:** Replace arguments with options ([#615](#615)) ([498f44e](498f44e))
* **platform:** Optimized codebase ([#629](#629)) ([d411081](d411081))
* **platform:** Refactor project components ([#626](#626)) ([5b70805](5b70805))
* **web:** Changed the text in the hero section of the web application ([#579](#579)) ([a92925f](a92925f))
@rajdip-b
Copy link
Member

🎉 This PR is included in version 2.9.0 🎉

The release is available on GitHub release

Your semantic-release bot 📦🚀

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

PLATFROM: Delete variable from a project
3 participants