=== Admin Page Framework Change Log ===
== Changelog ==
= 3.4.6 - 2015/01/06 =
- Added a page that lets the user download the minified version of the framework in the demo examples.
- Added a utility class that checks requirements of servers such as PHP and MySQL versions etc.
- Added the
print_type
argument to thesystem
field type. - Added more information to the
system
field type. - Added (revived) the minified version and it is now human readable.
- Fixed an issue that form fields without setting a section were not registered in pages except first added ones.
- Changed the timing of importing and exporting of the
import
andexport
field types to be done after performing validation callbacks.
= 3.4.5.1 - 2015/01/01 =
- Removed the minified version as the WordPress plugin team demanded to do so.
= 3.4.5 - 2014/12/27 =
- Added the
setting_update_url_{instantiated class name}
filter hook and the pre-defined callback method. - CHanged the
getValue()
method of the admin page factory class to respect last input arrays. - Fixed a bug that caused a PHP warning that prevented a contact form from being sent on servers with some error reporting settings.
- Fixed an issue on some servers that the script got aborted while sending an email of the contact form.
- Fixed a url query key after submitting a contact form.
- Tweaked the styling of the form confirmation message container element.
= 3.4.4 - 2014/12/17 =
- Fixed a bug that in in-page tabs saving form values of page meta box fields caused data loss of other in-page tabs, introduced in v3.4.3.
= 3.4.3 - 2014/12/15 =
- Added CSS rules for debug output container elements.
- Changed the format of ID of section container elements.
- Fixed a bug that repeated fields could not be removed in page meta boxes started in v3.4.1.
- Fixed a bug that in page meta boxes, the
select
field type with theis_multiple
argument enabled could not store the submitted data properly. - Fixed a bug that page meta boxes could not be added by in-page tab slug.
= 3.4.2 - 2014/12/08 =
- Added the ability to automatically update the preview element of an image field when an image URL is manually typed without using the upload window.
- Added the ability to accept URLs for the
attachments
argument for theemail
argument of thesubmit
field type. - Changed the timing of the
setUp()
method of the post type factory class to let the post type arguments set in the method. - Fixed an issue of the custom media uploader with IE8.
- Fixed a bug that the
Insert from URL
pane of the custom uploader modal window did not function even when theallow_external_source
is set totrue
.
= 3.4.1 - 2014/12/02 =
- Added the
options_update_status_{...}
andvalidation_saved_options_without_dynamic_elements_
filters for the admin page factory class. - Added the
field_definition_{...}
filters for the page meta box class. - Added the
validate()
andcontent()
methods for the meta box and page meta box factory classes. - Changed the timing of
field_definition_{...}
filters of the admin page class. - Changed not to lose the input data when a form validation error occurs for the meta box, page meta box, and page classes.
- Fixed an issue that github buttons of the
github
field type did not load in some sites. - Fixed a bug that repeatable sections could not be repeated when there is no collapsible section in the page.
- Fixed a bug that the old options of the second parameter passed in a validation callback method of the page meta box class did not hold dynamic elements.
- Fixed a bug that the action hooks and their predefined callbacks
submit_{instantiated class name}_{page slug}
andsubmit_after_{instantiated class name}_{page slug}
did not work.
= 3.4.0 - 2014/11/23 =
- Added the ability of collapsing and expanding section containers with the
collapsible
section definition argument. - Added the
select_type
argument for therevealer
custom field type that enables to have checkboxes and radio buttons for the selector. - Tweaked the styling of the
section_title
field type. - Fixed a bug that the layout of form fields broke in Internet Explorer.
= 3.3.3 - 2014/11/08 =
- Added the framework version indication at the bottom of form sections in meta-boxes and widgets when
WP_Debug
is true. - Changed not to display colon(:) after the field title if the title is empty in meta-boxes, taxonomy fields, and widgets.
- Fixed a bug that a gray blank image was inserted in the featured image's image uploader when the framework media uploader is loaded, introduced in v3.3.1.
- Fixed a bug that caused the uploader button of the
media
field type not appear, introduced in v3.3.2.
= 3.3.2 - 2014/11/07 =
- Added the
label_no_term_found
,label_list_title
,query
, andqueries
arguments for thetaxonomy
field type. - Added the ability to compress CSS rules and JavaScript scripts defined in PHP variables for the minified version.
- Tweaked the styling of the
taxonomy
field type to reflect the hierarchical depths. - Fixed a bug that resources of taxonomy fields added by the framework were loaded in other taxonomy pages that caused JavaScript errors.
- Fixed a bug that meta box field values defined via the
field_definition_{...}
filter hooks were not saved. - Fixed a bug that setting sections for page meta box fields caused an error after submitting the form.
- Fixed a bug that class selectors set in the top level of the
class
argument for fields got inserted in all type of field containers includingfieldrow
,fieldset
,fields
,field
. - Fixed the
for
attribute value of label tags for fields to the focus input.
= 3.3.1 - 2014/11/02 =
- Added the
class
argument for fields. - Added the
class
,attributes
,hidden
arguments for sections. - Added the
submit_after_{...}
action hooks that are triggered when the submitted form data are saved. - Added the value length to be indicated in the log file created with the log method of the debug class.
- Fixed an issue that resources of widgets registered by the framework were loaded in all admin pages.
- Fixed a jQuery method conflict of the
sortable()
plugin. - Tweaked the styling of sortable fields in meta boxes.
- Tweaked the styling of form fields in meta boxes.
- Changed the
attributes
field definition argument to be able to override the system set attributes. - Changed the built-in field types to extend the same base class to custom field types.
= 3.3.0 - 2014/10/22 =
- Added the
Select All
andSelect None
buttons for check boxes. - Added the ace custom field type.
- Added the ability to have different menu title from the page title with the
page_title
andmenu_title
argument pass to theaddSubMenuItems()
method. - Added the ability for the
description
field/section definition argument to accept an array to process elements as multiple paragraphs. - Added the ability to set custom arguments to enqueuing resource(style/script) tags.
- Added an example of querying posts by custom meta key and value in the demo plugin.
- Added the ability to send emails with the
submit
field type. - Added the
reset
custom field type. - Added the
system
field type (changed from a custom field type and became built-in). - Fixed an issue that JavaScript scripts added by widget fields could not be properly loaded in
customize.php
. - Fixed an issue of the
revealer
custom field type that the saved selected item could not be displayed after saving the form. - Fixed unescaped tags and attributes in tabs.
- Fixed a bug that the
reset
argument of thesubmit
field type caused a loss of stored options when the form fields are not added via the load_{...} hooks and have multiple pages are added. - Fixed an issue that when setting form elements with the
load_{page slug}_{tab}
hook, the fields could not be displayed if the user clicked on the sidebar menu and the tab is the default tab. - Fixed an issue that the TinyMCE rich editor could not be enabled in widget forms.
- Fixed an issue that Quick Tags of rich editors could not be repeated.
- Fixed an issue that values set to textarea tags were not escaped.
- Optimized the process of handling field errors in post meta boxes.
- Tweaked the timing of jQuery event binding of the
date
, 'date_time', and 'time' custom field types. - Tweaked the styling of remove buttons for
image
,media
,font
field types for WordPress 3.7.x or below. - Tweaked the styling of sortable fields.
- Tweaked the styling of widget forms.
- Changed to prevent posts from being published if there are field errors of meta boxes.
- Changed the layout of meta-box field table by making the field title column to be displayed as inline-block.
- Changed the metabox factory class to accept an empty ID to be passed to let the factory class automatically generates an ID from the class name.
- Changed the timing of finalizing in-page tabs.
- Changed the positions of the + and - repeatable buttons.
= 3.2.1 - 2014/09/29 =
- Added an example of using the
content_top_{...}
and thestyle_common_admin_page_framework
filters. - Added the
style_common_admin_page_framework
hook. - Added support for a file path to be passed for image submit buttons.
- Added support for custom queries for the
posttype
field type. - Added the
radio_checkbox
custom field type. - Added the
image_checkbox
custom field type. - Tweaked the styling of field error messages.
- Fixed an issue that sortable fields could not be rendered properly when being dragged in browser screen widths of less than 782px in Chrome in WordPress above v3.8.
- Fixed the
content_top_{...}
hooks and the methods were not available.
= 3.2.0 - 2014/09/25 =
- Added an example of using an image for a submit button.
- Added the option to set custom button labels via the
data-label
attribute for theimage
,media
, andfont
field types. - Added the remove button for the
image
,media
, andfont
field types. - Added the default and Japanese translation files.
- Added the
show_post_count
argument for thetaxonomy
field type and made it enabled by default. - Added the widget factory class and the examples of creating widgets with the framework in the demo plugin.
- Fixed an issue that registering multiple taxonomies after the
init
hook failed registering second or later items. - Fixed a bug that a last item did not set when selecting multiple items in the fields of the
image
,media
,font
field types. - Fixed a bug in the
autocomplete
custom field type that the default post type slug was not set properly when the page that the field is displayed contains thepost_type
query key in the url.
= 3.1.7 - 2014/09/12 =
- Added the
github
custom field type that displays GitHub buttons. - Fixed an incompatibility issue of the
grid
custom field type with Internet Explorer. - Fixed an incompatibility issue of the
link
custom field type with WordPress 3.8.x or below and Internet Explorer. - Fixed a bug that the
checkbox
field type could not be repeated and sorted. - Fixed an incompatibility issue of the
autocomplete
field type with WordPress 4.0 whenWP_DEBUG
is enabled.
= 3.1.6 - 2014/09/08 =
- Added the
stopped_sorting_fields
JavaScript hook for field type that supports sortable fields. - Added support of repeatable and sortable rich text editor of the
textarea
field type except quick tags. - Added an example of a download button in the demo plugin.
- Added the
system
custom field type. - Changed the timing of the
removed_repeatable_field
callback for sections from before removing the section to after removing it. - Tweaked the styling of switchable tabs of tabbed sections to remove dotted outlines when focused or activated which occur in FireFox.
- Fixed an incompatibility issue with WordPress 4.0 for the media modal frame.
= 3.1.5 - 2014/08/31 =
- Added the
content_{instantiated class name}
hook and the defaultcontent()
callback method that filters the post type post content for the post type class. - Added the ability to flush rewrite rules automatically upon plugin de/activation and theme activation.
- Changed the post type class to perform the set-ups including post type and taxonomy registration immediately if the class is instantiated after the
init
hook. - Fixed an issue that then the user opens multiple pages created by the framework in the browser and submit one of the forms, the other forms failed nonce verification.
- Fixed a bug that caused JavaScript errors in
post.php
when adding meta box fields with the framework, which caused the media button not to function in the page.
= 3.1.4 - 2014/08/29 =
- Added the ability to search users for the
autocomplete
custom field type. - Fixed an issue that field error transients and admin notice transients were not handled properly when multiple WordPress users on the site are working on admin pages created by the framework.
- Fixed an issue that options did not save when the site enables object caching.
= 3.1.3 - 2014/08/13 =
- Added the
load_after_{instantiated class name}
hook that is triggered right after theload_{...}
hooks are triggered. - Added the
set_up_{instantiated class name}
hook that is triggered right after thesetUp()
method is called. - Added the footer link in the custom taxonomy pages created by the framework (
tags.php
,edit-tags.php
). - Added the ability for the
autocomplete
custom field type to support multiple post types and post statues. - Added the
link
custom field type in the demo plugin. - Changed the timing of finalizing in-page tabs so that in-page tabs now can be added in
load_{...}
hook callbacks. - Changed the
start_{instantiated class name}
,do_{...}
,do_before_{...}
,do_after_{...}
, anddo_form_{...}
action hook to pass the class object instance in the first parameter of the callback methods. - Tweaked the process of post type registration to improve performance.
- Tweaked the performance by eliminating unnecessary function calls.
- Tweaked the styling of media select buttons.
- Fixed bugs that in the network admin area, transients were not handled properly.
- Fixed a bug that admin notices were not displayed in the network admin pages.
- Fixed a bug that the
load_{...}
hooks are triggered more than once per page. - Fixed a bug that the same setting notice message got displayed the number of times of the framework object instances when another framework page with a form is loaded while saving the form data in the page.
= 3.1.2 - 2014/08/09 =
- Added the
validation_saved_options_{instantiated class name}
filter hook. - Changed the timing of loading field type definitions in the taxonomy and meta box classes to allow define custom field types in the
setUp()
method. - Changed the
load_{...}
hook callbacks to be able to add form elements. - Fixed an issue that nonce verification failed when there is an output of
WP_List_Table
in the framework page with the framework form elements. - Fixed a bug that meta boxes for the
post
post type created with the framework meta box class did not appear inpost-new.php
page.
= 3.1.1 - 2014/08/01 =
- Added the
before_fieldset
andafter_fieldset
arguments for the field definition array. - Added the third parameter to the
addTaxonomy()
method to accept multiple object types in the post type class. - Changed the
label_min_width
argument to accept non pixel values. - Changed the default value of the
order
argument of in-page tabs to 10. - Changed the field definition arrays to be formatted after applying filters of the
field_definition_{instantiated class name}
hook. - Changed the timing of
field_definition_{instantiated class name}
filter hook to be triggered after allfield_definition_{instantiated class name}_{section id}_{field_id}
andfield_definition_{instantiated class name}_{field_id}
filter hooks. - Fixed a bug that the
show_in_menu
argument of theaddSubMenuItems()
method did not take effect. - Fixed an issue that the
order
argument of in-page tabs did not take effect when in-page tabs are added via thetabs_{instantiated class name}
filter. - Fixed an issue that the
label_min_width
argument of a field definition array was no longer effective as of v3.1.0. - Fixed a bug that the stored values of repeatable fields with a custom capability got lost when a lower capability user submits the form.
- Fixed a bug that items of repeatable fields of page-meta-boxes could not be removed.
= 3.1.0 - 2014/07/18 =
- Added the
options_{instantiated class name}
filter hook to suppress the data used to display the form values. - Added the
AdminPageFramework_Debug::log()
method. - Added the ability not to set the default link to the custom post type post listing table's page in the plugin listing table page by passing an empty string to the 'plugin_listing_table_title_cell_link` key of the 'label' argument option.
- Added the
date_range
,date_time_range
,time_range
custom field type. - Added the ability to set options for the
date
,date_time
, andtime
custom field types. - Added the
hasSettingNotice()
method that checks if at least one setting notice has been set or not. - Added the
admin-page-framework-subfield
class selector to the div element's class attribute of field containers of sub-fields. - Added the
field_definition_{instantiated class name}
filter hook that applies to all the defined field arrays. - Added the
disableSavingOptions()
method that disables the functionality to save submitted form data into the options table. - Added the
setPluginSettingsLinkLabel()
method which enables to set the text label to the automatically embedded link to the plugin listing table of the plugin title cell in addition to disabling the functionality. - Added the
start()
method which is automatically called at the end of the constructor, which can be used when the instantiated class name cannot be determined. - Added the ability to disable settings notices by passing false to the
$_GET{'settings-notice']
key. - Added the
AdminPageFramework_NetworkAdmin
abstract class that enables to add pages in the network admin area. - Tweaked the styling of the
number
input type to align the text on the right. - Tweaked the styling of the
checkbox
field type not to wrap the label after the checkbox. - Tweaked the styling of field td element when the
show_title_column
option is set to false to disable the title. - Changed the
removed_repeatable_field
callback to be triggered after the element is removed. - Changed the target form action url not to contain the
settings-updated
key. - Changed the demo plugin to be separated into smaller components.
- Changed the
validation_{...}
callback methods to receive a third parameter of the class object so that third party scripts can access object members inside from the validation method. - Changed the
AdminPageFramework
class to accept an empty string value to be passed to the first parameter of the constructor, to be used to disable saving options. - Changed the scope of
oUtil
,oDebug
, andoMsg
objects to public from protected to be accessed from an instantiated object. - Changed the
section_head
filter hook to be triggered even when the section description is not set. - Changed not to redirect to options.php when a form created by the framework is submitted in the pages created by the framework.
- Fixed a bug that a value of
0
did not get displayed but and empty string instead. - Fixed a bug that sub-fields could not properly have the default key-values of the field definition of the type.
- Fixed a bug that in PHP v5.2.x, setting a section error message caused a string "A" to be inserted in each belonging field.
- Fixed a bug that previously set field error arrays were lost if the
setFieldErrors()
method is performed multiple times in a page load. - Fixed a bug that page load info was not inserted when multiple admin page objects were instantiated.
- Fixed a bug that duplicated setting notices were displayed.
- Fixed a bug that the redirect transient remained when a field error is set and caused unexpected redirects when the 'href' argument is set for the submit field type.
- Fixed an issue that
textarea
input field was placed in the wrong position when the browser turned off JavaScript. - Fixed a bug that the
autocomplete
custom field type's JavaScript script could not run when the prePopulate option is set and the value is saved without changing. - Fixed an issue in the class autoloader that caused a PHP fatal error in some non GNU OSes such as Solaris in the development version.
= 3.0.6 - 05/10/2014 =
- Fixed a JavaScript syntax error in the
font
custom field type. - Fixed a bug in the
image
andmedia
field types and thefont
custom field type that escaping the frame did not cancel setting the selection. - Fixed an issue that the section tab script was applying the styling to all the
ul
elements inside the section. - Tweaked the styling of the repeatable section buttons.
- Tweaked the
autocomplete
custom field type to find more posts by loosening the search criteria. - Fixed a bug in the
autocomplete
custom field type that setting theprePopulate
option caused a JavaScript error after submitting the form. - Fixed an issue that submitted form input data array in validation callback methods lost array keys of fields with individual set capabilities when the form-submitting user has lower capability than the stored field capability.
- Added the ability to set a link and its label in the title cell of the plugin listing table for a custom post type created by the framework.
- Fixed an issue that the
dial
andautocomplete
custom field type fields could not be repeated properly in repeatable sections.
= 3.0.5 - 04/29/2014 =
- Fixed a bug that the
redirect_url
option of thesubmit
field type did not take effect. - Fixed a bug that repeatable sections messages did not indicate the correct maximum and minimum numbers.
- Tweaked the
autocomplete
custom field type to have some delays to perform post title queries in the background. - Changed the
validation_{instantiated class name}_{section id}_{field id}
andvalidation_{instantiated class name}_{field id}
hooks to be triggered only when the section or field belongs to the page that the form is submitted. - Fixed a bug that some public methods caused a PHP fatal error "Call to a member function" after submitting a form in multi-sites when a plugin is network-activated.
- Changed the post type class methods,
enquueueStyles()
,enquueueStyle()
,enquueueScripts()
,enquueueScript()
to silently fail when they are called not in the post type page.
= 3.0.4 - 04/19/2014 =
- Improved the accuracy on search results of the
autocomplete
custom field type. - Fixed a bug that the help pane of meta box fields did not appear in the page after submitting the form.
- Added the ability to set a validation error message to appear at the top of a form section output.
- Fixed a bug that saved field values of page meta boxes got lost when fields are saved in a different tab but in the same page.
- Fixed a bug that the
script_common_{...}
filter was not functioning in meta box classes. - Added the ability to throw a warning when undefined method is called.
- Changed the file structure of the
development
directory.
= 3.0.3 - 03/24/2014 =
- Added the ability to reveal more than one elements to the
revealer
custom field type with a small braking change. - Tweaked certain routines not to be triggered in irrelevant pages.
- Tweaked the field type registration process to be faster.
- Fixed an undefined index warning in the
AdminPageFramework_Property_MetaBox_Page
class. - Fixed a bug in the development version that the fatal error occurred when trying to include a taxonomy field class individually.
- Changed the default log location and file name.
= 3.0.2 - 03/22/2014 =
- Fixed a bug that repeatable sections could not be removed when they are placed in generic pages but without in-page tabs.
- Fixed an issue of magic quotes with meta box fields for the framework pages.
- Added examples of implementing a custom sort algorithm for columns of the taxonomy term listing table and the custom post type post listing table in the demo plugin.
- Added the the
cell_{instantiated class name}_{column slug}
filter for the taxonomy field class. - Added the
field_definition_{...}
filter.
= 3.0.1.4 - 03/09/2014 =
- Fixed a bug that
setCapability()
did not take effect for form elements. - Fixed an issue that the target tab slug and the target section tab slug do not reset after the
setSettingFields()
method returns. - Tweaked the layout of the geometry custom field type.
= 3.0.1.3 - 03/07/2014 =
- Fixed a bug that custom columns could not be updated properly in the taxonomy definition page (edit-tags.php).
- Added
class_exists()
checks for sample custom field type classes for the demo plugin.
= 3.0.1.2 - 03/04/2014 =
- Fixed a bug that repeatable field buttons did not add/remove when a section is repeated with a new ID due to non-assigned options.
- Fixed a bug that sortable fields of a repeated section could not be sorted.
- Fixed a bug that
image
andmedia
field type fields could not be repeated properly in repeatable sections.
= 3.0.1.1 - 03/01/2014 =
- Fixed a bug that
taxonomy
field type fields could not be properly repeated. - Tweaked the styling of the
taxonomy
field type fields. - Tweaked the styling of horizontal alignment of
th
andtd
form elements.
= 3.0.1 - 02/26/2014 =
- Added the
AdminPageFramework::getOption()
method that can be used from the front-end to retrieve saved option values. - Fixed a bug that the plus(+) field repeater button got inserted when a section is repeated in WordPress 3.5.x or below.
- Tweaked the styling of section tabs to prevent small dots from appearing when activating a tab.
= 3.0.0.1 - 02/24/2014 =
- Tweaked the styling of section tabs with
section_title
type fields.
= 3.0.0 - 02/24/2014 =
- Added: the
section_title
field type that lets the user to enter a section title. - Added: the ability to display form sections in tabs by specifying the
section_tab_slug
. - Added: the
autocomplete
custom field type. - Added: the ability to repeat form section.
- Added: the ability to set form sections in meta boxes.
- Added: the ability to omit the
addSettingSections()
method not to set a section. In other words, setting a section became optional. - Added: the
fields_{instantiated class name}_{section id}
filter that receives registered field definition arrays which belong to the given section. - Added: the
grid
custom field type. - Added: the documentation pages in the distribution package.
- Added: an example to add a thumbnail to the taxonomy term listing table in the demo plugin.
- Added: the
cell_{taxonomy slug}
and thecell_{instantiated class name}
filters for the taxonomy field class. - Added: the
sortable_columns_{taxonomy slug}
and thesortable_columns_{instantiated class name}
filters for the taxonomy field class. - Added: the
columns_{taxonomy slug}
and thecolumns_{instantiated class name}
filters for the taxonomy field class. - Added: the
columns_{post type slug}
filter for the post type class. - Added: the
sortable_columns_{post type slug}
filter for the post type class. - Deprecated: ( Breaking Change ) the
setColumnHeader()
method in the post type class. - Deprecated: ( Breaking Change ) the
setSortableColumns()
method in the post type class. - Deprecated: ( Breaking Change ) the
addSubMenuLink()
method in the main class. - Deprecated: ( Breaking Change ) the
addSubMenuPages()
and the addSubMenuPage() method in the main class. - Added: the minified version of the library.
- Added: the ability to add fields in the taxonomy definition page.
- Added: the ability to add meta boxes in pages added by the framework.
- Added: the ability to set the target section ID in the
addSettingFields()
method so that thesection_id
key can be omitted for the next passing field arrays. - Added: the ability to set the target page and tab slugs in the
addSettingSection()
and theaddSettingSections()
methods so that the page and tab slug keys can be omitted for the next passing section arrays. - Added: the ability to set the target page slug in the
addInPageTabs()
method so that the page slug key can be omitted for the next passing tab arrays. - Added: the ability to set options for repeatable fields including the maximum number of fields and the minimum number of fields.
- Changed: the all the registered field default values to be saved regardless of the page where the user submits the form.
- Changed: it to store all added sections and fields into the property object regardless of they belong to currently loading page and with some other conditions.
- Added: the ability to sort fields by drag and drop.
- Fixed: a bug that meta box specific styles were not loaded per class basis when multiple meta box class instances were created and they were displayed in the same page; only the first instantiated meta box class's styles were loaded.
- Added: the filters,
style_common_{extended meta box class name}
,style_ie_common_{extended meta box class name}
,style_ie_{extended meta box class name}
. - Added: the ability to set option group in the
select
field type. - Added: the ability to set tag attributes on field tags on an individual basis in the
select
,radio
, andcheckbox
field types. - Added: the ability to set tag attributes with the
attributes
key by passing an array with the key of the attribute name and the value of the property value for input fields. - Added: the ability to mix field types in sub-fields.
- Added: the
hidden
key to the field definition array of pages that hides the field output. - Added: the
show_title_column
key to the field definition array of pages. - Added: the
after_fields
and thebefore_fields
keys to the field definition array. - Changed: ( Breaking Change ) the structure of field definition arrays.
- Changed: ( Breaking Change ) dropped the page slug dimensions from the saved option array structure.
- Fixed: a bug that page load info in the footer area was not embedded when multiple root pages are created.
- Moved: the method to retrieve library data into the property base class and they will be stored as static properties.
- Changed: ( Breaking Change ) the name of the
showInPageTabs()
method tosetInPageTabsVisibility()
. - Changed: ( Breaking Change ) the name of the
showPageHeadingTabs()
method tosetPageHeadingTabsVisibility()
. - Changed: ( Breaking Change ) the name of the
showPageTitle()
method tosetPageTitleVisibility()
. - Changed: ( Breaking Change ) the
foot_{...}
filters to be renamed tocontent_bottom_{...}
. - Changed: ( Breaking Change ) the
head_{...}
filters to be renamed tocontent_top_{...}
. - Changed: ( Breaking Change ) the
{instantiated class name}_{page slug}_tabs
filter to be renamed totabs_{instantiated class name}_{page slug}
. - Changed: ( Breaking Change ) the
{instantiated class name}_pages
filter to be renamed topages_{instantiated class name}
. - Changed: ( Breaking Change ) the
{instantiated class name}_setting_fields
filter to be renamed tofields_{instantiated class name}
. - Changed: ( Breaking Change ) the
{instantiated class name}_setting_sections
filter to be renamed tosections_{instantiated class name}
. - Changed: ( Breaking Change ) the
{instantiated class name}_field_{field id}
filter to be renamed tofield_{instantiated class name}_{field id}
. - Changed: ( Breaking Change ) the
{instantiated class name}_section_{section id}
filter to be renamed tosection_head_{instantiated class name}_{section id}
. - Changed: the scope of all the methods intended to be used by the user to
public
fromprotected
. - Changed: all the callback methods to have the prefix of
replyTo
. - Changed: all the internal methods to have the prefix of an underscore.
- Changed: all the variable names used in the code to apply the Alternative PHP Hungarian Notation.
- Changed: ( Breaking Change ) the name of the property
oProps
tooProp
. - Changed: ( Breaking Change ) the name of the class
AdminPageFramework_CustomFieldType
toAdminPageFramework_FieldType
. - Changed: some of the class names used internally.
- Changed: ( Breaking Change ) apart from the conversion to the lower case, renamed some of the keys of the field definition array and the section field definition array.
- Changed: ( Breaking Change ) all the names of array keys with which the user may interact to consist of lower case characters and underscores.
= 2.1.7.2 - 01/18/2014 =
- Fixed: a bug that the
for
attribute of thelabel
tag was not updated in repeatable fields. - Fixed: the warning:
Strict standards: Declaration of ... should be compatible with ...
.
= 2.1.7.1 - 12/25/2013 =
- Added: an example of basic usage of creating a page group as well as specifying a dashicon.
- Added: the ability for the
setRootMenuPage()
method to acceptdashicons
, thenone
value, and SVG base64 encoded icon for the second parameter. - Fixed: a bug that the
color
field type was replaced with thetaxonomy
field type and thetaxonomy
field type was not available.
= 2.1.7 - 12/23/2013 =
- Fixed a bug that the screen icon could not be retrieved when the
strScreenIcon
key was not set (started to occur around v2.1.6). - Added: the
import_mime_types_{...}
filter that receives the array holding allowed MIME types so that the user can add custom MIME types for the imported files. - Added: the
enqueueScript()
and theenqueueStyle()
methods for the post type class. - Added: the ability to automatically insert page load information in the admin footer if the
WPDEBUG
constant is true. - Fixed: a bug that the
password
field type could not be defined as of v2.1.6.
= 2.1.6 - 12/14/2013 =
- Fixed: a bug that the focus of a drop-down list of the
size
field type got stolen when the user tries to select a unit. - Added: another example to define custom field types in the demo plugin.
- Changed: the built-in field types to be declared before loading any custom field types.
- Added: a sample custom field type,
font
, in the demo plugin. - Fixed: the
logArray()
method to use the site local time. - Added: a sample page to view the message object's properties in the demo plugin.
- Fixed: all the individual messages to be in the message object so that it gives easier access to for the user to modify the framework's default messages.
- Added: a sample custom field type,
dial
, in the demo plugin. - Added: sample custom field types,
date
,time
, anddate_time
in the demo plugin. - Added: additional input fields to the custom
geometry
field type to retrieve the location name and the elevation. - Removed: ( Breaking Change ) the
date
field type. - Added: the ability to set an icon with a file path for the
setRootMenuPage()
,addSubMenuPage()
, andgetStylesForPostTypeScreenIcon()
methods.
= 2.1.5 - 12/08/2013 =
- Changed: ( Minor Breaking Change ) the format of the
id
andfor
attributes of the input and label tags of thetaxonomy
field type. - Fixed: a bug that caused name collisions with the
for
attribute of label tags in thetaxonomy
field type. - Added: the
field_{instantiated class name}_{field id}
andsection_{instantiated class name}_{section id}
filters. - Added: the
export_{instantiated class name}_{field id}
,export_{instantiated class name}_{input id}
filters. - Added: the
import_{instantiated class name}_{field id}
,import_{instantiated class name}_{input id}
filters. - Added: an example to retrieve the saved options from the front end in the demo plugin.
- Added: the ability for the
enqueueScript()
andenqueueStyle()
methods to accept absolute file paths. - Introduced: a new class
AdminPageFramework_CustomFieldType
. - Added: a sample custom field type,
geometry
, in the demo plugin. - Fixed: a bug that the
enqueueScripts()
method caused infinite loops. - Added: the
field_types_{instantiated class name}
filter that receives the field type defining array so that the user can return custom field types by adding a definition array to it. - Added: the
vClassAttributeUpload
key for theimport
field type that defines the class attribute of the custom file input tag in the field output. - Added: the
vUnitSize
key for thesize
field type that indicates thesize
attribute of the select(unit) input field. - Added: the
vMerge
key for theimport
field type that determines whether the imported data should be merged with the existing options. - Changed: admin settings notifications with
setSettingNotice()
not to have multiple messages with the same id. - Added: the
validation_{instantiated class name}_{field id}
and thevalidation_{instantiated class name}_{input id}
filters. - Fixed: a bug in the demo plugin that the
size
fields were not displayed properly. - Fixed: a bug that menu positions could not be set with the
setRootMenuPage()
method.
= 2.1.4 - 11/24/2013 =
- Changed: the output of each field to have enclosing
fieldset
tag to be compatible with WordPress v3.8. - Changed: ( Minor Breaking Change ) the default value of all the
vDelimiter
key to be an empty string as some input types' default values were<br />
. - Changed: ( Minor Breaking Change ) the structure of input field elements to enclose input elements in the
label
tag to make it compatible with the WordPress v3.8 admin style. Accordingly, those who are using thevBeforeInputTag
and thevAfterinputTag
keys should make sure that block elements are not passed to those outputs. - Fixed: a bug that enqueuing multiple scripts/styles with the
enqueueStyle()
/enqueueScript()
method did not take effect. - Changed: some menu item labels in the demo plugin.
- Added: sample pages that demonstrate the use of hidden pages with the
fShowInMenu
key in the demo plugin. - Added: the
fShowInMenu
key for the sub-menu page array which will add the ability to hide the page from the sidebar menu.
= 2.1.3 - 11/19/2013 =
- Fixed: a bug that the style of the Iris color picker had a conflict with the date picker.
- Added: the
screen_icon
key for the post type argument array that can set the screen icon of the post type pages. - Added: the
fAllowExternalSource
key for theimage
andmedia
field types that enables to set external URLs via the media uploader. - Added: the
media
field type. - Added: the
arrCaptureAttributes
key to save additional attributes of the image selected via the media uploader. - Tweaked: the image fields' preview images to have the maximum width of 600px.
- Added: the ability to select multiple image files for repeatable fields.
- Added: the WordPress 3.5 uploader for the image field type.
- Fixed: a bug that an image URL could not be inserted from the
From URL
tab of the image uploader. - Added: the
fRepeatable
key to thetext
,textarea
,image
,date
,color
, andfile
field types that make the fields to be repeatable.
= 2.1.2 - 11/3/2013 =
- Added: the 'vRich' key to the
textarea
field type that enables rich text editor. - Added: the
vReset
key to thesubmit
field type that performs resetting options. - Added: class electors to the field elements.
- Changed: ( Minor Breacking Change ) the
field_description
class selector name toadmin-page-framework-fields-description
. - Changed: the assets folder name to asset.
- Added: the
setDisallowedQueryKeys()
method that can define disallowed query keys to be embedded in the links of in-page tabs and page-heading tabs. - Fixed: a bug that the
settings-updated
query key string was embedded in the links of in-page tabs and page-heading tabs. - Changed: the
showPageTitle()
,showPageHeadingTabs()
,showInPageTabs()
,setInPageTabTag()
, andsetPageHeadingTabTag()
methods to be able to use after registering pages. That means it can be used in methods that are triggered after registering pages such as thedo_before_{page slug}
hook. - Changed: ( Breacking Change ) the key name of page property array
fPageHeadingTab
tofShowPageHeadingTab
. - Added: the
setAdminNotice()
method which enables the user to add custom admin messages. - Changed: the link class for custom post types to use a public property for the link title that appears in the plugin listing table so that the user can change the text.
- Fixed: a bug that the link url automatically inserted in the plugin listing table was not correct when setting a custom root page slug.
- Fixed: a bug that undefined index
typenow
warning occurred when a custom database query with the WP_Query class was performed in the edit.php admin page. - Added: the
admin-page-framework-radio-label
and theadmin-page-framework-checkbox-label
class selectors for the elements enclosing radio and checkbox input labels and removeddisplay:inline-block
from the inline CSS rule of the elements. - Fixed: an undefined index warning to occur that appears when a non-existent parent tab slug is given to the
strParentTabSlug
in-page tab array element. - Added: the
getFieldValue()
method which retrieves the stored value in the option properties by specifying the field name. This is helpful when the section name is unknown. - Added: the
dumpArray()
method for the debug class. - Added: the
fHideTitleColumn
field key for the meta box class's field array structure. This allows the user to disable the title column in the options table. - Added: the
addSettingSection()
method that only accepts one section array so that the user can use it in loops to pass multiple items. - Added: the
addSettingField()
method that only accepts one field array so that the user can use it in loops to pass multiple items. - Added: the
enqueueStyle()
method and theenqueueScript()
method that enqueue script/style by page/tab slug. - Changed: the submit field type with the
vRedirect
value not to be redirected when a field error array is set. - Fixed: a bug that hidden in-page tabs with the
fHide
value could not have associated callbacks such asvalidation_{page slug}_{tab slug}
. - Changed: the
getParentTabSlug()
method to return an empty string if the parent slug has the fHide to be true. - Fixed: a bug that the redirect submit button did not work with a long page slug.
- Added: the Other Notes section including tips in the demo plugin.
- Added: the
setPageHeadingTabTag()
method that sets the page-heading tab's tag. - Added: the ability to set visibility of in-page tabs, page-heading tabs, and page title by page slug.
= 2.1.1 - 10/08/2013 =
- Added: the for attribute of the label tag for checklist input elements so that clicking on the label checks/unchecks the item.
- Added: the strWidth and the strHeight field array keys for the taxonomy field type.
- Deprecated: the numMaxWidth and the numMaxHeight field array keys for the taxonomy field type.
- Changed: the taxonomy field type to display the elements in a tabbed box.
- Changed: the post type check list to display post types' labels instead of their slugs.
- Changed: the vDelimiter elements to be inserted after the vAfterInputTag elements.
- Changed: the footer text links to have title attributes with script descriptions.
- Removed: the script version number in the footer text link and moved it to be displayed in the title attribute.
- Added: the getCurrentAdminURL() method.
= 2.1.0 - 10/05/2013 =
- Added: the load_{instantiated class name}, load_{page slug} and load_{page slug}_{tab slug} filters.
- Fixed: a bug that saving options with a custom capability caused the Cheatin' Uh message.
- Deprecated: ( Breaking Change ) the setPageCapability() method since it did not do anything.
- Changed: ( Breaking Change ) the AdminPageFramework_PostType class properties and AdminPageFramework_MetaBox to be encapsulated into a class object each.
- Added: the strHelp field key that adds a contextual help tab on the upper part of the admin page.
- Fixed: the required WordPress version to 3.3 as some of the functionalities were relying on the screen object that has been implemented since WordPress 3.3.
= 2.0.2 - 09/07/2013 =
- Fixed: a bug in the demo plugin that custom taxonomies were not added.
- Added: the size field type.
= 2.0.1 - 09/04/2013 =
- Fixed: a bug that admin setting notices were displayed twice in the options-general.php page.
= 2.0.0 - 08/28/2013 =
- Released 2.0.0.
= 2.0.0.b4 - 08/28/2013 =
- Fixed: a bug that custom post type preview page did not show the stored values in the demo plugin.
- Refactored: the code that loads the color picker script.
- Refactored: the code that loads the image selector script.
- Refactored: the code that loads framework's style.
= 2.0.0.b3 - 08/28/2013 =
- Added: more documentation in the source code.
- Removed: the document folder.
- Moved: the documentation_guideline.md file to the top level folder.
- Removed: the documentation pages and added an external link to the documentation web site.
- Removed: the arrField parameter of the constructor of the AdminPageFramework_MetaBox class.
- Removed: the setFieldArray() method of the AdminPageFramework_MetaBox class.
- Fixed: a bug that meta box color piker, image selector, data picker scripts did not load in the page after the Publish button was pressed.
- Changed: the validation_ instantiated class name filter for meta boxes to accept the second parameter to receive the stored data.
= 2.0.0.b2 - 08/26/2013 =
- Changed: addLinkToPluginDescription() and addLinkToPluginTitle() to accept variadic parameters.
- Added: an example of using addLinkToPluginDescription() and addLinkToPluginTitle() in the demo plugin.
- Changed: the demo plugins file name.
- Fixed: an issue that date picker script caused an irregular element to be inserted around the page footer.
- Changed: the documentation compatible with the DocBlock syntax.
= 2.0.0.b1 - 08/24/13 =
- Changed: the setSettingsNotice() method name to setSettingNotice() to be consistent with other names with Settings.
- Added: the date input field that adds a date picker.
- Added: the ability to specify the multiple attribute to the select field with the vMultiple key.
- Added: the color input field that adds a color picker.
= 1.1.0 - 2013/07/13 =
- Added: the addSubMenuItems() and addSubMenuItem() methods that enables to add not only sub menu pages but also external links.
- Added: the ability to list the terms of specified taxonomy with checkbox by taxonomy slug.
- Changed: ( Breaking Change ) the category field type to taxonomy field type.
- Fixed: a bug that adding sub pages to an existing custom post type page caused the links of in-page tabs to have the wrong urls.
- Changed: the image field type to be a custom text field.
- Added: the import_format_{page slug}_{tab slug}, import_format_{page slug}, import_format_{instantiated class name} filters to allow to modify the import format type.
- Added: the import_option_key_{page slug}_{tab slug}, import_option_key_{page slug}, import_option_key_{instantiated class name} filters to allow to modify the import option key.
- Added: the export_format_{page slug}_{tab slug}, export_format_{page slug}, export_fomat_{instantiated class name} filters to allow to modify the export format type.
- Added: the export_name_{page slug}_{tab slug}, export_name_{page slug}, export_name_{instantiated class name} filters to allow to modify the export file name.
- Added: the ability to set the accept attribute for the file input field.
- Added: ( Breaking Change ) the second parameter to the validation callback method to pass the old stored option data.
- Changed: ( Breaking Change ) the validation behaviour to maintain the stored option values to return the second parameter value in the validation callback method from returning an empty array.
- Changed: ( Breaking Change ) the validation behaviour to delete the stored option values to return an empty array in the validation callback method from returning a null value.
- Added: the validation_{instantiated class name} filter that allows to modify the submitted form data throughout the whole script.
- Added: the ability to set the text domain for the text messages that the framework uses.
- Added: the ability to set the minimum width for label tags for textarea, text, and number input fields.
- Added: the ability to set the label tag for textarea, text, and number input fields.
- Added: the {instantiated class name}field{field id} filter to allow to modify settings field output.
- Added: the {instantiated class name}_{page slug}_tabs filter to allow to modify adding in-page tabs.
- Added: the {instantiated_class name}_pages filter to allow to modify adding pages.
- Added: the {instantiated class name}_setting_fields and {instantiated class name}_setting_sections filters to allow to modify registering sections and fields.
- Changed: ( Breaking Change ) the default option key that is stored in the option database table to be the instantiated class name from the page slug.
- Changed: ( Breaking Change ) the section and field filters to have the prefix of the instantiated class name of the Admin Page Framework so that it prevents conflicts with other plugins that uses the framework.
- Changed: the anchor link name attribute to id.
- Added: the ability to order the in-page tabs with the numOrder key.
- Added: the addInPageTab() methods to set in-page tabs.
- Changed: ( Breaking Change ) the array structure of the parameter of the addInPageTabs() methods.
- Added: the ability to automatically assign the default screen icon if not set, which is of the generic id.
- Added: the ability to set the WordPress built-in screen icon to the custom added sub-menu pages.
- Added: a class for handling custom-post types.
- Added: a class for handling meta-boxes.
- Changed: ( Breaking Change ) to apply the camel-back notation to all the array argument keys.
- Changed: ( Breaking Change ) all the method names to be uncapitalised.
- Changed: ( Breaking Change ) the sub-string of class names, Admin_Page_Framework, to AdminPageFramework.
= 1.0.4.2 - 07/01/2013 =
- Tweaked: the demo plugin to load the admin-page object only in the administration pages with the is_admin() function.
- Fixed: a bug that setting and retrieving a transient for the field error array caused extra database queries.
- Fixed: a bug that setting multiple checkboxes caused undefined index warning.
- Fixed: a bug in the demo plugin that single upload field did not appear and caused undefined index warning after updating the options.
= 1.0.4.1 - 04/14/2013 =
- Added: the if key for section and field array that evaluates the passed expression to evaluate whether the section or field should be displayed or not.
- Added: the support of the label key for the text input field and multiple elements to be passed as array.
- Fixed: a bug that the disable field key for the check box type did not take effects when multiple elements were passed as array.
= 1.0.4 - 04/07/2013 =
- Fixed: an issue that the submit field type with the redirect key caused an unset index warning.
- Changed: not to use the get_plugin_data() function if it does not exist to support those who change the location of the wp-admin directory.
- Added: enclosed the checkbox, radio fields and its label in a tag with the display:inline-block; property so that each item do not wrap in the middle.
- Added: the SetSettingsNotice() method which can be used instead of the AddSettingsError() method. The new method does not require an ID to be passed.
- Changed: (Breaking Change) the parameters of SetFieldErrors() method; the first parameter is now the error array and the second parameter is the ID and it is optional.
- Changed: that when multiple labels were set for the field types that supports multiple labels but the name key was set null, it now returns the default value instead of an empty string.
- Tweaked: the settings registration process including sections and fields to be skipped if the loading page is not one of the pages added by the user.
- Improved: the accuracy to retrieve the caller script information.
- Added: the posttype field type.
- Added: the category field type.
= 1.0.3.3 - 04/02/2013 =
- Fixed: a bug that a debug log file was created after submitting form data introduced in 1.0.3.2.
= 1.0.3.2 - 04/02/2013 =
- Added: the redirect field key for the submit input type that redirects the page after the submitted form data is successfully saved.
- Fixed: an issue that when there are multiple submit input fields and the same label was used with the href key, the last url was set to previous buttons; the previous buttons urls were overwritten by the last one.
- Fixed: a bug that a value for the pre_field was applied to the post_field key in some field types.
- Added: the ability to disable Settings API's admin notices to be automatically displayed after submitting a form by default. To enable the Settings API's notification messages, use the EnableSettingsAPIAdminNotice() method.
= 1.0.3.1 - 04/01/2013 =
- Added: the default message which appears when the settings are saved.
- Changed: to automatically insert plugin information into the plugin footer regardless of whether the second parameter of the constructor is set or not.
= 1.0.3 - 04/01/2013 =
- Added: the href field key for the submit field type that makes the button serve like a hyper link.
- Added: the SetFieldErrors() method that enables to set field errors easily without dealing with transients.
- Added: the AddSettingsError() and the ShowSettingsErrors() methods to be alternated with the settings_errors() and the add_settings_error() functions to prevent multiple duplicate messages to be displayed.
- Added: the ability to automatically insert anchor links to each section and field of form elements.
- Added: the readonly field key for text and textarea input fields that inserts the readonly attribute to the input tag.
- Added: the pre_field and post_field field keys that adds HTML code right before/after the input element.
- Fixed: a minor bug in the method that merges arrays that did not merge correctly with keys with a null value.
= 1.0.2.3 - 03/17/2013 =
- Added: the ability to set access rights ( capability ) to adding pages individually, which can be set in the newly added fourth parameter of the AddSubMenu() method.
= 1.0.2.2 - 03/17/2013 =
- Changed: (Breaking Change) the second parameter of the constructor from capability to script path; the capability can be set via the SetCapability() method.
- Added: the ability to automatically insert script information ( plugin/theme name, version, and author ) into the footer if the second parameter is set in the constructor.
= 1.0.2.1 - 03/16/2013 =
- Added: the capability key for section and field arrays which sets access rights to the form elements.
- Added: a hidden tab page which belongs to the first page with a link back-and-forth in the demo plugin.
- Changed: the required WordPress version to 3.2 as the newly used filter option_page_capability_{$pageslug} requires it.
- Fixed: an issue that setting a custom capability caused the "Creatin' huh?" message and the user could not change the options.
- Added: the HideInPageTab() method which hides a specified in-page tab yet still accessible by the direct url.
- changed: the method name RenderInPageTabs() to GetInPageTabs() since it did not print anything but returned the output string.
= 1.0.2 - 03/11/2013 =
- Added: the export_{suffix} and import_{suffix} filters and the corresponding callback methods to capture exporting/importing array to modify before processing it.
- Supported: multiple export buttons per page.
- Added: the delimiter key which delimits multiple fields passed as array including the field types of checkbox, radio, submit, export, import, and file.
- Fixed: to apply the value of the disable key to the import and export custom field.
- Fixed: a bug that an empty string was applied for the description key even when it is not set.
- Added: the transient key for the export custom field to set a custom exporting array.
- Added: do_form action hooks ( tag, page, global ) which are triggered before rendering the form elements after the form opening tag.
- Fixed: a bug that the file_name key for the export field key did not take effect.
= 1.0.1.2 - 03/09/2013 =
- Fixed: a typo which caused a page not to be added to the Appearance menu.
= 1.0.1.1 - 03/08/2013 =
- Fixed: typos in the demo plugin.
- Changed: error message for a field to display the field value as well in addition to the specified error message.
- Changed: the post_html key to be inserted after the description key.
- Changed: tip key to use the description key if it is not set.
= 1.0.1 - 03/05/2013 =
- Removed: array_replace_recursive() to support PHP below 5.3 and applied an alternative.
- Changed: to use md5() for the error transient name, class name + page slug, to prevent WordPress from failing to retrieve or save options for the character lengths exceeding 45 characters.
- Changed: to echo the value in a user-defined custom field type.
- Added: the pre_html and post_html keys for input fields that adds extra HTML code before/after the field input and the description.
- Added: the value key for input fields that precedes the option values saved in the database.
- Added: the disable key for input fields to add disabled="Disabled".
= 1.0.0.2 - 02/17/2013 =
- Fixed a warning in debug mode, undefined index, selectors.
- Added a brief instruction in the demo plugin code and fixed some inaccurate descriptions.
= 1.0.0.1 - 02/15/2013 =
- Fixed a bug that the options were not properly saved when the forms were created in multiple pages.
= 1.0.0.0 - 02/14/2013 =
- Initial Release