Skip to content
This repository has been archived by the owner on Jan 16, 2023. It is now read-only.

Get Lever job details and post applications from Craft.

License

Notifications You must be signed in to change notification settings

workingconcept/lever-craft-plugin

Repository files navigation

Lever

Lever Craft CMS 4 Plugin

Get Lever job details and post applications directly from Craft.

Scrutinizer status


Installation & Setup

  • composer require workingconcept/craft-lever
  • php craft install lever or install from SettingsPlugins in the control panel
  • add your site and API details in the control panel via SettingsLever

Development

Templating

craft.lever.jobs([])

Returns an array of jobs. Supply valid parameters for the job postings API if you need to tailor the results.

craft.lever.job(id)

Returns a specific job matching the provided Lever ID, or false.

Job Properties

  • id
  • text
  • categories
  • country
  • description
  • descriptionPlain
  • lists
  • additional
  • additionalPlain
  • hostedUrl
  • applyUrl
  • createdAt
  • workplaceType

Template Examples

List Jobs

{% set positions = craft.lever.jobs %}

<h2>Work with Us!</h2>

<ul>
{% for position in positions %}
    <li><a href="{{ position.hostedUrl }}" target="_blank">{{ position.text }}</a></li>
{% endfor %}
</ul>

Custom Job Application Form

You can create your own form and validation and submit it with an action field set to lever/apply. Use any fields named exactly as seen in the postings API, with jobId, name, and email being required.

<h3>Apply</h3>

{% if application is defined and application.getErrors() | length %}
    {% for field in application.getErrors() %}
        {% for error in field %}
            <p class="error" role="alert">{{ error }}</p>
        {% endfor %}
    {% endfor %}
{% endif %}

<form id="job" action="" method="post" accept-charset="UTF-8" enctype="multipart/form-data">
    {{ csrfInput() }}
    {{ redirectInput(craft.app.request.absoluteUrl ~ "?success=y") }}
    <input type="hidden" name="action" value="lever/apply">
    <input type="hidden" name="jobId" value="{{ job.id }}">

    <input type="text" name="name" value="{{ application.name ?? '' }}" required>
    <input type="email" name="email" value="{{ application.email ?? '' }}" required>
    <textarea name="comments">{{ application.comments ?? '' }}</textarea>

    <input type="file" name="resume" required>

    <button class="btn">Submit</button>
</form>

Establishing Custom Job Detail Pages

You can display all job details on your site if you'd like, including custom detail pages. One way you might go about that is to create a detail page template like jobs/_detail.twig and set up a custom route for it.

Barebones template:

{% extends "_layout" %}

{% set job = craft.lever.job(id) %}

{% if job is empty %}
    {% exit 404 %}
{% endif %}

{% block content %}

...

Custom route in config/routes.php:

return [
    'jobs/<id>' => ['template' => 'jobs/_detail'],
];

This will take requests like https://site.foo/jobs/be9f3647-b59a-4272-94a0-8b937520a69f and send them to your template, where they'll 404 if the ID is invalid.

Events

EVENT_BEFORE_VALIDATE_APPLICATION

Triggered after an application is submitted and before it's validated. You can adjust $event->application if you need to do something custom like handle a FilePond upload and attach it to the LeverJobApplication model.

EVENT_BEFORE_SEND_APPLICATION

Triggered after an application is submitted and before it's sent to Lever. Grab the application data from $event->application and prevent it from being sent by setting $event->isSpam to true.

EVENT_AFTER_SEND_APPLICATION

Triggered immediately after an application is sent to Lever successfully. Same $event->application and $event->isSpam properties available.

Support

Please submit an issue or a pull request if anything needs attention. We'll do our best to respond promptly.


This plugin is brought to you by Working Concept, which has no affiliation with Lever.