Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

chore(components): sub in storybook for styleguidist #7549

Merged
merged 91 commits into from
May 3, 2021
Merged
Changes from 1 commit
Commits
Show all changes
91 commits
Select commit Hold shift + click to select a range
084411e
remove at flow, add tsconfig, change file extensions
b-cooper Feb 23, 2021
86a7336
mixed to unknown and pull type imports out
b-cooper Feb 23, 2021
a08ddc6
add types
b-cooper Feb 23, 2021
7e7e8d4
migrate synthetic mouse events over
b-cooper Feb 23, 2021
f926dc5
add typings for css modules dep
b-cooper Feb 24, 2021
2b743ca
update loader
b-cooper Feb 24, 2021
c883f15
swap css modules plugin out
b-cooper Feb 24, 2021
b338c8a
tsx ext for jsx files
b-cooper Feb 24, 2021
dfeb0f5
pick at style props
b-cooper Feb 24, 2021
df2d557
tests with jsx ext
b-cooper Feb 25, 2021
4a7ecd0
migrate more ts
b-cooper Feb 26, 2021
0d7b91a
work through tsc errors
b-cooper Mar 3, 2021
546b50a
jsx element return type
b-cooper Mar 3, 2021
9481e40
jest styled components types
b-cooper Mar 3, 2021
dc17d4e
add types for react test renderer
b-cooper Mar 3, 2021
8918d62
interface for prop types
b-cooper Mar 3, 2021
0f1546a
misc clean up
b-cooper Mar 3, 2021
bb8b4d8
Merge branch 'edge' into components_port-source-to-ts
b-cooper Mar 3, 2021
3db923d
shared data types
b-cooper Mar 3, 2021
d105565
continue clean up
b-cooper Mar 3, 2021
6b65363
styled components types clean up
b-cooper Mar 4, 2021
973a566
use PrimitiveComponent props
b-cooper Mar 4, 2021
a581bf3
knockin the errors down
b-cooper Mar 4, 2021
7b71e14
address first batch of pr commments
b-cooper Mar 5, 2021
2f28bf1
fine tooth combing
b-cooper Mar 5, 2021
eb371dd
clean up some tooltip type gunk
b-cooper Mar 5, 2021
be07f4b
clean up shared data stubstypes
b-cooper Mar 8, 2021
8b23039
fixup: fix errors with atoms types
mcous Mar 8, 2021
8f6ace7
forms bits
b-cooper Mar 8, 2021
baba5c3
fixup: get types working in interaction-enhancers
mcous Mar 8, 2021
35c39ff
some deck comp type fixes
b-cooper Mar 8, 2021
9ee75f8
memo exotic component type
b-cooper Mar 8, 2021
ffe808a
a couple more
b-cooper Mar 8, 2021
9f82285
fixup: get types sorted in tooltips
mcous Mar 8, 2021
de6b1c4
correct type for deck components
b-cooper Mar 8, 2021
1ec3f5d
add webpack env types and fix getDeckDefMock
b-cooper Mar 8, 2021
65a9013
formatOptionLabel returns react node
b-cooper Mar 9, 2021
e795522
type for fill
b-cooper Mar 9, 2021
6937b25
gitignore lib dir
b-cooper Mar 9, 2021
b3b9ce2
Well pointer events type
b-cooper Mar 9, 2021
90578a0
memo exotic component
b-cooper Mar 9, 2021
aaead15
robot coords text extend text props
b-cooper Mar 9, 2021
f9ed804
indeterminate prop missing todo
b-cooper Mar 9, 2021
bcd9311
struggle through react select generic types
b-cooper Mar 10, 2021
154b9cc
iron out select types
b-cooper Mar 10, 2021
6b0c746
disabled prop fixups
b-cooper Mar 10, 2021
f01e901
last errors
b-cooper Mar 10, 2021
7e214f1
no extension in import
b-cooper Mar 11, 2021
1d5908a
add react docgen typescript
b-cooper Mar 12, 2021
2c52afc
init storybook at root
b-cooper Mar 12, 2021
207fdbb
try out migrating alert item to storybook
b-cooper Mar 12, 2021
5bafba9
proof of concept btn and alert item in storybook
b-cooper Mar 15, 2021
eba7114
make stories for all atom
b-cooper Mar 16, 2021
2494b20
icon stories
b-cooper Mar 17, 2021
b18be1a
checkbox field and dropdown field
b-cooper Mar 17, 2021
0f835c0
Merge branch 'edge' into components_add-storybook
b-cooper Mar 24, 2021
cd9aeba
regrab deps
b-cooper Mar 24, 2021
7c23b61
add tooltip story
b-cooper Mar 29, 2021
b39773a
house-keeping todo comments in tabbed nav and structure dirs
b-cooper Mar 29, 2021
dbfd400
stories for structure components
b-cooper Mar 29, 2021
ed529a6
add todo comment to slot map component
b-cooper Mar 29, 2021
3c1b764
story for side panel
b-cooper Mar 29, 2021
030eaf0
add modal stories
b-cooper Mar 29, 2021
c406412
add instrument stories
b-cooper Mar 31, 2021
b562f32
form group story
b-cooper Apr 1, 2021
fae5813
hoist basic story components to top
b-cooper Apr 1, 2021
122d2f5
form components
b-cooper Apr 7, 2021
a66e8e4
select for module mode
b-cooper Apr 9, 2021
62f3782
wire up storybook in place of styleguidist deploy
b-cooper Apr 9, 2021
3b1d517
fix tab in makefile
b-cooper Apr 9, 2021
325ea8d
add makefile to path for components build action
b-cooper Apr 9, 2021
72b850f
deckLayerBlocklist control
b-cooper Apr 14, 2021
82ebdb6
chore(components): sub in storybook for styleguidist
b-cooper Apr 15, 2021
c2a9fc8
remove duplicate lint override
b-cooper Apr 15, 2021
0902454
delint
b-cooper Apr 15, 2021
ef32740
Merge branch 'edge' into components_add-storybook
b-cooper Apr 15, 2021
d0d9be0
bump flow memory capacity
b-cooper Apr 15, 2021
04f18d4
nuke merge conflict
b-cooper Apr 15, 2021
6aad3a7
clean up css lint
b-cooper Apr 15, 2021
109785d
remove react styleguidist dep
b-cooper Apr 15, 2021
0487af7
remove styleguidist markdown files
b-cooper Apr 15, 2021
915478c
remove styleguide config
b-cooper Apr 15, 2021
49fb4e5
remove styleguidist flow types
b-cooper Apr 16, 2021
4764d83
Merge branch 'edge' into components_add-storybook
b-cooper Apr 19, 2021
2d3a7b7
Merge branch 'edge' into components_add-storybook
b-cooper Apr 19, 2021
bcd2fdb
fixup: tweak eslint config for Storybook (#7708)
mcous Apr 27, 2021
1fe352e
fixup: fix linting and storybook build
mcous Apr 27, 2021
18058ca
fixup: add note about story classname
mcous Apr 27, 2021
09678be
fixup: fix broken teardown and dev tasks for components
mcous Apr 29, 2021
f1686ff
Merge branch 'edge' into components_add-storybook
mcous May 3, 2021
df28643
fixup: fix TS linting after shared-data merge
mcous May 3, 2021
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
fixup: get types working in interaction-enhancers
mcous committed Mar 8, 2021
commit baba5c3043ae7850cc13bfa9b5d74cf71283f2df
1 change: 1 addition & 0 deletions .eslintrc.js
Original file line number Diff line number Diff line change
@@ -39,6 +39,7 @@ module.exports = {
'no-case-declarations': 'warn',
'prefer-regex-literals': 'warn',
'react/prop-types': 'warn',
'@typescript-eslint/strict-boolean-expressions': 'warn',
},

globals: {},
11 changes: 3 additions & 8 deletions components/src/interaction-enhancers/HandleKeypress.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,4 @@
import * as React from 'react'

type KeypressEvent = React.KeyboardEvent<HTMLElement>

export interface KeypressHandler {
key: string
shiftKey?: boolean | null | undefined
@@ -17,7 +14,7 @@ export interface HandleKeypressProps {
children?: React.ReactNode
}

const matchHandler = (e: KeypressEvent) => (h: KeypressHandler) =>
const matchHandler = (e: KeyboardEvent) => (h: KeypressHandler) =>
h.key === e.key && (h.shiftKey == null || h.shiftKey === e.shiftKey)

/**
@@ -27,13 +24,11 @@ const matchHandler = (e: KeypressEvent) => (h: KeypressHandler) =>
* and `props.preventDefault` is true.
*/
export class HandleKeypress extends React.Component<HandleKeypressProps> {
handlePressIfKey: (event: KeypressEvent) => void = (event: KeypressEvent) => {
handlePressIfKey = (event: KeyboardEvent): void => {
this.props.handlers.filter(matchHandler(event)).forEach(h => h.onPress())
}

preventDefaultIfKey: (event: KeypressEvent) => void = (
event: KeypressEvent
) => {
preventDefaultIfKey = (event: KeyboardEvent): void => {
if (!this.props.preventDefault) return

const pressHandled = this.props.handlers.some(matchHandler(event))
2 changes: 0 additions & 2 deletions components/src/interaction-enhancers/index.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,3 @@


export * from './ClickOutside'
export * from './HandleKeypress'
export * from './useOnClickOutside'
10 changes: 8 additions & 2 deletions components/src/interaction-enhancers/useHover.ts
Original file line number Diff line number Diff line change
@@ -38,12 +38,18 @@ export type UseHoverResult = [boolean, HoverHandlers]
export function useHover(options: UseHoverOptions = {}): UseHoverResult {
const { enterDelay, leaveDelay } = options
const [hovered, setHovered] = useState(false)
const timeoutRef = useRef()
const timeoutRef = useRef<number>()

const handleHoverChange = useCallback((value, delay) => {
clearTimeout(timeoutRef.current)
if (delay) {
timeoutRef.current = setTimeout(() => setHovered(value), delay)
timeoutRef.current = setTimeout(
// TODO(mc, 2021-03-08): use window.setTimeout or a separate const
// for the handler to tell TS that we're using DOM setTimeout, not Node.js
// eslint-disable-next-line @typescript-eslint/no-implied-eval
(() => setHovered(value)) as TimerHandler,
delay
)
} else {
setHovered(value)
}
10 changes: 5 additions & 5 deletions components/src/interaction-enhancers/useOnClickOutside.ts
Original file line number Diff line number Diff line change
@@ -1,20 +1,20 @@
import { useEffect, useRef } from 'react'
import assert from 'assert'

import type { SyntheticEvent } from 'react'
import type { RefObject } from 'react'

export interface UseOnClickOutsideOptions {
onClickOutside?: (e: SyntheticEvent) => void
onClickOutside?: (e: MouseEvent) => void
}

export const useOnClickOutside = <E extends Element>(
options: UseOnClickOutsideOptions
): { current: E | null } => {
): RefObject<E> => {
const { onClickOutside } = options
const node: { current: E | null } = useRef(null)
const node = useRef<E>(null)

useEffect(() => {
const handleClickOutside = (event: SyntheticEvent): void => {
const handleClickOutside = (event: MouseEvent): void => {
const clickedElem = event.target

assert(