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): Add new variables to a project #593

Merged
merged 13 commits into from
Jan 11, 2025

Conversation

poswalsameer
Copy link
Contributor

@poswalsameer poswalsameer commented Dec 20, 2024

User description

Description

This PR adds the feature to add new variables to a project.

Fixes #559

Screenshots of relevant screens

Screenshot 2024-12-11 160310
Screenshot (617)

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


Description

  • Added new variable creation functionality with a styled dialog form
  • Implemented environment selection with dynamic loading of available environments
  • Added form fields for variable name, note, environment name and value
  • Integrated with API for creating new variables
  • Updated project card navigation to use slugs instead of IDs
  • Enhanced UI with proper styling and form validation
  • Added proper error handling for API calls

Changes walkthrough 📝

Relevant files
Enhancement
layout.tsx
Add new variable creation dialog and functionality             

apps/platform/src/app/(main)/project/[project]/layout.tsx

  • Added new variable creation functionality with form dialog
  • Implemented environment selection and value input fields
  • Added API integration for creating variables
  • Enhanced UI with styled components and proper form validation
  • +247/-48
    index.tsx
    Update project card navigation to use slugs                           

    apps/platform/src/components/dashboard/projectCard/index.tsx

  • Updated project link to use slug instead of id
  • Added slug to project card props
  • +2/-1     

    💡 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 ✅

    559 - Fully compliant

    Compliant requirements:

    • Added popup dialog for new variable creation
    • UI matches Figma design with proper styling
    • Feature implemented in correct file location
    ⏱️ Estimated effort to review: 3 🔵🔵🔵⚪⚪
    🧪 No relevant tests
    🔒 No security concerns identified
    ⚡ Recommended focus areas for review

    Error Handling

    The error handling in addVariable function only logs to console without showing user feedback or retrying failed requests

        if(error){
          // eslint-disable-next-line no-console -- we need to log the error
          console.error(error)
        }
    Form Validation

    No validation is performed on the variable name and value fields before submission, which could lead to invalid data being sent to API

                        <Input
                          id="variable-name"
                          placeholder="Enter the key of the variable"
                          value={newVariableData.variableName}
                          onChange={(e) =>
                            setNewVariableData({
                              ...newVariableData,
                              variableName: e.target.value
                            })
                          }
                          className="h-[2.75rem] w-[20rem] border-0 bg-[#2a2a2a] text-gray-300 placeholder:text-gray-500"
                        />

    Copy link
    Contributor

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

    PR Code Suggestions ✨

    Explore these optional code suggestions:

    CategorySuggestion                                                                                                                                    Score
    Possible issue
    ✅ Add form validation to prevent submission of invalid data
    Suggestion Impact:The commit adds validation for currentProject existence, though in a different way than suggested. It throws an error if currentProject doesn't exist rather than showing a toast message.

    code diff:

    +    if (!currentProject) {
    +      throw new Error("Current project doesn't exist")
    +    }

    Add input validation before submitting the variable creation request. Currently the
    form can be submitted with empty required fields which could cause API errors.

    apps/platform/src/app/(main)/project/[project]/layout.tsx [60-65]

    -const addVariable = async (e: any) => {
    +const addVariable = async (e: React.FormEvent) => {
       e.preventDefault()
    +  if (!newVariableData.variableName.trim()) {
    +    toast.error('Variable name is required');
    +    return;
    +  }
    +  if (!currentProject?.slug) {
    +    toast.error('Project not found');
    +    return;
    +  }
       const request: CreateVariableRequest = {
    -    name: newVariableData.variableName,
    -    projectSlug: currentProject?.slug as string,
    +    name: newVariableData.variableName.trim(),
    +    projectSlug: currentProject.slug,
    • Apply this suggestion
    Suggestion importance[1-10]: 9

    Why: Adding input validation is critical for preventing API errors and ensuring data integrity. This helps avoid runtime errors and provides better user feedback for required fields.

    9
    ✅ Replace type suppression with proper type assertion to maintain type safety
    Suggestion Impact:The @ts-ignore comment was removed from the setCurrentProject call, improving type safety

    code diff:

    -        //@ts-ignore
             setCurrentProject(data)

    Remove the @ts-ignore comment and properly type the response data from getProject
    API call. Using @ts-ignore masks potential type mismatches that could cause runtime
    errors.

    apps/platform/src/app/(main)/project/[project]/layout.tsx [99-100]

     if (success && data) {
    -  //@ts-ignore
    -  setCurrentProject(data)
    +  setCurrentProject(data as Project)
     }
    • Apply this suggestion
    Suggestion importance[1-10]: 7

    Why: Removing @ts-ignore and using proper type assertion improves type safety and helps catch potential runtime errors during development. This is important for maintaining code reliability.

    7
    General
    ✅ Enhance error handling with user-facing notifications instead of just console logging
    Suggestion Impact:The commit implemented toast notifications for both success and error cases when creating variables, including specific error handling for 409 conflict errors

    code diff:

    +    if (success) {
    +      toast.success('Variable added successfully', {
    +        // eslint-disable-next-line react/no-unstable-nested-components -- we need to nest the description
    +        description: () => (
    +          <p className="text-xs text-emerald-300">
    +            The variable has been added to the project
    +          </p>
    +        )
    +      })
    +    }
    +
    +    if (error) {
    +      if (error.statusCode === 409) {
    +        toast.error('Variable name already exists', {
    +          // eslint-disable-next-line react/no-unstable-nested-components -- we need to nest the description
    +          description: () => (
    +            <p className="text-xs text-red-300">
    +              Variable name is already there, kindly use different one.
    +            </p>
    +          )
    +        })
    +      } else {
    +        // eslint-disable-next-line no-console -- we need to log the error that are not in the if condition
    +        console.error(error)
    +      }
         }

    Add proper error handling and user feedback for the variable creation API call.
    Currently errors are only logged to console which provides poor UX. Consider showing
    a toast/notification to inform users of success/failure.

    apps/platform/src/app/(main)/project/[project]/layout.tsx [82-85]

    -if(error){
    -  // eslint-disable-next-line no-console -- we need to log the error
    -  console.error(error)
    +if (error) {
    +  toast.error('Failed to create variable: ' + error.message);
    +  return;
     }
    +toast.success('Variable created successfully');
    • Apply this suggestion
    Suggestion importance[1-10]: 8

    Why: Adding user-facing error notifications significantly improves UX by providing clear feedback on operation success/failure, rather than silently logging to console which users can't see.

    8

    @kriptonian1 kriptonian1 changed the title feat: Add new variables to a project feat(platfrom): Add new variables to a project Dec 21, 2024
    @rajdip-b
    Copy link
    Member

    @kriptonian1 review ser

    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 🚀

    @kriptonian1
    Copy link
    Contributor

    @rajdip-b you can merge this code now

    @poswalsameer poswalsameer changed the title feat(platfrom): Add new variables to a project feat(platform): Add new variables to a project Dec 30, 2024
    @poswalsameer
    Copy link
    Contributor Author

    poswalsameer commented Jan 4, 2025

    @rajdip-b, this one's approved. You can merge this too.

    @rajdip-b rajdip-b merged commit d6c6252 into keyshade-xyz:develop Jan 11, 2025
    4 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.

    PLATFORM: Add new variable in a project
    3 participants