amostajo / wordpress-add-on-post-picker
Wordpress Post Picker Add-on for Wordpress Plugin and Theme templates.
Requires
- php: >=5.4.0
- 10quality/wpmvc-addon: 1.0.*
- 10quality/wpmvc-core: ^3.1
This package is auto-updated.
Last update: 2024-11-28 06:02:07 UTC
README
Add-on package for Wordpress MVC exclusively.
Post Picker is a built-in modal that can be used within Wordpress' admin dashboard to pick / select posts.
** THIS WILL CREATE CONFLICT WITH VueJS.
Installation
This package requires Composer.
Add it in your composer.json
file located on your template's root folder:
"amostajo/wordpress-add-on-post-picker": "2.0.*"
Then run
composer install
or
composer update
to download package and dependencies.
Configure in Template
Add the following string line in your addons
array option located at your template's config file.
'Amostajo\Wordpress\PostPickerAddon\PostPicker',
This should be added to:
config\plugin.php
on Wordpress Plugin Templateconfig\theme.php
on Wordpress Theme Template
Usage
Enqueue on Main
Before you do any custom code, you need to load or enqueue the Post Picker to Wordpress.
Call addon_post_picker()
function within your template's Main class, like this:
class Main extends Plugin { public function metabox() { // The function must be called within your Main.php file $this->addon_post_picker(); } }
HTML and JS
Create a clickable element, who will call the Post Picker:
<a id="post-picker-caller"> Add Posts </a>
Init Post Picker, ala jQuery, with the options wanted:
$("#post-picker-caller").postPicker({ render: false, success: function (posts) { // YOUR CUSTOM CODE HERE // Example: $.each(posts, function(index) { // Print post in console console.log(this); }); } });
Rendering
Post Picker has a built-in rendering system that will lets you display the results easily.
To do this, you need two things in your HTML.
- Template: A template for each of the results to display.
- Placeholder target: A target element that will act as placeholder for the results.
Example using the previous sample:
<a id="post-picker-caller"> Add Posts </a> <!-- TARGET PLACEHOLDER --> <div id="post-picker-placeholder"></div> <!-- TEMPLATE --> <div id="post-picker-templateholder"> <div class="post post-{{ ID }}"> <img alt="{{ title }}"> <a href="{{ permalink }}">{{ title }}</a> <input type="hidden" value="{{ ID }}"> </div> </div>
The javascript section should look like this:
$("#post-picker-caller").postPicker({ target: "#post-picker-placeholder", templateElement: "#post-picker-templateholder" });
Post Picker renders the results by default.
Templates
There are 3 ways to set your template.
- Inside caller (Default): Your template will be the HTML inside the caller tags. In the example case
#post-picker-caller
. - An element: Same as the previous example.
- As option: Pass it as jQuery option.
These are the available Post properties for display:
Options
Coding Guidelines
The coding is a mix between PSR-2 and Wordpress PHP guidelines.
License
Post Picker is free software distributed under the terms of the MIT license.