diff --git a/package.json b/package.json index 6ce6e04..f50050f 100644 --- a/package.json +++ b/package.json @@ -1,7 +1,7 @@ { "name": "atomplayer", "description": "Reproductor de musica, descarga mp3 de youtube", - "version": "1.0.0", + "version": "1.1.0", "main": "main.js", "license": "Apache-2.0", "scripts": { @@ -16,27 +16,29 @@ "dependencies": { "electron-is-dev": "^1.0.1", "ffbinaries": "^1.1.0", + "first-image-search-load": "^0.4.0", "localized-strings": "^0.2.1", "mkdirp": "^0.5.1", "nedb": "^1.8.0", "react": "^16.7.0", "react-contextmenu": "^2.10.0", "react-dom": "^16.7.0", - "semver": "^5.6.0", + "semver": "^6.2.0", "stream": "0.0.2", - "unzipper": "^0.9.7", + "unzipper": "^0.10.1", "vex-js": "^4.1.0", - "youtube-mp3-downloader": "^0.5.3" + "youtube-mp3-downloader": "^0.5.3", + "ytdl-core": "^0.29.3" }, "devDependencies": { "@babel/core": "^7.2.2", "@babel/preset-env": "^7.2.3", "@babel/preset-react": "^7.0.0", "babel-loader": "^8.0.4", - "electron": "^4.0.0", - "electron-builder": "^20.38.4", + "electron": "^5.0.6", + "electron-builder": "^21.0.15", "electron-installer-zip": "^0.1.2", - "electron-packager": "^13.0.1", + "electron-packager": "^14.0.1", "electron-zip-packager": "^4.0.2", "webpack": "^4.28.3", "webpack-cli": "^3.1.2" diff --git a/resources/css/styles.css b/resources/css/styles.css index e3eabac..b1d285e 100644 --- a/resources/css/styles.css +++ b/resources/css/styles.css @@ -236,6 +236,17 @@ input[type=range]:focus { outline: none; } +.album { + float: left; +} + +.album > img { + height: 74px; + width: 74px; + padding: 5px 5px 5px 0px; + border-radius: 10px; +} + @media screen and (max-height: 100px) { .toolbar-header { display: none; @@ -290,4 +301,8 @@ input[type=range]:focus { #toggleLyrics { display: none; } + + .album { + display: none; + } } diff --git a/resources/js/components/Player.jsx b/resources/js/components/Player.jsx index ffc6305..8c4647a 100644 --- a/resources/js/components/Player.jsx +++ b/resources/js/components/Player.jsx @@ -1,4 +1,6 @@ import React from 'react'; +const {getFirstImageURL} = require('first-image-search-load'); + function sectostr (time) { return ~~(time / 60) + ':' + (time % 60 < 10 ? '0' : '') + time % 60; @@ -23,6 +25,7 @@ export default class Player extends React.Component { this.state = { _id: null, _id_playlist: null, + img_album: null, title: null, currentTime: 0, totalTime: 0, @@ -104,6 +107,17 @@ export default class Player extends React.Component { let _state = self.props.songlist.current.state; _state.current = song._id; self.props.songlist.current.setState(_state); + + //search for the image + getFirstImageURL(song.name + ' album').then(function (response) { + let state = self.state; + state.img_album = response; + self.setState(state); + }).catch(function () { + let state = self.state; + state.img_album = null; + self.setState(state); + }); } }); } @@ -188,15 +202,22 @@ export default class Player extends React.Component { } render () { + let img_album = this.state.img_album; + if (img_album === null) { + img_album = ''; + } return ( [ +
+ +
,