Blu Frame UI Building Blocks provides a collection of customizable React components to speed up your web development process. 🎨
If you are using yarn
:
yarn add @bluframe/blublocks
And if you are using npm
:
npm i @bluframe/blublocks
You can import the components individually:
import Button from "@bluframe/blublocks/Button"
Or import multiple components at once:
import { Button, InputText } from "@bluframe/blublocks"
This is a Badge component, often used to highlight a certain feature or aspect of a product or a piece of information.
-
className
: (optional) string - The class name for the badge wrapper. -
color
: (optional) $Keys - Defaults to"primary"
. The color of the badge. Colors are defined in our Palette type. -
label
: string - The text to display on the badge.
import Badge from "@bluframe/blublocks/Badge"
function App() {
return <Badge className="custom-class" color="secondary" label="Apples" />
}
A simple button component that can be styled to all needs.
-
bold
: (optional) boolean - Iftrue
, the button label will be displayed in bold. Defaults tofalse
. -
className
: (optional) string - The class name for the button wrapper. -
disabled
: (optional) boolean - Iftrue
, the button will be displayed in a disabled state. Defaults tofalse
. -
expanded
: (optional) boolean - Iftrue
, the button will expand to fill its container's width. Defaults tofalse
. -
iconEnd
: (optional) React$Node - The icon to display at the end of the button label. 🔚 -
iconStart
: (optional) React$Node - The icon to display at the beginning of the button label. 🔜 -
icon
: (optional) React$Node - The icon to display wheniconOnly
istrue
. 🎯 -
iconOnly
: (optional) boolean - Iftrue
, the button will only display an icon. Defaults tofalse
. -
label
: string - The label for the button. 🏷️ -
loading
: (optional) boolean - Iftrue
, a loading spinner will be displayed at the end of the button. Defaults tofalse
. -
noHoverHighlight
: (optional) boolean - Iftrue
, the button will not have a hover effect. Defaults tofalse
. -
onClick
: (optional) function - The callback that is fired when the button is clicked. 🖱️ -
outlined
: (optional) boolean - Iftrue
, the button will be displayed with an outlined style. Defaults tofalse
. -
padded
: (optional) boolean - Iftrue
, the button will have extra padding. Defaults tofalse
. -
secondary
: (optional) boolean - Iftrue
, the button will be displayed with a secondary color. Defaults tofalse
. -
small
: (optional) boolean - Iftrue
, the button will be displayed in a smaller size. Defaults tofalse
. -
transparent
: (optional) boolean - Iftrue
, the button will be displayed with a transparent background. Defaults tofalse
. -
type
: (optional) string - The type attribute for the button element. Defaults to"button"
.
import Button from "@bluframe/blublocks/Button"
function App() {
const handleClick = () => {
console.log("Button clicked")
}
return (
<Button
bold={true}
buttonType="button"
disabled={false}
expanded={false}
iconEnd={<Icon name="IoArrowForward" />}
iconStart={<Icon name="IoArrowBack" />}
label="Click me"
loading={false}
noHoverHighlight={false}
onClick={handleClick}
outlined={false}
padded={true}
secondary={false}
small={false}
/>
)
}
- InputText
- Select
- Radio
- RadioGroup
- Checkbox
- Toggle
- TextArea
All our input components support ARIA attributes. 💯
A customizable input text component that supports ARIA attributes.
-
className
: (optional) string - The class name for the input text wrapper. -
defaultValue
: (optional) string - The default value attribute for the input element. 📝 -
error
: (optional) boolean - Iftrue
, the input text field will be displayed in an error state. Defaults tofalse
.⚠️ -
helperText
: (optional) string - The helper text to display below the input text field. If the 'error' prop istrue
, this text will be displayed in the error color. 🆘 -
inputId
: (optional) string - The id attribute for the input element. 🆔 -
isFullBorder
: (optional) boolean - Iftrue
, the input text field will have a full border instead of just a bottom border. Defaults tofalse
. -
label
: string - The label for the input text. 🏷️ -
name
: string - The name attribute for the input element. -
onBlur
: (optional) function - The callback that is fired when the input text loses focus. 💨 -
onChange
: function - The callback that is fired when the input text value changes. 🔀 -
required
: (optional) boolean - Iftrue
, the input will have the "required" attribute. Defaults tofalse
. -
step
: (optional) string - The step attribute for the input element. This is applicable when the input type isnumber
. 📊 -
type
: (optional) string - The type attribute for the input element. Defaults totext
. -
value
: string - The value of the input text.
import InputText from "@bluframe/blublocks/InputText"
function App() {
const [value, setValue] = useState("")
const [error, setError] = useState(false)
const handleBlur = (event) => {
if (event.target.value === "") {
setError(true)
} else {
setError(false)
}
}
const handleChange = (event) => {
setValue(event.target.value)
}
return (
<InputText
error={error}
helperText={error ? "This field is required" : ""}
inputId="name-input"
label="Name"
name="name"
required
onBlur={handleBlur}
onChange={handleChange}
value={value}
/>
)
}
A customizable select component that supports ARIA attributes, automatically selects the first option if no selected option is provided, and provides a dropdown with a list of options.
-
className
: (optional) string - The class name for the select wrapper. -
defaultValue
: (optional) string - The default value of the select component. 📝 -
label
: React$Node - The label for the select. 🏷️ -
name
: string - The name attribute for the input element. -
onBlur
: (optional) function - The callback that is fired when the select loses focus. 💨 -
onChange
: function - The callback that is fired when an option is selected. -
options
: Option[] - An array of options for the select. Each option should have alabel
and avalue
. -
placeholder
: (optional) string - The placeholder text to display when no option is selected. 💭 -
value
: (optional) string - The currently selected value in the select. If not provided, the first option will be selected by default.
import Select from "@bluframe/blublocks/Select"
function App() {
const [selectedValue, setSelectedValue] = useState(null)
const options = [
{
label: "Apple",
value: "apple"
},
{
label: "Orange",
value: "orange"
}
// ... more options
]
const handleBlur = () => {
console.log("Select lost focus")
}
const handleChange = (newValue) => {
setSelectedValue(newValue)
}
return (
<Select
label="Fruit"
name="fruit"
onBlur={handleBlur}
onChange={handleChange}
options={options}
placeholder="Select a fruit"
value={selectedValue}
/>
)
}
A customizable radio component that supports ARIA attributes. 📻
-
inputId
: (optional) string - The id attribute for the input element. 🆔 -
isChecked
: boolean - Determines whether the radio is checked or not. ✅ -
label
: React$Node - The label for the radio. 🏷️ -
name
: string - The name attribute for the input element. -
onChange
: function - The callback that is fired when the radio is clicked. 🖱️ -
value
: OptionValue - The value of the radio.
import Radio from "@bluframe/blublocks/Radio"
function App() {
const [selectedValue, setSelectedValue] = useState("apple")
const handleChange = (newValue) => {
setSelectedValue(newValue)
}
return (
<>
<Radio
inputId="apple-radio"
isChecked={selectedValue === "apple"}
label="Apple"
name="fruit"
onChange={handleChange}
value="apple"
/>
<Radio
inputId="orange-radio"
isChecked={selectedValue === "orange"}
label="Orange"
name="fruit"
onChange={handleChange}
value="orange"
/>
</>
)
}
A customizable radio group component that supports ARIA attributes and automatically selects the first option if no selected option is provided. 🎛️
-
className
: (optional) string - The class name for the radio group wrapper. -
label
: React$Node - The label for the radio group. 🏷️ -
name
: string - The name attribute for the input elements. -
onChange
: function - The callback that is fired when a radio within the group is clicked. 🖱️ -
options
: Option[] - An array of options for the radio group. Each option should have alabel
and avalue
. -
selected
: (optional) OptionValue | null - The currently selected value in the radio group. If not provided, the first option will be selected by default.
import RadioGroup from "@bluframe/blublocks/RadioGroup"
function App() {
const [selectedValue, setSelectedValue] = useState(null)
const handleChange = (newValue) => {
setSelectedValue(newValue)
}
const options = [
{
label: "Apple",
value: "apple"
},
{
label: "Banana",
value: "banana"
}
]
return (
<RadioGroup
label="Select a fruit"
name="fruit"
onChange={handleChange}
options={options}
selected={selectedValue}
/>
)
}
A customizable checkbox component that supports ARIA attributes. ☑️
-
inputId
: (optional) string - The id attribute for the input element. 🆔 -
isChecked
: boolean - Determines whether the checkbox is checked or not. ✅ -
label
: React$Node - The label for the checkbox. 🏷️ -
name
: string - The name attribute for the input element. -
value
: OptionValue - The value of the checkbox. -
onChange
: function - The callback that is fired when the checkbox is clicked. 🖱️
import Checkbox from "@bluframe/blublocks/Checkbox"
function App() {
const [isChecked, setIsChecked] = useState(true)
const handleChange = (value) => {
setIsChecked(!isChecked)
}
return (
<Checkbox
inputId="apple-checkbox"
isChecked={isChecked}
label="Apple"
name="fruit"
value="apple"
onChange={handleChange}
/>
)
}
A customizable toggle switch component that supports ARIA attributes.
-
checked
: (optional) boolean - Determines whether the toggle is checked or not. Default tofalse
. -
disabled
: (optional) boolean - Iftrue
, the toggle will be displayed in a disabled state. Default tofalse
. -
defaultChecked
: (optional) boolean - Determines whether the toggle is checked by default. -
inputId
: (optional) string - The id attribute for the input element. 🆔 -
name
: string - The name attribute for the input element. -
onChange
: (optional) function - The callback that is fired when the toggle state changes. -
ref
: (optional) ForwardedRef - A forwarded ref for the input element.
import Toggle from "@bluframe/blublocks/Toggle"
function App() {
const handleChange = (checked) => {
console.log("Toggle state:", checked)
}
return (
<Toggle
checked={false}
disabled={false}
inputId="toggle-id"
name="toggle-name"
onChange={handleChange}
/>
)
}
The Toggle
component makes it simple to add a toggle switch to your application. It supports both controlled and uncontrolled states and is accessible via keyboard (Space key and Enter key). This component can be customized further by overriding its default styles using styled-components
or CSS classes.
A versatile TextArea component for those larger inputs. Supports customization and theming.
-
className
: (optional) string - The class name for the textarea wrapper. -
cols
: (optional) number - The visible width of the text control, in average character widths. Defaults to50
. -
defaultValue
: (optional) string - The default value of the textarea. -
inputId
: (optional) string - The id attribute for the textarea element. 🆔 -
label
: (optional) React$Node - The label for the textarea. -
labelId
: (optional) string - The id for the label element. -
name
: (required) string - The name attribute for the textarea element. -
onBlur
: (optional) function - The callback that is fired when the textarea loses focus. -
onChange
: (required) function - The callback that is fired when the content of the textarea changes. -
placeholder
: (optional) string - The placeholder text for the textarea. -
required
: (optional) boolean - Iftrue
, the textarea will be required. -
rows
: (optional) number - The number of visible text lines for the control. Defaults to10
. -
value
: (optional) string - The value of the textarea.
import TextArea from "@bluframe/blublocks/TextArea"
function App() {
const [content, setContent] = useState("")
const handleChange = (event) => {
setContent(event.target.value)
}
return (
<TextArea
inputId="my-textarea"
label="My Textarea"
name="myTextArea"
onChange={handleChange}
placeholder="Start typing..."
value={content}
/>
)
}
A secure and customizable login component.
-
isLoading
: (optional) boolean - Indicates if the login process is ongoing. Defaults tofalse
. -
name
: (optional) string - Displays a welcome message or heading above the login form. -
onSubmitLogin
: function - The callback function that is executed when the login form is submitted. It should handle the actual login logic, like API calls.
import { useState } from "react"
import Login from "@bluframe/blublocks/Login"
function App() {
const [isLoading, setIsLoading] = useState(false)
const handleSubmitLogin = ({ username, password }) => {
console.log(username, password)
setIsLoading(true)
// Here you can handle the login logic, e.g., making an API call.
setIsLoading(false)
}
return (
<Login
isLoading={isLoading}
name="Welcome to Our App"
onSubmitLogin={handleSubmitLogin}
/>
)
}
The Login
component makes it simple to add a login form to your application. It supports loading states and customization for a welcome message. This component requires you to handle the actual login logic in the onSubmitLogin
prop, where you receive the username and password entered by the user.
Like other components in the Blu Frame UI Building Blocks library, the Login
component can be customized in terms of styling and appearance. You can override the default styles using styled-components or CSS classes to match your application's branding and design requirements.
Beautiful and customizable typography components. ✍️
- H1
- H2
- H3
- H4
- H5
- H6
- Paragraph
- SubtitleH1
- SubtitleH2
- SubtitleH3
import H1 from "@bluframe/blublocks/Typography/H1"
import SubtitleH1 from "@bluframe/blublocks/Typography/SubtitleH1"
function App() {
return (
<>
<H1>This is a Heading</H1>
<SubtitleH1>This is a Subtitle</SubtitleH1>
</>
)
}
BluFrame UI Building Blocks makes it easy to customize the styling of the typography components according to your needs. You can override the default styles using styled-components and theming. 🎨
Here's an example of how to create a custom H1 component with your own styles:
// CustomH1.js
import styled from "styled-components"
import H1 from "@bluframe/blublocks/Typography/H1"
const CustomH1 = styled(H1)`
color: #ff0000;
font-family: "Comic Sans MS", cursive, sans-serif;
font-weight: 400;
`
export default CustomH1
And then you can use your custom H1 component in your app:
import CustomH1 from "./CustomH1"
function App() {
return <CustomH1>This is a custom Heading</CustomH1>
}
A versatile component that accepts markdown and beautifully displays it on your page. 📄
-
className
: (optional) string - The class name for the content wrapper. -
components
: (optional) ContentComponents - Custom components to override default markdown components. -
content
: string - The markdown content to be displayed. -
max
: (optional) number - The maximum number of characters to display from the content. Defaults toInfinity
. 📏 -
paragraphAs
: (optional) string - The HTML tag to use for rendering paragraphs. Defaults to"p"
. -
stripMarkdown
: (optional) boolean - Iftrue
, all markdown formatting will be stripped from the content. Defaults tofalse
.
import Content from "@bluframe/blublocks/Content"
function App() {
const markdownContent = `
# This is a heading
This is a paragraph with **bold** and *italic* text.
- This is a list item
- Another list item
`
return (
<Content
className="custom-class"
content={markdownContent}
max={100}
paragraphAs="div"
stripMarkdown={false}
/>
)
}
The Breadcrumbs
component is a navigation aid that helps users understand and navigate through a website. It typically shows the user's current location within the website's hierarchy and allows quick navigation back to previous sections.
-
LinkComponent
: (optional)React.ComponentType<{children: React.ReactNode; href: string}
- A custom link component -
className
: (optional)string
- The class name for the breadcrumbs wrapper. -
items
:Array<{ label: string, href?: string }>
- An array of breadcrumb items. Each item should have alabel
and may have anhref
for navigation.
import Breadcrumbs from "@bluframe/blublocks/Breadcrumbs"
function App() {
const breadcrumbItems = [
{ label: "Home", href: "/" },
{ label: "Category", href: "/category" },
{ label: "Subcategory", href: "/category/subcategory" },
{ label: "Current Page" }
]
return <Breadcrumbs items={breadcrumbItems} />
}
The Breadcrumbs
component accepts an array of items, where each item has a label
and optionally an href
. If an item has an href
, it will be rendered as a link. If not, it will be rendered as plain text.
A modal component to manage and display overlay content.
-
children
: React$Node - The content to display inside the modal. -
isOpen
: boolean - Determines whether the modal is open or not. -
onClose
: function - The callback that is fired when the modal is closed.
import Modal from "@bluframe/blublocks/Modal"
function App() {
const [isOpen, setIsOpen] = useState(false)
const handleOpen = () => setIsOpen(true)
const handleClose = () => setIsOpen(false)
return (
<div>
<button onClick={handleOpen}>Open Modal</button>
<Modal isOpen={isOpen} onClose={handleClose}>
<p>Modal Content!</p>
</Modal>
</div>
)
}
The FormModal
component is used to display modals with form content. It supports customizable children, and actions for submission and cancellation. The component also accepts props to control its state (e.g., disabled or loading).
-
cancelLabel
: (optional) string - The label for the cancel button. Defaults to"Cancel"
. -
children
: React.ReactNode - The content of the modal. Usually, this will include form fields and other elements. -
isDisabled
: (optional) boolean - Iftrue
, the submit button will be disabled. Defaults tofalse
. -
isLoading
: (optional) boolean - Iftrue
, the submit button will show a loading spinner and be disabled. Defaults tofalse
. -
onClose
: () => void - The callback that is fired when the cancel button is clicked. -
onSubmit
: FormEventHandler - The callback that is fired when the form is submitted. -
submitLabel
: (optional) string - The label for the submit button. Defaults to"Submit"
.
import FormModal from "@bluframe/blublocks/FormModal"
import InputText from "@bluframe/blublocks/InputText"
function App() {
const handleClose = () => {
console.log("Modal closed")
}
const handleSubmit = (event) => {
event.preventDefault()
console.log("Form submitted")
}
return (
<FormModal onClose={handleClose} onSubmit={handleSubmit}>
<InputText label="Name" name="name" />
</FormModal>
)
}
Our Bio component is a versatile, customizable block that allows you to display a biography section with ease. Perfect for about pages, team member profiles and more. 🚀
-
avatar
: (required) string | React$Node - A link to an avatar image or a React component to display as the avatar. -
description
: (required) string - A string containing the bio description. This description can include markdown format text. -
name
: (required) string - The name to be displayed. -
color
: (optional) string - A color definition for the bio content links.
First, import the Bio component from blublocks:
import Bio from "@bluframe/blublocks/Bio"
Use the Bio component in your app:
function App() {
return (
<Bio
avatar="https://somelinktoanimage.jpg"
description="This is my awesome bio!"
name="John Doe"
/>
)
}
The avatar prop can accept a URL string indicating the path to an image:
<Bio
avatar="https://somelinktoanimage.jpg"
description="This is my awesome bio!"
name="John Doe"
/>
Alternatively, the avatar prop can accept a React component:
import CustomAvatar from "./CustomAvatar"
;<Bio
avatar={<CustomAvatar />}
description="This is an awesome bio!"
name="John Doe"
/>
The description prop supports markdown formatting. Here's an example:
<Bio
avatar="https://somelinktoanimage.jpg"
description="This is my *awesome* bio! [Visit my website!](https://mywebsite.com)"
name="John Doe"
/>
This will render the description with italic text and a hyperlink to the website.
If you want to customize the appearance even further, you can use styled-components to override the styles. Here's an example how to create a custom Bio component with extra styles:
import styled from "styled-components"
import Bio from "@bluframe/blublocks/Bio"
const CustomBio = styled(Bio)`
font-family: "Comic Sans MS", cursive, sans-serif;
color: #ff0000;
`
function App() {
return (
<CustomBio
avatar="https://somelinktoanimage.jpg"
description="This is my awesome bio!"
name="John Doe"
/>
)
}
A Carousel component to display a collection of content in a sliding view.
-
children
: React.ReactNode - The slides to display within the carousel. -
className
: (optional) string - The class name for the carousel. -
slidesToShow
: (optional) number - The number of slides to show at a time. Defaults to1
. -
slidesToScroll
: (optional) number - The number of slides to scroll on each action. Defaults to1
.
import { useState } from "react"
import Carousel from "@bluframe/blublocks/Carousel"
function App() {
const slides = [
<img
key="1"
src="https://source.unsplash.com/random/200x200?sig=1"
alt="slide 1"
/>,
<img
key="2"
src="https://source.unsplash.com/random/200x200?sig=2"
alt="slide 2"
/>,
<img
key="3"
src="https://source.unsplash.com/random/200x200?sig=3"
alt="slide 3"
/>,
<img
key="4"
src="https://source.unsplash.com/random/200x200?sig=4"
alt="slide 4"
/>
]
return (
<Carousel slidesToShow={3} slidesToScroll={1}>
{slides}
</Carousel>
)
}
This will set up a Carousel component that shows 3 slides at a time and scrolls one slide upon each action. The children
prop is used to pass in the slides which can be any React node like images or custom components.
The Carousel
component is designed to be highly customizable. You can adjust the number of slides displayed at one time and how many slides to scroll with each action using the slidesToShow
and slidesToScroll
props respectively. Additionally, you can customize the appearance of the carousel by adding your own class names or by using styled-components to override the default styles.
Here's an example of how to create a custom styled Carousel:
import styled from "styled-components"
import Carousel from "@bluframe/blublocks/Carousel"
const CustomCarousel = styled(Carousel)`
background-color: #f8f9fa;
border-radius: 8px;
`
export default CustomCarousel
And then, use your custom Carousel in your app:
import CustomCarousel from "./CustomCarousel"
function App() {
const slides = [
<img
key="1"
src="https://source.unsplash.com/random/200x200?sig=1"
alt="slide 1"
/>,
<img
key="2"
src="https://source.unsplash.com/random/200x200?sig=2"
alt="slide 2"
/>,
<img
key="3"
src="https://source.unsplash.com/random/200x200?sig=3"
alt="slide 3"
/>,
<img
key="4"
src="https://source.unsplash.com/random/200x200?sig=4"
alt="slide 4"
/>
]
return (
<CustomCarousel slidesToShow={2} slidesToScroll={1}>
{slides}
</CustomCarousel>
)
}
A classic Hamburger component made with 100% CSS. 🍔
-
isMenuExpanded
: (optional) boolean - Determines whether the menu is expanded or not. Defaults tofalse
. -
menuId
: (optional) string - The id attribute for the menu that the Hamburger controls. 🆔 -
onClick
: (optional) function - The callback that is fired when the Hamburger is clicked. 🖱️
import Hamburger from "@bluframe/blublocks/Hamburger"
function App() {
const [isMenuExpanded, setIsMenuExpanded] = useState(false)
const handleHamburgerClick = () => {
setIsMenuExpanded(!isMenuExpanded)
}
return (
<Hamburger
isMenuExpanded={isMenuExpanded}
menuId="main-navigation"
onClick={handleHamburgerClick}
/>
)
}
We welcome contributions to improve Blu Frame UI Building Blocks! If you'd like to contribute, please follow these steps: 🤝
- Fork the repository. 🍴
- Create a new branch for your feature or bugfix. 🌿
- Make your changes and commit them to your branch. 📝
- Submit a pull request with a detailed description of your changes. 📬
Please ensure that your code follows our coding style and passes all tests. 🔎
Blu Frame UI Building Blocks is MIT licensed.