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(web): Grant - Mobile view and sidemenu refactor #17214

Merged
merged 12 commits into from
Dec 20, 2024

Conversation

disaerna
Copy link
Member

@disaerna disaerna commented Dec 12, 2024

Grant - Tweaks

What

  • Add subheading to action card apply button

  • Add "Go back" arrow

  • Rearrange sidemenu

  • Add mobile view for "sidemenu" props

  • Add disabled logic to button

  • Minor UI tweaks

  • Island UI -> make Breadcrumbs wrap if too long

Why

Specify why you need to achieve this

Screenshots / Gifs

Attach Screenshots / Gifs to help reviewers understand the scope of the pull request

Checklist:

  • I have performed a self-review of my own code
  • I have made corresponding changes to the documentation
  • My changes generate no new warnings
  • I have added tests that prove my fix is effective or that my feature works
  • Formatting passes locally with my changes
  • I have rebased against main before asking for a review

Summary by CodeRabbit

Release Notes

  • New Features

    • Introduced new components: DetailPanel, ExtraPanel, and InstitutionPanel for enhanced grant information display.
    • Added a responsive sidebar with navigation options and improved layout.
  • Improvements

    • Enhanced the ActionCard to dynamically reflect grant status and deadlines.
    • Updated date formatting for consistency across the application.
    • Added a new style to remove box shadows from specific elements.
    • Modified the Breadcrumbs component to allow items to wrap within the container.
  • Bug Fixes

    • Corrected message text in the application status display.
  • Chores

    • Removed the old GrantSidebar component to streamline the codebase.

Copy link
Contributor

coderabbitai bot commented Dec 12, 2024

Walkthrough

This pull request introduces enhancements to the Grants section of the web application. The changes restructure the grant details page by breaking down the previous GrantSidebar into modular components such as DetailPanel, ExtraPanel, and InstitutionPanel. Modifications include improved layout, dynamic status handling, and updates to date formatting and message translations. Additionally, the Breadcrumbs component is adjusted for better layout flexibility, and new CSS styles are introduced for improved visual presentation.

Changes

File Change Summary
apps/web/screens/Grants/Grant/Grant.css.ts Added new CSS module with noUnderline style and global span styling
apps/web/screens/Grants/Grant/Grant.tsx Updated component with dynamic status rendering, new panel imports, and responsive layout
apps/web/screens/Grants/Grant/GrantSidebar.tsx Removed old sidebar component
apps/web/screens/Grants/Grant/GrantSidebar/DetailPanel.tsx New component for displaying grant details with memoized data
apps/web/screens/Grants/Grant/GrantSidebar/ExtraPanel.tsx New component for rendering support links and files
apps/web/screens/Grants/Grant/GrantSidebar/GrantSidebar.tsx New sidebar component with modular panel structure
apps/web/screens/Grants/Grant/GrantSidebar/PanelLine.tsx Added utility function for generating panel lines
apps/web/screens/Grants/messages.ts Added new message for "go back" and updated deadline message
apps/web/screens/Grants/utils.ts Modified date formatting to include a space before the month
libs/island-ui/core/src/lib/Breadcrumbs/Breadcrumbs.tsx Added flexWrap property to breadcrumbs component

Possibly related PRs

Suggested Labels

automerge

Suggested Reviewers

  • thorkellmani
  • RunarVestmann

Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media?

❤️ Share
🪧 Tips

Chat

There are 3 ways to chat with CodeRabbit:

  • Review comments: Directly reply to a review comment made by CodeRabbit. Example:
    • I pushed a fix in commit <commit_id>, please review it.
    • Generate unit testing code for this file.
    • Open a follow-up GitHub issue for this discussion.
  • Files and specific lines of code (under the "Files changed" tab): Tag @coderabbitai in a new review comment at the desired location with your query. Examples:
    • @coderabbitai generate unit testing code for this file.
    • @coderabbitai modularize this function.
  • PR comments: Tag @coderabbitai in a new PR comment to ask questions about the PR branch. For the best results, please provide a very specific query, as very limited context is provided in this mode. Examples:
    • @coderabbitai gather interesting stats about this repository and render them as a table. Additionally, render a pie chart showing the language distribution in the codebase.
    • @coderabbitai read src/utils.ts and generate unit testing code.
    • @coderabbitai read the files in the src/scheduler package and generate a class diagram using mermaid and a README in the markdown format.
    • @coderabbitai help me debug CodeRabbit configuration file.

Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments.

CodeRabbit Commands (Invoked using PR comments)

  • @coderabbitai pause to pause the reviews on a PR.
  • @coderabbitai resume to resume the paused reviews.
  • @coderabbitai review to trigger an incremental review. This is useful when automatic reviews are disabled for the repository.
  • @coderabbitai full review to do a full review from scratch and review all the files again.
  • @coderabbitai summary to regenerate the summary of the PR.
  • @coderabbitai resolve resolve all the CodeRabbit review comments.
  • @coderabbitai configuration to show the current CodeRabbit configuration for the repository.
  • @coderabbitai help to get help.

Other keywords and placeholders

  • Add @coderabbitai ignore anywhere in the PR description to prevent this PR from being reviewed.
  • Add @coderabbitai summary to generate the high-level summary at a specific location in the PR description.
  • Add @coderabbitai anywhere in the PR title to generate the title automatically.

Documentation and Community

  • Visit our Documentation for detailed information on how to use CodeRabbit.
  • Join our Discord Community to get help, request features, and share feedback.
  • Follow us on X/Twitter for updates and announcements.

Copy link

codecov bot commented Dec 12, 2024

Codecov Report

Attention: Patch coverage is 0% with 74 lines in your changes missing coverage. Please review.

Project coverage is 35.67%. Comparing base (e146770) to head (9331bcb).
Report is 3 commits behind head on main.

Files with missing lines Patch % Lines
.../screens/Grants/Grant/GrantSidebar/DetailPanel.tsx 0.00% 28 Missing ⚠️
...b/screens/Grants/Grant/GrantSidebar/ExtraPanel.tsx 0.00% 16 Missing ⚠️
apps/web/screens/Grants/Grant/Grant.tsx 0.00% 12 Missing ⚠️
...screens/Grants/Grant/GrantSidebar/GrantSidebar.tsx 0.00% 12 Missing ⚠️
...eb/screens/Grants/Grant/GrantSidebar/PanelLine.tsx 0.00% 4 Missing ⚠️
apps/web/screens/Grants/utils.ts 0.00% 2 Missing ⚠️
Additional details and impacted files

Impacted file tree graph

@@            Coverage Diff             @@
##             main   #17214      +/-   ##
==========================================
- Coverage   35.70%   35.67%   -0.03%     
==========================================
  Files        6924     6926       +2     
  Lines      148678   148630      -48     
  Branches    42476    42471       -5     
==========================================
- Hits        53080    53023      -57     
- Misses      95598    95607       +9     
Flag Coverage Δ
air-discount-scheme-web 0.00% <ø> (ø)
api 3.33% <ø> (ø)
application-api-files 61.90% <ø> (ø)
application-core 75.72% <ø> (ø)
application-system-api 38.75% <ø> (+<0.01%) ⬆️
application-template-api-modules 27.67% <ø> (-0.03%) ⬇️
application-templates-accident-notification 27.61% <ø> (ø)
application-templates-car-recycling 3.12% <ø> (ø)
application-templates-criminal-record 25.74% <ø> (ø)
application-templates-driving-license 18.15% <ø> (ø)
application-templates-estate 13.69% <ø> (ø)
application-templates-example-payment 24.69% <ø> (ø)
application-templates-financial-aid 14.45% <ø> (ø)
application-templates-general-petition 23.12% <ø> (ø)
application-templates-inheritance-report 6.59% <ø> (ø)
application-templates-marriage-conditions 15.18% <ø> (ø)
application-templates-mortgage-certificate 43.62% <ø> (ø)
application-templates-parental-leave 29.93% <ø> (ø)
application-types 6.51% <ø> (ø)
application-ui-components 1.22% <ø> (ø)
application-ui-shell 22.31% <ø> (ø)
clients-charge-fjs-v2 28.35% <ø> (ø)
contentful-apps 4.71% <ø> (ø)
financial-aid-backend 51.42% <ø> (ø)
financial-aid-shared 17.88% <ø> (ø)
island-ui-core 30.40% <ø> (ø)
judicial-system-web 27.72% <ø> (ø)
portals-admin-regulations-admin 1.80% <ø> (ø)
portals-core 19.61% <ø> (ø)
shared-components 29.64% <ø> (ø)
shared-form-fields 33.36% <ø> (ø)
web 2.40% <0.00%> (-0.01%) ⬇️

Flags with carried forward coverage won't be shown. Click here to find out more.

Files with missing lines Coverage Δ
apps/web/screens/Grants/messages.ts 0.00% <ø> (ø)
...island-ui/core/src/lib/Breadcrumbs/Breadcrumbs.tsx 100.00% <ø> (ø)
...-ui/core/src/lib/InfoCardGrid/DetailedInfoCard.tsx 5.88% <ø> (ø)
apps/web/screens/Grants/utils.ts 0.00% <0.00%> (ø)
...eb/screens/Grants/Grant/GrantSidebar/PanelLine.tsx 0.00% <0.00%> (ø)
apps/web/screens/Grants/Grant/Grant.tsx 0.00% <0.00%> (ø)
...screens/Grants/Grant/GrantSidebar/GrantSidebar.tsx 0.00% <0.00%> (ø)
...b/screens/Grants/Grant/GrantSidebar/ExtraPanel.tsx 0.00% <0.00%> (ø)
.../screens/Grants/Grant/GrantSidebar/DetailPanel.tsx 0.00% <0.00%> (ø)

... and 15 files with indirect coverage changes


Continue to review full report in Codecov by Sentry.

Legend - Click here to learn more
Δ = absolute <relative> (impact), ø = not affected, ? = missing data
Powered by Codecov. Last update 27a704f...9331bcb. Read the comment docs.

@datadog-island-is
Copy link

datadog-island-is bot commented Dec 12, 2024

Datadog Report

All test runs 1be9bce 🔗

10 Total Test Services: 0 Failed, 10 Passed
🔻 Test Sessions change in coverage: 1 decreased (-0.01%), 147 no change

Test Services
This report shows up to 10 services
Service Name Failed Known Flaky New Flaky Passed Skipped Total Time Code Coverage Change Test Service View
air-discount-scheme-web 0 0 0 2 0 6.64s 1 no change Link
api 0 0 0 4 0 2.37s 1 no change Link
application-api-files 0 0 0 2 0 4.46s 1 no change Link
application-core 0 0 0 97 0 14.9s 1 no change Link
application-system-api 0 0 0 46 0 2m 16.49s 1 no change Link
application-template-api-modules 0 0 0 118 0 2m 7.96s 1 decreased (-0.01%) Link
application-templates-accident-notification 0 0 0 140 0 13.2s 1 no change Link
application-templates-criminal-record 0 0 0 2 0 9.49s 1 no change Link
application-templates-driving-license 0 0 0 13 0 12.69s 1 no change Link
application-templates-example-payment 0 0 0 2 0 9.93s 1 no change Link

🔻 Code Coverage Decreases vs Default Branch (1)

  • application-template-api-modules - jest 30.08% (-0.01%) - Details

@disaerna disaerna added the deploy-feature Deploys features to dev label Dec 17, 2024
Copy link
Contributor

Affected services are: api,application-system-api,financial-aid-api,financial-aid-backend,financial-aid-open-api,services-auth-personal-representative,air-discount-scheme-web,consultation-portal,contentful-apps,financial-aid-web-osk,financial-aid-web-veita,judicial-system-web,skilavottord-web,web,application-system-form,island-ui-storybook,portals-admin,service-portal,system-e2e,
Feature deployment of your services will begin shortly. Your feature will be accessible here:
https://web-grants-apply-cards-api-catalogue.dev01.devland.is/api
https://web-grants-apply-cards-application-callback-xrd.internal.dev01.devland.is/application-payment
https://web-grants-apply-cards-application-callback-xrd.internal.dev01.devland.is/applications
https://web-grants-apply-cards-application-payment-callback-xrd.internal.dev01.devland.is/application-payment
https://web-grants-apply-cards-application-payment-callback-xrd.internal.dev01.devland.is/applications
https://web-grants-apply-cards-beta.dev01.devland.is/
https://web-grants-apply-cards-beta.dev01.devland.is/api
https://web-grants-apply-cards-beta.dev01.devland.is/app/skilavottord/
https://web-grants-apply-cards-beta.dev01.devland.is/bff
https://web-grants-apply-cards-beta.dev01.devland.is/minarsidur
https://web-grants-apply-cards-beta.dev01.devland.is/samradsgatt
https://web-grants-apply-cards-beta.dev01.devland.is/stjornbord
https://web-grants-apply-cards-beta.dev01.devland.is/stjornbord/bff
https://web-grants-apply-cards-beta.dev01.devland.is/umsoknir
https://web-grants-apply-cards-loftbru-cf.dev01.devland.is/
https://web-grants-apply-cards-loftbru.dev01.devland.is/
https://web-grants-apply-cards-ui.dev01.devland.is/

Deployed services: application-system-api,application-system-form,service-portal,portals-admin,consultation-portal,api,web,skilavottord-web,island-ui-storybook,air-discount-scheme-web,application-system-api-worker,services-bff-portals-admin,services-bff-portals-my-pages.
Excluded services: contentful-apps

@disaerna disaerna changed the title feat(web): Grant - WIP action card & alert banner for grant feat(web): Grant - Mobile view and sidemenu refactor Dec 19, 2024
@disaerna disaerna marked this pull request as ready for review December 19, 2024 11:47
@disaerna disaerna requested review from a team as code owners December 19, 2024 11:47
Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

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

Actionable comments posted: 4

🧹 Nitpick comments (12)
apps/web/screens/Grants/Grant/Grant.css.ts (2)

3-3: Consider adding explicit styles or renaming the style

The empty style object with name noUnderline is misleading as it doesn't directly handle underlines. Consider either:

  1. Adding explicit styles in the object
  2. Renaming to better reflect its purpose (e.g., noBoxShadow)

5-7: Consider using a more specific selector

The global style targeting all spans within elements using this class could be too broad. Consider using a more specific selector or moving the style to the component level if it's only used in a specific context.

-globalStyle(`${noUnderline} span`, {
+globalStyle(`${noUnderline} span[class*="Button"]`, {
   boxShadow: 'none',
})
apps/web/screens/Grants/Grant/GrantSidebar/PanelLine.tsx (1)

3-15: Consider enhancing component flexibility with spacing props

The component follows good practices but could be more flexible. Consider:

  1. Adding spacing props for vertical margins
  2. Making the Box component's props configurable
-export const generateLine = (heading: string, content?: React.ReactNode) => {
+interface PanelLineProps {
+  heading: string;
+  content?: React.ReactNode;
+  spacing?: number;
+  boxProps?: BoxProps;
+}
+
+export const generateLine = ({
+  heading,
+  content,
+  spacing = 2,
+  boxProps
+}: PanelLineProps) => {
   if (!content) {
     return null
   }
   return (
-    <Box>
+    <Box marginY={spacing} {...boxProps}>
       <Text variant="medium" fontWeight="semiBold">
         {heading}
       </Text>
apps/web/screens/Grants/Grant/GrantSidebar/GrantSidebar.tsx (4)

35-54: Optimize goBackToDashboard with useMemo

The function recreates JSX on every render. Consider memoizing it with useMemo for better performance.

-  const goBackToDashboard = () => {
+  const goBackToDashboard = useMemo(() => {
     return (
       <Box printHidden className={styles.noUnderline}>
         <LinkV2 href={'/styrkjatorg/styrkir'}>
           <Button
             preTextIcon="arrowBack"
             preTextIconType="filled"
             size="small"
             type="button"
             variant="text"
             truncate
             as="span"
             unfocusable
           >
             {formatMessage(m.general.goBack)}
           </Button>
         </LinkV2>
       </Box>
     )
-  }
+  }, [formatMessage])

38-38: Move hardcoded URL to constants

The URL '/styrkjatorg/styrkir' should be moved to a constants file for better maintainability.

+const ROUTES = {
+  GRANTS_DASHBOARD: '/styrkjatorg/styrkir'
+} as const
+
-        <LinkV2 href={'/styrkjatorg/styrkir'}>
+        <LinkV2 href={ROUTES.GRANTS_DASHBOARD}>

64-66: Simplify null coalescing with nullish coalescing operator

The current implementation could be simplified using the nullish coalescing operator.

-          institution={
-            grant.fund?.parentOrganization.title ??
-            formatMessage(m.single.unknownInstitution)
-          }
+          institution={grant.fund?.parentOrganization.title ?? formatMessage(m.single.unknownInstitution)}

39-50: Extract button props for reusability

Consider extracting the common button props to a constant for reusability across the application.

+const BACK_BUTTON_PROPS = {
+  preTextIcon: "arrowBack" as const,
+  preTextIconType: "filled" as const,
+  size: "small" as const,
+  type: "button" as const,
+  variant: "text" as const,
+  truncate: true,
+  as: "span" as const,
+  unfocusable: true,
+} as const;

-          <Button
-            preTextIcon="arrowBack"
-            preTextIconType="filled"
-            size="small"
-            type="button"
-            variant="text"
-            truncate
-            as="span"
-            unfocusable
-          >
+          <Button {...BACK_BUTTON_PROPS}>
apps/web/screens/Grants/Grant/GrantSidebar/ExtraPanel.tsx (1)

15-71: Consider enhancing error handling and accessibility

The component handles null checks well but could benefit from:

  1. URL validation before rendering links
  2. Aria labels for better screen reader support
  3. Loading states for async resources

Consider adding these enhancements:

 <LinkV2
   newTab
   key={link.id}
   href={link.url}
+  aria-label={`Support link for ${link.text}`}
   underlineVisibility="hover"
 >
apps/web/screens/Grants/Grant/GrantSidebar/DetailPanel.tsx (1)

21-114: Consider adding error boundary and loading states

The component could benefit from error handling and loading states for better user experience.

  1. Wrap the component with an error boundary
  2. Add loading states for async data
  3. Handle edge cases when grant data is incomplete

Would you like me to provide an example implementation?

apps/web/screens/Grants/Grant/Grant.tsx (3)

117-138: Enhance type safety for ActionCard props

Consider creating a dedicated type for the ActionCard's cta configuration to improve maintainability and type safety.

+type ActionCardCTA = {
+  disabled: boolean
+  size: 'small'
+  label: string
+  onClick: () => void
+  icon: 'open'
+  iconType: 'outline'
+}

 <ActionCard
   heading={grant.name}
   text={status
     ? generateStatusTag(status.applicationStatus, formatMessage)?.label +
       (status.deadlineStatus ? ' / ' + status.deadlineStatus : '')
     : ''}
   backgroundColor="blue"
-  cta={{
+  cta={({
     disabled:
       status?.applicationStatus === 'closed' ||
       status?.applicationStatus === 'unknown',
     size: 'small',
     label: grant.applicationButtonLabel ?? formatMessage(m.single.apply),
     onClick: () => router.push(grant.applicationUrl?.slug ?? ''),
     icon: 'open',
     iconType: 'outline',
-  }}
+  } as ActionCardCTA)}

193-206: Consider grouping mobile-specific panels

The mobile-specific panels (ExtraPanel and InstitutionPanel) could be grouped into a single component to improve maintainability and reduce the number of Hidden components.

+const MobilePanels: React.FC<{ grant: Grant; locale: Locale }> = ({ grant, locale }) => {
+  const { formatMessage } = useIntl()
+  return (
+    <>
+      <ExtraPanel grant={grant} />
+      <InstitutionPanel
+        institutionTitle={formatMessage(m.single.provider)}
+        institution={
+          grant.fund?.parentOrganization.title ??
+          formatMessage(m.single.unknownInstitution)
+        }
+        img={grant.fund?.parentOrganization.logo?.url}
+        locale={locale}
+      />
+    </>
+  )
+}

-<Hidden above="md">
-  <ExtraPanel grant={grant} />
-</Hidden>
-<Hidden above="md">
-  <InstitutionPanel
-    institutionTitle={formatMessage(m.single.provider)}
-    institution={
-      grant.fund?.parentOrganization.title ??
-      formatMessage(m.single.unknownInstitution)
-    }
-    img={grant.fund?.parentOrganization.logo?.url}
-    locale={locale}
-  />
-</Hidden>
+<Hidden above="md">
+  <MobilePanels grant={grant} locale={locale} />
+</Hidden>

Line range hint 81-83: Enhance error handling with specific messages

Consider providing more specific feedback when the grant is not found, rather than returning null.

 if (!grant) {
-  return null
+  return (
+    <Box padding={4}>
+      <Text variant="h1">{formatMessage(m.errors.grantNotFound)}</Text>
+      <Text marginTop={2}>{formatMessage(m.errors.grantNotFoundDescription)}</Text>
+    </Box>
+  )
 }
📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between 62ccd49 and 0494ba9.

📒 Files selected for processing (10)
  • apps/web/screens/Grants/Grant/Grant.css.ts (1 hunks)
  • apps/web/screens/Grants/Grant/Grant.tsx (6 hunks)
  • apps/web/screens/Grants/Grant/GrantSidebar.tsx (0 hunks)
  • apps/web/screens/Grants/Grant/GrantSidebar/DetailPanel.tsx (1 hunks)
  • apps/web/screens/Grants/Grant/GrantSidebar/ExtraPanel.tsx (1 hunks)
  • apps/web/screens/Grants/Grant/GrantSidebar/GrantSidebar.tsx (1 hunks)
  • apps/web/screens/Grants/Grant/GrantSidebar/PanelLine.tsx (1 hunks)
  • apps/web/screens/Grants/messages.ts (2 hunks)
  • apps/web/screens/Grants/utils.ts (1 hunks)
  • libs/island-ui/core/src/lib/Breadcrumbs/Breadcrumbs.tsx (1 hunks)
💤 Files with no reviewable changes (1)
  • apps/web/screens/Grants/Grant/GrantSidebar.tsx
🧰 Additional context used
📓 Path-based instructions (9)
apps/web/screens/Grants/Grant/GrantSidebar/PanelLine.tsx (1)

Pattern apps/**/*: "Confirm that the code adheres to the following:

  • NextJS best practices, including file structure, API routes, and static generation methods.
  • Efficient state management and server-side rendering techniques.
  • Optimal use of TypeScript for component and utility type safety."
apps/web/screens/Grants/Grant/Grant.css.ts (1)

Pattern apps/**/*: "Confirm that the code adheres to the following:

  • NextJS best practices, including file structure, API routes, and static generation methods.
  • Efficient state management and server-side rendering techniques.
  • Optimal use of TypeScript for component and utility type safety."
libs/island-ui/core/src/lib/Breadcrumbs/Breadcrumbs.tsx (1)

Pattern libs/**/*: "Confirm that the code adheres to the following:

  • Reusability of components and hooks across different NextJS apps.
  • TypeScript usage for defining props and exporting types.
  • Effective tree-shaking and bundling practices."
apps/web/screens/Grants/messages.ts (1)

Pattern apps/**/*: "Confirm that the code adheres to the following:

  • NextJS best practices, including file structure, API routes, and static generation methods.
  • Efficient state management and server-side rendering techniques.
  • Optimal use of TypeScript for component and utility type safety."
apps/web/screens/Grants/utils.ts (1)

Pattern apps/**/*: "Confirm that the code adheres to the following:

  • NextJS best practices, including file structure, API routes, and static generation methods.
  • Efficient state management and server-side rendering techniques.
  • Optimal use of TypeScript for component and utility type safety."
apps/web/screens/Grants/Grant/GrantSidebar/ExtraPanel.tsx (1)

Pattern apps/**/*: "Confirm that the code adheres to the following:

  • NextJS best practices, including file structure, API routes, and static generation methods.
  • Efficient state management and server-side rendering techniques.
  • Optimal use of TypeScript for component and utility type safety."
apps/web/screens/Grants/Grant/GrantSidebar/GrantSidebar.tsx (1)

Pattern apps/**/*: "Confirm that the code adheres to the following:

  • NextJS best practices, including file structure, API routes, and static generation methods.
  • Efficient state management and server-side rendering techniques.
  • Optimal use of TypeScript for component and utility type safety."
apps/web/screens/Grants/Grant/GrantSidebar/DetailPanel.tsx (1)

Pattern apps/**/*: "Confirm that the code adheres to the following:

  • NextJS best practices, including file structure, API routes, and static generation methods.
  • Efficient state management and server-side rendering techniques.
  • Optimal use of TypeScript for component and utility type safety."
apps/web/screens/Grants/Grant/Grant.tsx (1)

Pattern apps/**/*: "Confirm that the code adheres to the following:

  • NextJS best practices, including file structure, API routes, and static generation methods.
  • Efficient state management and server-side rendering techniques.
  • Optimal use of TypeScript for component and utility type safety."
🔇 Additional comments (5)
apps/web/screens/Grants/messages.ts (2)

9-12: LGTM: New navigation message follows conventions.

The new goBack message is well-structured and follows the established naming conventions for internationalization keys.


89-89: Verify the message change impact across components.

The simplified message removes "og með" from the deadline text. While this makes the message more concise, we should verify that this change doesn't affect the semantic meaning in components using this message.

✅ Verification successful

Message change is safe to implement

The verification shows that the message is used in a conditional context where applicationWasOpenToAndWith is only selected when the date contains a time part. The removal of "og með" from the message is consistent with this logic, as it's used to display a simple deadline format. The change maintains the semantic meaning while making the text more concise.

  • The message is only referenced in utils.ts where it's properly handled based on the date format
  • No direct usage of this message was found in the SearchResults components
  • The change aligns with other similar deadline messages in the codebase
🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Find components using the applicationWasOpenToAndWith message

# Search for direct message usage
rg "applicationWasOpenToAndWith" --type ts --type tsx

# Search for components that might format or display application deadlines
ast-grep --pattern 'defaultMessage: $msg' apps/web/screens/Grants

Length of output: 149


Script:

#!/bin/bash
# Search for direct message usage with correct file type
rg "applicationWasOpenToAndWith" -t ts

# Search for components that might format or display application deadlines
# First, find all message definitions in the Grants directory
rg "defaultMessage.*Frestur" -t ts

# Look for imports of messages.ts to track usage
rg -l "from.*messages" apps/web/screens/Grants/

Length of output: 1556


Script:

#!/bin/bash
# Let's check the actual usage context in utils.ts
rg -B 3 -A 3 "applicationWasOpenToAndWith" apps/web/screens/Grants/utils.ts

# Check the content around the message usage in components
rg -B 3 -A 3 "Frestur.*til" apps/web/screens/Grants/SearchResults/

Length of output: 384

libs/island-ui/core/src/lib/Breadcrumbs/Breadcrumbs.tsx (1)

41-41: LGTM! Good improvement for mobile responsiveness

Adding flexWrap: 'wrap' is a good solution for handling long breadcrumbs on mobile devices, aligning well with the PR objectives.

Let's verify this doesn't affect existing implementations:

✅ Verification successful

Let me check the CSS files to ensure there are no conflicting styles that might affect the flex-wrap property.


Verified: The flexWrap addition is safe and won't conflict with existing styles

After reviewing the CSS files, there are no conflicting styles that would interfere with the flexWrap: 'wrap' property. The CSS files only define color schemes, focus states, and basic layout properties like margins and display types. The flex-wrap property will work as intended for improving mobile responsiveness.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Search for custom styling that might conflict with flex-wrap
rg -g '*.{ts,tsx,css}' -A 3 'Breadcrumbs.*style|Breadcrumbs.*css'

Length of output: 1623


Script:

#!/bin/bash
# Check the content of all Breadcrumbs CSS files
fd "Breadcrumbs.css" --exec cat {}

Length of output: 3087

apps/web/screens/Grants/Grant/Grant.tsx (2)

75-78: Good use of useMemo for status computation

The memoization of status parsing prevents unnecessary recomputation when unrelated props change.


113-115: Verify mobile/desktop breakpoint behavior

The component uses different layouts for mobile (<sm) and desktop (>md) views. Please verify:

  1. The behavior at exactly the 'sm' and 'md' breakpoints
  2. That no content is hidden at both breakpoints simultaneously
  3. That no content is duplicated across breakpoints

Also applies to: 116-139

Copy link
Member

@thorkellmani thorkellmani left a comment

Choose a reason for hiding this comment

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

Can you maybe fix the icon scaling issue in this one?

Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

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

Actionable comments posted: 0

🧹 Nitpick comments (2)
libs/island-ui/core/src/lib/InfoCardGrid/InfoCard.css.ts (1)

22-23: Consider removing empty style object if only used for targeting SVGs.

The empty style object iconBox appears to be used solely as a selector for targeting SVG elements. Consider using a more direct approach or combining the styles.

-export const iconBox = style({})
-
-globalStyle(`${iconBox} > svg`, {
-  minWidth: 24,
-})
+export const iconBox = style({
+  '& > svg': {
+    minWidth: 24,
+  },
+})
libs/island-ui/core/src/lib/InfoCardGrid/DetailedInfoCard.tsx (1)

Line range hint 25-25: Consider extracting magic number to a named constant.

The limit of 5 detail lines appears as a magic number in both the comment and implementation. Consider extracting it to a named constant for better maintainability.

+const MAX_DETAIL_LINES = 5;
+
 export type DetailedProps = BaseProps & {
   logo?: string
   logoAlt?: string
   subEyebrow?: string
-  //max 5 lines
+  //max MAX_DETAIL_LINES lines
   detailLines?: Array<{
     icon: IconMapIcon
     text: string
   }>
   tags?: Array<ActionCardProps['tag']>
 }

 // ... later in the code ...
-          {detailLines?.slice(0, 5).map((d, index) => (
+          {detailLines?.slice(0, MAX_DETAIL_LINES).map((d, index) => (

Also applies to: 69-69

📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between eabea45 and eb57c0f.

📒 Files selected for processing (2)
  • libs/island-ui/core/src/lib/InfoCardGrid/DetailedInfoCard.tsx (2 hunks)
  • libs/island-ui/core/src/lib/InfoCardGrid/InfoCard.css.ts (2 hunks)
🧰 Additional context used
📓 Path-based instructions (2)
libs/island-ui/core/src/lib/InfoCardGrid/InfoCard.css.ts (1)

Pattern libs/**/*: "Confirm that the code adheres to the following:

  • Reusability of components and hooks across different NextJS apps.
  • TypeScript usage for defining props and exporting types.
  • Effective tree-shaking and bundling practices."
libs/island-ui/core/src/lib/InfoCardGrid/DetailedInfoCard.tsx (1)

Pattern libs/**/*: "Confirm that the code adheres to the following:

  • Reusability of components and hooks across different NextJS apps.
  • TypeScript usage for defining props and exporting types.
  • Effective tree-shaking and bundling practices."
🔇 Additional comments (2)
libs/island-ui/core/src/lib/InfoCardGrid/InfoCard.css.ts (1)

24-26: Review mobile responsiveness of fixed SVG width.

The hard-coded minWidth: 24 for SVGs might affect the component's appearance on smaller screens. Consider using relative units or adding responsive breakpoints.

✅ Verification successful

Fixed SVG width is appropriate for this use case

The minWidth: 24 for SVGs in the InfoCard component is actually a reasonable choice:

  • The component already has responsive layout handling through its parent grid system, as seen in the judicial system implementation.
  • The 24px minimum width ensures icons maintain consistent and readable dimensions while allowing them to scale larger if needed.
  • This is a common practice for icon sizing in design systems to maintain visual consistency.

The current implementation provides a good balance between consistency and flexibility, and doesn't require modification for mobile responsiveness.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Check for responsive width implementations in other icon-related styles
rg -l "minWidth.*px" --type css

Length of output: 33


Script:

#!/bin/bash
# Let's check for any SVG-related styles and responsive patterns in the component
rg -g "*.ts" -g "*.tsx" "minWidth.*(?:px|rem|em|vw)" -A 2

# Also check for any media query implementations in the same file
rg -g "InfoCard.css.ts" "media|screen|@media"

# Look for other SVG styling patterns in the codebase
ast-grep --pattern 'globalStyle($_, { $$$minWidth$$$})'

Length of output: 12639


Script:

#!/bin/bash
# Let's check the specific InfoCard component and its responsive implementations
rg -g "InfoCard.css.ts" "(?:minWidth|width)" -A 2

# Check for any SVG-specific styling patterns in the same component
rg -g "InfoCard.css.ts" "svg|icon" -B 2 -A 2

Length of output: 1299

libs/island-ui/core/src/lib/InfoCardGrid/DetailedInfoCard.tsx (1)

18-18: LGTM! Style implementation follows best practices.

The implementation:

  • Uses TypeScript effectively for type safety
  • Follows modular styling approach
  • Maintains component reusability

Also applies to: 70-70

@disaerna
Copy link
Member Author

Can you maybe fix the icon scaling issue in this one?

Yes fixed @thorkellmani

@disaerna disaerna added the deprecated:automerge (Disabled) Merge this PR as soon as all checks pass label Dec 20, 2024
@disaerna disaerna removed the request for review from RunarVestmann December 20, 2024 10:21
Copy link
Member

@thorkellmani thorkellmani left a comment

Choose a reason for hiding this comment

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

LGTM

@disaerna disaerna removed the deploy-feature Deploys features to dev label Dec 20, 2024
@kodiakhq kodiakhq bot merged commit 95f602a into main Dec 20, 2024
126 checks passed
@kodiakhq kodiakhq bot deleted the feature/web-grants-apply-cards branch December 20, 2024 10:52
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
deprecated:automerge (Disabled) Merge this PR as soon as all checks pass
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants