Skip to content
This repository has been archived by the owner on Jul 19, 2021. It is now read-only.

Commit

Permalink
Simplify assets
Browse files Browse the repository at this point in the history
  • Loading branch information
t-kelly committed Oct 23, 2018
1 parent d3c5c91 commit d9f85b0
Show file tree
Hide file tree
Showing 18 changed files with 424 additions and 400 deletions.
13 changes: 0 additions & 13 deletions packages/html-webpack-liquid-asset-tags-plugin/README.md

This file was deleted.

42 changes: 0 additions & 42 deletions packages/html-webpack-liquid-asset-tags-plugin/index.js

This file was deleted.

13 changes: 0 additions & 13 deletions packages/html-webpack-liquid-asset-tags-plugin/package.json

This file was deleted.

23 changes: 12 additions & 11 deletions packages/slate-config/common/paths.schema.js
Original file line number Diff line number Diff line change
Expand Up @@ -15,18 +15,13 @@ module.exports = {
// Source directory of theme
'paths.theme.src': (config) => path.join(config.get('paths.theme'), 'src'),

'paths.theme.src.assets': (config) =>
path.join(config.get('paths.theme.src'), 'assets'),

// Source of theme configuration files
'paths.theme.src.config': (config) =>
path.join(config.get('paths.theme.src'), 'config'),

// Source font directory for theme
'paths.theme.src.fonts': (config) =>
path.join(config.get('paths.theme.src'), 'assets', 'fonts'),

// Source of images directory
'paths.theme.src.images': (config) =>
path.join(config.get('paths.theme.src'), 'assets', 'images'),

// Source of theme liquid layout files
'paths.theme.src.layouts': (config) =>
path.join(config.get('paths.theme.src'), 'layout'),
Expand All @@ -37,15 +32,15 @@ module.exports = {

// Source scripts directory for theme
'paths.theme.src.scripts': (config) =>
path.join(config.get('paths.theme.src'), 'assets', 'scripts'),
path.join(config.get('paths.theme.src'), 'scripts'),

// Source snippets directory
'paths.theme.src.snippets': (config) =>
path.join(config.get('paths.theme.src'), 'snippets'),

// Static asset directory for files that statically copied to paths.theme.dist.assets
'paths.theme.src.static': (config) =>
path.join(config.get('paths.theme.src'), 'assets', 'static'),
'paths.theme.src.sections': (config) =>
path.join(config.get('paths.theme.src'), 'sections'),

// Main SVG source directory for theme
'paths.theme.src.svgs': (config) =>
Expand Down Expand Up @@ -78,6 +73,12 @@ module.exports = {
'paths.theme.dist.locales': (config) =>
path.join(config.get('paths.theme.dist'), 'locales'),

'paths.theme.dist.sections': (config) =>
path.join(config.get('paths.theme.dist'), 'sections'),

'paths.theme.dist.templates': (config) =>
path.join(config.get('paths.theme.dist'), 'templates'),

// Directory for storing all temporary and/or cache files
'paths.theme.cache': (config) =>
path.join(config.get('paths.theme'), '.cache'),
Expand Down
3 changes: 0 additions & 3 deletions packages/slate-liquid-asset-loader/README.md

This file was deleted.

76 changes: 0 additions & 76 deletions packages/slate-liquid-asset-loader/index.js

This file was deleted.

17 changes: 0 additions & 17 deletions packages/slate-liquid-asset-loader/package.json

This file was deleted.

4 changes: 1 addition & 3 deletions packages/slate-tools/slate-tools.schema.js
Original file line number Diff line number Diff line change
Expand Up @@ -109,7 +109,5 @@ module.exports = {
'webpack.cssnano.settings': {zindex: false, reduceIdents: false},

// Object which contains entrypoints used in webpack's config.entry key
'webpack.entrypoints': {
static: path.resolve(__dirname, 'tools/webpack/static-files-glob.js'),
},
'webpack.entrypoints': {},
};
5 changes: 5 additions & 0 deletions packages/slate-tools/tools/asset-server/app.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,13 +3,18 @@ const webpackHotMiddleware = require('webpack-hot-middleware');
const corsMiddleware = require('cors');
const express = require('express');

const {isHotUpdateFile} = require('../utilities');

module.exports = class App {
constructor(compiler) {
const app = express();

app.webpackDevMiddleware = webpackDevMiddleware(compiler, {
logLevel: 'silent',
reload: true,
writeToDisk: (filePath) => {
return !isHotUpdateFile(filePath);
},
});
app.webpackHotMiddleware = webpackHotMiddleware(compiler, {
log: false,
Expand Down
22 changes: 11 additions & 11 deletions packages/slate-tools/tools/asset-server/client.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,32 +7,32 @@ module.exports = class Client {
this.skipNextSync = false;
this.files = [];
this.hooks = {
beforeSync: new AsyncSeriesHook(['files']),
sync: new SyncHook(['files']),
syncDone: new SyncHook(['files']),
afterSync: new AsyncSeriesHook(['files']),
syncSkipped: new SyncHook(['files']),
beforeSync: new AsyncSeriesHook(['files', 'stats']),
sync: new SyncHook(['files', 'stats']),
syncDone: new SyncHook(['files', 'stats']),
afterSync: new AsyncSeriesHook(['files', 'stats']),
syncSkipped: new SyncHook(['files', 'stats']),
};
}

async sync(files) {
async sync(files, stats) {
this.files = files;

await this.hooks.beforeSync.promise(this.files);
await this.hooks.beforeSync.promise(this.files, stats);

if (this.files.length === 0) {
this.skipNextSync = true;
}

if (this.skipNextSync) {
this.hooks.syncSkipped.call(this.files);
this.hooks.syncSkipped.call(this.files, stats);
} else {
this.hooks.sync.call(this.files);
this.hooks.sync.call(this.files, stats);
await sync(this.files);
this.hooks.syncDone.call(this.files);
this.hooks.syncDone.call(this.files, stats);
}

this.hooks.afterSync.promise(this.files);
this.hooks.afterSync.promise(this.files, stats);

this.skipNextSync = false;
}
Expand Down
37 changes: 26 additions & 11 deletions packages/slate-tools/tools/asset-server/index.js
Original file line number Diff line number Diff line change
@@ -1,12 +1,11 @@
const fs = require('fs');
const webpack = require('webpack');
const {createServer} = require('https');
const createHash = require('crypto').createHash;
const SlateConfig = require('@shopify/slate-config');

const App = require('./app');
const Client = require('./client');
const {sslKeyCert} = require('../utilities');
const {sslKeyCert, isHotUpdateFile} = require('../utilities');
const config = new SlateConfig(require('../../slate-tools.schema'));

module.exports = class DevServer {
Expand All @@ -16,6 +15,7 @@ module.exports = class DevServer {
}/`;

this.assetHashes = {};
this.chunkHashes = {};
this.domain = options.domain;
this.options = options;
this.port = options.port;
Expand Down Expand Up @@ -48,32 +48,47 @@ module.exports = class DevServer {
}

_onCompileDone(stats) {
const files = this._getChangedLiquidFiles(stats);
const files = this._getAssetsToUpload(stats);

return this.client.sync(files);
return this.client.sync(files, stats);
}

_onAfterSync(files) {
// Send an event to webpackHotMiddleware to force a page reload if there are
// files that require it.
this.app.webpackHotMiddleware.publish({
action: 'shopify_upload_finished',
force: files.length > 0,
});
}

_getChangedLiquidFiles(stats) {
_isChunk(key, chunks) {
return (
chunks.filter((chunk) => {
return key.indexOf(chunk.id) > -1;
}).length > 0
);
}

_hasAssetChanged(key, asset) {
const oldHash = this.assetHashes[key];
const newHash = this._updateAssetHash(key, asset);

return oldHash !== newHash;
}

_getAssetsToUpload(stats) {
const assets = Object.entries(stats.compilation.assets);
const chunks = stats.compilation.chunks;

return (
assets
.filter(([key, asset]) => {
const oldHash = this.assetHashes[key];
const newHash = this._updateAssetHash(key, asset);

return (
asset.emitted &&
(/\.liquid$/.test(key) || /\.json$/.test(key)) &&
fs.existsSync(asset.existsAt) &&
oldHash !== newHash
!this._isChunk(key, chunks) &&
!isHotUpdateFile(key) &&
this._hasAssetChanged(key, asset)
);
})
/* eslint-disable-next-line no-unused-vars */
Expand Down
5 changes: 5 additions & 0 deletions packages/slate-tools/tools/utilities/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,10 @@ const config = new SlateConfig(require('../../slate-tools.schema'));

const findAPortInUse = promisify(portscanner.findAPortInUse);

function isHotUpdateFile(key) {
return /\.hot-update\.json$/.test(key) || /\.hot-update\.js$/.test(key);
}

function sslKeyCert() {
const key = readFileSync(getSSLKeyPath());
const cert = readFileSync(getSSLCertPath());
Expand Down Expand Up @@ -53,4 +57,5 @@ module.exports = {
getSSLKeyPath,
getSSLCertPath,
getAvailablePortSeries,
isHotUpdateFile,
};
Loading

0 comments on commit d9f85b0

Please sign in to comment.