"+results[i]+"";
- }
-}
-
-function initAjax(boxname, areaname) {
- var box = byId(boxname);
- if(!box) return;
-
- addEvent(
- box,
- "keyup",
- function f() {
- starter = endWord(box.value);
-
- if(resultCache[starter]) {
- fillCompletionZone(boxname, areaname, resultCache[starter]);
- }
- else {
- ajaxRequest(
- "ajax.php?start="+starter,
- function g(text) {
- resultCache[starter] = text.split("\n");
- fillCompletionZone(boxname, areaname, resultCache[starter]);
- }
- );
- }
- },
- false
- );
-}
-
-
-//completion_cache = new array();
-
-input = byId("search_input");
-output = byId("search_completions");
-
-function get_cached_completions(start) {
-// if(completion_cache[start]) {
-// return completion_cache[start];
-// }
-// else {
- return null;
-// }
-}
-function get_completions(start) {
- cached = get_cached_completions(start);
- if(cached) {
- output.innerHTML = cached;
- }
- else {
- ajaxRequest(autocomplete_url+"/"+start, function(data) {set_completions(start, data);});
- }
-}
-function set_completions(start, data) {
-// completion_cache[start] = data;
- output.innerHTML = data;
-}
-
-if(input) {
- input.onkeyup = function() {
- if(input.value.length < 3) {
- output.innerHTML = "";
- }
- else {
- get_completions(input.value);
- }
- };
-}
diff --git a/contrib/handle_flash/main.php b/contrib/handle_flash/main.php
deleted file mode 100644
index 867ddf8e..00000000
--- a/contrib/handle_flash/main.php
+++ /dev/null
@@ -1,67 +0,0 @@
-
- * Description: Handle Flash files
- */
-
-class FlashFileHandler extends Extension {
- var $theme;
-
- public function receive_event($event) {
- if(is_null($this->theme)) $this->theme = get_theme_object("handle_flash", "FlashFileHandlerTheme");
-
- if(is_a($event, 'DataUploadEvent') && $event->type == "swf" && $this->check_contents($event->tmpname)) {
- $hash = $event->hash;
- $ha = substr($hash, 0, 2);
- if(!copy($event->tmpname, "images/$ha/$hash")) {
- $event->veto("Flash Handler failed to move file from uploads to archive");
- return;
- }
- send_event(new ThumbnailGenerationEvent($event->hash, $event->type));
- $image = $this->create_image_from_data("images/$ha/$hash", $event->metadata);
- if(is_null($image)) {
- $event->veto("Flash Handler failed to create image object from data");
- return;
- }
- send_event(new ImageAdditionEvent($event->user, $image));
- }
-
- if(is_a($event, 'ThumbnailGenerationEvent') && $event->type == "swf") {
- $hash = $event->hash;
- $ha = substr($hash, 0, 2);
- // FIXME: scale image, as not all boards use 192x192
- copy("ext/handle_flash/thumb.jpg", "thumbs/$ha/$hash");
- }
-
- if(is_a($event, 'DisplayingImageEvent') && $event->image->ext == "swf") {
- $this->theme->display_image($event->page, $event->image);
- }
- }
-
- private function create_image_from_data($filename, $metadata) {
- global $config;
-
- $image = new Image();
-
- // FIXME: need more flash format specs :|
- $image->width = 0;
- $image->height = 0;
-
- $image->filesize = $metadata['size'];
- $image->hash = $metadata['hash'];
- $image->filename = $metadata['filename'];
- $image->ext = $metadata['extension'];
- $image->tag_array = tag_explode($metadata['tags']);
- $image->source = $metadata['source'];
-
- return $image;
- }
-
- private function check_contents($file) {
- // FIXME: flash magic header?
- return (file_exists($file));
- }
-}
-add_event_listener(new FlashFileHandler());
-?>
diff --git a/contrib/handle_flash/theme.php b/contrib/handle_flash/theme.php
deleted file mode 100644
index 62c238cd..00000000
--- a/contrib/handle_flash/theme.php
+++ /dev/null
@@ -1,19 +0,0 @@
-get_image_link();
- // FIXME: object and embed have "height" and "width"
- $html = "
- ";
- $page->add_block(new Block("Image", $html, "main", 0));
- }
-}
-?>
diff --git a/contrib/handle_flash/thumb.jpg b/contrib/handle_flash/thumb.jpg
deleted file mode 100644
index 3debb306..00000000
Binary files a/contrib/handle_flash/thumb.jpg and /dev/null differ
diff --git a/contrib/handle_mp3/main.php b/contrib/handle_mp3/main.php
deleted file mode 100644
index 7e8924a5..00000000
--- a/contrib/handle_mp3/main.php
+++ /dev/null
@@ -1,67 +0,0 @@
-
- * Description: Handle MP3 files
- */
-
-class MP3FileHandler extends Extension {
- var $theme;
-
- public function receive_event($event) {
- if(is_null($this->theme)) $this->theme = get_theme_object("handle_mp3", "MP3FileHandlerTheme");
-
- if(is_a($event, 'DataUploadEvent') && $event->type == "mp3" && $this->check_contents($event->tmpname)) {
- $hash = $event->hash;
- $ha = substr($hash, 0, 2);
- if(!copy($event->tmpname, "images/$ha/$hash")) {
- $event->veto("MP3 Handler failed to move file from uploads to archive");
- return;
- }
- send_event(new ThumbnailGenerationEvent($event->hash, $event->type));
- $image = $this->create_image_from_data("images/$ha/$hash", $event->metadata);
- if(is_null($image)) {
- $event->veto("MP3 Handler failed to create image object from data");
- return;
- }
- send_event(new ImageAdditionEvent($event->user, $image));
- }
-
- if(is_a($event, 'ThumbnailGenerationEvent') && $event->type == "mp3") {
- $hash = $event->hash;
- $ha = substr($hash, 0, 2);
- // FIXME: scale image, as not all boards use 192x192
- copy("ext/handle_mp3/thumb.jpg", "thumbs/$ha/$hash");
- }
-
- if(is_a($event, 'DisplayingImageEvent') && $event->image->ext == "mp3") {
- $this->theme->display_image($event->page, $event->image);
- }
- }
-
- private function create_image_from_data($filename, $metadata) {
- global $config;
-
- $image = new Image();
-
- // FIXME: need more flash format specs :|
- $image->width = 0;
- $image->height = 0;
-
- $image->filesize = $metadata['size'];
- $image->hash = $metadata['hash'];
- $image->filename = $metadata['filename'];
- $image->ext = $metadata['extension'];
- $image->tag_array = tag_explode($metadata['tags']);
- $image->source = $metadata['source'];
-
- return $image;
- }
-
- private function check_contents($file) {
- // FIXME: mp3 magic header?
- return (file_exists($file));
- }
-}
-add_event_listener(new MP3FileHandler());
-?>
diff --git a/contrib/handle_mp3/theme.php b/contrib/handle_mp3/theme.php
deleted file mode 100644
index 524c38e0..00000000
--- a/contrib/handle_mp3/theme.php
+++ /dev/null
@@ -1,22 +0,0 @@
-get_image_link();
- $html = "
-
- Download";
- $page->add_block(new Block("Music", $html, "main", 0));
- }
-}
-?>
diff --git a/contrib/handle_mp3/thumb.jpg b/contrib/handle_mp3/thumb.jpg
deleted file mode 100644
index f4e9d64f..00000000
Binary files a/contrib/handle_mp3/thumb.jpg and /dev/null differ
diff --git a/contrib/handle_mp3/xspf_player.as b/contrib/handle_mp3/xspf_player.as
deleted file mode 100644
index 0cd58e1a..00000000
--- a/contrib/handle_mp3/xspf_player.as
+++ /dev/null
@@ -1,448 +0,0 @@
-/*
-Copyright (c) 2005, Fabricio Zuardi
-All rights reserved.
-
-Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
-
- * Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
- * Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
- * Neither the name of the author nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.
-
-THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-*/
-stop();
-//autoplay=true
-//repeat_playlist = true;
-//playlist_size = 3;
-//player_title = "customizeable title test"
-//song_url = "http://downloads.betterpropaganda.com/music/Imperial_Teen-Ivanka_128.mp3";
-//playlist_url = "http://cchits.ning.com/recent/xspf/?xn_auth=no";
-//playlist_url = "http://hideout.com.br/shows/radio-test.xspf";
-//radio_mode = true;
-//song_title = "Imperial Teen - Ivanka";
-autoload=true;
-//info_button_text = "Add to Cart"
-//playlist_url = "http%3A%2F%2Fwebjay%2Eorg%2Fby%2Flucas%5Fgonze%2Flaconic%2Exspf"
-//playlist_url= "http://hideout.com.br/tests/hideout2325.xspf"
-//constants
-DEFAULT_PLAYLIST_URL = "http://hideout.com.br/shows/allshows.xspf";
-DEFAULT_WELCOME_MSG = "Hideout XSPF Music Player - by Fabricio Zuardi";
-LOADING_PLAYLIST_MSG = "Loading Playlist...";
-DEFAULT_LOADED_PLAYLIST_MSG = "- click to start"
-DEFAULT_INFOBUTTON_TXT = "Info"
-//playlists has priority over songs, if a playlist_url parameter is found the song_url is ignored
-//default playlist if none is passed through query string
-if(!playlist_url){
- if(!song_url){
- playlist_url = DEFAULT_PLAYLIST_URL;
- }else{
- single_music_playlist = "";
- single_music_playlist += ""
- single_music_playlist += ""
- }
-}
-info_mc._visible=false;
-if(!info_button_text){
- info_button_text = DEFAULT_INFOBUTTON_TXT;
-}
-info_mc.display_txt.text = info_button_text;
-
-//variables initialization
-playlist_array = [];
-track_index = 0;
-playlist_mc.track_count = 0;
-pause_position = 0;
-volume_level = 100;
-playlist_xml = new XML();
-playlist_xml.ignoreWhite = true;
-playlist_xml.onLoad = playlistLoaded;
-mysound = new Sound(this);
-playlist_listener = new Object();
-playlist_list.addEventListener("change", playlist_listener)
-//play_btn.onPress = playTrack;
-//functions
-//xml parser
-function playlistLoaded (success){
- if(success){
- var root_node = this.firstChild;
- for(var node = root_node.firstChild; node != null; node = node.nextSibling){
- if(node.nodeName == "title"){
- playlist_title = node.firstChild.nodeValue;
- }
- if(node.nodeName == "trackList"){
- //tracks
- var tracks_array = [];
- for(var track_node = node.firstChild; track_node != null; track_node = track_node.nextSibling){
- var track_obj = new Object()
- //track attributes
- for(var track_child = track_node.firstChild; track_child != null; track_child = track_child.nextSibling){
- if(track_child.nodeName=="location"){
- track_obj.location = track_child.firstChild.nodeValue
- }
- if(track_child.nodeName=="image"){
- track_obj.image = track_child.firstChild.nodeValue
- }
- if(track_child.nodeName=="title"){
- track_obj.title = track_child.firstChild.nodeValue
- }
- if(track_child.nodeName=="creator"){
- track_obj.creator = track_child.firstChild.nodeValue
- }
- if(track_child.nodeName=="annotation"){
- track_obj.annotation = track_child.firstChild.nodeValue
- }
- if(track_child.nodeName=="info"){
- track_obj.info = track_child.firstChild.nodeValue
- }
- }
- track_obj.label = (tracks_array.length+1) +". ";
- if(track_obj.title) {
- if(track_obj.creator) {
- track_obj.label += track_obj.creator+' - ';
- }
- track_obj.label += track_obj.title;
- } else {
- track_obj.label += track_obj.annotation;
- }
- tracks_array.push(track_obj)
- addTrack(track_obj.label);
- }
- }
- }
- playlist_array = tracks_array;
- if(!playlist_size) playlist_size = playlist_array.length;
- playlist_mc.tracks_mc["track_"+track_index+"_mc"].bg_mc.gotoAndStop(2)
- if(autoplay){
- loadTrack()
- }else{
- start_btn_mc.start_btn.onPress = loadTrack;
- track_display_mc.display_txt.text = playlist_title+" "+DEFAULT_LOADED_PLAYLIST_MSG;
- if(track_display_mc.display_txt._width>track_display_mc.mask_mc._width){
- track_display_mc.onEnterFrame = scrollTitle;
- }else{
- track_display_mc.onEnterFrame = null;
- track_display_mc.display_txt._x = 0;
- }
- }
- }else{
- annotation_txt.text = "Error opening "+playlist_url;
- }
-}
-
-playlist_listener.change = function(eventObject){
- annotation_txt.text = playlist_list.selectedItem.annotation;
- location_txt.text = playlist_list.selectedItem.location;
-}
-
-function loadTrack(){
-
- //Radio Mode feature by nosferathoo, more info in: https://sourceforge.net/tracker/index.php?func=detail&aid=1341940&group_id=128363&atid=711474
- if (radio_mode && track_index==playlist_size-1) {
- playlist_url=playlist_array[track_index].location;
- for (i=0;itrack_display_mc.mask_mc._width){
- track_display_mc.onEnterFrame = scrollTitle;
- }else{
- track_display_mc.onEnterFrame = null;
- track_display_mc.display_txt._x = 0;
- }
- cover_mc.content_mc["photo"+last_track_index].removeMovieClip();
- mysound.loadSound(playlist_array[track_index].location,true);
- play_mc.gotoAndStop(2)
-
- //image from playlist
- if(playlist_array[track_index].image!=undefined){
- cover_mc.content_mc.createEmptyMovieClip("photo"+track_index,track_index)
- cover_mc.content_mc["photo"+track_index].loadMovie(playlist_array[track_index].image)
- }else{
- }
- //info button
- if(playlist_array[track_index].info!=undefined){
- info_mc._visible = true;
- info_mc.info_btn.onPress = function(){
- getURL(playlist_array[track_index].info,"_blank")
- }
- }else{
- info_mc._visible = false;
- }
- _root.onEnterFrame=function(){
- //HACK doesnt need to set the volume at every enterframe
- mysound.setVolume(this.volume_level)
- var sound_load_percent = (mysound.getBytesLoaded()/mysound.getBytesTotal())*100
- track_display_mc.loader_mc.load_bar_mc._xscale = sound_load_percent;
- var image_load_percent = (cover_mc.content_mc["photo"+track_index].getBytesLoaded()/cover_mc.content_mc["photo"+track_index].getBytesTotal())*100
- cover_mc.load_bar_mc._xscale = image_load_percent;
- if((cover_mc.content_mc["photo"+track_index].getBytesLoaded()>4)&&(image_load_percent==100)){
- //image loaded
- //make image fit
- cover_mc.content_mc["photo"+track_index]._width = cover_mc.load_bar_mc._width
- cover_mc.content_mc["photo"+track_index]._height = cover_mc.load_bar_mc._height
- }
- }
-}
-
-stop_btn.onRelease = stopTrack;
-play_mc.play_btn.onRelease = playTrack
-next_btn.onRelease = nextTrack
-prev_btn.onRelease = prevTrack
-mysound.onSoundComplete = nextTrack;
-volume_mc.volume_btn.onPress = volumeChange;
-volume_mc.volume_btn.onRelease = volume_mc.volume_btn.onReleaseOutside = function(){
- this._parent.onMouseMove = this._parent.onMouseDown = null;
-}
-
-function volumeChange(){
- this._parent.onMouseMove = this._parent.onMouseDown = function(){
- var percent = (this._xmouse/this._width)*100
- if(percent>100)percent=100;
- if(percent<0)percent=0;
- this.volume_bar_mc._xscale = percent
- this._parent.volume_level = percent;
- mysound.setVolume(percent)
- }
-}
-
-function stopTrack() {
- mysound.stop();
- play_mc.gotoAndStop(1)
- mysound.stop();
- mysound.start();
- mysound.stop();
- _root.pause_position = 0;
-
-};
-function playTrack() {
- if(play_mc._currentframe==1){ //play
- seekTrack(_root.pause_position)
- play_mc.gotoAndStop(2)
- }else if(play_mc._currentframe==2){
- _root.pause_position = mysound.position;
- mysound.stop();
- play_mc.gotoAndStop(1)
- }
-
-};
-function seekTrack(p_offset:Number){
- mysound.stop()
- mysound.start(int((p_offset)/1000),1)
-}
-function nextTrack(){
- if(track_index0){
- last_track_index = track_index;
- track_index --;
- loadTrack();
- }
- playlist_mc.tracks_mc["track_"+last_track_index+"_mc"].bg_mc.gotoAndStop(1)
- playlist_mc.tracks_mc["track_"+track_index+"_mc"].bg_mc.gotoAndStop(2)
-}
-
-function scrollTitle(){
- track_display_mc.display_txt._x -= 5;
- if (track_display_mc.display_txt._x+track_display_mc.display_txt._width<0){
- track_display_mc.display_txt._x = track_display_mc.mask_mc._width;
- }
-}
-
-function resizeUI(){
- bg_mc._width = Stage.width;
- track_display_mc.loader_mc._width = Stage.width - track_display_mc._x - 2;
- track_display_mc.mask_mc._width = track_display_mc.loader_mc._width-3;
- if(track_display_mc.display_txt._width>track_display_mc.mask_mc._width){
- track_display_mc.onEnterFrame = scrollTitle;
- }else{
- track_display_mc.onEnterFrame = null;
- track_display_mc.display_txt._x = 0;
- }
- volume_mc._x = Stage.width - 22;
- start_btn_mc._xscale = Stage.width;
- //playlist area tinnier that the album cover
- if(Stage.width<2.5*cover_mc._width){
- //
- if (Stage.height>2.5*cover_mc._height){
- //send album cover to bottom
- cover_mc._y = Stage.height - cover_mc._height -2- info_mc._height -2;
- info_mc._y = Stage.height - info_mc._height -2;
- var covervisible =1;
- }else{
- var covervisible =0;
- //hide album cover
- cover_mc._y = Stage.height;
- }
- //send playlist to left
- playlist_mc._x = cover_mc._x;
- scrollbar_mc.bg_mc._height = Stage.height - (19+(cover_mc._height+info_mc._height+4)*covervisible);
- playlist_mc.bg_mc._height = Stage.height - (19+(cover_mc._height+info_mc._height+4)*covervisible);
- playlist_mc.mask_mc._height = Stage.height - (23+(cover_mc._height+info_mc._height+4)*covervisible);
- }else{
- cover_mc._y = 17;
- info_mc._y = 153;
- playlist_mc._x = 138;
- scrollbar_mc.bg_mc._height = Stage.height -19;
- playlist_mc.bg_mc._height = Stage.height - 19;
- playlist_mc.mask_mc._height = Stage.height - 23;
- }
- scrollbar_mc._x = Stage.width - 12;
- playlist_mc.mask_mc._width = Stage.width - (playlist_mc._x + 19);
- playlist_mc.bg_mc._width = Stage.width - (playlist_mc._x + 14);
-}
-function addTrack(track_label){
- if(playlist_mc.track_count>0) {
- playlist_mc.tracks_mc.track_0_mc.duplicateMovieClip("track_"+playlist_mc.track_count+"_mc",playlist_mc.track_count);
- }
- playlist_mc.tracks_mc["track_"+playlist_mc.track_count+"_mc"]._y += playlist_mc.track_count*14;
- playlist_mc.tracks_mc["track_"+playlist_mc.track_count+"_mc"].display_txt.autoSize = "left";
- playlist_mc.tracks_mc["track_"+playlist_mc.track_count+"_mc"].display_txt.text = track_label;
- playlist_mc.tracks_mc["track_"+playlist_mc.track_count+"_mc"].bg_mc.index = playlist_mc.track_count;
- playlist_mc.tracks_mc["track_"+playlist_mc.track_count+"_mc"].bg_mc.select_btn.onPress = function(){
- last_track_index = track_index;
- playlist_mc.tracks_mc["track_"+track_index+"_mc"].bg_mc.gotoAndStop(1)
- track_index = this._parent.index;
- playlist_mc.tracks_mc["track_"+track_index+"_mc"].bg_mc.gotoAndStop(2)
- loadTrack();
- }
- playlist_mc.track_count ++;
-}
-//scroll
-
-scrollbar_mc.up_btn.onPress = function(){
- this._parent.v = -1;
- this._parent.onEnterFrame = scrollTracks;
-}
-scrollbar_mc.down_btn.onPress = function(){
- this._parent.v = 1;
- this._parent.onEnterFrame = scrollTracks;
-}
-scrollbar_mc.up_btn.onRelease = scrollbar_mc.down_btn.onRelease = function(){
- this._parent.onEnterFrame = null;
-}
-scrollbar_mc.handler_mc.drag_btn.onPress = function(){
- var scroll_top_limit = 19;
- var scroll_bottom_limit = scrollbar_mc.bg_mc._height - scrollbar_mc.handler_mc._height - 2;
- this._parent.startDrag(false,this._parent._x,scroll_top_limit,this._parent._x,scroll_bottom_limit)
- this._parent.isdragging = true;
- this._parent.onEnterFrame = scrollTracks;
-}
-scrollbar_mc.handler_mc.drag_btn.onRelease = scrollbar_mc.handler_mc.drag_btn.onReleaseOutside = function(){
- stopDrag()
- this._parent.isdragging = false;
- this._parent.onEnterFrame = null;
-}
-function scrollTracks(){
- var scroll_top_limit = 19;
- var scroll_bottom_limit = scrollbar_mc.bg_mc._height - scrollbar_mc.handler_mc._height - 2;
- var list_bottom_limit = 1;
- var list_top_limit = (1-Math.round(playlist_mc.tracks_mc._height))+Math.floor(playlist_mc.mask_mc._height/14)*14
- if(playlist_mc.tracks_mc._height>playlist_mc.mask_mc._height){
- if(scrollbar_mc.handler_mc.isdragging){
- var percent = (scrollbar_mc.handler_mc._y-scroll_top_limit)/(scroll_bottom_limit-scroll_top_limit)
- playlist_mc.tracks_mc._y = (list_top_limit-list_bottom_limit)*percent+list_bottom_limit;
- }else{
- if(scrollbar_mc.v==-1){
- if(playlist_mc.tracks_mc._y+14list_top_limit){
- playlist_mc.tracks_mc._y -= 14;
- }else{
- playlist_mc.tracks_mc._y = list_top_limit;
- }
- var percent = (playlist_mc.tracks_mc._y-1)/(list_top_limit-1)
- scrollbar_mc.handler_mc._y = percent*(scroll_bottom_limit - scroll_top_limit)+scroll_top_limit;
- }
- }
- }
-}
-function loadPlaylist(){
- track_display_mc.display_txt.text = LOADING_PLAYLIST_MSG;
- if(track_display_mc.display_txt._width>track_display_mc.mask_mc._width){
- track_display_mc.onEnterFrame = scrollTitle;
- }else{
- track_display_mc.onEnterFrame = null;
- track_display_mc.display_txt._x = 0;
- }
-
- //playlist
- if(playlist_url){
- playlist_xml.load(unescape(playlist_url))
- }else{
- //single track
- playlist_xml.parseXML(single_music_playlist)
- playlist_xml.onLoad(true);
- }
-}
-
-//first click - load playlist
-start_btn_mc.start_btn.onPress = function(){
- autoplay = true;
- loadPlaylist();
-}
-
-
-//main
-Stage.scaleMode = "noScale"
-Stage.align = "LT";
-this.onResize = resizeUI;
-Stage.addListener(this);
-if(!player_title) player_title = DEFAULT_WELCOME_MSG;
-track_display_mc.display_txt.autoSize = "left";
-track_display_mc.display_txt.text = player_title;
-if(track_display_mc.display_txt._width>track_display_mc.mask_mc._width){
- track_display_mc.onEnterFrame = scrollTitle;
-}else{
- track_display_mc.onEnterFrame = null;
- track_display_mc.display_txt._x = 0;
-}
-//start to play automatically if parameter autoplay is present
-if(autoplay){
- start_btn_mc.start_btn.onPress();
-} else if (autoload){
- loadPlaylist()
-}
-//customized menu
-var my_cm:ContextMenu = new ContextMenu();
-my_cm.customItems.push(new ContextMenuItem("Stop", stopTrack));
-my_cm.customItems.push(new ContextMenuItem("Play!", playTrack));
-my_cm.customItems.push(new ContextMenuItem("Next", nextTrack));
-my_cm.customItems.push(new ContextMenuItem("Previous", prevTrack));
-my_cm.customItems.push(new ContextMenuItem("Download this song", function(){getURL(playlist_array[track_index].location,"_blank")},true));
-my_cm.customItems.push(new ContextMenuItem("Add song to Webjay playlist", function(){getURL("http://webjay.org/poster?media="+escape(playlist_array[track_index].location),"_blank")}));
-my_cm.customItems.push(new ContextMenuItem("About Hideout", function(){getURL("http://www.hideout.com.br","_blank")},true));
-//my_cm.customItems.push(new ContextMenuItem("Crossfade", function(){}));
-//my_cm.customItems.push(new ContextMenuItem("Mando Diao - Paralyzed", function(){}));
-my_cm.hideBuiltInItems();
-this.menu = my_cm;
-resizeUI();
\ No newline at end of file
diff --git a/contrib/handle_mp3/xspf_player.fla.bz2 b/contrib/handle_mp3/xspf_player.fla.bz2
deleted file mode 100644
index 9b5fa834..00000000
Binary files a/contrib/handle_mp3/xspf_player.fla.bz2 and /dev/null differ
diff --git a/contrib/handle_mp3/xspf_player.swf b/contrib/handle_mp3/xspf_player.swf
deleted file mode 100644
index f03790a4..00000000
Binary files a/contrib/handle_mp3/xspf_player.swf and /dev/null differ
diff --git a/contrib/handle_mp3/xspf_player_license.txt b/contrib/handle_mp3/xspf_player_license.txt
deleted file mode 100644
index 12d609e1..00000000
--- a/contrib/handle_mp3/xspf_player_license.txt
+++ /dev/null
@@ -1,10 +0,0 @@
-Copyright (c) 2005, Fabricio Zuardi
-All rights reserved.
-
-Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
-
- * Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
- * Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
- * Neither the name of the author nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.
-
-THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
diff --git a/contrib/handle_svg/main.php b/contrib/handle_svg/main.php
deleted file mode 100644
index c117199a..00000000
--- a/contrib/handle_svg/main.php
+++ /dev/null
@@ -1,92 +0,0 @@
-
- * Description: Handle SVG files
- */
-
-class SVGFileHandler extends Extension {
- var $theme;
-
- public function receive_event($event) {
- if(is_null($this->theme)) $this->theme = get_theme_object("handle_svg", "SVGFileHandlerTheme");
-
- if(is_a($event, 'DataUploadEvent') && $event->type == "svg" && $this->check_contents($event->tmpname)) {
- $hash = $event->hash;
- $ha = substr($hash, 0, 2);
- if(!copy($event->tmpname, "images/$ha/$hash")) {
- $event->veto("SVG Handler failed to move file from uploads to archive");
- return;
- }
- send_event(new ThumbnailGenerationEvent($event->hash, $event->type));
- $image = $this->create_image_from_data("images/$ha/$hash", $event->metadata);
- if(is_null($image)) {
- $event->veto("SVG Handler failed to create image object from data");
- return;
- }
- send_event(new ImageAdditionEvent($event->user, $image));
- }
-
- if(is_a($event, 'ThumbnailGenerationEvent') && $event->type == "svg") {
- $hash = $event->hash;
- $ha = substr($hash, 0, 2);
-
- global $config;
-
-// if($config->get_string("thumb_engine") == "convert") {
-// $w = $config->get_int("thumb_width");
-// $h = $config->get_int("thumb_height");
-// $q = $config->get_int("thumb_quality");
-// $mem = $config->get_int("thumb_max_memory") / 1024 / 1024; // IM takes memory in MB
-//
-// exec("convert images/{$ha}/{$hash}[0] -geometry {$w}x{$h} -quality {$q} jpg:thumbs/{$ha}/{$hash}");
-// }
-// else {
- // FIXME: scale image, as not all boards use 192x192
- copy("ext/handle_svg/thumb.jpg", "thumbs/$ha/$hash");
-// }
- }
-
- if(is_a($event, 'DisplayingImageEvent') && $event->image->ext == "svg") {
- $this->theme->display_image($event->page, $event->image);
- }
-
- if(is_a($event, 'PageRequestEvent') && ($event->page_name == "get_svg")) {
- global $database;
- $id = int_escape($event->get_arg(0));
- $image = $database->get_image($id);
- $hash = $image->hash;
- $ha = substr($hash, 0, 2);
-
- $event->page->set_type("image/svg+xml");
- $event->page->set_mode("data");
- $event->page->set_data(file_get_contents("images/$ha/$hash"));
- }
- }
-
- private function create_image_from_data($filename, $metadata) {
- global $config;
-
- $image = new Image();
-
- // FIXME: ugh, xml parsing :|
- $image->width = 0;
- $image->height = 0;
-
- $image->filesize = $metadata['size'];
- $image->hash = $metadata['hash'];
- $image->filename = $metadata['filename'];
- $image->ext = $metadata['extension'];
- $image->tag_array = tag_explode($metadata['tags']);
- $image->source = $metadata['source'];
-
- return $image;
- }
-
- private function check_contents($file) {
- // FIXME: magic header?
- return (file_exists($file));
- }
-}
-add_event_listener(new SVGFileHandler());
-?>
diff --git a/contrib/handle_svg/theme.php b/contrib/handle_svg/theme.php
deleted file mode 100644
index 89e0d212..00000000
--- a/contrib/handle_svg/theme.php
+++ /dev/null
@@ -1,16 +0,0 @@
-id}/{$image->id}.svg");
- $ilink = $image->get_image_link();
- // FIXME: object and embed have "height" and "width"
- $html = "
-
- ";
- $page->add_block(new Block("Image", $html, "main", 0));
- }
-}
-?>
diff --git a/contrib/handle_svg/thumb.jpg b/contrib/handle_svg/thumb.jpg
deleted file mode 100644
index d89117b5..00000000
Binary files a/contrib/handle_svg/thumb.jpg and /dev/null differ
diff --git a/contrib/notes/main.php b/contrib/notes/main.php
deleted file mode 100644
index 0f30c126..00000000
--- a/contrib/notes/main.php
+++ /dev/null
@@ -1,52 +0,0 @@
-
- * Link: http://trac.shishnet.org/shimmie2/
- * License: GPLv2
- * Description: Adds notes overlaid on the images
- */
-
-class Notes extends Extension {
- var $theme;
-
- public function receive_event($event) {
- if(is_null($this->theme)) $this->theme = get_theme_object("notes", "NotesTheme");
-
- if(is_a($event, 'InitExtEvent')) {
- global $config;
- if($config->get_int("ext_notes_version") < 1) {
- $this->install();
- }
- }
-
- if(is_a($event, 'DisplayingImageEvent')) {
- global $database;
- $notes = $database->get_all("SELECT * FROM image_notes WHERE image_id = ?", array($event->image->id));
- $this->theme->display_notes($event->page, $notes);
- }
- }
-
- protected function install() {
- global $database;
- global $config;
- $database->Execute("CREATE TABLE image_notes (
- id int(11) NOT NULL auto_increment PRIMARY KEY,
- image_id int(11) NOT NULL,
- user_id int(11) NOT NULL,
- owner_ip char(15) NOT NULL,
- created_at datetime NOT NULL,
- updated_at datetime NOT NULL,
- version int(11) DEFAULT 1 NOT NULL,
- is_active enum('Y', 'N') DEFAULT 'Y' NOT NULL,
- x int(11) NOT NULL,
- y int(11) NOT NULL,
- w int(11) NOT NULL,
- h int(11) NOT NULL,
- body text NOT NULL
- )");
- $config->set_int("ext_notes_version", 1);
- }
-}
-add_event_listener(new Notes());
-?>
diff --git a/contrib/notes/theme.php b/contrib/notes/theme.php
deleted file mode 100644
index df4f140d..00000000
--- a/contrib/notes/theme.php
+++ /dev/null
@@ -1,13 +0,0 @@
-
-img = byId("main_image");
-
-EOD;
- $page->add_block(new Block(null, $html));
- }
-}
-?>
diff --git a/contrib/rating/main.php b/contrib/rating/main.php
deleted file mode 100644
index b32612c7..00000000
--- a/contrib/rating/main.php
+++ /dev/null
@@ -1,106 +0,0 @@
-
- * Link: http://trac.shishnet.org/shimmie2/
- * License: GPLv2
- * Description: Allow users to rate images
- */
-
-class RatingSetEvent extends Event {
- var $image_id, $user, $rating;
-
- public function RatingSetEvent($image_id, $user, $rating) {
- $this->image_id = $image_id;
- $this->user = $user;
- $this->rating = $rating;
- }
-}
-
-class Ratings extends Extension {
- var $theme;
-
- public function receive_event($event) {
- if(is_null($this->theme)) $this->theme = get_theme_object("rating", "RatingsTheme");
-
- if(is_a($event, 'InitExtEvent')) {
- global $config;
- if($config->get_int("ext_ratings2_version") < 2) {
- $this->install();
- }
-
- global $config;
- $config->set_default_string("ext_rating_anon_privs", 'sq');
- $config->set_default_string("ext_rating_user_privs", 'sq');
- }
-
- if(is_a($event, 'RatingSetEvent')) {
- $this->set_rating($event->image_id, $event->rating);
- }
-
- if(is_a($event, 'ImageInfoBoxBuildingEvent')) {
- global $user;
- if($user->is_admin()) {
- $event->add_part($this->theme->get_rater_html($event->image->id, $event->image->rating), 80);
- }
- }
-
- if(is_a($event, 'ImageInfoSetEvent')) {
- global $user;
- if($user->is_admin()) {
- send_event(new RatingSetEvent($event->image_id, $user, $_POST['rating']));
- }
- }
-
- if(is_a($event, 'SetupBuildingEvent')) {
- $privs = array();
- $privs['Safe Only'] = 's';
- $privs['Safe and Questionable'] = 'sq';
- $privs['All'] = 'sqe';
-
- $sb = new SetupBlock("Image Ratings");
- $sb->add_choice_option("ext_rating_anon_privs", $privs, "Anonymous: ");
- $sb->add_choice_option("ext_rating_user_privs", $privs, "
Logged in: ");
- $event->panel->add_block($sb);
- }
-
- if(is_a($event, 'ParseLinkTemplateEvent')) {
- $event->replace('$rating', $this->theme->rating_to_name($event->image->rating));
- }
-
- if(is_a($event, 'SearchTermParseEvent')) {
- $matches = array();
- if(preg_match("/rating=([sqe]+)/", $event->term, $matches)) {
- $sqes = $matches[1];
- $arr = array();
- for($i=0; $iset_querylet(new Querylet("AND (rating IN ($set))"));
- }
- }
- }
-
- private function install() {
- global $database;
- global $config;
-
- if($config->get_int("ext_ratings2_version") < 1) {
- $database->Execute("ALTER TABLE images ADD COLUMN rating ENUM('s', 'q', 'e') NOT NULL DEFAULT 'q'");
- $config->set_int("ext_ratings2_version", 1);
- }
-
- if($config->get_int("ext_ratings2_version") < 2) {
- $database->Execute("CREATE INDEX images__rating ON images(rating)");
- $config->set_int("ext_ratings2_version", 2);
- }
- }
-
- private function set_rating($image_id, $rating) {
- global $database;
- $database->Execute("UPDATE images SET rating=? WHERE id=?", array($rating, $image_id));
- }
-}
-add_event_listener(new Ratings());
-?>
diff --git a/contrib/rating/theme.php b/contrib/rating/theme.php
deleted file mode 100644
index 24a460fa..00000000
--- a/contrib/rating/theme.php
+++ /dev/null
@@ -1,28 +0,0 @@
-
-
-
-
- ";
- return $html;
- }
-
- public function rating_to_name($rating) {
- switch($rating) {
- case 's': return "Safe";
- case 'q': return "Questionable";
- case 'e': return "Explicit";
- default: return "Unknown";
- }
- }
-}
-
-?>
diff --git a/contrib/svn_update/main.php b/contrib/svn_update/main.php
deleted file mode 100644
index d4bb7f52..00000000
--- a/contrib/svn_update/main.php
+++ /dev/null
@@ -1,79 +0,0 @@
-
- * Link: http://trac.shishnet.org/shimmie2/
- * License: GPLv2
- * Description: Provides a button to check for updates
- */
-
-class SVNUpdate extends Extension {
- var $theme;
-
- public function receive_event($event) {
- if(is_null($this->theme)) $this->theme = get_theme_object("svn_update", "SVNUpdateTheme");
-
- if(is_a($event, 'PageRequestEvent') && ($event->page_name == "update")) {
- if($event->user->is_admin()) {
- if($event->get_arg(0) == "view_changes") {
- $this->theme->display_update_todo($event->page,
- $this->get_update_log(),
- $this->get_branches());
- }
- if($event->get_arg(0) == "update") {
- $this->theme->display_update_log($event->page, $this->run_update());
- }
- if($event->get_arg(0) == "dump") {
- $this->theme->display_update_log($event->page, $this->run_dump());
- }
- //if($event->get_arg(0) == "switch") {
- // $this->theme->display_update_log($event->page, $this->run_update());
- //}
- }
- }
-
- if(is_a($event, 'AdminBuildingEvent')) {
- global $page;
- $this->theme->display_form($page);
- }
- }
-
- private function get_update_log() {
- return shell_exec("svn log -r HEAD:BASE .");
- }
- private function run_update() {
- return shell_exec("svn update");
- }
- private function run_dump() {
- global $database_dsn;
- $matches = array();
-
- // FIXME: MySQL specific
- if(preg_match("#^mysql://([^:]+):([^@]+)@([^/]+)/([^\?]+)#", $database_dsn, $matches)) {
- $date = date("Ymd");
- return
- shell_exec("mysqldump -uUSER -pPASS -hHOST DATABASE | gzip > db-$date.sql.gz") .
- "\n\nDatabase dump should now be sitting in db-$date.sql.gz in the shimmie folder";
- }
- else {
- return "Couldn't parse database connection string";
- }
- }
- private function get_branches() {
- $data = shell_exec("svn ls http://svn.shishnet.org/shimmie2/branches/");
- $list = array();
- foreach(split("\n", $data) as $line) {
- $matches = array();
- if(preg_match("/branch_(\d.\d+)/", $line, $matches)) {
- $ver = $matches[1];
- $list["branch_$ver"] = "Stable ($ver.X)";
- }
- }
- ksort($list);
- $list = array_reverse($list, true);
- $list["trunk"] = "Unstable (Trunk)";
- return $list;
- }
-}
-add_event_listener(new SVNUpdate());
-?>
diff --git a/contrib/svn_update/theme.php b/contrib/svn_update/theme.php
deleted file mode 100644
index bcae1846..00000000
--- a/contrib/svn_update/theme.php
+++ /dev/null
@@ -1,52 +0,0 @@
-Check for Updates
- ";
- $page->add_block(new Block("Update", $html));
- }
-
- public function display_update_todo($page, $log, $branches) {
- $h_log = html_escape($log);
- $updates = "
-
-
-
- ";
- $options = "";
- foreach($branches as $name => $nice) {
- $options .= "";
- }
- $branches = "
-
- ";
-
- $page->set_title("Updates Available");
- $page->set_heading("Updates Available");
- $page->add_block(new NavBlock());
- $page->add_block(new Block("Updates For Current Branch", $updates));
- $page->add_block(new Block("Available Branches", $branches));
- }
-
- public function display_update_log($page, $log) {
- $h_log = html_escape($log);
- $html = "
-
- ";
-
- $page->set_title("Update Log");
- $page->set_heading("Update Log");
- $page->add_block(new NavBlock());
- $page->add_block(new Block("Update Log", $html));
- }
-}
-?>