Completionist
Manage, pin, automate, and display Asana tasks in relevant areas of your WordPress admin and website frontend.
Latest Release Info
-
Version:
4.3.0
-
Released:
4 months ago
-
Requires WP:
5.0.0
-
Tested Up To:
6.5.2
-
Requires PHP:
7.2
-
File Size:
1.8 MB
Changelog
4.3.0 - 2024-05-04
Added
- New shortcode
[ptc_asana_task]
to display an individual Asana task. - Automation Actions now support dynamically pinning the newly created Asana task to the WordPress post which triggered its creation. Clear the "Pin to Post" input field value to see both available options,
{post.ID}
and{post.post_parent}
.
Changed
- The "Pin to Post" field label in Automation Actions no longer shifts due to centered positioning.
- Improved error messaging when the "Pin to Post" field's post title could not be retrieved from the REST API.
- Prevent unnecessary Asana API calls when WordPress checks REST API route permissions.
Fixed
- Resolved log messages for PHP 8.1 by updating Asana's PHP SDK dependency packages.
- Resolved log messages for PHP 8.2 by forking Asana's PHP SDK and declaring missing class properties.
- REST API routes which require a logged in WordPress user would fail if no user is logged in and PHP
display_errors
is enabled.
4.2.1 - 2024-04-21
Changed
- Tested up to WordPress 6.5.2.
- Updated Asana color palette values.
- Updated build script package versions.
- Added "Support" to Helpful Links to direct feedback to the plugin support forum rather than personal email address. This promotes building a knowledgebase in public so users can quickly find answers.
Removed
- Removed latest version changes from being noted in the WordPress.org readme. To access the complete changelog history, please visit https://purpleturtlecreative.com/completionist/plugin-info/ or see
changelog.md
in Completionist's files.
Fixed
- Assignee name would be displayed as
(Not Connected)
in the admin widgets, even when the assignee's name is accessible from Asana. In the admin widgets, the WordPress user's display name is still prioritized if the assignee has connected their Asana account to their WordPress user profile.
4.2.0 - 2024-02-03
Added
- New JavaScript filter hook
TaskListItem_main_row_content
to modify the main header row of tasks listed in a project list. Helpful for injecting additional task data, such as custom fields.
4.1.1 - 2024-01-14
Fixed
- Typo in readme.
4.1.0 - 2024-01-14
Added
- New shortcode attribute
layout
to specify a custom layout for the[ptc_asana_project]
shortcode. Note this is only useful for extenders and third-party customizations. Completionist always displays projects inlist
layout by default. - New shortcode attribute
sort_tasks_by
to sort tasks by the specified field. Common values aredue_on
,assignee
,completed_at
, andname
. Unlike Asana, subtasks are also sorted. .pdf
attachments on tasks are now supported.- External attachments (eg. Vimeo and YouTube embeds) are now displayed as their oEmbed HTML representations when available.
Changed
- Unsupported or otherwise non-displayable task attachments are now listed as error or warning notices for clarity. Previously, such attachments would simply be logged to the browser console and ignored.
4.0.0 - 2023-12-10
Added
- New
readme.txt
file for WordPress.org plugins listing. - New
Uninstaller
class to handle plugin data removal. - New
Upgrader
class to handle plugin version updates. This also offers support assistance when a version rollback is detected, which usually indicates that the user is experiencing issues with a newer version of the plugin. - New
Admin_Notices
class to handle displaying of admin notices. All notices are respectful in that they are either displayed once or dismissible. - New
Errors\No_Authorization
exception type class to fix class name and file inconsistency. - New
Autoloader
class to autoload class files. - New REST API endpoints to replace all WP Admin AJAX actions.
Changed
- Remote updates are now handled through WordPress.org. See the official plugin listing at https://wordpress.org/plugins/completionist/
- Class declarations are no longer wrapped in
if ( class_exists( ... ) )
checks. All classes are properly namespaced and should not normally cause collisions. - Upgraded the legacy Tasks metabox within the Classic Editor. This offers great UX/UI and performance improvements, matching the Pinned Tasks panel in the Block Editor. This also removes script dependencies on jQuery.
- All admin scripts are now loaded in the document footer.
- The
global $submenu
is no longer modified in wp-admin to change the main menu page's submenu title to "Settings". Instead, it's now explicitly added as a duplicate submenu page with the overridden title. - Refactored
Automation::to_stdClass()
toAutomation::to_std_class()
for proper snake casing per WordPress Coding Standards.
Removed
- The
YahnisElsts/plugin-update-checker
Composer package which facilitated remote updates. Remote updates are now hosted by WordPress.org. - The
uninstall.php
file. Data is now uninstalled by using the registered uninstall hook. - The deprecated
Request_Tokens
class file, options, and other references. - The
Errors\NoAuthorization
class due to inconsistent naming and class file. - All
require_once
calls which manually included class files. The newAutoloader
class now handles this. - All WP Admin AJAX actions to instead use the new REST API endpoints.
- The
HTML_Builder::format_task_row()
function. It was only used by the legacy Tasks metabox within the Classic Editor, which is now replaced by the upgraded ReactJS-based components. - The
Task_Categorizer
class, all child classes, and theTask_Categorizer
namespace. These PHP classes have not been used since this functionality was moved to ReactJS on the frontend. - Non-class files within the
src/admin
directory. All PHP+HTML template code has been moved to methods within the related PHP classes, eitherAdmin_Pages
orAdmin_Widgets
.
Fixed
- Unpinning a task from the post editor would unpin the task across the entire site.
- Some edge-case oddities with the WP Admin AJAX actions for managing tasks. The new REST API endpoints are now more robust after a thorough code review and refactor.
- Searching for posts in an Automation Action's "Pin to Post" field would include WordPress's internal types such as
wp_navigation
andwp_global_styles
. - The Asana Data Cache Duration (TTL) could not be set to 0 seconds.
- Resolve console errors and warnings in React scripts logged when
SCRIPT_DEBUG
is enabled.
Security
- Various improvements with the new REST API endpoints which replace the original WP Admin AJAX actions.
- Unique nonces to authorize different requests to the new REST API endpoints which replace the original WP Admin AJAX actions.
- Searching for posts in an Automation Action's "Pin to Post" field would include posts that the current user did not have permission to read.
- Improve sanitization of nonce values before validation.
3.11.0 - 2023-11-19
Added
- New PHP filter hook
ptc_completionist_project_task_fields
to edit the task fields that will be retrieved for each task in an Asana project.
3.10.2 - 2023-10-10
Changed
- Clearing the Asana Data Cache no longer completely deletes all request tokens, so it's now compatible with frontend page caching.
Fixed
- Media attachments with uppercase file suffix, such as
JPG
orPNG
, would not be displayed in Project Embeds. - Style issues on the Settings screen when using Chrome with the Loom browser extension.
- Error 404 when using the new Asana project URL as the
src
in Project Embeds.
3.10.1 - 2023-09-15
Fixed
- PHP error when creating or displaying Asana tasks assigned to an Asana user connection that's being used by multiple WordPress users in Completionist.
- PHP 8.2 compatibility for handling dates which was causing fatal errors when trying to create and display tasks in the Pinned Tasks metabox.
- Increased minimum version requirement to PHP 7.2 due to Composer dependencies.
3.10.0 - 2023-08-15
Added
- Settings to clear the Asana data cache and set the cache duration (TTL).
Changed
- Improved the styling and language clarity of the Asana authorization screen.
Fixed
- Automation actions firing multiple times or never at all for the Post is Created event. The
'transition_post_status'
action hook is now used instead of'wp_insert_post'
. - Large images that failed to load would overflow the container in Project Embeds.
- Special characters would be encoded to HTML entities or completely stripped in automations and Asana tasks created by automations.
- Minor style fix on the Settings admin page.
3.9.1 - 2023-07-28
Changed
- FontAwesome assets are now included locally to avoid third-party tracking and hosting.
Fixed
- Database compatibility for the Request Tokens database table primary key size. The database table would continuously fail to install due to max key length limits, such as 1000 bytes, making shortcodes unusable on some hosting providers.
3.9.0 - 2023-07-10
Added
- New filter hooks in JavaScript for adding custom ReactJS components after the task description in the
TaskListItem
component. - New filter hooks in PHP for customizing retrieved Asana project data.
- New PHP class
Asana_Batch
to handle batching Asana API requests.
Changed
- Use
wp_remote_get()
instead of PHP's built-in cURL functions to proxy Asana attachments. - Proxied attachment responses now include the
X-Robots-Tag: noindex
HTTP header. - Task attachments and images now feature a loading animation.
- Updated Composer PHP dependencies.
Fixed
- Failure to detect and localize inline attachments where their HTML tag includes attributes.
- Failure to detect and insert oEmbeds within Asana tasks on WordPress <5.9.0.
- Disabled dragging of attachment images via the
draggable="false"
HTML attribute. - Content layout shifting (CLS) of attachment images as they are loaded. Inline images now feature their intrinsic
width
andheight
to properly reserve space. Attachments and images with unknown dimensions reserve space for a 2:1 aspect ratio until loaded.
3.8.0 - 2023-06-26
Added
- New action hook in PHP
'ptc_completionist_deleted_stale_request_tokens'
fires when stale request tokens are deleted from the database. - New action hook in PHP
'ptc_completionist_deleted_all_request_tokens'
fires when the request tokens database table is truncated (aka cleared). - New filter hook in PHP
'ptc_completionist_shortcodes_meta_init'
filters the metadata definitions array of shortcodes registered and managed by Completionist. 'default_atts'
and'render_callback'
keys in the metadata definitions array of shortcodes registered and managed by Completionist.
Changed
- The main admin page's submenu item is now labeled "Settings".
- Minor error check improvements when saving some plugin settings.
- Minor style updates for border-radius consistency.
Fixed
- Flash of an empty error message before the
[ptc_asana_project]
shortcode begins loading. - Cache data for remote plugin update checks is now removed during uninstallation.
Security
- Request tokens could fail to become stale due to public access. Request tokens are now only refreshed when they are saved in a secure context. Note that HTML caching could now cause request tokens to become stale, depending on the interval and frequency that the HTML cache is refreshed. See the newly added action hooks to know when request tokens are deleted.
- Request tokens would use the Asana connection of WordPress user ID 1 (if available) to authenticate
[ptc_asana_project]
shortcodes when noauth_user
or default frontend authentication user has been specified.
3.7.0 - 2023-04-21
Added
- New custom database table for the new request tokens architecture. The rearchitecture drastically improves performance, storage, and reliability for all frontend requests by batching database writes into a single transaction and using an atomic storage strategy.
- New action hook
ptc_completionist_shortcode_enqueue_assets
for users to easily and efficiently enqueue custom scipts and stylesheets for each rendered shortcode. - JavaScript hooks are now available within the new frontend global
window.Completionist.hooks
. Only one filter hook is currently available to demonstrate this new architecture.
Changed
- Saving the "Frontend Authentication User" setting no longer forces the Asana request tokens cache entries to be deleted. Request tokens are now properly invalidated automatically.
- Minor performance improvement when rendering multiple shortcodes on a single page load.
- Minor performance improvement when
Database_Manager::init()
by preventing redundant initialization.
Deprecated
- The original
Request_Tokens
class and most of its methods. Methods related to data removal are still used for a clean migration to the newRequest_Token
class. - The
Options::REQUEST_TOKENS
postmeta key used by the originalRequest_Tokens
class. - The
$post_id
argument is deprecated and no longer used when localizing Asana attachment URLs. This is due to the request tokens rearchitecture. - Filter hook
ptc_completionist_shortcode_asana_project_script_deps
is deprecated and replaced by the new action hookptc_completionist_shortcode_enqueue_assets
. Filtering the dependency array of each asset for each shortcode is not a scalable or performant approach. Please instead use the new, generic action hook for enqueueing custom assets. The new action hook also ensures custom assets are enqueued after included assets for proper sequencing of script and stylesheet overrides.
Fixed
- The
[ptc_asana_project]
shortcode now works in contexts where a post ID is not available, such as in widgets or complex page builders. - The
[ptc_asana_project]
shortcode's associated data would be saved across unrelated posts if displayed in a global context, such as a site footer. - Race conditions with database reads and writes related to request tokens would cause interruptions in functionality, such as Asana attachments failing to load.
- WordPress's
dbDelta()
compatibility withFOREIGN KEY
declarations by ignoring its relatedADD COLUMN
table alter queries. - WordPress's
dbDelta()
compatibility with uppercaseUNSIGNED
constraints by using lowercase instead. - WordPress's
dbDelta()
compatibility with a zero fractional second precisiondatetime
datatype by simply removing it altogether. That is, usingdatetime
instead ofdatetime(0)
.
Security
- An Asana authentication user must now be provided when request tokens are created. This guarantees request tokens are properly invalidated if the authentication user ever changes, though there were no known vulnerabilities related to the existing functionality.
- A unique "cache key" must now be provided when request tokens are created. This guarantees cache entries are specific to each request token's usage, though there were no known vulnerabilities related to the existing functionality.
3.6.0 - 2023-04-07
Added
- Project sections can now be excluded by name in the
[ptc_asana_project]
shortcode using the new attribute likeexclude_sections="First Section,Another Section"
. No project sections are excluded by default. - Tags on tasks are now displayed in the
[ptc_asana_project]
shortcode with new attributeshow_tasks_tags="true"
. It is enabled by default. .mp4
video attachments on tasks are now supported.- YouTube and Vimeo video embeds within task descriptions are now supported. They are displayed responsively at a 16:9 aspect ratio.
Changed
- All default HTTP headers are now removed from proxied attachment requests to ensure only the desired headers are returned. For example, an
Expires
header would be present with a time that came before the desiredCache-Control: max-age=...
duration. - Updated the
@wordpress/scripts
package which is responsible for building ReactJS components and their styles. - Added
untitled section
andUntitled Section
to the default section names to be erased. - Minor performance improvements to evaluating the
show_tasks_completed
option when retrieving tasks in an Asana project. - The
'ptc-completionist-shortcode-asana-project'
stylesheet's version is now the stylesheet's build version rather than the Completionist plugin's version.
3.5.2 - 2023-03-27
Fixed
- Asana deprecations still being logged by some
\Asana\Client
instances that were loaded with different options than expected, particularly missing theAsana-Enable
headers.
3.5.1 - 2023-03-22
Changed
- Remote plugin updates are now hooked by a named callback rather than an anonymous function.
- Plugin description and copyright year.
- Added "Project Embeds" as a feature listed in the README.
- Added documentation links for each feature in the README.
Fixed
- Fatal error when block editor assets are enqueued in a context with no current post ID, such as when using the classic theme Customizer.
- Enabled
new_goal_memberships
Asana update to resolve deprecation logs.
3.5.0 - 2023-03-19
Added
- Image attachments on tasks are now displayed in the
[ptc_asana_project]
shortcode with new attributeshow_tasks_attachments="true"
. It is enabled by default. - New REST API endpoint
/v1/attachments
to proxy Asana attachment requests.
Changed
- The
'ptc-completionist-shortcode-asana-project'
script's version is now the script's build version rather than the Completionist plugin's version.
Fixed
- Image attachments in task descriptions would break due to Amazon S3 source URLs expiring access after 2 minutes. This is now fixed in the
[ptc_asana_project]
shortcode. - Enabled
new_memberships
Asana update to resolve deprecation logs.
3.4.0 - 2022-11-04
Added
- By popular demand, the first frontend feature is now implemented! The shortcode,
[ptc_asana_project]
, displays an Asana project in list layout. - First custom REST API endpoint,
/v1/projects
, with the new Request Keys architecture to securely perform requests from the website's public frontend. - Settings option for which WordPress user's Asana connection should be used to authenticate frontend requests by default.
- Many new ReactJS components and styles to render the
[ptc_asana_project]
shortcode. - Helpful links to the Settings screen to quickly access Asana, Completionist's documentation, Completionist's changelog, and where to send feedback.
Changed
- Minor style tweaks to the Settings admin screen.
Removed
- User task list links from the "site collaborators" list on the Settings screen. The Asana API returns a
Forbidden
error when trying to get the user task list link for other users, defeating the purpose of this feature and causing useless API requests.
Fixed
- Duplicate display of a user listed in the plugin settings screen when their connected Asana account email does not match their WordPress user account email.
- Repeated authentication to the Asana API when using the currently logged-in user's identity. This fix improves performance and reduces API calls for connected Asana users in wp-admin.
3.3.0 - 2022-10-15
Added
- Pinned Tasks post editor metabox has been converted to ReactJS, offering a better experience, and is now directly integrated into the Block Editor as a plugin panel.
- Several new ReactJS components to compose the new Pinned Tasks plugin panel in the Block Editor.
- Task request errors are now elegantly displayed on the frontend for the Dashboard Widget and Pinned Tasks panel ReactJS components. Before, errors were only logged to the browser console or rarely displayed in a browser window alert.
Changed
- The original, jQuery-based Pinned Tasks metabox is now marked as existing only for backwards compatibility with WordPress's Classic Editor.
- The
ptc_create_task
AJAX action now returns the full Asana task object inresponse.data
instead of the generated HTML representation. - The
ptc_pin_task
AJAX action now returns the full Asana task object inresponse.data
instead of just the task GID. This also helps ensure proper task visibility permissions are enforced. Asana_Interface::maybe_get_task_data()
andAsana_Interface::create_task()
now also include the task'saction_link
for frontend component compatibility.- The ReactJS Pinned Tasks panel and Dashboard Widget styles are now imported as SCSS modules for automatic compiling and composition ease.
- Simplified the Dashboard Widget's HTML
id
fromptc-PTCCompletionistTasksDashboardWidget
to simplyptc-DashboardWidget
.
Removed
- Distribution build files, such as webpacked JavaScript and processed CSS, from version control.
Fixed
- Task due dates being one day off in the Dashboard Widget, depending on your local timezone.
- Enabled
new_project_templates
Asana update to resolve deprecation logs.
3.2.0 - 2022-05-22
Added
- Per user request, Automations now supports entering a custom action or filter hook name as the Event Trigger.
- Helpful messaging in Automations. For example, when no Event Trigger is selected, the Conditions section will display an informative message rather than empty fields.
Changed
- Improved the UX of Automations' edit screens by tweaking some styles and messaging.
Fixed
- The Automations edit screen is now more reliable. In certain cases, for example, the deleted Action would not reflect as deleted. The underlying data would become out-of-sync with the frontend display.
- Removed usage of
FILTER_SANITIZE_STRING
PHP filter, which is deprecated in PHP 8.1.
3.1.1 - 2022-04-10
Changed
- Separated ReactJS build entrypoints to ensure only necessary scripts are enqueued for the Tasks dashboard widget and Automations screen.
- Display a message when there are no tasks to display for the selected filter in the Tasks dashboard widget.
- Hide the pagination navigation when there is only 1 page of tasks in the Tasks dashboard widget.
- Removed ReactJS source files from package bundling.
Fixed
- Task descriptions with long words (such as link URLs) causing layout breaks in the Tasks dashboard widget.
- Completed tasks showing in Tasks dashboard widget on initial load.
- Fatal error when an Automation triggered to create an Asana task with no description.
3.1.0 - 2021-12-25
Deprecated
$opt_fields
arguments in all relevantAsana_Interface
methods, using newAsana_Interface::TASK_OPT_FIELDS
member constant instead for consistency.
Added
- Many new ReactJS components to compose the new Tasks dashboard widget.
Changed
- Tasks dashboard widget has been converted to ReactJS, offering a better experience.
- Tasks dashboard widget style overhaul, offering a better experience.
Fixed
Asana_Interface::$wp_user_id
would not be properly set to the current user's ID when loading the Asana client where user ID is0
, the default value.- Newlines not rendering in the dashboard widget's task descriptions.
3.0.1 - 2021-11-09
Fixed
- Incorrect require file path in the admin dashboard widget.
- Minor style fixes.
3.0.0 - 2021-07-27
Changed
- Greatly improved source code organization—introduces breaking changes for source code users.
- Minor style tweaks due to better color organization and standardization.
- Task descriptions are now displayed on click instead of hover.
- Increased task title font-size in the dashboard widget and pinned tasks metabox task lists.
- Automation action buttons are now hidden until the automation row is hovered.
- Updated the Asana client library to
v0.10.2
.
Fixed
- Plugin "Docs" link refers to the new PTC Docs website!
- Character escaping visible in Automation description.
- Enabled
new_user_task_lists
Asana updated endpoint to resolve deprecation logs. - Task actions no longer cause layout shifting when displayed on hover in the dashboard widget and pinned tasks metabox task lists.
2.0.0 - 2021-01-18
Added
- Remote updates via YahnisElsts/plugin-update-checker and custom resources API.
Removed
- Licensing and remote updates system via WCAM.
Changed
- Software is now licensed under GPL v3 or later.
Fixed
- Unnecessary files drastically increasing plugin size.
- Asana API outage causing fatal TypeError when attempting to identify the current Asana user.
1.1.0 - 2020-08-22
Added
- NEW "Automations" feature!
Changed
- Licensing is no longer required to use Completionist's features, but license activation is still required to check for and receive plugin updates.
- Improved design of licensing screens.
Fixed
- Authenticated users who could not be matched by email in Asana are now properly included in the site collaborators listing.
- Added existence checks for classes and functions used in uninstallation script.
- Corrected retrieval and typecasting on array of users returned when searching for WordPress user by Asana GID.
1.0.1 - 2020-04-21
Fixed
- Malformed script enqueue condition causing excessive error logging.
1.0.0 - 2020-04-16
Added
- Initial release featuring task-to-post pinning and the tasks overview dashboard widget.