Let’s say we have to access a page property foobar in our Angular Controller. One simple and quick way that might come to mind is to initialize with a ng-init directive like this:
<span ng-init="yourFooBar=’${properties.foobar}’" ></span>
This allows it to become available to the containing controller’s scope. But, what if your title is dynamic? There can potentially be a value where this syntax could go wrong, such as when you have a word with a single quote in it.
For example, foobar = Tonga, Pa’anga (a currency name I want to display on the page). The apostrophe in the word would abruptly end the word there, and subsequently, cause errors.
<span ng-init="yourFooBar=’Tonga, Pa'anga.’" ></span>
The alternative way to do this would be to initialize a script variable on the HTML page and pass it to the Angular Controller through Angular service ‘$window’ as shown below.
Detailed steps:
Create a component and its corresponding script file, such as demo.html and a dialog with demo field as shown.
data:image/s3,"s3://crabby-images/809ff/809ffe5950eadd4e3ea88e08602b9eee8d8f4d20" alt=""
data:image/s3,"s3://crabby-images/761d4/761d49a6558360f8a3d477a3e24dae97bb484ef6" alt=""
Demo.html:
<meta data-sly-use.clientlib="${'/libs/granite/sightly/templates/clientlib.html'}"></meta>
<meta data-sly-call="${clientlib.js @ categories='apps.demo'}"></meta>
<script type="text/javascript">
var yourFooBar = "${properties.foobar @ context='scriptString'}";
</script>
<section ng-app="yourApp" ng-controller="yourController">
<span> {{modifiedFooBar}}</span>
</section>
Note: By default, Sightly renders the page properties in the HTML context. To use your page properties inside <script> tags, you should mention the display context as ‘scriptString’.
2. Create a clientlib folder ‘demolib’ with category ‘apps.demo’. In js.txt include AngularJS library and your Javascript file in which you have the Angular Controller code.
data:image/s3,"s3://crabby-images/39261/3926111dcdb2009a59398e7dcc3ba157173d5651" alt=""
data:image/s3,"s3://crabby-images/635c8/635c84c676990343ab720fcdd322aedc0dcb40f0" alt=""
<meta data-sly-use.clientlib="${'/libs/granite/sightly/templates/clientlib.html'}"></meta>
<meta data-sly-call="${clientlib.js @ categories='apps.demo'}"></meta>
<script type="text/javascript">
var yourFooBar = "${properties.foobar @ context='scriptString'}";
</script>
<section ng-app="yourApp" ng-controller="yourController">
<span> {{modifiedFooBar}}</span>
</section>
Note: By default, Sightly renders the page properties in the HTML context. To use your page properties inside <script> tags, you should mention the display context as ‘scriptString’.
2. Create a clientlib folder ‘demolib’ with category ‘apps.demo’. In js.txt include AngularJS library and your Javascript file in which you have the Angular Controller code.
data:image/s3,"s3://crabby-images/39261/3926111dcdb2009a59398e7dcc3ba157173d5651" alt=""
data:image/s3,"s3://crabby-images/635c8/635c84c676990343ab720fcdd322aedc0dcb40f0" alt=""
Add the following code in demo.js file:
<code?(function(){
var app = angular.module('yourApp');
app.controller('yourController', ["$scope",'$window', function($scope, $window){
var modifiedFooBar = "";
$scope.modifiedFooBar = $window.yourFooBar.toUpperCase() + "is now all CAPS";
}]);
})();
Create a demo page. Fill the demo field with a single quote as follows.
data:image/s3,"s3://crabby-images/0446b/0446b149e773b6f39da875fef7c8a1055fdb88ca" alt=""
On the page, you should now see that we have successfully passed the page property ‘foobar’ with value “Tongan Pa’Anga” into Angular Controller and modified it to all CAPS.
data:image/s3,"s3://crabby-images/aa3c5/aa3c5a2831d12347ea9c765b6dcce646e460cbb7" alt=""
<code?(function(){
var app = angular.module('yourApp');
app.controller('yourController', ["$scope",'$window', function($scope, $window){
var modifiedFooBar = "";
$scope.modifiedFooBar = $window.yourFooBar.toUpperCase() + "is now all CAPS";
}]);
})();
Create a demo page. Fill the demo field with a single quote as follows.
data:image/s3,"s3://crabby-images/0446b/0446b149e773b6f39da875fef7c8a1055fdb88ca" alt=""
On the page, you should now see that we have successfully passed the page property ‘foobar’ with value “Tongan Pa’Anga” into Angular Controller and modified it to all CAPS.
data:image/s3,"s3://crabby-images/aa3c5/aa3c5a2831d12347ea9c765b6dcce646e460cbb7" alt=""
No comments:
Post a Comment
If you have any doubts or questions, please let us know.