-
Notifications
You must be signed in to change notification settings - Fork 2
/
AdminHelp.module
324 lines (253 loc) · 10.3 KB
/
AdminHelp.module
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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
<?php
/**
* ProcessWire Admin Help Module
*
* Main module for setup
*
* @copyright Copyright (c) 2015, Macrura/Outflux3
*
*/
class AdminHelp extends WireData implements Module, ConfigurableModule {
/**
* Return information about this module (required)
*
* @return array
*
*/
static public function getModuleInfo() {
return array(
'title' => 'Admin Help Setup',
'summary' => 'Main module for managing setup of admin help pages',
'version' => 109,
'author' => 'Marc W. | @Macrura(community), @outflux3 (Github), http://nibiri.com',
'autoload' => true,
'icon' => 'life-ring'
);
}
/**
* Name of activity/error log files without extension (.txt)
*
*/
const LOG_FILENAME_ACTIVITY = 'adminhelp_activity';
/**
* __construct() is the right place to init config vars before they'll get populated
*
*/
public function __construct() {
$configData = $this->modules->getModuleConfigData($this);
$this->setupYN = (!empty($configData['setupYN']) ? $configData['setupYN'] : "");
}
/**
* init() is called when PW's API is ready
*
*/
public function init() {
}
/**
* ready() is called when both PW's API is ready and $page object is initialized (for autoload modules!)
* Add the hook here to be able to skip it based on the template of the edited page.
*
*/
public function ready() {
if($this->setupYN === 1) {
$this->runSetup();
}
}
private function runSetup() {
$data = $this->modules->getModuleConfigData($this);
// if there is no template select field, and the Fieldtype is installed, setup that field:
if(!$this->fields->get('template_select') && $this->modules->get("FieldtypeTemplates")) {
$field = new Field();
$field->type = $this->modules->get("FieldtypeTemplates");
$field->name = 'template_select';
$field->label = 'Select Template';
$field->description = 'Select the templates to show this help doc on.';
$field->save();
$this->log->save( self::LOG_FILENAME_ACTIVITY , 'template_select field created');
}
// if there is no help-index template, and the user hasn't set their own...
if(!$this->templates->get('help-index') && !$data['helpTplIndex']) {
//new fieldgroup
$fg = new Fieldgroup();
$fg->name = 'help-index';
// help-index only needs title:
$field = $this->fields->get('title');
$fg->add($field);
// Save FG
$fg->save();
//create a new template to use with this fieldgroup
$t = new Template();
$t->name ='help-index';
$t->fieldgroup = $fg; //add the fieldgroup
$t->noParents = -1; // set the index temlpate to only be used once.
//save new template with fields and settings now added
$t->save();
$this->log->save( self::LOG_FILENAME_ACTIVITY , 'help-index template created');
// tell the module to use this template as the index.
$data['helpTplIndex'] = $t->name;
}
// if there is no help-doc template, and the user hasn't set their own...
if(!$this->templates->get('help-doc') && !$data['helpTpl']) {
//new fieldgroup
$fg = new Fieldgroup();
$fg->name = 'help-doc';
$field = $this->fields->get('title');
$fg->add($field);
if($this->fields->get('body')) {
$field = $this->fields->get('body');
$fg->add($field);
} else {
$this->message($this->_("No body field was found, please add manually."));
}
if($this->fields->get('images')) {
$field = $this->fields->get('images');
$fg->add($field);
} else {
$this->message($this->_("No image field was found, please add manually."));
}
if($this->fields->get('template_select')) {
$field = $this->fields->get('template_select');
$fg->add($field);
}
$fg->save();
//create a new template to use with this fieldgroup
$t = new Template();
$t->name ='help-doc';
$t->fieldgroup = $fg; //add the fieldgroup
// Set the parent allowed template of the help page to the help-index
$par = wire('templates')->get('help-index');
$t->parentTemplates = array($par->id); //needs to be added as array of template IDs
$t->noChildren = 1; // keep this only 1 level deep for now...
$t->save();
$this->log->save( self::LOG_FILENAME_ACTIVITY , 'help-doc template created');
// tell the module to use this template for the help doc.
$data['helpTpl'] = $t->name;
}
// once the 2 templates above are added, set the parent template to only allow the child:
if(wire('templates')->get('help-index') && wire('templates')->get('help-doc')) {
$hindextpl = wire('templates')->get('help-index');
$hdoctpl = wire('templates')->get('help-doc');
$hindextpl->childTemplates = array($hdoctpl->id);
$hindextpl->save();//save the template
if(!$data['helpTplIndex']) $data['helpTplIndex'] = $hindextpl->name;
if(!$data['helpTpl']) $data['helpTpl'] = $hdoctpl->name;
//$this->message($this->_("Config Data: " . print_r($data, true) ) );
if(!$data['helpRoot']) {
// Make new Help Docs Index page
$p = new Page();
$p->parent = '/';
$p->template = $hindextpl;
$p->title = 'Help Docs';
$p->name = 'help-docs';
//if name already exists [i.e. a child under this parent]; don't proceed
if($p->parent->child("name={$p->name}, include=all")->id) {
//if name already in use, we tell the user in an error message and halt proceedings
$this->error($this->_("There is already a Help Docs page."));
return false;
}
$p->addStatus(Page::statusHidden);
$p->save();
$this->message($this->_("Added Help Docs index page."));
$data['helpRoot'] = $p->id;
// add the child page
$pc = new Page();
$pc->parent = $p;
$pc->template = $hdoctpl;
$pc->title = 'Basic Page Help';
$pc->name = 'basic-page-help';
$pc->body = file_get_contents($this->config->paths->siteModules . __CLASS__ . DIRECTORY_SEPARATOR . 'example.html');
$tplBasic = $this->templates->get('basic-page');
$pc->template_select = $tplBasic;
$pc->save();
$this->message($this->_("Added Example Page."));
}
}
// Unset the setup checkbox:
$data['setupYN'] = '';
// Save the new config data:
wire('modules')->saveModuleConfigData(__CLASS__, $data);
}
/**
* Return an InputfieldsWrapper of Inputfields used to configure the class
*
* @param array $data Array of config values indexed by field name
* @return InputfieldsWrapper
*
*/
public static function getModuleConfigInputfields(array $data) {
$wrapper = new InputfieldWrapper();
/* INSTRUCTIONS
------------------------------------------------------------------------ */
$f = wire('modules')->get('InputfieldMarkup');
$f->name = 'instructions';
$f->label = __('Instructions', __FILE__);
//$text = wireRenderFile(__DIR__ . '/instructions.php');
//$f->markupText = __($text, __FILE__);
$f->markupText = wireRenderFile(__DIR__ . '/instructions.php');
$wrapper->add($f);
// Select the help index template --------------------------------------------------
$field = wire('modules')->get('InputfieldSelect');
$field->attr('name+id', 'helpTplIndex');
$field->label = __('Help index template', __FILE__);
$field->description = __('Please set the template used for the help index', __FILE__);
$field->attr('title', __('Help Index Template', __FILE__));
$field->columnWidth = 50;
// populate with all available templates
foreach(wire('templates') as $t) {
// filter out system templates
if(!($t->flags & Template::flagSystem)) $field->addOption($t->name);
}
if(isset($data['helpTplIndex'])) $field->value = $data['helpTplIndex'];
$wrapper->add($field);
// Select the help template --------------------------------------------------
$field = wire('modules')->get('InputfieldSelect');
$field->attr('name+id', 'helpTpl');
$field->label = __('Help pages template', __FILE__);
$field->description = __('Please set the template to be used for help pages.', __FILE__);
$field->attr('title', __('Help Page Template', __FILE__));
$field->columnWidth = 50;
// populate with all available templates
foreach(wire('templates') as $t) {
// filter out system templates
if(!($t->flags & Template::flagSystem)) $field->addOption($t->name);
}
if(isset($data['helpTpl'])) $field->value = $data['helpTpl'];
$wrapper->add($field);
// make a field to set the root of the help pages ---------------------------
$field = wire('modules')->get('InputfieldPageListSelect');
$field->attr('name+id', 'helpRoot');
$field->label = __('Help Pages Root', __FILE__);
$field->description = __('Select the root your help pages. (Allows the module to know where to create new help docs.', __FILE__);
$field->attr('title', __('Help root', __FILE__));
if(isset($data['helpRoot'])) {
$savedPageID = (int) $data['helpRoot'];// name of our input above
$field->value = $savedPageID;
}
$wrapper->add($field);
// make a checkbox to optionally create the help templates, fields and pages ---------------------------
$field = wire('modules')->get('InputfieldCheckbox');
$field->attr('name', 'setupYN');
$field->label = __('Setup Fields, Templates & Pages?', __FILE__);
$field->description = __('Select this and hit submit to setup the fields, templates and pages.', __FILE__);
$field->notes = __("Selecting this and submitting will initiate an automated process that will create the template_select field, help-index template, help-doc template, and if there is no help docs root specified, a Help Docs index page, and a sample Help Page for basic page. Note: You must install FieldtypeTemplates to auto-create the template select field.");
$field->collapsed = 1;
//$field->showIf = "helpTpl|helpTplIndex=''";
if( !isset($data['setupYN']) || $data['setupYN'] == '') {
$field->value = '';
} else {
$field->value = 1;
}
$field->checked = ($field->value == 1) ? 'checked' : '';
$wrapper->add($field);
// make a checkbox to specify use of modal
$field = wire('modules')->get('InputfieldCheckbox');
$field->attr('name', 'use_modal');
$field->label = __('** This setting is now on the Help Tab Module Config ** ', __FILE__);
$field->notes = __('This setting has no effect - it is here for backwards compatibility - please set this on the other module config.', __FILE__);
$field->value = (isset($data['use_modal'])) ? $data['use_modal'] : 1;
$field->checked = ($field->value == 1) ? 'checked' : '';
$field->collapsed = 1;
$wrapper->add($field);
return $wrapper;
}
}