Skip to content

Commit

Permalink
Scaffolds SplitNavItem (#32870)
Browse files Browse the repository at this point in the history
  • Loading branch information
mltejera authored Sep 19, 2024
1 parent 8506c11 commit c189a92
Show file tree
Hide file tree
Showing 12 changed files with 206 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
{
"type": "minor",
"comment": "Scaffolds SplitNavItem",
"packageName": "@fluentui/react-nav-preview",
"email": "matejera@microsoft.com",
"dependentChangeType": "patch"
}
Original file line number Diff line number Diff line change
Expand Up @@ -381,6 +381,26 @@ export const renderNavSubItem_unstable: (state: NavSubItemState) => JSX.Element;
// @public
export const renderNavSubItemGroup_unstable: (state: NavSubItemGroupState) => JSX.Element | null;

// @public
export const renderSplitNavItem_unstable: (state: SplitNavItemState) => JSX.Element;

// @public
export const SplitNavItem: ForwardRefComponent<SplitNavItemProps>;

// @public (undocumented)
export const splitNavItemClassNames: SlotClassNames<SplitNavItemSlots>;

// @public
export type SplitNavItemProps = ComponentProps<SplitNavItemSlots> & {};

// @public (undocumented)
export type SplitNavItemSlots = {
root: Slot<'div'>;
};

// @public
export type SplitNavItemState = ComponentState<SplitNavItemSlots>;

// @public
export const useAppItem_unstable: (props: AppItemProps, ref: React_2.Ref<HTMLButtonElement | HTMLAnchorElement>) => AppItemState;

Expand Down Expand Up @@ -471,6 +491,12 @@ export const useNavSubItemGroupStyles_unstable: (state: NavSubItemGroupState) =>
// @public
export const useNavSubItemStyles_unstable: (state: NavSubItemState) => NavSubItemState;

// @public
export const useSplitNavItem_unstable: (props: SplitNavItemProps, ref: React_2.Ref<HTMLDivElement>) => SplitNavItemState;

// @public
export const useSplitNavItemStyles_unstable: (state: SplitNavItemState) => SplitNavItemState;

// (No @packageDocumentation comment for this package)

```
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
export * from './components/SplitNavItem/index';
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
import * as React from 'react';
import { render } from '@testing-library/react';
import { isConformant } from '../../testing/isConformant';
import { SplitNavItem } from './SplitNavItem';

describe('SplitNavItem', () => {
isConformant({
Component: SplitNavItem,
displayName: 'SplitNavItem',
});

// TODO add more tests here, and create visual regression tests in /apps/vr-tests

it('renders a default state', () => {
const result = render(<SplitNavItem>Default SplitNavItem</SplitNavItem>);
expect(result.container).toMatchSnapshot();
});
});
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
import * as React from 'react';
import type { ForwardRefComponent } from '@fluentui/react-utilities';
import { useSplitNavItem_unstable } from './useSplitNavItem';
import { renderSplitNavItem_unstable } from './renderSplitNavItem';
import { useSplitNavItemStyles_unstable } from './useSplitNavItemStyles.styles';
import type { SplitNavItemProps } from './SplitNavItem.types';

/**
* SplitNavItem component - TODO: add more docs
*/
export const SplitNavItem: ForwardRefComponent<SplitNavItemProps> = React.forwardRef((props, ref) => {
const state = useSplitNavItem_unstable(props, ref);

useSplitNavItemStyles_unstable(state);

/**
* @see https://github.com/microsoft/fluentui/blob/master/docs/react-v9/contributing/rfcs/react-components/convergence/custom-styling.md
*
* TODO: 💡 once package will become stable (PR which will be part of promoting PREVIEW package to STABLE),
* - uncomment this line
* - update types {@link file://./../../../../../../../packages/react-components/react-shared-contexts/library/src/CustomStyleHooksContext/CustomStyleHooksContext.ts#CustomStyleHooksContextValue}
* - verify that custom global style override works for your component
*/
// useCustomStyleHook_unstable('useSplitNavItemStyles_unstable')(state);

return renderSplitNavItem_unstable(state);
});

SplitNavItem.displayName = 'SplitNavItem';
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
import type { ComponentProps, ComponentState, Slot } from '@fluentui/react-utilities';

export type SplitNavItemSlots = {
root: Slot<'div'>;
};

/**
* SplitNavItem Props
*/
export type SplitNavItemProps = ComponentProps<SplitNavItemSlots> & {};

/**
* State used in rendering SplitNavItem
*/
export type SplitNavItemState = ComponentState<SplitNavItemSlots>;
// TODO: Remove semicolon from previous line, uncomment next line, and provide union of props to pick from SplitNavItemProps.
// & Required<Pick<SplitNavItemProps, 'propName'>>
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
// Jest Snapshot v1, https://goo.gl/fbAQLP

exports[`SplitNavItem renders a default state 1`] = `
<div>
<div
class="fui-SplitNavItem"
>
Default SplitNavItem
</div>
</div>
`;
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
export * from './SplitNavItem';
export * from './SplitNavItem.types';
export * from './renderSplitNavItem';
export * from './useSplitNavItem';
export * from './useSplitNavItemStyles.styles';
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
/** @jsxRuntime automatic */
/** @jsxImportSource @fluentui/react-jsx-runtime */

import { assertSlots } from '@fluentui/react-utilities';
import type { SplitNavItemState, SplitNavItemSlots } from './SplitNavItem.types';

/**
* Render the final JSX of SplitNavItem
*/
export const renderSplitNavItem_unstable = (state: SplitNavItemState) => {
assertSlots<SplitNavItemSlots>(state);

// TODO Add additional slots in the appropriate place
return <state.root />;
};
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
import * as React from 'react';
import { getIntrinsicElementProps, slot } from '@fluentui/react-utilities';
import type { SplitNavItemProps, SplitNavItemState } from './SplitNavItem.types';

/**
* Create the state required to render SplitNavItem.
*
* The returned state can be modified with hooks such as useSplitNavItemStyles_unstable,
* before being passed to renderSplitNavItem_unstable.
*
* @param props - props from this instance of SplitNavItem
* @param ref - reference to root HTMLDivElement of SplitNavItem
*/
export const useSplitNavItem_unstable = (
props: SplitNavItemProps,
ref: React.Ref<HTMLDivElement>,
): SplitNavItemState => {
return {
// TODO add appropriate props/defaults
components: {
// TODO add each slot's element type or component
root: 'div',
},
// TODO add appropriate slots, for example:
// mySlot: resolveShorthand(props.mySlot),
root: slot.always(
getIntrinsicElementProps('div', {
ref,
...props,
}),
{ elementType: 'div' },
),
};
};
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
import { makeStyles, mergeClasses } from '@griffel/react';
import type { SlotClassNames } from '@fluentui/react-utilities';
import type { SplitNavItemSlots, SplitNavItemState } from './SplitNavItem.types';

export const splitNavItemClassNames: SlotClassNames<SplitNavItemSlots> = {
root: 'fui-SplitNavItem',
// TODO: add class names for all slots on SplitNavItemSlots.
// Should be of the form `<slotName>: 'fui-SplitNavItem__<slotName>`
};

/**
* Styles for the root slot
*/
const useStyles = makeStyles({
root: {
// TODO Add default styles for the root element
},

// TODO add additional classes for different states and/or slots
});

/**
* Apply styling to the SplitNavItem slots based on the state
*/
export const useSplitNavItemStyles_unstable = (state: SplitNavItemState): SplitNavItemState => {
'use no memo';

const styles = useStyles();
state.root.className = mergeClasses(splitNavItemClassNames.root, styles.root, state.root.className);

// TODO Add class names to slots, for example:
// state.mySlot.className = mergeClasses(styles.mySlot, state.mySlot.className);

return state;
};
Original file line number Diff line number Diff line change
Expand Up @@ -113,3 +113,11 @@ export {
useAppItemStaticStyles_unstable,
useAppItemStatic_unstable,
} from './AppItemStatic';
export type { SplitNavItemProps, SplitNavItemSlots, SplitNavItemState } from './SplitNavItem';
export {
SplitNavItem,
renderSplitNavItem_unstable,
splitNavItemClassNames,
useSplitNavItemStyles_unstable,
useSplitNavItem_unstable,
} from './SplitNavItem';

0 comments on commit c189a92

Please sign in to comment.