Преглед изворни кода

Worked on community station private playlists selecting for queue.

KrisVos130 пре 8 година
родитељ
комит
a32667acf4

+ 37 - 1
frontend/components/Modals/AddSongToQueue.vue

@@ -7,6 +7,18 @@
 				<button class="delete" @click="$parent.toggleModal('addSongToQueue')" ></button>
 				<button class="delete" @click="$parent.toggleModal('addSongToQueue')" ></button>
 			</header>
 			</header>
 			<section class="modal-card-body">
 			<section class="modal-card-body">
+				<aside class='menu' v-if='$parent.$parent.loggedIn'>
+					<ul class='menu-list'>
+						<li v-for='playlist in playlists' track-by='$index'>
+							<a :href='' target='_blank' @click='$parent.editPlaylist(playlist._id)'>{{ playlist.displayName }}</a>
+							<div class='controls'>
+								<a href='#' @click='selectPlaylist(playlist._id)' v-if="!isPlaylistSelected(playlist._id)"><i class='material-icons'>panorama_fish_eye</i></a>
+								<a href='#' @click='unSelectPlaylist()' v-if="isPlaylistSelected(playlist._id)"><i class='material-icons'>lens</i></a>
+							</div>
+						</li>
+					</ul>
+					<br />
+				</aside>
 				<div class="control is-grouped">
 				<div class="control is-grouped">
 					<p class="control is-expanded">
 					<p class="control is-expanded">
 						<input class="input" type="text" placeholder="YouTube Query" v-model="querySearch">
 						<input class="input" type="text" placeholder="YouTube Query" v-model="querySearch">
@@ -45,10 +57,30 @@
 		data() {
 		data() {
 			return {
 			return {
 				querySearch: '',
 				querySearch: '',
-				queryResults: []
+				queryResults: [],
+				playlists: [],
+				privatePlaylistQueueSelected: null
 			}
 			}
 		},
 		},
 		methods: {
 		methods: {
+			isPlaylistSelected: function(playlistId) {
+				console.log(this.privatePlaylistQueueSelected === playlistId);
+				return this.privatePlaylistQueueSelected === playlistId;
+			},
+			selectPlaylist: function (playlistId) {
+				let _this = this;
+				if (_this.$parent.type === 'community') {
+					_this.privatePlaylistQueueSelected = playlistId;
+					_this.$parent.privatePlaylistQueueSelected = playlistId;
+				}
+			},
+			unSelectPlaylist: function () {
+				let _this = this;
+				if (_this.$parent.type === 'community') {
+					_this.privatePlaylistQueueSelected = null;
+					_this.$parent.privatePlaylistQueueSelected = null;
+				}
+			},
 			addSongToQueue: function (songId) {
 			addSongToQueue: function (songId) {
 				let _this = this;
 				let _this = this;
 				if (_this.$parent.type === 'community') {
 				if (_this.$parent.type === 'community') {
@@ -100,6 +132,10 @@
 			let _this = this;
 			let _this = this;
 			io.getSocket((socket) => {
 			io.getSocket((socket) => {
 				_this.socket = socket;
 				_this.socket = socket;
+				_this.socket.emit('playlists.indexForUser', res => {
+					if (res.status === 'success') _this.playlists = res.data;
+				});
+				_this.privatePlaylistQueueSelected = _this.$parent.privatePlaylistQueueSelected;
 			});
 			});
 		},
 		},
 		events: {
 		events: {

+ 0 - 11
frontend/components/Sidebars/Playlist.vue

@@ -147,16 +147,5 @@
 		&:active, &:focus { border: 0; }
 		&:active, &:focus { border: 0; }
 	}
 	}
 
 
-	.menu { padding: 0 20px; }
-
-	.menu-list li a:hover { color: #000 !important; }
-
-	.menu-list li {
-		display: flex;
-		justify-content: space-between;
-	}
-
-	.icons-group { display: flex; }
-
 	.none-found { text-align: center; }
 	.none-found { text-align: center; }
 </style>
 </style>

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

@@ -114,7 +114,8 @@
 				queue: [],
 				queue: [],
 				timeBeforePause: 0,
 				timeBeforePause: 0,
 				station: {},
 				station: {},
-				skipVotes: 0
+				skipVotes: 0,
+				privatePlaylistQueueSelected: null
 			}
 			}
 		},
 		},
 		methods: {
 		methods: {
@@ -745,4 +746,19 @@
 	.btn-search {
 	.btn-search {
 		font-size: 14px;
 		font-size: 14px;
 	}
 	}
+
+	.menu { padding: 0 10px; }
+
+	.menu-list li a:hover { color: #000 !important; }
+
+	.menu-list li {
+		display: flex;
+		justify-content: space-between;
+	}
+
+	.menu-list a {
+		padding: 0 10px !important;
+	}
+
+	.icons-group { display: flex; }
 </style>
 </style>