LSL.AddressFormatting
1.0.2
There is a newer version of this package available.
See the version list below for details.
See the version list below for details.
dotnet add package LSL.AddressFormatting --version 1.0.2
NuGet\Install-Package LSL.AddressFormatting -Version 1.0.2
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="LSL.AddressFormatting" Version="1.0.2" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add LSL.AddressFormatting --version 1.0.2
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: LSL.AddressFormatting, 1.0.2"
#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 LSL.AddressFormatting as a Cake Addin #addin nuget:?package=LSL.AddressFormatting&version=1.0.2 // Install LSL.AddressFormatting as a Cake Tool #tool nuget:?package=LSL.AddressFormatting&version=1.0.2
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
LSL.AddressFormatting
A package for building a single address line using simple logic to filter out empty lines and parts of a line.
Example
// Required usings
using LSL.AddressFormatting;
...
var builder = new AddressBuilder();
var singleLineAddress = builder.Build(c => c
// The string to separate each line.
// In this case it is not required as ", "
// is the default separator
.WithLineSeparator(", ")
// The string to separate each section within a line.
// In this case it is not required as " "
// is the default separator
.WithSectionSeparator(" ")
// The following line will have the two middle items removed
// since they are null or empty strings
.AddLine(ld => ld.AddSections([
"123",
null,
"",
"High Street"
]))
// This line will not be used as it has no sections
.AddLine(ld => ld.AddSections([
]))
// This line will not be used as all its sections are either
// null or empty strings
.AddLine(ld => ld.AddSections([
"",
null
]))
.AddLine(ld => ld.AddSections([
"Chester"
]))
.AddLine(ld => ld.AddSections([
"Cheshire",
"more info"
])
// This is a section separator that
// is only applied to this ilne
.WithSectionSeparator(" - "))
.AddLine(ld => ld.AddSections(["CH1 3DD"]))
);
// singleLineAddress will be "123 High Street, Chester, Cheshire - more info, CH1 3DD"
Example using the Create<T>
method
// Required usings
using LSL.AddressFormatting;
...
var builder = new AddressBuilder();
var fn = builder.Create<MyType>(c => c
.WithSectionSeparator(" ")
.WithLineSeparator(", ")
.AddLine(ld =>
{
ld.AddSectionProviders([
i => i.Name,
i => i.Street
]).WithSectionSeparator(" - ");
})
.AddLine(ld => ld.AddSectionProviders([i => i.City]))
.AddLine(ld =>
{
ld.AddSectionProviders([
i => i.Postcode,
]);
}));
using var scope = new AssertionScope();
var address1 = fn(new MyType
{
Name = "Als",
Street = "my street",
City = "my city",
Postcode = "my postcode"
})
// address1 will be "Als - my street, my city, my postcode"
var address2 = fn(new MyType
{
Name = "Als",
Postcode = "my postcode"
});
// address2 will be "Als, my postcode"
The MyType
class is defined as:
public class MyType
{
public string Name { get; set; }
public string Street { get; set; }
public string City { get; set; }
public string Postcode { get; set; }
}
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. 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. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
.NETStandard 2.0
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.