Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

mixmotion-player

Package Overview
Dependencies
Maintainers
1
Versions
15
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

mixmotion-player

Mixmotion Player is an open source music player that blends together Mixcloud audio with dynamic visual effects to create some captivating moments

  • 1.0.22
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
15
decreased by-11.76%
Maintainers
1
Weekly downloads
 
Created
Source

Mixmotion Player

Latest npm version MIT License Monthly npm downloads

An open source music player that blends together Mixcloud audio with dynamic visual effects

https://lewhunt.github.io/mixmotion/

Click the image to try out the app

How to use

For casual users who just want to discover some new music with full-screen visuals, hit the image above or link below to launch the Mixmotion web app on your mobile, desktop or TV device.

:point_right: Try out the App :point_left:

https://lewhunt.github.io/mixmotion

On playing a set, you'll enter playback mode with dynamic background effects appearing after a few seconds of user inactivity. Below is a quick video of the app transitioning between playback modes (give the video a tap if it doesn't autoplay):

https://github.com/lewhunt/mixmotion/assets/9886284/95a2116f-5e4c-47fc-af65-6e65a53a0048

More screenshots and videos at the end of this doc.


Installation

Developers can also install Mixmotion Player as an open source component to use in React apps. Quickest install method is via the npm i command below. Or integrate it manually for more control by grabbing the lib folder in this repo along with the associated dependencies.

npm install mixmotion-player

Basic Usage

After install, import the player and render MixmotionPlayer in your own app with a Mixcloud URL. It will use default settings for the other non declared props.

import { useEffect, useState } from "react";
import { MixmotionPlayer } from "mixmotion-player";

function Demo() {
  const [url, setUrl] = useState("");

  useEffect(() => {
    setUrl("https://www.mixcloud.com/discover/trance/?order=latest");
  }, []);

  return <MixmotionPlayer url={url} />;
}

export default Demo;

Advanced Usage

The advanced demo and official web app illustrate how the component can be customised further. Props are specified for custom buttons, video backgrounds and local data (saved items). A complete list of props are detailed further down this page.

<MixmotionPlayer
  url={url}
  showsData={getSavedData}
  customButtons={customButtons}
  backdropVideoList={backdropVideoList}
  enableBackdropVideo={true}
></MixmotionPlayer>

Why Another Music Player?

There are plenty of web players and widgets already available from the likes of Soundcloud and Mixcloud that you can integrate into your app.

Mixmotion offers something a bit different; an immersive, full-screen experience with unique visual effects, still providing free access to Mixcloud's vast music catalogue.

What Sets It Apart?

  • Mixcloud Integration: Simple yet versatile access to Mixcloud content that goes beyond their official widget. Access playlists, user sets, genres, tags and individual shows, with the ability to privately save favourites via local storage and share mixes.
  • Dynamic Visuals: Artwork combined with canvas effects and video motion backgrounds generate a captivating blend of imagery in a rich, immersive music player.
  • Broad Device Support: Designed for mobile, desktop and TV devices. Touch, cursor and arrow-key navigation help make the user experience smooth across platforms.
  • Future Considerations: Integration with local file paths, audio streams and other music services like Soundcloud. Real-time audio visualizations and beat detection are also being considered.

How Does It Work?

Under the hood, the component is built on top of the official Mixcloud API and Mixcloud Widget. It also utilises another custom component of mine - Dynamic Backdrop - to create the blended mix of transforms, canvas animations and video backgrounds.

Built with React TypeScript, it's packaged using Vite to generate an installable npm component library.


Props

PropDescriptionDefault
urlThe Mixcloud URL of the content to play
◦ Most URLs are supported such as playlists, users, genres, tags and individual shows/sets
◦ This can be a full URL or a partial Mixcloud key
null
showsDataAn array of locally stored shows data that can be used instead of a URL.
◦ The app utilises this for local-storage saved shows.
null
backdropVideoListA string array of background video URLs which appear in a random sequence during playback mode when there is no user activitynull
enableBackdropVideoSet to true to show the above background videos when there is no user activity.
◦ The video toggle button in the UI (and local storage flag) will override this
false
enableUserLinkSet to true to turn the user/artist sub-title into a react-router link. (used in the deployed app)false
collapsedSet to true to minimise the player metadata and controls, in order to make space for other content.
◦ Used in the app for home and search page content.
false
activityTimeoutOverride the timeout period of user inactivity, which then triggers an 'innactive mode' during playback to show full dynamic visuals
◦ Used in the app to provide longer timeout periods in home and search pages.
4000
showWidgetDisplay the official Mixcloud widget at bottom of page - with its own controls and progress bar - instead of the custom progress bar.
◦ The official widget does not support arrow-key navigation for TV devices.
false
widthOverride the width of the player.
◦ Note: full-screen is the intended user experience, with content layered over
◦ You may need to modify the CSS if you override width
100%
heightOverride the height of the player.
◦ Note: full-screen is the intended user experience, with content layered over
◦ You may need to modify the CSS if you override height
100%
customButtonsSpecify a collection of custom buttons for the player UI
  ◦  A set of default buttons will be used if none are specified.
null
autoplaySet to false to disable the attempt to auto-play contenttrue
withExclusivesSet to true to include exclusive content from the Mixcloud API.
◦ Note: exclusive content is unlikely to play without further development to support Mixcloud user sign-in authentication
false
listIndexSet the initial media index number if you have multiple shows/sets in the requested URL or local showData array0
styleadd inline CSS styles to the playernull

Callback Props

Callback props get fired on various player events, so you can take further actions when they occur:

PropDescription
onReadyCalled when media is loaded and ready to play
onPlayCalled when media starts or resumes playing after pausing or buffering
onPauseCalled when media is paused
onBufferingCalled when media starts buffering
onEndedCalled when media finishes playing
&nbsp
onErrorCalled when an error occurs whilst attempting to play media
onProgressCalled when playback is progressing

Custom Buttons

As illustrated in the advanced demo, the player can be overridden with custom buttons. There is a selection of pre-built action types with their own icons and behaviours or you can add your own with the "custom" action type.

import { MixmotionPlayer, ButtonProps } from "mixmotion-player";
import { faBars } from "@fortawesome/free-solid-svg-icons";

const customButtons: ButtonProps[] = [
  { action: "save", align: "right" },
  { action: "previous", align: "center" },
  { action: "playpause", align: "center" },
  { action: "next", align: "center" },
  {
    action: "custom",
    align: "right",
    label: "Queue",
    faIcon: faBars,
    onPress: () => {
      console.log("my custom button pressed");
    },
  },
];

function Demo() {
  return <MixmotionPlayer url={url} customButtons={customButtons} />;
}
Button PropsDescription
actionChoose from custom or one of the pre-built actions: collapse, github, mixcloud, mute, next, playpause, previous, save, videos
alignAlignment of the button. Choose from left,center, right
labelA hint text label to appear below the current button in focus. Pre-built button actions use relevent labels.
faIconA font-awesome icon. Pre-built button actions use relevent icons.
onPressCalled when a button is pressed. Pre-built button actions have their own behaviours.
onReleaseCalled when a button is released. Currently unused.
isSelectedFillAllows support of toggle behaviour (in the form of a button fill) when set to true.
disablePrevents button action when set to true.

useSavedItems Hook

This custom hook is used to update and retrieve shows that are favourited/liked by the user. The below snippet from the advanced demo illustrates how to load the player with local saved data.

import { MixmotionPlayer,
  useSavedItems,
  ShowsDataType
} from "./lib/MixmotionPlayer";

function Demo() {
  const { getSavedItems } = useSavedItems();

  const getSavedData = useMemo(() => {
    const savedItems = getSavedItems();
    if (savedItems.length)
      return {
        label: "Saved Sets",
        shows: savedItems.reverse(),
      } as ShowsDataType;
  }, [getSavedItems]);

  return (
    <MixmotionPlayer
      showsData={getSavedData}
    />
  );
}


useStore Hook

For more control you can import the useStore custom hook to globally access player state. View the inner components like MixmotionPlayerUI for examples of use. The below snippet shows basic usage to get current show title and playing state:

// 1. import useStore
import { MixmotionPlayer, useStore } from "mixmotion-player";

// 2. get desired state values
const playing = useStore((s) => s.playing);
const title = useStore((s) => s.title);

console.log("playing: state ", playing);
console.log("Current title: ", title);

<MixmotionPlayer ... />;

App Screenshots and Videos

https://lewhunt.github.io/mixmotion/https://lewhunt.github.io/mixmotion/
Player UI on Desktopon Mobile

 

https://lewhunt.github.io/mixmotion/

Search Page

 

https://lewhunt.github.io/mixmotion/

Playback Mode

 

https://github.com/lewhunt/mixmotion/assets/9886284/fe234146-28f5-49ca-8786-d2efde7f7476

Playback Mode (example 1)

 

https://github.com/lewhunt/mixmotion/assets/9886284/3eac30ea-ae4b-4916-9615-3cc38ff6b213

Playback Mode (example 2)

 

https://github.com/lewhunt/mixmotion/assets/9886284/ff9fdb0d-ef02-4f04-914d-e8ce6a91fdcb

Playback Mode (example 3)

 

Support

:speech_balloon: Fire over a comment if you have any feedback, requests or issues :bug:

:star: Smash us a Github star if you like the app or component :pray:

:link: Share your favourite sets in the app to support the creators :raised_hands:

 

:point_right: Try out the App :point_left:

https://lewhunt.github.io/mixmotion

Keywords

FAQs

Package last updated on 06 Mar 2024

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc