forked from rainlab/blog-plugin
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Plugin.php
95 lines (84 loc) · 2.85 KB
/
Plugin.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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
<?php namespace RainLab\Blog;
use Backend;
use Controller;
use System\Classes\PluginBase;
use RainLab\Blog\Classes\TagProcessor;
class Plugin extends PluginBase
{
public function pluginDetails()
{
return [
'name' => 'Blog',
'description' => 'A robust blogging platform.',
'author' => 'Alexey Bobkov, Samuel Georges',
'icon' => 'icon-pencil'
];
}
public function registerComponents()
{
return [
'RainLab\Blog\Components\Post' => 'blogPost',
'RainLab\Blog\Components\Posts' => 'blogPosts',
'RainLab\Blog\Components\Categories' => 'blogCategories',
'RainLab\Blog\Components\Category' => 'blogCategory'
];
}
public function registerNavigation()
{
return [
'blog' => [
'label' => 'Blog',
'url' => Backend::url('rainlab/blog/posts'),
'icon' => 'icon-pencil',
'permissions' => ['blog.*'],
'order' => 500,
'sideMenu' => [
'posts' => [
'label' => 'Posts',
'icon' => 'icon-copy',
'url' => Backend::url('rainlab/blog/posts'),
'permissions' => ['blog.access_posts'],
],
'categories' => [
'label' => 'Categories',
'icon' => 'icon-list-ul',
'url' => Backend::url('rainlab/blog/categories'),
'permissions' => ['blog.access_categories'],
],
]
]
];
}
public function registerFormWidgets()
{
return [
'RainLab\Blog\FormWidgets\Preview' => [
'label' => 'Preview',
'alias' => 'preview'
]
];
}
/**
* Register method, called when the plugin is first registered.
*/
public function register()
{
/*
* Register the image tag processing callback
*/
TagProcessor::instance()->registerCallback(function($input, $preview){
if (!$preview)
return $input;
return preg_replace('|\<img alt="([0-9]+)" src="image" \/>|m',
'<span class="image-placeholder" data-index="$1">
<span class="dropzone">
<span class="label">Click or drop an image...</span>
<span class="indicator"></span>
</span>
<input type="file" class="file" name="image[$1]"/>
<input type="file" class="trigger"/>
</span>',
$input);
});
}
}