=== PressPrimer Assignment – Homework Submission, Document Viewer & LMS Grading Workflows === Contributors: pressprimer Tags: assignment, grading, education, lms, learndash Requires at least: 6.4 Tested up to: 6.9.4 Stable tag: 2.1.0 Requires PHP: 7.4 License: GPLv2 or later License URI: https://www.gnu.org/licenses/gpl-2.0.html Collect, review, and grade student assignments in WordPress. File uploads, text submissions, inline feedback, and LMS integration. Free forever. == Description == **PressPrimer Assignment** is a professional assignment submission and grading plugin that gives WordPress educators everything they need to collect student work, provide meaningful feedback, and track grades, all without juggling email attachments, shared drives, or clunky LMS add-ons. Students get a clean, focused submission experience. Teachers get a centralized grading dashboard with a built-in document viewer, rich text feedback, and inline annotations available via the School addon. And you keep full control of your data on your own WordPress site. **This is a genuinely free plugin.** Unlimited assignments, unlimited submissions, full grading tools, LMS integration, and email notifications are all included at no cost. We earn upgrades by building specialized features worth paying for — group management, rubric grading, AI-assisted grading and proofreading, document annotations, anonymous grading, AI content and plagiarism detection, xAPI / LRS support, automated data retention, audit logging, and white-label branding — not by crippling what you get for free. https://www.youtube.com/watch?v=6hh4blc4dNQ = Why PressPrimer Assignment? = Built-in assignment tools in WordPress LMS plugins are often afterthoughts, limited to basic file uploads with no real grading workflow, limited feedback options, and dated interfaces. Dedicated assignment platforms charge monthly fees with per-student pricing that gets expensive fast. PressPrimer Assignment delivers a focused, polished assignment workflow with the features educators actually need: * **Flexible Submission Types** – Accept file uploads, rich text submissions, or let students choose. Support for PDF, DOCX, TXT, RTF, ODT, and image files out of the box. * **Grade Without Leaving WordPress** – A dedicated grading queue with a side-by-side interface: the student's document renders on the left while you score and write feedback on the right. Built-in viewers for PDF, Word documents, images, and text files mean you never have to download, open, and track files on your desktop. * **Native LMS Integration** – Works with LearnDash, Tutor LMS, LifterLMS, and LearnPress. Assignments appear in lessons, passing grades trigger lesson completion, and instructor roles are mapped automatically. * **Secure File Handling** – Six-layer file validation and permission-based file serving. Student files are never directly accessible via URL. * **Customizable Email Notifications** – Automatic emails for submission confirmation, grade release, and new submission alerts. Fully customizable templates with token placeholders. * **Three Professional Themes** – Default, Modern, and Minimal themes that match the PressPrimer Quiz visual style. = Features Included Free = PressPrimer Assignment includes everything you need to manage assignments at any scale: **Assignment Creation** * Unlimited assignments and submissions * Configurable maximum points and passing score * Three submission types: file upload, text/rich text, or student's choice * Configurable file types, file size limits, and multiple files per submission * Duplicate any assignment to copy its settings **Student Submission Experience** * Drag-and-drop file upload with progress indicators * TinyMCE rich text editor with live word count and auto-save drafts * Student notes field for context or questions * View submission status, grade, and instructor feedback * Previous submission history with feedback for each attempt **Grading & Feedback** * Centralized grading queue with filter and sort * Side-by-side grading interface: document viewer on the left, grading panel on the right * Built-in viewers render PDF, DOCX, images, and text files directly in WordPress; no downloading required * Automatic text extraction from PDF, DOCX, ODT, RTF, and TXT files with quality scoring * Rich text feedback editor with bold, italic, lists, and links — feedback is rendered with its formatting on the student view, not as plain text * Submissions list filterable by score range, feedback presence, and submission date range * Grading guidelines reference panel pulled from the assignment **Email Notifications** * Submission confirmation, grade notification, and new submission alert emails * Customizable subject and body templates per email type * Token placeholders: student name, assignment title, score, feedback URL, and more **Admin Dashboard & Reports** * Dashboard with submission statistics, activity chart, and recent submissions * Reports page with filterable submission data **Security & Accessibility** * Six-layer file upload validation (extension whitelist, MIME verification, double-extension blocking, dangerous file rejection) * Files stored outside webroot with permission-based serving through PHP * Capability-based access control (teachers see only their own assignments) * WordPress Privacy API integration (Tools > Export/Erase Personal Data) * Clean uninstall with optional complete data and file removal * Keyboard navigation, screen reader support, and reduced motion preferences = Perfect For = * **Course creators** using LearnDash, Tutor LMS, LifterLMS, or LearnPress who need better assignments than built-in tools * **University departments** collecting essays, lab reports, or research papers * **Corporate trainers** gathering certification documents and project deliverables * **Standalone WordPress educators** who need assignments without a full LMS * **Online course entrepreneurs** selling courses with graded assignments = Built-in Integrations = PressPrimer Assignment automatically detects and integrates with popular WordPress LMS plugins: **LearnDash:** Attach assignments to lessons or topics via the editor sidebar. Passing an assignment can automatically mark the lesson or topic complete. LearnDash Group Leaders are granted teacher-level permissions to create assignments and grade their students' submissions. The "Mark Complete" button is hidden until a required assignment is passed. **Tutor LMS:** Attach assignments to lessons via the course builder. Passing an assignment can auto-complete the lesson and trigger course completion when all lessons are done. Tutor LMS Instructors are granted teacher-level permissions. **LifterLMS:** Attach assignments to lessons via meta box. Passing an assignment can auto-complete the lesson and course. Works with open/free courses, enrolled students, and instructor roles. **LearnPress:** Attach assignments to lessons via the lesson settings panel. Link passing an assignment to lesson and course completion. Works with open courses, enrolled students, and instructor roles. **Uncanny Automator:** Four triggers available—user submits an assignment, user is graded, user passes, user fails. All integrations are bundled in the free version. = Premium Features = Unlock additional premium features at [pressprimer.com](https://pressprimer.com/pressprimer-assignment-pricing/). Premium capabilities are organized across three tiers — Educator, School, and Enterprise — each building on the one below it: **Educator** * **Groups & Assignments** – Organize students into groups, distribute assignments with per-group due dates, and track completion progress * **Group Reports** – Per-group completion dashboards with submission status grids, score distributions with pass-threshold coloring, drill-down student data * **Rubric Builder** – Create analytic rubrics with criteria and performance levels, attach them to assignments for structured grading with automatic score calculation and per-criterion feedback * **Per-Criteria Report** – See where students are struggling at the rubric-criterion level * **Teacher Role** – Teachers manage their own groups and grade only their students' submissions, while admins retain full access to all data * **Data Retention & Cleanup** – Automatically prune old submission files and orphaned data **School** *(everything in Educator, plus)* * **Inline Document Annotations** – Mark up PDFs, images, and text submissions directly in the grading interface with highlights, underline, strikethrough, freehand drawing, and comments. * **AI-Assisted Grading** – Generate suggested scores and feedback for submissions using OpenAI or Anthropic. Rubric-aware: returns per-criterion scores when a rubric is attached. * **AI Proofreading** – Detect spelling and grammar issues in student submissions with one-click insertion of notes into feedback. Configurable locale for regional spelling variants. * **xAPI / LRS Integration** – Send Experience API statements to your Learning Record Store. Built-in queueing system ensures reliable delivery. **Enterprise** *(everything in School, plus)* * **AI Content & Plagiarism Detection** – Run submitted text through Winston AI, GPTZero, or Originality.ai to surface AI-generated content and plagiarism scores. Auto-check on submission or run manually. Provider-aware grading panel shows scores and interpretation. * **Plagiarism Report** – Cohort-wide report with AI-likelihood and originality-score distributions, stat cards, a per-provider confidence breakdown, and a paginated flagged-submissions table with colour-coded scores and tooltips explaining exactly why each row was flagged. * **Anonymous Grading** – Per-assignment toggle that masks student identity throughout the grading window so grades aren't biased by who wrote the work. Identity stays hidden until submissions have been graded and returned. * **Audit Logging** – Immutable log of every assignment, submission, grading, settings change, annotation, xAPI emission, plagiarism check, and cleanup run with configurable retention, role-based viewer, and export. Audit Trail report on the Reports page surfaces filterable events with object links and a search box. * **White-Label Branding** – Remove all PressPrimer branding and customize with your own plugin name, logos, colors, and custom CSS = Built for Developers = * Action hooks for assignment creation, submission, grading, and email events * Filter hooks for submission permissions, file access, email templates, and role mapping * Full REST API for assignments, submissions, files, categories, and statistics * Custom database tables with automatic schema migration = Documentation & Support = * [Knowledge Base](https://pressprimer.com/knowledge-base/pressprimer-assignment/) = Source Code & Development = The full uncompressed source code for all JavaScript and CSS files is available in our public GitHub repository: * [GitHub Repository](https://github.com/PressPrimer/pressprimer-assignment) The `/src` directory contains all unminified source files. The plugin uses webpack for building production assets. To rebuild from source: 1. Clone the repository 2. Run `npm install` to install dependencies 3. Run `npm run build` to compile assets == Installation == = Automatic Installation = 1. Go to **Plugins > Add New** in your WordPress admin 2. Search for "PressPrimer Assignment" 3. Click **Install Now** and then **Activate** 4. Navigate to ** Assignments ** in your admin menu to get started = LMS Integration = If you have LearnDash, Tutor LMS, LifterLMS, or LearnPress installed, integration features enable automatically. No configuration required—just edit a lesson or topic and you'll see the assignment attachment options. == Privacy == PressPrimer Assignment stores student submission data (files, text, grades, and feedback) in your WordPress database under your full control. No data is transmitted to external servers. All submitted files are stored in a protected directory under `wp-content/uploads/ppa-submissions/` and served via PHP with permission checks. The plugin integrates with the WordPress Privacy API: * **Tools > Export Personal Data** — includes all submissions, grades, feedback, and uploaded file metadata for the requested user. * **Tools > Erase Personal Data** — permanently deletes all submissions, grades, and uploaded files for the requested user. Administrators can permanently delete all plugin data (database tables, uploaded files, options, and user meta) via Settings > Advanced > "Remove all data on uninstall" before uninstalling the plugin. == Frequently Asked Questions == = Is this really free, or is it a limited trial? = It's genuinely free and not locked down. PressPrimer Assignment includes unlimited assignments, unlimited submissions, full grading tools, LMS integrations, email notifications, and three professional themes in the free version. We believe in earning upgrades by offering genuinely valuable features, not by crippling the free experience. = Does this work with LearnDash? = Yes. PressPrimer Assignment integrates natively with LearnDash. Attach assignments to lessons or topics, and passing grades can automatically trigger lesson completion. LearnDash Group Leaders receive teacher-level permissions to create assignments and grade submissions. The integration activates automatically when LearnDash is detected. = Does this work with Tutor LMS? = Yes. Assignments integrate with Tutor LMS lessons via the editor sidebar and course builder. Passing grades can auto-complete lessons, and course completion triggers when all lessons are done. Tutor LMS Instructors receive teacher-level permissions automatically. = Can I use this without an LMS plugin? = Absolutely. PressPrimer Assignment works as a standalone plugin. Use the `[pressprimer_assignment]` shortcode to embed assignments on any page or post. The LMS integrations are a bonus that enable automatically when an LMS is detected—they don't restrict standalone use. = Does this work with PressPrimer Quiz? = Yes. Both plugins are part of the PressPrimer suite and are designed to work together. When both are active, they share the Groups infrastructure and Teacher role for a unified experience. Each plugin also works independently. = What file types can students upload? = By default: PDF, DOCX, TXT, RTF, ODT, JPG, JPEG, PNG, and GIF. Administrators can configure allowed file types per assignment. All uploads go through six layers of security validation including MIME type verification and dangerous file blocking. = Can students submit text instead of files? = Yes. Each assignment can be configured to accept file uploads, text/rich text submissions, or let the student choose. Text submissions use a TinyMCE editor with live word and character counts, auto-save drafts, and a 50,000-character limit. = How does the grading interface work? = The grading interface uses a side-by-side layout. The student's submitted document renders directly in the left panel. PDF, DOCX, images, and text files all display without downloading. The right panel has fields for score, pass/fail status, and rich text feedback, plus a reference panel showing the assignment's grading guidelines. = Can I customize the email notifications? = Yes. Each email type (submission confirmation, grade notification, admin alert) has its own customizable subject and body template. Templates support token placeholders for dynamic content like student name, assignment title, score, and feedback. You can also set a custom from name, from email, and upload a logo for the email header. = Can graders annotate student documents directly? = Yes, with the School addon. Inline document annotations let you highlight, underline, strikethrough, freehand draw, and drop sticky-note comments on PDFs, images, and text submissions — all without leaving the WordPress grading interface. Annotations save automatically, are visible to students when the submission is returned, and the PDF viewer includes a zoom toolbar so you can dig into details on long documents. = Can I check submissions for AI-generated content or plagiarism? = Yes, with the Enterprise addon. AI Content & Plagiarism Detection runs submitted text through your choice of Winston AI, GPTZero, or Originality.ai. Checks can run automatically on submission or be triggered manually per submission. The grading panel surfaces the scores with colour-coded interpretation labels, matched-source counts, and a one-click "Insert plagiarism summary" button that drops a provider-specific summary into your feedback. A cohort-wide Plagiarism Report shows AI-likelihood and originality distributions plus a paginated flagged-submissions table. = Does PressPrimer Assignment integrate with my LRS or xAPI pipeline? = Yes, with the School addon. PressPrimer Assignment can emit Experience API (xAPI) statements to your Learning Record Store when students submit, grades are saved, and submissions are returned. The settings page includes a Test Connection workflow, a queue with retry handling, and per-event toggles so you can decide which actions are reported. == Screenshots == 1. Dashboard showing key stats, quick actions, and assignment activity 2. Upload support for a variety of document formats, including PDF, Word, and images 3. Side-by-side grading interface with embedded document viewer and feedback panel 4. Reports show how each assessment is performing 5. Assignment text editor with autosave and formatting controls == Changelog == = 2.1.0 = * Added: Rich text editing in assignment description, instructions, grading guidelines, instructor feedback, and email template body fields. Toolbar supports bold, italic, bulleted and numbered lists, links, undo, and redo. * Added: Submissions list filters for score range, feedback presence (any / has feedback / no feedback), and submission date range * Added: Duplicate assignment action available as a row action, bulk action, and editor toolbar button — copies all settings and taxonomy into a new draft owned by the current user * Added: New `pressprimer_assignment_assignment_duplicated` action hook so addons can copy their own per-assignment data * Added: Returned submissions render inline on the student view so grader annotations from the School addon are visible to students * Fixed: Submission scores no longer shift retroactively when an assignment's max points is later edited — the Reports page, admin submission detail, the student assignment page (current returned card and the resubmission history), and the [ppa_my_submissions] dashboard widget all use the max points value recorded at grade time * Fixed: The Re-extract text button is no longer shown to students on the assignment page and no longer appears on submissions that have already been graded or returned (it overwrites the extracted text, which shouldn't happen after grading) * Fixed: The submission viewer's file header reflows cleanly on narrow screens * Fixed: PDFs render at a scale that fits the available column width on the student frontend viewer instead of overflowing * Fixed: Download URLs work correctly when the file URL already contains a query string * Fixed: Concurrent file uploads no longer create duplicate draft submissions for the same student * Fixed: LearnDash, LifterLMS, LearnPress, and Tutor LMS lesson pages no longer display "Assignment not found" when the mapped assignment has been deleted — the lesson renders normally with the assignment block omitted * Fixed: Submissions list and grading-queue tables resize sensibly as the admin window shrinks, with column widths sized in em units so they scale with the user's font size * Fixed: Submissions list column widths so the Student column no longer wraps when name and email don't fit = 2.0.0 = * Added: LifterLMS integration with lesson embedding, completion triggers, and instructor role mapping * Added: LearnPress integration with lesson embedding, completion triggers, and instructor role mapping * Added: Multi-format text extraction for DOCX, ODT, RTF, and TXT files with quality scoring * Added: Unlimited resubmissions option (set max resubmissions to 0) * Added: Grader name now shown alongside the graded date in student feedback ("Graded by X on Y") * Added: Premium add-on support with extensibility hooks for Groups, Rubrics, AI Grading, AI Proofreading, White-Label, and Audit Logging * Added: Status page shows addon versions and database table health for all installed addons * Added: Reports page supports addon report cards * Fixed: Assignment edit links in reports and TutorLMS integration now point to the correct admin page * Fixed: Graded submissions stay visible in the grading queue until explicitly returned to the student * Fixed: Save validation failures now switch to the tab containing the first error so the message is visible * Fixed: Duplicate assignments no longer created when a rubric save fails after assignment creation * Fixed: File upload error messages now show the specific constraint that was exceeded * Fixed: Download button now triggers a file download instead of opening the file inline in the browser * Fixed: Resubmitted assignments no longer resurface old submissions in the grading queue * Fixed: Thin border-radius rendering on the text editor container * Fixed: Save Draft, Submit, and word counter now work correctly when retaking a text-only assignment after a failed submission * Fixed: File upload progress bar no longer overlaps the file type icon during upload * Fixed: When an assignment save is rejected by validation, an error notification appears at the top of the screen so the message is visible regardless of where the Save button was clicked * Improved: Inline CSS injection uses wp_strip_all_tags() and wp_kses() sanitization * Improved: All WP_Error codes use the full pressprimer_assignment_ prefix = 1.0.0 = * Initial release == Upgrade Notice == = 2.1.0 = New: rich text editing across content fields, submissions list filters for score / feedback / date, and a Duplicate assignment action. = 2.0.0 = New: LifterLMS and LearnPress integrations, multi-format text extraction, unlimited resubmissions, and premium addon support. = 1.0.0 = Initial release of PressPrimer Assignment. Assignment submission, grading, and LMS integration—free forever.