Môžete pridať panel Vlastné nastavenia, ktorý poskytuje polia pre všetky dátové prvky definované v HTML komponente. Používateľ potom môže na stránke na paneli Vlastné nastavenia vyplniť hodnoty pre inštanciu komponentu.
render.html, aby obsahovala všetky požadované dátové prvky. Nasledujúci príklad používa šablónový jazyk Mustache JS, takže dátové prvky je potrebné pridať so syntaxou {{ a }}, ako je uvedené dole:
<ul class="wrapper">
<li class="box">
<h1 class="title">{{title1}}</h1>
<p class="text">{{text1}}</p>
</li>
<li class="box">
<h1 class="title">{{title2}}</h1>
<p class="text">{{text2}}</p>
</li>
<li class="box">
<h1 class="title">{{title3}}</h1>
<p class="text">{{text3}}</p>
</li>
<li class="box">
<h1 class="title">{{title4}}</h1>
<p class="text">{{text4}}</p>
</li>
</ul>appinfo.json v HTML komponente:
{
"id": "html-component-id",
"settingsData": {
"settingsHeight":600,
"settingsWidth": 300,
"settingsRenderOption": "dialog",
"componentLayouts": [],
"triggers": [],
"actions": []
},
"initialData": {
"styleClassName": "html-component",
"customSettingsData": {
"title1":"One",
"title2":"Two",
"title3":"Three",
"title4":"Four",
"text1":"Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.",
"text2":"Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.",
"text3":"Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.",
"text4":"Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua."
},
"nestedComponents": []
}
}render.html HTML šablóny na vytvorenie nastavení, ktoré používateľ zmení v editore. Zmeňte obsah súboru settings.html na nasledujúci:
<!DOCTYPE html>
<html lang="en">
<head>
<!-- only allow embedding of this iFrame in SCS -->
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>H1 Mustache Component</title>
<!-- include sample apps styling -->
<link href="/_sitescloud/renderer/app/sdk/css/app-styles.css" rel="stylesheet">
<!-- include supporting files -->
<script type="text/javascript" src="/_sitescloud/renderer/app/apps/js/knockout.min.js"></script>
<script type="text/javascript" src="/_sitescloud/renderer/app/apps/js/jquery.min.js"></script>
<!-- include the Sites SDK -->
<script type="text/javascript" src="/_sitescloud/renderer/app/sdk/js/sites.min.js"></script>
</head>
<body data-bind="visible: true" style="display:none; margin:0px; padding:0px;background:transparent;background-
image:none;">
<!-- ko if: initialized() -->
<div class="scs-component-settings">
<div>
<!-- Width -->
<label id="headingTextLabel" for="headingText" class="settings-heading" data-bind="text:
'Heading Text'"></label>
<input id="headingText" data-bind="value: headingText" placeholder="Heading" class="settings-
text-box">
</div>
</div>
<div data-bind="setSettingsHeight: true"></div>
<!-- /ko -->
<!-- ko ifnot: initialized() -->
<div data-bind="text: 'waiting for initialization to complete'"></div>
<!-- /ko -->
<script type="text/javascript">
// set the iFrame height when we've fully rendered
ko.bindingHandlers.scsCompComponentImpl = {
init: function (element, valueAccessor, allBindings, viewModel, bindingContext) {
var body = document.body,
html = document.documentElement;
SitesSDK.setHeight(Math.max(
body.scrollHeight,
body.offsetHeight,
html.clientHeight,
html.scrollHeight,
html.offsetHeight));
}
};
// define the viewModel object
var SettingsViewModel = function () {
var self = this;
// create the observables for passing data
self.headingText = ko.observable('Heading 1');
// create rest of viewModel
self.initialized = ko.observable(false);
self.saveData = false;
// Get custom settings
SitesSDK.getProperty('customSettingsData', function (data) {
//update observable
self.headingText(data.headingText);
// note that viewModel is initialized and can start saving data
self.initialized(true);
self.saveData = true;
});
// save whenever any updates occur
self.save = ko.computed(function () {
var saveconfig = {
'headingText': self.headingText()
};
// save data in page
if (self.saveData) {
SitesSDK.setProperty('customSettingsData', saveconfig);
}
}, self);
};
// apply the bindings
ko.applyBindings(new SettingsViewModel());
</script>
</body>
Poznámka:
Pretože ste zmenili súborappinfo.json, na načítanie zmien je potrebné obnoviť prehľadávač a znova pridať komponent na stránku.Ako overiť, že komponent teraz načíta predvolené dáta zo súboru appinfo.json a že môžete zmeniť hodnoty na paneli Vlastné nastavenia (kontrolný bod 2):
Nezabudnite, že po zmene súboru appinfo.json je na načítanie zmien potrebné obnoviť prehľadávač a znova pridať komponent na stránku.
Otvorte panel Vlastné nastavenia v HTML komponente a zadajte dáta.

Overte, či komponent Oracle Content Management používa HTML a CSS so šablónami Mustache JS na vykresľovanie obsahu na základe dát, ktoré ste zadali na paneli Vlastné nastavenia .