now playing card working, ready for css

This commit is contained in:
andy 2021-11-09 20:58:02 +00:00
parent 40d7b3e676
commit cfcb5ece97
10 changed files with 82 additions and 17 deletions

View File

@ -0,0 +1,8 @@
.card {
background-color: grey;
}
.now-playing-card {
max-width: 400px;
}

View File

@ -2,7 +2,10 @@ using System;
using System.Threading.Tasks; using System.Threading.Tasks;
using Microsoft.AspNetCore.SignalR; using Microsoft.AspNetCore.SignalR;
using StackExchange.Redis;
using Selector.Cache; using Selector.Cache;
using System.Text.Json;
namespace Selector.Web.Hubs namespace Selector.Web.Hubs
{ {
@ -13,9 +16,18 @@ namespace Selector.Web.Hubs
public class NowPlayingHub: Hub<INowPlayingHubClient> public class NowPlayingHub: Hub<INowPlayingHubClient>
{ {
public Task SendNewPlaying(CurrentlyPlayingDTO context) private readonly IDatabaseAsync Cache;
public NowPlayingHub(IDatabaseAsync cache)
{ {
return Clients.All.OnNewPlaying(context); Cache = cache;
}
public async Task SendNewPlaying()
{
var nowPlaying = await Cache.StringGetAsync(Key.CurrentlyPlaying(Context.UserIdentifier));
var deserialised = JsonSerializer.Deserialize<CurrentlyPlayingDTO>(nowPlaying);
await Clients.Caller.OnNewPlaying(deserialised);
} }
} }
} }

View File

@ -6,9 +6,4 @@
<div class="text-center"> <div class="text-center">
<h1 class="display-4">Welcome</h1> <h1 class="display-4">Welcome</h1>
<partial name="_LoginPartial" />
</div> </div>
@section Scripts {
<script type="module" src="~/js/index.bundle.js"></script>
}

View File

@ -8,6 +8,7 @@
<h1 class="display-4">Now</h1> <h1 class="display-4">Now</h1>
<div id="app"> <div id="app">
<h1>{{ count }}</h1> <h1>{{ count }}</h1>
<now-playing-card :track="currentlyPlaying.track"></now-playing-card>
</div> </div>
</div> </div>

View File

@ -28,6 +28,7 @@
</li> </li>
</ul> </ul>
</div> </div>
<partial name="_LoginPartial" />
</div> </div>
</nav> </nav>
</header> </header>

View File

@ -80,7 +80,7 @@ namespace Selector.Web
{ {
// Cookie settings // Cookie settings
options.Cookie.HttpOnly = true; options.Cookie.HttpOnly = true;
options.ExpireTimeSpan = TimeSpan.FromMinutes(5); options.ExpireTimeSpan = TimeSpan.FromDays(1);
options.LoginPath = "/Identity/Account/Login"; options.LoginPath = "/Identity/Account/Login";
options.AccessDeniedPath = "/Identity/Account/AccessDenied"; options.AccessDeniedPath = "/Identity/Account/AccessDenied";

View File

@ -0,0 +1,21 @@
import * as Vue from "vue";
import { FullTrack } from "./HubInterfaces";
let component: Vue.Component = {
props: ['track'],
template:
`
<div class="card now-playing-card" >
<img :src="track.album.images[0].url">
<h4>{{ track.name }}</h4>
<h6>
<template v-for="(artist, index) in track.artists">
<template v-if="index > 0">,</template>
<span>{{ artist.name }}</span>
</template>
</h6>
</div>
`
}
export default component;

View File

@ -1,24 +1,49 @@
import * as signalR from "@microsoft/signalr"; import * as signalR from "@microsoft/signalr";
import * as Vue from "vue"; import * as Vue from "vue";
import { FullTrack, CurrentlyPlayingDTO } from "./HubInterfaces"; import { FullTrack, CurrentlyPlayingDTO } from "./HubInterfaces";
import NowPlayingCard from "./NowPlayingCard";
const connection = new signalR.HubConnectionBuilder() const connection = new signalR.HubConnectionBuilder()
.withUrl("/hub") .withUrl("/hub")
.build(); .build();
connection.on("OnNewPlaying", (context: CurrentlyPlayingDTO) => console.log(context));
connection.start().catch(err => console.error(err)); connection.start().catch(err => console.error(err));
interface NowPlaying {
currentlyPlaying?: CurrentlyPlayingDTO
}
const app = Vue.createApp({ const app = Vue.createApp({
data() { data() {
return { return {
count: 4 currentlyPlaying: {
} track: {
name: "No Playback",
album: {
name: "",
images: [
{
url: ""
}
]
},
artists: [
{
name: ""
}
]
}
}
} as NowPlaying
}, },
created() { created() {
console.log(this.count); connection.on("OnNewPlaying", (context: CurrentlyPlayingDTO) =>
{
console.log(context);
this.currentlyPlaying = context;
});
} }
}); });
// app.component("", TrackNowPlaying);
app.component("now-playing-card", NowPlayingCard);
const vm = app.mount('#app'); const vm = app.mount('#app');

View File

@ -4,7 +4,7 @@
"strict": true, "strict": true,
"sourceMap": true, "sourceMap": true,
"noImplicitAny": true, "noImplicitAny": true,
"noEmitOnError": true, "noEmitOnError": false,
"module": "es6", "module": "es6",
"target": "es5", "target": "es5",
"allowJs": true, "allowJs": true,
@ -19,6 +19,7 @@
} }
}, },
"include": [ "include": [
"scripts/**/*" "scripts/**/*",
"vue-file-import.d.ts"
] ]
} }

View File

@ -27,6 +27,7 @@ namespace Selector
var config = await spotifyFactory.GetConfig(); var config = await spotifyFactory.GetConfig();
var client = new SpotifyClient(config); var client = new SpotifyClient(config);
// TODO: catch spotify exceptions
var user = await client.UserProfile.Current(); var user = await client.UserProfile.Current();
return new PlayerWatcher( return new PlayerWatcher(