Class DocumentLinkerImpl
- java.lang.Object
- 
- org.apache.tapestry5.internal.services.DocumentLinkerImpl
 
- 
- All Implemented Interfaces:
- DocumentLinker
 
 public class DocumentLinkerImpl extends Object implements DocumentLinker 
- 
- 
Constructor SummaryConstructors Constructor Description DocumentLinkerImpl(ModuleManager moduleManager, boolean omitGeneratorMetaTag, boolean enablePageloadingMask, String tapestryVersion)
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description protected voidaddContentToBody(Element body)Adds<script>elements for the RequireJS library, then any statically includes JavaScript libraries (including JavaScript stack virtual assets), then the initialization script block.voidaddCoreLibrary(String libraryURL)A special case used only for the libraries that are part of the core stack, which itself contains RequireJS and is used to bootstrap up to adding non-core libraries.voidaddInitialization(InitializationPriority priority, String moduleName, String functionName, JSONArray arguments)Adds initialization, based on invoking functions exported by JavaScript modules.voidaddLibrary(String libraryURL)Adds a link to load a non-core JavaScript library.voidaddModuleConfigurationCallback(ModuleConfigurationCallback callback)Adds a module configuration callback for this request.voidaddScript(InitializationPriority priority, String script)Adds JavaScript code.voidaddStylesheetLink(StylesheetLink sheet)Adds a link to load a CSS stylesheet.protected voidaddStylesheetsToHead(Element root, List<StylesheetLink> stylesheets)Locates the head element under the root ("html") element, creating it if necessary, and adds the stylesheets to it.voidupdateDocument(Document document)Updates the supplied Document, possibly adding <head> or <body> elements.
 
- 
- 
- 
Constructor Detail- 
DocumentLinkerImplpublic DocumentLinkerImpl(ModuleManager moduleManager, boolean omitGeneratorMetaTag, boolean enablePageloadingMask, String tapestryVersion) - Parameters:
- moduleManager- used to identify the root folder for dynamically loaded modules
- omitGeneratorMetaTag- via symbol configuration
- enablePageloadingMask-
- tapestryVersion-
 
 
- 
 - 
Method Detail- 
addStylesheetLinkpublic void addStylesheetLink(StylesheetLink sheet) Description copied from interface:DocumentLinkerAdds a link to load a CSS stylesheet.- Specified by:
- addStylesheetLinkin interface- DocumentLinker
 
 - 
addCoreLibrarypublic void addCoreLibrary(String libraryURL) Description copied from interface:DocumentLinkerA special case used only for the libraries that are part of the core stack, which itself contains RequireJS and is used to bootstrap up to adding non-core libraries.- Specified by:
- addCoreLibraryin interface- DocumentLinker
 
 - 
addLibrarypublic void addLibrary(String libraryURL) Description copied from interface:DocumentLinkerAdds a link to load a non-core JavaScript library. These libraries are loaded, sequentially, only once the core libraries have loaded and initialized. Thus difference between core libraries and other libraries is new in 5.4, and represents a conflict between asynchronous loading of modules (introduced in 5.4) and sequential loading of libraries (in 5.3 and earlier).- Specified by:
- addLibraryin interface- DocumentLinker
 
 - 
addScriptpublic void addScript(InitializationPriority priority, String script) Description copied from interface:DocumentLinkerAdds JavaScript code. The code is collected into a single block that is injected just before the close body tag of the page (in a full page render) and collected as the "script" property of the partial page render response. The JavaScript is executed after the page loads (or in an Ajax update, after external JavaScript libraries are loaded and the DOM is updated). This method may be called multiple times for the same priority and the script will be accumulated.- Specified by:
- addScriptin interface- DocumentLinker
- Parameters:
- priority- when to execute the provided script
- script- statement to add to the block (a newline will be appended as well)
 
 - 
addInitializationpublic void addInitialization(InitializationPriority priority, String moduleName, String functionName, JSONArray arguments) Description copied from interface:DocumentLinkerAdds initialization, based on invoking functions exported by JavaScript modules.- Specified by:
- addInitializationin interface- DocumentLinker
- Parameters:
- priority- priority at which to perform initialization
- moduleName- name of module; the module exports a single function, or a map of functions
- functionName- name of function exported by module, or null (if the module exports a single function)
- arguments- arguments to pass to the function, or null if no arguments
 
 - 
updateDocumentpublic void updateDocument(Document document) Updates the supplied Document, possibly adding <head> or <body> elements.- Parameters:
- document- to be updated
 
 - 
addContentToBodyprotected void addContentToBody(Element body) Adds<script>elements for the RequireJS library, then any statically includes JavaScript libraries (including JavaScript stack virtual assets), then the initialization script block.- Parameters:
- body- element to add the dynamic scripting to
 
 - 
addStylesheetsToHeadprotected void addStylesheetsToHead(Element root, List<StylesheetLink> stylesheets) Locates the head element under the root ("html") element, creating it if necessary, and adds the stylesheets to it.- Parameters:
- root- element of document
- stylesheets- to add to the document
 
 - 
addModuleConfigurationCallbackpublic void addModuleConfigurationCallback(ModuleConfigurationCallback callback) Description copied from interface:DocumentLinkerAdds a module configuration callback for this request.- Specified by:
- addModuleConfigurationCallbackin interface- DocumentLinker
- Parameters:
- callback- a- ModuleConfigurationCallback. It cannot be null.
 
 
- 
 
-