split compass sass

pull/12065/head
Carlos Matallín 8 years ago
parent fb5b7e6f42
commit 8986017184

@ -48,9 +48,7 @@ function isRunningTask (taskName, grunt) {
/**
* CartoDB UI assets generation
*/
module.exports = function(grunt) {
if (timer) timer.init(grunt);
var environment = grunt.option('environment') || DEVELOPMENT;
@ -82,8 +80,8 @@ module.exports = function(grunt) {
logFn && logFn(err ? new Error(err): null);
});
}
checkVersion('node -v', requiredNodeVersion, 'node', logFn);
checkVersion('npm -v', requiredNpmVersion, 'npm', logFn);
// checkVersion('node -v', requiredNodeVersion, 'node', logFn);
// checkVersion('npm -v', requiredNpmVersion, 'npm', logFn);
}
var mustCheckNodeVersion = grunt.option('no-node-checker');
@ -117,9 +115,12 @@ module.exports = function(grunt) {
var ROOT_ASSETS_DIR = './public/assets/';
var ASSETS_DIR = './public/assets/<%= pkg.version %>';
// use grunt --environment production
/**
* `grunt --environment=production`
*/
var env = './config/grunt_' + environment + '.json';
grunt.log.writeln('env: ' + env);
if (grunt.file.exists(env)) {
env = grunt.file.readJSON(env)
} else {
@ -170,10 +171,14 @@ module.exports = function(grunt) {
connect: require('./lib/build/tasks/connect.js').task(),
availabletasks: require('./lib/build/tasks/availabletasks.js').task()
availabletasks: require('./lib/build/tasks/availabletasks.js').task(),
sass: require('./lib/build/tasks/sass.js').task()
});
// $ grunt availabletasks
/**
* `grunt availabletasks`
*/
grunt.loadNpmTasks('grunt-available-tasks');
// Load Grunt tasks
@ -183,20 +188,7 @@ module.exports = function(grunt) {
require('./lib/build/tasks/manifest').register(grunt, ASSETS_DIR);
// builds cdb
grunt.registerTask('cdb', "builds cartodb.js", function() {
var done = this.async();
require("child_process").exec('make update_cdb', function (error, stdout, stderr) {
if (error) {
grunt.log.fail('cartodb.js not updated (due to '+ stdout +", "+ stderr +")");
} else {
grunt.log.ok('cartodb.js updated');
}
done();
});
});
grunt.registerTask('invalidate', "invalidate cache", function() {
grunt.registerTask('invalidate', 'invalidate cache', function() {
var done = this.async();
var url = require('url');
var https = require('https');
@ -222,25 +214,26 @@ module.exports = function(grunt) {
}).end();
});
grunt.registerTask('config', "generates assets config for current configuration", function() {
grunt.registerTask('config', 'generates assets config for current configuration', function() {
// Set assets url for static assets in our app
var config = grunt.template.process("cdb.config.set('assets_url', '<%= env.http_path_prefix %>/assets/<%= pkg.version %>');");
config += grunt.template.process("\nconsole.log('cartodbui v<%= pkg.version %>');");
grunt.file.write("lib/build/app_config.js", config);
});
grunt.registerTask('check_release', "checks release can be done", function() {
grunt.registerTask('check_release', 'checks release can be done', function() {
if (environment === DEVELOPMENT) {
grunt.log.error("you can't release running development environment");
return false;
}
grunt.log.ok("************************************************");
grunt.log.ok(" you are going to deploy to " + env );
grunt.log.ok("************************************************");
});
grunt.event.on('watch', function(action, filepath, subtask) {
// configure copy vendor to only run on changed file
// Configure copy vendor to only run on changed file
var cfg = grunt.config.get('copy.vendor');
if (filepath.indexOf(cfg.cwd) !== -1) {
grunt.config('copy.vendor.src', filepath.replace(cfg.cwd, ''));
@ -249,17 +242,13 @@ module.exports = function(grunt) {
}
var builderFiles = [
'js_core_cartodb3',
'js_client_cartodb3',
'js_test_spec_core_cartodb3',
'js_test_spec_client_cartodb3'
'js_cartodb3',
'js_test_spec_cartodb3'
];
var otherFiles = [
'app',
'js_core_cartodb',
'js_client_cartodb',
'js_test_jasmine_core_cartodb3',
'js_test_jasmine_client_cartodb3'
'js_cartodb',
'js_test_jasmine_cartodb3'
];
var COPY_PATHS = [];
@ -269,7 +258,7 @@ module.exports = function(grunt) {
COPY_PATHS = COPY_PATHS.concat(otherFiles).concat(builderFiles);
}
// configure copy paths to only run on changed files
// Configure copy paths to only run on changed files
for (var j = 0, m = COPY_PATHS.length; j < m; ++j) {
var copy_path = COPY_PATHS[j];
var files = grunt.config.get('copy.' + copy_path + '.files');
@ -284,10 +273,154 @@ module.exports = function(grunt) {
}
});
grunt.registerTask('css', [
'copy:vendor',
'copy:app',
'compass',
'sass',
// TODO: migrate mixins to postcss
// 'postcss',
'concat:css'
]);
grunt.registerTask('run_browserify', 'Browserify task with options', function (option) {
var skipEditor = false;
var skipBuilder = false;
var skipAllSpecs = false;
var skipEditorSpecs = false;
var skipBuilderSpecs = false;
if (environment === DEVELOPMENT) {
if (!isRunningTask('test', grunt)) {
grunt.log.writeln('Skipping only Builder specs generation by browserify because we are not running the `test` task.');
skipBuilderSpecs = true;
}
if (option === 'builder') {
grunt.log.writeln('Skipping Editor assets and specs generation by browserify because we are running the `dev` task.');
skipEditor = true;
skipEditorSpecs = true;
} else {
grunt.log.writeln('Skipping Builder assets generation by browserify because we are running the `dev` task later.');
skipBuilder = true;
}
} else {
grunt.log.writeln('Skipping all specs generation by browserify because not in development environment.');
skipAllSpecs = true;
}
if (skipEditor) {
delete grunt.config.data.browserify['explore'];
delete grunt.config.data.browserify['user_feed'];
delete grunt.config.data.browserify['account'];
delete grunt.config.data.browserify['confirmation'];
delete grunt.config.data.browserify['editor'];
delete grunt.config.data.browserify['dashboard'];
delete grunt.config.data.browserify['keys'];
delete grunt.config.data.browserify['new_public_table'];
delete grunt.config.data.browserify['organization'];
delete grunt.config.data.browserify['public_dashboard'];
delete grunt.config.data.browserify['data_library'];
delete grunt.config.data.browserify['public_map'];
delete grunt.config.data.browserify['mobile_apps'];
}
if (skipBuilder) {
delete grunt.config.data.browserify['vendor_editor3'];
delete grunt.config.data.browserify['common_editor3'];
delete grunt.config.data.browserify['dataset'];
delete grunt.config.data.browserify['editor3'];
delete grunt.config.data.browserify['public_editor3'];
}
if (skipAllSpecs) {
delete grunt.config.data.browserify['test_specs_for_browserify_modules'];
delete grunt.config.data.browserify['cartodb3-specs'];
} else if (skipEditorSpecs) {
delete grunt.config.data.browserify['test_specs_for_browserify_modules'];
} else if (skipBuilderSpecs) {
delete grunt.config.data.browserify['cartodb3-specs'];
}
grunt.task.run('browserify');
});
grunt.registerTask('cdb', 'builds cartodb.js', function() {
var done = this.async();
require('child_process').exec('make update_cdb', function (error, stdout, stderr) {
if (error) {
grunt.log.fail('cartodb.js not updated (due to '+ stdout + ', ' + stderr + ')');
} else {
grunt.log.ok('cartodb.js updated');
}
done();
});
});
grunt.registerTask('copy_builder', 'Multitask with all the tasks responsible for copying builder files.', [
'copy:locale',
'copy:js_cartodb3',
'copy:js_test_spec_cartodb3'
]);
grunt.registerTask('js', [
'cdb',
'copy_builder',
'copy:js_cartodb',
'copy:js_test_jasmine_cartodb3',
'run_browserify',
'concat:js',
'jst'
]);
grunt.registerTask('prepare', [
'clean',
'config',
'js'
]);
/**
* `grunt` default task to compile Editor assets, builder assets will be compiled by `grunt dev` task.
* `grunt --environment=production` default task to compile Builder and Editor assets.
*/
grunt.registerTask('default', [
'prepare',
'css',
'manifest'
]);
grunt.registerTask('run_watch', 'All watch tasks except those that watch spec changes', function (option) {
if (option === 'builder_specs=false') {
delete grunt.config.data.watch.js_test_spec_cartodb3;
delete grunt.config.data.watch.js_test_jasmine_cartodb3;
delete grunt.config.data.watch.js_affected;
}
grunt.task.run('watch');
});
grunt.registerTask('build-jasmine-specrunners', _.chain(jasmineCfg)
.keys()
.map(function (name) {
return ['jasmine', name, 'build'].join(':');
})
.value());
grunt.registerTask('setConfig', 'Set a config property', function(name, val) {
grunt.config.set(name, val);
});
/**
* `grunt dev` compile and watch Builder assets.
*/
grunt.registerTask('dev', 'Frontend development task (watch JS/CSS changes)', [
'setConfig:env.browserify_watch:true',
'run_browserify:builder',
'build-jasmine-specrunners',
// 'connect:server',
// 'run_watch:builder_specs=false'
]);
// still have to use this custom task because registerCmdTask outputs tons of warnings like:
// path/to/some/ignored/files:0:0: File ignored because of your .eslintignore file. Use --no-ignore to override.
grunt.registerTask('lint', 'lint source files', function () {
@ -308,62 +441,17 @@ module.exports = function(grunt) {
});
});
grunt.registerTask('pre_client', [
'copy:locale_core',
'copy:locale_client',
'copy:js_core_cartodb',
'copy:js_client_cartodb',
'copy:js_core_cartodb3',
'copy:js_client_cartodb3',
'copy:js_test_spec_core_cartodb3',
'copy:js_test_spec_client_cartodb3',
'copy:js_test_jasmine_core_cartodb3',
'copy:js_test_jasmine_client_cartodb3'
]);
grunt.registerTask('js', ['cdb', 'pre_client', 'run_browserify', 'concat:js', 'jst']);
grunt.registerTask('pre_default', ['clean', 'config', 'js']);
/**
* `grunt test`
*/
grunt.registerTask('test', '(CI env) Re-build JS files and run all tests. For manual testing use `grunt jasmine` directly', [
'pre_default',
'prepare',
'jasmine:cartodbui',
'jasmine:cartodb3',
'lint'
]);
grunt.registerTask('editor3', [
'browserify:vendor_editor3',
'browserify:common_editor3',
'browserify:editor3',
'browserify:public_editor3'
]);
grunt.registerTask('css_editor_3', [
'copy:cartofonts',
'copy:iconfont',
'copy:cartoassets',
'copy:perfect_scrollbar',
'copy:colorpicker',
'copy:deep_insights',
'copy:cartodbjs_v4'
]);
grunt.registerTask('css', ['copy:vendor', 'css_editor_3', 'copy:app', 'compass', 'concat:css']);
grunt.registerTask('default', ['pre_default', 'css', 'manifest']);
grunt.registerTask('minimize', ['default', 'copy:js', 'exorcise', 'uglify']);
grunt.registerTask('release', ['check_release', 'minimize', 's3', 'invalidate']);
grunt.registerTask('build-jasmine-specrunners', _
.chain(jasmineCfg)
.keys()
.map(function (name) {
return ['jasmine', name, 'build'].join(':');
})
.value());
grunt.registerTask('dev', 'Typical task for frontend development (watch JS/CSS changes)', [
'setConfig:env.browserify_watch:true',
'run_browserify',
'build-jasmine-specrunners',
'connect:server',
'run_watch:builder_specs=false']);
grunt.registerTask('sourcemaps',
'generate sourcemaps, to be used w/ trackjs.com for bughunting', [
grunt.registerTask('sourcemaps', 'generate sourcemaps, to be used w/ trackjs.com for bughunting', [
'setConfig:assets_dir:./tmp/sourcemaps',
'config',
'js',
@ -372,49 +460,22 @@ module.exports = function(grunt) {
'uglify'
]);
grunt.registerTask('run_watch', 'All watch tasks except those that watch spec changes', function (option) {
if (option === 'builder_specs=false') {
delete grunt.config.data.watch.js_test_spec_core_cartodb3;
delete grunt.config.data.watch.js_test_spec_client_cartodb3;
delete grunt.config.data.watch.js_test_jasmine_core_cartodb3;
delete grunt.config.data.watch.js_test_jasmine_client_cartodb3;
delete grunt.config.data.watch.js_affected;
}
grunt.task.run('watch');
});
grunt.registerTask('run_browserify', 'Browserify task with options', function (option) {
var skipAllSpecs = false;
var skipBuilderSpecs = false;
if (environment !== DEVELOPMENT) {
grunt.log.writeln('Skipping all specs generation by browserify because not in development environment.');
skipAllSpecs = true;
} else if (!isRunningTask('test', grunt)) {
grunt.log.writeln('Skipping only Builder specs generation by browserify because we are not running the `test` task.');
skipBuilderSpecs = true;
}
if (skipAllSpecs) {
delete grunt.config.data.browserify['test_specs_for_browserify_modules'];
delete grunt.config.data.browserify['cartodb3-specs'];
} else if (skipBuilderSpecs) {
delete grunt.config.data.browserify['cartodb3-specs'];
}
grunt.task.run('browserify');
});
grunt.registerTask('copy_builder', 'Multitask with all the tasks responsible for copying builder files.', [
'copy:locale_core',
'copy:locale_client',
'copy:js_core_cartodb3',
'copy:js_client_cartodb3',
'copy:js_test_spec_core_cartodb3',
'copy:js_test_spec_client_cartodb3'
grunt.registerTask('minimize', [
'default',
'copy:js',
'exorcise',
'uglify'
]);
// Affected specs section - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
/**
* `grunt release`
*/
grunt.registerTask('release', [
'check_release',
'minimize',
's3',
'invalidate'
]);
grunt.registerTask('affected', 'Generate only affected specs', function () {
requireWebpackTask().affected.call(this, grunt);
@ -442,8 +503,6 @@ module.exports = function(grunt) {
'watch:js_affected'
]);
// / Affected specs section - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
/**
* Delegate task to command line.
* @param {String} name - If taskname starts with npm it's run a npm script (i.e. `npm run foobar`

@ -4,7 +4,7 @@
# Set this to the root of your project when deployed:
http_path = "/"
css_dir = "dist/css"
sass_dir = "tmp/sass/"
sass_dir = "tmp/sass/editor"
images_dir = "app/assets/images/"
#javascripts_dir = "lib/assets/javascripts"

@ -124,7 +124,6 @@ module.exports = {
]
}
},
common_editor3: {
src: editor3Bundles.common.map(require.resolve),
dest: '<%= assets_dir %>/javascripts/common_editor3.js',
@ -138,7 +137,6 @@ module.exports = {
]
}
},
dataset: {
src: [
'lib/assets/javascripts/cartodb3/dataset.js'
@ -148,7 +146,6 @@ module.exports = {
external: editor3Bundles.vendor.concat(editor3Bundles.common)
}
},
editor3: {
src: [
'lib/assets/javascripts/cartodb3/editor.js'
@ -158,7 +155,6 @@ module.exports = {
external: editor3Bundles.vendor.concat(editor3Bundles.common)
}
},
public_editor3: {
src: [
'lib/assets/javascripts/cartodb3/public_editor.js'
@ -171,7 +167,6 @@ module.exports = {
]
}
},
'cartodb3-specs': {
src: [
'lib/build/source-map-support.js',

@ -1,7 +1,5 @@
var css_files;
module.exports = css_files = {
cdb: [
'<%= assets_dir %>/stylesheets/map/leaflet.css',
'<%= assets_dir %>/stylesheets/vendor/cartodb.css'
@ -224,7 +222,6 @@ module.exports = css_files = {
api_keys: [
'<%= assets_dir %>/stylesheets/api_keys/*.css'
]
};
var _all_css = [];

@ -1,23 +1,21 @@
/**
* Clean task config
*/
exports.task = function() {
return {
options: {
force: true
},
src: [
"lib/build/app_config.js",
".sass-cache",
"tmp/sass",
"<%= assets_dir %>",
".grunt",
"lib/assets/javascripts/cartodb3",
"lib/assets/test/{spec,jasmine}/cartodb3",
"lib/assets/locale"
dist: [
'.grunt',
'.sass-cache',
'tmp/sass',
'lib/build/app_config.js',
'<%= assets_dir %>',
'lib/assets/javascripts/cartodb3',
'lib/assets/test/{spec,jasmine}/cartodb3',
'lib/assets/locale'
]
}
}

@ -7,19 +7,10 @@ exports.task = function () {
dist: {
options: {
importPath: [
'tmp/sass/common',
'tmp/sass/cartoassets'
],
sassDir: 'tmp/sass',
sassDir: 'tmp/sass/editor',
cssDir: '<%= assets_dir %>/stylesheets',
specify: [
'tmp/sass/**/*.scss',
'!tmp/sass/deep-insights/**/*.scss',
'tmp/sass/deep-insights/main.scss',
'tmp/sass/deep-insights/entry.scss',
'!tmp/sass/cartodbjs_v4/**/*.scss',
'tmp/sass/cartodbjs_v4/entry.scss'
],
fontsDir: '<%= assets_dir %>/fonts',
httpFontsPath: '<%= env.http_path_prefix %>/assets/<%= pkg.version %>/fonts',

@ -1,14 +1,9 @@
/**
* Copy task config
*/
exports.task = function (grunt) {
return {
// Vendor stylesheets
vendor: {
expand: true,
cwd: 'vendor/assets/stylesheets/',
@ -27,21 +22,24 @@
}
},
cartoassets: {
app: {
files: [{
expand: true,
dot: true,
cwd: 'node_modules/cartoassets/src/fonts',
src: '**/*.*',
dest: '<%= assets_dir %>/fonts/'
}, {
expand: true,
cwd: 'node_modules/cartoassets/src/scss/',
src: '**/*.scss',
dest: 'tmp/sass/cartoassets/'
},
perfect_scrollbar: {
}, {
expand: true,
cwd: 'node_modules/perfect-scrollbar/src/css/',
src: '*.scss',
dest: 'tmp/sass/deep-insights/'
},
colorpicker: {
}, {
expand: true,
cwd: 'node_modules/bootstrap-colorpicker/dist/css/',
src: 'bootstrap-colorpicker.css',
@ -49,81 +47,35 @@
rename: function (dest, src) {
return dest + src.replace(/\.css$/, '.scss');
}
},
deep_insights: {
}, {
expand: true,
cwd: 'node_modules/cartodb-deep-insights.js/themes/scss',
src: '**/*.scss',
dest: 'tmp/sass/deep-insights/'
},
cartodbjs_v4: {
}, {
expand: true,
cwd: 'node_modules/cartodb.js/themes/scss',
src: '**/*.scss',
dest: 'tmp/sass/cartodbjs_v4/'
},
iconfont: {
expand: true,
cwd: 'node_modules/cartoassets/src/scss/',
src: 'cdb-icon-font.scss',
dest: 'tmp/sass/common/'
},
cartofonts: {
files: [{
expand: true,
dot: true,
cwd: 'node_modules/cartoassets/src/fonts',
src: '**/*.*',
dest: '<%= assets_dir %>/fonts/'
}]
},
app: {
files: [
/**
* Stylesheets
*/
// App stylesheets
{
}, {
// TODO: remove editor
expand: true,
cwd: 'app/assets/stylesheets/',
cwd: 'app/assets/stylesheets/editor',
src: ['**/*.css.scss', '**/*.scss'],
dest: 'tmp/sass/',
dest: 'tmp/sass/editor/',
rename: function (dest, src) {
return dest + src.replace(/\.css.scss$/, '.scss');
}
},
// Vendor stylesheets
{
}, {
// TODO: remove editor
expand: true,
cwd: 'vendor/assets/stylesheets/',
src: ['**/*.css.scss', '**/*.scss'],
dest: 'tmp/sass/',
cwd: 'app/assets/stylesheets/builder',
src: ['**/*.scss'],
dest: 'tmp/sass/builder/',
rename: function (dest, src) {
return dest + src.replace(/\.css.scss$/, '.scss');
}
},
// Jasmine stylesheets
{
expand: true,
cwd: 'lib/assets/test/lib/jasmine-1.3.1/',
src: ['**/*.css'],
dest: 'tmp/sass/specs/',
rename: function (dest, src) {
return dest + src.replace(/\.css$/, '.scss');
}
},
// Embed stylesheets
{
}, {
expand: true,
cwd: 'lib/assets/javascripts/cdb/themes/css/',
src: ['cartodb.css'],
@ -131,10 +83,8 @@
rename: function (dest, src) {
return dest + src.replace(/\.css$/, '.scss');
}
},
}, {
// Client stylesheets
{
expand: true,
cwd: 'app/assets/client/stylesheets/',
src: [
@ -145,108 +95,74 @@
rename: function (dest, src) {
return dest + src.replace(/\.css.scss$/, '.scss');
}
},
/**
* Images
*/
// public images
{
}, {
expand: true,
cwd: 'app/assets/images/',
src: ['**/*'],
dest: '<%= assets_dir %>/images/'
},
// some images should be placed in a unversioned folder
{
}, {
// Some images should be placed in a unversioned folder
expand: true,
cwd: 'app/assets/images/',
src: ['avatars/**/*', 'alphamarker.png', 'google-maps-basemap-icons/*'],
dest: '<%= root_assets_dir %>/unversioned/images/'
},
// CartoDB.js images
{
}, {
// CARTO.js images
expand: true,
cwd: 'lib/assets/javascripts/cdb/themes/img/',
src: ['**/*'],
dest: '<%= assets_dir %>/images/themes/'
},
/**
* Fonts
*/
{
}, {
// Fonts
expand: true,
cwd: 'app/assets/fonts/',
src: ['*.{svg,ttf,eot,woff,woff2}'],
dest: '<%= assets_dir %>/fonts/'
},
{
expand: true,
cwd: 'vendor/assets/fonts/',
src: ['*.{svg,ttf,eot,woff,woff2}'],
dest: '<%= assets_dir %>/fonts/'
},
// client fonts
{
}, {
// Client fonts
expand: true,
cwd: 'app/assets/client/fonts/',
src: ['*.{svg,ttf,eot,woff,woff2}'],
dest: '<%= assets_dir %>/fonts/'
},
/**
* Flash
*/
{
}, {
// Flash
expand: true,
cwd: 'app/assets/flash/',
src: ['**/*'],
dest: '<%= assets_dir %>/flash/'
},
/**
* Favicons
*/
{
}, {
// Favicons
expand: true,
cwd: 'public/favicons/',
src: ['**/*'],
dest: '<%= assets_dir %>/favicons/'
},
// client Favicons
{
}, {
// Client favicons
expand: true,
cwd: 'app/assets/client/favicons/',
src: ['**/*'],
dest: '<%= assets_dir %>/favicons/'
}]
},
css_tests: {
expand: true,
cwd: 'lib/assets/test/lib/jasmine-1.3.1/',
src: ['**/*.css'],
dest: 'tmp/sass/specs/',
rename: function (dest, src) {
return dest + src.replace(/\.css$/, '.scss');
}
]
},
js_core_cartodb: {
js_cartodb: {
files: [
{
expand: true,
cwd: 'lib/assets/core/javascripts/cartodb/organization/',
src: ['**/*'],
dest: 'lib/assets/javascripts/cartodb/organization/'
}
]
},
js_client_cartodb: {
files: [
{
} , {
expand: true,
cwd: 'lib/assets/client/javascripts/cartodb/organization/',
src: ['**/*'],
@ -255,20 +171,14 @@
]
},
js_core_cartodb3: {
js_cartodb3: {
files: [
{
expand: true,
cwd: 'lib/assets/core/javascripts/cartodb3/',
src: ['**/*'],
dest: 'lib/assets/javascripts/cartodb3/'
}
]
},
js_client_cartodb3: {
files: [
{
}, {
expand: true,
cwd: 'lib/assets/client/javascripts/cartodb3/',
src: ['**/*'],
@ -277,31 +187,14 @@
]
},
js_test_spec_core_cartodb3: {
js_test_spec_cartodb3: {
files: [
{
expand: true,
cwd: 'lib/assets/core/test/spec/cartodb3/',
src: ['**/*'],
dest: 'lib/assets/test/spec/cartodb3/'
}
]
},
js_test_jasmine_core_cartodb3: {
files: [
{
expand: true,
cwd: 'lib/assets/core/test/jasmine/cartodb3/',
src: ['**/*'],
dest: 'lib/assets/test/jasmine/cartodb3/'
}
]
},
js_test_spec_client_cartodb3: {
files: [
{
} , {
expand: true,
cwd: 'lib/assets/client/test/spec/cartodb3/',
src: ['**/*'],
@ -310,9 +203,14 @@
]
},
js_test_jasmine_client_cartodb3: {
js_test_jasmine_cartodb3: {
files: [
{
expand: true,
cwd: 'lib/assets/core/test/jasmine/cartodb3/',
src: ['**/*'],
dest: 'lib/assets/test/jasmine/cartodb3/'
} , {
expand: true,
cwd: 'lib/assets/client/test/jasmine/cartodb3/',
src: ['**/*'],
@ -321,20 +219,14 @@
]
},
locale_core: {
locale: {
files: [
{
expand: true,
cwd: 'lib/assets/core/locale/',
src: ['**/*'],
dest: 'lib/assets/locale/'
}
]
},
locale_client: {
files: [
{
}, {
expand: true,
cwd: 'lib/assets/client/locale/',
src: ['**/*'],

@ -1,6 +1,4 @@
module.exports = {
task: function() {
return {}
},

@ -0,0 +1,43 @@
/**
* Compass task config
*/
exports.task = function () {
return {
options: {
sourceMap: true,
sourceMapEmbed: true,
sourceMapContents: true,
includePaths: [
'tmp/sass/cartoassets/'
]
},
dist: {
files: [{
expand: true,
cwd: 'tmp/sass/builder/',
src: [
'**/*.scss'
],
dest: '<%= assets_dir %>/stylesheets',
ext: '.css'
}, {
expand: true,
cwd: 'tmp/sass/',
src: [
'**/*.scss',
'!builder/**/*',
'!editor/**/*',
// TODO: this can be achieved prepending the asstes with _
'!deep-insights/**/*.scss',
'deep-insights/main.scss',
'deep-insights/entry.scss',
'!cartodbjs_v4/**/*.scss',
'cartodbjs_v4/entry.scss'
],
dest: '<%= assets_dir %>/stylesheets',
ext: '.css'
}]
},
};
};

@ -1,6 +1,6 @@
{
"name": "cartodb-ui",
"version": "4.6.81",
"version": "4.6.81.11962.02",
"description": "CARTO UI frontend",
"repository": {
"type": "git",
@ -69,6 +69,7 @@
"grunt-contrib-watch": "1.0.0",
"grunt-exorcise": "2.1.0",
"grunt-postcss": "0.5.5",
"grunt-sass": "^2.0.0",
"grunt-timer": "0.3.3",
"jasmine": "2.5.2",
"jasmine-ajax": "git://github.com/nobuti/jasmine-ajax.git#master",

Loading…
Cancel
Save