-
-
Notifications
You must be signed in to change notification settings - Fork 23
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'rewrite-alpine-tailwind'
- Loading branch information
Showing
8 changed files
with
434 additions
and
272 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,28 @@ | ||
// For format details, see https://aka.ms/devcontainer.json. For config options, see the | ||
// README at: https://github.com/devcontainers/templates/tree/main/src/php | ||
{ | ||
"name": "PHP", | ||
// Or use a Dockerfile or Docker Compose file. More info: https://containers.dev/guide/dockerfile | ||
"image": "mcr.microsoft.com/devcontainers/php:1-8.2-bullseye", | ||
|
||
// Features to add to the dev container. More info: https://containers.dev/features. | ||
// "features": {}, | ||
|
||
// Configure tool-specific properties. | ||
// "customizations": {}, | ||
|
||
// Use 'forwardPorts' to make a list of ports inside the container available locally. | ||
"forwardPorts": [ | ||
8080 | ||
], | ||
"features": { | ||
"ghcr.io/devcontainers-contrib/features/zsh-plugins:0": {}, | ||
"ghcr.io/stuartleeks/dev-container-features/shell-history:0": {} | ||
}, | ||
|
||
// Use 'postCreateCommand' to run commands after the container is created. | ||
"postCreateCommand": "sudo a2enmod rewrite && sudo chmod a+x \"$(pwd)\" && sudo rm -rf /var/www/html && sudo ln -s \"$(pwd)\" /var/www/html && service apache2 restart" | ||
|
||
// Uncomment to connect as root instead. More info: https://aka.ms/dev-containers-non-root. | ||
// "remoteUser": "root" | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,59 @@ | ||
// Check if cookie refreshToken is set | ||
let cookie = document.cookie; | ||
if (!cookie.includes("refreshToken")) { window.location.replace('login.php'); } | ||
|
||
const refreshTime = readCookie('refreshTime'); | ||
let spotifyApi; | ||
|
||
document.addEventListener('alpine:init', x => { | ||
Alpine.store('player', { | ||
init() { | ||
spotifyApi = new SpotifyWebApi(); | ||
spotifyApi.setAccessToken(readCookie('accessToken')); | ||
|
||
this.poolingLoop(); | ||
}, | ||
|
||
playbackObj: {}, | ||
lastPlaybackObj: {}, | ||
|
||
targetImg: 'assets/images/no_song.png', | ||
|
||
async poolingLoop() { | ||
setInterval(async () => { | ||
await this.fetchState(); | ||
}, 1000) | ||
}, | ||
|
||
async fetchState() { | ||
if (Math.floor(Date.now() / 1000) >= refreshTime) { | ||
window.location.replace('token.php?action=refresh'); | ||
} | ||
|
||
const response = await spotifyApi.getMyCurrentPlaybackState(); | ||
if (response) { | ||
this.handleChange(response); | ||
} | ||
}, | ||
|
||
handleChange(obj) { | ||
this.lastPlaybackObj = this.playbackObj; | ||
this.playbackObj = obj; | ||
|
||
if (this.playbackObj.item?.name) { | ||
document.title = `${this.playbackObj.item?.name} - ${this.playbackObj.item?.artists[0].name} - NowPlaying`; | ||
} | ||
|
||
// Fetch album art | ||
const imgUrl = this.playbackObj.item?.album?.images[0]?.url; | ||
if (imgUrl !== this.lastPlaybackObj.item?.album?.images[0]?.url) { | ||
// Load image in new element and then set it on the target | ||
const img = new Image(); | ||
img.src = (imgUrl !== undefined) ? imgUrl : 'assets/images/no_song.png' | ||
img.onload = () => { | ||
this.targetImg = this.playbackObj.item?.album?.images[0]?.url; | ||
} | ||
} | ||
} | ||
}) | ||
}) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.