Contributors: mikejolley, automattic, adamkheckler, alexsanford1, annezazu, cena, chaselivingston, csonnek, davor.altman, donnapep, donncha, drawmyface, erania-pinnera, jacobshere, jakeom, jeherve, jenhooks, jgs, jonryan, kraftbj, lamdayap, lschuyler, macmanx, nancythanki, orangesareorange, rachelsquirrel, ryancowles, richardmtl, scarstocea
Tags: job manager, job listing, job board, job management, job lists, job list, job, jobs, company, hiring, employment, employer, employees, candidate, freelance, internship, job listings, positions, board, application, hiring, listing, manager, recruiting, recruitment, talent
Requires at least: 4.7.0
Tested up to: 4.9
Stable tag: 1.31.0
License: GPLv3
License URI: http://www.gnu.org/licenses/gpl-3.0.html
Manage job listings from the WordPress admin panel, and allow users to post job listings directly to your site.
WP Job Manager is a lightweight job listing plugin for adding job-board like functionality to your WordPress site. Being shortcode based, it can work with any theme (given a bit of CSS styling) and is really simple to setup.
- Add, manage, and categorize job listings using the familiar WordPress UI.
- Searchable & filterable ajax powered job listings added to your pages via shortcodes.
- Frontend forms for guests and registered users to submit & manage job listings.
- Allow job listers to preview their listing before it goes live. The preview matches the appearance of a live job listing.
- Each listing can be tied to an email or website address so that job seekers can apply to the jobs.
- Searches also display RSS links to allow job seekers to be alerted to new jobs matching their search.
- Allow logged in employers to view, edit, mark filled, or delete their active job listings.
- Developer friendly code — Custom Post Types, endpoints & template files.
The plugin comes with several shortcodes to output jobs in various formats, and since its built with Custom Post Types you are free to extend it further through themes.
Read more about WP Job Manager.
Documentation for the core plugin and add-ons can be found on the docs site here. Please take a look before requesting support because it covers all frequently asked questions!
The core WP Job Manager plugin is free and always will be. It covers all functionality we consider 'core' to running a simple job board site.
Additional, advanced functionality is available through add-ons. Not only do these extend the usefulness of the core plugin, they also help fund the development and support of core.
You can browse available add-ons after installing the plugin by going to Job Listings > Add-ons
. Our popular add-ons include:
Allow candidates to apply to jobs using a form & employers to view and manage the applications from their job dashboard.
Paid listing functionality powered by WooCommerce. Create custom job packages which can be purchased or redeemed during job submission. Requires the WooCommerce plugin.
Resume Manager is a plugin built on top of WP Job Manager which adds a resume submission form to your site and resume listings, all manageable from WordPress admin.
Allow registered users to save their job searches and create alerts which send new jobs via email daily, weekly or fortnightly.
You can get the above add-ons and several others at discount with our Core Add-on Bundle. Take a look!
You can contribute code to this plugin via GitHub: https://github.com/Automattic/WP-Job-Manager and localizations via https://translate.wordpress.org/projects/wp-plugins/wp-job-manager
Thanks to all of our contributors.
Use the WordPress.org forums for community support where we try to help all users. If you spot a bug, you can log it (or fix it) on Github where we can act upon them more efficiently.
If you need help with one of our add-ons, please raise a ticket in our help desk.
If you want help with a customization, please consider hiring a developer! http://jobs.wordpress.net/ is a good place to start.
Automatic installation is the easiest option as WordPress handles the file transfers itself and you don't even need to leave your web browser. To do an automatic install, log in to your WordPress admin panel, navigate to the Plugins menu and click Add New.
In the search field type "WP Job Manager" and click Search Plugins. Once you've found the plugin you can view details about it such as the point release, rating and description. Most importantly of course, you can install it by clicking Install Now.
The manual installation method involves downloading the plugin and uploading it to your web server via your favorite FTP application.
- Download the plugin file to your computer and unzip it
- Using an FTP program, or your hosting control panel, upload the unzipped plugin folder to your WordPress installation's
wp-content/plugins/
directory. - Activate the plugin from the Plugins menu within the WordPress admin.
Once installed:
- Create a page called "jobs" and inside place the
[jobs]
shortcode. This will list your jobs. - Create a page called "submit job" and inside place the
[submit_job_form]
shortcode if you want front-end submissions. - Create a page called "job dashboard" and inside place the
[job_dashboard]
shortcode for logged in users to manage their listings.
Note when using shortcodes, if the content looks blown up/spaced out/poorly styled, edit your page and above the visual editor click on the 'text' tab. Then remove any 'pre' or 'code' tags wrapping your shortcode.
For more information, read the documentation.
View the getting installation and setup guide for advice getting started with the plugin. In most cases it's just a case of adding some shortcodes to your pages!
Yes! If you don't setup the [submit_job_form] shortcode, you can just post from the admin backend.
There are several ways to customize the job application process in WP Job Manager, including using some extra plugins (some are free on Wordpress.org).
See: Customizing the Job Application Process
There are three ways to customize the fields in WP Job Manager;
- For simple text changes, using a localisation file or a plugin such as https://wordpress.org/plugins/say-what/
- For field changes, or adding new fields, using functions/filters inside your theme's functions.php file: https://wpjobmanager.com/document/editing-job-submission-fields/
- Use a 3rd party plugin such as https://plugins.smyl.es/wp-job-manager-field-editor/ which has a UI for field editing.
If you'd like to learn about WordPress filters, here is a great place to start: https://pippinsplugins.com/a-quick-introduction-to-using-filters/
If you wish to be notified of new postings on your site you can use a plugin such as Post Status Notifier.
You can view (and contribute) translations via the translate.wordpress.org.
- The submit job form.
- Submit job preview.
- A single job listing.
- Job dashboard.
- Job listings and filters.
- Job listings in admin.
- Change: Minimum WordPress version is now 4.7.0.
- Enhancement: Add email notifications with initial support for new jobs, updated jobs, and expiring listings.
- Enhancement: For GDPR, scrub WPJM data from database on uninstall if option is enabled.
- Enhancement: Filter by Filled and Featured status in WP admin.
- Enhancement: Simplify the display of application URLs.
- Enhancement: When using WPML, prevent changes to page options when on a non-default language. (@vukvukovich)
- Enhancement: Include company logo in structured data. (@RajeebTheGreat)
- Enhancement: Use more efficient jQuery selectors in scripts. (@RajeebTheGreat)
- Enhancement: Use proper
<h2>
tag incontent-summary-job_listing.php
template for the job title. (@abdullah1908) - Enhancement: Hide empty categories on
[job]
filter. - Fix: Update calls to
get_terms()
to use the new format. - Fix: Maintain the current tab when saving settings in WP Admin.
- Fix: Enqueue the date picker CSS when used on the front-end.
- Fix: Remove errors when widget instance was created without setting defaults.
- REST API Pre-release: Add support for job category taxonomy endpoints.
- Dev: Add
$job_id
parameter tojob_manager_job_dashboard_do_action_{$action}
action hook. (@jonasvogel) - Dev: Add support for hidden WPJM settings in WP Admin.
- Enhancement: Show notice when user is using an older version of WordPress.
- Enhancement: Hide unnecessary view mode in WP Admin's Job Listings page. (@RajeebTheGreat)
- Enhancement: Add support for the
paged
parameter in the RSS feed. (@RajeebTheGreat) - Fix: Minor PHP 7.2 compatibility fixes.
- Dev: Allow
parent
attribute to be passed tojob_manager_dropdown_categories()
. (@RajeebTheGreat)
- Fix: Minor issue with a strict standard error being displayed on some instances.
- Enhancement: Adds ability to have a reCAPTCHA field to check if job listing author is human.
- Enhancement: Allows for option to make edits to job listings force listing back into pending approval status.
- Enhancement: Adds spinner and disables form when user submits job listing.
- Enhancement: Update the add-ons page of the plugin.
- Enhancement: Added the ability to sort jobs randomly on the Featured Jobs Widget.
- Enhancement: Improved handling of alternative date formats when editing job expiration field in WP admin.
- Enhancement: Added star indicator next to featured listings on
[job_dashboard]
. - Enhancement: Opt-in to usage tracking so we can better improve the plugin.
- Enhancement: Introduced new asset enqueuing strategy that will be turned on in 1.32.0. Requires plugin and theme updates. (Dev notes: Automattic#1354)
- Fix: Use WordPress core checks for image formats to not confuse
docx
as an image. (@tripflex) - Fix: Issue with
[jobs]
shortcode whencategories
argument is provided. - Fix: Issue with double encoding HTML entities in custom text area fields.
- Fix: Updates
job-dashboard.php
template withcolspan
fix on no active listings message. - Fix: Clear job listings cache when deleting a user and their job listings.
- Dev: Adds
is_wpjm()
and related functions to test if we're on a WPJM related page. - Dev: Adds
job_manager_user_edit_job_listing
action that fires after a user edits a job listing. - Dev: Adds
job_manager_enable_job_archive_page
filter to enable job archive page. - Dev: Adds
date
field for custom job listing form fields.
- Fix: When retrieving job listing results, cache only the post results and not all of
WP_Query
(props slavco)
- Fix: PHP Notice when sanitizing multiple inputs (bug in 1.29.1 release). (@albionselimaj)
- Enhancement: When retrieving listings in
[jobs]
shortcode, settingorderby
torand_featured
will still place featured listings at the top. - Enhancement: Scroll to show application details when clicking on "Apply for Job" button.
- Change: Updates
account-signin.php
template to warn users email will be confirmed only if that is enabled. - Fix: Sanitize URLs and emails differently on the application method job listing field.
- Fix: Remove PHP notice in Featured Jobs widget. (@himanshuahuja96)
- Fix: String fix for consistent spelling of "license" when appearing in strings. (@garrett-eclipse)
- Fix: Issue with paid add-on licenses not showing up when some third-party plugins were installed.
- Dev: Runs new actions (
job_manager_recent_jobs_widget_before
andjob_manager_recent_jobs_widget_after
) inside Recent Jobs widget. - Dev: Change
wpjm_get_the_job_types()
to return an empty array when job types are disabled. - See all: https://github.com/Automattic/WP-Job-Manager/milestone/15?closed=1
- Enhancement: Moves license and update management for official add-ons to the core plugin.
- Enhancement: Update language for setup wizard with more clear descriptions.
- Fix: Prevent duplicate attachments to job listing posts for non-image media. (@tripflex)
- Fix: PHP error on registration form due to missing placeholder text.
- Fix: Apply
the_job_application_method
filter even when no default is available. (@turtlepod) - Fix: Properly reset category selector on
[jobs]
shortcode.
- Enhancement: Improves support for Google Job Search by adding
JobPosting
structured data. - Enhancement: Adds ability for job types to be mapped to an employment type as defined for Google Job Search.
- Enhancement: Requests search engines no longer index expired and filled job listings.
- Enhancement: Improves support with third-party sitemap generation in Jetpack, Yoast SEO, and All in One SEO.
- Enhancement: Updated descriptions and help text on settings page.
- Enhancement: Lower cache expiration times across plugin and limit use of autoloaded cache transients.
- Fix: Localization issue with WPML in the [jobs] shortcode.
- Fix: Show job listings' published date in localized format.
- Fix: Job submission form allows users to select multiple job types when they go back a step.
- Fix: Some themes that overloaded functions would break in previous release.
- Dev: Adds versions to template files so it is easier to tell when they are updated.
- Dev: Adds a new
wpjm_notify_new_user
action that allows you to override default behavior. - Dev: Early version of REST API is bundled but disabled by default. Requires PHP 5.3+ and
WPJM_REST_API_ENABLED
constant must be set to true. Do not use in production; endpoints may change. (@pkg)
- Enhancement: Admins can now allow users to specify an account password when posting their first job listing.
- Enhancement: Pending job listing counts are now cached for improved WP Admin performance. (@tripflex)
- Enhancement: Allows users to override permalink slugs in WP Admin's Permalink Settings screen.
- Enhancement: Allows admins to perform bulk updating of jobs as filled/not filled.
- Enhancement: Adds job listing status CSS classes on single job listings.
- Enhancement: Adds
wpjm_the_job_title
filter for inserting non-escaped HTML alongside job titles in templates. - Enhancement: Allows admins to filter by
post_status
in[jobs]
shortcode. - Enhancement: Allows accessing settings tab from hash in URL. (@tripflex)
- Fix: Make sure cron jobs for checking/cleaning expired listings are always in place.
- Fix: Better handling of multiple job types. (@spencerfinnell)
- Fix: Issue with deleting company logos from job listings submission form.
- Fix: Warning thrown on job submission form when user not logged in. (@piersb)
- Fix: Issue with WPML not syncing some meta fields.
- Fix: Better handling of AJAX upload errors. (@tripflex)
- Fix: Remove job posting cookies on logout.
- Fix: Expiration date can be cleared if default job duration option is empty. (@spencerfinnell)
- Fix: Issue with Safari and expiration datepicker.
- Fix: Prevents use of Ajax file upload endpoint for visitors who aren't logged in. Themes should check with
job_manager_user_can_upload_file_via_ajax()
if using endpoint in templates. - Fix: Escape post title in WP Admin's Job Listings page and template segments. (Props to @EhsanCod3r)
- Enhancement: Add language using WordPress's current locale to geocode requests.
- Fix: Allow attempts to use Google Maps Geocode API without an API key. (@spencerfinnell)
- Fix: Issue affecting job expiry date when editing a job listing. (@spencerfinnell)
- Fix: Show correct total count of results on
[jobs]
shortcode.
- Enhancement: Warn the user if they're editing an existing job.
- Enhancement: WP Admin Job Listing page's table is now responsive. (@turtlepod)
- Enhancement: New setting for hiding expired listings from
[jobs]
filter. (@turtlepod) - Enhancement: Use WP Query's built in search function to improve searching in
[jobs]
. - Fix: Job Listing filter only searches meta fields with relevant content. Add custom fields with
job_listing_searchable_meta_keys
filter. (@turtlepod) - Fix: Improved support for WPML and Polylang.
- Fix: Expired field no longer forces admins to choose a date in the future. (@turtlepod)
- Fix: Listings with expiration date in past will immediately expire; moving to Active status will extend if necessary. (@turtlepod)
- Fix: Google Maps API key setting added to fix geolocation retrieval on new sites.
- Fix: Issue when duplicating a job listing with a field for multiple file uploads. (@turtlepod)
- Fix: Hide page results when adding links in the
[submit_job_form]
shortcode. - Fix: Job feed now loads when a site has no posts.
- Fix: No error is thrown when deleting a user. (@tripflex)
- Dev: Plugins and themes can now retrieve JSON of Job Listings results without HTML. (@spencerfinnell)
- Dev: Updated inline documentation.
See additional changelog items in changelog.txt