-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvue-example.php
68 lines (61 loc) · 2.37 KB
/
vue-example.php
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
<?php
namespace Grav\Plugin;
use Grav\Common\Plugin;
use RocketTheme\Toolbox\Event\Event;
/**
* Class VueExamplePlugin
* @package Grav\Plugin
*/
class VueExamplePlugin extends Plugin {
/**
* @return array
*
* The getSubscribedEvents() gives the core a list of events
* that the plugin wants to listen to. The key of each
* array section is the event that the plugin listens to
* and the value (in the form of an array) contains the
* callable (or function) as well as the priority. The
* higher the number the higher the priority.
*/
public static function getSubscribedEvents() {
return [
'onPluginsInitialized' => [ 'onPluginsInitialized', 0 ]
];
}
/**
* Initialize the plugin
*/
public function onPluginsInitialized() {
// Don't proceed if we are in the admin plugin
if ( $this->isAdmin() ) {
return;
}
// Enable the main event we are interested in
$this->enable( [
'onPageContentProcessed' => [ 'onPageContentProcessed', 0 ],
'onAssetsInitialized' => [ 'onAssetsInitialized', 0 ],
] );
}
/**
* Programmatically add a vue element, so you don't need to modify your theme twig
* what you should know is you should include {{ page.content }} in your page twig at least, cuz onPageContentProcessed change the page.content,
* if you don't include it, absolutely vue can't find the anchor.
*/
public function onPageContentProcessed() {
// Get a variable from the plugin configuration
$content = $this->grav['page']->getRawContent();
$vueAnchor = '<div id="grav-plugin-vue-example-app"></div>';
$this->grav['page']->setRawContent( $vueAnchor . $content );
}
public function onAssetsInitialized() {
/**
* Attention: Grav can only handle the duplicate JS files( md5 check or Just path string? ),but not the window.GlOBLE_NAME itself;
* so you should take care of the exposed "Vue" by yourself. or bundle it with your code in a closure.
* if you have multiple plugins share one vue.js file, the better place to add it is in the site configuration.
*/
// $this->grav['assets']->addJs( 'https://unpkg.com/[email protected]/dist/vue.js'); // for develop
$this->grav['assets']->addJs( 'https://unpkg.com/[email protected]/dist/vue.min.js'); // for production
$this->grav['assets']->addJs( 'plugin://' . $this->name . '/dist/bundle.js');
$this->grav['assets']->addCss( 'plugin://' . $this->name . '/dist/bundle.css');
}
}