
es6 is currently breaking in browsers so lets use es5 for now. Change-Id: I918c79ceb24490e85870a8b30bf4506acb54c391
60 lines
1.9 KiB
JavaScript
60 lines
1.9 KiB
JavaScript
// Copyright (C) 2017 The Android Open Source Project
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
(function() {
|
|
'use strict';
|
|
|
|
Polymer({
|
|
is: 'gr-external-style',
|
|
|
|
properties: {
|
|
name: String,
|
|
},
|
|
|
|
_import: function(url) {
|
|
return new Promise(function(resolve, reject) {
|
|
this.importHref(url, resolve, reject);
|
|
}.bind(this));
|
|
},
|
|
|
|
_applyStyle: function(name) {
|
|
var s = document.createElement('style', 'custom-style');
|
|
s.setAttribute('include', name);
|
|
Polymer.dom(this.root).appendChild(s);
|
|
},
|
|
|
|
ready: function() {
|
|
Gerrit.awaitPluginsLoaded().then(function() {
|
|
var sharedStyles = Gerrit._styleModules[this.name];
|
|
if (sharedStyles) {
|
|
var pluginUrls = [];
|
|
var moduleNames = [];
|
|
sharedStyles.reduce(function(result, item) {
|
|
if (!result.pluginUrls.includes(item.pluginUrl)) {
|
|
result.pluginUrls.push(item.pluginUrl);
|
|
}
|
|
result.moduleNames.push(item.moduleName);
|
|
return result;
|
|
}, {pluginUrls: pluginUrls, moduleNames: moduleNames});
|
|
Promise.all(pluginUrls.map(this._import.bind(this)))
|
|
.then(function() {
|
|
moduleNames.forEach(function(name) {
|
|
this._applyStyle(name);
|
|
}.bind(this));
|
|
}.bind(this));
|
|
}
|
|
}.bind(this));
|
|
},
|
|
});
|
|
})();
|