Skip to content

Commit

Permalink
feature: organise on save
Browse files Browse the repository at this point in the history
  • Loading branch information
jcdcdev committed Aug 9, 2024
1 parent e8fff94 commit 6e1da6b
Show file tree
Hide file tree
Showing 15 changed files with 193 additions and 50 deletions.
36 changes: 25 additions & 11 deletions .github/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,14 +3,16 @@
[![Umbraco Marketplace](https://img.shields.io/badge/Umbraco-Marketplace-%233544B1?style=flat&logo=umbraco)](https://marketplace.umbraco.com/package/umbraco.community.backofficeorganiser)
[![GitHub License](https://img.shields.io/github/license/jcdcdev/Umbraco.Community.BackOfficeOrganiser?color=8AB803&label=License&logo=github)](https://github.com/jcdcdev/Umbraco.Community.BackOfficeOrganiser/blob/main/LICENSE)
[![NuGet Downloads](https://img.shields.io/nuget/dt/Umbraco.Community.BackOfficeOrganiser?color=cc9900&label=Downloads&logo=nuget)](https://www.nuget.org/packages/Umbraco.Community.BackOfficeOrganiser/)
[![Project Website](https://img.shields.io/badge/Project%20Website-jcdc.dev-jcdcdev?style=flat&color=3c4834&logo=)](https://jcdc.dev/umbraco-packages/back-office-organiser)

Is your backoffice a bit untidy?

- Single-click (and opinionated) organiser for
- Document Types
- Media Types
- Member Types
- Data Types
- Document Types
- Media Types
- Member Types
- Data Types
- Automatically sorts on save (configurable)

![A screenshot of the Back Office Organiser in action](https://raw.githubusercontent.com/jcdcdev/Umbraco.Community.BackOfficeOrganiser/main/docs/screenshots/backoffice.png)

Expand All @@ -27,13 +29,25 @@ Is your backoffice a bit untidy?
Add the following to your `appsettings.json` file

```JSON
"BackOfficeOrganiser": {
"DataTypes": {
"InternalFolderName": "Internal",
"ThirdPartyFolderName": "Third Party",
"CustomFolderName": "Custom"
}
}
{
"BackOfficeOrganiser": {
"DataTypes": {
"InternalFolderName": "Internal",
"ThirdPartyFolderName": "Third Party",
"CustomFolderName": "Custom",
"OrganiseOnSave": true
},
"ContentTypes": {
"OrganiseOnSave": true
},
"MediaTypes": {
"OrganiseOnSave": true
},
"MemberTypes": {
"OrganiseOnSave": true
}
}
}
```

## Extending
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,89 @@
using Microsoft.Extensions.Options;
using Umbraco.Cms.Core.Events;
using Umbraco.Cms.Core.Notifications;
using Umbraco.Community.BackOfficeOrganiser.Models;
using Umbraco.Community.BackOfficeOrganiser.Organisers.ContentTypes;
using Umbraco.Community.BackOfficeOrganiser.Organisers.DataTypes;
using Umbraco.Community.BackOfficeOrganiser.Organisers.MediaTypes;
using Umbraco.Community.BackOfficeOrganiser.Organisers.MemberTypes;

namespace Umbraco.Community.BackOfficeOrganiser.Composing;

public class BackofficeOrganiserNotificationHandler :
INotificationHandler<DataTypeSavedNotification>,
INotificationHandler<ContentTypeSavedNotification>,
INotificationHandler<MemberTypeSavedNotification>,
INotificationHandler<MediaTypeSavedNotification>
{
private readonly ContentTypeOrganiser _contentTypeOrganiser;
private readonly DataTypeOrganiser _dataTypeOrganiser;
private readonly MediaTypeOrganiser _mediaTypeOrganiser;
private readonly MemberTypeOrganiser _memberTypeOrganiser;
private readonly BackOfficeOrganiserOptions _options;

public BackofficeOrganiserNotificationHandler(
DataTypeOrganiser dataTypeOrganiser,
ContentTypeOrganiser contentTypeOrganiser,
MediaTypeOrganiser mediaTypeOrganiser,
MemberTypeOrganiser memberTypeOrganiser,
IOptions<BackOfficeOrganiserOptions> options)
{
_dataTypeOrganiser = dataTypeOrganiser;
_contentTypeOrganiser = contentTypeOrganiser;
_mediaTypeOrganiser = mediaTypeOrganiser;
_memberTypeOrganiser = memberTypeOrganiser;
_options = options.Value;
}

public void Handle(ContentTypeSavedNotification notification)
{
if (!_options.ContentTypes.OrganiseOnSave)
{
return;
}

foreach (var item in notification.SavedEntities)
{
_contentTypeOrganiser.Organise(item);
}
}

public void Handle(DataTypeSavedNotification notification)
{
if (!_options.DataTypes.OrganiseOnSave)
{
return;
}

foreach (var dataType in notification.SavedEntities)
{
_dataTypeOrganiser.Organise(dataType);
}
}

public void Handle(MediaTypeSavedNotification notification)
{
if (!_options.MediaTypes.OrganiseOnSave)
{
return;
}

foreach (var item in notification.SavedEntities)
{
_mediaTypeOrganiser.Organise(item);
}
}

public void Handle(MemberTypeSavedNotification notification)
{
if (!_options.MemberTypes.OrganiseOnSave)
{
return;
}

foreach (var item in notification.SavedEntities)
{
_memberTypeOrganiser.Organise(item);
}
}
}
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
using Microsoft.Extensions.DependencyInjection;
using Umbraco.Cms.Core.Composing;
using Umbraco.Cms.Core.DependencyInjection;
using Umbraco.Cms.Core.Notifications;
using Umbraco.Community.BackOfficeOrganiser.Models;
using Umbraco.Community.BackOfficeOrganiser.Organisers.ContentTypes;
using Umbraco.Community.BackOfficeOrganiser.Organisers.DataTypes;
Expand Down Expand Up @@ -30,5 +31,10 @@ public void Compose(IUmbracoBuilder builder)
builder.ContentTypeOrganiseActions().Append<DefaultContentTypeOrganiseAction>();
builder.MediaTypeOrganiseActions().Append<DefaultMediaTypeOrganiseAction>();
builder.MemberTypeOrganiseActions().Append<DefaultMemberTypeOrganiseAction>();

builder.AddNotificationHandler<DataTypeSavedNotification, BackofficeOrganiserNotificationHandler>();
builder.AddNotificationHandler<ContentTypeSavedNotification, BackofficeOrganiserNotificationHandler>();
builder.AddNotificationHandler<MemberTypeSavedNotification, BackofficeOrganiserNotificationHandler>();
builder.AddNotificationHandler<MediaTypeSavedNotification, BackofficeOrganiserNotificationHandler>();
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -3,5 +3,8 @@ namespace Umbraco.Community.BackOfficeOrganiser.Models;
public class BackOfficeOrganiserOptions
{
public DataTypeOptions DataTypes { get; set; } = new();
public ContentTypeOptions ContentTypes { get; set; } = new();
public MemberTypeOptions MemberTypes { get; set; } = new();
public MediaTypeOptions MediaTypes { get; set; } = new();
public static string SectionName => "BackOfficeOrganiser";
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
namespace Umbraco.Community.BackOfficeOrganiser.Models;

public class ContentTypeOptions
{
public bool OrganiseOnSave { get; set; } = true;
}
Original file line number Diff line number Diff line change
Expand Up @@ -5,4 +5,5 @@ public class DataTypeOptions
public string InternalFolderName { get; set; } = "🔒 Internal";
public string ThirdPartyFolderName { get; set; } = "🦄 Third Party";
public string CustomFolderName { get; set; } = "🔧 Custom";
public bool OrganiseOnSave { get; set; } = true;
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
namespace Umbraco.Community.BackOfficeOrganiser.Models;

public class MediaTypeOptions
{
public bool OrganiseOnSave { get; set; } = true;
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
namespace Umbraco.Community.BackOfficeOrganiser.Models;

public class MemberTypeOptions
{
public bool OrganiseOnSave { get; set; } = true;
}
Original file line number Diff line number Diff line change
Expand Up @@ -11,13 +11,22 @@ protected BackOfficeOrganiserBase(ILogger logger)
Logger = logger;
}

public void OrganiseType()
protected virtual void PostOrganiseAll()
{
}

public void OrganiseAll()
{
Logger.LogInformation("BackOfficeOrganiser: Cleanup for {Type} Started", typeof(T).Name);

try
{
Organise();
var items = GetAll();
foreach (var item in items)
{
Organise(item);
}
PostOrganiseAll();
}
catch (Exception ex)
{
Expand All @@ -28,5 +37,7 @@ public void OrganiseType()
Logger.LogInformation("BackOfficeOrganiser: Cleanup for {Type} Complete", typeof(T).Name);
}

public abstract void Organise();
public abstract void Organise(T item);

protected abstract List<T> GetAll();
}
Original file line number Diff line number Diff line change
Expand Up @@ -19,16 +19,16 @@ public ContentTypeOrganiser(
_organiseActions = organiseActions;
}

public override void Organise()
{
var contentTypes = _contentTypeService.GetAll().ToList();
protected override List<IContentType> GetAll() => _contentTypeService.GetAll().ToList();

foreach (var contentType in contentTypes)
{
var organiser = _organiseActions.FirstOrDefault(x => x.CanMove(contentType, _contentTypeService));
organiser?.Move(contentType, _contentTypeService);
}
public override void Organise(IContentType contentType)
{
var organiser = _organiseActions.FirstOrDefault(x => x.CanMove(contentType, _contentTypeService));
organiser?.Move(contentType, _contentTypeService);
}

protected override void PostOrganiseAll()
{
_contentTypeService.DeleteAllEmptyContainers();
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -19,16 +19,16 @@ public DataTypeOrganiser(
_organiseActions = organiseActions;
}

public override void Organise()
public override void Organise(IDataType dataType)
{
var dataTypes = _dataTypeService.GetAll().ToList();

foreach (var dataType in dataTypes)
{
var organiser = _organiseActions.FirstOrDefault(x => x.CanMove(dataType, _dataTypeService));
organiser?.Move(dataType, _dataTypeService);
}
var organiser = _organiseActions.FirstOrDefault(x => x.CanMove(dataType, _dataTypeService));
organiser?.Move(dataType, _dataTypeService);
}

protected override List<IDataType> GetAll() => _dataTypeService.GetAll().ToList();

protected override void PostOrganiseAll()
{
_dataTypeService.DeleteAllEmptyContainers();
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -2,5 +2,6 @@ namespace Umbraco.Community.BackOfficeOrganiser.Organisers;

public interface IBackOfficeOrganiser<T>
{
void OrganiseType();
void OrganiseAll();
void Organise(T item);
}
Original file line number Diff line number Diff line change
Expand Up @@ -19,16 +19,16 @@ public MediaTypeOrganiser(
_organiseActions = organiseActions;
}

public override void Organise()
public override void Organise(IMediaType mediaType)
{
var mediaTypes = _mediaTypeService.GetAll().ToList();

foreach (var mediaType in mediaTypes)
{
var organiser = _organiseActions.FirstOrDefault(x => x.CanMove(mediaType, _mediaTypeService));
organiser?.Move(mediaType, _mediaTypeService);
}
var organiser = _organiseActions.FirstOrDefault(x => x.CanMove(mediaType, _mediaTypeService));
organiser?.Move(mediaType, _mediaTypeService);
}

protected override List<IMediaType> GetAll() => _mediaTypeService.GetAll().ToList();

protected override void PostOrganiseAll()
{
_mediaTypeService.DeleteAllEmptyContainers();
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -19,16 +19,16 @@ public MemberTypeOrganiser(
_organiseActions = organiseActions;
}

public override void Organise()
public override void Organise(IMemberType item)
{
var memberTypes = _memberTypeService.GetAll().ToList();
var organiser = _organiseActions.FirstOrDefault(x => x.CanMove(item, _memberTypeService));
organiser?.Move(item, _memberTypeService);
}

foreach (var memberType in memberTypes)
{
var organiser = _organiseActions.FirstOrDefault(x => x.CanMove(memberType, _memberTypeService));
organiser?.Move(memberType, _memberTypeService);
}
protected override List<IMemberType> GetAll() => _memberTypeService.GetAll().ToList();

protected override void PostOrganiseAll()
{
_memberTypeService.DeleteAllEmptyContainers();
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -65,21 +65,21 @@ public Attempt<OrganiseType> Organise(OrganiseType organise)

private void OrganiseDataTypes()
{
_dataTypeOrganiser.OrganiseType();
_dataTypeOrganiser.OrganiseAll();
}

private void OrganiseMemberTypes()
{
_memberTypeOrganiser.OrganiseType();
_memberTypeOrganiser.OrganiseAll();
}

private void OrganiseMediaTypes()
{
_mediaTypeOrganiser.OrganiseType();
_mediaTypeOrganiser.OrganiseAll();
}

private void OrganiseContentTypes()
{
_contentTypeOrganiser.OrganiseType();
_contentTypeOrganiser.OrganiseAll();
}
}

0 comments on commit 6e1da6b

Please sign in to comment.