Skip to content

Commit

Permalink
chore(react): merge commit
Browse files Browse the repository at this point in the history
  • Loading branch information
savindi7 committed Feb 14, 2023
2 parents 4a7facb + 8e5d523 commit c786a2a
Show file tree
Hide file tree
Showing 19 changed files with 312 additions and 201 deletions.
6 changes: 3 additions & 3 deletions packages/react/.storybook/story-config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@ enum StorybookCategories {
export type Stories =
| 'AppBar'
| 'Avatar'
| 'ButtonDropdownMenu'
| 'UserDropdownMenu'
| 'Header'
| 'Box'
| 'Button'
Expand Down Expand Up @@ -104,8 +104,8 @@ const StoryConfig: StorybookConfig = {
Button: {
hierarchy: `${StorybookCategories.Inputs}/Button`,
},
ButtonDropdownMenu: {
hierarchy: `${StorybookCategories.Navigation}/Button Dropdown Menu`,
UserDropdownMenu: {
hierarchy: `${StorybookCategories.Navigation}/User Dropdown Menu`,
},
ColorModeToggle: {
hierarchy: `${StorybookCategories.Theme}/Color Mode Toggle`,
Expand Down
12 changes: 12 additions & 0 deletions packages/react/src/components/AppBar/AppBar.stories.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ export const Template = args => <AppBar {...args} />;

- [Overview](#overview)
- [Props](#props)
- [Usage](#usage)

## Overview

Expand All @@ -33,3 +34,14 @@ The top App bar provides content and actions related to the current screen. It's
## Props

<ArgsTable story="Overview" />

## Usage

Import and use the `AppBar` component in your components as follows.

<Source
language="jsx"
dark
format
code={dedent`import AppBar from '@oxygen-ui/react/AppBar';\n`}
/>
12 changes: 11 additions & 1 deletion packages/react/src/components/Avatar/Avatar.stories.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,6 @@ export const Template = args => <Avatar {...args} />;
- [Overview](#overview)
- [Props](#props)
- [Usage](#usage)
- [Variants](#variants)

## Overview

Expand All @@ -35,3 +34,14 @@ The Avatar can be used to mainly display profile pictures of users and can be us
## Props

<ArgsTable story="Overview" />

## Usage

Import and use the `Avatar` component in your components as follows.

<Source
language="jsx"
dark
format
code={dedent`import Avatar from '@oxygen-ui/react/Avatar';\n`}
/>
32 changes: 32 additions & 0 deletions packages/react/src/components/Avatar/__tests__/Avatar.test.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
/**
* Copyright (c) 2023, WSO2 LLC. (https://www.wso2.com). All Rights Reserved.
*
* WSO2 LLC. licenses this file to you under the Apache License,
* Version 2.0 (the "License"); you may not use this file except
* in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/

import {render} from '@unit-testing';
import Avatar from '../Avatar';

describe('Avatar', () => {
it('should render successfully', () => {
const {baseElement} = render(<Avatar />);
expect(baseElement).toBeTruthy();
});

it('should match the snapshot', () => {
const {baseElement} = render(<Avatar />);
expect(baseElement).toMatchSnapshot();
});
});
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
// Jest Snapshot v1, https://goo.gl/fbAQLP

exports[`Avatar should match the snapshot 1`] = `
<body>
<div>
<div
class="MuiAvatar-root MuiAvatar-circular MuiAvatar-colorDefault oxygen-ui-avatar css-woe6xp-MuiAvatar-root"
>
<svg
aria-hidden="true"
class="MuiSvgIcon-root MuiSvgIcon-fontSizeMedium MuiAvatar-fallback css-10mi8st-MuiSvgIcon-root-MuiAvatar-fallback"
data-testid="PersonIcon"
focusable="false"
viewBox="0 0 24 24"
>
<path
d="M12 12c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm0 2c-2.67 0-8 1.34-8 4v2h16v-2c0-2.66-5.33-4-8-4z"
/>
</svg>
</div>
</div>
</body>
`;

This file was deleted.

This file was deleted.

12 changes: 11 additions & 1 deletion packages/react/src/components/Header/Header.stories.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,6 @@ export const Template = args => <Header {...args} />;
- [Overview](#overview)
- [Props](#props)
- [Usage](#usage)
- [Variants](#variants)

## Overview

Expand Down Expand Up @@ -75,3 +74,14 @@ The Header provides content and actions related to the current screen. It's used
## Props

<ArgsTable story="Overview" />

## Usage

Import and use the `Header` component in your components as follows.

<Source
language="jsx"
dark
format
code={dedent`import Header from '@oxygen-ui/react/Header';\n`}
/>
54 changes: 27 additions & 27 deletions packages/react/src/components/Header/Header.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@
* under the License.
*/

import {Box, IconButton, Toolbar, Typography, useMediaQuery} from '@mui/material';
import {useMediaQuery} from '@mui/material';
import {useColorScheme, useTheme, Theme} from '@mui/material/styles';
import {Mode} from '@mui/system/cssVars/useCurrentColorScheme';
import {ChevronDownIcon, HamburgerIcon, PowerIcon} from '@oxygen-ui/react-icons';
Expand All @@ -27,13 +27,14 @@ import {composeComponentDisplayName} from '../../utils';
import './header.scss';
import AppBar, {AppBarProps} from '../AppBar';
import Avatar from '../Avatar';
import Box from '../Box';
import Button, {ButtonProps} from '../Button';
import ButtonDropdownMenu, {ModeListInterface} from '../ButtonDropdownMenu';
import IconButton from '../IconButton';
import Link from '../Link';
import Toolbar from '../Toolbar';
import Typography from '../Typography';
import UserDropdownMenu, {ModeList, UserTemplate} from '../UserDropdownMenu';

/**
* Interface for the Header component props.
*/
export interface HeaderProps extends AppBarProps {
/**
* Brand information.
Expand All @@ -50,7 +51,7 @@ export interface HeaderProps extends AppBarProps {
/**
* List of modes.
*/
modes?: ModeListInterface[];
modes?: ModeList[];
/**
* Function to handle left navigation bar button toggle.
*/
Expand All @@ -61,32 +62,32 @@ export interface HeaderProps extends AppBarProps {
user?: UserTemplate;
}

/**
* Interface for the brand template.
*/
export interface BrandTemplate {
/**
* Logo for the brand template.
*/
logo?: {
/**
* Desktop logo for the brand template.
*/
desktop?: ReactNode;
/**
* Mobile logo for the brand template.
*/
mobile?: ReactNode;
};
/**
* Function on clicking on the brand logo and name.
*/
onClick?: () => void;
/**
* Title of the brand, portal name or company.
*/
title?: ReactNode;
}

/**
* Interface for the logged user template.
*/
export interface UserTemplate {
email?: string;
image?: string;
name?: string;
}

const COMPONENT_NAME: string = 'Header';

/**
* Header component.
*/
const Header: FC<HeaderProps> & WithWrapperProps = (props: HeaderProps): ReactElement => {
const {className, children, isLeftNavigationActive, brand, user, links, modes, onLeftNavigationTrigger, ...rest} =
props;
Expand Down Expand Up @@ -114,7 +115,7 @@ const Header: FC<HeaderProps> & WithWrapperProps = (props: HeaderProps): ReactEl
variant="outlined"
elevation={0}
className={classes}
role="navigation"
role="banner"
{...rest}
>
<Toolbar>
Expand All @@ -126,16 +127,15 @@ const Header: FC<HeaderProps> & WithWrapperProps = (props: HeaderProps): ReactEl
{brand && (
<Box
tabIndex={0}
component={brand.onClick ? Link : Box}
component={Boolean(brand.onClick) && Link}
className={clsx('logo-box', {
'with-link': Boolean(brand.onClick),
})}
onClick={brand.onClick}
underline="none"
color="inherit"
>
<Box className="logo">{isMobile ? brand.logo.mobile ?? brand.logo.desktop : brand.logo.desktop}</Box>
<Typography variant="h6" component="h1" className="portal-name">
<Typography variant="h1" className="portal-name">
{brand.title}
</Typography>
</Box>
Expand Down Expand Up @@ -165,9 +165,9 @@ const Header: FC<HeaderProps> & WithWrapperProps = (props: HeaderProps): ReactEl
</>
</Box>
<Box className="dropdown-menu">
<ButtonDropdownMenu
<UserDropdownMenu
user={user}
buttonProps={{
triggerOptions={{
children: user?.name,
color: 'inherit',
endIcon: <ChevronDownIcon />,
Expand Down
Loading

0 comments on commit c786a2a

Please sign in to comment.