diff options
author | Thomas Lange <code@nerdmind.de> | 2016-06-23 13:10:24 +0200 |
---|---|---|
committer | Thomas Lange <code@nerdmind.de> | 2016-06-23 13:16:30 +0200 |
commit | c5637489e603c588fca41e2b7bd4345b67914f33 (patch) | |
tree | 5a1e8cc8f9558105422c24ddf8c1b8067df0a081 /include/pagelets.php | |
parent | 102d2dc24505f4ce7fe6601b21a7e2e414f613cb (diff) | |
download | bigpipe-c5637489e603c588fca41e2b7bd4345b67914f33.tar.gz bigpipe-c5637489e603c588fca41e2b7bd4345b67914f33.tar.xz bigpipe-c5637489e603c588fca41e2b7bd4345b67914f33.zip |
Pagelets executed immediately; Dependency feature; Several improvements
+ All pagelets are now executed immediately on arrive.
+ A "Display Dependency" feature was added. If you give a pagelet an dependency, it will first be executed if all pagelets, who registered as dependency, are displayed.
+ If BigPipe.reset() is called, the function loops through each Resource and executes Resource.abortLoading(). This removes the <link> or <script> element from DOM and removes the onload callbacks. This is to prevent that an onload callback from a previous page are executed while the user has already changes the page asynchronously and a resource from the previous page wasn't already loaded.
Diffstat (limited to 'include/pagelets.php')
-rw-r--r-- | include/pagelets.php | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/include/pagelets.php b/include/pagelets.php new file mode 100644 index 0000000..176bc74 --- /dev/null +++ b/include/pagelets.php @@ -0,0 +1,50 @@ +<?php +#=============================================================================== +# Pagelet with red background color +#=============================================================================== +$PageletRed = new BigPipe\DemoPagelet('redPL'); +$PageletRed->addHTML('<section id="red" class="text">I AM A PAGELET WITH RED BACKGROUND</section>'); +$PageletRed->addCSS('static/red.php'); +$PageletRed->addCSS('static/red.php'); +$PageletRed->addJS('static/delayJS.php'); +$PageletRed->addJSCode("document.getElementById('red').innerHTML += ' [JS executed]';document.getElementById('red').style.borderRadius = '30px';"); + +#=============================================================================== +# Pagelet with blue background color +#=============================================================================== +$PageletBlue = new BigPipe\DemoPagelet('bluePL', BigPipe\Pagelet::PRIORITY_HIGH); +$PageletBlue->addHTML('<section id="blue" class="text">I AM A PAGELET WITH BLUE BACKGROUND</section>'); +$PageletBlue->addCSS('static/blue.php'); +$PageletRed->addCSS('static/red.php'); +$PageletBlue->addJS('static/delayJS.php'); +$PageletBlue->addJSCode("document.getElementById('blue').innerHTML += ' [JS executed]';document.getElementById('blue').style.borderRadius = '30px';"); + +#=============================================================================== +# Pagelet with green background color +#=============================================================================== +$PageletGreen = new BigPipe\DemoPagelet('greenPL'); + +{ + #=============================================================================== + # Pagelet within $PageletGreen + #=============================================================================== + // The third parameter is required to ensure that the $InnerPagelet will only be + // executed if the HTML from the $PageletGreen has ALREADY DISPLAYED. Otherwise, + // $InnerPagelet would not find his placeholder tag which is defined WITHIN the + // HTML on $PageletGreen. Of course, you can still add other pagelets as + // dependency. Then will $InnerPagelet only displayed if all dependencies are + // already displayed! + // + // NOTE: PRIORITY_HIGHEST is only set so that you can see, that this pagelet is + // the first which arrives, but it will first be displayed if his dependency + // pagelets are already displayed. + + $InnerPagelet = new BigPipe\DemoPagelet('innerPL', BigPipe\Pagelet::PRIORITY_HIGHEST, [$PageletGreen->getID()]); + $InnerPagelet->addHTML('<section sytle="background:#FFF;padding:5px;">Inner Pagelet \(o_o)/</section>'); +} + +$PageletGreen->addHTML('<section id="green" class="text">I AM A PAGELET WITH GREEN BACKGROUND'.$InnerPagelet.'</section>'); +$PageletGreen->addCSS('static/green.php'); +$PageletGreen->addJS('static/delayJS.php'); +$PageletGreen->addJSCode("document.getElementById('green').innerHTML += ' [JS executed]';document.getElementById('green').style.borderRadius = '30px';"); +?>
\ No newline at end of file |