angular2
Version:
Angular 2 - a web framework for modern web apps
94 lines • 17.8 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);
};
import { SourceModule, SourceExpression, moduleRef } from './source_module';
import { ViewEncapsulation } from 'angular2/src/core/metadata/view';
import { XHR } from 'angular2/src/compiler/xhr';
import { IS_DART, isBlank } from 'angular2/src/facade/lang';
import { PromiseWrapper } from 'angular2/src/facade/async';
import { ShadowCss } from 'angular2/src/compiler/shadow_css';
import { UrlResolver } from 'angular2/src/compiler/url_resolver';
import { extractStyleUrls } from './style_url_resolver';
import { escapeSingleQuoteString, codeGenExportVariable, MODULE_SUFFIX } from './util';
import { Injectable } from 'angular2/src/core/di';
const COMPONENT_VARIABLE = '%COMP%';
const HOST_ATTR = `_nghost-${COMPONENT_VARIABLE}`;
const CONTENT_ATTR = `_ngcontent-${COMPONENT_VARIABLE}`;
export let StyleCompiler = class {
constructor(_xhr, _urlResolver) {
this._xhr = _xhr;
this._urlResolver = _urlResolver;
this._styleCache = new Map();
this._shadowCss = new ShadowCss();
}
compileComponentRuntime(template) {
var styles = template.styles;
var styleAbsUrls = template.styleUrls;
return this._loadStyles(styles, styleAbsUrls, template.encapsulation === ViewEncapsulation.Emulated);
}
compileComponentCodeGen(template) {
var shim = template.encapsulation === ViewEncapsulation.Emulated;
return this._styleCodeGen(template.styles, template.styleUrls, shim);
}
compileStylesheetCodeGen(stylesheetUrl, cssText) {
var styleWithImports = 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))
];
}
clearCache() { this._styleCache.clear(); }
_loadStyles(plainStyles, absUrls, encapsulate) {
var promises = absUrls.map((absUrl) => {
var cacheKey = `${absUrl}${encapsulate ? '.shim' : ''}`;
var result = this._styleCache.get(cacheKey);
if (isBlank(result)) {
result = this._xhr.get(absUrl).then((style) => {
var styleWithImports = extractStyleUrls(this._urlResolver, absUrl, style);
return this._loadStyles([styleWithImports.style], styleWithImports.styleUrls, encapsulate);
});
this._styleCache.set(cacheKey, result);
}
return result;
});
return PromiseWrapper.all(promises).then((nestedStyles) => {
var result = plainStyles.map(plainStyle => this._shimIfNeeded(plainStyle, encapsulate));
nestedStyles.forEach(styles => result.push(styles));
return result;
});
}
_styleCodeGen(plainStyles, absUrls, shim) {
var arrayPrefix = IS_DART ? `const` : '';
var styleExpressions = plainStyles.map(plainStyle => escapeSingleQuoteString(this._shimIfNeeded(plainStyle, shim)));
for (var i = 0; i < absUrls.length; i++) {
var moduleUrl = this._createModuleUrl(absUrls[i], shim);
styleExpressions.push(`${moduleRef(moduleUrl)}STYLES`);
}
var expressionSource = `${arrayPrefix} [${styleExpressions.join(',')}]`;
return new SourceExpression([], expressionSource);
}
_styleModule(stylesheetUrl, shim, expression) {
var moduleSource = `
${expression.declarations.join('\n')}
${codeGenExportVariable('STYLES')}${expression.expression};
`;
return new SourceModule(this._createModuleUrl(stylesheetUrl, shim), moduleSource);
}
_shimIfNeeded(style, shim) {
return shim ? this._shadowCss.shimCssText(style, CONTENT_ATTR, HOST_ATTR) : style;
}
_createModuleUrl(stylesheetUrl, shim) {
return shim ? `${stylesheetUrl}.shim${MODULE_SUFFIX}` : `${stylesheetUrl}${MODULE_SUFFIX}`;
}
};
StyleCompiler = __decorate([
Injectable(),
__metadata('design:paramtypes', [XHR, UrlResolver])
], 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"]}