angular2
Version:
Angular 2 - a web framework for modern web apps
95 lines • 18.7 kB
JavaScript
;var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var __metadata = (this && this.__metadata) || function (k, v) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
};
var source_module_1 = require('./source_module');
var view_1 = require('angular2/src/core/metadata/view');
var xhr_1 = require('angular2/src/compiler/xhr');
var lang_1 = require('angular2/src/facade/lang');
var async_1 = require('angular2/src/facade/async');
var shadow_css_1 = require('angular2/src/compiler/shadow_css');
var url_resolver_1 = require('angular2/src/compiler/url_resolver');
var style_url_resolver_1 = require('./style_url_resolver');
var util_1 = require('./util');
var di_1 = require('angular2/src/core/di');
var COMPONENT_VARIABLE = '%COMP%';
var HOST_ATTR = "_nghost-" + COMPONENT_VARIABLE;
var CONTENT_ATTR = "_ngcontent-" + COMPONENT_VARIABLE;
var StyleCompiler = (function () {
function StyleCompiler(_xhr, _urlResolver) {
this._xhr = _xhr;
this._urlResolver = _urlResolver;
this._styleCache = new Map();
this._shadowCss = new shadow_css_1.ShadowCss();
}
StyleCompiler.prototype.compileComponentRuntime = function (template) {
var styles = template.styles;
var styleAbsUrls = template.styleUrls;
return this._loadStyles(styles, styleAbsUrls, template.encapsulation === view_1.ViewEncapsulation.Emulated);
};
StyleCompiler.prototype.compileComponentCodeGen = function (template) {
var shim = template.encapsulation === view_1.ViewEncapsulation.Emulated;
return this._styleCodeGen(template.styles, template.styleUrls, shim);
};
StyleCompiler.prototype.compileStylesheetCodeGen = function (stylesheetUrl, cssText) {
var styleWithImports = style_url_resolver_1.extractStyleUrls(this._urlResolver, stylesheetUrl, cssText);
return [
this._styleModule(stylesheetUrl, false, this._styleCodeGen([styleWithImports.style], styleWithImports.styleUrls, false)),
this._styleModule(stylesheetUrl, true, this._styleCodeGen([styleWithImports.style], styleWithImports.styleUrls, true))
];
};
StyleCompiler.prototype.clearCache = function () { this._styleCache.clear(); };
StyleCompiler.prototype._loadStyles = function (plainStyles, absUrls, encapsulate) {
var _this = this;
var promises = absUrls.map(function (absUrl) {
var cacheKey = "" + absUrl + (encapsulate ? '.shim' : '');
var result = _this._styleCache.get(cacheKey);
if (lang_1.isBlank(result)) {
result = _this._xhr.get(absUrl).then(function (style) {
var styleWithImports = style_url_resolver_1.extractStyleUrls(_this._urlResolver, absUrl, style);
return _this._loadStyles([styleWithImports.style], styleWithImports.styleUrls, encapsulate);
});
_this._styleCache.set(cacheKey, result);
}
return result;
});
return async_1.PromiseWrapper.all(promises).then(function (nestedStyles) {
var result = plainStyles.map(function (plainStyle) { return _this._shimIfNeeded(plainStyle, encapsulate); });
nestedStyles.forEach(function (styles) { return result.push(styles); });
return result;
});
};
StyleCompiler.prototype._styleCodeGen = function (plainStyles, absUrls, shim) {
var _this = this;
var arrayPrefix = lang_1.IS_DART ? "const" : '';
var styleExpressions = plainStyles.map(function (plainStyle) { return util_1.escapeSingleQuoteString(_this._shimIfNeeded(plainStyle, shim)); });
for (var i = 0; i < absUrls.length; i++) {
var moduleUrl = this._createModuleUrl(absUrls[i], shim);
styleExpressions.push(source_module_1.moduleRef(moduleUrl) + "STYLES");
}
var expressionSource = arrayPrefix + " [" + styleExpressions.join(',') + "]";
return new source_module_1.SourceExpression([], expressionSource);
};
StyleCompiler.prototype._styleModule = function (stylesheetUrl, shim, expression) {
var moduleSource = "\n " + expression.declarations.join('\n') + "\n " + util_1.codeGenExportVariable('STYLES') + expression.expression + ";\n ";
return new source_module_1.SourceModule(this._createModuleUrl(stylesheetUrl, shim), moduleSource);
};
StyleCompiler.prototype._shimIfNeeded = function (style, shim) {
return shim ? this._shadowCss.shimCssText(style, CONTENT_ATTR, HOST_ATTR) : style;
};
StyleCompiler.prototype._createModuleUrl = function (stylesheetUrl, shim) {
return shim ? stylesheetUrl + ".shim" + util_1.MODULE_SUFFIX : "" + stylesheetUrl + util_1.MODULE_SUFFIX;
};
StyleCompiler = __decorate([
di_1.Injectable(),
__metadata('design:paramtypes', [xhr_1.XHR, url_resolver_1.UrlResolver])
], StyleCompiler);
return StyleCompiler;
})();
exports.StyleCompiler = StyleCompiler;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"style_compiler.js","sourceRoot":"","sources":["angular2/src/compiler/style_compiler.ts"],"names":["StyleCompiler","StyleCompiler.constructor","StyleCompiler.compileComponentRuntime","StyleCompiler.compileComponentCodeGen","StyleCompiler.compileStylesheetCodeGen","StyleCompiler.clearCache","StyleCompiler._loadStyles","StyleCompiler._styleCodeGen","StyleCompiler._styleModule","StyleCompiler._shimIfNeeded","StyleCompiler._createModuleUrl"],"mappings":"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","sourcesContent":["import {CompileTypeMetadata, CompileTemplateMetadata} from './directive_metadata';\nimport {SourceModule, SourceExpression, moduleRef} from './source_module';\nimport {ViewEncapsulation} from 'angular2/src/core/metadata/view';\nimport {XHR} from 'angular2/src/compiler/xhr';\nimport {IS_DART, StringWrapper, isBlank} from 'angular2/src/facade/lang';\nimport {PromiseWrapper} from 'angular2/src/facade/async';\nimport {ShadowCss} from 'angular2/src/compiler/shadow_css';\nimport {UrlResolver} from 'angular2/src/compiler/url_resolver';\nimport {extractStyleUrls} from './style_url_resolver';\nimport {\n  escapeSingleQuoteString,\n  codeGenExportVariable,\n  codeGenToString,\n  MODULE_SUFFIX\n} from './util';\nimport {Injectable} from 'angular2/src/core/di';\n\nconst COMPONENT_VARIABLE = '%COMP%';\nconst HOST_ATTR = `_nghost-${COMPONENT_VARIABLE}`;\nconst CONTENT_ATTR = `_ngcontent-${COMPONENT_VARIABLE}`;\n\n@Injectable()\nexport class StyleCompiler {\n  private _styleCache: Map<string, Promise<string[]>> = new Map<string, Promise<string[]>>();\n  private _shadowCss: ShadowCss = new ShadowCss();\n\n  constructor(private _xhr: XHR, private _urlResolver: UrlResolver) {}\n\n  compileComponentRuntime(template: CompileTemplateMetadata): Promise<Array<string | any[]>> {\n    var styles = template.styles;\n    var styleAbsUrls = template.styleUrls;\n    return this._loadStyles(styles, styleAbsUrls,\n                            template.encapsulation === ViewEncapsulation.Emulated);\n  }\n\n  compileComponentCodeGen(template: CompileTemplateMetadata): SourceExpression {\n    var shim = template.encapsulation === ViewEncapsulation.Emulated;\n    return this._styleCodeGen(template.styles, template.styleUrls, shim);\n  }\n\n  compileStylesheetCodeGen(stylesheetUrl: string, cssText: string): SourceModule[] {\n    var styleWithImports = extractStyleUrls(this._urlResolver, stylesheetUrl, cssText);\n    return [\n      this._styleModule(\n          stylesheetUrl, false,\n          this._styleCodeGen([styleWithImports.style], styleWithImports.styleUrls, false)),\n      this._styleModule(stylesheetUrl, true, this._styleCodeGen([styleWithImports.style],\n                                                                styleWithImports.styleUrls, true))\n    ];\n  }\n\n  clearCache() { this._styleCache.clear(); }\n\n  private _loadStyles(plainStyles: string[], absUrls: string[],\n                      encapsulate: boolean): Promise<Array<string | any[]>> {\n    var promises = absUrls.map((absUrl) => {\n      var cacheKey = `${absUrl}${encapsulate ? '.shim' : ''}`;\n      var result = this._styleCache.get(cacheKey);\n      if (isBlank(result)) {\n        result = this._xhr.get(absUrl).then((style) => {\n          var styleWithImports = extractStyleUrls(this._urlResolver, absUrl, style);\n          return this._loadStyles([styleWithImports.style], styleWithImports.styleUrls,\n                                  encapsulate);\n        });\n        this._styleCache.set(cacheKey, result);\n      }\n      return result;\n    });\n    return PromiseWrapper.all(promises).then((nestedStyles: string[][]) => {\n      var result: Array<string | any[]> =\n          plainStyles.map(plainStyle => this._shimIfNeeded(plainStyle, encapsulate));\n      nestedStyles.forEach(styles => result.push(styles));\n      return result;\n    });\n  }\n\n  private _styleCodeGen(plainStyles: string[], absUrls: string[], shim: boolean): SourceExpression {\n    var arrayPrefix = IS_DART ? `const` : '';\n    var styleExpressions = plainStyles.map(\n        plainStyle => escapeSingleQuoteString(this._shimIfNeeded(plainStyle, shim)));\n\n    for (var i = 0; i < absUrls.length; i++) {\n      var moduleUrl = this._createModuleUrl(absUrls[i], shim);\n      styleExpressions.push(`${moduleRef(moduleUrl)}STYLES`);\n    }\n    var expressionSource = `${arrayPrefix} [${styleExpressions.join(',')}]`;\n    return new SourceExpression([], expressionSource);\n  }\n\n  private _styleModule(stylesheetUrl: string, shim: boolean,\n                       expression: SourceExpression): SourceModule {\n    var moduleSource = `\n      ${expression.declarations.join('\\n')}\n      ${codeGenExportVariable('STYLES')}${expression.expression};\n    `;\n    return new SourceModule(this._createModuleUrl(stylesheetUrl, shim), moduleSource);\n  }\n\n  private _shimIfNeeded(style: string, shim: boolean): string {\n    return shim ? this._shadowCss.shimCssText(style, CONTENT_ATTR, HOST_ATTR) : style;\n  }\n\n  private _createModuleUrl(stylesheetUrl: string, shim: boolean): string {\n    return shim ? `${stylesheetUrl}.shim${MODULE_SUFFIX}` : `${stylesheetUrl}${MODULE_SUFFIX}`;\n  }\n}\n"]}