home-js.php 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455
  1. <?PHP
  2. /**
  3. * Copyright (c) 2016, 2024, 5 Mode
  4. *
  5. * This file is part of Musicing.
  6. *
  7. * Musicing is free software: you can redistribute it and/or modify
  8. * it under the terms of the GNU General Public License as published by
  9. * the Free Software Foundation, either version 3 of the License, or
  10. * (at your option) any later version.
  11. *
  12. * Musicing is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  15. * GNU General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU General Public License
  18. * along with Musicing. If not, see <https://www.gnu.org/licenses/>.
  19. *
  20. * home-js.php
  21. *
  22. * Musicing js for the Home page.
  23. *
  24. * @author Daniele Bonini <my25mb@aol.com>
  25. * @copyrights (c) 2016, 2024, 5 Mode
  26. */
  27. require "../../Private/core/init.inc";
  28. header("Content-Type: text/javascript");
  29. // PARAMETERS AND VARIABLES INIT
  30. $lang = APP_DEF_LANG;
  31. $lang1 = substr(filter_input(INPUT_GET, "hl")??"", 0, 5);
  32. $lang1= strip_tags($lang1);
  33. if ($lang1 !== PHP_STR) {
  34. $lang = $lang1;
  35. }
  36. $shortLang = getShortLang($lang);
  37. $AVATAR_NAME=filter_input(INPUT_GET, "av")??"";
  38. $AVATAR_NAME= strip_tags($AVATAR_NAME);
  39. $CURRENT_VIEW=filter_input(INPUT_GET, "cv")??"";
  40. $CURRENT_VIEW= strip_tags($CURRENT_VIEW);
  41. $CUDOZ=filter_input(INPUT_GET, "cu")??"";
  42. $CUDOZ= strip_tags($CUDOZ);
  43. ?>
  44. var myToolsOnIntID;
  45. function showHowTo() {
  46. <?PHP if ($lang == PHP_EN): ?>
  47. alert("Here how to manage your avatars in Musicing\n" +
  48. "- Type in the url of your avatar like http://" + "<?PHP echo($_SERVER['HTTP_HOST']);?>" + "/<your avatar>.\n" +
  49. "- Login with your pasword.\n" +
  50. "- Drag-n-drop in the browser window all the resources you like: \n" +
  51. " a. Drop in mp3 files to shape your music blog, in the form 'Playlist~Song Title.mp3';\n" +
  52. " a. Drop in pic to shape your gallery; the first one as yr avatar picture.\n" +
  53. " b. Drop in texts with link separeted by <ENTER> to shape your friends.\n" +
  54. "\n" +
  55. "Enjoy!");
  56. <?PHP elseif ($lang == PHP_IT): ?>
  57. alert("Ecco come gestire i tuoi avatar in Musicing:\n" +
  58. "- Scrivi l'url del tuo avatar come http://" + "<?PHP echo($_SERVER['HTTP_HOST']);?>" + "/<tuo avatar>.\n" +
  59. "- Loggati con la pasword.\n" +
  60. "- Fai il drag-n-drop nella finestra del browser di tutte le risorse che ritieni: \n" +
  61. " a. Trascina .mp3 file per creare il tuo blog musicale, attenendoti a 'Playlist~Titolo Canzone.mp3'\n" +
  62. " b. Trascina le tue immagini per creare la galleria, la prima sara' il tuo avatar.\n" +
  63. " b. Trascina link da testo separati da <INVIO> per creare i tuoi amici.\n" +
  64. "\n" +
  65. "Buon proseguimento!");
  66. <?PHP elseif ($lang == PHP_CN): ?>
  67. alert("在这里如何免费管理您的化身:\n" +
  68. "- 以以下格式输入阿凡达的URLhttp://" + "<?PHP echo($_SERVER['HTTP_HOST']);?>" + "/<你的头像>.\n" +
  69. "- 使用密码登录.\n" +
  70. "- 在浏览器窗口中拖动n-drop您喜欢的所有资源: \n" +
  71. " a. 放入.txt文件以形成您的博客:'Playlist~Song Title.mp3'.\n" +
  72. " b. 放入图片以塑造画廊; 第一个作为您的头像.\n" +
  73. " b. 删除带有链接<enter>分隔的链接以塑造您的朋友的文本.\n" +
  74. "\n" +
  75. "Enjoy!");
  76. <?PHP endif; ?>
  77. }
  78. function playSample() {
  79. //document.getElementById("myPlayer").src = "http://<?PHP echo(APP_HOST);?>/media/sample.mp3";
  80. document.getElementById("myPlayer").src = "/audio?av=<?PHP echo($AVATAR_NAME); ?>&f=/sample.mp3";
  81. document.getElementById("myPlayer").volume = 1;
  82. document.getElementById("myPlayer").play();
  83. }
  84. function playSong(playlist, song) {
  85. //document.getElementById("myPlayer").src = "http://<?PHP echo(APP_HOST);?>/media/" + encodeURI(playlist) + "/" + song;
  86. document.getElementById("myPlayer").src = "/audio?av=<?PHP echo($AVATAR_NAME); ?>&f=/" + encodeURI(playlist) + "/" + song;
  87. document.getElementById("myPlayer").volume = 1;
  88. document.getElementById("myPlayer").play();
  89. }
  90. function stopSong() {
  91. stopPlayList();
  92. document.getElementById("myPlayer").pause();
  93. }
  94. var curPlayF = -1;
  95. var ih;
  96. function playList(playlist, allowed, onclick) {
  97. if (allowed) {
  98. /*
  99. if (onclick) {
  100. if ($(".play-list-img2").attr("src") ==="/res/stopicon.png") {
  101. stopPlayList();
  102. return;
  103. }
  104. } */
  105. if (document.getElementById("myPlayer").readyState===0 || document.getElementById("myPlayer").ended || document.getElementById("myPlayer").paused) {
  106. //$(".play-list-img2").attr("src","/res/stopicon.png");
  107. $("#playListImg"+playlist).attr("src","/res/stopicon.png");
  108. curPlayF++;
  109. if (document.getElementsByClassName("playf"+playlist)[curPlayF]) {
  110. $(document.getElementsByClassName("playf"+playlist)[curPlayF]).click();
  111. clearInterval(ih);
  112. ih = setInterval("playList("+playlist+", true, false)", 5000);
  113. } else {
  114. //stopPlayList();
  115. curPlayF = -1;
  116. }
  117. } else {
  118. if (onclick) {
  119. //if ($(".play-list-img2").attr("src") ==="/res/stopicon.png") {
  120. stopPlayList();
  121. return;
  122. //}
  123. }
  124. }
  125. }
  126. return;
  127. }
  128. function stopPlayList() {
  129. curPlayF = -1;
  130. clearInterval(ih);
  131. $(".play-list-img").attr("src","/res/playicon.png");
  132. $(".play-list-img2").attr("src","/res/playicon.png");
  133. document.getElementById("myPlayer").pause();
  134. }
  135. function settingsOn() {
  136. $(".settingson").hide();
  137. $(".magicjar1").show();
  138. $(".magicjar2").show();
  139. $(".magicjar3").show();
  140. $(".settingsoff").show();
  141. setTimeout("settingsOff()",6000);
  142. }
  143. function settingsOff() {
  144. $(".settingsoff").hide("slow");
  145. $(".magicjar1").hide("slow");
  146. $(".magicjar2").hide("slow");
  147. $(".magicjar3").hide("slow");
  148. $(".settingson").show();
  149. }
  150. function toolsOn() {
  151. settingsOn();
  152. $(".tools").show("slow");
  153. clearInterval(myToolsOnIntID);
  154. }
  155. function setJar1On() {
  156. $(".magicjar1").css("background","url(/res/magicjar1.png)");
  157. $(".magicjar1").css("background-size","120px 120px");
  158. document.getElementsByClassName("magicjar1")[0].onclick=setJar1Off;
  159. document.getElementById("txtMagicJar1").value="1";
  160. document.getElementById("frmUpload").submit();
  161. }
  162. function setJar1Off() {
  163. $(".magicjar1").css("background","url(/res/magicjar1dis.png)");
  164. $(".magicjar1").css("background-size","120px 120px");
  165. document.getElementsByClassName("magicjar1")[0].onclick=setJar1On;
  166. document.getElementById("txtMagicJar1").value="0";
  167. document.getElementById("frmUpload").submit();
  168. }
  169. function setJar2On() {
  170. $(".magicjar2").css("background","url(/res/magicjar2.png)");
  171. $(".magicjar2").css("background-size","120px 120px");
  172. document.getElementsByClassName("magicjar2")[0].onclick=setJar2Off;
  173. document.getElementById("txtMagicJar2").value="1";
  174. document.getElementById("frmUpload").submit();
  175. }
  176. function setJar2Off() {
  177. $(".magicjar2").css("background","url(/res/magicjar2dis.png)");
  178. $(".magicjar2").css("background-size","120px 120px");
  179. document.getElementsByClassName("magicjar2")[0].onclick=setJar2On;
  180. document.getElementById("txtMagicJar2").value="0";
  181. document.getElementById("frmUpload").submit();
  182. }
  183. function setJar3On() {
  184. $(".magicjar3").css("background","url(/res/magicjar3.png)");
  185. $(".magicjar3").css("background-size","120px 120px");
  186. document.getElementsByClassName("magicjar3")[0].onclick=setJar3Off;
  187. document.getElementById("txtMagicJar3").value="1";
  188. document.getElementById("frmUpload").submit();
  189. }
  190. function setJar3Off() {
  191. $(".magicjar3").css("background","url(/res/magicjar3dis.png)");
  192. $(".magicjar3").css("background-size","120px 120px");
  193. document.getElementsByClassName("magicjar3")[0].onclick=setJar3On;
  194. document.getElementById("txtMagicJar3").value="0";
  195. }
  196. function startApp() {
  197. hidePassword();
  198. }
  199. function hidePassword() {
  200. $("#passworddisplay").css("visibility","hidden");
  201. }
  202. /*
  203. * call to startApp
  204. *
  205. * @returns void
  206. */
  207. function _startApp() {
  208. setTimeout("startApp()", 1000);
  209. }
  210. /*
  211. * Display the current hash for the config file
  212. *
  213. * @returns void
  214. */
  215. function showEncodedPassword() {
  216. if ($("#Password").val() === "") {
  217. $("#Password").addClass("emptyfield");
  218. return;
  219. }
  220. //if ($("#Salt").val() === "") {
  221. // $("#Salt").addClass("emptyfield");
  222. // return;
  223. //}
  224. passw = encryptSha2( $("#Password").val() + $("#Salt").val());
  225. msg = "<?PHP echo(getResource0("Please set your hash in the config file with this value", $lang, "/js/home-js.php"));?>:";
  226. alert(msg + "\n\n" + passw);
  227. }
  228. function changeLang(tthis) {
  229. window.open("/<?PHP echo($AVATAR_NAME);?>?hl="+$(tthis).val(),"_self");
  230. }
  231. function adminView() {
  232. document.getElementById("_reqView").value="<?PHP echo(ADMIN_VIEW);?>";
  233. document.getElementById("frmUpload").submit();
  234. }
  235. function privateView() {
  236. document.getElementById("_reqView").value="<?PHP echo(PRIVATE_VIEW);?>";
  237. document.getElementById("frmUpload").submit();
  238. }
  239. function reload() {
  240. //window.location.reload();
  241. document.getElementById("frmUpload").submit();
  242. }
  243. $("div.dragover").on("dragover", function(e) {
  244. e.stopPropagation();
  245. e.preventDefault();
  246. e.originalEvent.dataTransfer.dropEffect = "copy";
  247. return false;
  248. });
  249. $("div.dragover").on("drop", function(e) {
  250. e.stopPropagation();
  251. e.preventDefault();
  252. // Get the current Upload form obejct..
  253. var form = document.getElementById("frmUpload");
  254. // Create a FormData object including the actual form data..
  255. var fd = new FormData(form);
  256. // Get the array of files dropped..
  257. var dt = e.originalEvent.dataTransfer;
  258. var files = dt.files;
  259. var count = files.length;
  260. //alert("File Count: " + count + "\n");
  261. if (count !== 0) {
  262. for (var i = 0; i < count; i++) {
  263. //alert(" File " + i + ":\n(" + (typeof files[i]) + ") : <" + files[i] + " > " +
  264. // files[i].name + " " + files[i].size + " " + files[i].type + "\n");
  265. if (files[i].size > <?PHP echo(APP_FILE_MAX_SIZE); ?>) {
  266. alert("ERROR: file size (" + files[i].size +") exceeds app limit: <?PHP echo(APP_FILE_MAX_SIZE); ?>");
  267. return;
  268. }
  269. if (files[i].size > <?PHP echo(ini_get('upload_max_filesize'));?>) {
  270. alert("ERROR: file size (" + files[i].size +") exceeds PHP upload limit: <?PHP echo(ini_get('upload_max_filesize')); ?>");
  271. return;
  272. }
  273. if (files[i].size > <?PHP echo(ini_get('post_max_size'));?>) {
  274. alert("ERROR: file size (" + files[i].size +") exceeds PHP post limit: <?PHP echo(ini_get('post_max_size')); ?>");
  275. return;
  276. }
  277. fd.append("filesdd[]", files[i]);
  278. }
  279. // Submit of the FormData..
  280. $.ajax("/<?PHP echo($AVATAR_NAME);?>", {
  281. method: "POST",
  282. processData: false,
  283. contentType: false,
  284. data: fd//,
  285. //success: function (data) {
  286. //$("body").html(data);
  287. //}
  288. });
  289. setTimeout("reload()", 2000);
  290. } else {
  291. mytext = e.originalEvent.dataTransfer.getData('text/plain');
  292. re = new RegExp(/(https?:\/\/)([\da-z\.-]+)\.([a-z\.]{2,8})(\/?.+)?$/gum);
  293. matches = mytext.matchAll(re);
  294. ffriends="";
  295. if (matches !== null) {
  296. for(const match of matches) {
  297. if (ffriends==="") {
  298. ffriends+=match[0];
  299. } else {
  300. ffriends+="|"+match[0];
  301. }
  302. }
  303. }
  304. if (ffriends!=="") {
  305. //fd.append("f", ffriends);
  306. document.getElementById("f").value = ffriends;
  307. //alert(document.getElementById("f").value);
  308. document.getElementById("frmUpload").submit();
  309. } else {
  310. //alert("ale!");
  311. }
  312. }
  313. return false;
  314. });
  315. $("input#files").on("change", function(e) {
  316. frmUpload.submit();
  317. });
  318. function setContentPos() {
  319. h=parseInt(window.innerHeight);
  320. w=parseInt(window.innerWidth);
  321. <?PHP if ($CURRENT_VIEW ==ADMIN_VIEW): ?>
  322. $("#fireupload").css("top", ((h - 255) / 2) + "px");
  323. $("#fireupload").css("left", ((w - 255) / 2) + "px");
  324. $("#fireupload").css("display", "inline");
  325. //$("#picavatar").css("top", ((h - 255) / 2) + "px");
  326. //$("#picavatar").css("left", ((w - 255) / 2) + "px");
  327. $("#picavatar").css("display", "inline");
  328. <?PHP else: ?>
  329. if (window.innerWidth<800) {
  330. $("#header").css("display", "none");
  331. $("#headerMob").css("display", "inline");
  332. $("#cudoz").css("display", "none");
  333. } else {
  334. $("#header").css("display", "inline");
  335. $("#headerMob").css("display", "none");
  336. $("#cudoz").css("display", "inline");
  337. }
  338. <?PHP endif; ?>
  339. $(".dragover").css("height", h + "px");
  340. $(".dragover").css("width", w + "px");
  341. newleft=parseInt(window.innerWidth - 145);
  342. $(".tools").css("left",newleft+"px");
  343. mytop = parseInt(window.innerHeight - ($("#passworddisplay").height() + 60));
  344. $("#passworddisplay").css("top", mytop+"px");
  345. }
  346. function setFooterPos() {
  347. if (document.getElementById("footerCont")) {
  348. tollerance = 16;
  349. $("#footerCont").css("top", parseInt( window.innerHeight - $("#footerCont").height() - tollerance ) + "px");
  350. $("#footer1").css("top", parseInt( window.innerHeight - $("#footer1").height() - tollerance ) + "px");
  351. $("#footer2").css("top", parseInt( window.innerHeight - $("#footer2").height() - tollerance ) + "px");
  352. $("#footer2").css("left", parseInt( window.innerWidth - $("#footer2").width() - tollerance ) + "px");
  353. $("#footer").css("top", parseInt( window.innerHeight - $("#footer").height() - tollerance ) + "px");
  354. }
  355. }
  356. window.addEventListener("load", function() {
  357. setTimeout("setContentPos()", 500);
  358. setTimeout("setFooterPos()", 1000);
  359. <?PHP if ($CURRENT_VIEW ==ADMIN_VIEW): ?>
  360. myToolsOnIntID = setInterval("toolsOn()", 2000);
  361. <?PHP else: ?>
  362. // display cudoz
  363. //for (i=1;i<=<?PHP echo($CUDOZ);?>;i++) {
  364. // $("#cudozentry"+i).get(0).src="/res/chicca_<?PHP echo($shortLang);?>.png";
  365. //}
  366. <?PHP endif; ?>
  367. setTimeout("_startApp()", 10000);
  368. }, true);
  369. window.addEventListener("resize", function() {
  370. setTimeout("setContentPos()", 500);
  371. setTimeout("setFooterPos()", 1000);
  372. }, true);