Flip.Umbraco 10.0.0

There is a newer version of this package available.
See the version list below for details.
dotnet add package Flip.Umbraco --version 10.0.0                
NuGet\Install-Package Flip.Umbraco -Version 10.0.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Flip.Umbraco" Version="10.0.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Flip.Umbraco --version 10.0.0                
#r "nuget: Flip.Umbraco, 10.0.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Flip.Umbraco as a Cake Addin
#addin nuget:?package=Flip.Umbraco&version=10.0.0

// Install Flip.Umbraco as a Cake Tool
#tool nuget:?package=Flip.Umbraco&version=10.0.0                

First, a quick history lesson

Cast your mind back, if you will, to the heady days of Umbraco 7. We had a fresh new backoffice, shiny and glorious.

In among the tools and features, we had that most powerful button - Change Document Type. As the name would suggest, this humble button allowed flipping content nodes from one document type to another.

Alas, when Umbraco 8 hit the scene, the Change Document Type button was lost to the annals of CMS history.

This was intentional, and sensible. Over time, Umbraco's property editors became increasingly complex, often storing large JSON data structures rather than primitive values.

That change made changing document types more difficult and error prone (although, in the wrong hands, the feature always had the potential to wreak havoc on a website).

However, deep in the bowels of Umbraco, the magic required to convert document types lay dormant. Like Smaug on his mountain of ill-gotten loot.

Flip is here to wake the dragon.

What's the deal?

Flip adds an action to the context menu to allow changing the current document to a new type.

It is not foolproof, but will provide a list of valid document types for the current location and suggest an appropriate template. When calculating valid types, Flip considers the permitted child types of the current node and its parent, so many not always allow conversion.

Once a new type is selected, users can map properties from the old/current type to the new. Unmapped properties are discarded.

Flip offers two mapping modes:

  • Data type: allow mapping values to properties using the same data type (ie Textstring, of type Umbraco.Textbox)
  • Property editor: allow mapping values to properties using the same property editor (ie any instance of Umbraco.Textbox)

The former results in tighter mapping rules (ie different Grid editors can only map to the exact same data type).

Buyer, beware!

Is this a super safe, bulletproof tool? No.

Does it work for most cases? Yes, probably.

For any complex data - Block Lists, Nested Content - it's probably not a great idea, but will still allow in-situ conversion of document types, which is still an easier process for editors compared to creating a new node, moving child nodes, deleting the old node, moving the new node and children.

As property mapping is opt-in, it's completely viable to map simple values, ignore Block List, and re-build the list on the new type.

To re-iterate: this is an experimental package. Experiment at your own risk.

Supported versions

Flip will play nice with Umbraco 8 and above.

Installation

Install-Package Flip.Umbraco or dotnet add package Flip.Umbraco

Credits

Icon: flip by Joshua Weber from <a href="https://thenounproject.com/browse/icons/term/flip/" target="_blank" title="flip Icons">Noun Project</a>

Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
14.0.0 124 8/6/2024
13.0.1 214 12/10/2024
13.0.0 1,199 2/15/2024
12.0.0 824 9/5/2023
11.0.0 455 2/3/2023
10.0.1 85 12/10/2024
10.0.0 1,024 2/3/2023
1.0.0-beta.954 157 6/29/2022