SoundCloudPlayer.js 2.7KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. function SoundCloudPlayer(ref_id, object_for_player, finish_callback, autoplay)
  2. {
  3. autoplay = typeof autoplay !== 'undefined' ? autoplay : false;
  4. var _autoplay = autoplay;
  5. var _iframe_id = '';
  6. if (typeof(ref_id) == 'string')
  7. {
  8. var _ref_id = ref_id.replace('http://', 'https://');
  9. }
  10. else
  11. {
  12. var _ref_id = ref_id
  13. }
  14. var _object_for_player = object_for_player;
  15. var _player = null;
  16. var _sounds_count = 0;
  17. var _current_sound_index = 0;
  18. var _finish_callback = finish_callback;
  19. this.play = function()
  20. {
  21. createPlayer(
  22. event_ready,
  23. event_play,
  24. event_finish
  25. );
  26. }
  27. var createPlayer = function(callback_ready, callback_play, callback_finish)
  28. {
  29. _iframe_id = 'soundcloud_player_'+new Date().getTime();
  30. if (!_autoplay)
  31. {
  32. _object_for_player.html('<iframe id="'+_iframe_id+'" src="https://w.soundcloud.com/player/?url='
  33. +_ref_id+'&show_artwork=false&auto_play=true" width="100%" '
  34. +'height="350" scrolling="no" frameborder="no"></iframe>');
  35. }
  36. else
  37. {
  38. $('#autoplay_player_soundcloud').append('<iframe id="'+_iframe_id+'" src="https://w.soundcloud.com/player/?url='
  39. +_ref_id+'&show_artwork=false&auto_play=true" width="100%" '
  40. +'height="350" scrolling="no" frameborder="no"></iframe>');
  41. }
  42. SC.initialize({
  43. client_id: '39946ea18e3d78d64c0ac95a025794e1'
  44. });
  45. SC.get(_ref_id, function(track, error)
  46. {
  47. if (!error)
  48. {
  49. _player = SC.Widget(document.getElementById(_iframe_id));
  50. _player.bind(SC.Widget.Events.READY, callback_ready);
  51. _player.bind(SC.Widget.Events.PLAY, callback_play);
  52. _player.bind(SC.Widget.Events.FINISH, callback_finish);
  53. }
  54. else
  55. {
  56. _finish_callback();
  57. }
  58. });
  59. }
  60. var event_ready = function()
  61. {
  62. _player.getSounds(function(value){
  63. _sounds_count = value.length;
  64. });
  65. }
  66. var event_play = function()
  67. {
  68. _player.getSounds(function(value){
  69. _sounds_count = value.length;
  70. });
  71. _player.getCurrentSoundIndex(function(value){
  72. _current_sound_index = value;
  73. });
  74. }
  75. var event_finish = function()
  76. {
  77. if (_sounds_count == _current_sound_index+1)
  78. {
  79. event_finish_playlist();
  80. }
  81. }
  82. var event_finish_playlist = function()
  83. {
  84. _finish_callback();
  85. }
  86. this.stop = function()
  87. {
  88. }
  89. this.destroy = function(force)
  90. {
  91. if (_player && !_autoplay)
  92. {
  93. _object_for_player.html('');
  94. }
  95. if (_autoplay || force)
  96. {
  97. $('#autoplay_player_soundcloud').html('');
  98. }
  99. }
  100. this.stopAndDestroy = function()
  101. {
  102. //this.stop();
  103. this.destroy(false);
  104. }
  105. this.close = function()
  106. {
  107. this.destroy(true);
  108. }
  109. }