summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--.jshintrc4
-rw-r--r--bower.json23
-rw-r--r--gulpfile.js2
-rw-r--r--tasks/cdn.js26
-rw-r--r--tasks/config.js1
-rw-r--r--tasks/docsite.js7
6 files changed, 46 insertions, 17 deletions
diff --git a/.jshintrc b/.jshintrc
new file mode 100644
index 0000000..59f01b9
--- /dev/null
+++ b/.jshintrc
@@ -0,0 +1,4 @@
+{
+ "node": true,
+ "esnext": true
+}
diff --git a/bower.json b/bower.json
index deb2a6a..1b852bb 100644
--- a/bower.json
+++ b/bower.json
@@ -4,7 +4,7 @@
"authors": [
"Vaadin Ltd"
],
- "description": "Vaadin Core Elements is an evolving set of free, open sourced custom HTML elements, built using Polymer, for building mobile and desktop web applications in modern browsers.",
+ "description": "Vaadin Core Elements is an evolving set of free, open sourced custom HTML elements, built using Polymer.",
"license": "Apache-2.0",
"keywords": [
"vaadin",
@@ -24,11 +24,11 @@
"**/tests"
],
"dependencies": {
- "vaadin-grid": "vaadin/vaadin-grid#~1.1.0",
- "vaadin-combo-box": "vaadin/vaadin-combo-box#~1.1.0",
- "vaadin-icons": "vaadin/vaadin-icons#~1.0.0",
- "vaadin-date-picker": "vaadin/vaadin-date-picker#~1.1.0",
- "vaadin-upload": "vaadin/vaadin-upload#~1.0.0"
+ "vaadin-grid": "vaadin/vaadin-grid#1.1.x",
+ "vaadin-combo-box": "vaadin/vaadin-combo-box#1.1.x",
+ "vaadin-icons": "vaadin/vaadin-icons#1.0.x",
+ "vaadin-date-picker": "vaadin/vaadin-date-picker#1.1.x",
+ "vaadin-upload": "vaadin/vaadin-upload#1.0.x"
},
"devDependencies": {
"web-component-tester": "^4.0.3",
@@ -41,5 +41,16 @@
},
"resolutions": {
"polymer": "v1.1.1"
+ },
+ "masterOverrides": {
+ "version": "master",
+ "dependencies": {
+ "vaadin-grid": "vaadin/vaadin-grid#master",
+ "vaadin-combo-box": "vaadin/vaadin-combo-box#master",
+ "vaadin-icons": "vaadin/vaadin-icons#master",
+ "vaadin-date-picker": "vaadin/vaadin-date-picker#master",
+ "vaadin-upload": "vaadin/vaadin-upload#master",
+ "vaadin-split-layout": "vaadin/vaadin-split-layout#master"
+ }
}
}
diff --git a/gulpfile.js b/gulpfile.js
index 9f60d08..312593b 100644
--- a/gulpfile.js
+++ b/gulpfile.js
@@ -4,8 +4,6 @@ require('require-dir')('./tasks');
var args = require('yargs').argv;
var git = require('gulp-git');
-var version = '0.3.0';
-
gulp.task('default', function() {
console.log('\n Use:\n gulp <stage|deploy[:cdn]>|<zip>\n');
});
diff --git a/tasks/cdn.js b/tasks/cdn.js
index 816f852..0db7bb9 100644
--- a/tasks/cdn.js
+++ b/tasks/cdn.js
@@ -3,6 +3,7 @@ var config = require('./config');
var common = require('./common');
var gulp = require('gulp');
var fs = require('fs-extra');
+var path = require('path');
var modify = require('gulp-modify');
var rsync = require('gulp-rsync');
var gutil = require('gulp-util');
@@ -12,16 +13,31 @@ var stagingBasePath = config.paths.staging.cdn;
var version = config.version;
var host = config.toolsHost;
var permalink = config.permalink;
-var stagingPath = stagingBasePath + '/' + version;
-var testPath = process.cwd() + '/' + stagingPath + '/test';
+var stagingPath = path.join(process.cwd(), stagingBasePath, version);
gulp.task('clean:cdn', function() {
fs.removeSync(stagingBasePath);
});
-gulp.task('cdn:stage-bower_components', function() {
+gulp.task('cdn:stage-bower.json', ['clean:cdn'], function() {
+ // Load the bower.json, assign overrides and write back to disk.
+ let bowerJson = JSON.parse(fs.readFileSync('./bower.json', 'utf-8'));
+
+ if (version === 'master') {
+ gutil.log('Applying overrides to ' + stagingPath + '/bower.json');
+ bowerJson = Object.assign(bowerJson, bowerJson.masterOverrides);
+ delete bowerJson.masterOverrides;
+ }
+
+ fs.mkdirSync(stagingBasePath);
+ fs.mkdirSync(stagingPath);
+ fs.writeFileSync(stagingPath + '/bower.json', JSON.stringify(bowerJson, null, ' '));
+});
+
+gulp.task('cdn:stage-bower_components', ['cdn:stage-bower.json'], function() {
return bower({
- directory: stagingPath,
+ directory: '.',
+ cwd: stagingPath,
forceLatest: true,
cmd: 'install'
});
@@ -41,7 +57,7 @@ gulp.task('cdn:stage-vaadin-core-elements', function() {
return contents;
}
}))
- .pipe(gulp.dest(stagingPath + "/vaadin-core-elements"));
+ .pipe(gulp.dest(stagingPath + '/vaadin-core-elements'));
});
gulp.task('stage:cdn', ['clean:cdn', 'cdn:stage-bower_components', 'cdn:stage-vaadin-core-elements']);
diff --git a/tasks/config.js b/tasks/config.js
index 61d550f..521a8ce 100644
--- a/tasks/config.js
+++ b/tasks/config.js
@@ -4,7 +4,6 @@ var fs = require('fs');
var userhome = process.env.HOME || process.env.HOMEPATH || process.env.USERPROFILE;
module.exports = {
- coreElements: ['vaadin-grid', 'vaadin-combo-box', 'vaadin-date-picker', 'vaadin-upload', 'vaadin-icons'],
version: args.version || 'master',
permalink: args.version ? 'latest' : '',
toolsHost: args.toolsHostname || 'tools.vaadin.com',
diff --git a/tasks/docsite.js b/tasks/docsite.js
index 50fb02e..4c18233 100644
--- a/tasks/docsite.js
+++ b/tasks/docsite.js
@@ -56,9 +56,10 @@ gulp.task('cdn:docsite:core-elements-integrations', function() {
});
gulp.task('cdn:docsite:core-elements-elements', ['cdn:docsite:bower_components'], function() {
- var docsPaths = config.coreElements.map(function(c) {
- return stagingPath + '/' + c + '/docs/**';
- });
+ const bowerJson = require('../' + stagingPath + '/bower.json');
+ var docsPaths = Object.keys(bowerJson.dependencies).map(function(c) {
+ return stagingPath + '/' + c + '/docs/**';
+ });
return gulp.src(docsPaths, {base: stagingPath})
.pipe(rename(function (path) {