Skip to content

Commit

Permalink
Merge remote-tracking branch 'upstream/master' into export-typography…
Browse files Browse the repository at this point in the history
…-types
  • Loading branch information
aleccaputo committed Feb 7, 2020
2 parents 6b61500 + 0db2675 commit 63cb5ba
Show file tree
Hide file tree
Showing 19 changed files with 244 additions and 31 deletions.
2 changes: 1 addition & 1 deletion CONTRIBUTING.md
Original file line number Diff line number Diff line change
Expand Up @@ -254,7 +254,7 @@ If you are no familiar with that language, write the demo in JavaScript, a core

#### 4. You are done 🎉!

In case you missed something, [we have a real example that can be used as a summary report](https://github.com/mui-org/material-ui/pull/8922/files).
In case you missed something, [we have a real example that can be used as a summary report](https://github.com/mui-org/material-ui/pull/19582/files).

## Translations

Expand Down
18 changes: 9 additions & 9 deletions docs/pages/blog/2019.md
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ The numbers speak for themselves. 2019 was super exciting and made Material-UI o
When we started 2019, we were celebrating the launch of the **first stable release** of the framework and iterating to polish it (looking at the list of breaking changes, v3 is almost identical to v1).
We thought we were almost done, and that we had done the hardest part with the release of the stable version. All we would need to do going forward was to keep up with the Material Design specification and fix a couple of bugs.

We have quickly realized that we could do way way more. It was just the beginning :D.
We soon realized that we could do way more. It was just the beginning :D.
Some of the key factors:

- The results of the [2019 Developer Survey](https://medium.com/material-ui/2019-material-ui-developer-survey-results-c9589434bbcf) have highlighted the immense potential for working on advanced components and features, especially for enterprise users.
Expand Down Expand Up @@ -61,12 +61,12 @@ We won't rest until we successfully unify these efforts. It's a long term missio
- We have fixed a significant number of [accessibility issues](https://github.com/mui-org/material-ui/issues?q=is%3Aissue+label%3Aaccessibility+is%3Aclosed).
- We have introduced global class names.
- We have migrated the whole codebase to hooks.
- We have migrated all the demos to TypeScript (while also offering transpiled JS demos).
- We have introduced [native tree-shaking](/guides/minimizing-bundle-size/) support.
- We have introduced [built-in localization](/guides/localization/).
- We have remove a good number of external dependencies and increased the `features/bundle size` density.
- We have introduced an [icon search page](/components/material-icons/).
- We have released a [store for Material-UI](https://themes.material-ui.com/).
- We migrated all the demos to TypeScript (while also offering transpiled JS demos).
- We introduced [native tree-shaking](/guides/minimizing-bundle-size/) support.
- We introduced [built-in localization](/guides/localization/).
- We removed a good number of external dependencies and increased the `features/bundle size` density.
- We introduced an [icon search page](/components/material-icons/).
- We released a [store for Material-UI](https://themes.material-ui.com/).

## Looking at 2020

Expand All @@ -76,11 +76,11 @@ We will continue in the same direction.
### Survey

The developer survey we ran [last year](/blog/2019-developer-survey-results/) was so insightful that we plan to run it every year.
It's a great opportunity for us to adjust the strategy and to pause to analyse the outcome of the actions we took in the previous year.
It's a great opportunity for us to adjust the strategy and to pause to analyze the outcome of the actions we took in the previous year.

### Open source roadmap

Most of the time we work in the open. Here's our our [public roadmap](/discover-more/roadmap).
Most of the time we work in the open. Here's our [public roadmap](/discover-more/roadmap).
We plan to release a new major around the end of the year (v5).
We will promote components that are in the lab to the core, migrate to styled-components, and more.

Expand Down
2 changes: 1 addition & 1 deletion docs/src/pages/company/jobs/jobs.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,5 +2,5 @@

<p class="description">Join our team!</p>

- [Software Engineer](/company/software-engineer/) • Remote or Paris<br />
- [Senior Software Engineer](/company/software-engineer/) • Remote<br />
We are looking for a software engineer to help support our open source team, assist the Material-UI community and grow our premium products. Join us in our mission to make React application development fun by making it simple.
21 changes: 13 additions & 8 deletions docs/src/pages/company/software-engineer/software-engineer.md
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
# Software Engineer
# Senior Software Engineer

<p class="description">We are looking for a software engineer to help support our open source team, assist the Material-UI community and grow our premium products. Join us in our mission to make React application development fun by making it simple.</p>

Expand All @@ -12,17 +12,20 @@ Material-UI started back in 2014 to unify React and Material Design. Today, Mate

## Details of the Role

- Type of work: Contractor (long mission, full-time, convertible to an employee position)
- Start date: Immediately
- Location: Remote (preference for UTC-5 to UTC+4), or Paris
- Type of work: Contractor (long mission, full-time, convertible to an employee position in the future).
- Start date: Immediately.
- Location: Remote (preference for UTC-5 to UTC+4).
- Level: [Senior Engineer or above](https://open.buffer.com/engineering-career-framework/).
- We're a remote company, we prefer asynchronous communication over meetings.
- We work independently, the rest of us won't know what you're doing day-to-day unless you tell us.

## Why we’re hiring

Both our open source products and community, and our premium products are [growing fast](https://www.rank2traffic.com/material-ui.com) and we need talented engineers to keep that going!

We need help to continue to improve the health of Material-UI open source: make the library easier to use, make it support more use cases, improve performance, make it more accessible, and make it easier to customize. We also need help keeping up with the community, guiding developers to answers, and just generally being a positive presence in the open source community.
We need help to continue to improve the health of Material-UI open source: make the library easier to use, make it support more use cases, improve performance, make it more accessible, and make it easier to customize to support [in-house design systems](https://medium.com/google-design/state-of-design-systems-2019-ff5f26ada71). We also need help keeping up with the community, guiding developers to answers, and just generally being a positive presence in the open source community.

We also need to develop our premium content. We have a premium store, and soon an enterprise class offering, starting with the data grid.
We also need to develop our premium content. We have a store, and soon an enterprise offering, starting with the data grid.
Enterprise features will build on the open source version of the components.

## Why this is interesting
Expand All @@ -38,7 +41,7 @@ Depending on the day, you’ll:
On the open source side:

- **Help guide architectural decisions**. From modernizing the way we handle styles to building new components, the future of Material-UI is discussed and planned in our public RFCs and issues. You’ll be helping drive these conversations and guiding Material-UI toward the best possible solutions.
- **Contribute to deep, meaningful refactors and feature releases**. Material-UI is a complex codebase. Components we’ve shipped recently, such as the Tree View and Slider have required weeks of dedicated, careful work.
- **Contribute to deep, meaningful refactors and feature releases**. Material-UI is a complex codebase. Components we’ve shipped recently, such as the Tree View, Autocomplete, and Slider have required weeks of dedicated, careful work.
- **Reduce friction**. A large amount of the work on Material-UI is reducing friction and making it easier to use. This might involve careful API design, identifying and fixing top bugs, creating easier to understand error messages, and writing documentation and blog posts about features you ship.
- **Collaborate with the community**. Many small as well as meaningful fixes and features have been contributed by the community. Your role as a core team maintainer is to draw the best out of the community — to inspire those across the world to create and contribute through your reviews of their issues and pull requests.
- **Experiment and play**. Great, unexpected features and heisenbug fixes have come from a number of sources — relentlessly methodical processes of elimination, free-flowing team collaboration, inspiration by adjacent libraries and projects, and difficult-to-explain individual strokes of brilliance. Whatever your preferred style is for creating new things that others might not have thought of, you’ll find a welcome home on the team.
Expand All @@ -47,6 +50,7 @@ Premium components:

- **Take ownership of features from idea/mockup to live deployment**. You’ll shape and guide the direction of crucial new features, including new components.
- **Ship. Early and often**. You’ll iterate and ship frequently. You’ll have a real impact on the end-user experience and you’ll love working on a team that builds stunning UIs and prioritizes delivering real user value as often as possible.
- **You'll be interacting with our customers** on a regular basis, handling inbound support and feature requests (every developer helps with support).

## Experience you should have

Expand All @@ -61,6 +65,7 @@ Premium components:

## Experience it would be nice if you had, but isn’t required

- **You’ve contributed to a design system before**. You have worked on enterprise components in the past, maybe for internal usage in your company. You have built complex and advanced features while making sure the accessibility was fully functional.
- **You’ve maintained an active repository before**. Maybe you’ve helped maintain a popular open source repo, or perhaps you’ve worked on internal repos that saw contributions from multiple teams. Previous experience with highly active repo workflows is a definite plus for this role.
- **You have used Material-UI before**. You have built a non trivial application with Material-UI in the past. You know the limitations of the library, you know a few areas that could be improved.
- **You have contributed code to Material-UI before**. A history of contributing to Material-UI would be a definite plus.
Expand All @@ -81,7 +86,7 @@ The work you would be doing is somewhat unique and idiosyncratic. You probably h

## Benefits for you

- A competitive compensation.
- Competitive compensation of up to $120k/year, depending on the profile. Could go higher in the case of an extraordinary match.
- Flexible workplace & hours.

## Apply
Expand Down
80 changes: 80 additions & 0 deletions docs/src/pages/components/toggle-button/ToggleButtonNotEmpty.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,80 @@
import React from 'react';
import { makeStyles } from '@material-ui/core/styles';
import FormatAlignLeftIcon from '@material-ui/icons/FormatAlignLeft';
import FormatAlignCenterIcon from '@material-ui/icons/FormatAlignCenter';
import FormatAlignRightIcon from '@material-ui/icons/FormatAlignRight';
import FormatAlignJustifyIcon from '@material-ui/icons/FormatAlignJustify';
import LaptopIcon from '@material-ui/icons/Laptop';
import TvIcon from '@material-ui/icons/Tv';
import PhoneAndroidIcon from '@material-ui/icons/PhoneAndroid';
import Grid from '@material-ui/core/Grid';
import ToggleButton from '@material-ui/lab/ToggleButton';
import ToggleButtonGroup from '@material-ui/lab/ToggleButtonGroup';

const useStyles = makeStyles(theme => ({
toggleContainer: {
margin: theme.spacing(2, 0),
},
}));

export default function ToggleButtonNotEmpty() {
const [alignment, setAlignment] = React.useState('left');
const [formats, setFormats] = React.useState(() => ['phone']);

const handleFormat = (event, newFormats) => {
if (newFormats.length) {
setFormats(newFormats);
}
};

const handleAlignment = (event, newAlignment) => {
if (newAlignment !== null) {
setAlignment(newAlignment);
}
};

const classes = useStyles();

return (
<Grid container spacing={2}>
<Grid item sm={12} md={6}>
<div className={classes.toggleContainer}>
<ToggleButtonGroup
value={alignment}
exclusive
onChange={handleAlignment}
aria-label="text alignment"
>
<ToggleButton value="left" aria-label="left aligned">
<FormatAlignLeftIcon />
</ToggleButton>
<ToggleButton value="center" aria-label="centered">
<FormatAlignCenterIcon />
</ToggleButton>
<ToggleButton value="right" aria-label="right aligned">
<FormatAlignRightIcon />
</ToggleButton>
<ToggleButton value="justify" aria-label="justified" disabled>
<FormatAlignJustifyIcon />
</ToggleButton>
</ToggleButtonGroup>
</div>
</Grid>
<Grid item sm={12} md={6}>
<div className={classes.toggleContainer}>
<ToggleButtonGroup value={formats} onChange={handleFormat} aria-label="device">
<ToggleButton value="laptop" aria-label="laptop">
<LaptopIcon />
</ToggleButton>
<ToggleButton value="tv" aria-label="tv">
<TvIcon />
</ToggleButton>
<ToggleButton value="phone" aria-label="phone">
<PhoneAndroidIcon />
</ToggleButton>
</ToggleButtonGroup>
</div>
</Grid>
</Grid>
);
}
80 changes: 80 additions & 0 deletions docs/src/pages/components/toggle-button/ToggleButtonNotEmpty.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,80 @@
import React from 'react';
import { makeStyles } from '@material-ui/core/styles';
import FormatAlignLeftIcon from '@material-ui/icons/FormatAlignLeft';
import FormatAlignCenterIcon from '@material-ui/icons/FormatAlignCenter';
import FormatAlignRightIcon from '@material-ui/icons/FormatAlignRight';
import FormatAlignJustifyIcon from '@material-ui/icons/FormatAlignJustify';
import LaptopIcon from '@material-ui/icons/Laptop';
import TvIcon from '@material-ui/icons/Tv';
import PhoneAndroidIcon from '@material-ui/icons/PhoneAndroid';
import Grid from '@material-ui/core/Grid';
import ToggleButton from '@material-ui/lab/ToggleButton';
import ToggleButtonGroup from '@material-ui/lab/ToggleButtonGroup';

const useStyles = makeStyles(theme => ({
toggleContainer: {
margin: theme.spacing(2, 0),
},
}));

export default function ToggleButtonNotEmpty() {
const [alignment, setAlignment] = React.useState('left');
const [formats, setFormats] = React.useState(() => ['phone']);

const handleFormat = (event: React.MouseEvent<HTMLElement>, newFormats: string[]) => {
if (newFormats.length) {
setFormats(newFormats);
}
};

const handleAlignment = (event: React.MouseEvent<HTMLElement>, newAlignment: string | null) => {
if (newAlignment !== null) {
setAlignment(newAlignment);
}
};

const classes = useStyles();

return (
<Grid container spacing={2}>
<Grid item sm={12} md={6}>
<div className={classes.toggleContainer}>
<ToggleButtonGroup
value={alignment}
exclusive
onChange={handleAlignment}
aria-label="text alignment"
>
<ToggleButton value="left" aria-label="left aligned">
<FormatAlignLeftIcon />
</ToggleButton>
<ToggleButton value="center" aria-label="centered">
<FormatAlignCenterIcon />
</ToggleButton>
<ToggleButton value="right" aria-label="right aligned">
<FormatAlignRightIcon />
</ToggleButton>
<ToggleButton value="justify" aria-label="justified" disabled>
<FormatAlignJustifyIcon />
</ToggleButton>
</ToggleButtonGroup>
</div>
</Grid>
<Grid item sm={12} md={6}>
<div className={classes.toggleContainer}>
<ToggleButtonGroup value={formats} onChange={handleFormat} aria-label="device">
<ToggleButton value="laptop" aria-label="laptop">
<LaptopIcon />
</ToggleButton>
<ToggleButton value="tv" aria-label="tv">
<TvIcon />
</ToggleButton>
<ToggleButton value="phone" aria-label="phone">
<PhoneAndroidIcon />
</ToggleButton>
</ToggleButtonGroup>
</div>
</Grid>
</Grid>
);
}
4 changes: 2 additions & 2 deletions docs/src/pages/components/toggle-button/ToggleButtons.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -21,14 +21,14 @@ const useStyles = makeStyles(theme => ({
}));

export default function ToggleButtons() {
const [alignment, setAlignment] = React.useState('left');
const [alignment, setAlignment] = React.useState<string | null>('left');
const [formats, setFormats] = React.useState(() => ['bold']);

const handleFormat = (event: React.MouseEvent<HTMLElement>, newFormats: string[]) => {
setFormats(newFormats);
};

const handleAlignment = (event: React.MouseEvent<HTMLElement>, newAlignment: string) => {
const handleAlignment = (event: React.MouseEvent<HTMLElement>, newAlignment: string | null) => {
setAlignment(newAlignment);
};

Expand Down
21 changes: 21 additions & 0 deletions docs/src/pages/components/toggle-button/toggle-button.md
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,27 @@ Fancy larger or smaller buttons? Use the `size` property.

{{"demo": "pages/components/toggle-button/ToggleButtonSizes.js"}}

## Enforce value set

If you want to enforce at least one button to be active, you can adapt your handleChange
function.

```jsx
const handleFormat = (event, newFormats) => {
if (newFormats.length) {
setFormats(newFormats);
}
};

const handleAlignment = (event, newAlignment) => {
if (newAlignment !== null) {
setAlignment(newAlignment);
}
};
```

{{"demo": "pages/components/toggle-button/ToggleButtonNotEmpty.js"}}

## Standalone toggle button

{{"demo": "pages/components/toggle-button/StandaloneToggleButton.js"}}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,11 @@ You didn't find the design assets your team is looking for? Let us know!
- [Unsplash](https://unsplash.com): 📷 A great resource for finding beautiful, high-resolution, free photos that you can use in your projects.
- [unDraw](https://undraw.co/): 📐 Like Unsplash but for amazing vector illustrations.

## IDE Tools

- [Material-UI Snippets](https://marketplace.visualstudio.com/items?itemName=vscodeshift.material-ui-snippets) VSCode extension providing snippets.
- [Material-UI Codemorphs](https://marketplace.visualstudio.com/items?itemName=vscodeshift.material-ui-codemorphs) VSCode extension providing codemods.

## Components

This is a collection of third-party projects that extend Material-UI.
Expand All @@ -31,8 +36,7 @@ This is a collection of third-party projects that extend Material-UI.

### Tables

- [material-table](https://github.com/mbrn/material-table): A simple and powerful Datatable for React based on Material-UI Table with some additional features.
They support many different use cases (editable, filtering, grouping, sorting, selection, i18n, tree data and more). You should check it out.
- [material-table](https://github.com/mbrn/material-table): A simple and powerful Datatable for React based on Material-UI Table with some additional features. It supports many different use cases (editable, filtering, grouping, sorting, selection, i18n, tree data and more).
- [dx-react-grid-material-ui](https://devexpress.github.io/devextreme-reactive/react/grid/): A data grid for Material-UI with paging, sorting, filtering, grouping and editing features ([paid license](https://js.devexpress.com/licensing/)).
- [mui-datatables](https://github.com/gregnb/mui-datatables): Responsive data tables for Material-UI with filtering, sorting, search and more.
- [tubular-react](https://github.com/unosquare/tubular-react): A Material-UI table with local or remote data-source. Featuring filtering, sorting, free-text search, export to CSV locally, and aggregations.
Expand Down
3 changes: 2 additions & 1 deletion docs/src/pages/guides/typescript/typescript.md
Original file line number Diff line number Diff line change
Expand Up @@ -242,7 +242,8 @@ And a custom theme factory with additional defaulted options:

**./styles/createMyTheme**:
```ts
import createMuiTheme, { ThemeOptions } from '@material-ui/core/styles/createMuiTheme';
import { createMuiTheme } from '@material-ui/core/styles';
import { ThemeOptions } from '@material-ui/core/styles/createMuiTheme';

export default function createMyTheme(options: ThemeOptions) {
return createMuiTheme({
Expand Down
Loading

0 comments on commit 63cb5ba

Please sign in to comment.