0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-01-20 22:42:53 -05:00

Move Ember Admin to use es6 modules

- adds required dependencies to package.json
 and to bower.json
- added required Grunt tasks to transpile and
 concat ember admin files
This commit is contained in:
Harry Wolff 2014-02-26 23:45:45 -05:00
parent 14b1d0c01f
commit 4334c3deb6
11 changed files with 362 additions and 24 deletions

1
.gitignore vendored
View file

@ -29,6 +29,7 @@ projectFilesBackup
.build
.dist
.tmp
/core/clientold/tpl/hbs-tpl.js
/core/clientold/assets/css

View file

@ -1,6 +1,7 @@
!**
.build
.dist
.tmp
docs/**
_site/**
content/images/**

View file

@ -58,6 +58,12 @@ var path = require('path'),
files: 'core/client/templates/**/*.hbs',
tasks: ['emberTemplates']
},
ember: {
files: [
'core/client/**/*.js'
],
tasks: ['transpile', 'concat_sourcemap']
},
sass: {
files: ['<%= paths.adminOldAssets %>/sass/**/*'],
tasks: ['sass:admin']
@ -72,12 +78,6 @@ var path = require('path'),
],
tasks: ['concat']
},
'concat-ember': {
files: [
'core/client/**/*.js'
],
tasks: ['concat:dev-ember']
},
livereload: {
files: [
// Theme CSS
@ -311,9 +311,13 @@ var path = require('path'),
// ### Config for grunt-ember-templates
// Compiles handlebar templates for ember
emberTemplates: {
compile: {
dev: {
options: {
templateBasePath: /core\/client\/templates/
templateBasePath: /core\/client\//,
templateFileExtensions: /\.hbs/,
templateRegistration: function (name, template) {
return grunt.config.process("define('ghost/") + name + "', ['exports'], function(__exports__){ __exports__['default'] = " + template + "; });";
}
},
files: {
"core/built/scripts/templates-ember.js": "core/client/templates/**/*.hbs"
@ -321,6 +325,35 @@ var path = require('path'),
}
},
// ### Config for grunt-es6-module-transpiler
// Compiles Ember es6 modules
transpile: {
client: {
type: 'amd',
moduleName: function (path) {
return 'ghost/' + path;
},
files: [{
expand: true,
cwd: 'core/client/',
src: ['**/*.js'],
dest: '.tmp/ember-transpiled/'
}]
}
},
// ### Config for grunt-es6-module-transpiler
// Compiles Ember es6 modules
concat_sourcemap: {
client: {
src: ['.tmp/ember-transpiled/**/*.js'],
dest: 'core/built/scripts/ghost-dev-ember.js',
options: {
sourcesContent: true
}
}
},
// ### Config for grunt-groc
// Generate documentation from code
groc: {
@ -441,13 +474,11 @@ var path = require('path'),
'dev-ember': {
files: {
'core/built/scripts/vendor-ember.js': [
'core/shared/vendor/loader.js',
'core/shared/vendor/jquery/jquery.js',
'core/shared/vendor/handlebars/handlebars.js',
'core/shared/vendor/ember/ember.js'
],
'core/built/scripts/ghost-dev-ember.js': [
'core/client/**/*.js'
'core/shared/vendor/ember/ember.js',
'core/shared/vendor/ember-resolver/dist/ember-resolver.js'
]
}
},
@ -830,6 +861,7 @@ var path = require('path'),
'sass:admin',
'handlebars',
'concat',
'emberBuild',
'express:dev',
'watch'
]);
@ -875,8 +907,11 @@ var path = require('path'),
// Before running in production mode
grunt.registerTask('prod', 'Build CSS, JS & templates for production', ['sass:compress', 'handlebars', 'concat', 'uglify']);
// All tasks related to building the Ember client code
grunt.registerTask('emberBuild', 'Build Ember JS & templates for development', ['emberTemplates:dev', 'transpile', 'concat_sourcemap']);
// When you just say 'grunt'
grunt.registerTask('default', 'Build CSS, JS & templates for development', ['update_submodules', 'sass:compress', 'handlebars', 'emberTemplates:compile', 'concat']);
grunt.registerTask('default', 'Build CSS, JS & templates for development', ['update_submodules', 'sass:compress', 'handlebars', 'concat', 'emberBuild']);
};
module.exports = configureGrunt;

View file

@ -2,6 +2,10 @@
"name": "ghost",
"dependencies": {
"handlebars": "~1.1.2",
"ember": "~1.4.0",
"ember-resolver": "git://github.com/stefanpenner/ember-jj-abrams-resolver.git#9805033c178e7f857f801359664adb599444b430"
},
"resolutions": {
"ember": "~1.4.0"
}
}

View file

@ -1,6 +1,8 @@
/*global Ember */
var App = Ember.Application.create({
import Resolver from 'ember/resolver';
var App = Ember.Application.extend({
/**
* These are debugging flags, they are useful during development
*/
@ -9,6 +11,8 @@ var App = Ember.Application.create({
LOG_TRANSITIONS: true,
LOG_TRANSITIONS_INTERNAL: true,
LOG_VIEW_LOOKUPS: true,
rootElement: '#ember-app' // tells ember to inject this app into element with selector #ember-app
modulePrefix: 'ghost', // TODO: loaded via config
Resolver: Resolver['default']
});
export default App;

View file

@ -1,9 +1,11 @@
/*global App */
/*global Ember */
App.Router.map(function () {
// ensure we don't share routes between all Router instances
var Router = Ember.Router.extend();
Router.map(function () {
'use strict';
this.resource('posts');
this.resource('post', {path: 'post/:id'}, function () {
this.route('edit');
});
});
export default Router;

View file

@ -0,0 +1 @@
<em>This is the index route</em>

View file

@ -32,10 +32,12 @@
</head>
<body class="{{bodyClass}}{{update_notification classOnly="true"}}">
<div id="ember-app"></div>
<script src="/ghost/scripts/vendor-ember.js"></script>
<script src="/ghost/scripts/templates-ember.js"></script>
<script src="/ghost/scripts/ghost-dev-ember.js"></script>
<script>
window.App = require('ghost/app')['default'].create();
</script>
</body>
</html>

View file

@ -0,0 +1,211 @@
// ==========================================================================
// Project: Ember - JavaScript Application Framework
// Copyright: Copyright 2013 Stefan Penner and Ember App Kit Contributors
// License: Licensed under MIT license
// See https://raw.github.com/stefanpenner/ember-jj-abrams-resolver/master/LICENSE
// ==========================================================================
// Version: 0.0.1
(function() {
/*globals define registry requirejs */
define("ember/resolver",
[],
function() {
"use strict";
/*
* This module defines a subclass of Ember.DefaultResolver that adds two
* important features:
*
* 1) The resolver makes the container aware of es6 modules via the AMD
* output. The loader's _seen is consulted so that classes can be
* resolved directly via the module loader, without needing a manual
* `import`.
* 2) is able provide injections to classes that implement `extend`
* (as is typical with Ember).
*/
function classFactory(klass) {
return {
create: function (injections) {
if (typeof klass.extend === 'function') {
return klass.extend(injections);
} else {
return klass;
}
}
};
}
var underscore = Ember.String.underscore;
var classify = Ember.String.classify;
var get = Ember.get;
function parseName(fullName) {
/*jshint validthis:true */
var nameParts = fullName.split(":"),
type = nameParts[0], fullNameWithoutType = nameParts[1],
name = fullNameWithoutType,
namespace = get(this, 'namespace'),
root = namespace;
return {
fullName: fullName,
type: type,
fullNameWithoutType: fullNameWithoutType,
name: name,
root: root,
resolveMethodName: "resolve" + classify(type)
};
}
function chooseModuleName(seen, moduleName) {
var underscoredModuleName = Ember.String.underscore(moduleName);
if (moduleName !== underscoredModuleName && seen[moduleName] && seen[underscoredModuleName]) {
throw new TypeError("Ambiguous module names: `" + moduleName + "` and `" + underscoredModuleName + "`");
}
if (seen[moduleName]) {
return moduleName;
} else if (seen[underscoredModuleName]) {
return underscoredModuleName;
} else {
var parts = moduleName.split('/'),
lastPart = parts[parts.length - 1],
partializedModuleName;
parts[parts.length - 1] = lastPart.replace(/^-/, '_');
partializedModuleName = parts.join('/');
if (seen[partializedModuleName]) {
Ember.deprecate('Modules should not contain underscores. ' +
'Attempted to lookup "'+moduleName+'" which ' +
'was not found. Please rename "'+partializedModuleName+'" '+
'to "'+moduleName+'" instead.', false);
return partializedModuleName;
} else {
return moduleName;
}
}
}
function logLookup(found, parsedName, moduleName) {
if (Ember.ENV.LOG_MODULE_RESOLVER) {
var symbol;
if (found) { symbol = '[✓]'; }
else { symbol = '[ ]'; }
Ember.Logger.info(symbol, parsedName.fullName, new Array(40 - parsedName.fullName.length).join('.'), moduleName);
}
}
function resolveOther(parsedName) {
/*jshint validthis:true */
var moduleName, tmpModuleName, prefix, podPrefix, moduleRegistry;
prefix = this.namespace.modulePrefix;
podPrefix = this.namespace.podModulePrefix || prefix;
moduleRegistry = requirejs._eak_seen;
Ember.assert('module prefix must be defined', prefix);
var pluralizedType = parsedName.type + 's';
var name = parsedName.fullNameWithoutType;
// lookup using POD formatting first
tmpModuleName = podPrefix + '/' + name + '/' + parsedName.type;
if (moduleRegistry[tmpModuleName]) {
moduleName = tmpModuleName;
}
// if not using POD format, use the custom prefix
if (this.namespace[parsedName.type + 'Prefix']) {
prefix = this.namespace[parsedName.type + 'Prefix'];
}
// if router:main or adapter:main look for a module with just the type first
tmpModuleName = prefix + '/' + parsedName.type;
if (!moduleName && name === 'main' && moduleRegistry[tmpModuleName]) {
moduleName = prefix + '/' + parsedName.type;
}
// fallback if not type:main or POD format
if (!moduleName) { moduleName = prefix + '/' + pluralizedType + '/' + name; }
// allow treat all dashed and all underscored as the same thing
// supports components with dashes and other stuff with underscores.
var normalizedModuleName = chooseModuleName(moduleRegistry, moduleName);
if (moduleRegistry[normalizedModuleName]) {
var module = require(normalizedModuleName, null, null, true /* force sync */);
if (module && module['default']) { module = module['default']; }
if (module === undefined) {
throw new Error(" Expected to find: '" + parsedName.fullName + "' within '" + normalizedModuleName + "' but got 'undefined'. Did you forget to `export default` within '" + normalizedModuleName + "'?");
}
if (this.shouldWrapInClassFactory(module, parsedName)) {
module = classFactory(module);
}
logLookup(true, parsedName, moduleName);
return module;
} else {
logLookup(false, parsedName, moduleName);
return this._super(parsedName);
}
}
// Ember.DefaultResolver docs:
// https://github.com/emberjs/ember.js/blob/master/packages/ember-application/lib/system/resolver.js
var Resolver = Ember.DefaultResolver.extend({
resolveTemplate: resolveOther,
resolveOther: resolveOther,
makeToString: function(factory, fullName) {
return '' + this.namespace.modulePrefix + '@' + fullName + ':';
},
parseName: parseName,
shouldWrapInClassFactory: function(module, parsedName){
return false;
},
normalize: function(fullName) {
// replace `.` with `/` in order to make nested controllers work in the following cases
// 1. `needs: ['posts/post']`
// 2. `{{render "posts/post"}}`
// 3. `this.render('posts/post')` from Route
var split = fullName.split(':');
if (split.length > 1) {
return split[0] + ':' + Ember.String.dasherize(split[1].replace(/\./g, '/'));
} else {
return fullName;
}
}
});
Resolver['default'] = Resolver;
return Resolver;
});
define("resolver",
["ember/resolver"],
function (Resolver) {
Ember.deprecate('Importing/requiring Ember Resolver as "resolver" is deprecated, please use "ember/resolver" instead');
return Resolver;
});
})();
(function() {
})();

75
core/shared/vendor/loader.js vendored Executable file
View file

@ -0,0 +1,75 @@
var define, requireModule, require, requirejs;
(function() {
var registry = {}, seen = {}, state = {};
var FAILED = false;
define = function(name, deps, callback) {
registry[name] = {
deps: deps,
callback: callback
};
};
requirejs = require = requireModule = function(name) {
if (state[name] !== FAILED &&
seen.hasOwnProperty(name)) {
return seen[name];
}
if (!registry.hasOwnProperty(name)) {
throw new Error('Could not find module ' + name);
}
var mod = registry[name];
var deps = mod.deps;
var callback = mod.callback;
var reified = [];
var exports;
var value;
var loaded = false;
seen[name] = { }; // enable run-time cycles
try {
for (var i=0, l=deps.length; i<l; i++) {
if (deps[i] === 'exports') {
reified.push(exports = {});
} else {
reified.push(requireModule(resolve(deps[i], name)));
}
}
value = callback.apply(this, reified);
loaded = true;
} finally {
if (!loaded) {
state[name] = FAILED;
}
}
return seen[name] = exports || value;
};
function resolve(child, name) {
if (child.charAt(0) !== '.') { return child; }
var parts = child.split('/');
var parentBase = name.split('/').slice(0, -1);
for (var i = 0, l = parts.length; i < l; i++) {
var part = parts[i];
if (part === '..') { parentBase.pop(); }
else if (part === '.') { continue; }
else { parentBase.push(part); }
}
return parentBase.join('/');
}
requirejs._eak_seen = registry;
requirejs.clear = function(){
requirejs._eak_seen = registry = {};
seen = {};
};
})();

View file

@ -62,6 +62,7 @@
"grunt": "~0.4.1",
"grunt-ember-templates": "~0.4.18",
"grunt-cli": "~0.1.13",
"grunt-concat-sourcemap": "~0.4.0",
"grunt-contrib-clean": "~0.5.0",
"grunt-contrib-compress": "~0.5.2",
"grunt-contrib-concat": "~0.3.0",
@ -70,6 +71,7 @@
"grunt-contrib-sass": "~0.5.0",
"grunt-contrib-uglify": "~0.2.5",
"grunt-contrib-watch": "~0.5.3",
"grunt-es6-module-transpiler": "~0.6.0",
"grunt-express-server": "~0.4.11",
"grunt-groc": "~0.4.0",
"grunt-jslint": "~1.1.1",