commit 323fc9e12021b50399243f66fc1226b99f92f384 Author: unknown Date: Fri May 23 20:17:46 2025 +0200 Initial commit: Add ShadowStream media application with file scanning and classification diff --git a/.idea/.idea.VPR_ShadowStream/.idea/.gitignore b/.idea/.idea.VPR_ShadowStream/.idea/.gitignore new file mode 100644 index 0000000..3051707 --- /dev/null +++ b/.idea/.idea.VPR_ShadowStream/.idea/.gitignore @@ -0,0 +1,13 @@ +# Default ignored files +/shelf/ +/workspace.xml +# Rider ignored files +/projectSettingsUpdater.xml +/modules.xml +/.idea.file finder test.iml +/contentModel.xml +# Editor-based HTTP Client requests +/httpRequests/ +# Datasource local storage ignored files +/dataSources/ +/dataSources.local.xml diff --git a/.idea/.idea.VPR_ShadowStream/.idea/indexLayout.xml b/.idea/.idea.VPR_ShadowStream/.idea/indexLayout.xml new file mode 100644 index 0000000..7b08163 --- /dev/null +++ b/.idea/.idea.VPR_ShadowStream/.idea/indexLayout.xml @@ -0,0 +1,8 @@ + + + + + + + + \ No newline at end of file diff --git a/.idea/.idea.VPR_ShadowStream/.idea/vcs.xml b/.idea/.idea.VPR_ShadowStream/.idea/vcs.xml new file mode 100644 index 0000000..94a25f7 --- /dev/null +++ b/.idea/.idea.VPR_ShadowStream/.idea/vcs.xml @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/.idea/.idea.file finder test/.idea/workspace.xml b/.idea/.idea.file finder test/.idea/workspace.xml new file mode 100644 index 0000000..a946f4d --- /dev/null +++ b/.idea/.idea.file finder test/.idea/workspace.xml @@ -0,0 +1,168 @@ + + + + ModuleManager/ModuleManager.csproj + Module_Manager/Module_Manager.csproj + Mudule Manager/Mudule Manager.csproj + file finder test/file finder test.csproj + + + + + + + + + + + + + + + + { + "associatedIndex": 5 +} + + + + { + "keyToString": { + ".NET Project.file finder test.executor": "Run", + "RunOnceActivity.ChatTagsLlmMigration": "true", + "RunOnceActivity.CodyAccountHistoryMigration": "true", + "RunOnceActivity.CodyAccountsIdsRefresh": "true", + "RunOnceActivity.CodyAssignOrphanedChatsToActiveAccount": "true", + "RunOnceActivity.CodyConvertUrlToCodebaseName": "true", + "RunOnceActivity.CodyHistoryLlmMigration": "true", + "RunOnceActivity.CodyMigrateChatHistory-v2": "true", + "RunOnceActivity.CodyProjectSettingsMigration": "true", + "RunOnceActivity.DeprecatedChatLlmMigration": "true", + "RunOnceActivity.ShowReadmeOnStart": "true", + "RunOnceActivity.ToggleCodyToolWindowAfterMigration": "true", + "node.js.detected.package.eslint": "true", + "node.js.detected.package.tslint": "true", + "node.js.selected.package.eslint": "(autodetect)", + "node.js.selected.package.tslint": "(autodetect)", + "nodejs_package_manager_path": "npm", + "settings.editor.selected.configurable": "com.sourcegraph.cody.config.ui.CodyConfigurable", + "vue.rearranger.settings.migration": "true" + } +} + + + + + + + + + + + + + + + 1745927066187 + + + + + + + + + + + + diff --git a/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/dialogs/browse_window.html b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/dialogs/browse_window.html new file mode 100644 index 0000000..c66ac49 --- /dev/null +++ b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/dialogs/browse_window.html @@ -0,0 +1,44 @@ + + +
"> +
+
    +
  1. +
+
+
diff --git a/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/dialogs/create_stream.html b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/dialogs/create_stream.html new file mode 100644 index 0000000..1eb077f --- /dev/null +++ b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/dialogs/create_stream.html @@ -0,0 +1,394 @@ + +
"> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+ +
+
+
+
+
+
+
+
+
+ + + + + + + +
+ + + + + + + +
+ + + +   + +
+ + + +   +
+ + + + + + + + + + + + + +
+
+
+ +   
+ + + +
" opendialog="window_browse">
+
" >
+
+ +
+ + diff --git a/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/dialogs/equalizer_window.html b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/dialogs/equalizer_window.html new file mode 100644 index 0000000..a81bb13 --- /dev/null +++ b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/dialogs/equalizer_window.html @@ -0,0 +1,54 @@ + +
"> +
+
0dB
+
+
+
+
+
diff --git a/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/dialogs/error_window.html b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/dialogs/error_window.html new file mode 100644 index 0000000..2237bab --- /dev/null +++ b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/dialogs/error_window.html @@ -0,0 +1,19 @@ + +
"> +
+
+
diff --git a/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/dialogs/mosaic_window.html b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/dialogs/mosaic_window.html new file mode 100644 index 0000000..a93c0b6 --- /dev/null +++ b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/dialogs/mosaic_window.html @@ -0,0 +1,146 @@ + + +
"> + + + + + + + + + + + + + + + + + + + + + +
+ + + + + + + +
+ + + + + + + +
+
+

+ + + + + + + + + + +

+
+
diff --git a/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/dialogs/offset_window.html b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/dialogs/offset_window.html new file mode 100644 index 0000000..05a0fb3 --- /dev/null +++ b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/dialogs/offset_window.html @@ -0,0 +1,79 @@ + +
"> +
+
">
+
1x
+
+
+
">
+
0s
+
+
+
">
+
0s
+
diff --git a/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/dialogs/stream_config_window.html b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/dialogs/stream_config_window.html new file mode 100644 index 0000000..12737aa --- /dev/null +++ b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/dialogs/stream_config_window.html @@ -0,0 +1,40 @@ + +
"> + + + + + + + + + + + + + + + + + +
+
diff --git a/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/dialogs/stream_window.html b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/dialogs/stream_window.html new file mode 100644 index 0000000..86ff218 --- /dev/null +++ b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/dialogs/stream_window.html @@ -0,0 +1,99 @@ + + +
"> +
" opendialog="window_create_stream">
+
" opendialog="window_create_mosaiac">
+
">
+
">
+
">
+
+ +
+ +
+
"> + + + + + + + + + + + + + + + + + +
+
diff --git a/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/favicon.ico b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/favicon.ico new file mode 100644 index 0000000..a7d6288 Binary files /dev/null and b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/favicon.ico differ diff --git a/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/images/Audio-48.png b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/images/Audio-48.png new file mode 100644 index 0000000..a32e6aa Binary files /dev/null and b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/images/Audio-48.png differ diff --git a/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/images/Back-48.png b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/images/Back-48.png new file mode 100644 index 0000000..0363d84 Binary files /dev/null and b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/images/Back-48.png differ diff --git a/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/images/Folder-48.png b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/images/Folder-48.png new file mode 100644 index 0000000..59fe638 Binary files /dev/null and b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/images/Folder-48.png differ diff --git a/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/images/Other-48.png b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/images/Other-48.png new file mode 100644 index 0000000..83fae77 Binary files /dev/null and b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/images/Other-48.png differ diff --git a/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/images/Video-48.png b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/images/Video-48.png new file mode 100644 index 0000000..8a2b82d Binary files /dev/null and b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/images/Video-48.png differ diff --git a/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/images/buttons.png b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/images/buttons.png new file mode 100644 index 0000000..7dee3a5 Binary files /dev/null and b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/images/buttons.png differ diff --git a/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/images/speaker-32.png b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/images/speaker-32.png new file mode 100644 index 0000000..5a7fc13 Binary files /dev/null and b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/images/speaker-32.png differ diff --git a/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/images/vlc-48.png b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/images/vlc-48.png new file mode 100644 index 0000000..327b538 Binary files /dev/null and b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/images/vlc-48.png differ diff --git a/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/images/vlc16x16.png b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/images/vlc16x16.png new file mode 100644 index 0000000..aec7160 Binary files /dev/null and b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/images/vlc16x16.png differ diff --git a/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/index.html b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/index.html new file mode 100644 index 0000000..ed1d839 --- /dev/null +++ b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/index.html @@ -0,0 +1,313 @@ + + + + + <?vlc gettext("VLC media player - Web Interface") ?> + + + + + + + + + + + + + + + +
+
+
+
+
    +
  • ">
  • +
  • ">
  • +
  • ">
  • +
  • ">
  • +
  • ">
  • +
  • ">
  • +
  • ">
  • +
+
    +
  • ">
  • +
  • ">
  • +
  • ">
  • +
  • ">
  • +
  • ">
  • +
  • ">
  • +
+
+
volume
+
50%
+
+
+ Album Art +
+
+
+
">
+
00:00:00
+
00:00:00
+
+
+
+
+
    +
  • ">
  • +
  • ">
  • +
  • ">
  • +
  • ">
  • +
  • ">
  • +
  • ">
  • +
  • ">
  • +
+
+
+
+
+
+


+
+
+
+ +
+
+
"> +

+ +

+

+ +

+
+
"> +

+ Main Controls will operate the stream instead of the main interface.") ?> + Manage Streams") ?> + "> +

+

+ Media Viewer window will display the stream.") ?> + Main Controls.") ?> +

+

+ Library will be the subject of the stream.") ?> +

+

+ Open Stream button again.") ?> +

+

+ +

+
+ + + diff --git a/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/js/common.js b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/js/common.js new file mode 100644 index 0000000..d766699 --- /dev/null +++ b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/js/common.js @@ -0,0 +1,93 @@ +var intv = 0; +var ccmd = ""; +var video_types = [ + "asf", "avi", "bik", "bin", "divx", "drc", "dv", "f4v", "flv", "gxf", "iso", + "m1v", "m2v", "m2t", "m2ts", "m4v", "mkv", "mov", + "mp2", "mp4", "mpeg", "mpeg1", + "mpeg2", "mpeg4", "mpg", "mts", "mtv", "mxf", "mxg", "nuv", + "ogg", "ogm", "ogv", "ogx", "ps", + "rec", "rm", "rmvb", "rpl", "thp", "ts", "txd", "vob", "wmv", "xesc" ]; +var audio_types = [ + "3ga", "a52", "aac", "ac3", "ape", "awb", "dts", "flac", "it", + "m4a", "m4p", "mka", "mlp", "mod", "mp1", "mp2", "mp3", + "oga", "ogg", "oma", "s3m", "spx", "thd", "tta", + "wav", "wma", "wv", "xm" +]; +var playlist_types = [ + "asx", "b4s", "cue", "ifo", "m3u", "m3u8", "pls", "ram", "rar", + "sdp", "vlc", "xspf", "zip", "conf" +]; + +var stream_server = window.location.hostname; + +function format_time(s) { + var hours = Math.floor(s / 3600); + var minutes = Math.floor((s / 60) % 60); + var seconds = Math.floor(s % 60); + hours = hours < 10 ? "0" + hours : hours; + minutes = minutes < 10 ? "0" + minutes : minutes; + seconds = seconds < 10 ? "0" + seconds : seconds; + return hours + ":" + minutes + ":" + seconds; +} + +function toFloat(text) { + return parseFloat(text.replace(',', '.')); +} + +function setIntv() { + if (intv > 0) { + intv++; + setTimeout(setIntv, 500); + } else { + intv = 0; + } + if (intv > 5) { + var nt = 0; + switch (ccmd) { + case 'prev': + nt = Math.max(0, $('#seekSlider').slider('value') - 10); + break; + case 'next': + nt = Math.max(0, $('#seekSlider').slider('value') + 10); + break; + } + switch (current_que) { + case 'main': + sendCommand({ + 'command': 'seek', + 'val': Math.round((nt / 100) * $('#seekSlider').attr('totalLength')), + plreload: false + }); + break; + case 'stream': + sendVLMCmd('control Current seek ' + nt); + break; + } + } +} + +function isMobile() { + var a = navigator.userAgent || navigator.vendor || window.opera; + if (/android|avantgo|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|symbian|treo|up\.(browser|link)|vodafone|wap|windows (ce|phone)|xda|xiino/i.test(a) || /1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|e\-|e\/|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(di|rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|xda(\-|2|g)|yas\-|your|zeto|zte\-/i.test(a.substr(0, 4))) { + return true; + } + return false; +} + +function createElementLi(name, type, dir, ext) { + var icon = "Other-48.png"; + if( type == "dir" && name == '..' ) + icon = "Back-48.png"; + else if( type == 'dir' ) + icon = "Folder-48.png"; + else if( $.inArray(ext, video_types) != -1 ) + icon = "Video-48.png"; + else if( $.inArray(ext, audio_types) != -1 ) + icon = "Audio-48.png"; + else if( $.inArray(ext, playlist_types) != -1 ) + // TODO: Playlist-48.png + icon = "Other-48.png"; + var open = type == "dir" ? "opendir='" + dir + "'" : (type == "file" ? "openfile='" + dir + "'" : "opendev='" + dir + "'"); + var str = "
  • " + name + "
    " + name + "
  • "; + return str; +} diff --git a/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/js/controllers.js b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/js/controllers.js new file mode 100644 index 0000000..c7bbdb6 --- /dev/null +++ b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/js/controllers.js @@ -0,0 +1,532 @@ +var currentArt = null; +var current_que = 'main'; +var current_playlist_id = -1; +var previous_playlist_id = -1; +var seek_sec = 0; + +function updateArt(url) { + $('#albumArt').fadeOut(500, function () { + $(this).addClass('hidden').removeAttr('height').removeAttr('width').attr('src', url); + }); +} + +function updateStatus() { + $.ajax({ + url: 'requests/status.xml', + success: function (data, status, jqXHR) { + if (current_que == 'main') { + $('.dynamic').empty(); + $('#mediaTitle').append($('[name="filename"]', data).text()); + $('#totalTime').append(format_time($('length', data).text())); + $('#currentTime').append(format_time($('time', data).text())); + if (!$('#seekSlider').data('clicked')) { + $('#seekSlider').slider({ + value: toFloat($('position', data).text()) * 100 + }); + } + $('#currentVolume').append(Math.round($('volume', data).text() / 2.56) + '%'); + /* Don't interfere with the user's action */ + if (!$('#volumeSlider').data('clicked')) { + $('#volumeSlider').slider({ + value: ($('volume', data).text() / 5.12) + }); + } + $('#rateSlider').slider({ + value: ($('rate', data).text()) + }); + $('#currentRate').append(Math.round($('rate', data).text() * 100) / 100 + 'x'); + $('#audioSlider').slider({ + value: ($('audiodelay', data).text()) + }); + $('#currentAudioDelay').append(Math.round($('audiodelay', data).text() * 100) / 100 + 's'); + $('#subtitleSlider').slider({ + value: ($('subtitledelay', data).text()) + }); + $('#currentSubtitleDelay').append(Math.round($('subtitledelay', data).text() * 100) / 100 + 's'); + $('#seekSlider').attr('totalLength', $('length', data).text()); + $('#buttonPlay').attr('state', $('state', data).text()).attr('mrl', $('[name="filename"]', data).text()); + if ($('state', data).text() == 'playing') { + $('#buttonPlay').removeClass('paused').addClass('playing'); + } else { + $('#buttonPlay').removeClass('playing').addClass('paused'); + } + if ($('random', data).text() == 'true') { + $('#buttonShuffle').removeClass('ui-state-default').addClass('ui-state-active'); + } else { + $('#buttonShuffle').addClass('ui-state-default').removeClass('ui-state-active'); + } + if ($('loop', data).text() == 'true') { + $('#buttonLoop').removeClass('ui-state-default').addClass('ui-state-active'); + } else { + $('#buttonLoop').addClass('ui-state-default').removeClass('ui-state-active'); + } + if ($('repeat', data).text() == 'true') { + $('#buttonRepeat').removeClass('ui-state-default').addClass('ui-state-active'); + } else { + $('#buttonRepeat').addClass('ui-state-default').removeClass('ui-state-active'); + } + + if ($('[name="artwork_url"]', data).text() != currentArt && $('[name="artwork_url"]', data).text() != "") { + var tmp = new Date(); + currentArt = $('[name="artwork_url"]', data).text(); + updateArt('/art?' + tmp.getTime()); + } else if ($('[name="artwork_url"]', data).text() == "" && currentArt != 'images/vlc-48.png') { + currentArt = 'images/vlc-48.png'; + updateArt(currentArt); + } + + current_playlist_id = parseInt($('currentplid', data).text()); + if (previous_playlist_id != current_playlist_id) { + updatePlayList(); + previous_playlist_id = current_playlist_id; + } + + seek_sec = parseInt($('seek_sec', data).text()); + + if (pollStatus) { + setTimeout(updateStatus, 1000); + } + + } + $('band', data).each(function () { + var id = $(this).attr('id'); + var value = $(this).text() ? $(this).text() : 0; + var freq = ["60 Hz","170 Hz", "310 Hz", "600 Hz", "1 kHz","3 kHz", "6 kHz", "12 kHz" , "14 kHz" , "16 kHz" ]; + if (!$('#eq_container' + id).length) { + $('#window_equalizer').append('
    ' + value + 'dB
    ' + freq[id] + '
    '); + $('#eq' + id).slider({ + min: -20, + max: 20, + step: 0.1, + range: "min", + value: value, + animate: true, + orientation: "vertical", + stop: function (event, ui) { + $('#' + $(this).attr('id') + '_txt').empty().append(ui.value + 'dB'); + sendCommand({ + command: 'equalizer', + val: ui.value, + band: $(this).attr('id').substr(2) + }) + }, + slide: function (event, ui) { + $('#' + $(this).attr('id') + '_txt').empty().append(ui.value + 'dB'); + } + }); + } else { + $('#eq' + id).slider({ + value: value + }); + $('#eq' + id + '_txt').empty().append(Math.round(value * 100) / 100 + 'dB'); + } + }); + $('#preamp').slider('value', $('preamp', data).text()); + $('#preamp_txt').empty().append(Math.round($('preamp', data).text() * 100) / 100 + 'dB'); + }, + error: function (jqXHR, status, error) { + setTimeout(updateStatus, 500); + } + }); +} + +function updatePlayList(force_refresh) { + if (force_refresh) { + //refresh playlist.. + $('#libraryTree').jstree('refresh', -1); + } else { + //iterate through playlist.. + var match = false; + $('.jstree-leaf').each(function(){ + var id = $(this).attr('id'); + if (id != null && id.substr(0,5) == 'plid_') { + if ( id.substr(5) == current_playlist_id ) { + $(this).addClass('ui-state-highlight'); + $(this).attr('current', 'current'); + this.scrollIntoView(true); + match = true; + } else { + $(this).removeClass('ui-state-highlight'); + $(this).removeAttr('current'); + } + if ($(this).children('a').size() > 0) { + $($(this).children('a')[0]).removeClass('ui-state-active'); + } + } + }); + //local title wasn't found - refresh playlist.. + if (!match) updatePlayList(true); + } +} + +function sendCommand(params, append) { + if (current_que == 'stream') { + $.ajax({ + url: 'requests/status.xml', + data: params, + success: function (data, status, jqXHR) { + if (append != undefined) { + eval(append); + } + updateStatus(); + } + }); + } else { + if (params.plreload === false) { + $.ajax({ + url: 'requests/status.xml', + data: params, + success: function (data, status, jqXHR) { + if (append != undefined) { + eval(append); + } + } + }); + } else { + $.ajax({ + url: 'requests/status.xml', + data: params, + success: function (data, status, jqXHR) { + if (append != undefined) { + eval(append); + } + } + }); + } + } +} + +function browse(dir) { + dir = dir == undefined ? 'file://~' : dir; + $.ajax({ + url: 'requests/browse.xml', + data: 'uri=' + encodeURIComponent(dir), + success: function (data, status, jqXHR) { + var tgt = browse_target.indexOf('__') == -1 ? browse_target : browse_target.substr(0, browse_target.indexOf('__')); + $('#browse_elements').empty(); + $('element', data).each(function () { + var ext = $(this).attr('name').substr($(this).attr('name').lastIndexOf('.') + 1).toLowerCase(); + if ($(this).attr('type') == 'dir' || $.inArray(ext, video_types) != -1 || $.inArray(ext, audio_types) != -1 || $.inArray(ext, playlist_types) != -1) { + $('#browse_elements').append(createElementLi($(this).attr('name'), $(this).attr('type'), $(this).attr('uri'), ext)); + } + }); + $('[opendir]').dblclick(function () { + browse($(this).attr('opendir')); + }); + $('[openfile]').dblclick(function () { + switch (tgt) { + case '#stream_input': + $(browse_target).val($(this).attr('openfile')); + break; + case '#mosaic_open': + $('li', browse_target).remove(); + $(browse_target).append(this); + $(this).css({ + 'margin-left': -40, + 'margin-top': -46, + 'float': 'left' + }); + break; + case '#mobile': + break; + default: + sendCommand('command=in_play&input=' + encodeURIComponent($(this).attr('openfile'))); + updatePlayList(true); + break; + } + $('#window_browse').dialog('close'); + }); + $('[opendir]').click(function () { + switch (tgt) { + case '#mobile': + browse($(this).attr('opendir')); + break; + default: + break; + } + }); + $('[openfile]').click(function () { + switch (tgt) { + case '#mobile': + sendCommand('command=in_play&input=' + encodeURIComponent($(this).attr('openfile')), "window.location='mobile.html'"); + break; + default: + break; + } + }); + switch (tgt) { + case '#mobile': + break; + default: + $('[selectable]').selectable(); + break; + } + }, + error: function (jqXHR, status, error) { + setTimeout('browse("' + dir + '")', 1041); + } + }); +} + +function updateStreams() { + $.ajax({ + url: 'requests/vlm.xml', + success: function (data, status, jqXHR) { + $('#stream_info').accordion("destroy"); + $('#stream_info').empty(); + $('broadcast', data).each(function () { + var stream_div = $('#stream_status_').clone(); + var name = $(this).attr('name'); + var loop = $(this).attr('loop') == 'yes'; + var playing = $('instance', $(this)).attr('state') == 'playing'; + var file = $('input', $(this)).text(); + var output = $('output', $(this)).text(); + var time = isNaN(Math.round($('instance', $(this)).attr('time') / 1000000)) ? 0 : Math.round($('instance', $(this)).attr('time') / 1000000); + var length = isNaN(Math.round($('instance', $(this)).attr('length') / 1000000)) ? 0 : Math.round($('instance', $(this)).attr('length') / 1000000); + $('[id]', stream_div).each(function () { + $(this).attr('id', $(this).attr('id') + name); + }); + $(stream_div).attr('id', $(stream_div).attr('id') + name); + $('#stream_title_' + name, stream_div).append(name); + $('#stream_file_' + name, stream_div).append(file); + $('#stream_pos_' + name, stream_div).slider({ + value: 0, + range: "min", + min: 0, + slide: function (event, ui) { + $("#stream_current_time_" + name, stream_div).empty(); + $("#stream_current_time_" + name, stream_div).append(format_time(ui.value)); + $("#stream_total_time_" + name, stream_div).empty(); + $("#stream_total_time_" + name, stream_div).append(format_time($('#stream_pos_' + name, stream_div).slider('option', 'max'))); + sendVLMCmd('control ' + name + ' seek ' + Math.round(ui.value / $('#stream_pos_' + name, stream_div).slider('option', 'max') * 100)); + }, + change: function (event, ui) { + $("#stream_current_time_" + name, stream_div).empty(); + $("#stream_current_time_" + name, stream_div).append(format_time(ui.value)); + $("#stream_total_time_" + name, stream_div).empty(); + $("#stream_total_time_" + name, stream_div).append(format_time($('#stream_pos_' + name, stream_div).slider('option', 'max'))); + } + }); + $('#button_stream_stop_' + name, stream_div).click(function () { + sendVLMCmd('control ' + name + ' stop'); + return false; + }); + $('#button_stream_play_' + name, stream_div).click(function () { + if ($('span', this).hasClass('ui-icon-pause')) { + sendVLMCmd('control ' + name + ' pause'); + } else { + sendVLMCmd('control ' + name + ' play'); + } + }); + $('#button_stream_loop_' + name, stream_div).click(function () { + if (loop) { + sendVLMCmd('setup ' + name + ' unloop'); + } else { + sendVLMCmd('setup ' + name + ' loop'); + } + }); + $('#button_stream_delete_' + name, stream_div).click(function () { + sendVLMCmd('del ' + name); + }); + $('#stream_pos_' + name, stream_div).slider({ + max: length, + value: time + }); + if (playing) { + $('span', $('#button_stream_play_' + name, stream_div)).removeClass('ui-icon-play'); + $('span', $('#button_stream_play_' + name, stream_div)).addClass('ui-icon-pause'); + } + if (loop) { + $('#button_stream_loop_' + name, stream_div).addClass('ui-state-active'); + } + $(stream_div).css({ + 'visibility': '', + 'display': '' + }); + $('#stream_info').append(stream_div); + + }); + $('.button').hover( + + function () { + $(this).addClass('ui-state-hover'); + }, function () { + $(this).removeClass('ui-state-hover'); + }); + $('#stream_info').accordion({ + header: "h3", + collapsible: true, + autoHeight: true + }); + if (current_que == 'stream') { + $('.dynamic').empty(); + $('#mediaTitle').append($('[name="Current"] input', data).text()); + $('#totalTime').append(format_time(isNaN($('[name="Current"] instance', data).attr('length')) ? 0 : $('[name="Current"] instance', data).attr('length') / 1000000)); + $('#currentTime').append(format_time(isNaN($('[name="Current"] instance', data).attr('time')) ? 0 : $('[name="Current"] instance', data).attr('time') / 1000000)); + $('#seekSlider').slider({ + value: (($('[name="Current"] instance', data).attr('time') / 1000000) / ($('[name="Current"] instance', data).attr('length') / 1000000) * 100) + }); + $('#seekSlider').attr('totalLength', $('[name="Current"] instance', data).attr('length') / 1000000); + $('#buttonPlay').attr('state', $('[name="Current"] instance', data).length > 0 ? $('[name="Current"] instance', data).attr('state') : 'stopped'); + if ($('[name="Current"] instance', data).attr('state') == 'playing') { + $('#buttonPlay').removeClass('paused'); + $('#buttonPlay').addClass('playing'); + } else { + $('#buttonPlay').removeClass('playing'); + $('#buttonPlay').addClass('paused'); + } + setTimeout(updateStreams, 1000); + } + } + }); +} + +function updateEQ() { + $.ajax({ + url: 'requests/status.xml', + success: function (data, status, jqXHR) { + $('band', data).each(function () { + var freq = ["60 Hz","170 Hz", "310 Hz", "600 Hz", "1 kHz","3 kHz", "6 kHz", "12 kHz" , "14 kHz" , "16 kHz" ]; + var id = $(this).attr('id'); + var value = $(this).text() ? $(this).text() : 0; + if (!$('#eq_container' + id).length) { + $('#window_equalizer').append('
    ' + value + 'dB
    ' + freq[id] + '
    '); + $('#eq' + id).slider({ + min: -20, + max: 20, + step: 0.1, + range: "min", + value: value, + animate: true, + orientation: "vertical", + stop: function (event, ui) { + $('#' + $(this).attr('id') + '_txt').empty().append(ui.value + 'dB'); + sendEQCmd({ + command: 'equalizer', + val: ui.value, + band: $(this).attr('id').substr(2) + }) + }, + slide: function (event, ui) { + $('#' + $(this).attr('id') + '_txt').empty().append(ui.value + 'dB'); + } + }); + } else { + $('#eq' + id).slider({ + value: value + }); + $('#eq' + id + '_txt').empty().append(Math.round(value * 100) / 100 + 'dB'); + } + }); + $('#preamp').slider('value', $('preamp', data).text()); + $('#preamp_txt').empty().append(Math.round($('preamp', data).text() * 100) / 100 + 'dB'); + } + }) +} + +function sendVLMCmd(command, append) { + var commands = command.split(';'); + if (commands.length > 1) { + sendBatchVLMCmd(command, append); + } else { + if (current_que == 'main') { + $.ajax({ + url: 'requests/vlm_cmd.xml', + data: 'command=' + encodeURIComponent(command), + success: function (data, status, jqXHR) { + if ($('error', data).text()) { + $('#error_container').append('
    ' + $('error', data).text() + '
    '); + $('#window_error').dialog('open'); + } + if (append != undefined) { + eval(append); + } + updateStreams(); + } + }); + } else { + $.ajax({ + url: 'requests/vlm_cmd.xml', + data: 'command=' + encodeURIComponent(command), + success: function (data, status, jqXHR) { + if ($('error', data).text()) { + $('#error_container').append('
    ' + $('error', data).text() + '
    '); + $('#window_error').dialog('open'); + } + updateStreams(); + } + }); + } + } +} + +function sendBatchVLMCmd(command, append) { + var commands = command.split(';'); + $.ajax({ + url: 'requests/vlm_cmd.xml', + data: 'command=' + encodeURIComponent(commands.shift()), + success: function (data, status, jqXHR) { + if ($('error', data).text()) { + $('#error_container').append('
    ' + $('error', data).text() + '
    '); + $('#window_error').dialog('open'); + } + sendVLMCmd(commands.join(';'), append); + } + }); +} + +function sendEQCmd(params) { + $.ajax({ + url: 'requests/status.xml', + data: params, + success: function (data, status, jqXHR) { + updateEQ(); + } + }); +} + +$(function () { + $('#albumArt').load(function () { + var width = $(this).width(); + var height = $(this).height(); + var max = Math.max(width, height); + if (max > 150) { + var ratio = 150 / max; + width = Math.floor(width * ratio); + height = Math.floor(height * ratio); + } + $(this).attr('width', width).attr('height', height).css('margin-left', Math.floor((150 - width) / 2)).css('margin-top', Math.floor((150 - height) / 2)).removeClass('hidden').fadeIn(); + }); + $('#libraryTree').jstree({ + "xml_data": { + "ajax": { + "url": "requests/playlist_jstree.xml" + }, + "xsl": "nest" + }, + "themeroller": { + "item_leaf": "ui-icon-video" + }, + "core": { + "initially_open": ["plid_1", "plid_2", "plid_3"] + }, + "plugins": ["xml_data", "ui", "themeroller"] + }).bind("loaded.jstree", function (event, data) { + $('[current]', '[id^="plid_"]').each(function () { + $(this).addClass('ui-state-highlight'); + current_playlist_id = $(this).attr('id').substr(5); + }); + }).bind("refresh.jstree", function (event, data) { + $('[current]', '[id^="plid_"]').each(function () { + $(this).addClass('ui-state-highlight'); + current_playlist_id = $(this).attr('id').substr(5); + }); + }).delegate("#plid_0 li.jstree-leaf a", "click", function (event, data) { + event.preventDefault(); + current_playlist_id = $(this).parent().attr('id').substr(5); + sendCommand('command=pl_play&id=' + current_playlist_id); + }); + updateStatus(); + updateStreams(); + updateEQ(); +}); diff --git a/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/js/jquery.jstree.js b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/js/jquery.jstree.js new file mode 100644 index 0000000..a47e949 --- /dev/null +++ b/ShadowStream/bin/Debug/net8.0-windows/libvlc/win-x64/lua/http/js/jquery.jstree.js @@ -0,0 +1,4544 @@ +/* + * jsTree 1.0-rc3 + * http://jstree.com/ + * + * Copyright (c) 2010 Ivan Bozhanov (vakata.com) + * + * Licensed same as jquery - under the terms of either the MIT License or the GPL Version 2 License + * http://www.opensource.org/licenses/mit-license.php + * http://www.gnu.org/licenses/gpl.html + * + * $Date: 2011-02-09 01:17:14 +0200 (ср, 09 февр 2011) $ + * $Revision: 236 $ + */ + +/*jslint browser: true, onevar: true, undef: true, bitwise: true, strict: true */ +/*global window : false, clearInterval: false, clearTimeout: false, document: false, setInterval: false, setTimeout: false, jQuery: false, navigator: false, XSLTProcessor: false, DOMParser: false, XMLSerializer: false*/ + +"use strict"; + +// top wrapper to prevent multiple inclusion (is this OK?) +(function () { if(jQuery && jQuery.jstree) { return; } + var is_ie6 = false, is_ie7 = false, is_ff2 = false; + +/* + * jsTree core + */ +(function ($) { + // Common functions not related to jsTree + // decided to move them to a `vakata` "namespace" + $.vakata = {}; + // CSS related functions + $.vakata.css = { + get_css : function(rule_name, delete_flag, sheet) { + rule_name = rule_name.toLowerCase(); + var css_rules = sheet.cssRules || sheet.rules, + j = 0; + do { + if(css_rules.length && j > css_rules.length + 5) { return false; } + if(css_rules[j].selectorText && css_rules[j].selectorText.toLowerCase() == rule_name) { + if(delete_flag === true) { + if(sheet.removeRule) { sheet.removeRule(j); } + if(sheet.deleteRule) { sheet.deleteRule(j); } + return true; + } + else { return css_rules[j]; } + } + } + while (css_rules[++j]); + return false; + }, + add_css : function(rule_name, sheet) { + if($.jstree.css.get_css(rule_name, false, sheet)) { return false; } + if(sheet.insertRule) { sheet.insertRule(rule_name + ' { }', 0); } else { sheet.addRule(rule_name, null, 0); } + return $.vakata.css.get_css(rule_name); + }, + remove_css : function(rule_name, sheet) { + return $.vakata.css.get_css(rule_name, true, sheet); + }, + add_sheet : function(opts) { + var tmp = false, is_new = true; + if(opts.str) { + if(opts.title) { tmp = $("style[id='" + opts.title + "-stylesheet']")[0]; } + if(tmp) { is_new = false; } + else { + tmp = document.createElement("style"); + tmp.setAttribute('type',"text/css"); + if(opts.title) { tmp.setAttribute("id", opts.title + "-stylesheet"); } + } + if(tmp.styleSheet) { + if(is_new) { + document.getElementsByTagName("head")[0].appendChild(tmp); + tmp.styleSheet.cssText = opts.str; + } + else { + tmp.styleSheet.cssText = tmp.styleSheet.cssText + " " + opts.str; + } + } + else { + tmp.appendChild(document.createTextNode(opts.str)); + document.getElementsByTagName("head")[0].appendChild(tmp); + } + return tmp.sheet || tmp.styleSheet; + } + if(opts.url) { + if(document.createStyleSheet) { + try { tmp = document.createStyleSheet(opts.url); } catch (e) { } + } + else { + tmp = document.createElement('link'); + tmp.rel = 'stylesheet'; + tmp.type = 'text/css'; + tmp.media = "all"; + tmp.href = opts.url; + document.getElementsByTagName("head")[0].appendChild(tmp); + return tmp.styleSheet; + } + } + } + }; + + // private variables + var instances = [], // instance array (used by $.jstree.reference/create/focused) + focused_instance = -1, // the index in the instance array of the currently focused instance + plugins = {}, // list of included plugins + prepared_move = {}; // for the move_node function + + // jQuery plugin wrapper (thanks to jquery UI widget function) + $.fn.jstree = function (settings) { + var isMethodCall = (typeof settings == 'string'), // is this a method call like $().jstree("open_node") + args = Array.prototype.slice.call(arguments, 1), + returnValue = this; + + // if a method call execute the method on all selected instances + if(isMethodCall) { + if(settings.substring(0, 1) == '_') { return returnValue; } + this.each(function() { + var instance = instances[$.data(this, "jstree-instance-id")], + methodValue = (instance && $.isFunction(instance[settings])) ? instance[settings].apply(instance, args) : instance; + if(typeof methodValue !== "undefined" && (settings.indexOf("is_") === 0 || (methodValue !== true && methodValue !== false))) { returnValue = methodValue; return false; } + }); + } + else { + this.each(function() { + // extend settings and allow for multiple hashes and $.data + var instance_id = $.data(this, "jstree-instance-id"), + a = [], + b = settings ? $.extend({}, true, settings) : {}, + c = $(this), + s = false, + t = []; + a = a.concat(args); + if(c.data("jstree")) { a.push(c.data("jstree")); } + b = a.length ? $.extend.apply(null, [true, b].concat(a)) : b; + + // if an instance already exists, destroy it first + if(typeof instance_id !== "undefined" && instances[instance_id]) { instances[instance_id].destroy(); } + // push a new empty object to the instances array + instance_id = parseInt(instances.push({}),10) - 1; + // store the jstree instance id to the container element + $.data(this, "jstree-instance-id", instance_id); + // clean up all plugins + b.plugins = $.isArray(b.plugins) ? b.plugins : $.jstree.defaults.plugins.slice(); + b.plugins.unshift("core"); + // only unique plugins + b.plugins = b.plugins.sort().join(",,").replace(/(,|^)([^,]+)(,,\2)+(,|$)/g,"$1$2$4").replace(/,,+/g,",").replace(/,$/,"").split(","); + + // extend defaults with passed data + s = $.extend(true, {}, $.jstree.defaults, b); + s.plugins = b.plugins; + $.each(plugins, function (i, val) { + if($.inArray(i, s.plugins) === -1) { s[i] = null; delete s[i]; } + else { t.push(i); } + }); + s.plugins = t; + + // push the new object to the instances array (at the same time set the default classes to the container) and init + instances[instance_id] = new $.jstree._instance(instance_id, $(this).addClass("jstree jstree-" + instance_id), s); + // init all activated plugins for this instance + $.each(instances[instance_id]._get_settings().plugins, function (i, val) { instances[instance_id].data[val] = {}; }); + $.each(instances[instance_id]._get_settings().plugins, function (i, val) { if(plugins[val]) { plugins[val].__init.apply(instances[instance_id]); } }); + // initialize the instance + setTimeout(function() { instances[instance_id].init(); }, 0); + }); + } + // return the jquery selection (or if it was a method call that returned a value - the returned value) + return returnValue; + }; + // object to store exposed functions and objects + $.jstree = { + defaults : { + plugins : [] + }, + _focused : function () { return instances[focused_instance] || null; }, + _reference : function (needle) { + // get by instance id + if(instances[needle]) { return instances[needle]; } + // get by DOM (if still no luck - return null + var o = $(needle); + if(!o.length && typeof needle === "string") { o = $("#" + needle); } + if(!o.length) { return null; } + return instances[o.closest(".jstree").data("jstree-instance-id")] || null; + }, + _instance : function (index, container, settings) { + // for plugins to store data in + this.data = { core : {} }; + this.get_settings = function () { return $.extend(true, {}, settings); }; + this._get_settings = function () { return settings; }; + this.get_index = function () { return index; }; + this.get_container = function () { return container; }; + this.get_container_ul = function () { return container.children("ul:eq(0)"); }; + this._set_settings = function (s) { + settings = $.extend(true, {}, settings, s); + }; + }, + _fn : { }, + plugin : function (pname, pdata) { + pdata = $.extend({}, { + __init : $.noop, + __destroy : $.noop, + _fn : {}, + defaults : false + }, pdata); + plugins[pname] = pdata; + + $.jstree.defaults[pname] = pdata.defaults; + $.each(pdata._fn, function (i, val) { + val.plugin = pname; + val.old = $.jstree._fn[i]; + $.jstree._fn[i] = function () { + var rslt, + func = val, + args = Array.prototype.slice.call(arguments), + evnt = new $.Event("before.jstree"), + rlbk = false; + + if(this.data.core.locked === true && i !== "unlock" && i !== "is_locked") { return; } + + // Check if function belongs to the included plugins of this instance + do { + if(func && func.plugin && $.inArray(func.plugin, this._get_settings().plugins) !== -1) { break; } + func = func.old; + } while(func); + if(!func) { return; } + + // context and function to trigger events, then finally call the function + if(i.indexOf("_") === 0) { + rslt = func.apply(this, args); + } + else { + rslt = this.get_container().triggerHandler(evnt, { "func" : i, "inst" : this, "args" : args, "plugin" : func.plugin }); + if(rslt === false) { return; } + if(typeof rslt !== "undefined") { args = rslt; } + + rslt = func.apply( + $.extend({}, this, { + __callback : function (data) { + this.get_container().triggerHandler( i + '.jstree', { "inst" : this, "args" : args, "rslt" : data, "rlbk" : rlbk }); + }, + __rollback : function () { + rlbk = this.get_rollback(); + return rlbk; + }, + __call_old : function (replace_arguments) { + return func.old.apply(this, (replace_arguments ? Array.prototype.slice.call(arguments, 1) : args ) ); + } + }), args); + } + + // return the result + return rslt; + }; + $.jstree._fn[i].old = val.old; + $.jstree._fn[i].plugin = pname; + }); + }, + rollback : function (rb) { + if(rb) { + if(!$.isArray(rb)) { rb = [ rb ]; } + $.each(rb, function (i, val) { + instances[val.i].set_rollback(val.h, val.d); + }); + } + } + }; + // set the prototype for all instances + $.jstree._fn = $.jstree._instance.prototype = {}; + + // load the css when DOM is ready + $(function() { + // code is copied from jQuery ($.browser is deprecated + there is a bug in IE) + var u = navigator.userAgent.toLowerCase(), + v = (u.match( /.+?(?:rv|it|ra|ie)[\/: ]([\d.]+)/ ) || [0,'0'])[1], + css_string = '' + + '.jstree ul, .jstree li { display:block; margin:0 0 0 0; padding:0 0 0 0; list-style-type:none; } ' + + '.jstree li { display:block; min-height:18px; line-height:18px; white-space:nowrap; margin-left:18px; min-width:18px; } ' + + '.jstree-rtl li { margin-left:0; margin-right:18px; } ' + + '.jstree > ul > li { margin-left:0px; } ' + + '.jstree-rtl > ul > li { margin-right:0px; } ' + + '.jstree ins { display:inline-block; text-decoration:none; width:18px; height:18px; margin:0 0 0 0; padding:0; } ' + + '.jstree a { display:inline-block; line-height:16px; height:16px; color:black; white-space:nowrap; text-decoration:none; padding:1px 2px; margin:0; } ' + + '.jstree a:focus { outline: none; } ' + + '.jstree a > ins { height:16px; width:16px; } ' + + '.jstree a > .jstree-icon { margin-right:3px; } ' + + '.jstree-rtl a > .jstree-icon { margin-left:3px; margin-right:0; } ' + + 'li.jstree-open > ul { display:block; } ' + + 'li.jstree-closed > ul { display:none; } '; + // Correct IE 6 (does not support the > CSS selector) + if(/msie/.test(u) && parseInt(v, 10) == 6) { + is_ie6 = true; + + // fix image flicker and lack of caching + try { + document.execCommand("BackgroundImageCache", false, true); + } catch (err) { } + + css_string += '' + + '.jstree li { height:18px; margin-left:0; margin-right:0; } ' + + '.jstree li li { margin-left:18px; } ' + + '.jstree-rtl li li { margin-left:0px; margin-right:18px; } ' + + 'li.jstree-open ul { display:block; } ' + + 'li.jstree-closed ul { display:none !important; } ' + + '.jstree li a { display:inline; border-width:0 !important; padding:0px 2px !important; } ' + + '.jstree li a ins { height:16px; width:16px; margin-right:3px; } ' + + '.jstree-rtl li a ins { margin-right:0px; margin-left:3px; } '; + } + // Correct IE 7 (shifts anchor nodes onhover) + if(/msie/.test(u) && parseInt(v, 10) == 7) { + is_ie7 = true; + css_string += '.jstree li a { border-width:0 !important; padding:0px 2px !important; } '; + } + // correct ff2 lack of display:inline-block + if(!/compatible/.test(u) && /mozilla/.test(u) && parseFloat(v, 10) < 1.9) { + is_ff2 = true; + css_string += '' + + '.jstree ins { display:-moz-inline-box; } ' + + '.jstree li { line-height:12px; } ' + // WHY?? + '.jstree a { display:-moz-inline-box; } ' + + '.jstree .jstree-no-icons .jstree-checkbox { display:-moz-inline-stack !important; } '; + /* this shouldn't be here as it is theme specific */ + } + // the default stylesheet + $.vakata.css.add_sheet({ str : css_string, title : "jstree" }); + }); + + // core functions (open, close, create, update, delete) + $.jstree.plugin("core", { + __init : function () { + this.data.core.locked = false; + this.data.core.to_open = this.get_settings().core.initially_open; + this.data.core.to_load = this.get_settings().core.initially_load; + }, + defaults : { + html_titles : false, + animation : 500, + initially_open : [], + initially_load : [], + open_parents : true, + notify_plugins : true, + rtl : false, + load_open : false, + strings : { + loading : "Loading ...", + new_node : "New node", + multiple_selection : "Multiple selection" + } + }, + _fn : { + init : function () { + this.set_focus(); + if(this._get_settings().core.rtl) { + this.get_container().addClass("jstree-rtl").css("direction", "rtl"); + } + this.get_container().html(""); + this.data.core.li_height = this.get_container_ul().find("li.jstree-closed, li.jstree-leaf").eq(0).height() || 18; + + this.get_container() + .delegate("li > ins", "click.jstree", $.proxy(function (event) { + var trgt = $(event.target); + if(trgt.is("ins") && event.pageY - trgt.offset().top < this.data.core.li_height) { this.toggle_node(trgt); } + }, this)) + .bind("mousedown.jstree", $.proxy(function () { + this.set_focus(); // This used to be setTimeout(set_focus,0) - why? + }, this)) + .bind("dblclick.jstree", function (event) { + var sel; + if(document.selection && document.selection.empty) { document.selection.empty(); } + else { + if(window.getSelection) { + sel = window.getSelection(); + try { + sel.removeAllRanges(); + sel.collapse(); + } catch (err) { } + } + } + }); + if(this._get_settings().core.notify_plugins) { + this.get_container() + .bind("load_node.jstree", $.proxy(function (e, data) { + var o = this._get_node(data.rslt.obj), + t = this; + if(o === -1) { o = this.get_container_ul(); } + if(!o.length) { return; } + o.find("li").each(function () { + var th = $(this); + if(th.data("jstree")) { + $.each(th.data("jstree"), function (plugin, values) { + if(t.data[plugin] && $.isFunction(t["_" + plugin + "_notify"])) { + t["_" + plugin + "_notify"].call(t, th, values); + } + }); + } + }); + }, this)); + } + if(this._get_settings().core.load_open) { + this.get_container() + .bind("load_node.jstree", $.proxy(function (e, data) { + var o = this._get_node(data.rslt.obj), + t = this; + if(o === -1) { o = this.get_container_ul(); } + if(!o.length) { return; } + o.find("li.jstree-open:not(:has(ul))").each(function () { + t.load_node(this, $.noop, $.noop); + }); + }, this)); + } + this.__callback(); + this.load_node(-1, function () { this.loaded(); this.reload_nodes(); }); + }, + destroy : function () { + var i, + n = this.get_index(), + s = this._get_settings(), + _this = this; + + $.each(s.plugins, function (i, val) { + try { plugins[val].__destroy.apply(_this); } catch(err) { } + }); + this.__callback(); + // set focus to another instance if this one is focused + if(this.is_focused()) { + for(i in instances) { + if(instances.hasOwnProperty(i) && i != n) { + instances[i].set_focus(); + break; + } + } + } + // if no other instance found + if(n === focused_instance) { focused_instance = -1; } + // remove all traces of jstree in the DOM (only the ones set using jstree*) and cleans all events + this.get_container() + .unbind(".jstree") + .undelegate(".jstree") + .removeData("jstree-instance-id") + .find("[class^='jstree']") + .andSelf() + .attr("class", function () { return this.className.replace(/jstree[^ ]*|$/ig,''); }); + $(document) + .unbind(".jstree-" + n) + .undelegate(".jstree-" + n); + // remove the actual data + instances[n] = null; + delete instances[n]; + }, + + _core_notify : function (n, data) { + if(data.opened) { + this.open_node(n, false, true); + } + }, + + lock : function () { + this.data.core.locked = true; + this.get_container().children("ul").addClass("jstree-locked").css("opacity","0.7"); + this.__callback({}); + }, + unlock : function () { + this.data.core.locked = false; + this.get_container().children("ul").removeClass("jstree-locked").css("opacity","1"); + this.__callback({}); + }, + is_locked : function () { return this.data.core.locked; }, + save_opened : function () { + var _this = this; + this.data.core.to_open = []; + this.get_container_ul().find("li.jstree-open").each(function () { + if(this.id) { _this.data.core.to_open.push("#" + this.id.toString().replace(/^#/,"").replace(/\\\//g,"/").replace(/\//g,"\\\/").replace(/\\\./g,".").replace(/\./g,"\\.").replace(/\:/g,"\\:")); } + }); + this.__callback(_this.data.core.to_open); + }, + save_loaded : function () { }, + reload_nodes : function (is_callback) { + var _this = this, + done = true, + current = [], + remaining = []; + if(!is_callback) { + this.data.core.reopen = false; + this.data.core.refreshing = true; + this.data.core.to_open = $.map($.makeArray(this.data.core.to_open), function (n) { return "#" + n.toString().replace(/^#/,"").replace(/\\\//g,"/").replace(/\//g,"\\\/").replace(/\\\./g,".").replace(/\./g,"\\.").replace(/\:/g,"\\:"); }); + this.data.core.to_load = $.map($.makeArray(this.data.core.to_load), function (n) { return "#" + n.toString().replace(/^#/,"").replace(/\\\//g,"/").replace(/\//g,"\\\/").replace(/\\\./g,".").replace(/\./g,"\\.").replace(/\:/g,"\\:"); }); + if(this.data.core.to_open.length) { + this.data.core.to_load = this.data.core.to_load.concat(this.data.core.to_open); + } + } + if(this.data.core.to_load.length) { + $.each(this.data.core.to_load, function (i, val) { + if(val == "#") { return true; } + if($(val).length) { current.push(val); } + else { remaining.push(val); } + }); + if(current.length) { + this.data.core.to_load = remaining; + $.each(current, function (i, val) { + if(!_this._is_loaded(val)) { + _this.load_node(val, function () { _this.reload_nodes(true); }, function () { _this.reload_nodes(true); }); + done = false; + } + }); + } + } + if(this.data.core.to_open.length) { + $.each(this.data.core.to_open, function (i, val) { + _this.open_node(val, false, true); + }); + } + if(done) { + // TODO: find a more elegant approach to synchronizing returning requests + if(this.data.core.reopen) { clearTimeout(this.data.core.reopen); } + this.data.core.reopen = setTimeout(function () { _this.__callback({}, _this); }, 50); + this.data.core.refreshing = false; + this.reopen(); + } + }, + reopen : function () { + var _this = this; + if(this.data.core.to_open.length) { + $.each(this.data.core.to_open, function (i, val) { + _this.open_node(val, false, true); + }); + } + this.__callback({}); + }, + refresh : function (obj) { + var _this = this; + this.save_opened(); + if(!obj) { obj = -1; } + obj = this._get_node(obj); + if(!obj) { obj = -1; } + if(obj !== -1) { obj.children("UL").remove(); } + else { this.get_container_ul().empty(); } + this.load_node(obj, function () { _this.__callback({ "obj" : obj}); _this.reload_nodes(); }); + }, + // Dummy function to fire after the first load (so that there is a jstree.loaded event) + loaded : function () { + this.__callback(); + }, + // deal with focus + set_focus : function () { + if(this.is_focused()) { return; } + var f = $.jstree._focused(); + if(f) { f.unset_focus(); } + + this.get_container().addClass("jstree-focused"); + focused_instance = this.get_index(); + this.__callback(); + }, + is_focused : function () { + return focused_instance == this.get_index(); + }, + unset_focus : function () { + if(this.is_focused()) { + this.get_container().removeClass("jstree-focused"); + focused_instance = -1; + } + this.__callback(); + }, + + // traverse + _get_node : function (obj) { + var $obj = $(obj, this.get_container()); + if($obj.is(".jstree") || obj == -1) { return -1; } + $obj = $obj.closest("li", this.get_container()); + return $obj.length ? $obj : false; + }, + _get_next : function (obj, strict) { + obj = this._get_node(obj); + if(obj === -1) { return this.get_container().find("> ul > li:first-child"); } + if(!obj.length) { return false; } + if(strict) { return (obj.nextAll("li").size() > 0) ? obj.nextAll("li:eq(0)") : false; } + + if(obj.hasClass("jstree-open")) { return obj.find("li:eq(0)"); } + else if(obj.nextAll("li").size() > 0) { return obj.nextAll("li:eq(0)"); } + else { return obj.parentsUntil(".jstree","li").next("li").eq(0); } + }, + _get_prev : function (obj, strict) { + obj = this._get_node(obj); + if(obj === -1) { return this.get_container().find("> ul > li:last-child"); } + if(!obj.length) { return false; } + if(strict) { return (obj.prevAll("li").length > 0) ? obj.prevAll("li:eq(0)") : false; } + + if(obj.prev("li").length) { + obj = obj.prev("li").eq(0); + while(obj.hasClass("jstree-open")) { obj = obj.children("ul:eq(0)").children("li:last"); } + return obj; + } + else { var o = obj.parentsUntil(".jstree","li:eq(0)"); return o.length ? o : false; } + }, + _get_parent : function (obj) { + obj = this._get_node(obj); + if(obj == -1 || !obj.length) { return false; } + var o = obj.parentsUntil(".jstree", "li:eq(0)"); + return o.length ? o : -1; + }, + _get_children : function (obj) { + obj = this._get_node(obj); + if(obj === -1) { return this.get_container().children("ul:eq(0)").children("li"); } + if(!obj.length) { return false; } + return obj.children("ul:eq(0)").children("li"); + }, + get_path : function (obj, id_mode) { + var p = [], + _this = this; + obj = this._get_node(obj); + if(obj === -1 || !obj || !obj.length) { return false; } + obj.parentsUntil(".jstree", "li").each(function () { + p.push( id_mode ? this.id : _this.get_text(this) ); + }); + p.reverse(); + p.push( id_mode ? obj.attr("id") : this.get_text(obj) ); + return p; + }, + + // string functions + _get_string : function (key) { + return this._get_settings().core.strings[key] || key; + }, + + is_open : function (obj) { obj = this._get_node(obj); return obj && obj !== -1 && obj.hasClass("jstree-open"); }, + is_closed : function (obj) { obj = this._get_node(obj); return obj && obj !== -1 && obj.hasClass("jstree-closed"); }, + is_leaf : function (obj) { obj = this._get_node(obj); return obj && obj !== -1 && obj.hasClass("jstree-leaf"); }, + correct_state : function (obj) { + obj = this._get_node(obj); + if(!obj || obj === -1) { return false; } + obj.removeClass("jstree-closed jstree-open").addClass("jstree-leaf").children("ul").remove(); + this.__callback({ "obj" : obj }); + }, + // open/close + open_node : function (obj, callback, skip_animation) { + obj = this._get_node(obj); + if(!obj.length) { return false; } + if(!obj.hasClass("jstree-closed")) { if(callback) { callback.call(); } return false; } + var s = skip_animation || is_ie6 ? 0 : this._get_settings().core.animation, + t = this; + if(!this._is_loaded(obj)) { + obj.children("a").addClass("jstree-loading"); + this.load_node(obj, function () { t.open_node(obj, callback, skip_animation); }, callback); + } + else { + if(this._get_settings().core.open_parents) { + obj.parentsUntil(".jstree",".jstree-closed").each(function () { + t.open_node(this, false, true); + }); + } + if(s) { obj.children("ul").css("display","none"); } + obj.removeClass("jstree-closed").addClass("jstree-open").children("a").removeClass("jstree-loading"); + if(s) { obj.children("ul").stop(true, true).slideDown(s, function () { this.style.display = ""; t.after_open(obj); }); } + else { t.after_open(obj); } + this.__callback({ "obj" : obj }); + if(callback) { callback.call(); } + } + }, + after_open : function (obj) { this.__callback({ "obj" : obj }); }, + close_node : function (obj, skip_animation) { + obj = this._get_node(obj); + var s = skip_animation || is_ie6 ? 0 : this._get_settings().core.animation, + t = this; + if(!obj.length || !obj.hasClass("jstree-open")) { return false; } + if(s) { obj.children("ul").attr("style","display:block !important"); } + obj.removeClass("jstree-open").addClass("jstree-closed"); + if(s) { obj.children("ul").stop(true, true).slideUp(s, function () { this.style.display = ""; t.after_close(obj); }); } + else { t.after_close(obj); } + this.__callback({ "obj" : obj }); + }, + after_close : function (obj) { this.__callback({ "obj" : obj }); }, + toggle_node : function (obj) { + obj = this._get_node(obj); + if(obj.hasClass("jstree-closed")) { return this.open_node(obj); } + if(obj.hasClass("jstree-open")) { return this.close_node(obj); } + }, + open_all : function (obj, do_animation, original_obj) { + obj = obj ? this._get_node(obj) : -1; + if(!obj || obj === -1) { obj = this.get_container_ul(); } + if(original_obj) { + obj = obj.find("li.jstree-closed"); + } + else { + original_obj = obj; + if(obj.is(".jstree-closed")) { obj = obj.find("li.jstree-closed").andSelf(); } + else { obj = obj.find("li.jstree-closed"); } + } + var _this = this; + obj.each(function () { + var __this = this; + if(!_this._is_loaded(this)) { _this.open_node(this, function() { _this.open_all(__this, do_animation, original_obj); }, !do_animation); } + else { _this.open_node(this, false, !do_animation); } + }); + // so that callback is fired AFTER all nodes are open + if(original_obj.find('li.jstree-closed').length === 0) { this.__callback({ "obj" : original_obj }); } + }, + close_all : function (obj, do_animation) { + var _this = this; + obj = obj ? this._get_node(obj) : this.get_container(); + if(!obj || obj === -1) { obj = this.get_container_ul(); } + obj.find("li.jstree-open").andSelf().each(function () { _this.close_node(this, !do_animation); }); + this.__callback({ "obj" : obj }); + }, + clean_node : function (obj) { + obj = obj && obj != -1 ? $(obj) : this.get_container_ul(); + obj = obj.is("li") ? obj.find("li").andSelf() : obj.find("li"); + obj.removeClass("jstree-last") + .filter("li:last-child").addClass("jstree-last").end() + .filter(":has(li)") + .not(".jstree-open").removeClass("jstree-leaf").addClass("jstree-closed"); + obj.not(".jstree-open, .jstree-closed").addClass("jstree-leaf").children("ul").remove(); + this.__callback({ "obj" : obj }); + }, + // rollback + get_rollback : function () { + this.__callback(); + return { i : this.get_index(), h : this.get_container().children("ul").clone(true), d : this.data }; + }, + set_rollback : function (html, data) { + this.get_container().empty().append(html); + this.data = data; + this.__callback(); + }, + // Dummy functions to be overwritten by any datastore plugin included + load_node : function (obj, s_call, e_call) { this.__callback({ "obj" : obj }); }, + _is_loaded : function (obj) { return true; }, + + // Basic operations: create + create_node : function (obj, position, js, callback, is_loaded) { + obj = this._get_node(obj); + position = typeof position === "undefined" ? "last" : position; + var d = $("
  • "), + s = this._get_settings().core, + tmp; + + if(obj !== -1 && !obj.length) { return false; } + if(!is_loaded && !this._is_loaded(obj)) { this.load_node(obj, function () { this.create_node(obj, position, js, callback, true); }); return false; } + + this.__rollback(); + + if(typeof js === "string") { js = { "data" : js }; } + if(!js) { js = {}; } + if(js.attr) { d.attr(js.attr); } + if(js.metadata) { d.data(js.metadata); } + if(js.state) { d.addClass("jstree-" + js.state); } + if(!js.data) { js.data = this._get_string("new_node"); } + if(!$.isArray(js.data)) { tmp = js.data; js.data = []; js.data.push(tmp); } + $.each(js.data, function (i, m) { + tmp = $(""); + if($.isFunction(m)) { m = m.call(this, js); } + if(typeof m == "string") { tmp.attr('href','#')[ s.html_titles ? "html" : "text" ](m); } + else { + if(!m.attr) { m.attr = {}; } + if(!m.attr.href) { m.attr.href = '#'; } + tmp.attr(m.attr)[ s.html_titles ? "html" : "text" ](m.title); + if(m.language) { tmp.addClass(m.language); } + } + tmp.prepend(" "); + if(m.icon) { + if(m.icon.indexOf("/") === -1) { tmp.children("ins").addClass(m.icon); } + else { tmp.children("ins").css("background","url('" + m.icon + "') center center no-repeat"); } + } + d.append(tmp); + }); + d.prepend(" "); + if(obj === -1) { + obj = this.get_container(); + if(position === "before") { position = "first"; } + if(position === "after") { position = "last"; } + } + switch(position) { + case "before": obj.before(d); tmp = this._get_parent(obj); break; + case "after" : obj.after(d); tmp = this._get_parent(obj); break; + case "inside": + case "first" : + if(!obj.children("ul").length) { obj.append("