From 089e896476951c0d6ef00b5e73331d7722498da7 Mon Sep 17 00:00:00 2001 From: Sebastian Silbermann Date: Tue, 21 Jan 2020 20:46:17 +0100 Subject: [PATCH] feat: Remove IsEmptyInterface --- __snapshots__/IsEmptyInterface | 20 +++++----- .../core/styles/createMixins.d.ts | 6 +-- .../core/styles/createTypography.d.ts | 33 ++++++++-------- .../@material-ui/core/styles/makeStyles.d.ts | 16 ++++++-- .../styles/makeStyles/makeStyles.d.ts | 36 ++++-------------- .../styles/withStyles/withStyles.d.ts | 20 +++++++--- vendor/@material-ui/types/index.d.ts | 38 ------------------- 7 files changed, 64 insertions(+), 105 deletions(-) diff --git a/__snapshots__/IsEmptyInterface b/__snapshots__/IsEmptyInterface index f809000..352629f 100644 --- a/__snapshots__/IsEmptyInterface +++ b/__snapshots__/IsEmptyInterface @@ -1,15 +1,15 @@ sources/IsEmptyInterface.test.ts(11,27): error TS2554: Expected 1 arguments, but got 0. Files: 54 -Lines: 61523 -Nodes: 180439 -Identifiers: 62593 -Symbols: 104001 -Types: 36907 -Memory used: 133717K +Lines: 61475 +Nodes: 180254 +Identifiers: 62545 +Symbols: 102462 +Types: 33716 +Memory used: 146633K I/O read: 0.02s I/O write: 0.00s -Parse time: 0.68s -Bind time: 0.76s -Check time: 3.13s +Parse time: 0.65s +Bind time: 0.28s +Check time: 3.33s Emit time: 0.00s -Total time: 4.57s +Total time: 4.26s diff --git a/vendor/@material-ui/core/styles/createMixins.d.ts b/vendor/@material-ui/core/styles/createMixins.d.ts index cbf7ace..2b22e56 100644 --- a/vendor/@material-ui/core/styles/createMixins.d.ts +++ b/vendor/@material-ui/core/styles/createMixins.d.ts @@ -1,10 +1,10 @@ import { Breakpoints } from './createBreakpoints'; import { Spacing } from './createSpacing'; -import { CSSProperties } from './withStyles'; +import * as React from 'react'; export interface Mixins { - gutters: (styles?: CSSProperties) => CSSProperties; - toolbar: CSSProperties; + gutters: (styles?: React.CSSProperties) => React.CSSProperties; + toolbar: React.CSSProperties; // ... use interface declaration merging to add custom mixins } diff --git a/vendor/@material-ui/core/styles/createTypography.d.ts b/vendor/@material-ui/core/styles/createTypography.d.ts index 43e493a..8bdcd0d 100644 --- a/vendor/@material-ui/core/styles/createTypography.d.ts +++ b/vendor/@material-ui/core/styles/createTypography.d.ts @@ -1,7 +1,8 @@ import { Palette } from './createPalette'; +import * as React from 'react'; import { CSSProperties } from './withStyles'; -export type ThemeStyle = +export type Variant = | 'h1' | 'h2' | 'h3' @@ -18,37 +19,33 @@ export type ThemeStyle = export interface FontStyle extends Required<{ - fontFamily: CSSProperties['fontFamily']; + fontFamily: React.CSSProperties['fontFamily']; fontSize: number; - fontWeightLight: CSSProperties['fontWeight']; - fontWeightRegular: CSSProperties['fontWeight']; - fontWeightMedium: CSSProperties['fontWeight']; - fontWeightBold: CSSProperties['fontWeight']; + fontWeightLight: React.CSSProperties['fontWeight']; + fontWeightRegular: React.CSSProperties['fontWeight']; + fontWeightMedium: React.CSSProperties['fontWeight']; + fontWeightBold: React.CSSProperties['fontWeight']; }> {} export interface FontStyleOptions extends Partial { htmlFontSize?: number; - allVariants?: CSSProperties; + allVariants?: React.CSSProperties; } -export type TypographyStyle = Required< - Pick -> & - Partial>; - -export interface TypographyStyleOptions extends Partial {} +// TODO: which one should actually be allowed to be subject to module augmentation? +// current type vs interface decision is kept for historical reasons until we +// made a decision +export type TypographyStyle = CSSProperties; +export interface TypographyStyleOptions extends TypographyStyle {} export interface TypographyUtils { pxToRem: (px: number) => string; } -export interface Typography - extends Record, - FontStyle, - TypographyUtils {} +export interface Typography extends Record, FontStyle, TypographyUtils {} export interface TypographyOptions - extends Partial & FontStyleOptions> {} + extends Partial & FontStyleOptions> {} export default function createTypography( palette: Palette, diff --git a/vendor/@material-ui/core/styles/makeStyles.d.ts b/vendor/@material-ui/core/styles/makeStyles.d.ts index a50cd3d..d7702ab 100644 --- a/vendor/@material-ui/core/styles/makeStyles.d.ts +++ b/vendor/@material-ui/core/styles/makeStyles.d.ts @@ -1,8 +1,18 @@ import { Theme as DefaultTheme } from './createMuiTheme'; -import { Styles, WithStylesOptions } from '@material-ui/styles/withStyles'; -import { StylesHook } from '@material-ui/styles/makeStyles'; +import { ClassNameMap, Styles, WithStylesOptions } from '@material-ui/styles/withStyles'; + import { Omit } from '@material-ui/types'; +/** + * `makeStyles` where the passed `styles` do not depend on props + */ +export default function makeStyles( + style: Styles, + options?: Omit, 'withTheme'>, +): (props?: any) => ClassNameMap; +/** + * `makeStyles` where the passed `styles` do depend on props + */ export default function makeStyles< Theme = DefaultTheme, Props extends {} = {}, @@ -10,4 +20,4 @@ export default function makeStyles< >( styles: Styles, options?: Omit, 'withTheme'>, -): StylesHook>; +): (props: Props) => ClassNameMap; diff --git a/vendor/@material-ui/styles/makeStyles/makeStyles.d.ts b/vendor/@material-ui/styles/makeStyles/makeStyles.d.ts index aa92527..aa91cc7 100644 --- a/vendor/@material-ui/styles/makeStyles/makeStyles.d.ts +++ b/vendor/@material-ui/styles/makeStyles/makeStyles.d.ts @@ -1,42 +1,22 @@ import { - ClassKeyOfStyles, ClassNameMap, PropsOfStyles, Styles, WithStylesOptions, } from '@material-ui/styles/withStyles'; -import { Omit, IsAny, Or, IsEmptyInterface } from '@material-ui/types'; +import { Omit } from '@material-ui/types'; import { DefaultTheme } from '../defaultTheme'; /** - * @internal - * - * If a style callback is given with `theme => stylesOfTheme` then typescript - * infers `Props` to `any`. - * If a static object is given with { ...members } then typescript infers `Props` - * to `{}`. - * - * So we require no props in `useStyles` if `Props` in `makeStyles(styles)` is - * inferred to either `any` or `{}` + * `makeStyles` where the passed `styles` do not depend on props */ -export type StylesRequireProps = Or< - IsAny>, - IsEmptyInterface> -> extends true - ? false - : true; - +export default function makeStyles( + style: Styles, + options?: Omit, 'withTheme'>, +): (props?: any) => ClassNameMap; /** - * @internal - * - * `Props` are `any` either by explicit annotation or if there are no callbacks - * from which the typechecker could infer a type so it falls back to `any`. - * See the test cases for examples and implications of explicit `any` annotation + * `makeStyles` where the passed `styles` do depend on props */ -export type StylesHook> = StylesRequireProps extends false - ? (props?: any) => ClassNameMap> - : (props: PropsOfStyles) => ClassNameMap>; - export default function makeStyles< Theme = DefaultTheme, Props extends {} = {}, @@ -44,4 +24,4 @@ export default function makeStyles< >( styles: Styles, options?: Omit, 'withTheme'>, -): StylesHook>; +): (props: Props) => ClassNameMap; diff --git a/vendor/@material-ui/styles/withStyles/withStyles.d.ts b/vendor/@material-ui/styles/withStyles/withStyles.d.ts index b3610bd..3bd02d7 100644 --- a/vendor/@material-ui/styles/withStyles/withStyles.d.ts +++ b/vendor/@material-ui/styles/withStyles/withStyles.d.ts @@ -1,5 +1,5 @@ import * as React from 'react'; -import { PropInjector, IsEmptyInterface } from '@material-ui/types'; +import { PropInjector } from '@material-ui/types'; import * as CSS from 'csstype'; import * as JSS from 'jss'; import { DefaultTheme } from '../defaultTheme'; @@ -18,7 +18,14 @@ export interface BaseCSSProperties extends CSS.Properties { export interface CSSProperties extends BaseCSSProperties { // Allow pseudo selectors and media queries - [k: string]: BaseCSSProperties[keyof BaseCSSProperties] | CSSProperties; + // `unknown` is used since TS does not allow assigning an interface without + // an index signature to one with an index signature. This is to allow type safe + // module augmentation. + // Technically we want any key not typed in `BaseCSSProperties` to be of type + // `CSSProperties` but this doesn't work. The index signature needs to cover + // BaseCSSProperties as well. Usually you would use `BaseCSSProperties[keyof BaseCSSProperties]` + // but this would not allow assigning React.CSSProperties to CSSProperties + [k: string]: unknown | CSSProperties; } export type BaseCreateCSSProperties = { @@ -43,9 +50,12 @@ export interface CreateCSSProperties */ export type StyleRules = Record< ClassKey, - IsEmptyInterface extends true - ? CSSProperties | (() => CSSProperties) - : CreateCSSProperties | ((props: Props) => CreateCSSProperties) + // JSS property bag + | CSSProperties + // JSS property bag where values are based on props + | CreateCSSProperties + // JSS property bag based on props + | ((props: Props) => CreateCSSProperties) >; /** diff --git a/vendor/@material-ui/types/index.d.ts b/vendor/@material-ui/types/index.d.ts index 4dea0a0..c126d62 100644 --- a/vendor/@material-ui/types/index.d.ts +++ b/vendor/@material-ui/types/index.d.ts @@ -44,41 +44,3 @@ export type Omit = T extends any ? Pick = Omit & U; - -/** - * Returns true if T is any, otherwise false - */ -// https://stackoverflow.com/a/49928360/3406963 without generic branch types -export type IsAny = 0 extends (1 & T) ? true : false; - -export type Or = A extends true - ? true - : B extends true - ? true - : C extends true - ? true - : false; - -export type And = A extends true - ? B extends true - ? C extends true - ? true - : false - : false - : false; - -/** - * @internal - * - * check if a type is `{}` - * - * 1. false if the given type has any members - * 2. false if the type is `object` which is the only other type with no members - * {} is a top type so e.g. `string extends {}` but not `string extends object` - * 3. false if the given type is `unknown` - */ -export type IsEmptyInterface = And< - keyof T extends never ? true : false, - string extends T ? true : false, - unknown extends T ? false : true ->;