Skip to content

Commit 356e350

Browse files
authored
Merge pull request #5722 from sbwalker/dev
add internal module template to application template
2 parents 7ce7020 + b976983 commit 356e350

File tree

23 files changed

+1284
-0
lines changed

23 files changed

+1284
-0
lines changed

Oqtane.Application/Server/Oqtane.Application.Server.csproj

Lines changed: 9 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -11,6 +11,15 @@
1111
<BlazorDisableThrowNavigationException>true</BlazorDisableThrowNavigationException>
1212
</PropertyGroup>
1313

14+
<ItemGroup>
15+
<Compile Remove="wwwroot\Modules\Templates\**" />
16+
<Compile Remove="wwwroot\Themes\Templates\**" />
17+
<Content Remove="wwwroot\Modules\Templates\**" />
18+
<Content Remove="wwwroot\Themes\Templates\**" />
19+
<EmbeddedResource Remove="wwwroot\Modules\Templates\**" />
20+
<EmbeddedResource Remove="wwwroot\Themes\Templates\**" />
21+
</ItemGroup>
22+
1423
<ItemGroup>
1524
<PackageReference Include="Microsoft.AspNetCore.Components.WebAssembly.Server" Version="10.0.0-rc.2.25502.107" />
1625
<PackageReference Include="Microsoft.AspNetCore.Identity.EntityFrameworkCore" Version="10.0.0-rc.2.25502.107" />
Lines changed: 107 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,107 @@
1+
@using Oqtane.Modules.Controls
2+
@using [Owner].Module.[Module].Services
3+
@using [Owner].Module.[Module].Models
4+
5+
@namespace [Owner].Module.[Module]
6+
@inherits ModuleBase
7+
@inject I[Module]Service [Module]Service
8+
@inject NavigationManager NavigationManager
9+
@inject IStringLocalizer<Edit> Localizer
10+
11+
<form @ref="form" class="@(validated ? " was-validated" : "needs-validation" )" novalidate>
12+
<div class="container">
13+
<div class="row mb-1 align-items-center">
14+
<Label Class="col-sm-3" For="name" HelpText="Enter a name" ResourceKey="Name">Name: </Label>
15+
<div class="col-sm-9">
16+
<input id="name" class="form-control" @bind="@_name" required />
17+
</div>
18+
</div>
19+
</div>
20+
<button type="button" class="btn btn-success" @onclick="Save">@Localizer["Save"]</button>
21+
<NavLink class="btn btn-secondary" href="@NavigateUrl()">@Localizer["Cancel"]</NavLink>
22+
<br /><br />
23+
@if (PageState.Action == "Edit")
24+
{
25+
<AuditInfo CreatedBy="@_createdby" CreatedOn="@_createdon" ModifiedBy="@_modifiedby" ModifiedOn="@_modifiedon"></AuditInfo>
26+
}
27+
</form>
28+
29+
@code {
30+
public override SecurityAccessLevel SecurityAccessLevel => SecurityAccessLevel.Edit;
31+
32+
public override string Actions => "Add,Edit";
33+
34+
public override string Title => "Manage [Module]";
35+
36+
private ElementReference form;
37+
private bool validated = false;
38+
39+
private int _id;
40+
private string _name;
41+
private string _createdby;
42+
private DateTime _createdon;
43+
private string _modifiedby;
44+
private DateTime _modifiedon;
45+
46+
protected override async Task OnInitializedAsync()
47+
{
48+
try
49+
{
50+
if (PageState.Action == "Edit")
51+
{
52+
_id = Int32.Parse(PageState.QueryString["id"]);
53+
[Module] [Module] = await [Module]Service.Get[Module]Async(_id, ModuleState.ModuleId);
54+
if ([Module] != null)
55+
{
56+
_name = [Module].Name;
57+
_createdby = [Module].CreatedBy;
58+
_createdon = [Module].CreatedOn;
59+
_modifiedby = [Module].ModifiedBy;
60+
_modifiedon = [Module].ModifiedOn;
61+
}
62+
}
63+
}
64+
catch (Exception ex)
65+
{
66+
await logger.LogError(ex, "Error Loading [Module] {[Module]Id} {Error}", _id, ex.Message);
67+
AddModuleMessage(Localizer["Message.LoadError"], MessageType.Error);
68+
}
69+
}
70+
71+
private async Task Save()
72+
{
73+
try
74+
{
75+
validated = true;
76+
var interop = new Oqtane.UI.Interop(JSRuntime);
77+
if (await interop.FormValid(form))
78+
{
79+
if (PageState.Action == "Add")
80+
{
81+
[Module] [Module] = new [Module]();
82+
[Module].ModuleId = ModuleState.ModuleId;
83+
[Module].Name = _name;
84+
[Module] = await [Module]Service.Add[Module]Async([Module]);
85+
await logger.LogInformation("[Module] Added {[Module]}", [Module]);
86+
}
87+
else
88+
{
89+
[Module] [Module] = await [Module]Service.Get[Module]Async(_id, ModuleState.ModuleId);
90+
[Module].Name = _name;
91+
await [Module]Service.Update[Module]Async([Module]);
92+
await logger.LogInformation("[Module] Updated {[Module]}", [Module]);
93+
}
94+
NavigationManager.NavigateTo(NavigateUrl());
95+
}
96+
else
97+
{
98+
AddModuleMessage(Localizer["Message.SaveValidation"], MessageType.Warning);
99+
}
100+
}
101+
catch (Exception ex)
102+
{
103+
await logger.LogError(ex, "Error Saving [Module] {Error}", ex.Message);
104+
AddModuleMessage(Localizer["Message.SaveError"], MessageType.Error);
105+
}
106+
}
107+
}
Lines changed: 79 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,79 @@
1+
@using [Owner].Module.[Module].Services
2+
@using [Owner].Module.[Module].Models
3+
4+
@namespace [Owner].Module.[Module]
5+
@inherits ModuleBase
6+
@inject I[Module]Service [Module]Service
7+
@inject NavigationManager NavigationManager
8+
@inject IStringLocalizer<Index> Localizer
9+
10+
@if (_[Module]s == null)
11+
{
12+
<p><em>Loading...</em></p>
13+
}
14+
else
15+
{
16+
<ActionLink Action="Add" Security="SecurityAccessLevel.Edit" Text="Add [Module]" ResourceKey="Add" />
17+
<br />
18+
<br />
19+
@if (@_[Module]s.Count != 0)
20+
{
21+
<Pager Items="@_[Module]s">
22+
<Header>
23+
<th style="width: 1px;">&nbsp;</th>
24+
<th style="width: 1px;">&nbsp;</th>
25+
<th>@Localizer["Name"]</th>
26+
</Header>
27+
<Row>
28+
<td><ActionLink Action="Edit" Parameters="@($"id=" + context.[Module]Id.ToString())" ResourceKey="Edit" /></td>
29+
<td><ActionDialog Header="Delete [Module]" Message="Are You Sure You Wish To Delete This [Module]?" Action="Delete" Security="SecurityAccessLevel.Edit" Class="btn btn-danger" OnClick="@(async () => await Delete(context))" ResourceKey="Delete" Id="@context.[Module]Id.ToString()" /></td>
30+
<td>@context.Name</td>
31+
</Row>
32+
</Pager>
33+
}
34+
else
35+
{
36+
<p>@Localizer["Message.DisplayNone"]</p>
37+
}
38+
}
39+
40+
@code {
41+
public override string RenderMode => RenderModes.Static;
42+
43+
public override List<Resource> Resources => new List<Resource>()
44+
{
45+
new Stylesheet(ModulePath() + "[Owner].Module.[Module]/Module.css"),
46+
new Script(ModulePath() + "[Owner].Module.[Module]/Module.js")
47+
};
48+
49+
List<[Module]> _[Module]s;
50+
51+
protected override async Task OnInitializedAsync()
52+
{
53+
try
54+
{
55+
_[Module]s = await [Module]Service.Get[Module]sAsync(ModuleState.ModuleId);
56+
}
57+
catch (Exception ex)
58+
{
59+
await logger.LogError(ex, "Error Loading [Module] {Error}", ex.Message);
60+
AddModuleMessage(Localizer["Message.LoadError"], MessageType.Error);
61+
}
62+
}
63+
64+
private async Task Delete([Module] [Module])
65+
{
66+
try
67+
{
68+
await [Module]Service.Delete[Module]Async([Module].[Module]Id, ModuleState.ModuleId);
69+
await logger.LogInformation("[Module] Deleted {[Module]}", [Module]);
70+
_[Module]s = await [Module]Service.Get[Module]sAsync(ModuleState.ModuleId);
71+
StateHasChanged();
72+
}
73+
catch (Exception ex)
74+
{
75+
await logger.LogError(ex, "Error Deleting [Module] {[Module]} {Error}", [Module], ex.Message);
76+
AddModuleMessage(Localizer["Message.DeleteError"], MessageType.Error);
77+
}
78+
}
79+
}
Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,15 @@
1+
using Microsoft.JSInterop;
2+
using System.Threading.Tasks;
3+
4+
namespace [Owner].Module.[Module]
5+
{
6+
public class Interop
7+
{
8+
private readonly IJSRuntime _jsRuntime;
9+
10+
public Interop(IJSRuntime jsRuntime)
11+
{
12+
_jsRuntime = jsRuntime;
13+
}
14+
}
15+
}
Lines changed: 16 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,16 @@
1+
using Oqtane.Models;
2+
using Oqtane.Modules;
3+
4+
namespace [Owner].Module.[Module]
5+
{
6+
public class ModuleInfo : IModule
7+
{
8+
public ModuleDefinition ModuleDefinition => new ModuleDefinition
9+
{
10+
Name = "[Module]",
11+
Description = "[Description]",
12+
Version = "1.0.0",
13+
ServerManagerType = "[ServerManagerType]"
14+
};
15+
}
16+
}
Lines changed: 47 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,47 @@
1+
@namespace [Owner].Module.[Module]
2+
@inherits ModuleBase
3+
@inject ISettingService SettingService
4+
@inject IStringLocalizer<Settings> Localizer
5+
6+
<div class="container">
7+
<div class="row mb-1 align-items-center">
8+
<Label Class="col-sm-3" For="value" HelpText="Enter a value" ResourceKey="SettingName" ResourceType="@resourceType">Name: </Label>
9+
<div class="col-sm-9">
10+
<input id="value" type="text" class="form-control" @bind="@_value" />
11+
</div>
12+
</div>
13+
</div>
14+
15+
@code {
16+
private string resourceType = "[Owner].Module.[Module].Settings, [Owner].Module.[Module].Client.Oqtane"; // for localization
17+
public override string Title => "[Module] Settings";
18+
19+
string _value;
20+
21+
protected override async Task OnInitializedAsync()
22+
{
23+
try
24+
{
25+
Dictionary<string, string> settings = await SettingService.GetModuleSettingsAsync(ModuleState.ModuleId);
26+
_value = SettingService.GetSetting(settings, "SettingName", "");
27+
}
28+
catch (Exception ex)
29+
{
30+
AddModuleMessage(ex.Message, MessageType.Error);
31+
}
32+
}
33+
34+
public async Task UpdateSettings()
35+
{
36+
try
37+
{
38+
var settings = await SettingService.GetModuleSettingsAsync(ModuleState.ModuleId);
39+
settings = SettingService.SetSetting(settings, "SettingName", _value);
40+
await SettingService.UpdateModuleSettingsAsync(settings, ModuleState.ModuleId);
41+
}
42+
catch (Exception ex)
43+
{
44+
AddModuleMessage(ex.Message, MessageType.Error);
45+
}
46+
}
47+
}

0 commit comments

Comments
 (0)