Skip to content

Commit

Permalink
Merge pull request #31 from bobmotor/v1.5.2
Browse files Browse the repository at this point in the history
add Docker support, change README.md, fix config name
  • Loading branch information
volodymyr-lisniak authored Dec 2, 2022
2 parents 09838ec + 1daa8d9 commit f7c059b
Show file tree
Hide file tree
Showing 7 changed files with 41 additions and 138 deletions.
151 changes: 29 additions & 122 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,29 +1,21 @@
[![Stand With Ukraine](https://raw.githubusercontent.com/vshymanskyy/StandWithUkraine/main/banner2-direct.svg)](https://stand-with-ukraine.pp.ua)

# Getting Started
## Getting Started

### Check for Node and NPM
This build supports gulp `4.x.x`.
For gulp `3.x.x` use [~1.4.0](/~https://github.com/bobmotor/magento-2-gulp/tree/v1.4.1) version.

Make sure that you've installed Node and NPM before attempting to install gulp (supports gulp `4.x.x`). For gulp `3.x.x` use [~1.4.0](/~https://github.com/bobmotor/magento-2-gulp/tree/v1.4.1) version.
```
$ node -v
```
```
$ npm -v
```
### Install Gulp globally
### Be sure that Node, NPM and Gulp are installed

```
$ npm install gulp -g
```bash
node -v && npm -v && gulp -v
```

## Project integration

- ### Composer

Add repository's path to the `composer.json`

```
```json
"repositories": [
{
"type": "github",
Expand All @@ -34,106 +26,44 @@ Add repository's path to the `composer.json`

Run

```bash
composer require --dev bobmotor/magento-2-gulp
```
$ composer require --dev bobmotor/magento-2-gulp
```

Rename the following files in your project root directory

* `package.json.example` to `package.json`

Install modules listed as dependencies in `package.json`

```
$ npm install
```
or
```
$ yarn
```

- ### Manually

Copy source files to your project root directory


Rename the following files in your project root directory

* `package.json.example` to `package.json`

Install modules listed as dependencies in `package.json`

```
$ npm install
```bash
npm install
```
or
```
$ yarn
```bash
yarn
```

## Configuration

Copy the contents of `themes.js` into `local-themes.js` and add your theme configuration in the `dev/tools/grunt/configs/` directory.

```
module.exports = {
...
<Theme>: {
area: 'frontend|adminhtml',
name: '<Vendor>/<Theme>',
locale: locale,
files: [
'css/styles-m',
'css/styles-l',
],
dsl: 'less'
}
...
}
```

Example:

```
module.exports = {
...
themeName: {
area: 'frontend',
name: 'Package/themeName',
locale: 'en_US',
files: [
'css/styles-m',
'css/styles-l'
],
dsl: 'less'
}
...
}
```
Make sure that you configure `dev/tools/grunt/configs/local-themes.js` file ([adobe docs](https://developer.adobe.com/commerce/frontend-core/guide/tools/grunt/#configuration-file))

Open `dev/tools/gulp/configs/local.js` and set your `hostname` to configure `BrowserSync` and `Critical CSS` urls.
Copy the contents of `local.js.example` into `local.js` in the `dev/tools/gulp/configs/` directory and setup Gulp configuration.

```
```javascript
module.exports = {
hostname: 'hostname',
generic: 'loc',
useHttp2: false
useHttps: false,
useInDocker: false
};
```

Example:

```
module.exports = {
hostname: 'localhost',
generic: 'loc',
useHttp2: true
};
```
### Optionally

If you need to configure `BrowserSync` use the `dev/tools/gulp/configs/bsConfig.js`
* If you need to configure `BrowserSync` use the `dev/tools/gulp/configs/bsConfig.js`

```
```javascript
module.exports = {
proxy: `${ptotocol}://${localConfig.hostname}.${localConfig.generic}/`,
host: `${localConfig.hostname}.${localConfig.generic}`,
Expand All @@ -142,42 +72,19 @@ module.exports = {
};
```

Example:

```
module.exports = {
proxy: `${ptotocol}://${localConfig.hostname}.${localConfig.generic}/`,
host: `${localConfig.hostname}.${localConfig.generic}`,
tunnel: `${localConfig.hostname}`,
open: true
};
```

To configure your desired screen size for the critical path use the `dev/tools/gulp/configs/criticalConfig.js`
* To configure your desired screen size for the critical path use the `dev/tools/gulp/configs/criticalConfig.js`

```
```javascript
module.exports = {
out: 'critical.css',
url: `${ptotocol}://${localConfig.hostname}.${localConfig.generic}/`,
width: 1920,
height: 900,
height: 200,
forceExclude: [/\[data-role=main-css-loader]/]
};
```

Example:

```
module.exports = {
out: 'critical.css',
url: `${ptotocol}://${localConfig.hostname}.${localConfig.generic}/`,
width: 1920,
height: 250,
forceExclude: [/\[data-role=main-css-loader]/]
};
```

### How to use
## How to use

In project root dir run `gulp [command] --[theme] --[arguments]`

Expand Down Expand Up @@ -207,20 +114,20 @@ Options:
Examples:

Removes the theme related static files in the `pub/static` and `var` directories, republishes symlinks to the source files to the `pub/static/frontend/ directory` and compiles CSS files using the symlinks published in the `pub/static/frontend/ directory` with source map and minification.
```
```bash
gulp clean --luma && gulp exec --luma && gulp less --luma --map --min
```
Compiles CSS files using the symlinks published in the `pub/static/frontend/` directory with source map.
```
```bash
gulp less --luma --map
```
Watch styles with `livereload` (`LiveReload` browser extension should be installed)
```
```bash
gulp watch-styles --luma --live
```
Creates `critical.css` from `styles-l.css` and `styles-m.css` and put it to `app/design/frontend/<VandorName>/<ThemeName>/web/css`.
In `production` mode should be run after `php bin/magento s:s:d` (task uses `pub/static/deployed_version.txt` to create absolute path to the static files)
```
```bash
gulp critical --luma
```

Expand Down
2 changes: 1 addition & 1 deletion dev/tools/gulp/configs/bsConfig.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
const localConfig = require('./local');

const ptotocol = localConfig.useHttp2 ? 'https' : 'http';
const ptotocol = localConfig.useHttps ? 'https' : 'http';

module.exports = {
proxy: `${ptotocol}://${localConfig.hostname}.${localConfig.generic}/`,
Expand Down
2 changes: 1 addition & 1 deletion dev/tools/gulp/configs/criticalConfig.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
const localConfig = require('./local');

const ptotocol = localConfig.useHttp2 ? 'https' : 'http';
const ptotocol = localConfig.useHttps ? 'https' : 'http';

module.exports = {
out: 'critical.css',
Expand Down
13 changes: 2 additions & 11 deletions dev/tools/gulp/configs/local.js.example
Original file line number Diff line number Diff line change
@@ -1,15 +1,6 @@
/**
* Absolute Web Services Intellectual Property
*
* @category {development/deployment}
* @copyright Copyright © 1999-2020 Absolute Web Services, Inc. (http://www.absolutewebservices.com)
* @author Absolute Web Services
* @license http://www.absolutewebservices.com/license-agreement/ Single domain license
* @terms of use http://www.absolutewebservices.com/terms-of-use/
*/

module.exports = {
hostname: 'hostname',
generic: 'loc',
useHttp2: false
useHttps: false,
useInDocker: false
};
2 changes: 1 addition & 1 deletion dev/tools/gulp/loggers.js
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,7 @@ module.exports = {
console.log(
color('\nMagento 2 Gulp', 'GREEN'),
color('version', 'WHITE'),
color('1.5.0\n\n', 'YELLOW'),
color('1.5.2\n\n', 'YELLOW'),
color('Usage:\n', 'YELLOW'),
color(' gulp [command] --[package] --[arguments]\n\n', 'WHITE'),
color('Avaliable commands:\n', 'YELLOW'),
Expand Down
7 changes: 6 additions & 1 deletion dev/tools/gulp/tasks/watchStyles.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ const browserSync = require('browser-sync').create();

const args = require('../args');
const bsConfig = require('../configs/bsConfig');
const localConfig = require('../configs/local');
const devArgs = require('../constants/devArgs');
const loggers = require('../loggers');
const matchTheme = require('../matchTheme');
Expand All @@ -30,7 +31,11 @@ module.exports = async () => {
if ({}.hasOwnProperty.call(paths.sources, source)) {
if (args.liveArg >= 0) {
livereload.listen();
gulp.watch([`${paths.sources[source].watch}`], gulp.series('less'));
gulp.watch(
[`${paths.sources[source].watch}`],
{ usePolling: localConfig?.useInDocker },
gulp.series('less')
);
} else if (args.bsArg >= 0) {
gulp.watch([`${paths.sources[source].watch}`], gulp.series('less'));
browserSync.init(bsConfig);
Expand Down
2 changes: 1 addition & 1 deletion package.json.example
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "magento-2-gulp",
"version": "1.5.0",
"version": "1.5.2",
"author": "Volodymyr Lisniak <thebobmotor@gmail.com>",
"description": "Magento 2 node modules dependencies",
"license": "MIT",
Expand Down

0 comments on commit f7c059b

Please sign in to comment.