Modules all the way
This commit is contained in:
@@ -14,12 +14,12 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"plugins": [
|
"plugins": [
|
||||||
"config/jsdoc/api/plugins/markdown",
|
"config/jsdoc/api/plugins/markdown.cjs",
|
||||||
"jsdoc-plugin-typescript",
|
"jsdoc-plugin-typescript",
|
||||||
"config/jsdoc/api/plugins/inline-options",
|
"config/jsdoc/api/plugins/inline-options.cjs",
|
||||||
"config/jsdoc/api/plugins/events",
|
"config/jsdoc/api/plugins/events.cjs",
|
||||||
"config/jsdoc/api/plugins/observable",
|
"config/jsdoc/api/plugins/observable.cjs",
|
||||||
"config/jsdoc/api/plugins/api"
|
"config/jsdoc/api/plugins/api.cjs"
|
||||||
],
|
],
|
||||||
"typescript": {
|
"typescript": {
|
||||||
"moduleRoot": "src"
|
"moduleRoot": "src"
|
||||||
|
|||||||
@@ -1,3 +1,5 @@
|
|||||||
|
/* eslint-disable import/no-commonjs */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Define an @api tag
|
* Define an @api tag
|
||||||
* @param {Object} dictionary The tag dictionary.
|
* @param {Object} dictionary The tag dictionary.
|
||||||
@@ -1,3 +1,5 @@
|
|||||||
|
/* eslint-disable import/no-commonjs */
|
||||||
|
|
||||||
const events = {};
|
const events = {};
|
||||||
|
|
||||||
exports.handlers = {
|
exports.handlers = {
|
||||||
@@ -1,3 +1,5 @@
|
|||||||
|
/* eslint-disable import/no-commonjs */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @fileoverview
|
* @fileoverview
|
||||||
* Inlines option params from typedefs
|
* Inlines option params from typedefs
|
||||||
@@ -1,3 +1,5 @@
|
|||||||
|
/* eslint-disable import/no-commonjs */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Modified from JSDoc's plugins/markdown and lib/jsdoc/util/markdown modules
|
* Modified from JSDoc's plugins/markdown and lib/jsdoc/util/markdown modules
|
||||||
* (see https://github.com/jsdoc3/jsdoc/), which are licensed under the Apache 2
|
* (see https://github.com/jsdoc3/jsdoc/), which are licensed under the Apache 2
|
||||||
@@ -1,3 +1,5 @@
|
|||||||
|
/* eslint-disable import/no-commonjs */
|
||||||
|
|
||||||
const classes = {};
|
const classes = {};
|
||||||
const observables = {};
|
const observables = {};
|
||||||
|
|
||||||
@@ -1,3 +1,5 @@
|
|||||||
|
/* eslint-disable import/no-commonjs */
|
||||||
|
|
||||||
/*global env: true */
|
/*global env: true */
|
||||||
|
|
||||||
const hasOwnProp = Object.prototype.hasOwnProperty;
|
const hasOwnProp = Object.prototype.hasOwnProperty;
|
||||||
|
|||||||
@@ -11,8 +11,8 @@
|
|||||||
},
|
},
|
||||||
"plugins": [
|
"plugins": [
|
||||||
"jsdoc-plugin-typescript",
|
"jsdoc-plugin-typescript",
|
||||||
"config/jsdoc/info/define-plugin",
|
"config/jsdoc/info/define-plugin.cjs",
|
||||||
"config/jsdoc/info/virtual-plugin"
|
"config/jsdoc/info/virtual-plugin.cjs"
|
||||||
],
|
],
|
||||||
"typescript": {
|
"typescript": {
|
||||||
"moduleRoot": "src"
|
"moduleRoot": "src"
|
||||||
|
|||||||
@@ -1,3 +1,5 @@
|
|||||||
|
/* eslint-disable import/no-commonjs */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @fileoverview This plugin extracts info from boolean defines. This only
|
* @fileoverview This plugin extracts info from boolean defines. This only
|
||||||
* handles boolean defines with the default value in the description. Default
|
* handles boolean defines with the default value in the description. Default
|
||||||
@@ -1,3 +1,5 @@
|
|||||||
|
/* eslint-disable import/no-commonjs */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @fileoverview Generates JSON output based on exportable symbols.
|
* @fileoverview Generates JSON output based on exportable symbols.
|
||||||
*/
|
*/
|
||||||
|
|||||||
@@ -1,3 +1,5 @@
|
|||||||
|
/* eslint-disable import/no-commonjs */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handle the interface and abstract annotations.
|
* Handle the interface and abstract annotations.
|
||||||
* @param {Object} dictionary The tag dictionary.
|
* @param {Object} dictionary The tag dictionary.
|
||||||
4
config/jsdoc/package.json
Normal file
4
config/jsdoc/package.json
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
{
|
||||||
|
"description": "JSDoc loads publish.js files with require(), so we need to configure everything under this path as a CommonJS module.",
|
||||||
|
"type": "commonjs"
|
||||||
|
}
|
||||||
@@ -1,7 +1,10 @@
|
|||||||
const path = require('path');
|
import TerserPlugin from 'terser-webpack-plugin';
|
||||||
const TerserPlugin = require('terser-webpack-plugin');
|
import path, {dirname} from 'path';
|
||||||
|
import {fileURLToPath} from 'url';
|
||||||
|
|
||||||
module.exports = {
|
const baseDir = dirname(fileURLToPath(import.meta.url));
|
||||||
|
|
||||||
|
export default {
|
||||||
entry: './build/index.js',
|
entry: './build/index.js',
|
||||||
devtool: 'source-map',
|
devtool: 'source-map',
|
||||||
mode: 'production',
|
mode: 'production',
|
||||||
@@ -18,7 +21,7 @@ module.exports = {
|
|||||||
},
|
},
|
||||||
include: [
|
include: [
|
||||||
path.join(
|
path.join(
|
||||||
__dirname,
|
baseDir,
|
||||||
'..',
|
'..',
|
||||||
'node_modules',
|
'node_modules',
|
||||||
'@mapbox',
|
'@mapbox',
|
||||||
|
|||||||
@@ -5,12 +5,5 @@
|
|||||||
},
|
},
|
||||||
"parserOptions": {
|
"parserOptions": {
|
||||||
"ecmaVersion": 2017
|
"ecmaVersion": 2017
|
||||||
},
|
|
||||||
"rules": {
|
|
||||||
"space-before-function-paren": ["error", {
|
|
||||||
"anonymous": "never",
|
|
||||||
"named": "never",
|
|
||||||
"asyncArrow": "always"
|
|
||||||
}]
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,12 +1,15 @@
|
|||||||
const TerserPlugin = require('terser-webpack-plugin');
|
import CopyPlugin from 'copy-webpack-plugin';
|
||||||
const CopyPlugin = require('copy-webpack-plugin');
|
import ExampleBuilder from './example-builder.js';
|
||||||
const ExampleBuilder = require('./example-builder');
|
import TerserPlugin from 'terser-webpack-plugin';
|
||||||
const fs = require('fs');
|
import fs from 'fs';
|
||||||
const path = require('path');
|
import path, {dirname} from 'path';
|
||||||
|
import {fileURLToPath} from 'url';
|
||||||
|
|
||||||
const src = path.join(__dirname, '..');
|
const baseDir = dirname(fileURLToPath(import.meta.url));
|
||||||
|
|
||||||
module.exports = {
|
const src = path.join(baseDir, '..');
|
||||||
|
|
||||||
|
export default {
|
||||||
context: src,
|
context: src,
|
||||||
target: ['web', 'es5'],
|
target: ['web', 'es5'],
|
||||||
entry: () => {
|
entry: () => {
|
||||||
@@ -33,10 +36,10 @@ module.exports = {
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
include: [
|
include: [
|
||||||
path.join(__dirname, '..', '..', 'src'),
|
path.join(baseDir, '..', '..', 'src'),
|
||||||
path.join(__dirname, '..'),
|
path.join(baseDir, '..'),
|
||||||
path.join(
|
path.join(
|
||||||
__dirname,
|
baseDir,
|
||||||
'..',
|
'..',
|
||||||
'..',
|
'..',
|
||||||
'node_modules',
|
'node_modules',
|
||||||
@@ -48,9 +51,9 @@ module.exports = {
|
|||||||
{
|
{
|
||||||
test: /\.js$/,
|
test: /\.js$/,
|
||||||
use: {
|
use: {
|
||||||
loader: path.join(__dirname, 'worker-loader.js'),
|
loader: path.join(baseDir, 'worker-loader.cjs'),
|
||||||
},
|
},
|
||||||
include: [path.join(__dirname, '..', '..', 'src', 'ol', 'worker')],
|
include: [path.join(baseDir, '..', '..', 'src', 'ol', 'worker')],
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
@@ -77,7 +80,7 @@ module.exports = {
|
|||||||
},
|
},
|
||||||
plugins: [
|
plugins: [
|
||||||
new ExampleBuilder({
|
new ExampleBuilder({
|
||||||
templates: path.join(__dirname, '..', 'templates'),
|
templates: path.join(baseDir, '..', 'templates'),
|
||||||
common: 'common',
|
common: 'common',
|
||||||
}),
|
}),
|
||||||
new CopyPlugin({
|
new CopyPlugin({
|
||||||
@@ -93,7 +96,7 @@ module.exports = {
|
|||||||
devtool: 'source-map',
|
devtool: 'source-map',
|
||||||
output: {
|
output: {
|
||||||
filename: '[name].js',
|
filename: '[name].js',
|
||||||
path: path.join(__dirname, '..', '..', 'build', 'examples'),
|
path: path.join(baseDir, '..', '..', 'build', 'examples'),
|
||||||
},
|
},
|
||||||
resolve: {
|
resolve: {
|
||||||
fallback: {
|
fallback: {
|
||||||
@@ -101,7 +104,7 @@ module.exports = {
|
|||||||
},
|
},
|
||||||
alias: {
|
alias: {
|
||||||
// allow imports from 'ol/module' instead of specifiying the source path
|
// allow imports from 'ol/module' instead of specifiying the source path
|
||||||
ol: path.join(__dirname, '..', '..', 'src', 'ol'),
|
ol: path.join(baseDir, '..', '..', 'src', 'ol'),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -1,20 +1,32 @@
|
|||||||
const assert = require('assert');
|
import assert from 'assert';
|
||||||
const frontMatter = require('front-matter');
|
import frontMatter from 'front-matter';
|
||||||
const fs = require('fs');
|
import fse from 'fs-extra';
|
||||||
const handlebars = require('handlebars');
|
import handlebars from 'handlebars';
|
||||||
const marked = require('marked');
|
import marked from 'marked';
|
||||||
const path = require('path');
|
import path, {dirname} from 'path';
|
||||||
const pkg = require('../../package.json');
|
import sources from 'webpack-sources';
|
||||||
const promisify = require('util').promisify;
|
import {fileURLToPath} from 'url';
|
||||||
const RawSource = require('webpack-sources').RawSource;
|
|
||||||
|
const RawSource = sources.RawSource;
|
||||||
|
const baseDir = dirname(fileURLToPath(import.meta.url));
|
||||||
|
|
||||||
const readFile = promisify(fs.readFile);
|
|
||||||
const isCssRegEx = /\.css(\?.*)?$/;
|
const isCssRegEx = /\.css(\?.*)?$/;
|
||||||
const isJsRegEx = /\.js(\?.*)?$/;
|
const isJsRegEx = /\.js(\?.*)?$/;
|
||||||
const importRegEx = /^import .* from '(.*)';$/;
|
const importRegEx = /^import .* from '(.*)';$/;
|
||||||
const isTemplateJs = /\/(jquery(-\d+\.\d+\.\d+)?|(bootstrap(\.bundle)?))(\.min)?\.js(\?.*)?$/;
|
const isTemplateJs = /\/(jquery(-\d+\.\d+\.\d+)?|(bootstrap(\.bundle)?))(\.min)?\.js(\?.*)?$/;
|
||||||
const isTemplateCss = /\/bootstrap(\.min)?\.css(\?.*)?$/;
|
const isTemplateCss = /\/bootstrap(\.min)?\.css(\?.*)?$/;
|
||||||
|
|
||||||
|
let cachedPackageInfo = null;
|
||||||
|
async function getPackageInfo() {
|
||||||
|
if (cachedPackageInfo) {
|
||||||
|
return cachedPackageInfo;
|
||||||
|
}
|
||||||
|
cachedPackageInfo = await fse.readJSON(
|
||||||
|
path.resolve(baseDir, '../../package.json')
|
||||||
|
);
|
||||||
|
return cachedPackageInfo;
|
||||||
|
}
|
||||||
|
|
||||||
handlebars.registerHelper(
|
handlebars.registerHelper(
|
||||||
'md',
|
'md',
|
||||||
(str) => new handlebars.SafeString(marked(str))
|
(str) => new handlebars.SafeString(marked(str))
|
||||||
@@ -111,9 +123,10 @@ function createWordIndex(exampleData) {
|
|||||||
/**
|
/**
|
||||||
* Gets dependencies from the js source.
|
* Gets dependencies from the js source.
|
||||||
* @param {string} jsSource Source.
|
* @param {string} jsSource Source.
|
||||||
|
* @param {Object} pkg Package info.
|
||||||
* @return {Object<string, string>} dependencies
|
* @return {Object<string, string>} dependencies
|
||||||
*/
|
*/
|
||||||
function getDependencies(jsSource) {
|
function getDependencies(jsSource, pkg) {
|
||||||
const lines = jsSource.split('\n');
|
const lines = jsSource.split('\n');
|
||||||
const dependencies = {
|
const dependencies = {
|
||||||
ol: pkg.version,
|
ol: pkg.version,
|
||||||
@@ -140,7 +153,7 @@ function getDependencies(jsSource) {
|
|||||||
return dependencies;
|
return dependencies;
|
||||||
}
|
}
|
||||||
|
|
||||||
class ExampleBuilder {
|
export default class ExampleBuilder {
|
||||||
/**
|
/**
|
||||||
* A webpack plugin that builds the html files for our examples.
|
* A webpack plugin that builds the html files for our examples.
|
||||||
* @param {Object} config Plugin configuration. Requires a `templates` property
|
* @param {Object} config Plugin configuration. Requires a `templates` property
|
||||||
@@ -241,16 +254,17 @@ class ExampleBuilder {
|
|||||||
async parseExample(dir, name) {
|
async parseExample(dir, name) {
|
||||||
const htmlName = `${name}.html`;
|
const htmlName = `${name}.html`;
|
||||||
const htmlPath = path.join(dir, htmlName);
|
const htmlPath = path.join(dir, htmlName);
|
||||||
const htmlSource = await readFile(htmlPath, {encoding: 'utf8'});
|
const htmlSource = await fse.readFile(htmlPath, {encoding: 'utf8'});
|
||||||
|
|
||||||
const jsName = `${name}.js`;
|
const jsName = `${name}.js`;
|
||||||
const jsPath = path.join(dir, jsName);
|
const jsPath = path.join(dir, jsName);
|
||||||
const jsSource = await readFile(jsPath, {encoding: 'utf8'});
|
const jsSource = await fse.readFile(jsPath, {encoding: 'utf8'});
|
||||||
|
|
||||||
const {attributes, body} = frontMatter(htmlSource);
|
const {attributes, body} = frontMatter(htmlSource);
|
||||||
assert(!!attributes.layout, `missing layout in ${htmlPath}`);
|
assert(!!attributes.layout, `missing layout in ${htmlPath}`);
|
||||||
const data = Object.assign(attributes, {contents: body});
|
const data = Object.assign(attributes, {contents: body});
|
||||||
|
|
||||||
|
const pkg = await getPackageInfo();
|
||||||
data.olVersion = pkg.version;
|
data.olVersion = pkg.version;
|
||||||
data.filename = htmlName;
|
data.filename = htmlName;
|
||||||
data.dir = dir;
|
data.dir = dir;
|
||||||
@@ -299,7 +313,7 @@ class ExampleBuilder {
|
|||||||
const workerPath = path.join(data.dir, workerName);
|
const workerPath = path.join(data.dir, workerName);
|
||||||
let workerSource;
|
let workerSource;
|
||||||
try {
|
try {
|
||||||
workerSource = await readFile(workerPath, readOptions);
|
workerSource = await fse.readFile(workerPath, readOptions);
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
// pass
|
// pass
|
||||||
}
|
}
|
||||||
@@ -321,11 +335,14 @@ class ExampleBuilder {
|
|||||||
assets[workerName] = workerSource;
|
assets[workerName] = workerSource;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const pkg = await getPackageInfo();
|
||||||
|
|
||||||
data.pkgJson = JSON.stringify(
|
data.pkgJson = JSON.stringify(
|
||||||
{
|
{
|
||||||
name: data.name,
|
name: data.name,
|
||||||
dependencies: getDependencies(
|
dependencies: getDependencies(
|
||||||
jsSource + (workerSource ? `\n${workerSource}` : '')
|
jsSource + (workerSource ? `\n${workerSource}` : ''),
|
||||||
|
pkg
|
||||||
),
|
),
|
||||||
devDependencies: {
|
devDependencies: {
|
||||||
parcel: '^2.0.0-beta.1',
|
parcel: '^2.0.0-beta.1',
|
||||||
@@ -344,7 +361,7 @@ class ExampleBuilder {
|
|||||||
const cssPath = path.join(data.dir, cssName);
|
const cssPath = path.join(data.dir, cssName);
|
||||||
let cssSource;
|
let cssSource;
|
||||||
try {
|
try {
|
||||||
cssSource = await readFile(cssPath, readOptions);
|
cssSource = await fse.readFile(cssPath, readOptions);
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
// pass
|
// pass
|
||||||
}
|
}
|
||||||
@@ -358,6 +375,7 @@ class ExampleBuilder {
|
|||||||
|
|
||||||
// add additional resources
|
// add additional resources
|
||||||
if (data.resources) {
|
if (data.resources) {
|
||||||
|
const pkg = await getPackageInfo();
|
||||||
const localResources = [];
|
const localResources = [];
|
||||||
const remoteResources = [];
|
const remoteResources = [];
|
||||||
data.resources.forEach((resource) => {
|
data.resources.forEach((resource) => {
|
||||||
@@ -389,11 +407,9 @@ class ExampleBuilder {
|
|||||||
}
|
}
|
||||||
|
|
||||||
const templatePath = path.join(this.templates, data.layout);
|
const templatePath = path.join(this.templates, data.layout);
|
||||||
const templateSource = await readFile(templatePath, readOptions);
|
const templateSource = await fse.readFile(templatePath, readOptions);
|
||||||
|
|
||||||
assets[data.filename] = handlebars.compile(templateSource)(data);
|
assets[data.filename] = handlebars.compile(templateSource)(data);
|
||||||
return assets;
|
return assets;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
module.exports = ExampleBuilder;
|
|
||||||
|
|||||||
@@ -1,6 +1,8 @@
|
|||||||
const build = require('../../tasks/serialize-workers').build;
|
/* eslint-disable import/no-commonjs */
|
||||||
|
|
||||||
function loader() {
|
const build = require('../../tasks/serialize-workers.cjs').build;
|
||||||
|
|
||||||
|
module.exports = function loader() {
|
||||||
const callback = this.async();
|
const callback = this.async();
|
||||||
const minify = this.mode === 'production';
|
const minify = this.mode === 'production';
|
||||||
|
|
||||||
@@ -12,6 +14,4 @@ function loader() {
|
|||||||
callback(null, chunk.code);
|
callback(null, chunk.code);
|
||||||
})
|
})
|
||||||
.catch(callback);
|
.catch(callback);
|
||||||
}
|
};
|
||||||
|
|
||||||
module.exports = loader;
|
|
||||||
62
package-lock.json
generated
62
package-lock.json
generated
@@ -15,6 +15,7 @@
|
|||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@babel/core": "^7.6.4",
|
"@babel/core": "^7.6.4",
|
||||||
|
"@babel/eslint-parser": "^7.13.14",
|
||||||
"@babel/preset-env": "^7.4.4",
|
"@babel/preset-env": "^7.4.4",
|
||||||
"@openlayers/eslint-plugin": "^4.0.0",
|
"@openlayers/eslint-plugin": "^4.0.0",
|
||||||
"@rollup/plugin-babel": "^5.3.0",
|
"@rollup/plugin-babel": "^5.3.0",
|
||||||
@@ -32,6 +33,7 @@
|
|||||||
"copy-webpack-plugin": "^8.0.0",
|
"copy-webpack-plugin": "^8.0.0",
|
||||||
"coverage-istanbul-loader": "^3.0.5",
|
"coverage-istanbul-loader": "^3.0.5",
|
||||||
"coveralls": "3.1.0",
|
"coveralls": "3.1.0",
|
||||||
|
"es-main": "^1.0.2",
|
||||||
"eslint": "^7.2.0",
|
"eslint": "^7.2.0",
|
||||||
"eslint-config-openlayers": "^15.0.0",
|
"eslint-config-openlayers": "^15.0.0",
|
||||||
"expect.js": "0.3.1",
|
"expect.js": "0.3.1",
|
||||||
@@ -66,7 +68,7 @@
|
|||||||
"shx": "^0.3.2",
|
"shx": "^0.3.2",
|
||||||
"sinon": "^10.0.0",
|
"sinon": "^10.0.0",
|
||||||
"terser-webpack-plugin": "^5.1.1",
|
"terser-webpack-plugin": "^5.1.1",
|
||||||
"typescript": "^4.2.3",
|
"typescript": "^4.2.4",
|
||||||
"url-polyfill": "^1.1.5",
|
"url-polyfill": "^1.1.5",
|
||||||
"walk": "^2.3.9",
|
"walk": "^2.3.9",
|
||||||
"webpack": "^5.27.2",
|
"webpack": "^5.27.2",
|
||||||
@@ -127,6 +129,33 @@
|
|||||||
"url": "https://opencollective.com/babel"
|
"url": "https://opencollective.com/babel"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"node_modules/@babel/eslint-parser": {
|
||||||
|
"version": "7.13.14",
|
||||||
|
"resolved": "https://registry.npmjs.org/@babel/eslint-parser/-/eslint-parser-7.13.14.tgz",
|
||||||
|
"integrity": "sha512-I0HweR36D73Ibn/FfrRDMKlMqJHFwidIUgYdMpH+aXYuQC+waq59YaJ6t9e9N36axJ82v1jR041wwqDrDXEwRA==",
|
||||||
|
"dev": true,
|
||||||
|
"dependencies": {
|
||||||
|
"eslint-scope": "^5.1.0",
|
||||||
|
"eslint-visitor-keys": "^1.3.0",
|
||||||
|
"semver": "^6.3.0"
|
||||||
|
},
|
||||||
|
"engines": {
|
||||||
|
"node": "^10.13.0 || ^12.13.0 || >=14.0.0"
|
||||||
|
},
|
||||||
|
"peerDependencies": {
|
||||||
|
"@babel/core": ">=7.11.0",
|
||||||
|
"eslint": ">=7.5.0"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"node_modules/@babel/eslint-parser/node_modules/eslint-visitor-keys": {
|
||||||
|
"version": "1.3.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz",
|
||||||
|
"integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==",
|
||||||
|
"dev": true,
|
||||||
|
"engines": {
|
||||||
|
"node": ">=4"
|
||||||
|
}
|
||||||
|
},
|
||||||
"node_modules/@babel/generator": {
|
"node_modules/@babel/generator": {
|
||||||
"version": "7.13.16",
|
"version": "7.13.16",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.13.16.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.13.16.tgz",
|
||||||
@@ -3631,6 +3660,12 @@
|
|||||||
"url": "https://github.com/sponsors/ljharb"
|
"url": "https://github.com/sponsors/ljharb"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"node_modules/es-main": {
|
||||||
|
"version": "1.0.2",
|
||||||
|
"resolved": "https://registry.npmjs.org/es-main/-/es-main-1.0.2.tgz",
|
||||||
|
"integrity": "sha512-LLgW8Cby/FiyQygrI23q2EswulHiDKoyjWlDRgTGXjQ3iRim2R26VfoehpxI5oKRXSNams3L/80KtggoUdxdDQ==",
|
||||||
|
"dev": true
|
||||||
|
},
|
||||||
"node_modules/es-module-lexer": {
|
"node_modules/es-module-lexer": {
|
||||||
"version": "0.4.1",
|
"version": "0.4.1",
|
||||||
"resolved": "https://registry.npmjs.org/es-module-lexer/-/es-module-lexer-0.4.1.tgz",
|
"resolved": "https://registry.npmjs.org/es-module-lexer/-/es-module-lexer-0.4.1.tgz",
|
||||||
@@ -11410,6 +11445,25 @@
|
|||||||
"source-map": "^0.5.0"
|
"source-map": "^0.5.0"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"@babel/eslint-parser": {
|
||||||
|
"version": "7.13.14",
|
||||||
|
"resolved": "https://registry.npmjs.org/@babel/eslint-parser/-/eslint-parser-7.13.14.tgz",
|
||||||
|
"integrity": "sha512-I0HweR36D73Ibn/FfrRDMKlMqJHFwidIUgYdMpH+aXYuQC+waq59YaJ6t9e9N36axJ82v1jR041wwqDrDXEwRA==",
|
||||||
|
"dev": true,
|
||||||
|
"requires": {
|
||||||
|
"eslint-scope": "^5.1.0",
|
||||||
|
"eslint-visitor-keys": "^1.3.0",
|
||||||
|
"semver": "^6.3.0"
|
||||||
|
},
|
||||||
|
"dependencies": {
|
||||||
|
"eslint-visitor-keys": {
|
||||||
|
"version": "1.3.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz",
|
||||||
|
"integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==",
|
||||||
|
"dev": true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"@babel/generator": {
|
"@babel/generator": {
|
||||||
"version": "7.13.16",
|
"version": "7.13.16",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.13.16.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.13.16.tgz",
|
||||||
@@ -14260,6 +14314,12 @@
|
|||||||
"unbox-primitive": "^1.0.0"
|
"unbox-primitive": "^1.0.0"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"es-main": {
|
||||||
|
"version": "1.0.2",
|
||||||
|
"resolved": "https://registry.npmjs.org/es-main/-/es-main-1.0.2.tgz",
|
||||||
|
"integrity": "sha512-LLgW8Cby/FiyQygrI23q2EswulHiDKoyjWlDRgTGXjQ3iRim2R26VfoehpxI5oKRXSNams3L/80KtggoUdxdDQ==",
|
||||||
|
"dev": true
|
||||||
|
},
|
||||||
"es-module-lexer": {
|
"es-module-lexer": {
|
||||||
"version": "0.4.1",
|
"version": "0.4.1",
|
||||||
"resolved": "https://registry.npmjs.org/es-module-lexer/-/es-module-lexer-0.4.1.tgz",
|
"resolved": "https://registry.npmjs.org/es-module-lexer/-/es-module-lexer-0.4.1.tgz",
|
||||||
|
|||||||
19
package.json
19
package.json
@@ -15,21 +15,21 @@
|
|||||||
"test-rendering": "node test/rendering/test.js",
|
"test-rendering": "node test/rendering/test.js",
|
||||||
"test-spec": "npm run karma -- --single-run --log-level error",
|
"test-spec": "npm run karma -- --single-run --log-level error",
|
||||||
"test": "npm run test-spec && npm run test-rendering -- --force",
|
"test": "npm run test-spec && npm run test-rendering -- --force",
|
||||||
"karma": "karma start test/browser/karma.config.js",
|
"karma": "karma start test/browser/karma.config.cjs",
|
||||||
"start": "npm run serve-examples",
|
"start": "npm run serve-examples",
|
||||||
"serve-examples": "webpack serve --config examples/webpack/config.js --mode development",
|
"serve-examples": "webpack serve --config examples/webpack/config.js --mode development",
|
||||||
"build-examples": "webpack --config examples/webpack/config.js --mode production",
|
"build-examples": "webpack --config examples/webpack/config.js --mode production",
|
||||||
"build-package": "npm run transpile && npm run copy-css && node tasks/prepare-package",
|
"build-package": "npm run transpile && npm run copy-css && node tasks/prepare-package.js",
|
||||||
"build-index": "npm run build-package && node tasks/generate-index",
|
"build-index": "npm run build-package && node tasks/generate-index.js",
|
||||||
"build-legacy": "shx rm -rf build && npm run build-index && webpack --config config/webpack-config-legacy-build.js && cleancss --source-map src/ol/ol.css -o build/legacy/ol.css",
|
"build-legacy": "shx rm -rf build && npm run build-index && webpack --config config/webpack-config-legacy-build.js && cleancss --source-map src/ol/ol.css -o build/legacy/ol.css",
|
||||||
"build-site": "npm run build-examples && npm run apidoc && mkdir -p build/site && cp site/index.html build/site && mv build/apidoc build/site/apidoc && mv build/examples build/site/examples",
|
"build-site": "npm run build-examples && npm run apidoc && mkdir -p build/site && cp site/index.html build/site && mv build/apidoc build/site/apidoc && mv build/examples build/site/examples",
|
||||||
"copy-css": "shx cp src/ol/ol.css build/ol/ol.css",
|
"copy-css": "shx cp src/ol/ol.css build/ol/ol.css",
|
||||||
"transpile": "shx rm -rf build/ol && shx mkdir -p build/ol && shx cp -rf src/ol build/ol/src && node tasks/serialize-workers && tsc --project config/tsconfig-build.json",
|
"transpile": "shx rm -rf build/ol && shx mkdir -p build/ol && shx cp -rf src/ol build/ol/src && node tasks/serialize-workers.cjs && tsc --project config/tsconfig-build.json",
|
||||||
"typecheck": "tsc --pretty",
|
"typecheck": "tsc --pretty",
|
||||||
"apidoc-debug": "shx rm -rf build/apidoc && node --inspect-brk=9229 ./node_modules/jsdoc/jsdoc.js -R config/jsdoc/api/index.md -c config/jsdoc/api/conf.json -P package.json -d build/apidoc",
|
"apidoc-debug": "shx rm -rf build/apidoc && node --inspect-brk=9229 ./node_modules/jsdoc/jsdoc.js -R config/jsdoc/api/index.md -c config/jsdoc/api/conf.json -P package.json -d build/apidoc",
|
||||||
"apidoc": "shx rm -rf build/apidoc && jsdoc -R config/jsdoc/api/index.md -c config/jsdoc/api/conf.json -P package.json -d build/apidoc"
|
"apidoc": "shx rm -rf build/apidoc && jsdoc -R config/jsdoc/api/index.md -c config/jsdoc/api/conf.json -P package.json -d build/apidoc"
|
||||||
},
|
},
|
||||||
"main": "index.js",
|
"type": "module",
|
||||||
"repository": {
|
"repository": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "git://github.com/openlayers/openlayers.git"
|
"url": "git://github.com/openlayers/openlayers.git"
|
||||||
@@ -49,6 +49,7 @@
|
|||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@babel/core": "^7.6.4",
|
"@babel/core": "^7.6.4",
|
||||||
|
"@babel/eslint-parser": "^7.13.14",
|
||||||
"@babel/preset-env": "^7.4.4",
|
"@babel/preset-env": "^7.4.4",
|
||||||
"@openlayers/eslint-plugin": "^4.0.0",
|
"@openlayers/eslint-plugin": "^4.0.0",
|
||||||
"@rollup/plugin-babel": "^5.3.0",
|
"@rollup/plugin-babel": "^5.3.0",
|
||||||
@@ -66,6 +67,7 @@
|
|||||||
"copy-webpack-plugin": "^8.0.0",
|
"copy-webpack-plugin": "^8.0.0",
|
||||||
"coverage-istanbul-loader": "^3.0.5",
|
"coverage-istanbul-loader": "^3.0.5",
|
||||||
"coveralls": "3.1.0",
|
"coveralls": "3.1.0",
|
||||||
|
"es-main": "^1.0.2",
|
||||||
"eslint": "^7.2.0",
|
"eslint": "^7.2.0",
|
||||||
"eslint-config-openlayers": "^15.0.0",
|
"eslint-config-openlayers": "^15.0.0",
|
||||||
"expect.js": "0.3.1",
|
"expect.js": "0.3.1",
|
||||||
@@ -100,7 +102,7 @@
|
|||||||
"shx": "^0.3.2",
|
"shx": "^0.3.2",
|
||||||
"sinon": "^10.0.0",
|
"sinon": "^10.0.0",
|
||||||
"terser-webpack-plugin": "^5.1.1",
|
"terser-webpack-plugin": "^5.1.1",
|
||||||
"typescript": "^4.2.3",
|
"typescript": "^4.2.4",
|
||||||
"url-polyfill": "^1.1.5",
|
"url-polyfill": "^1.1.5",
|
||||||
"walk": "^2.3.9",
|
"walk": "^2.3.9",
|
||||||
"webpack": "^5.27.2",
|
"webpack": "^5.27.2",
|
||||||
@@ -113,10 +115,15 @@
|
|||||||
},
|
},
|
||||||
"eslintConfig": {
|
"eslintConfig": {
|
||||||
"extends": "openlayers",
|
"extends": "openlayers",
|
||||||
|
"parser": "@babel/eslint-parser",
|
||||||
|
"parserOptions": {
|
||||||
|
"requireConfigFile": false
|
||||||
|
},
|
||||||
"plugins": [
|
"plugins": [
|
||||||
"@openlayers"
|
"@openlayers"
|
||||||
],
|
],
|
||||||
"rules": {
|
"rules": {
|
||||||
|
"import/no-commonjs": "error",
|
||||||
"@openlayers/no-exclusive-tests": [
|
"@openlayers/no-exclusive-tests": [
|
||||||
"error",
|
"error",
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -1,6 +1,9 @@
|
|||||||
const fse = require('fs-extra');
|
import esMain from 'es-main';
|
||||||
const path = require('path');
|
import fse from 'fs-extra';
|
||||||
const generateInfo = require('./generate-info');
|
import generateInfo from './generate-info.js';
|
||||||
|
import path from 'path';
|
||||||
|
import {dirname} from 'path';
|
||||||
|
import {fileURLToPath} from 'url';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Read the symbols from info file.
|
* Read the symbols from info file.
|
||||||
@@ -21,11 +24,11 @@ function getImport(symbol, member) {
|
|||||||
const defaultExport = symbol.name.split('~');
|
const defaultExport = symbol.name.split('~');
|
||||||
const namedExport = symbol.name.split('.');
|
const namedExport = symbol.name.split('.');
|
||||||
if (defaultExport.length > 1 && defaultExport[0].indexOf('.') === -1) {
|
if (defaultExport.length > 1 && defaultExport[0].indexOf('.') === -1) {
|
||||||
const from = defaultExport[0].replace(/^module\:/, './');
|
const from = defaultExport[0].replace(/^module\:/, './') + '.js';
|
||||||
const importName = from.replace(/[.\/]+/g, '$');
|
const importName = from.replace(/[.\/]+/g, '$');
|
||||||
return `import ${importName} from '${from}';`;
|
return `import ${importName} from '${from}';`;
|
||||||
} else if (namedExport.length > 1 && member) {
|
} else if (namedExport.length > 1 && member) {
|
||||||
const from = namedExport[0].replace(/^module\:/, './');
|
const from = namedExport[0].replace(/^module\:/, './') + '.js';
|
||||||
const importName = from.replace(/[.\/]+/g, '_');
|
const importName = from.replace(/[.\/]+/g, '_');
|
||||||
return `import {${member} as ${importName}$${member}} from '${from}';`;
|
return `import {${member} as ${importName}$${member}} from '${from}';`;
|
||||||
}
|
}
|
||||||
@@ -97,7 +100,7 @@ function generateExports(symbols) {
|
|||||||
* Generate the exports code.
|
* Generate the exports code.
|
||||||
* @return {Promise<string>} Resolves with the exports code.
|
* @return {Promise<string>} Resolves with the exports code.
|
||||||
*/
|
*/
|
||||||
async function main() {
|
export default async function main() {
|
||||||
const symbols = await getSymbols();
|
const symbols = await getSymbols();
|
||||||
return generateExports(symbols);
|
return generateExports(symbols);
|
||||||
}
|
}
|
||||||
@@ -106,18 +109,15 @@ async function main() {
|
|||||||
* If running this module directly, read the config file, call the main
|
* If running this module directly, read the config file, call the main
|
||||||
* function, and write the output file.
|
* function, and write the output file.
|
||||||
*/
|
*/
|
||||||
if (require.main === module) {
|
if (esMain(import.meta)) {
|
||||||
|
const baseDir = dirname(fileURLToPath(import.meta.url));
|
||||||
|
|
||||||
main()
|
main()
|
||||||
.then(async (code) => {
|
.then(async (code) => {
|
||||||
const filepath = path.join(__dirname, '..', 'build', 'index.js');
|
const filepath = path.join(baseDir, '..', 'build', 'index.js');
|
||||||
await fse.outputFile(filepath, code);
|
await fse.outputFile(filepath, code);
|
||||||
})
|
})
|
||||||
.catch((err) => {
|
.catch((err) => {
|
||||||
process.stderr.write(`${err.message}\n`, () => process.exit(1));
|
process.stderr.write(`${err.message}\n`, () => process.exit(1));
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Export main function.
|
|
||||||
*/
|
|
||||||
module.exports = main;
|
|
||||||
|
|||||||
@@ -1,11 +1,16 @@
|
|||||||
const fse = require('fs-extra');
|
import esMain from 'es-main';
|
||||||
const path = require('path');
|
import fse from 'fs-extra';
|
||||||
const spawn = require('child_process').spawn;
|
import path from 'path';
|
||||||
const walk = require('walk').walk;
|
import {dirname} from 'path';
|
||||||
const isWindows = process.platform.indexOf('win') === 0;
|
import {fileURLToPath} from 'url';
|
||||||
|
import {spawn} from 'child_process';
|
||||||
|
import {walk} from 'walk';
|
||||||
|
|
||||||
const sourceDir = path.join(__dirname, '..', 'src');
|
const isWindows = process.platform.indexOf('win') === 0;
|
||||||
const infoPath = path.join(__dirname, '..', 'build', 'info.json');
|
const baseDir = dirname(fileURLToPath(import.meta.url));
|
||||||
|
|
||||||
|
const sourceDir = path.join(baseDir, '..', 'src');
|
||||||
|
const infoPath = path.join(baseDir, '..', 'build', 'info.json');
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get checked path of a binary.
|
* Get checked path of a binary.
|
||||||
@@ -17,9 +22,15 @@ function getBinaryPath(binaryName) {
|
|||||||
binaryName += '.cmd';
|
binaryName += '.cmd';
|
||||||
}
|
}
|
||||||
|
|
||||||
const jsdocResolved = require.resolve('jsdoc/jsdoc.js');
|
const jsdocResolved = path.join(
|
||||||
|
baseDir,
|
||||||
|
'..',
|
||||||
|
'node_modules',
|
||||||
|
'jsdoc',
|
||||||
|
'jsdoc.js'
|
||||||
|
);
|
||||||
const expectedPaths = [
|
const expectedPaths = [
|
||||||
path.join(__dirname, '..', 'node_modules', '.bin', binaryName),
|
path.join(baseDir, '..', 'node_modules', '.bin', binaryName),
|
||||||
path.resolve(
|
path.resolve(
|
||||||
path.join(path.dirname(jsdocResolved), '..', '.bin', binaryName)
|
path.join(path.dirname(jsdocResolved), '..', '.bin', binaryName)
|
||||||
),
|
),
|
||||||
@@ -40,7 +51,7 @@ function getBinaryPath(binaryName) {
|
|||||||
const jsdoc = getBinaryPath('jsdoc');
|
const jsdoc = getBinaryPath('jsdoc');
|
||||||
|
|
||||||
const jsdocConfig = path.join(
|
const jsdocConfig = path.join(
|
||||||
__dirname,
|
baseDir,
|
||||||
'..',
|
'..',
|
||||||
'config',
|
'config',
|
||||||
'jsdoc',
|
'jsdoc',
|
||||||
@@ -120,7 +131,7 @@ function spawnJSDoc(paths) {
|
|||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
let output = '';
|
let output = '';
|
||||||
let errors = '';
|
let errors = '';
|
||||||
const cwd = path.join(__dirname, '..');
|
const cwd = path.join(baseDir, '..');
|
||||||
const child = spawn(jsdoc, ['-c', jsdocConfig].concat(paths), {cwd: cwd});
|
const child = spawn(jsdoc, ['-c', jsdocConfig].concat(paths), {cwd: cwd});
|
||||||
|
|
||||||
child.stdout.on('data', (data) => {
|
child.stdout.on('data', (data) => {
|
||||||
@@ -162,7 +173,7 @@ async function write(info) {
|
|||||||
* Generate info from the sources.
|
* Generate info from the sources.
|
||||||
* @return {Promise<Error>} Resolves with the info object.
|
* @return {Promise<Error>} Resolves with the info object.
|
||||||
*/
|
*/
|
||||||
async function main() {
|
export default async function main() {
|
||||||
const paths = await getPaths();
|
const paths = await getPaths();
|
||||||
return await spawnJSDoc(paths);
|
return await spawnJSDoc(paths);
|
||||||
}
|
}
|
||||||
@@ -170,15 +181,10 @@ async function main() {
|
|||||||
/**
|
/**
|
||||||
* If running this module directly, generate and write out the info.json file.
|
* If running this module directly, generate and write out the info.json file.
|
||||||
*/
|
*/
|
||||||
if (require.main === module) {
|
if (esMain(import.meta)) {
|
||||||
main()
|
main()
|
||||||
.then(write)
|
.then(write)
|
||||||
.catch((err) => {
|
.catch((err) => {
|
||||||
process.stderr.write(`${err.message}\n`, () => process.exit(1));
|
process.stderr.write(`${err.message}\n`, () => process.exit(1));
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Export main function.
|
|
||||||
*/
|
|
||||||
module.exports = main;
|
|
||||||
|
|||||||
@@ -1,7 +1,11 @@
|
|||||||
const version = require('../package.json').version;
|
import esMain from 'es-main';
|
||||||
const semver = require('semver');
|
import process from 'process';
|
||||||
|
import semver from 'semver';
|
||||||
|
import {promises as fs} from 'fs';
|
||||||
|
|
||||||
function nextVersion() {
|
async function nextVersion() {
|
||||||
|
const pkg = await fs.readFile('../package.json', {encoding: 'utf8'});
|
||||||
|
const version = JSON.parse(pkg).version;
|
||||||
const s = semver.parse(version);
|
const s = semver.parse(version);
|
||||||
if (!s) {
|
if (!s) {
|
||||||
throw new Error(`Invalid version ${version}`);
|
throw new Error(`Invalid version ${version}`);
|
||||||
@@ -9,6 +13,13 @@ function nextVersion() {
|
|||||||
return `${s.major}.${s.minor}.${s.patch}-dev.${Date.now()}`;
|
return `${s.major}.${s.minor}.${s.patch}-dev.${Date.now()}`;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (require.main === module) {
|
if (esMain(import.meta)) {
|
||||||
process.stdout.write(`${nextVersion()}\n`);
|
nextVersion()
|
||||||
|
.then((version) => {
|
||||||
|
process.stdout.write(`${version}\n`);
|
||||||
|
})
|
||||||
|
.catch((error) => {
|
||||||
|
process.stderr.write(`${error}\n`);
|
||||||
|
process.exit(1);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,35 +1,49 @@
|
|||||||
const fs = require('fs');
|
import esMain from 'es-main';
|
||||||
const path = require('path');
|
import fse from 'fs-extra';
|
||||||
const pkg = require('../package.json');
|
import path from 'path';
|
||||||
|
import {dirname} from 'path';
|
||||||
|
import {fileURLToPath} from 'url';
|
||||||
|
|
||||||
const buildDir = path.resolve(__dirname, '../build/ol');
|
const baseDir = dirname(fileURLToPath(import.meta.url));
|
||||||
|
const buildDir = path.resolve(baseDir, '../build/ol');
|
||||||
|
|
||||||
// update the version number in util.js
|
async function main() {
|
||||||
const utilPath = path.join(buildDir, 'util.js');
|
const pkg = await fse.readJSON(path.resolve(baseDir, '../package.json'));
|
||||||
const versionRegEx = /var VERSION = '(.*)';/g;
|
|
||||||
const utilSrc = fs
|
|
||||||
.readFileSync(utilPath, 'utf-8')
|
|
||||||
.replace(versionRegEx, `var VERSION = '${pkg.version}';`);
|
|
||||||
fs.writeFileSync(utilPath, utilSrc, 'utf-8');
|
|
||||||
|
|
||||||
// write out simplified package.json
|
// update the version number in util.js
|
||||||
delete pkg.scripts;
|
const utilPath = path.join(buildDir, 'util.js');
|
||||||
delete pkg.devDependencies;
|
const versionRegEx = /var VERSION = '(.*)';/g;
|
||||||
delete pkg.style;
|
let utilSrc = await fse.readFile(utilPath, 'utf-8');
|
||||||
delete pkg.eslintConfig;
|
utilSrc = utilSrc.replace(versionRegEx, `var VERSION = '${pkg.version}';`);
|
||||||
delete pkg.private;
|
await fse.writeFile(utilPath, utilSrc, 'utf-8');
|
||||||
fs.writeFileSync(
|
|
||||||
path.join(buildDir, 'package.json'),
|
|
||||||
JSON.stringify(pkg, null, 2),
|
|
||||||
'utf-8'
|
|
||||||
);
|
|
||||||
|
|
||||||
// copy in readme and license files
|
// write out simplified package.json
|
||||||
fs.copyFileSync(
|
pkg.main = 'index.js';
|
||||||
path.resolve(__dirname, '../README.md'),
|
delete pkg.scripts;
|
||||||
path.join(buildDir, 'README.md')
|
delete pkg.devDependencies;
|
||||||
);
|
delete pkg.style;
|
||||||
fs.copyFileSync(
|
delete pkg.eslintConfig;
|
||||||
path.resolve(__dirname, '../LICENSE.md'),
|
delete pkg.private;
|
||||||
path.join(buildDir, 'LICENSE.md')
|
await fse.writeJSON(path.join(buildDir, 'package.json'), pkg, {spaces: 2});
|
||||||
);
|
|
||||||
|
// copy in readme and license files
|
||||||
|
await fse.copyFile(
|
||||||
|
path.resolve(baseDir, '../README.md'),
|
||||||
|
path.join(buildDir, 'README.md')
|
||||||
|
);
|
||||||
|
|
||||||
|
await fse.copyFile(
|
||||||
|
path.resolve(baseDir, '../LICENSE.md'),
|
||||||
|
path.join(buildDir, 'LICENSE.md')
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* If running this module directly, read the config file, call the main
|
||||||
|
* function, and write the output file.
|
||||||
|
*/
|
||||||
|
if (esMain(import.meta)) {
|
||||||
|
main().catch((err) => {
|
||||||
|
process.stderr.write(`${err.message}\n`, () => process.exit(1));
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|||||||
@@ -1,3 +1,5 @@
|
|||||||
|
/* eslint-disable import/no-commonjs */
|
||||||
|
|
||||||
const path = require('path');
|
const path = require('path');
|
||||||
const babel = require('@rollup/plugin-babel').babel;
|
const babel = require('@rollup/plugin-babel').babel;
|
||||||
const resolve = require('@rollup/plugin-node-resolve').nodeResolve;
|
const resolve = require('@rollup/plugin-node-resolve').nodeResolve;
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
// require all modules ending in ".test.js" from the
|
|
||||||
// current directory and all subdirectories
|
|
||||||
const testsContext = require.context('./spec', true, /\.test\.js$/);
|
|
||||||
|
|
||||||
testsContext.keys().forEach(testsContext);
|
|
||||||
@@ -1,3 +1,5 @@
|
|||||||
|
/* eslint-disable import/no-commonjs */
|
||||||
|
|
||||||
const path = require('path');
|
const path = require('path');
|
||||||
|
|
||||||
module.exports = function (karma) {
|
module.exports = function (karma) {
|
||||||
@@ -45,7 +47,7 @@ module.exports = function (karma) {
|
|||||||
pattern: path.resolve(__dirname, './test-extensions.js'),
|
pattern: path.resolve(__dirname, './test-extensions.js'),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
pattern: path.resolve(__dirname, './index_test.js'),
|
pattern: 'spec/**/*.test.js',
|
||||||
watched: false,
|
watched: false,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -54,7 +56,6 @@ module.exports = function (karma) {
|
|||||||
watched: false,
|
watched: false,
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
exclude: ['**/*.test.js'],
|
|
||||||
proxies: {
|
proxies: {
|
||||||
'/spec/': '/base/spec/',
|
'/spec/': '/base/spec/',
|
||||||
},
|
},
|
||||||
@@ -99,7 +100,7 @@ module.exports = function (karma) {
|
|||||||
use: {
|
use: {
|
||||||
loader: path.join(
|
loader: path.join(
|
||||||
__dirname,
|
__dirname,
|
||||||
'../../examples/webpack/worker-loader.js'
|
'../../examples/webpack/worker-loader.cjs'
|
||||||
),
|
),
|
||||||
},
|
},
|
||||||
include: [path.join(__dirname, '../../src/ol/worker')],
|
include: [path.join(__dirname, '../../src/ol/worker')],
|
||||||
@@ -1,18 +1,24 @@
|
|||||||
#! /usr/bin/env node
|
#! /usr/bin/env node
|
||||||
const puppeteer = require('puppeteer');
|
import config from './webpack.config.js';
|
||||||
const webpack = require('webpack');
|
import esMain from 'es-main';
|
||||||
const config = require('./webpack.config');
|
import express from 'express';
|
||||||
const webpackMiddleware = require('webpack-dev-middleware');
|
import fs from 'fs';
|
||||||
const express = require('express');
|
import fse from 'fs-extra';
|
||||||
const path = require('path');
|
import globby from 'globby';
|
||||||
const png = require('pngjs');
|
import log from 'loglevelnext';
|
||||||
const fs = require('fs');
|
import path from 'path';
|
||||||
const fse = require('fs-extra');
|
import pixelmatch from 'pixelmatch';
|
||||||
const pixelmatch = require('pixelmatch');
|
import png from 'pngjs';
|
||||||
const yargs = require('yargs');
|
import puppeteer from 'puppeteer';
|
||||||
const log = require('loglevelnext');
|
import serveStatic from 'serve-static';
|
||||||
const globby = require('globby');
|
import webpack from 'webpack';
|
||||||
const serveStatic = require('serve-static');
|
import webpackMiddleware from 'webpack-dev-middleware';
|
||||||
|
import yargs from 'yargs';
|
||||||
|
import {dirname} from 'path';
|
||||||
|
import {fileURLToPath} from 'url';
|
||||||
|
import {hideBin} from 'yargs/helpers';
|
||||||
|
|
||||||
|
const baseDir = dirname(fileURLToPath(import.meta.url));
|
||||||
|
|
||||||
const compiler = webpack(Object.assign({mode: 'development'}, config));
|
const compiler = webpack(Object.assign({mode: 'development'}, config));
|
||||||
|
|
||||||
@@ -20,11 +26,11 @@ function getHref(entry) {
|
|||||||
return path.dirname(entry).slice(1) + '/';
|
return path.dirname(entry).slice(1) + '/';
|
||||||
}
|
}
|
||||||
|
|
||||||
const staticHandler = serveStatic(__dirname);
|
const staticHandler = serveStatic(baseDir);
|
||||||
|
|
||||||
const defaultHandler = serveStatic(path.join(__dirname, 'default'));
|
const defaultHandler = serveStatic(path.join(baseDir, 'default'));
|
||||||
|
|
||||||
const srcHandler = serveStatic(path.join(__dirname, '..', '..', 'src'));
|
const srcHandler = serveStatic(path.join(baseDir, '..', '..', 'src'));
|
||||||
|
|
||||||
function indexHandler(req, res) {
|
function indexHandler(req, res) {
|
||||||
const items = [];
|
const items = [];
|
||||||
@@ -91,15 +97,15 @@ function serve(options) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function getActualScreenshotPath(entry) {
|
function getActualScreenshotPath(entry) {
|
||||||
return path.join(__dirname, path.dirname(entry), 'actual.png');
|
return path.join(baseDir, path.dirname(entry), 'actual.png');
|
||||||
}
|
}
|
||||||
|
|
||||||
function getExpectedScreenshotPath(entry) {
|
function getExpectedScreenshotPath(entry) {
|
||||||
return path.join(__dirname, path.dirname(entry), 'expected.png');
|
return path.join(baseDir, path.dirname(entry), 'expected.png');
|
||||||
}
|
}
|
||||||
|
|
||||||
function getPassFilePath(entry) {
|
function getPassFilePath(entry) {
|
||||||
return path.join(__dirname, path.dirname(entry), 'pass');
|
return path.join(baseDir, path.dirname(entry), 'pass');
|
||||||
}
|
}
|
||||||
|
|
||||||
function parsePNG(filepath) {
|
function parsePNG(filepath) {
|
||||||
@@ -284,7 +290,7 @@ async function getLatest(patterns) {
|
|||||||
|
|
||||||
async function getOutdated(entries, options) {
|
async function getOutdated(entries, options) {
|
||||||
const libTime = await getLatest(
|
const libTime = await getLatest(
|
||||||
path.join(__dirname, '..', 'src', 'ol', '**', '*')
|
path.join(baseDir, '..', 'src', 'ol', '**', '*')
|
||||||
);
|
);
|
||||||
options.log.debug('library time', libTime);
|
options.log.debug('library time', libTime);
|
||||||
const outdated = [];
|
const outdated = [];
|
||||||
@@ -298,7 +304,7 @@ async function getOutdated(entries, options) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
const caseTime = await getLatest(
|
const caseTime = await getLatest(
|
||||||
path.join(__dirname, path.dirname(entry), '**', '*')
|
path.join(baseDir, path.dirname(entry), '**', '*')
|
||||||
);
|
);
|
||||||
options.log.debug('case time', entry, caseTime);
|
options.log.debug('case time', entry, caseTime);
|
||||||
if (passTime < caseTime) {
|
if (passTime < caseTime) {
|
||||||
@@ -337,8 +343,8 @@ function sleep(ms) {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
if (require.main === module) {
|
if (esMain(import.meta)) {
|
||||||
const options = yargs
|
const options = yargs(hideBin(process.argv))
|
||||||
.option('fix', {
|
.option('fix', {
|
||||||
describe: 'Accept all screenshots as accepted',
|
describe: 'Accept all screenshots as accepted',
|
||||||
type: 'boolean',
|
type: 'boolean',
|
||||||
|
|||||||
@@ -1,7 +1,10 @@
|
|||||||
const fs = require('fs');
|
import fs from 'fs';
|
||||||
const path = require('path');
|
import path, {dirname} from 'path';
|
||||||
|
import {fileURLToPath} from 'url';
|
||||||
|
|
||||||
const cases = path.join(__dirname, 'cases');
|
const baseDir = dirname(fileURLToPath(import.meta.url));
|
||||||
|
|
||||||
|
const cases = path.join(baseDir, 'cases');
|
||||||
|
|
||||||
const caseDirs = fs.readdirSync(cases).filter((name) => {
|
const caseDirs = fs.readdirSync(cases).filter((name) => {
|
||||||
let exists = true;
|
let exists = true;
|
||||||
@@ -18,8 +21,8 @@ caseDirs.forEach((c) => {
|
|||||||
entry[`cases/${c}/main`] = `./cases/${c}/main.js`;
|
entry[`cases/${c}/main`] = `./cases/${c}/main.js`;
|
||||||
});
|
});
|
||||||
|
|
||||||
module.exports = {
|
export default {
|
||||||
context: __dirname,
|
context: baseDir,
|
||||||
target: 'web',
|
target: 'web',
|
||||||
entry: entry,
|
entry: entry,
|
||||||
devtool: 'source-map',
|
devtool: 'source-map',
|
||||||
@@ -30,18 +33,18 @@ module.exports = {
|
|||||||
test: /\.js$/,
|
test: /\.js$/,
|
||||||
use: {
|
use: {
|
||||||
loader: path.join(
|
loader: path.join(
|
||||||
__dirname,
|
baseDir,
|
||||||
'../../examples/webpack/worker-loader.js'
|
'../../examples/webpack/worker-loader.cjs'
|
||||||
),
|
),
|
||||||
},
|
},
|
||||||
include: [path.join(__dirname, '../../src/ol/worker')],
|
include: [path.join(baseDir, '../../src/ol/worker')],
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
resolve: {
|
resolve: {
|
||||||
alias: {
|
alias: {
|
||||||
// ol-mapbox-style imports ol/style/Style etc
|
// ol-mapbox-style imports ol/style/Style etc
|
||||||
ol: path.join(__dirname, '..', '..', 'src', 'ol'),
|
ol: path.join(baseDir, '..', '..', 'src', 'ol'),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user