Skip to content

Commit

Permalink
Merge pull request #126 from MacPaw/revert-125-revert-113-feat/update…
Browse files Browse the repository at this point in the history
…-typesript-version

Revert "Revert "[WIP] feat: bump ts version and add new eslint config""
  • Loading branch information
kulia26 authored Jun 9, 2023
2 parents 09582ac + 286b1f6 commit 85d7acf
Show file tree
Hide file tree
Showing 111 changed files with 2,630 additions and 2,973 deletions.
8 changes: 4 additions & 4 deletions .github/workflows/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ jobs:
runs-on: ubuntu-latest
continue-on-error: false
steps:
- name: Checkout
- name: Checkout
uses: actions/checkout@v2

- name: Setup node
Expand All @@ -21,7 +21,7 @@ jobs:
node-version: '16.x'
registry-url: 'https://registry.npmjs.org'
cache: 'npm'

- name: Install dependencies
run: npm i
env:
Expand All @@ -47,7 +47,7 @@ jobs:
uses: actions/download-artifact@v2
with:
name: ui-kit-artifact

- name: Unpack artifact
run: tar xf artifact.tar.gz

Expand All @@ -67,7 +67,7 @@ jobs:

- name: Unpack artifact
run: tar xf artifact.tar.gz

- name: Run typescript compile
run: yarn tsc --noEmit

Expand Down
1,363 changes: 839 additions & 524 deletions package-lock.json

Large diffs are not rendered by default.

9 changes: 5 additions & 4 deletions package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@macpaw/macpaw-ui",
"version": "4.10.6",
"version": "4.12.0",
"main": "lib/ui.js",
"scripts": {
"dev": "next -p 1234",
Expand Down Expand Up @@ -35,8 +35,9 @@
},
"devDependencies": {
"@babel/runtime": "^7.18.3",
"@macpaw/eslint-config-react": "^2.0.1",
"@macpaw/eslint-config-typescript": "^2.0.1",
"@macpaw/eslint-config-react": "^3.1.0",
"@macpaw/eslint-config-typescript": "^3.1.0",
"@macpaw/eslint-config-prettier": "^1.1.0",
"@mdx-js/loader": "^2.1.1",
"@mdx-js/react": "^2.3.0",
"@next/mdx": "^12.1.6",
Expand All @@ -54,7 +55,7 @@
"react": "^18.1.0",
"react-dom": "^18.1.0",
"sass": "^1.52.1",
"typescript": "^4.7.2"
"typescript": "^5.0.4"
},
"files": [
"src",
Expand Down
28 changes: 14 additions & 14 deletions pages/tooltip.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -77,7 +77,7 @@ import { Tooltip, Button, Grid, GridRow, GridCell } from '../src/ui';

## Tooltip with max width

<Tooltip
<Tooltip
maxWidth={100}
position="right"
content="So small"
Expand All @@ -88,7 +88,7 @@ import { Tooltip, Button, Grid, GridRow, GridCell } from '../src/ui';
</Tooltip>

```
<Tooltip
<Tooltip
maxWidth={100}
position="right"
content="Hi there"
Expand All @@ -102,7 +102,7 @@ import { Tooltip, Button, Grid, GridRow, GridCell } from '../src/ui';

## Tooltip that opens on click

<Tooltip
<Tooltip
position="right"
content="Hi there!"
openOnClick
Expand All @@ -113,7 +113,7 @@ import { Tooltip, Button, Grid, GridRow, GridCell } from '../src/ui';
</Tooltip>

```
<Tooltip
<Tooltip
position="right"
content="Hi there!"
openOnClick
Expand All @@ -138,7 +138,7 @@ export const ControlledTooltip = () => {
</Button>
</GridCell>
<GridCell>
<Tooltip
<Tooltip
position="top"
content={`Hi there! I'm ${tooltipBehaviorTitle} tooltip.`}
forceShow={isVisible}
Expand All @@ -148,7 +148,7 @@ export const ControlledTooltip = () => {
</Button>
</Tooltip>
</GridCell>
</GridRow>
</GridRow>
</Grid>
);
};
Expand All @@ -162,7 +162,7 @@ const tooltipBehaviorTitle = isVisible ? 'always visible' : 'normal'
<Button onClick={() => setIsVisible(current=>!current)}>
Toggle behavior: {tooltipBehaviorTitle}
</Button>
<Tooltip
<Tooltip
position="top"
content={`Hi there! I'm ${tooltipBehaviorTitle} tooltip.`}
forceShow={isVisible}
Expand All @@ -174,7 +174,7 @@ const tooltipBehaviorTitle = isVisible ? 'always visible' : 'normal'
```

## Tooltip force hidding
## Tooltip force hidding

export const HiddenTooltip = () => {
const [isHidden, setIsHidden] = useState(false);
Expand All @@ -188,7 +188,7 @@ export const HiddenTooltip = () => {
</Button>
</GridCell>
<GridCell>
<Tooltip
<Tooltip
position="top"
content={`Hi there! I'm ${tooltipBehaviorTitle} tooltip.`}
forceHide={isHidden}
Expand All @@ -198,7 +198,7 @@ export const HiddenTooltip = () => {
</Button>
</Tooltip>
</GridCell>
</GridRow>
</GridRow>
</Grid>
);
};
Expand All @@ -212,7 +212,7 @@ const tooltipBehaviorTitle = isHidden ? 'always hidden' : 'normal';
<Button onClick={() => setIsHidden(current=>!current)}>
Toggle behavior: {tooltipBehaviorTitle}
</Button>
<Tooltip
<Tooltip
position="top"
content={`Hi there! I'm ${tooltipBehaviorTitle} tooltip.`}
forceHide={isHidden}
Expand All @@ -238,7 +238,7 @@ export const FullyControlledTooltip = () => {
</Button>
</GridCell>
<GridCell>
<Tooltip
<Tooltip
position="top"
content={`Hi there! I'm ${tooltipBehaviorTitle} tooltip.`}
forceShow={isVisible}
Expand All @@ -249,7 +249,7 @@ export const FullyControlledTooltip = () => {
</Button>
</Tooltip>
</GridCell>
</GridRow>
</GridRow>
</Grid>
);
};
Expand All @@ -263,7 +263,7 @@ const tooltipBehaviorTitle = isVisible ? 'always visible' : 'always hidden';
<Button onClick={() => setIsVisible(current=>!current)}>
Toggle behavior: {tooltipBehaviorTitle}
</Button>
<Tooltip
<Tooltip
position="top"
content={`Hi there! I'm ${tooltipBehaviorTitle} tooltip.`}
forceShow={isVisible}
Expand Down
60 changes: 58 additions & 2 deletions src/.eslintrc.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,62 @@
{
"extends": [
"@macpaw/eslint-config-react",
"@macpaw/eslint-config-typescript"
]
"@macpaw/eslint-config-typescript",
"@macpaw/eslint-config-prettier"
],
"rules": {
"no-param-reassign": [2, { "props": true, "ignorePropertyModificationsForRegex": ["(R|r)ef"] }],
"no-multiple-empty-lines": [2, { "max": 1, "maxBOF": 0, "maxEOF": 0 }],
"import/order": [2, {
"alphabetize": {
"order": "asc",
"caseInsensitive": true
},
"pathGroups": [
{
"pattern": "react",
"group": "builtin",
"position": "before"
},
{
"pattern": "react*",
"group": "builtin"
},
{
"pattern": "@macpaw/**",
"group": "internal",
"position": "before"
},
{
"pattern": "*.sass",
"group": "index",
"position": "after"
}
],
"pathGroupsExcludedImportTypes": ["react"],
"groups": [
"builtin",
"external",
"internal",
"parent",
"sibling",
"index",
"object",
"type"
]
}],
"@typescript-eslint/no-explicit-any": 2,
"no-magic-numbers": 0,
"@typescript-eslint/no-magic-numbers": [
2,
{
"ignore": [0, 1],
"ignoreEnums": true,
"ignoreNumericLiteralTypes": true,
"ignoreTypeIndexes": true
}
],
"import/no-cycle": 2,
"react/react-in-jsx-scope": 0
}
}
4 changes: 1 addition & 3 deletions src/Accordion/Accordion.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -11,9 +11,7 @@ const Accordion: React.FC<React.PropsWithChildren<Accordion>> = (props) => {

const onToggle = (key: string | null) => {
setActiveKey(key);
if (onChange) {
onChange(key);
}
if (onChange) onChange(key);
};

return <AccordionContext.Provider value={{ activeKey, onToggle }}>{children}</AccordionContext.Provider>;
Expand Down
42 changes: 19 additions & 23 deletions src/Accordion/AccordionCollapsible.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,11 +6,13 @@ export interface AccordionCollapsible extends HTMLAttributes<HTMLDivElement> {
sectionKey: string;
}

const TIMEOUT = 20;

const AccordionCollapsible: React.FC<React.PropsWithChildren<AccordionCollapsible>> = (props) => {
const timeout = 300;
const { sectionKey, children, ...other } = props;
const [isExpanded, setIsExpanded] = useState(false);
const nodeRef = useRef<HTMLDivElement>(null);
const nodeRef = useRef<HTMLDivElement>(null as unknown as HTMLDivElement);
const { activeKey } = useContext(AccordionContext);

useEffect(() => {
Expand All @@ -25,46 +27,40 @@ const AccordionCollapsible: React.FC<React.PropsWithChildren<AccordionCollapsibl
transition: `${timeout}ms cubic-bezier(0.4, 0, 0.2, 1)`,
};

function onEnter() {
const onEnter = () => {
if (nodeRef.current) {
nodeRef.current.style.height = `${0}px`;
nodeRef.current.style.visibility = 'visible';
}
}
};

function onEntering() {
if (nodeRef.current) {
nodeRef.current.style.height = `${nodeRef.current.scrollHeight}px`;
}
}
const onEntering = () => {
if (nodeRef.current) nodeRef.current.style.height = `${nodeRef.current.scrollHeight}px`;
};

function onEntered() {
const onEntered = () => {
if (nodeRef.current) {
nodeRef.current.style.height = 'auto';
nodeRef.current.style.overflow = 'visible';
}
}
};

function onExit() {
const onExit = () => {
if (nodeRef.current) {
nodeRef.current.style.overflow = 'hidden';
nodeRef.current.style.height = `${nodeRef.current.clientHeight}px`;
}
}
};

function onExiting() {
const onExiting = () => {
setTimeout(() => {
if (nodeRef.current) {
nodeRef.current.style.height = `${0}px`;
}
}, 20);
}
if (nodeRef.current) nodeRef.current.style.height = `${0}px`;
}, TIMEOUT);
};

function onExited() {
if (nodeRef.current) {
nodeRef.current.style.visibility = 'hidden';
}
}
const onExited = () => {
if (nodeRef.current) nodeRef.current.style.visibility = 'hidden';
};

return (
<Transition
Expand Down
8 changes: 2 additions & 6 deletions src/Accordion/AccordionTrigger.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -11,9 +11,7 @@ const AccordionTrigger: React.FC<React.PropsWithChildren<AccordionTrigger>> = (p
const { activeKey, onToggle } = useContext(AccordionContext);
const onTrigger = (event: React.SyntheticEvent) => {
onToggle(sectionKey === activeKey ? null : sectionKey);
if (onClick) {
onClick(event);
}
if (onClick) onClick(event);
};

return (
Expand All @@ -22,9 +20,7 @@ const AccordionTrigger: React.FC<React.PropsWithChildren<AccordionTrigger>> = (p
tabIndex={0}
onClick={onTrigger}
onKeyPress={(event: React.KeyboardEvent) => {
if (event.which === 13) {
onTrigger(event);
}
if (event.key === 'Enter') onTrigger(event);
}}
{...other}
>
Expand Down
9 changes: 1 addition & 8 deletions src/Banner/Banner.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -8,14 +8,7 @@ export interface BannerProps extends HTMLAttributes<HTMLDivElement> {
}

const Banner: FC<React.PropsWithChildren<BannerProps>> = (props) => {
const {
className,
children,
type,
icon,
action,
...other
} = props;
const { className, children, type, icon, action, ...other } = props;

const classNames = cx('banner', className, {
'-secondary': type === 'secondary',
Expand Down
3 changes: 1 addition & 2 deletions src/Breadcrumbs/Breadcrumbs.tsx
Original file line number Diff line number Diff line change
@@ -1,8 +1,7 @@
import React, { FC, HTMLAttributes } from 'react';
import cx from 'clsx';

export interface BreadcrumbsProps extends HTMLAttributes<HTMLUListElement> {
}
export interface BreadcrumbsProps extends HTMLAttributes<HTMLUListElement> {}

const Breadcrumbs: FC<React.PropsWithChildren<BreadcrumbsProps>> = (props) => {
const { className, children, ...other } = props;
Expand Down
Loading

0 comments on commit 85d7acf

Please sign in to comment.