Skip to content

Commit

Permalink
Merge pull request #151 from FritzAndFriends/dev
Browse files Browse the repository at this point in the history
  • Loading branch information
csharpfritz authored Jun 7, 2020
2 parents 067648f + 4bba9ea commit 06cb3db
Show file tree
Hide file tree
Showing 110 changed files with 5,301 additions and 581 deletions.
1 change: 1 addition & 0 deletions .gitattributes
Original file line number Diff line number Diff line change
Expand Up @@ -82,6 +82,7 @@
*.filters text eol=crlf
*.vcxitems text eol=crlf

*.sh text eol=lf

#*.sln merge=binary
#*.csproj merge=binary
Expand Down
24 changes: 24 additions & 0 deletions .github/workflows/builds-docs.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
name: github pages

on:
push:
branches:
- dev

jobs:
deploy:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v2

- name: docfx-action
uses: nikeee/[email protected]
with:
args: docs/docfx.json

- name: Deploy
uses: peaceiris/[email protected]
with:
github_token: ${{ secrets.GITHUB_TOKEN }}
publish_dir: ./docs/_site
24 changes: 20 additions & 4 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,15 +1,20 @@
# StreamDeckToolkit

[![Build status](https://dev.azure.com/FritzAndFriends/StreamDeckTools/_apis/build/status/StreamDeckTools-CI)](https://dev.azure.com/FritzAndFriends/StreamDeckTools/_build/latest?definitionId=8) ![](https://vsrm.dev.azure.com/FritzAndFriends/_apis/public/Release/badge/00a6d40c-eb0d-4aa8-a405-d13d03317ca9/1/1) [![NuGet](https://img.shields.io/nuget/v/StreamDeckLib.svg)](https://www.nuget.org/packages/StreamDeckLib/)
[![github pages](https://github.com/FritzAndFriends/StreamDeckToolkit/workflows/github%20pages/badge.svg)](https://github.com/FritzAndFriends/StreamDeckToolkit/actions?query=workflow%3A%22github+pages%22)

![](https://img.shields.io/azure-devops/tests/FritzAndFriends/StreamDeckTools/8/dev.svg)

[Intellicode Model](https://prod.intellicode.vsengsaas.visualstudio.com/get?m=EE5419D495BE49528606139DA3ADC687)
[Intellicode Model](https://prod.intellicode.vsengsaas.visualstudio.com/get?m=409A792BE4F74201806A848409B2984D)

## What Is This?

This is a template to help create plugins for the [Elgato Stream Deck][Stream Deck], using the [Stream Deck SDK][] with [Dotnet Core][].

## Docs

You can read more in the [Docs](https://FritzAndFriends.github.io/StreamDeckToolkit/).

## Pre-Requisites

In order to make use of this template, you will need to have the [Dotnet Core SDK][] (version 2.2.100 or above) installed on your development machine.
Expand Down Expand Up @@ -42,14 +47,25 @@ To uninstall, run the following command from the root of the respository.

## Using the Template

Once the template is installed, open a terminal and create a new project.
Once the template is installed, open a terminal in the folder of your choice and create a new project.

dotnet new streamdeck-plugin -n FirstPlugin
dotnet new streamdeck-plugin --plugin-name FirstPlugin --uuid com.yourcompany.pluginname.actionname --skipRestore false

Or create a directory in a location of your choice, change to that directory and run the command, which will inherit the directory name as the project name.
Or create a directory in a location of your choice, change to that directory and run the command, which will inherit the directory name as the project name with default values.

dotnet new streamdeck-plugin

## Creating a Plugin Action
The Stream Deck Toolkit provides the functionality that communicates directly with the Stream Deck software. When creating a plugin, you are responsible for creating actions for the Stream Deck buttons to perform. There are two base classes that you can inherit from when creating your action:

1. BaseStreamDeckAction - this class contains all the integrations necessary to communicate with the Stream Deck at the 'barebones' level. Inheriting from this class will give you the greatest control over how your action sends and receives data from the software.

2. BaseStreamDeckActionWithSettingsModel<T> - this class inherits from BaseStreamDeckAction, this class will automate the population of model properties, where type T is defined as the data that is stored when issuing a 'setSettings' event to the Stream Deck software. The property **SettingsModel** will automatically instantiate an instance of class T, so it is best to assign default values when defining your class T. Also, when using the Property Inspector and passing data back and forth, ensure that the properties defined in the settingsModel in JavaScript matches those that you have defined in T for the automatic mapping to occur between both environments.

Your project may contain any number of actions, inheriting from one of the classes above. In order for the Action to be automatically registered on start up, it must bear the **[ActionUuid(Uuid="com.fritzanfriends.pluginname.anotheraction")]** attribute.

Actions must also be manually registered in the **manifest.json** file, with the Uuid that matches ActionUuid attribute.

<!-- Reference Links -->

[Dotnet Core]: https://dotnet.microsoft.com/ "Free, cross-platform application framework"
Expand Down
Empty file.
2 changes: 2 additions & 0 deletions Templates/StreamDeck.PluginTemplate.Csharp/content/RegisterPluginAndStartStreamDeck.sh
100644 → 100755
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
#!/bin/sh

#Notify user we are killing the process
echo 'Killing the Stream Deck process'

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,21 +10,6 @@ namespace _StreamDeckPlugin_
[ActionUuid(Uuid="$(UUID)")]
public class $(PluginName)Action : BaseStreamDeckActionWithSettingsModel<Models.CounterSettingsModel>
{
// Cheer 342 cpayette 15/2/19
// Cheer 100 devlead 15/2/19
// Cheer 200 kevin_downs Jan 11, 2019
// Cheer 401 cpayette Jan 15, 2019
// Cheer 2501 themikejolley Jan 15, 2019
// Cheer 100 wolfgang_blitz Jan 15, 2019
// Cheer 157 jongalloway Jan 15, 2019
// Cheer 100 johanb Jan 15, 2019
// Cheer 400 faniereynders Jan 15, 2019
// Cheer 100 TomMcQ Jan 15, 2019
// Cheer 361 Crazy240sx Jan 15, 2019
// Cheer 600 yarrgh Jan 15, 2019
// Cheer 1030 kulu83 Jan 15, 2019
// Cheer 2500 Auth0Bobby Jan 15, 2019

public override async Task OnKeyUp(StreamDeckEventPayload args)
{
SettingsModel.Counter++;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,12 +23,12 @@
<ItemGroup>
<PackageReference Include="StreamDeckLib" Version="0.*" />
<PackageReference Include="StreamDeckLib.Config" Version="0.*" />
<PackageReference Include="Microsoft.Extensions.Configuration" Version="2.2.0" />
<PackageReference Include="Microsoft.Extensions.Configuration.Json" Version="2.2.0" />
<PackageReference Include="Microsoft.Extensions.Configuration" Version="3.1.3" />
<PackageReference Include="Microsoft.Extensions.Configuration.Json" Version="3.1.3" />
<PackageReference Include="Serilog.Settings.Configuration" Version="3.0.1" />
<PackageReference Include="McMaster.Extensions.CommandLineUtils" Version="2.3.0" />
<PackageReference Include="Microsoft.Extensions.Logging" Version="2.2.0" />
<PackageReference Include="Newtonsoft.Json" Version="12.0.1" />
<PackageReference Include="McMaster.Extensions.CommandLineUtils" Version="3.0.0" />
<PackageReference Include="Microsoft.Extensions.Logging" Version="3.1.3" />
<PackageReference Include="Newtonsoft.Json" Version="12.0.3" />
<PackageReference Include="Serilog" Version="2.7.1" />
<PackageReference Include="Serilog.Extensions.Logging" Version="2.0.2" />
<PackageReference Include="Serilog.Sinks.File" Version="4.0.0" />
Expand Down
2 changes: 1 addition & 1 deletion Templates/StreamDeck.PluginTemplate.Csharp/global.json
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
{
"sdk": {
"version": "2.2.100"
"version": "3.1.201"
}
}
9 changes: 9 additions & 0 deletions docs/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
###############
# folder #
###############
/**/DROP/
/**/TEMP/
/**/packages/
/**/bin/
/**/obj/
_site
5 changes: 5 additions & 0 deletions docs/api/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
###############
# temp file #
###############
*.yml
.manifest
3 changes: 3 additions & 0 deletions docs/api/index.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
# API Documentaion

Welcome to the API Documentation, please see the navigation for each of the project apis in "StreamDeck Toolkit".
45 changes: 45 additions & 0 deletions docs/articles/contributing.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
## Contributing

There are two ways to contribute to this repo, either the code or the docs.

First check for any open [Issues](https://github.com/FritzAndFriends/StreamDeckToolkit/issues) on [GitHub](https://github.com/FritzAndFriends/StreamDeckToolkit) then comment to indicate you're helping out, or raise a new one with details.

### Code

Pull the code and add your necessary changes, then PR back to dev for review.

### Docs

You're in them! To help out fork this repo, install [DocFX](https://dotnet.github.io/docfx/) and update/add any info.

`docfx docfx.json` will build the site, then move to the "_site" folder and run `docfx serve` then open a browser to "http://localhost:8080/" to see your updates.

There are the Articles you can write to explain the toolkit, then the API docs which builds from the src.

The [docfx.json](../docfx.json) file contains a `metadata` which points to the `src` to built to produce

{
"metadata": [
{
"src": [
{
"files": ["**.csproj"],
"src": "../src"
}
],
"dest": "api"
}
]
}

### Template

This documentation site is using the [DocFX Material](https://ovasquez.github.io/docfx-material/) [template](https://dotnet.github.io/docfx/templates-and-plugins/templates-dashboard.html).

The [docfx.json](../docfx.json) file contains a `template` that has been updated, alongside the [templates](../tempaltes) folder containing the src of the template.

"template": [
"default",
"templates/material"
]

11 changes: 11 additions & 0 deletions docs/articles/create.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
## Creating a Plugin Action

The Stream Deck Toolkit provides the functionality that communicates directly with the Stream Deck software. When creating a plugin, you are responsible for creating actions for the Stream Deck buttons to perform. There are two base classes that you can inherit from when creating your action:

1. `BaseStreamDeckAction` - this class contains all the integrations necessary to communicate with the Stream Deck at the 'barebones' level. Inheriting from this class will give you the greatest control over how your action sends and receives data from the software.

2. `BaseStreamDeckActionWithSettingsModel<T>` - this class inherits from BaseStreamDeckAction, this class will automate the population of model properties, where type T is defined as the data that is stored when issuing a 'setSettings' event to the Stream Deck software. The property **`SettingsModel`** will automatically instantiate an instance of class T, so it is best to assign default values when defining your class T. Also, when using the Property Inspector and passing data back and forth, ensure that the properties defined in the settingsModel in JavaScript matches those that you have defined in T for the automatic mapping to occur between both environments.

Your project may contain any number of actions, inheriting from one of the classes above. In order for the Action to be automatically registered on start up, it must bear the **`[ActionUuid(Uuid="com.fritzanfriends.pluginname.anotheraction")]`** attribute.

Actions must also be manually registered in the **`manifest.json`** file, with the Uuid that matches ActionUuid attribute.
25 changes: 25 additions & 0 deletions docs/articles/install.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
## Install Project Template

### From File System

Installing the template from your filesystem is useful for local testing of the template itself. If you are actively working on the template making changes, this is the route you need to use.

To install, run the following command from the root of the repository.

`dotnet new -i Templates/StreamDeck.PluginTemplate.Csharp`

To pick up any changes you have made to the template source, you must uninstall the template and reinstall it.

To uninstall, run the following command from the root of the respository.

**Windows:** `dotnet new -u Templates/StreamDeck.PluginTemplate.Csharp`

**OSX/Linux:** `dotnet new -u $PWD/Templates/StreamDeck.PluginTemplate.Csharp`

### From NuGet

`dotnet new -i StreamDeckPluginTemplate`

- OR -

`Install-Package StreamDeckPluginTemplate [-Version x.y.zzz]`
13 changes: 13 additions & 0 deletions docs/articles/intro.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
## Welcome

Welcome to the documentation for the StreamDeck Toolkit, a .NET Standard library, template, and tools for building extensions to the Elgato Stream Deck.

## What Is This?

This is a template to help create plugins for the [Elgato Stream Deck][Stream Deck], using the [Stream Deck SDK][] with [Dotnet Core][].

<!-- Reference Links -->

[Dotnet Core]: https://dotnet.microsoft.com/ "Free, cross-platform application framework"
[Stream Deck]: https://www.elgato.com/gaming/stream-deck/ "Elgato's Stream Deck product page"
[Stream Deck SDK]: https://developer.elgato.com/documentation/stream-deck "Elgato's Stream Deck SDK documentation and reference site"
9 changes: 9 additions & 0 deletions docs/articles/plugins.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
## Plugins

Please add your plugins to the list:

- [vscode-streamdeck](https://github.com/nicollasricas/vscode-streamdeck)
- [streamdeck-plugins](https://github.com/madmatt/streamdeck-plugins)
- https://streamdeck-plugins.com/
- [WayBack Machine version](https://web.archive.org/web/20200424173307/https://streamdeck-plugins.com/)
- [BarRaider](https://barraider.com/)
10 changes: 10 additions & 0 deletions docs/articles/pre-reqs.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
## Pre-Requisites

In order to make use of this template, you will need to have the [Dotnet Core SDK][] (version 2.2.100 or above) installed on your development machine.

While not absolutely necessary, it is **strongly** recommended to have the [Stream Deck Software][] installed, to be able to perform some integration testing of your plugin.

<!-- Reference Links -->

[Dotnet Core SDK]: https://get.dot.net/ "Download the Dotnet Core SDK or Runtime"
[Stream Deck Software]: https://www.elgato.com/gaming/downloads "Download the Stream Deck desktop software"
5 changes: 5 additions & 0 deletions docs/articles/projects/dashboard.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
## StreamDeck Dashboard

A collection of stream deck actions in a single plugin for developers

- [code](https://github.com/FritzAndFriends/StreamDeckDashboard)
9 changes: 9 additions & 0 deletions docs/articles/projects/emulator.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
## Stream Deck Emulator

A simple emulator for the Stream Deck Application to allow plugin developers to develop, test, and debug their plugins without requiring a physical [Stream Deck][] device.

See the [code](https://github.com/FritzAndFriends/StreamDeckEmulator).

<!-- Reference Links -->

[Stream Deck]: https://www.elgato.com/gaming/stream-deck/ "Elgato's Stream Deck product page"
4 changes: 4 additions & 0 deletions docs/articles/projects/toc.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
- name: StreamDeck Emulator
href: emulator.md
- name: StreamDeck Dashboard
href: dashboard.md
5 changes: 5 additions & 0 deletions docs/articles/streams.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
## Streams

You can find all the [Twitch](https://www.twitch.tv/csharpfritz) streams that built this toolkit on [YouTube](https://www.youtube.com/channel/UCfvJirlbRTN-bU9sMWMb_ZQ)

- [StreamDeck Toolkit Playlist](https://www.youtube.com/playlist?list=PLVMqA0_8O85xhVTS3OkTOKhe6IIYj7Tna)
76 changes: 76 additions & 0 deletions docs/articles/template/action.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,76 @@
## Action

When you use the template there are a number of parameters which can set things in the following `Action` class:

--uuid com.yourcompany.pluginname.actionname
--plugin-name FirstPlugin

You will also have a model created `CounterSettingsModel` which will be set.

### Attribute

[ActionUuid(Uuid="com.yourcompany.pluginname.actionname")]

### Class Name

The `--plugin-name` will be a prefix for the `Action` class that is created:

public class FirstPluginAction : BaseStreamDeckActionWithSettingsModel<Models.CounterSettingsModel>

## BaseStreamDeckAction

```csharp
public ILogger Logger { get; }
public string ActionUuid { get; }
protected internal ConnectionManager Manager { get; set; }
```

There are a number of methods you can then override and implement with your own logic:

```csharp
public virtual Task OnApplicationDidLaunch(StreamDeckEventPayload args);
public virtual Task OnApplicationDidTerminate(StreamDeckEventPayload args);
public virtual Task OnDeviceDidConnect(StreamDeckEventPayload args);
public virtual Task OnDeviceDidDisconnect(StreamDeckEventPayload args);
public virtual Task OnDidReceiveGlobalSettings(StreamDeckEventPayload args);
public virtual Task OnDidReceiveSettings(StreamDeckEventPayload args);
public virtual Task OnKeyDown(StreamDeckEventPayload args);
public virtual Task OnKeyUp(StreamDeckEventPayload args);
public virtual Task OnPropertyInspectorDidAppear(StreamDeckEventPayload args);
public virtual Task OnPropertyInspectorDidDisappear(StreamDeckEventPayload args);
public virtual Task OnTitleParametersDidChange(StreamDeckEventPayload args);
public virtual Task OnWillAppear(StreamDeckEventPayload args);
public virtual Task OnWillDisappear(StreamDeckEventPayload args);
```

Just call the base method then implement the functionality you wish to achieve.

For example:

```csharp
public override async Task OnDidReceiveSettings(StreamDeckEventPayload args)
{
await base.OnDidReceiveSettings(args);
await Manager.SetTitleAsync(args.context, SettingsModel.Counter.ToString());
}
```

```csharp
public override async Task OnWillAppear(StreamDeckEventPayload args)
{
await base.OnWillAppear(args);
await Manager.SetTitleAsync(args.context, SettingsModel.Counter.ToString());
}
```

## BaseStreamDeckActionWithSettingsModel

```csharp
public T SettingsModel { get; }
```

```csharp
public override Task OnDidReceiveSettings(StreamDeckEventPayload args);
public override Task OnWillAppear(StreamDeckEventPayload args);
protected void SetModelProperties(StreamDeckEventPayload args);
```
Binary file added docs/articles/template/images/screenshot.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
9 changes: 9 additions & 0 deletions docs/articles/template/propertyinspector.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
## Property Inspector

There are various types of fields that are supported in property inspector see [Elgato Github PiSamples](https://github.com/elgatosf/streamdeck-pisamples) and [Elgato SDK Documentation](https://developer.elgato.com/documentation/stream-deck/sdk/property-inspector/)

![screenshot](images/screenshot.png)

The above sample from GitHub allows you to drag and drop elements into your html for quick development.

Add it to the `property_inspector.html` file in the project.
Loading

0 comments on commit 06cb3db

Please sign in to comment.