Skip to content
This repository was archived by the owner on Dec 10, 2019. It is now read-only.

Commit 8eba9b1

Browse files
committed
Merge remote-tracking branch 'refs/remotes/upstream/dev' into pattern-engines
2 parents b9e8139 + 029ac93 commit 8eba9b1

File tree

78 files changed

+284
-233
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

78 files changed

+284
-233
lines changed

Gruntfile.js

Lines changed: 27 additions & 27 deletions
Original file line numberDiff line numberDiff line change
@@ -3,7 +3,7 @@ module.exports = function (grunt) {
33
var path = require('path');
44

55
function paths() {
6-
return require('./config.json').paths;
6+
return require('./patternlab-config.json').paths;
77
}
88

99
// Project configuration.
@@ -15,52 +15,52 @@ module.exports = function (grunt) {
1515
banner: '/* \n * <%= pkg.name %> - v<%= pkg.version %> - <%= grunt.template.today("yyyy") %> \n * \n * <%= pkg.author %>, and the web community.\n * Licensed under the <%= pkg.license %> license. \n * \n * Many thanks to Brad Frost and Dave Olsen for inspiration, encouragement, and advice. \n *\n */\n\n',
1616
},
1717
patternlab: {
18-
src: './builder/patternlab.js',
19-
dest: './builder/patternlab.js'
18+
src: './core/lib/patternlab.js',
19+
dest: './core/lib/patternlab.js'
2020
},
2121
object_factory: {
22-
src: './builder/object_factory.js',
23-
dest: './builder/object_factory.js'
22+
src: './core/lib/object_factory.js',
23+
dest: './core/lib/object_factory.js'
2424
},
2525
lineage: {
26-
src: './builder/lineage_hunter.js',
27-
dest: './builder/lineage_hunter.js'
26+
src: './core/lib/lineage_hunter.js',
27+
dest: './core/lib/lineage_hunter.js'
2828
},
2929
media_hunter: {
30-
src: './builder/media_hunter.js',
31-
dest: './builder/media_hunter.js'
30+
src: './core/lib/media_hunter.js',
31+
dest: './core/lib/media_hunter.js'
3232
},
3333
patternlab_grunt: {
34-
src: './builder/patternlab_grunt.js',
35-
dest: './builder/patternlab_grunt.js'
34+
src: './core/lib/patternlab_grunt.js',
35+
dest: './core/lib/patternlab_grunt.js'
3636
},
3737
patternlab_gulp: {
38-
src: './builder/patternlab_gulp.js',
39-
dest: './builder/patternlab_gulp.js'
38+
src: './core/lib/patternlab_gulp.js',
39+
dest: './core/lib/patternlab_gulp.js'
4040
},
4141
parameter_hunter: {
42-
src: './builder/parameter_hunter.js',
43-
dest: './builder/parameter_hunter.js'
42+
src: './core/lib/parameter_hunter.js',
43+
dest: './core/lib/parameter_hunter.js'
4444
},
4545
pattern_exporter: {
46-
src: './builder/pattern_exporter.js',
47-
dest: './builder/pattern_exporter.js'
46+
src: './core/lib/pattern_exporter.js',
47+
dest: './core/lib/pattern_exporter.js'
4848
},
4949
pattern_assembler: {
50-
src: './builder/pattern_assembler.js',
51-
dest: './builder/pattern_assembler.js'
50+
src: './core/lib/pattern_assembler.js',
51+
dest: './core/lib/pattern_assembler.js'
5252
},
5353
pseudopattern_hunter: {
54-
src: './builder/pseudopattern_hunter.js',
55-
dest: './builder/pseudopattern_hunter.js'
54+
src: './core/lib/pseudopattern_hunter.js',
55+
dest: './core/lib/pseudopattern_hunter.js'
5656
},
5757
list_item_hunter: {
58-
src: './builder/list_item_hunter.js',
59-
dest: './builder/list_item_hunter.js'
58+
src: './core/lib/list_item_hunter.js',
59+
dest: './core/lib/list_item_hunter.js'
6060
},
6161
style_modifier_hunter: {
62-
src: './builder/style_modifier_hunter.js',
63-
dest: './builder/style_modifier_hunter.js'
62+
src: './core/lib/style_modifier_hunter.js',
63+
dest: './core/lib/style_modifier_hunter.js'
6464
}
6565
},
6666
copy: {
@@ -142,7 +142,7 @@ module.exports = function (grunt) {
142142
options: {
143143
configFile: './.eslintrc'
144144
},
145-
target: ['./builder/*']
145+
target: ['./core/lib/*']
146146
},
147147
bsReload: {
148148
css: path.resolve(paths().public.root + '**/*.css')
@@ -153,7 +153,7 @@ module.exports = function (grunt) {
153153
require('matchdep').filterDev('grunt-*').forEach(grunt.loadNpmTasks);
154154

155155
//load the patternlab task
156-
grunt.task.loadTasks('./builder/');
156+
grunt.task.loadTasks('./core/lib/');
157157

158158
grunt.registerTask('default', ['patternlab', 'copy:main', 'copy:styleguide']);
159159

README.md

Lines changed: 30 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -34,8 +34,8 @@ This repository ships with two `package.json` files, a `Gruntfile.js`, and a `gu
3434
To run patternlab-node using grunt, do the following in the directory you downloaded and extracted the zipped release:
3535

3636
1. Run `npm install` from the command line
37-
2. Optionally, delete `package.gulp.json`, `gulpfile.js`, and `builder/patternlab_gulp.js` files if you are certain you don't need it.
38-
* Not deleting `builder/patternlab_gulp.js` may cause a harmless error when running grunt. Delete it.
37+
2. Optionally, delete `package.gulp.json`, `gulpfile.js`, and `core/lib/patternlab_gulp.js` files if you are certain you don't need it.
38+
* Not deleting `core/lib/patternlab_gulp.js` may cause a harmless error when running grunt. Delete it.
3939
3. Run `grunt` or `grunt serve` from the command line
4040

4141
This creates all patterns, the styleguide, and the pattern lab site. It's strongly recommended to run `grunt serve` to have BrowserSync spin up and serve the files to you.
@@ -86,7 +86,7 @@ Get more information about patternlab-node, pattern lab in general, and where to
8686
To have patternlab-node watch for changes to either a mustache template, data, or stylesheets, run `grunt|gulp watch` or `grunt|gulp serve`. The `Gruntfile|Gulpfile` governs what is watched. It should be easy to add scss or whatever preprocessor you fancy.
8787

8888
##### Configurable Paths
89-
Pattern Lab Node ships with a particular source and public workflow intended to separate the code you work on with the code generated for consumption elsewhere. If you wish to change any paths, you may do so within `config.json`. The contents are here:
89+
Pattern Lab Node ships with a particular source and public workflow intended to separate the code you work on with the code generated for consumption elsewhere. If you wish to change any paths, you may do so within `patternlab-config.json`. The contents are here:
9090

9191
```
9292
"paths" : {
@@ -117,7 +117,7 @@ Pattern Lab Node ships with a particular source and public workflow intended to
117117
Note the intentional repitition of the nested structure, made this way for maximum flexibility. Relative paths are default but absolute paths should work too. You may also use these paths within Grunt or Gulp files by referring to the paths() object.
118118

119119
##### Nav Bar Controls
120-
If you don't have a need for some of the nav-bar tools in the Pattern Lab frontend, you can turn them off in `config.json`.
120+
If you don't have a need for some of the nav-bar tools in the Pattern Lab frontend, you can turn them off in `patternlab-config.json`.
121121

122122
The current selection is as follows.
123123

@@ -144,7 +144,7 @@ The current selection is as follows.
144144
}
145145
```
146146
##### Pattern States
147-
You can set the state of a pattern by including it in `config.json` too. The out of the box styles are in progress (orange), in review (yellow), and complete (green).
147+
You can set the state of a pattern by including it in `patternlab-config.json` too. The out of the box styles are in progress (orange), in review (yellow), and complete (green).
148148
Pattern states should be lowercase and use hyphens where spaces are present.
149149
```
150150
"patternStates": {
@@ -155,7 +155,7 @@ Pattern states should be lowercase and use hyphens where spaces are present.
155155
```
156156

157157
##### Pattern Export
158-
`config.json` also has two properties that work together to export completed patterns for use in a production environment. Provide an array of keys and an output directory. Pattern Lab doesn't ship with any pattern export keys, but the default directory is `"./pattern_exports/"` created inside the install directory.
158+
`patternlab-config.json` also has two properties that work together to export completed patterns for use in a production environment. Provide an array of keys and an output directory. Pattern Lab doesn't ship with any pattern export keys, but the default directory is `"./pattern_exports/"` created inside the install directory.
159159

160160
```
161161
"patternExportKeys": ["molecules-primary-nav", "organisms-header", "organisms-header"],
@@ -164,6 +164,28 @@ Pattern states should be lowercase and use hyphens where spaces are present.
164164

165165
Coupled with exported css (much easier to extract with existing tools like [grunt-contrib-copy](https://github.com/gruntjs/grunt-contrib-copy)), pattern export can help to maintain the relevancy of the design system by directly placing partials in a directory of your choosing.
166166

167+
##### cacheBust
168+
`patternlab-config.json` has this flag to instruct Pattern Lab to append a unique query string to Javascript and CSS assets throughout the frontend.
169+
170+
```
171+
"cacheBust": true
172+
```
173+
174+
Default: true
175+
176+
##### defaultPattter
177+
`patternlab-config.json` has an entry that allows you to specifiy a specific pattern upon launch of the main site. It works even without BrowserSync running. Set it like this:
178+
179+
```
180+
"defaultPattern": "pages-homepage",
181+
```
182+
Default: "all"
183+
If running with BrowserSync, you may also set [this BrowserSync options](https://www.browsersync.io/docs/options/#option-startPath) to achieve the same result via your Gruntfile or Gulpfile.
184+
185+
```
186+
startPath: '/?p=pages-homepage',
187+
```
188+
167189
##### baseurl
168190

169191
If your instance of Pattern Lab lives in a subdirectory of your server, for instance on github pages (ex: yourusername.github.io/patterns-demo/), then add the baseurl here. The baseurl is everything after the hostname - ie: `patterns-demo`
@@ -182,7 +204,7 @@ You can also exclude complete directories by prepending the directory name with
182204

183205
##### Style Guide Excludes
184206

185-
Exclude whole pattern types from the "All patterns" styleguide by adding entries to `config.json`. This is quite useful to make speedier. Pattern Lab Node ships with the following:
207+
Exclude whole pattern types from the "All patterns" styleguide by adding entries to `patternlab-config.json`. This is quite useful to make speedier. Pattern Lab Node ships with the following:
186208

187209
```
188210
"styleGuideExcludes": [
@@ -193,7 +215,7 @@ Exclude whole pattern types from the "All patterns" styleguide by adding entries
193215

194216

195217
##### Debug Mode
196-
`patternlab.json` is a file created for debugging purposes. Set `debug` to true in `.config.json` to see all the secrets.
218+
`patternlab.json` is a file created for debugging purposes. Set `debug` to true in `.patternlab-config.json` to see all the secrets.
197219

198220
##### Server &amp; BrowserSync
199221
Running `grunt serve` or `gulp serve` will compile the Pattern Lab frontend and host it by default on <a href="http://localhost:3000">http://localhost:3000</a> via [BrowserSync](http://www.browsersync.io/docs/). After it starts, templates, `data.json`, and scss/css changes in your source code will be automatically injected into the page.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.

0 commit comments

Comments
 (0)