1
1
mirror of https://github.com/primer/css.git synced 2024-11-23 20:38:58 +03:00

wrap up script/copy w/ --watch flag, add watching to next.config.js

This commit is contained in:
Shawn Allen 2018-12-06 13:23:43 -08:00
parent 29ef33801a
commit 8132c0c330
4 changed files with 52 additions and 42 deletions

View File

@ -6,11 +6,36 @@ const {basename, dirname, join} = require('path')
const {copySync, ensureDirSync, removeSync, writeFileSync} = require('fs-extra') const {copySync, ensureDirSync, removeSync, writeFileSync} = require('fs-extra')
const {getIgnored, setIgnored} = require('./ignore') const {getIgnored, setIgnored} = require('./ignore')
const sourceDir = join(__dirname, '../../modules')
const destDir = join(__dirname, '../pages/css')
const ignoreFile = join(destDir, '.gitignore')
const map = {
'../CHANGELOG.md': 'whats-new/changelog.md',
'primer/README.md': false, // 'packages/primer.md',
'primer-base/README.md': false, // 'support/base.md',
'primer-core/README.md': false, // 'packages/primer-core.md',
'primer-layout/README.md': 'objects/layout.md',
'primer-layout/docs/*.md': path => `objects/${basename(path)}`,
'primer-marketing-support/README.md': 'support/marketing-variables.md',
'primer-marketing-type/README.md': 'utilities/marketing-type.md',
'primer-marketing-utilities/README.md': false, // 'utilities/marketing.md',
'primer-marketing-utilities/docs/*.md': path => `utilities/marketing-${basename(path)}`,
'primer-marketing/README.md': false, // 'packages/primer-marketing.md',
'primer-product/README.md': false, // 'packages/primer-product.md',
'primer-support/README.md': false, // 'support/index.md',
'primer-support/docs/*.md': path => `support/${basename(path)}`,
'primer-table-object/README.md': 'objects/table-object.md',
'primer-utilities/README.md': false, // 'utilities/index.md',
'primer-utilities/docs/*.md': path => `utilities/${basename(path)}`,
// this is a catch-all rule that needs to go last so that it doesn't override others
'primer-*/README.md': path => `components/${shortName(path)}.md`,
}
module.exports = {sync, watch} module.exports = {sync, watch}
function sync({sourceDir, destDir, map, debug = false}) { function sync({debug = false}) {
const log = debug ? console.warn : noop const log = debug ? console.warn : noop
const ignoreFile = join(destDir, '.gitignore')
const ignored = getIgnored(ignoreFile) const ignored = getIgnored(ignoreFile)
for (const file of ignored) { for (const file of ignored) {
log(`${yellow('x')} removing: ${file}`) log(`${yellow('x')} removing: ${file}`)
@ -26,19 +51,24 @@ function sync({sourceDir, destDir, map, debug = false}) {
} }
function watch(options) { function watch(options) {
const globs = Object.keys(map).map(path => join(sourceDir, path)) const {debug = false} = options
const keys = Object.keys(map)
const globs = keys.map(path => join(sourceDir, path))
const log = debug ? console.warn : noop
let timeout let timeout
const update = path => { const update = path => {
if (timeout) return if (timeout) return
timeout = setTimeout(() => { timeout = setTimeout(() => {
copySync(options) log(`${yellow('changed')} ${path}`)
sync(options)
clearTimeout(timeout) clearTimeout(timeout)
timeout = null timeout = null
}, 50) }, 50)
} }
console.warn(`watching: ${globs.map(g => yellow(g)).join(', ')}`) sync(options)
log(`watching in ${yellow(sourceDir)}: ${keys.join(', ')}`)
return chokidar.watch(globs) return chokidar.watch(globs)
.on('add', update) // .on('add', update)
.on('change', update) .on('change', update)
.on('unlink', update) .on('unlink', update)
} }
@ -104,5 +134,9 @@ function getLinks(sourceDir, destDir, map) {
})) }))
} }
function shortName(path) {
return path.match(/primer-([-\w]+)/)[1]
}
function noop() { function noop() {
} }

View File

@ -1,13 +1,17 @@
// this runs synchronously
// require('./copy')
const {join, resolve} = require('path') const {join, resolve} = require('path')
const withPlugins = require('next-compose-plugins') const withPlugins = require('next-compose-plugins')
const configure = require('./lib/config')
const css = require('@zeit/next-css') const css = require('@zeit/next-css')
const sass = require('@zeit/next-sass') const sass = require('@zeit/next-sass')
const configure = require('./lib/config')
const {NODE_ENV, NOW_URL} = process.env const {NODE_ENV, NOW_URL} = process.env
if (!NOW_URL) {
const {watch} = require('./lib/sync')
const watcher = watch({debug: true})
process.on('exit', () => watcher.close())
}
const assetPrefix = NOW_URL || '' const assetPrefix = NOW_URL || ''
module.exports = withPlugins([ module.exports = withPlugins([

View File

@ -6,7 +6,8 @@
"lint": "eslint pages src", "lint": "eslint pages src",
"test": "./test.sh", "test": "./test.sh",
"dev": "next", "dev": "next",
"copy": "node copy.js", "copy": "script/copy",
"watch": "script/copy --watch",
"prebuild": "rm -rf .next", "prebuild": "rm -rf .next",
"build": "next build", "build": "next build",
"start": "next start" "start": "next start"
@ -19,6 +20,7 @@
"@zeit/next-css": "^1.0.1", "@zeit/next-css": "^1.0.1",
"@zeit/next-sass": "^1.0.1", "@zeit/next-sass": "^1.0.1",
"babel-core": "7.0.0-bridge.0", "babel-core": "7.0.0-bridge.0",
"chokidar": "^2.0.4",
"chroma-js": "^1.4.1", "chroma-js": "^1.4.1",
"colorette": "^1.0.7", "colorette": "^1.0.7",
"emotion": "9.2.8", "emotion": "9.2.8",

View File

@ -3,34 +3,8 @@ const {basename, join} = require('path')
const {sync, watch} = require('../lib/sync') const {sync, watch} = require('../lib/sync')
const args = process.argv.slice(2) const args = process.argv.slice(2)
const sourceDir = join(__dirname, '../../modules')
const destDir = join(__dirname, '../pages/css')
const options = { const options = {
sourceDir, debug: !args.includes('--quiet')
destDir,
debug: !args.includes('--quiet'),
map: {
'../CHANGELOG.md': 'whats-new/changelog.md',
'primer/README.md': false, // 'packages/primer.md',
'primer-base/README.md': false, // 'support/base.md',
'primer-core/README.md': false, // 'packages/primer-core.md',
'primer-layout/README.md': 'objects/layout.md',
'primer-layout/docs/*.md': path => `objects/${basename(path)}`,
'primer-marketing-support/README.md': 'support/marketing-variables.md',
'primer-marketing-type/README.md': 'utilities/marketing-type.md',
'primer-marketing-utilities/README.md': false, // 'utilities/marketing.md',
'primer-marketing-utilities/docs/*.md': path => `utilities/marketing-${basename(path)}`,
'primer-marketing/README.md': false, // 'packages/primer-marketing.md',
'primer-product/README.md': false, // 'packages/primer-product.md',
'primer-support/README.md': false, // 'support/index.md',
'primer-support/docs/*.md': path => `support/${basename(path)}`,
'primer-table-object/README.md': 'objects/table-object.md',
'primer-utilities/README.md': false, // 'utilities/index.md',
'primer-utilities/docs/*.md': path => `utilities/${basename(path)}`,
// this is a catch-all rule that needs to go last so that it doesn't override others
'primer-*/README.md': path => `components/${shortName(path)}.md`,
}
} }
if (args.includes('--watch')) { if (args.includes('--watch')) {
@ -39,7 +13,3 @@ if (args.includes('--watch')) {
} else { } else {
sync(options) sync(options)
} }
function shortName(path) {
return path.match(/primer-([-\w]+)/)[1]
}