-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathProcessJumplinksConfig.php
267 lines (240 loc) · 11.9 KB
/
ProcessJumplinksConfig.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
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
<?php
/**
* Jumplinks for ProcessWire
* Manage permanent and temporary redirects. Uses named wildcards and mapping collections.
*
* Process module for ProcessWire 2.6.1+
*
* @author Mike Rockett
* @copyright (c) 2015-19, Mike Rockett. All Rights Reserved.
* @license ISC
*
* @see Documentation: https://jumplinks.rockett.pw
* @see Modules Directory: https://mods.pw/92
* @see Forum Thred: https://processwire.com/talk/topic/8697-jumplinks/
* @see Donate: https://rockett.pw/donate
*/
class ProcessJumplinksConfig extends ModuleConfig
{
/**
* Documentation link
* @const string
*/
const DOCS_HREF = 'https://jumplinks.rockett.pw';
/**
* Support link
* @const string
*/
const SUPPORT_HREF = 'https://processwire.com/talk/topic/8697-jumplinks/';
/**
* Given a fieldtype, create, populate, and return an Inputfield
* @param string $fieldNameId
* @param array $meta
* @return Inputfield
*/
protected function buildInputField($fieldNameId, $meta)
{
$field = wire('modules')->get($fieldNameId);
foreach ($meta as $metaNames => $metaInfo) {
$metaNames = explode('+', $metaNames);
foreach ($metaNames as $metaName) {
$field->$metaName = $metaInfo;
}
}
return $field;
}
/**
* Get default condifguration, automatically passed to input fields.
* @return array
*/
public function getDefaults()
{
return [
'moduleDisable' => false,
'_schemaVersion' => 1, // Initial schema
'enhancedWildcardCleaning' => false,
'legacyDomain' => '',
'enable404Monitor' => false,
'moduleDebug' => false,
'redirectsImported' => false,
'statusCodes' => '200 301 302',
'wildcardCleaning' => 'fullClean',
];
}
/**
* Render input fields on config Page.
* @return string
*/
public function getInputFields()
{
// Inject assets
$moduleAssetPath = "{$this->config->urls->ProcessJumplinks}Assets";
$this->config->scripts->add("{$moduleAssetPath}/ProcessJumplinks.min.js");
$this->config->styles->add("{$moduleAssetPath}/ProcessJumplinks.css");
// Add JS config data
$this->config->js('pjModuleAdmin', true);
$this->config->js('pjAdminPageUrl', $this->pages->get('name=jumplinks,template=admin')->url);
$this->config->js('pjOldRedirectsInstalled', $this->modules->isInstalled('ProcessRedirects'));
// Start inputfields
$inputfields = parent::getInputfields();
// Wildcard Cleaning Fieldset
$fieldset = $this->buildInputField('InputfieldFieldset', [
'label' => $this->_('Wildcard Cleaning'),
]);
// Wildcard Cleaning
$fieldset->add($this->buildInputField('InputfieldRadios', [
'name+id' => 'wildcardCleaning',
'description' => $this->_("When set to 'Full Clean', each wildcard in a destination path will be automatically cleaned, or 'slugged', so that it is lower-case, and uses hyphens as word separators."),
'notes' => sprintf($this->_("**Note:** It's recommended that you keep this set to 'Full Clean', unless you have a module installed that uses different path formats (such as TitleCase with underscores or hyphens). **[Learn more about Wildcard Cleaning](%s/config#wildcard-cleaning)**"), self::DOCS_HREF),
'options' => [
'fullClean' => $this->_('Full Clean (default, recommended)'),
'semiClean' => $this->_("Clean, but don't change case"),
'noClean' => $this->_("Don't clean at all (not recommended)"),
],
'columnWidth' => 50,
'collapsed' => Inputfield::collapsedNever,
'skipLabel' => Inputfield::skipLabelHeader,
]));
// Enhanced Wildcard Cleaning
$fieldset->add($this->buildInputField('InputfieldCheckbox', [
'name+id' => 'enhancedWildcardCleaning',
'label' => $this->_('Enhanced Wildcard Cleaning'),
'description' => $this->_('When enabled, wildcard cleaning goes a step further by means of breaking and hyphenating TitleCase wildcards, as well as those that contain abbreviations (ex: NASALaunch). Examples below.'),
'label2' => $this->_('Use Enhanced Wildcard Cleaning'),
'notes' => $this->_("**Examples:** 'EnvironmentStudy' would become 'environment-study' and 'NASALaunch' would become 'nasa-launch'.\n**Note:** This feature only works when Wildcard Cleaning is enabled."),
'columnWidth' => 50,
'collapsed' => Inputfield::collapsedNever,
'autocheck' => true,
]));
$inputfields->add($fieldset);
// Legacy Domain Fieldset
$fieldset = $this->buildInputField('InputfieldFieldset', [
'label' => $this->_('Legacy Domain'),
'description' => sprintf($this->_('Only use this if you are performing a slow migration to ProcessWire, and would still like your visitors to access old content moved to a new location, like a subdomain or folder, for example. [Learn more about how this feature works](%s/config#legacy-domain).'), self::DOCS_HREF),
'collapsed' => Inputfield::collapsedYes,
]);
// Legacy Domain Name
$fieldset->add($this->buildInputField('InputfieldText', [
'name+id' => 'legacyDomain',
'columnWidth' => 50,
'description' => $this->_('Attempt any requested, unresolved Source paths on a legacy domain/URL.'),
'notes' => $this->_("Enter a *full*, valid domain/URL. **Source Path won't be cleaned upon redirect**."),
'placeholder' => $this->_('Examples: "http://legacy.domain.com/" or "http://domain.com/old/"'),
'collapsed' => Inputfield::collapsedNever,
'skipLabel' => Inputfield::skipLabelHeader,
'spellcheck' => 'false',
]));
// Legacy Domain Status Codes
$fieldset->add($this->buildInputField('InputfieldText', [
'name+id' => 'statusCodes',
'columnWidth' => 50,
'description' => $this->_('Only redirect if a request to it yields one of these HTTP status codes:'),
'notes' => $this->_('Separate each code with a space. **[Use Default](#resetLegacyStatusCodes)**'),
'collapsed' => Inputfield::collapsedNever,
'skipLabel' => Inputfield::skipLabelHeader,
'spellcheck' => 'false',
]));
$inputfields->add($fieldset);
// Log Not Found Hits
$inputfields->add($this->buildInputField('InputfieldCheckbox', [
'name+id' => 'enable404Monitor',
'label' => $this->_('404 Monitor'),
'description' => $this->_("If you'd like to monitor and log 404 hits so that you can later create jumplinks for them, check the box below."),
'label2' => $this->_('Log 404 hits to the database'),
'notes' => $this->_("This log will be displayed on the Jumplinks setup page in a separate tab (limited to the last 100).\n**Note:** Turning this off will not delete any existing records from the database."),
'collapsed' => Inputfield::collapsedBlank,
'autocheck' => true,
]));
// Info & Support
$fieldset = $this->buildInputField('InputfieldFieldset', [
'label' => $this->_('Info & Support'), // Hidden
'collapsed' => Inputfield::collapsedNo,
'skipLabel' => Inputfield::skipLabelHeader,
]);
// Debug Mode
$fieldset->add($this->buildInputField('InputfieldCheckbox', [
'name+id' => 'moduleDebug',
'label' => $this->_('Debug Mode'),
'description' => $this->_("If you run into any problems with your jumplinks, you can turn on debug mode. Once turned on, you'll be shown a scan log when a 404 Page Not Found is hit. That will give you an indication of what may be going wrong. If it doesn't, and you can't figure it out, then paste your log into the support thread on the forums."),
'label2' => $this->_('Turn debug mode on'),
'notes' => $this->_("**Notes:** Hits won't be affected when debug mode is turned on. Also, only those that have permission to manage jumplinks will be shown the debug logs."),
'collapsed' => Inputfield::collapsedBlank,
'autocheck' => true,
]));
// Disable module
$fieldset->add($this->buildInputField('InputfieldCheckbox', [
'name+id' => 'moduleDisable',
'label' => $this->_('Disable Module'),
'description' => $this->_('If you would like to temporarily disable the module, check the box below.'),
'label2' => $this->_('Disable Jumplinks'),
'notes' => $this->_('**Notes:** This does not retract your ability to create/edit/remove jumplinks and other data; it simply removes the 404 hook to the ProcessJumplinks module.'),
'collapsed' => Inputfield::collapsedBlank,
'autocheck' => true,
]));
// Support Thread
$links = [
'support' => self::SUPPORT_HREF,
'docs' => self::DOCS_HREF,
];
$text = [
'paragraph' => $this->_("Be sure to read the documentation, as it contains all the information you need to get started with Jumplinks. If you're having problems and unable to determine the cause(s) thereof, feel free to ask for help in the official support thread."),
'docs' => $this->_('Read the Documentation'),
'support' => $this->_('Official Support Thread'),
];
$fieldset->add($this->buildInputField('InputfieldMarkup', [
'id' => 'docsSupport',
'label' => $this->_('Documentation & Support'),
'value' => <<<HTML
<p>{$text['paragraph']}</p>
<div id="pjInputFieldLinks">
<a target="_blank" href="{$links['docs']}">{$text['docs']}</a>
<a target="_blank" href="{$links['support']}">{$text['support']}</a>
</div>
HTML
,
'collapsed'=>Inputfield::collapsedYes,
]));
// Module Recommendations
$moduleRecommendationPara = $this->_('Jumplinks complements your SEO-toolkit, which should comprise of the following modules as well:');
$fieldset->add($this->buildInputField('InputfieldMarkup', [
'id' => 'moduleRecommendations',
'label' => $this->_('Module Recommendations'),
'value' => <<<HTML
<p>{$moduleRecommendationPara}</p>
<div id="pjInputFieldLinks">
<a target="_blank" rel="noopener noreferrer" href="http://mods.pw/5q">All In One Minify (AIOM+)</a>
<a target="_blank" rel="noopener noreferrer" href="http://mods.pw/2J">Page Path History (core)</a>
<a target="_blank" rel="noopener noreferrer" href="http://mods.pw/1V">XML Sitemap</a>
<a target="_blank" rel="noopener noreferrer" href="http://mods.pw/8D">Markup SEO</a>
<a target="_blank" rel="noopener noreferrer" href="http://mods.pw/6d">ProFields: AutoLinks</a>
<a target="_blank" rel="noopener noreferrer" href="http://mods.pw/58">ProFields: ProCache</a>
</div>
HTML
,
'collapsed'=>Inputfield::collapsedYes,
]));
// Support Development
$text = [
'paragraph' => $this->_('Jumplinks is an open-source project, and is free to use. In fact, Jumplinks will always be open-source, and will always remain free to use. Forever. If you would like to support the development of Jumplinks, please make a small donation via PayPal using the button to the right.'),
'openSource' => $this->_('Open Source Software'),
'freeSoftware' => $this->_('Free Software'),
'learnMore' => $this->_('Learn more about'),
];
$fieldset->add($this->buildInputField('InputfieldMarkup', [
'id' => 'supportDevelopment',
'label' => $this->_('Support Jumplinks Development'),
'value' => <<<HTML
<p><a href="https://rockett.pw/donate"><img src="{$this->config->urls->ProcessJumplinks}Assets/DonateButton.png" alt="PayPal" style="float:right;margin-left: 22px;"></a>{$text['paragraph']}</p>
<div id="pjInputFieldLinks">
<span class="prefix">{$text['learnMore']}:</span>
<a target="_blank" href="http://opensource.com/resources/what-open-source">{$text['openSource']}</a>
<a target="_blank" href="https://en.wikipedia.org/wiki/Free_software">{$text['freeSoftware']}</a>
</div>
HTML
,
'collapsed'=>Inputfield::collapsedNo,
]));
$inputfields->add($fieldset);
return $inputfields;
}
}