enhanced scheduler to support one-time jobs, fixed pager component so that top/bottom have consistent UX, fixed Blazor theme z-index issues caused by input-group in Bootstrap 5, improved password reset instructions in email notification
This commit is contained in:
		| @ -38,6 +38,7 @@ | ||||
|                     <option value="d">@Localizer["Day(s)"]</option> | ||||
|                     <option value="w">@Localizer["Week(s)"]</option> | ||||
|                     <option value="M">@Localizer["Month(s)"]</option> | ||||
|                     <option value="O">@Localizer["Once"]</option> | ||||
|                 </select> | ||||
|             </div> | ||||
|         </div> | ||||
| @ -96,82 +97,89 @@ | ||||
| </form> | ||||
|  | ||||
| @code { | ||||
|     private ElementReference form; | ||||
|     private bool validated = false; | ||||
|     private int _jobId; | ||||
|     private string _name = string.Empty; | ||||
|     private string _jobType = string.Empty; | ||||
|     private string _isEnabled = "True"; | ||||
|     private string _interval = string.Empty; | ||||
|     private string _frequency = string.Empty; | ||||
|     private DateTime? _startDate = null; | ||||
|     private string _startTime = string.Empty; | ||||
|     private DateTime? _endDate = null; | ||||
|     private string _endTime = string.Empty; | ||||
|     private string _retentionHistory = string.Empty; | ||||
|     private DateTime? _nextDate = null; | ||||
|     private string _nextTime = string.Empty; | ||||
|     private string createdby; | ||||
|     private DateTime createdon; | ||||
|     private string modifiedby; | ||||
|     private DateTime modifiedon; | ||||
| 	private ElementReference form; | ||||
| 	private bool validated = false; | ||||
| 	private int _jobId; | ||||
| 	private string _name = string.Empty; | ||||
| 	private string _jobType = string.Empty; | ||||
| 	private string _isEnabled = "True"; | ||||
| 	private string _interval = string.Empty; | ||||
| 	private string _frequency = string.Empty; | ||||
| 	private DateTime? _startDate = null; | ||||
| 	private string _startTime = string.Empty; | ||||
| 	private DateTime? _endDate = null; | ||||
| 	private string _endTime = string.Empty; | ||||
| 	private string _retentionHistory = string.Empty; | ||||
| 	private DateTime? _nextDate = null; | ||||
| 	private string _nextTime = string.Empty; | ||||
| 	private string createdby; | ||||
| 	private DateTime createdon; | ||||
| 	private string modifiedby; | ||||
| 	private DateTime modifiedon; | ||||
|  | ||||
|     public override SecurityAccessLevel SecurityAccessLevel => SecurityAccessLevel.Host; | ||||
| 	public override SecurityAccessLevel SecurityAccessLevel => SecurityAccessLevel.Host; | ||||
|  | ||||
|     protected override async Task OnInitializedAsync() | ||||
|     { | ||||
|         try | ||||
|         { | ||||
|             _jobId = Int32.Parse(PageState.QueryString["id"]); | ||||
|             Job job = await JobService.GetJobAsync(_jobId); | ||||
|             if (job != null) | ||||
|             { | ||||
|                 _name = job.Name; | ||||
|                 _jobType = job.JobType; | ||||
|                 _isEnabled = job.IsEnabled.ToString(); | ||||
|                 _interval = job.Interval.ToString(); | ||||
|                 _frequency = job.Frequency; | ||||
|                 _startDate = job.StartDate; | ||||
|                 if (job.StartDate != null && job.StartDate.Value.TimeOfDay.TotalSeconds != 0) | ||||
|                 { | ||||
|                     _startTime = job.StartDate.Value.ToString("HH:mm"); | ||||
|                 } | ||||
|                 _endDate = job.EndDate; | ||||
|                 if (job.EndDate != null && job.EndDate.Value.TimeOfDay.TotalSeconds != 0) | ||||
|                 { | ||||
|                     _endTime = job.EndDate.Value.ToString("HH:mm"); | ||||
|                 } | ||||
|                 _retentionHistory = job.RetentionHistory.ToString(); | ||||
|                 _nextDate = job.NextExecution; | ||||
|                 if (job.NextExecution != null && job.NextExecution.Value.TimeOfDay.TotalSeconds != 0) | ||||
|                 { | ||||
|                     _nextTime = job.NextExecution.Value.ToString("HH:mm"); | ||||
|                 } | ||||
|                 createdby = job.CreatedBy; | ||||
|                 createdon = job.CreatedOn; | ||||
|                 modifiedby = job.ModifiedBy; | ||||
|                 modifiedon = job.ModifiedOn; | ||||
|             } | ||||
|         } | ||||
|         catch (Exception ex) | ||||
|         { | ||||
|             await logger.LogError(ex, "Error Loading Job {JobId} {Error}", _jobId, ex.Message); | ||||
|             AddModuleMessage(Localizer["Error.Job.Load"], MessageType.Error); | ||||
|         } | ||||
|     } | ||||
| 	protected override async Task OnInitializedAsync() | ||||
| 	{ | ||||
| 		try | ||||
| 		{ | ||||
| 			_jobId = Int32.Parse(PageState.QueryString["id"]); | ||||
| 			Job job = await JobService.GetJobAsync(_jobId); | ||||
| 			if (job != null) | ||||
| 			{ | ||||
| 				_name = job.Name; | ||||
| 				_jobType = job.JobType; | ||||
| 				_isEnabled = job.IsEnabled.ToString(); | ||||
| 				_interval = job.Interval.ToString(); | ||||
| 				_frequency = job.Frequency; | ||||
| 				_startDate = job.StartDate; | ||||
| 				if (job.StartDate != null && job.StartDate.Value.TimeOfDay.TotalSeconds != 0) | ||||
| 				{ | ||||
| 					_startTime = job.StartDate.Value.ToString("HH:mm"); | ||||
| 				} | ||||
| 				_endDate = job.EndDate; | ||||
| 				if (job.EndDate != null && job.EndDate.Value.TimeOfDay.TotalSeconds != 0) | ||||
| 				{ | ||||
| 					_endTime = job.EndDate.Value.ToString("HH:mm"); | ||||
| 				} | ||||
| 				_retentionHistory = job.RetentionHistory.ToString(); | ||||
| 				_nextDate = job.NextExecution; | ||||
| 				if (job.NextExecution != null && job.NextExecution.Value.TimeOfDay.TotalSeconds != 0) | ||||
| 				{ | ||||
| 					_nextTime = job.NextExecution.Value.ToString("HH:mm"); | ||||
| 				} | ||||
| 				createdby = job.CreatedBy; | ||||
| 				createdon = job.CreatedOn; | ||||
| 				modifiedby = job.ModifiedBy; | ||||
| 				modifiedon = job.ModifiedOn; | ||||
| 			} | ||||
| 		} | ||||
| 		catch (Exception ex) | ||||
| 		{ | ||||
| 			await logger.LogError(ex, "Error Loading Job {JobId} {Error}", _jobId, ex.Message); | ||||
| 			AddModuleMessage(Localizer["Error.Job.Load"], MessageType.Error); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
|     private async Task SaveJob() | ||||
|     { | ||||
|         validated = true; | ||||
|         var interop = new Interop(JSRuntime); | ||||
|         if (await interop.FormValid(form)) | ||||
|         { | ||||
|             var job = await JobService.GetJobAsync(_jobId); | ||||
|             job.Name = _name; | ||||
|             job.JobType = _jobType; | ||||
|             job.IsEnabled = Boolean.Parse(_isEnabled); | ||||
|             job.Frequency = _frequency; | ||||
|             job.Interval = int.Parse(_interval); | ||||
| 	private async Task SaveJob() | ||||
| 	{ | ||||
| 		validated = true; | ||||
| 		var interop = new Interop(JSRuntime); | ||||
| 		if (await interop.FormValid(form)) | ||||
| 		{ | ||||
| 			var job = await JobService.GetJobAsync(_jobId); | ||||
| 			job.Name = _name; | ||||
| 			job.JobType = _jobType; | ||||
| 			job.IsEnabled = Boolean.Parse(_isEnabled); | ||||
| 			job.Frequency = _frequency; | ||||
| 			if (job.Frequency == "O") // once | ||||
| 			{ | ||||
| 				job.Interval = 1; | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				job.Interval = int.Parse(_interval); | ||||
| 			} | ||||
|             job.StartDate = _startDate; | ||||
|             if (job.StartDate != null) | ||||
|             { | ||||
|  | ||||
| @ -49,60 +49,62 @@ else | ||||
| } | ||||
|  | ||||
| @code { | ||||
|     private List<Job> _jobs; | ||||
| 	private List<Job> _jobs; | ||||
|  | ||||
|     public override SecurityAccessLevel SecurityAccessLevel { get { return SecurityAccessLevel.Host; } } | ||||
| 	public override SecurityAccessLevel SecurityAccessLevel { get { return SecurityAccessLevel.Host; } } | ||||
|  | ||||
|     protected override async Task OnParametersSetAsync() | ||||
|     { | ||||
|         _jobs = await JobService.GetJobsAsync(); | ||||
|     } | ||||
| 	protected override async Task OnParametersSetAsync() | ||||
| 	{ | ||||
| 		_jobs = await JobService.GetJobsAsync(); | ||||
| 	} | ||||
|  | ||||
|     private string DisplayStatus(bool isEnabled, bool isExecuting) | ||||
|     { | ||||
|         var status = string.Empty; | ||||
|         if (!isEnabled) | ||||
|         { | ||||
|             status = Localizer["Disabled"]; | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             if (isExecuting) | ||||
|             { | ||||
|                 status = Localizer["Executing"]; | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 status = Localizer["Idle"]; | ||||
|             } | ||||
|         } | ||||
| 	private string DisplayStatus(bool isEnabled, bool isExecuting) | ||||
| 	{ | ||||
| 		var status = string.Empty; | ||||
| 		if (!isEnabled) | ||||
| 		{ | ||||
| 			status = Localizer["Disabled"]; | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			if (isExecuting) | ||||
| 			{ | ||||
| 				status = Localizer["Executing"]; | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				status = Localizer["Idle"]; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
|         return status; | ||||
|     } | ||||
| 		return status; | ||||
| 	} | ||||
|  | ||||
|  | ||||
|     private string DisplayFrequency(int interval, string frequency) | ||||
|     { | ||||
|         var result = $"{Localizer["Every"]} {interval.ToString()} "; | ||||
|         switch (frequency) | ||||
|         { | ||||
|             case "m": | ||||
|                 result += Localizer["Minute"]; | ||||
|                 break; | ||||
|             case "H": | ||||
|                 result += Localizer["Hour"]; | ||||
|                 break; | ||||
|             case "d": | ||||
|                 result += Localizer["Day"]; | ||||
|                 break; | ||||
|             case "w": | ||||
|                 result += Localizer["Week"]; | ||||
|                 break; | ||||
|             case "M": | ||||
|                 result += Localizer["Month"]; | ||||
|                 break; | ||||
|         } | ||||
|  | ||||
| 	private string DisplayFrequency(int interval, string frequency) | ||||
| 	{ | ||||
| 		var result = ""; | ||||
| 		switch (frequency) | ||||
| 		{ | ||||
| 			case "m": | ||||
| 				result = $"{Localizer["Every"]} {interval.ToString()} " + Localizer["Minute"]; | ||||
| 				break; | ||||
| 			case "H": | ||||
| 				result = $"{Localizer["Every"]} {interval.ToString()} " + Localizer["Hour"]; | ||||
| 				break; | ||||
| 			case "d": | ||||
| 				result = $"{Localizer["Every"]} {interval.ToString()} " + Localizer["Day"]; | ||||
| 				break; | ||||
| 			case "w": | ||||
| 				result = $"{Localizer["Every"]} {interval.ToString()} " + Localizer["Week"]; | ||||
| 				break; | ||||
| 			case "M": | ||||
| 				result = $"{Localizer["Every"]} {interval.ToString()} " + Localizer["Month"]; | ||||
| 				break; | ||||
| 			case "O": | ||||
| 				result = Localizer["Once"]; | ||||
| 				break; | ||||
| 		} | ||||
|         return result; | ||||
|     } | ||||
|  | ||||
|  | ||||
| @ -19,9 +19,10 @@ | ||||
|             <label for="Confirm" class="control-label">@Localizer["Password.Confirm"] </label> | ||||
|             <input type="password" class="form-control" placeholder="Password" @bind="@_confirm" id="Confirm" required /> | ||||
|         </div> | ||||
|         <button type="button" class="btn btn-primary" @onclick="Reset">@Localizer["Password.Reset"]</button> | ||||
|         <button type="button" class="btn btn-secondary" @onclick="Cancel">@SharedLocalizer["Cancel"]</button> | ||||
|     </div> | ||||
|     <br /> | ||||
|     <button type="button" class="btn btn-primary" @onclick="Reset">@Localizer["Password.Reset"]</button> | ||||
|     <button type="button" class="btn btn-secondary" @onclick="Cancel">@SharedLocalizer["Cancel"]</button> | ||||
| </form> | ||||
|  | ||||
| @code { | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 Shaun Walker
					Shaun Walker