mirror of
https://github.com/Poniverse/Pony.fm.git
synced 2024-11-27 15:27:58 +01:00
145 lines
4.6 KiB
CoffeeScript
145 lines
4.6 KiB
CoffeeScript
# Pony.fm - A community for pony fan music.
|
|
# Copyright (C) 2015 Feld0
|
|
#
|
|
# This program is free software: you can redistribute it and/or modify
|
|
# it under the terms of the GNU Affero General Public License as published by
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU Affero General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU Affero General Public License
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
module.exports = angular.module('ponyfm').controller "sidebar", [
|
|
'$scope', '$modal', 'playlists', '$rootScope', '$timeout'
|
|
($scope, $modal, playlists, $rootScope, $timeout) ->
|
|
$scope.playlists = playlists.pinnedPlaylists
|
|
$scope.menuVisible = false
|
|
$scope.menuActive = false
|
|
$scope.menuAnimated = true
|
|
$scope.navStyle = {}
|
|
|
|
$rootScope.$on('sidebarToggled', () ->
|
|
$timeout(() ->
|
|
if $scope.menuVisible
|
|
$scope.navStyle.transform = ''
|
|
$scope.menuAnimated = true
|
|
|
|
$scope.menuVisible = !$scope.menuVisible
|
|
$scope.menuActive = $scope.menuVisible
|
|
)
|
|
)
|
|
|
|
$rootScope.$on('sidebarHide', () ->
|
|
$timeout(() ->
|
|
$scope.navStyle.transform = ''
|
|
$scope.menuAnimated = true
|
|
$scope.menuVisible = false
|
|
$scope.menuActive = false
|
|
)
|
|
)
|
|
|
|
$scope.createPlaylist = () ->
|
|
$modal
|
|
templateUrl: '/templates/partials/playlist-dialog.html'
|
|
controller: 'playlist-form'
|
|
resolve: {
|
|
playlist: () ->
|
|
is_public: true
|
|
is_pinned: true
|
|
name: ''
|
|
description: ''
|
|
},
|
|
show: true
|
|
|
|
$scope.editPlaylist = (playlist) ->
|
|
$modal
|
|
templateUrl: '/templates/partials/playlist-dialog.html'
|
|
controller: 'playlist-form'
|
|
resolve: {
|
|
playlist: () -> angular.copy playlist
|
|
},
|
|
show: true
|
|
|
|
$scope.unpinPlaylist = (playlist) ->
|
|
playlist.is_pinned = false;
|
|
playlists.editPlaylist playlist
|
|
|
|
$scope.deletePlaylist = (playlist) ->
|
|
$scope.playlistToDelete = playlist
|
|
$modal({scope: $scope, templateUrl: 'templates/partials/delete-playlist-dialog.html', show: true})
|
|
|
|
$scope.confirmDeletePlaylist = () ->
|
|
playlists.deletePlaylist playlist
|
|
|
|
$scope.showCredits = () ->
|
|
$modal
|
|
templateUrl: '/templates/partials/credits-dialog.html'
|
|
controller: 'credits',
|
|
show: true
|
|
|
|
# Swipable side nav code
|
|
startX = 0
|
|
currentX = 0
|
|
touchingNav = false
|
|
|
|
onStart = (e) ->
|
|
|
|
if !$scope.menuVisible
|
|
return
|
|
|
|
startX = e.touches[0].pageX
|
|
currentX = startX
|
|
touchingNav = true
|
|
$scope.menuAnimated = false
|
|
requestAnimationFrame(update)
|
|
|
|
onMove = (e) ->
|
|
if !touchingNav
|
|
return
|
|
|
|
currentX = e.touches[0].pageX
|
|
translateX = Math.min(0, currentX - startX)
|
|
|
|
if translateX < 0
|
|
e.preventDefault()
|
|
|
|
onEnd = (e) ->
|
|
if !touchingNav
|
|
return
|
|
|
|
touchingNav = false
|
|
translateX = Math.min(0, currentX - startX)
|
|
$scope.menuAnimated = true
|
|
|
|
if translateX < 0
|
|
hideNav()
|
|
|
|
hideNav = () ->
|
|
$scope.navStyle.transform = ''
|
|
$scope.menuAnimated = true
|
|
$scope.menuVisible = false
|
|
$scope.menuActive = false
|
|
$scope.$apply()
|
|
|
|
update = () ->
|
|
if !touchingNav
|
|
return
|
|
|
|
requestAnimationFrame(update)
|
|
|
|
translateX = 170 + Math.min(0, currentX - startX)
|
|
$scope.navStyle.transform = 'translateX(' + translateX + 'px)'
|
|
$scope.$apply()
|
|
|
|
addEventListeners = () ->
|
|
document.addEventListener('touchstart', onStart)
|
|
document.addEventListener('touchmove', onMove)
|
|
document.addEventListener('touchend', onEnd)
|
|
|
|
addEventListeners()
|
|
]
|