Bläddra i källkod

refactor: showing skip vote button to owners/admins and changed skip to vote amount needed

Kristian Vos 6 år sedan
förälder
incheckning
e721ea559e
2 ändrade filer med 17 tillägg och 2 borttagningar
  1. 16 1
      backend/logic/actions/stations.js
  2. 1 1
      frontend/components/Station/StationHeader.vue

+ 16 - 1
backend/logic/actions/stations.js

@@ -436,6 +436,9 @@ module.exports = {
 	 * @param cb
 	 */
 	voteSkip: hooks.loginRequired((session, stationId, cb) => {
+		let skipVotes = 0;
+		let shouldSkip = false;
+
 		async.waterfall([
 			(next) => {
 				stations.getStation(stationId, next);
@@ -467,6 +470,18 @@ module.exports = {
 			(station, next) => {
 				if (!station) return next('Station not found.');
 				next(null, station);
+			},
+
+			(station, next) => {
+				skipVotes = station.currentSong.skipVotes.length;
+				utils.getRoomSockets(`station.${stationId}`).then(sockets => {
+					next(null, sockets);
+				}).catch(next);
+			},
+
+			(sockets, next) => {
+				if (sockets.length <= skipVotes) shouldSkip = true;
+				next();
 			}
 		], async (err, station) => {
 			if (err) {
@@ -476,8 +491,8 @@ module.exports = {
 			}
 			logger.success("STATIONS_VOTE_SKIP", `Vote skipping "${stationId}" successful.`);
 			cache.pub('station.voteSkipSong', stationId);
-			if (station.currentSong && station.currentSong.skipVotes.length >= 3) stations.skipStation(stationId)();
 			cb({ status: 'success', message: 'Successfully voted to skip the song.' });
+			if (shouldSkip) stations.skipStation(stationId)();
 		});
 	}),
 

+ 1 - 1
frontend/components/Station/StationHeader.vue

@@ -118,7 +118,7 @@
 						<span class="icon-purpose">Add song to queue</span>
 					</a>
 					<a
-						v-if="!isOwner() && !noSong"
+						v-if="!noSong"
 						class="sidebar-item"
 						href="#"
 						@click="$parent.voteSkipStation()"