Skip to content

A cross platform package to copy text to and from the clipboard.

License

Notifications You must be signed in to change notification settings

Cheshire92/TextCopy

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

TextCopy

  • AppVeyor: Build status
  • TravisCI: Build status
  • NuGet Status

A cross platform package to copy text to and from the clipboard.

Support is available via a Tidelift Subscription.

Contents

NuGet package

https://nuget.org/packages/TextCopy/

Usage

SetTextAsync

await ClipboardService.SetTextAsync("Text to place in clipboard");

snippet source | anchor

SetText

ClipboardService.SetText("Text to place in clipboard");

snippet source | anchor

GetTextAsync

var text = await ClipboardService.GetTextAsync();

snippet source | anchor

GetText

var text = ClipboardService.GetText();

snippet source | anchor

Clearing The Clipboard

ClipboardService.SetText("");

snippet source | anchor

await ClipboardService.SetTextAsync("");

snippet source | anchor

Instance API

In addition to the above static API, there is an instance API exposed:

var clipboard = new Clipboard();
clipboard.SetText("Text to place in clipboard");

snippet source | anchor

Dependency Injection

An instance of Clipboard can be injected into IServiceCollection:

serviceCollection.InjectClipboard();

snippet source | anchor

The instance should be injected by using IClipboard.

There is also a InjectMockClipboard that injects an instance of MockClipboard with all methods stubbed out.

Supported on

  • Windows with .NET Framework 4.6.1 and up
  • Windows with .NET Core 2.0 and up
  • Windows with Mono 5.0 and up
  • OSX with .NET Core 2.0 and up
  • OSX with Mono 5.20.1 and up
  • Linux with .NET Core 2.0 and up
  • Linux with Mono 5.20.1 and up
  • Xamarin.Android 9.0 and up
  • Xamarin.iOS 10.0 and up
  • Universal Windows Platform version 10.0.16299 and up
  • Blazor WebAssembly

Blazor WebAssembly

Due to the dependency on JSInterop the static ClipboardService is not supported on Blazor.

Instead inject an IClipboard:

var builder = WebAssemblyHostBuilder.CreateDefault();
var serviceCollection = builder.Services;
serviceCollection.InjectClipboard();
builder.RootComponents.Add<App>("app");

snippet source | anchor

Then consume it:

public partial class IndexModel :
    ComponentBase
{
    [Inject]
    public IClipboard Clipboard { get; set; }

    public string Content { get; set; }

    public Task CopyTextToClipboard()
    {
        return Clipboard.SetTextAsync(Content);
    }

    public async Task ReadTextFromClipboard()
    {
        Content = await Clipboard.GetTextAsync();
    }
}

snippet source | anchor

Blazor support requires the browser APIs clipboard.readText and clipboard.writeText.

Linux

Linux uses xclip to access the clipboard. As such it needs to be installed and callable.

Security contact information

To report a security vulnerability, use the Tidelift security contact. Tidelift will coordinate the fix and disclosure.

Icon

Clone designed by Wes Breazell from The Noun Project.

About

A cross platform package to copy text to and from the clipboard.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C# 91.8%
  • CSS 4.0%
  • HTML 3.0%
  • Other 1.2%