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

feat(Gatsby Recipes): Initial release #22709

Merged
merged 132 commits into from
Apr 16, 2020
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
132 commits
Select commit Hold shift + click to select a range
64cc1de
Initial commit
KyleAMathews Apr 1, 2020
b0698d9
Cleanups
KyleAMathews Apr 1, 2020
36b5421
more cleanup
KyleAMathews Apr 1, 2020
461c7ee
Add missing remark-stringify dep (#22721)
johno Apr 1, 2020
50f4e0a
WIP
KyleAMathews Apr 1, 2020
716600c
WIP
KyleAMathews Apr 1, 2020
1fc328e
update TODOs
KyleAMathews Apr 1, 2020
27ac5e2
Prettier + enable Ink's experimental mode
KyleAMathews Apr 1, 2020
92b7c04
Don't need this anymore
KyleAMathews Apr 1, 2020
353ae8f
Support running local recipes e.g. gatsby recipes ./text.mdx
KyleAMathews Apr 1, 2020
3d49140
prettier again
KyleAMathews Apr 1, 2020
faa261f
Make config slightly more robust (#22743)
johno Apr 1, 2020
904e47d
Add support for devDependencies in NPMPackage resource
KyleAMathews Apr 2, 2020
cfdb1d2
Move package to new prop name
KyleAMathews Apr 2, 2020
c0e7b83
Update todos
KyleAMathews Apr 2, 2020
f044af7
add TODO
KyleAMathews Apr 2, 2020
66ff708
recipes: Improve providers (#22764)
johno Apr 2, 2020
d3d8a7b
Improve recipes providers (#22783)
KyleAMathews Apr 3, 2020
1be1b24
Support rendering more markdown
KyleAMathews Apr 3, 2020
f00c6a3
Support more markdown tags
KyleAMathews Apr 3, 2020
140190e
Tweak providers, add more thorough tests
johno Apr 3, 2020
9df2182
Clean up file after plan test
johno Apr 3, 2020
a5db934
recipes: Add initial package json resource (#22805)
johno Apr 3, 2020
14b9548
Copy recipes on change
KyleAMathews Apr 3, 2020
98054b4
improve stylings for h2/h3
KyleAMathews Apr 3, 2020
0f1c3f3
Refactor to use xstate
KyleAMathews Apr 4, 2020
587c0ab
Update TODOs
KyleAMathews Apr 4, 2020
23d483e
Improve parsing to handle basic template strings
johno Apr 4, 2020
905b7da
Improve parsing to handle basic template strings
johno Apr 4, 2020
1231d94
Chore(Recipes): Add recipes machine tests (#22823)
KyleAMathews Apr 4, 2020
2b33c6a
feat(recipes): Add resource schema/validation support (#22830)
KyleAMathews Apr 6, 2020
4f60b91
fix(recipes): Don't duplicate plugin configuration by default (#22861)
johno Apr 6, 2020
310abd2
feat(recipes): Generate graphql schema from resources (#22864)
johno Apr 6, 2020
e22d67e
feat(recipes): Create connection types for resources (#22876)
johno Apr 6, 2020
7f7ac96
Find the root directory of the Node.js project/npm package and use th…
KyleAMathews Apr 6, 2020
bb7a4c9
Fix
KyleAMathews Apr 7, 2020
07860d6
update tests
KyleAMathews Apr 7, 2020
c88c6a5
Write e2e tests for npm package scripts & add validate/all implementa…
KyleAMathews Apr 7, 2020
fca6807
Fix recipes (#22885)
mxstbr Apr 7, 2020
fb46a1e
Fix some more recipes (#22889)
mxstbr Apr 7, 2020
c8d103e
Fix more recipes stuff (#22891)
mxstbr Apr 7, 2020
04ac784
Fix typo
KyleAMathews Apr 7, 2020
6d390c5
feat(recipes): Implement shadowable files for themes (#22909)
johno Apr 7, 2020
a08e767
feat(recipes): iterate on recipe design (#22911)
KyleAMathews Apr 8, 2020
6b67046
Squashed master
KyleAMathews Apr 8, 2020
3b3f926
add todo
KyleAMathews Apr 8, 2020
b11808b
feat(recipes): Show recap of operations & show diff for changes to fi…
KyleAMathews Apr 9, 2020
eaa0535
Merge remote-tracking branch 'origin/master' into add-recipes
KyleAMathews Apr 9, 2020
f1d245b
Fix merge barf
KyleAMathews Apr 9, 2020
bbfa77f
Remove file that came in from bad merge
KyleAMathews Apr 9, 2020
c6de714
update todos
KyleAMathews Apr 9, 2020
bc369a0
Validate resources & improve file diffing (#22986)
KyleAMathews Apr 10, 2020
63604f3
Improve diffing & just run all resource operations serially
KyleAMathews Apr 10, 2020
64625e4
feat(recipes): Import recipes from urls and begin moving parsing to t…
johno Apr 10, 2020
2d191c4
update todos
KyleAMathews Apr 10, 2020
0be2a5d
Add support for file content on remote URLs
KyleAMathews Apr 10, 2020
793c3de
Add some basic docs & new emotion recipe
KyleAMathews Apr 10, 2020
de5e40c
Small updates to README
KyleAMathews Apr 10, 2020
0d0367d
small fixes
KyleAMathews Apr 10, 2020
c36ecee
fix
KyleAMathews Apr 10, 2020
ae665f0
More todos
KyleAMathews Apr 10, 2020
f4d5b2a
Cleanup comments
KyleAMathews Apr 10, 2020
7a0f08b
Add to docs about how to upgrade gatsby-cli
KyleAMathews Apr 10, 2020
22912c3
feat(recipes): Implement basic gitignore provider (#23003)
johno Apr 10, 2020
9a4695d
Move to jest-diff for faster diffing & more control
KyleAMathews Apr 10, 2020
19ad1d0
Update snapshots & use default jest-diff export as that handles any t…
KyleAMathews Apr 10, 2020
0401a13
Chalk thinks it shouldn't output color in a child process — fix that
KyleAMathews Apr 11, 2020
9a71723
tweak TODOs
KyleAMathews Apr 11, 2020
cf8603c
update todos
KyleAMathews Apr 12, 2020
abad6f3
update todos
KyleAMathews Apr 12, 2020
44aee1a
Move mdx source for recipes to their own directory
KyleAMathews Apr 13, 2020
5efb22f
Add Sass recipe
Apr 13, 2020
4f2e2df
Add recipe for setting up local gatsby-theme-blog
Apr 13, 2020
2a2802b
Add todo around bundling
KyleAMathews Apr 13, 2020
6add891
feat(recipes): Eliminate new lines from markdown (#23064)
KyleAMathews Apr 13, 2020
a47d188
feat(recipes): Implement shadow file resource and test it (#23063)
johno Apr 13, 2020
4823995
update todos
KyleAMathews Apr 13, 2020
f3a6f66
Update README.md
shannonbux Apr 13, 2020
eb2acd7
feat(recipes): detect if port is used and use a different one (#23076)
KyleAMathews Apr 13, 2020
e5c9a3d
feat(recipes): Tell people recipes is experimental & point them to th…
KyleAMathews Apr 13, 2020
3fd10b4
Update todo
KyleAMathews Apr 13, 2020
4d80e58
feat(recipes): Use the package manager client the user specifies in t…
KyleAMathews Apr 13, 2020
32edae3
feat(recipes): Improve error handling and validation for MDX files an…
johno Apr 13, 2020
c0d111c
chore(recipes): test File resouces with remote file content (#23084)
KyleAMathews Apr 13, 2020
40b0cdc
update todos
KyleAMathews Apr 13, 2020
2ef02d1
Update todos
johno Apr 14, 2020
27376b0
feat(Recipes): Show list of recipes when one isn't passed in (#23086)
KyleAMathews Apr 14, 2020
0e482a2
update todos & add layout recipe to list"
KyleAMathews Apr 14, 2020
69bac1b
feat(recipes): Move recipes to a standalone package (#23108)
johno Apr 14, 2020
a2c264c
Prettier color
KyleAMathews Apr 14, 2020
9acdd11
feat(recipes): Format gatsby-config changes with Prettier (#23112)
KyleAMathews Apr 14, 2020
2225382
Merge branch 'add-recipes' of github.com:gatsbyjs/gatsby into add-rec…
KyleAMathews Apr 14, 2020
197f639
Bigger changes (#23078)
shannonbux Apr 14, 2020
74350b0
feat(recipes): Add more recipes (#23119)
KyleAMathews Apr 14, 2020
0ca5abb
Fix name of <GatsbyShadowFile> and document it
KyleAMathews Apr 14, 2020
feddd5a
feat(recipes): Bundle react libraries into the cli (#23122)
johno Apr 15, 2020
ca5876f
Format
KyleAMathews Apr 15, 2020
4b2d5f5
Fix linting errors
KyleAMathews Apr 15, 2020
d725570
Fix more linting
KyleAMathews Apr 15, 2020
ae658e8
update snapshots
KyleAMathews Apr 15, 2020
ba56623
Squashed commit of the following:
KyleAMathews Apr 15, 2020
b52fc38
update yarn.lock
KyleAMathews Apr 15, 2020
f583af8
Merge branch 'master' into add-recipes
KyleAMathews Apr 15, 2020
b33d513
update eslint recipe
KyleAMathews Apr 15, 2020
d9eb403
fix tests
KyleAMathews Apr 15, 2020
1834ecd
Fix telemetry data
KyleAMathews Apr 15, 2020
8064fb4
chore(recipes): Move recipes code to gatsby-recipes-core (#23138)
KyleAMathews Apr 15, 2020
d7bf2b5
Add codeowners to gatsby-recipes (#23146)
johno Apr 15, 2020
ce0c719
Use dist
KyleAMathews Apr 15, 2020
348d326
chore(recipes): fix stuff (#23154)
KyleAMathews Apr 15, 2020
189abc5
fix(recipes): Update tests and fix babel config, tweak readme (#23152)
johno Apr 15, 2020
3ac2358
Merge branch 'add-recipes' of github.com:gatsbyjs/gatsby into add-rec…
KyleAMathews Apr 15, 2020
71daa66
Make the dependency type 'development' as less repetative
KyleAMathews Apr 15, 2020
3dcc4ab
update docs for release
KyleAMathews Apr 15, 2020
6a41c60
Run prettier
KyleAMathews Apr 16, 2020
64d3651
Fix lint errors
KyleAMathews Apr 16, 2020
3dd8f6c
Update
KyleAMathews Apr 16, 2020
e856272
Have gatsby depend on recipes tag
KyleAMathews Apr 16, 2020
33ee7cf
Fix site build
KyleAMathews Apr 16, 2020
c035e6c
Add note to theme-ui recipe that people need to remove any background…
KyleAMathews Apr 16, 2020
71049cd
Fix remaining package.json inconsistency
johno Apr 16, 2020
1db306b
Remove another failing giphy
KyleAMathews Apr 16, 2020
474ce42
Fix typo in package update
johno Apr 16, 2020
bc6f0e7
Fixing building .org
KyleAMathews Apr 16, 2020
f83132b
fix another
KyleAMathews Apr 16, 2020
9bbf3f4
Remove 404ed starter
KyleAMathews Apr 16, 2020
37bf95e
chore(recipes): Move recipes readme to gatsby-recipes root, add examp…
johno Apr 16, 2020
82ee210
fix(recipes): Don't write out debug log unless env var is set (#23169)
johno Apr 16, 2020
503be2c
fix(recipes): Handle errors during package installs (#23175)
johno Apr 16, 2020
b4da4dc
use what will be stable release version of gatsby-recipes to make ler…
KyleAMathews Apr 16, 2020
8194479
Add raw arguments to the IProgram type
KyleAMathews Apr 16, 2020
9724da4
fix linting error
KyleAMathews Apr 16, 2020
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
feat(recipes): iterate on recipe design (#22911)
  • Loading branch information
KyleAMathews authored Apr 8, 2020
commit a08e7677f9c0fd54eb692aa571d4f2694824b771
120 changes: 103 additions & 17 deletions packages/gatsby/src/recipes/cli.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,8 +3,8 @@ const path = require(`path`)
const { inspect } = require(`util`)

const React = require(`react`)
const { useState, useContext } = require(`react`)
const { render, Box, Text, useInput, useApp } = require(`ink`)
const { useState, useContext, useEffect } = require(`react`)
const { render, Box, Text, useInput, useApp, Static } = require(`ink`)
const Spinner = require(`ink-spinner`).default
const Link = require(`ink-link`)
const MDX = require(`@mdx-js/runtime`)
Expand All @@ -26,6 +26,7 @@ const PlanDescribe = ({ resourceName }) => {
const { planForNextStep = [] } = usePlan()
const plans = planForNextStep.filter(p => p.resourceName === resourceName)

return null
return (
<Box>
{plans.map((stepPlan, i) => (
Expand All @@ -35,9 +36,17 @@ const PlanDescribe = ({ resourceName }) => {
)
}

const Div = props => (
<Box width={80} textWrap="wrap" flexDirection="column" {...props} />
)

const components = {
inlineCode: props => <Text {...props} />,
h1: props => <Text bold underline {...props} />,
h1: props => (
<Div marginBottom={1}>
<Text bold underline {...props} />
</Div>
),
h2: props => <Text bold {...props} />,
h3: props => <Text bold italic {...props} />,
h4: props => <Text bold {...props} />,
Expand All @@ -55,19 +64,15 @@ const components = {
{...props}
/>
),
ul: props => <Div marginBottom={1}>{props.children}</Div>,
li: props => <Text>* {props.children}</Text>,
Config: () => null,
GatsbyPlugin: () => <PlanDescribe resourceName="GatsbyPlugin" />,
NPMPackageJson: () => <PlanDescribe resourceName="NPMPackageJson" />,
NPMPackage: ({ name }) => (
// const { planForNextStep = [] } = usePlan()

<Box>
<Text>* {name}</Text>
</Box>
),
NPMPackage: () => null,
File: () => <PlanDescribe resourceName="File" />,
ShadowFile: () => <PlanDescribe resourceName="ShadowFile" />,
NPMScript: () => null,
}

const isRelative = path => {
Expand Down Expand Up @@ -149,10 +154,6 @@ module.exports = ({ recipe, projectRoot }) => {

const { commands: allCommands, stepsAsMdx: stepsAsMDX } = parsed

const Div = props => (
<Box width={80} textWrap="wrap" flexDirection="column" {...props} />
)

class ErrorBoundary extends React.Component {
constructor(props) {
super(props)
Expand All @@ -179,6 +180,7 @@ module.exports = ({ recipe, projectRoot }) => {
}
}

let renderCount = 1
const RecipeInterpreter = ({ commands }) => {
const [lastKeyPress, setLastKeyPress] = useState(``)
const { exit } = useApp()
Expand Down Expand Up @@ -226,12 +228,20 @@ module.exports = ({ recipe, projectRoot }) => {
}
})

log(`render`, new Date().toJSON())
/*
* TODOs
* on last step w/ no plan just exit
* show what's happened in Static — probably the state machine should put these in new context key.
*/

log(`render`, `${renderCount} ${new Date().toJSON()}`)
renderCount += 1

if (!subscriptionResponse.data) {
return null
}

// If we're done, exit.
if (state.value === `done`) {
process.exit()
}
Expand All @@ -241,14 +251,90 @@ module.exports = ({ recipe, projectRoot }) => {
log(`plan`, state.context.plan)
}

const PresentStep = ({ state }) => {
const isPlan = state.context.plan && state.context.plan.length > 0
const isPresetPlanState = state.value === `present plan`
const isRunningStep = state.value === `applyingPlan`

if (isRunningStep) {
return null
}

if (!isPlan || !isPresetPlanState) {
return (
<Div>
<Text>Press enter to continue</Text>
</Div>
)
}

return (
<Div>
{state.context.plan.map(p => {
return (
<Div key={p.resourceName}>
<Text italic>{p.resourceName}:</Text>
<Text> * {p.describe}</Text>
</Div>
)
})}
<Div marginTop={1}>
<Text>Do you want to run this step? Y/n</Text>
</Div>
</Div>
)
}

const RunningStep = ({ state }) => {
const isPlan = state.context.plan && state.context.plan.length > 0
const isRunningStep = state.value === `applyingPlan`

if (!isPlan || !isRunningStep) {
return null
}

return (
<Div>
{state.context.plan.map(p => {
return (
<Div key={p.resourceName}>
<Text italic>{p.resourceName}:</Text>
<Text>
{` `}
<Spinner /> {p.describe}
</Text>
</Div>
)
})}
</Div>
)
}

// <Static>
// <Text bold>Finished</Text>
// <Text italic>Step 1</Text>
// <Text>✅ Wrote out file to src/pages/what-about-bob.js</Text>
// <Text italic>Step 2</Text>
// <Text>
// ✅ Shadowed file src/gatsby-theme-blog/foo.js from gatsby-theme-blog
// </Text>
// </Static>
return (
<ErrorBoundary>
{state.context.currentStep > 0 && (
<Div>
<Text>
Step {state.context.currentStep} /{` `}
{state.context.steps.length - 1}
</Text>
</Div>
)}
<PlanContext.Provider value={{ planForNextStep: state.plan }}>
<MDX components={components}>
{stepsAsMDX[state.context.currentStep]}
</MDX>
<Text>{` `}</Text>
<Text>Press enter to apply!</Text>
<PresentStep state={state} />
<RunningStep state={state} />
</PlanContext.Provider>
</ErrorBoundary>
)
Expand Down
4 changes: 4 additions & 0 deletions packages/gatsby/src/recipes/create-plan.js
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,10 @@ module.exports = async context => {
const cmds = context.steps[context.currentStep]
const commandPlans = Object.entries(cmds).map(async ([key, val]) => {
const resource = resources[key]
// Filter out the Config resource
if (key === `Config`) {
return
}

// Does this resource support creating a plan?
if (!resource || !resource.plan) {
Expand Down
7 changes: 4 additions & 3 deletions packages/gatsby/src/recipes/eslint.mdx
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
# Add a custom ESLint config

## Introduction to ESLint
ESLint is an open source JavaScript linting utility. Code linting is a type of
static analysis that is frequently used to find problematic patterns. There are
code linters for most programming languages, and compilers sometimes
Expand All @@ -11,19 +12,19 @@ is typically executed in order to find syntax or other errors. Linting tools
like ESLint allow developers to discover problems with their JavaScript code
without executing it.

## How to use ESLint
## Why use this recipe

Gatsby ships with a built-in ESLint setup. For most users,
our built-in ESlint setup is all you need. If you know however that you’d like
to customize your ESlint config e.g. your company has their own custom ESlint
setup, this shows how this can be done.
setup, this recipe sets this up for you.

You’ll replicate (mostly) the ESLint config Gatsby ships with so you can then
add additional presets, plugins, and rules.

---

Installing necessary packages
Install necessary packages

<NPMPackage name="eslint-config-react-app" dependencyType={"dev"} />

Expand Down
13 changes: 8 additions & 5 deletions packages/gatsby/src/recipes/graphql.js
Original file line number Diff line number Diff line change
Expand Up @@ -52,11 +52,14 @@ const applyPlan = plan => {
state: state.value,
currentStep: state.context.currentStep,
})
emitOperation({
context: state.context,
lastEvent: state.event,
value: state.value,
})
// Wait until plans are created before updating the UI
if (state.value !== `creatingPlan`) {
emitOperation({
context: state.context,
lastEvent: state.event,
value: state.value,
})
}
}
})

Expand Down
2 changes: 1 addition & 1 deletion packages/gatsby/src/recipes/providers/gatsby/plugin.js
Original file line number Diff line number Diff line change
Expand Up @@ -245,6 +245,6 @@ module.exports.plan = async ({ root }, { id, name }) => {
name,
currentState: src,
newState: newContents,
describe: `Configure ${fullName}`,
describe: `Install ${fullName} in gatsby-config.js`,
}
}
4 changes: 2 additions & 2 deletions packages/gatsby/src/recipes/providers/npm/script.js
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,7 @@ module.exports.all = async ({ root }) => {
module.exports.plan = async ({ root }, { name, command }) => {
const resource = await read({ root }, name)

const scriptDescription = (name, command) => `"${name}": "${command}`
const scriptDescription = (name, command) => `"${name}": "${command}"`

let currentState = ``
if (resource) {
Expand All @@ -76,7 +76,7 @@ module.exports.plan = async ({ root }, { name, command }) => {
return {
currentState,
newState: scriptDescription(name, command),
describe: `Add new command to your package.json${scriptDescription(
describe: `Add new command to your package.json:\n${scriptDescription(
name,
command
)}`,
Expand Down
9 changes: 5 additions & 4 deletions packages/gatsby/src/recipes/todo.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,13 +6,12 @@
- [x] Run as a command
- [x] Boot up server as a process
- [x] Then run the CLI
- [ ] Clean up server after
- [x] Clean up server after

## Near future

- [x] Make it support relative paths for custom recipes (./src/recipes/foo.mdx)
- [ ] Document the supported components and trivial guide on recipe authoring (help)
- [ ] Theme UI preset selection (runs dependent install and file write)
- [ ] Move to more random port

## alpha
Expand All @@ -21,7 +20,6 @@
- [ ] Make `dependencyType` in NPMPackage an enum
- [ ] Add large warning to recipes output that this is an experimental feature & might change at any moment + link to docs / umbrella issue for bug reports & discussions
- [x] Step by step design
- [ ] Select input supported recipes
- [ ] Make port selection dynamic
- [x] Use `fs-extra`
- [x] Handle object style plugins
Expand All @@ -30,13 +28,16 @@
- [x] convert to xstate
- [ ] reasonably test resources
- [x] add Joi for validating resource objects
- [ ] handle error states
- [x] handle template strings in JSX parser
- [ ] integration test for each resource (read, create, update, delete)
- [ ] show plan to create/update or that nothing is necessary & then show in `<static>` what was done
- [ ] handle error states

## Near-ish future

- [ ] Make a proper "Config" provider to add recipes dir, store data, etc.
- [ ] Move parsing to the server
- [ ] init.js for providers to setup clients
- [ ] validate resource config
- [ ] Theme UI preset selection (runs dependent install and file write)
- [ ] Select input supported recipes