2015-04-13 00:11:11 +01:00
|
|
|
/**
|
2016-08-10 20:15:17 +01:00
|
|
|
* Copyright 2015, 2016 IBM Corp.
|
2015-04-13 00:11:11 +01:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
**/
|
|
|
|
|
|
|
|
var express = require("express");
|
|
|
|
var util = require("util");
|
|
|
|
var path = require("path");
|
|
|
|
var fs = require("fs");
|
2015-04-13 22:15:15 +01:00
|
|
|
var clone = require("clone");
|
2015-04-13 00:11:11 +01:00
|
|
|
|
2015-04-13 22:15:15 +01:00
|
|
|
var defaultContext = {
|
2015-04-13 00:11:11 +01:00
|
|
|
page: {
|
|
|
|
title: "Node-RED",
|
2016-02-08 09:20:07 -05:00
|
|
|
favicon: "favicon.ico",
|
|
|
|
tabicon: "red/images/node-red-icon-black.svg"
|
2015-04-13 00:11:11 +01:00
|
|
|
},
|
|
|
|
header: {
|
|
|
|
title: "Node-RED",
|
|
|
|
image: "red/images/node-red.png"
|
2015-05-11 20:24:15 +01:00
|
|
|
},
|
|
|
|
asset: {
|
|
|
|
red: (process.env.NODE_ENV == "development")? "red/red.js":"red/red.min.js"
|
2015-04-13 16:48:38 +01:00
|
|
|
}
|
2015-04-13 00:11:11 +01:00
|
|
|
};
|
|
|
|
|
2016-01-08 13:36:49 +00:00
|
|
|
var theme = null;
|
2015-04-13 22:15:15 +01:00
|
|
|
var themeContext = clone(defaultContext);
|
2015-04-13 00:11:11 +01:00
|
|
|
var themeSettings = null;
|
|
|
|
|
|
|
|
function serveFile(app,baseUrl,file) {
|
|
|
|
try {
|
|
|
|
var stats = fs.statSync(file);
|
|
|
|
var url = baseUrl+path.basename(file);
|
|
|
|
//console.log(url,"->",file);
|
|
|
|
app.get(url,function(req, res) {
|
2015-07-15 22:43:24 +01:00
|
|
|
res.sendFile(file);
|
2015-04-13 00:11:11 +01:00
|
|
|
});
|
2015-04-13 10:37:30 +01:00
|
|
|
return "theme"+url;
|
2015-04-13 00:11:11 +01:00
|
|
|
} catch(err) {
|
|
|
|
//TODO: log filenotfound
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = {
|
2015-11-11 22:11:02 +00:00
|
|
|
init: function(runtime) {
|
|
|
|
var settings = runtime.settings;
|
2015-04-13 22:15:15 +01:00
|
|
|
themeContext = clone(defaultContext);
|
2016-01-08 13:36:49 +00:00
|
|
|
if (runtime.version) {
|
|
|
|
themeContext.version = runtime.version();
|
|
|
|
}
|
2015-04-13 22:15:15 +01:00
|
|
|
themeSettings = null;
|
2016-01-08 13:36:49 +00:00
|
|
|
theme = settings.editorTheme;
|
|
|
|
},
|
2015-07-15 22:43:24 +01:00
|
|
|
|
2016-01-08 13:36:49 +00:00
|
|
|
app: function() {
|
2016-01-08 13:41:33 +00:00
|
|
|
var i;
|
|
|
|
var url;
|
2016-01-08 13:36:49 +00:00
|
|
|
themeSettings = {};
|
2015-07-15 22:43:24 +01:00
|
|
|
|
2016-01-08 13:36:49 +00:00
|
|
|
var themeApp = express();
|
2015-07-15 22:43:24 +01:00
|
|
|
|
2016-01-08 13:36:49 +00:00
|
|
|
if (theme.page) {
|
|
|
|
if (theme.page.css) {
|
|
|
|
var styles = theme.page.css;
|
|
|
|
if (!util.isArray(styles)) {
|
|
|
|
styles = [styles];
|
2015-04-13 00:11:11 +01:00
|
|
|
}
|
2016-01-08 13:36:49 +00:00
|
|
|
themeContext.page.css = [];
|
2015-07-15 22:43:24 +01:00
|
|
|
|
2016-01-08 13:36:49 +00:00
|
|
|
for (i=0;i<styles.length;i++) {
|
|
|
|
url = serveFile(themeApp,"/css/",styles[i]);
|
2015-04-13 00:11:11 +01:00
|
|
|
if (url) {
|
2016-01-08 13:36:49 +00:00
|
|
|
themeContext.page.css.push(url);
|
2015-04-13 00:11:11 +01:00
|
|
|
}
|
|
|
|
}
|
2016-01-08 13:36:49 +00:00
|
|
|
}
|
2015-07-15 22:43:24 +01:00
|
|
|
|
2016-01-08 13:36:49 +00:00
|
|
|
if (theme.page.favicon) {
|
|
|
|
url = serveFile(themeApp,"/favicon/",theme.page.favicon)
|
|
|
|
if (url) {
|
|
|
|
themeContext.page.favicon = url;
|
|
|
|
}
|
2015-04-13 00:11:11 +01:00
|
|
|
}
|
2016-08-10 20:15:17 +01:00
|
|
|
|
2016-02-08 09:20:07 -05:00
|
|
|
if (theme.page.tabicon) {
|
|
|
|
url = serveFile(themeApp,"/tabicon/",theme.page.tabicon)
|
|
|
|
if (url) {
|
|
|
|
themeContext.page.tabicon = url;
|
|
|
|
}
|
|
|
|
}
|
2015-07-15 22:43:24 +01:00
|
|
|
|
2016-01-08 13:36:49 +00:00
|
|
|
themeContext.page.title = theme.page.title || themeContext.page.title;
|
|
|
|
}
|
2015-07-15 22:43:24 +01:00
|
|
|
|
2016-01-08 13:36:49 +00:00
|
|
|
if (theme.header) {
|
2015-07-15 22:43:24 +01:00
|
|
|
|
2016-01-08 13:36:49 +00:00
|
|
|
themeContext.header.title = theme.header.title || themeContext.header.title;
|
2015-07-15 22:43:24 +01:00
|
|
|
|
2016-01-08 13:36:49 +00:00
|
|
|
if (theme.header.hasOwnProperty("url")) {
|
|
|
|
themeContext.header.url = theme.header.url;
|
2015-04-13 00:11:11 +01:00
|
|
|
}
|
2015-07-15 22:43:24 +01:00
|
|
|
|
2016-01-08 13:36:49 +00:00
|
|
|
if (theme.header.hasOwnProperty("image")) {
|
|
|
|
if (theme.header.image) {
|
|
|
|
url = serveFile(themeApp,"/header/",theme.header.image);
|
|
|
|
if (url) {
|
|
|
|
themeContext.header.image = url;
|
2015-04-13 09:48:49 +01:00
|
|
|
}
|
2016-01-08 13:36:49 +00:00
|
|
|
} else {
|
|
|
|
themeContext.header.image = null;
|
2015-04-13 09:48:49 +01:00
|
|
|
}
|
|
|
|
}
|
2016-01-08 13:36:49 +00:00
|
|
|
}
|
2015-07-15 22:43:24 +01:00
|
|
|
|
2016-01-08 13:36:49 +00:00
|
|
|
if (theme.deployButton) {
|
|
|
|
if (theme.deployButton.type == "simple") {
|
|
|
|
themeSettings.deployButton = {
|
|
|
|
type: "simple"
|
|
|
|
}
|
|
|
|
if (theme.deployButton.label) {
|
|
|
|
themeSettings.deployButton.label = theme.deployButton.label;
|
|
|
|
}
|
|
|
|
if (theme.deployButton.icon) {
|
|
|
|
url = serveFile(themeApp,"/deploy/",theme.deployButton.icon);
|
2015-04-13 10:37:30 +01:00
|
|
|
if (url) {
|
2016-01-08 13:36:49 +00:00
|
|
|
themeSettings.deployButton.icon = url;
|
2015-04-13 10:37:30 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2016-01-08 13:36:49 +00:00
|
|
|
}
|
2015-07-15 22:43:24 +01:00
|
|
|
|
2016-01-08 13:36:49 +00:00
|
|
|
if (theme.hasOwnProperty("userMenu")) {
|
|
|
|
themeSettings.userMenu = theme.userMenu;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (theme.login) {
|
|
|
|
if (theme.login.image) {
|
|
|
|
url = serveFile(themeApp,"/login/",theme.login.image);
|
|
|
|
if (url) {
|
|
|
|
themeContext.login = {
|
|
|
|
image: url
|
|
|
|
}
|
|
|
|
}
|
2015-04-13 13:55:17 +01:00
|
|
|
}
|
2016-01-08 13:36:49 +00:00
|
|
|
}
|
2015-07-15 22:43:24 +01:00
|
|
|
|
2016-01-08 13:36:49 +00:00
|
|
|
if (theme.hasOwnProperty("menu")) {
|
|
|
|
themeSettings.menu = theme.menu;
|
2015-04-13 00:11:11 +01:00
|
|
|
}
|
2016-01-08 13:36:49 +00:00
|
|
|
|
2016-08-10 20:15:17 +01:00
|
|
|
if (theme.hasOwnProperty("palette")) {
|
|
|
|
themeSettings.palette = theme.palette;
|
|
|
|
}
|
2016-01-08 13:36:49 +00:00
|
|
|
return themeApp;
|
2015-04-13 00:11:11 +01:00
|
|
|
},
|
|
|
|
context: function() {
|
|
|
|
return themeContext;
|
|
|
|
},
|
|
|
|
settings: function() {
|
|
|
|
return themeSettings;
|
|
|
|
}
|
|
|
|
}
|