DIGIT UI Core React Components
Migration guide to aid users in shifting from the "react-components" package to the "components-core" package
Topics covered:
Overview
This document details the essential modifications needed in the modules for smooth integration of components from the "components-core" package. It offers precise guidelines on utilizing FormComposerV2 and InboxSearchComposer, along with updates made in the configs.
In the components-core package, several enhancements have been implemented to improve code clarity and address issues related to pixel inconsistencies. Previously, there were challenges associated with pixel-based sizing, leading to inconsistencies across different devices and screen resolutions. To mitigate this, the codebase has been updated to utilize rems as the primary unit of measurement. This transition to rems offers several advantages over pixels, including improved scalability and responsiveness across various viewport sizes.
Adopting rems ensures the components' styling is more consistent and adaptable, providing a seamless user experience across different platforms and devices.
Furthermore, TextInput, TextArea, Radio, Button, Checkbox, Toggle, Dropdown, Multiselectdropdown, InfoCard, and Toast offer different variants. Adding variants for these components makes them more flexible, serving a wider range of purposes and meeting different design needs effectively.
These are some of the updates made in the components-core package.
Text
Date
Time
Geolocation
Numeric
Prefix
Suffix
Password
Search
Default
Filled
Disabled
NonEditable
Focus
Error
Label
Character Count
Inner Label
Info
Help Text/ Description
Default
Filled
Disabled
NonEditable
Focus
Error
Label
Character Count
Inner Label
Info
Help Text/ Description
resizeSmart
Default
Nested
Tree select
Profile
Profile with nested text
Nested Text
Default
Disabled
Selected
Interactions
Default
Nested
Tree Multiselect
Nested Text Multiselect
Default
Disabled
Selected
Interactions
Install
To install:
Add the dependency in the frontend/micro-ui/web/package.json
Apply
Syntax for importing any components:
Syntax for importing FormComposerV2:
Modify Project Module
In the micro-ui/web/micro-ui-internals/packages/modules/Project/src/pages/employee/CreateProject/CreateProjectForm.js:
import {FormComposerV2} from "@egovernenets/digit-ui-components-core"
In the micro-ui/web/micro-ui-internals/packages/modules/Project/package.json :
Add “@egovernments/digit-ui-components-core”:”0.0.1” in the dependencies.
And when you import any component the syntax for the import statement is:
In the micro-ui/web/micro-ui-internals/packages/modules/Project/src/pages/employee/ProjectWMSSearch:
Conclusion
Verify the components in the sample module:
Sample module Integrated with new components
These are some of the modifications that need to be done in the modules to use the components from the components-core package.
Last updated