A critical vulnerability was discovered in React Server Components (Next.js). Our systems remain protected but we advise to update packages to newest version. Learn More

Per Nergård (MVP)
Jan 15, 2026
  64
(0 votes)

ScheduledJob overview Blazor component

I have always felt that the admin UI for scheduled jobs in Optimizely is harder to use than it needs to be. To check a job you have to go into admin, filter to find the right job, click to see the history, and then click again to view status messages. When you are troubleshooting, this quickly becomes frustrating.

Back in 2017 I tried to improve this by creating a small plugin for viewing scheduled job run history. I wrote about it here:
https://world.optimizely.com/blogs/Per-Nergard/Dates/2017/9/plugin-for-viewing-scheduled-job-run-history/

During the Christmas break I decided to revisit the idea. The result is a Blazor component that gives a better overview of scheduled jobs and their status messages, with fewer clicks and faster access to the information you usually care about. I am using MudBlazor for UI components.  It's a Razor Class Library so you need to configure Blazor in you CMS solution and see that the MudBlazor css and js are loaded. 

The component includes:

  • Separate tabs for custom jobs and built-in jobs, since custom jobs are often the ones causing issues

  • Filtering on job names

  • Direct access to the latest run and status message when selecting a job

  • A list view of up to 1000 status message excerpts with keyword filtering

  • Drill-down into a specific status message with additional filtering

Image 1: Overview of the component.

Image 2: A selected job showing all status messages.

Image 3: Drill-down view of a single status message with filtering.

The full source code is available in a public GitHub repository:

https://github.com/PNergard/ScheduledJob-overview-Blazor-component

Jan 15, 2026

Comments

Please login to comment.
Latest blogs
Our OPAL solution for Innovation Challenge: Persona based Content Optimization

  Introduction Marketing success depends on one core principle : connection. We have may seen many marketing campaigns fail because they fail make...

Ratish | Jan 15, 2026 |

A day in the life of an Optimizely OMVP: Introducing Optimizely Style Manager

Managing display templates in Optimizely CMS (SaaS) has traditionally required working directly with the REST API or managing JSON configuration...

Graham Carr | Jan 13, 2026

Content modelling in Optimizely: Why your initial delivery decisions matter more than you think

The architectural shortcuts you take in sprint zero don't just create technical debt, they define whether your platform scales gracefully or crumbl...

Tom Robinson | Jan 12, 2026 |

A day in the life of an Optimizely OMVP: Introducing Query Library and Request Logs: Two Powerful New Features for OptiGraphExtensions v5

I am excited to announce two new features for OptiGraphExtensions v5 that give Optimizely CMS administrators greater visibility and control over...

Graham Carr | Jan 12, 2026

Indexing Geta Categories in Optimizely Graph

Different ways to fully use categories in headless architecture.

Damian Smutek | Jan 9, 2026 |