CMP Development FAQs & Troubleshooting
Support the team building MODX with a monthly donation.
The budget raised through OpenCollective is transparent, including payouts, and any contributor can apply to be paid for their work on MODX.
$305 per month—let's make that $500!Learn more
This page deals with Custom Manager Pages FAQs & Troubleshooting tips.
The question numbering represents nothing but that - a number to indicate what question you're looking at to help scanning through.
This is a documentation stub, and could use your help to complete! If you don't have access to edit this page, please post anything you would want to see added or updated in this topic on the forums.
This document will always be a work in progress as new features are added / changed, and it could use your help in keeping it structured and up to date! If you do not have access to editing this document, please post anything you would want to see added or updated in this topic on the forums.
- Please use the right headings (heading 2 for categories, heading 3 for questions) to make sure the table of contents et al are properly generated and make sense.
- Big subjects can be created as a subpage to this page its parent, and if other pages already exist on these docs please link to it in the first section.
- Please make sure the numbering is correct when you add a question to allow easier scanning of the page.
- Make sure you link generously to further reading on the subject.
- ExtJS 3.4.0 Documentation
- Custom Manager Pages
- Developing an Extra in MODX Revolution (Specifically part 2)
1.1. What are connectors and processors? And what is a controller?¶
A connector is a web-accessible php file which acts as the target point for back-end AJAX requests. It takes in a POST request, and routes that to the right processor (as indicated by the "action" post or url parameter), which is a file that does the actual work of processing the post (which has been added to the $scriptProperties variable by the connector) and returning a JSON array with the results of the request.
Typical locations within a component are:
- Connector: assets/components/mycomponent/connector.php or assets/components/mycomponent/mgr/connector.php
- Processor: core/components/mycomponent/processors/mgr/processorname.php
- Controller: core/components/mycomponent/controllers/controllername.php
1.2. Why do I need all those different parts in my manager page? Can't I just echo some values in my controller and build stuff from there?¶
Sure - you can do that too if you want.
Using the different parts however is advised to make sure you can easily deploy to other installations (as they all expect files at that specific location). It also allows users to move the core folder out of the web accessible root, improving security of the system.
1.3. What version of ExtJS does MODX Revolution use? When will MODX Revolution update to ExtJS 4.0?¶
|MODX Version||ExtJS version|
It is unlikely that MODX will start using ExtJS 4 until 2.3/2.4 or 3.0. If you insist on using ExtJS 4.0, you can always get your hands dirty and start the migration process of the manager/assets/modext/ folder.
1.4. Can I use ExtJS widgets that MODX uses in the Manager in my own CMP as well?¶
Yes - that saves code, too.
Make sure you test your code on various releases as core code is subject to changes that could break your implementation of it.
2. ExtJS / modExt Troubleshooting¶
2.1. Error: Syntax Error: Unexpected Token '<' on ext-all.js Line 7¶
When received after initiating an AJAX request to a connector/processor, this error usually means the response that came back is not valid.
Often this is caused by a PHP Fatal Error in the processor code. Inspect the outgoing request using Firebug or Developer Tools to see what it returns and where the error in the PHP side of things is.
This was caused by a legacy bug fixed for MODX 2.2-rc1. If you are still experiencing a number of requests that are not needed, make sure you don't have listeners calling another refresh/load, changePage(0) and refresh() or in another way are explicitely calling a request twice.