forked from pencilblue/pencilblue
-
Notifications
You must be signed in to change notification settings - Fork 0
/
client_js.js
executable file
·101 lines (87 loc) · 3.63 KB
/
client_js.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
/*
Copyright (C) 2016 PencilBlue, LLC
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
'use strict';
//dependencies
var util = require('./util.js');
module.exports = function ClientJsModule(pb) {
/**
* Service for creating JavaScript tags
*
* @module Services
* @class ClientJs
* @constructor
*/
function ClientJs(){}
/**
* Creates a basic AngularJS controller with a repeat directive for templatizing
* @static
* @method getAngularController
* @param {Object} objects Object to be passed into AngularJS scope
* @param {Array} modules Array of AngularJS module names
* @param {String} [directiveJS] JavaScript to run after on-finish-render directive
*/
ClientJs.getAngularController = function(objects, modules, directiveJS) {
if(!util.isArray(modules) || modules.length === 0) {
modules = ['ngRoute'];
}
var angularController = 'var pencilblueApp = angular.module("pencilblueApp", ' + JSON.stringify(modules) + ')';
if(!util.isNullOrUndefined(directiveJS)) {
angularController += '.directive("onFinishRender", function($timeout){return {restrict: "A",link: function(scope, element, attr){if (scope.$last === true){$timeout(function(){' + directiveJS + '})}}}})';
}
var scopeString = ClientJs.getAngularObjects(objects);
angularController = angularController.concat('.controller("PencilBlueController", function($scope, $sce) {' + scopeString + "});\n");
angularController = angularController.concat('pencilblueApp.config(["$compileProvider",function(e){e.aHrefSanitizationWhitelist(/^\s*(https?|ftp|mailto|javascript):/)}]);');
return ClientJs.getJSTag(angularController);
};
/**
*
* @static
* @method getAngularObjects
* @param {Object} objects
* @return {String}
*/
ClientJs.getAngularObjects = function(objects) {
var scopeString = '';
Object.keys(objects).forEach(function(key) {
if(util.isString(objects[key]) && objects[key].indexOf('function(') === 0) {
scopeString = scopeString.concat('$scope.' + key + ' = ' + objects[key] + ";\n");
return;
}
scopeString = scopeString.concat('$scope.' + key + '=' + JSON.stringify(objects[key], null, pb.log.isSilly() ? ' ' : undefined) + ";\n");
});
return scopeString;
};
/**
* Creates a JS tag that loads the specified url
*
* @static
* @method includeJS
* @param {String} url
*/
ClientJs.includeJS = function(url) {
return new pb.TemplateValue('<script type="text/javascript" src="' + url + '"></script>', false);
};
/**
* Puts the supplied JS code string into a script tag
*
* @static
* @method getJSTag
* @param {String} jsCode
*/
ClientJs.getJSTag = function(jsCode) {
return new pb.TemplateValue('<script type="text/javascript">\n' + jsCode + '\n</script>', false);
};
//exports
return ClientJs;
};