custom.js 68 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771
  1. /*jslint browser: true*/
  2. /*global $, jQuery, alert*/
  3. var idleTime = 0;
  4. var hasCookie = false;
  5. $(document).ajaxComplete(function () {
  6. pageLoad();
  7. });
  8. $(document).ready(function () {
  9. pageLoad();
  10. var clipboard = new Clipboard('.clipboard');
  11. clipboard.on('success', function(e) {
  12. message('Clipboard',e.text,'bottom-right','#FFF','info','5000');
  13. e.clearSelection();
  14. });
  15. "use strict";
  16. var body = $("body");
  17. $(function () {
  18. //$("#preloader").fadeOut();
  19. var set = function () {
  20. var topOffset = 60,
  21. width = (window.innerWidth > 0) ? window.innerWidth : this.screen.width,
  22. height = ((window.innerHeight > 0) ? window.innerHeight : this.screen.height) - 1;
  23. if (width < 768) {
  24. $('div.navbar-collapse').addClass('collapse');
  25. topOffset = 100; /* 2-row-menu */
  26. } else {
  27. $('div.navbar-collapse').removeClass('collapse');
  28. }
  29. /* ===== This is for resizing window ===== */
  30. if (width < 1170) {
  31. body.addClass('content-wrapper');
  32. $(".sidebar-nav, .slimScrollDiv").css("overflow-x", "visible").parent().css("overflow", "visible");
  33. } else {
  34. body.removeClass('content-wrapper');
  35. }
  36. height = height - topOffset;
  37. if (height < 1) {
  38. height = 1;
  39. }
  40. if (height > topOffset) {
  41. $("#page-wrapper").css("min-height", (height) + "px");
  42. }
  43. },
  44. url = window.location,
  45. element = $('ul.nav a').filter(function () {
  46. return this.href === url || url.href.indexOf(this.href) === 0;
  47. }).addClass('activez').parent().parent().addClass('ok').parent();
  48. if (element.is('li')) {
  49. element.addClass('activezo');
  50. }
  51. $(window).ready(set);
  52. $(window).bind("resize", set);
  53. });
  54. body.trigger("resize");
  55. //Increment the idle time counter every minute.
  56. var idleInterval = setInterval(timerIncrement, 60000); // 1 minute
  57. hasCookie = (getCookie('organizrToken')) ? true : false;
  58. //Zero the idle timer on mouse movement.
  59. $(this).mousemove(function (e) {
  60. idleTime = 0;
  61. });
  62. $(this).keypress(function (e) {
  63. idleTime = 0;
  64. });
  65. myLazyLoad = new LazyLoad({
  66. elements_selector: ".lazyload"
  67. });
  68. });
  69. function pageLoad(){
  70. "use strict";
  71. //Start Organizr
  72. $(function () {
  73. if($('#preloader:visible').length == 1){
  74. $("#preloader").fadeOut();
  75. }
  76. myLazyLoad.update();
  77. });
  78. /* ===== Collapsible Panels JS ===== */
  79. (function ($, window, document) {
  80. var panelSelector = '[data-perform="panel-collapse"]',
  81. panelRemover = '[data-perform="panel-dismiss"]';
  82. $(panelSelector).each(function () {
  83. var collapseOpts = {
  84. toggle: false
  85. },
  86. parent = $(this).closest('.panel'),
  87. wrapper = parent.find('.panel-wrapper'),
  88. child = $(this).children('i');
  89. if (!wrapper.length) {
  90. wrapper = parent.children('.panel-heading').nextAll().wrapAll('<div/>').parent().addClass('panel-wrapper');
  91. collapseOpts = {};
  92. }
  93. wrapper.collapse(collapseOpts).on('hide.bs.collapse', function () {
  94. child.removeClass('ti-minus').addClass('ti-plus');
  95. }).on('show.bs.collapse', function () {
  96. child.removeClass('ti-plus').addClass('ti-minus');
  97. });
  98. });
  99. /* ===== Collapse Panels ===== */
  100. $(document).on('click', panelSelector, function (e) {
  101. e.preventDefault();
  102. var parent = $(this).closest('.panel'),
  103. wrapper = parent.find('.panel-wrapper');
  104. $(this).children('i').toggleClass('ti-plus').toggleClass('ti-minus');
  105. wrapper.collapse('toggle');
  106. });
  107. /* ===== Remove Panels ===== */
  108. $(document).on('click', panelRemover, function (e) {
  109. e.preventDefault();
  110. var removeParent = $(this).closest('.panel');
  111. function removeElement() {
  112. var col = removeParent.parent();
  113. removeParent.remove();
  114. col.filter(function () {
  115. return ($(this).is('[class*="col-"]') && $(this).children('*').length === 0);
  116. }).remove();
  117. }
  118. removeElement();
  119. });
  120. }(jQuery, window, document));
  121. /* ===== Tooltip Initialization ===== */
  122. $(function () {
  123. $('[data-toggle="tooltip"]').tooltip();
  124. /*$('body').tooltip({
  125. selector: '[data-toggle="tooltip"]'
  126. });*/
  127. });
  128. /* ===== Popover Initialization ===== */
  129. $(function () {
  130. $('[data-toggle="popover"]').popover();
  131. });
  132. $(function () {
  133. // Switchery
  134. var elems = Array.prototype.slice.call(document.querySelectorAll('.js-switch'));
  135. $('.js-switch').each(function() {
  136. if ($(this).attr('data-switchery') !== 'true'){
  137. new Switchery($(this)[0], $(this).data());
  138. }
  139. });
  140. });
  141. /* ===== Collepsible Toggle ===== */
  142. $(".collapseble").on("click", function () {
  143. $(".collapseblebox").fadeToggle(350);
  144. });
  145. /* ===== Resize all elements ===== */
  146. /* ===== Visited ul li ===== */
  147. /*$('.visited li a').on("click", function (e) {
  148. $('.visited li').removeClass('active');
  149. var $parent = $(this).parent();
  150. if (!$parent.hasClass('active')) {
  151. $parent.addClass('active');
  152. }
  153. e.preventDefault();
  154. });*/
  155. /* =================================================================
  156. Update 1.5
  157. this is for close icon when navigation open in mobile view
  158. ================================================================= */
  159. /* magnific stuff */
  160. $('.image-popup-vertical-fit').magnificPopup({
  161. type: 'image',
  162. closeOnContentClick: true,
  163. mainClass: 'mfp-img-mobile',
  164. image: {
  165. verticalFit: true
  166. }
  167. });
  168. $('.image-popup-fit-width').magnificPopup({
  169. type: 'image',
  170. closeOnContentClick: true,
  171. image: {
  172. verticalFit: false
  173. }
  174. });
  175. $('.image-popup-no-margins').magnificPopup({
  176. type: 'image',
  177. closeOnContentClick: true,
  178. closeBtnInside: false,
  179. fixedContentPos: true,
  180. mainClass: 'mfp-no-margins mfp-with-zoom', // class to remove default margin from left and right side
  181. image: {
  182. verticalFit: true
  183. },
  184. zoom: {
  185. enabled: true,
  186. duration: 300 // don't foget to change the duration also in CSS
  187. }
  188. });
  189. $('.popup-gallery').magnificPopup({
  190. delegate: 'a',
  191. type: 'image',
  192. tLoading: 'Loading image #%curr%...',
  193. mainClass: 'mfp-img-mobile',
  194. gallery: {
  195. enabled: true,
  196. navigateByImgClick: true,
  197. preload: [0,1] // Will preload 0 - before current, and 1 after the current image
  198. },
  199. image: {
  200. tError: '<a href="%url%">The image #%curr%</a> could not be loaded.',
  201. titleSrc: function(item) {
  202. return item.el.attr('title') + '<small>by Marsel Van Oosten</small>';
  203. }
  204. }
  205. });
  206. $('.zoom-gallery').magnificPopup({
  207. delegate: 'a',
  208. type: 'image',
  209. closeOnContentClick: false,
  210. closeBtnInside: false,
  211. mainClass: 'mfp-with-zoom mfp-img-mobile',
  212. image: {
  213. verticalFit: true,
  214. titleSrc: function(item) {
  215. return item.el.attr('title') + ' &middot; <a class="image-source-link" href="'+item.el.attr('data-source')+'" target="_blank">image source</a>';
  216. }
  217. },
  218. gallery: {
  219. enabled: true
  220. },
  221. zoom: {
  222. enabled: true,
  223. duration: 300, // don't foget to change the duration also in CSS
  224. opener: function(element) {
  225. return element.find('img');
  226. }
  227. }
  228. });
  229. $('#image-popups').magnificPopup({
  230. delegate: 'a',
  231. type: 'image',
  232. removalDelay: 500, //delay removal by X to allow out-animation
  233. callbacks: {
  234. beforeOpen: function() {
  235. // just a hack that adds mfp-anim class to markup
  236. this.st.image.markup = this.st.image.markup.replace('mfp-figure', 'mfp-figure mfp-with-anim');
  237. this.st.mainClass = this.st.el.attr('data-effect');
  238. }
  239. },
  240. closeOnContentClick: true,
  241. midClick: true // allow opening popup on middle mouse click. Always set it to true if you don't provide alternative source.
  242. });
  243. $('.popup-youtube, .popup-vimeo, .popup-gmaps').magnificPopup({
  244. disableOn: 700,
  245. type: 'iframe',
  246. mainClass: 'mfp-fade',
  247. removalDelay: 160,
  248. preloader: false,
  249. fixedContentPos: false
  250. });
  251. $('.popup-with-form').magnificPopup({
  252. type: 'inline',
  253. preloader: true,
  254. removalDelay: 500,
  255. // When elemened is focused, some mobile browsers in some cases zoom in
  256. // It looks not nice, so we disable it:
  257. callbacks: {
  258. beforeOpen: function() {
  259. if($(window).width() < 700) {
  260. this.st.focus = false;
  261. } else {
  262. this.st.focus = '#name';
  263. }
  264. this.st.mainClass = this.st.el.attr('data-effect');
  265. }
  266. }
  267. });
  268. // Inline popups
  269. $('.inline-popups').magnificPopup({
  270. removalDelay: 500, //delay removal by X to allow out-animation
  271. closeOnBgClick: true,
  272. //closeOnContentClick: true,
  273. callbacks: {
  274. beforeOpen: function() {
  275. this.st.mainClass = this.st.el.attr('data-effect');
  276. this.st.focus = '.inline-focus';
  277. },
  278. close: function() {
  279. if(typeof player !== 'undefined'){
  280. console.log('STOP STOP STOP')
  281. player.destroy();
  282. }
  283. }
  284. },
  285. midClick: true // allow opening popup on middle mouse click. Always set it to true if you don't provide alternative source.
  286. });
  287. $('.simple-ajax-popup-align-top').magnificPopup({
  288. type: 'ajax',
  289. alignTop: true,
  290. overflowY: 'scroll' // as we know that popup content is tall we set scroll overflow by default to avoid jump
  291. });
  292. $('.simple-ajax-popup').magnificPopup({
  293. type: 'ajax'
  294. });
  295. //limit height of calendar list view
  296. $('.fc-scroller').slimScroll({
  297. height: '270px',
  298. position: 'right',
  299. size: "5px",
  300. color: '#dcdcdc'
  301. });
  302. }
  303. /* ===== Sidebar ===== */
  304. $('.slimscrollright').slimScroll({
  305. height: '100%',
  306. position: 'right',
  307. size: "5px",
  308. color: '#dcdcdc'
  309. });
  310. $('.slimscrollsidebar').slimScroll({
  311. height: '100%',
  312. position: 'left',
  313. size: "6px",
  314. color: 'rgba(0,0,0,0.5)'
  315. });
  316. if(bowser.mobile !== true){
  317. $('.inbox-center').slimScroll({
  318. height: '100%',
  319. position: 'right',
  320. size: "5px",
  321. color: '#dcdcdc'
  322. });
  323. }
  324. $(".navbar-toggle").on("click", function () {
  325. $(".navbar-toggle i").toggleClass("ti-menu").addClass("ti-close");
  326. });
  327. /* ===== Login and Recover Password ===== */
  328. $(document).on("click", "#to-recover", function(e) {
  329. $("#loginform").slideUp();
  330. $("#recoverform").fadeIn();
  331. });
  332. $(document).on("click", ".to-register", function(e) {
  333. $("#loginform").slideUp();
  334. $("#registerForm").removeClass('hidden');
  335. $("#registerform").fadeIn();
  336. });
  337. $(document).on("click", "#leave-recover", function(e) {
  338. $("#loginform").slideDown();
  339. $("#recoverform").fadeOut();
  340. });
  341. $(document).on("click", "#leave-registration", function(e) {
  342. $("#registerform").fadeOut();
  343. $("#registerForm").addClass('hidden');
  344. $("#loginform").slideDown();
  345. });
  346. $(document).on("click", ".updateNow", function(e) {
  347. updateNow();
  348. });
  349. $(document).on("click", ".show-login", function(e) {
  350. buildLogin();
  351. });
  352. $(document).on("click", ".depenency-item", function(e) {
  353. alert($(this).attr('data-name'));
  354. });
  355. function doneTypingMediaSearch () {
  356. var query = $('#mediaSearchQuery').val();
  357. var server = $('#mediaSearchQuery').attr('data-server');
  358. switch (server) {
  359. case 'plex':
  360. var action = 'getPlexSearch';
  361. break;
  362. case 'emby':
  363. var action = 'getEmbySearch';
  364. break;
  365. default:
  366. }
  367. organizrAPI('POST','api/?v1/homepage/connect',{action:action, query:query}).success(function(data) {
  368. var response = JSON.parse(data);
  369. $('.mediaSearch-div').html('');
  370. $('.mediaSearch-div').html(buildMediaResults(response.data,server,query));
  371. $('.openResults').trigger('click');
  372. }).fail(function(xhr) {
  373. console.error("Organizr Function: API Connection Failed");
  374. })
  375. }
  376. $(document).on("click", ".login-button", function(e) {
  377. e.preventDefault;
  378. $('div.login-box').block({
  379. message: '<h5><img width="20" src="plugins/images/busy.gif" /> Just a moment...</h4>',
  380. css: {
  381. color: '#fff',
  382. border: '1px solid #2cabe3',
  383. backgroundColor: '#2cabe3'
  384. }
  385. });
  386. var post = $( '#loginform' ).serializeArray();
  387. organizrAPI('POST','api/?v1/login',post).success(function(data) {
  388. var html = JSON.parse(data);
  389. if(html.data == true){
  390. location.reload();
  391. }else if(html.data == 'mismatch'){
  392. $('div.login-box').unblock({});
  393. $.toast().reset('all');
  394. message('Login Error',' Wrong username/email/password combo','bottom-right','#FFF','warning','10000');
  395. console.error('Organizr Function: Login failed - wrong username/email/password');
  396. }
  397. }).fail(function(xhr) {
  398. console.error("Organizr Function: Login Failed");
  399. });
  400. });
  401. $(document).on("click", ".register-button", function(e) {
  402. e.preventDefault;
  403. var post = $( '#registerForm' ).serializeArray();
  404. organizrAPI('POST','api/?v1/register',post).success(function(data) {
  405. var html = JSON.parse(data);
  406. console.log(html);
  407. if(html.data == true){
  408. location.reload();
  409. }else if(html.data == 'mismatch'){
  410. $.toast().reset('all');
  411. message('Registration Error',' Wrong Registration Password','bottom-right','#FFF','warning','10000');
  412. console.error('Organizr Function: Registration failed - Wrong Registration Password');
  413. }else if(html.data == 'username taken'){
  414. $.toast().reset('all');
  415. message('Registration Error',' Registration Error - Username/Email Taken','bottom-right','#FFF','warning','10000');
  416. console.error('Organizr Function: Registration Failed - Username/Email Taken');
  417. }
  418. }).fail(function(xhr) {
  419. console.error("Organizr Function: Login Failed");
  420. });
  421. });
  422. $(document).on("click", ".reset-button", function(e) {
  423. e.preventDefault;
  424. var email = $('#recover-input').val();
  425. if(email !== ''){
  426. var post = {
  427. email:email
  428. }
  429. organizrAPI('POST','api/?v1/recover',post).success(function(data) {
  430. var html = JSON.parse(data);
  431. if(html.data == true){
  432. message('Recover Password',' Email Sent','bottom-right','#FFF','success','10000');
  433. $('#leave-recover').trigger('click');
  434. }else if(html.data == 'an error occured'){
  435. $.toast().reset('all');
  436. message('Recover Error',' User Error','bottom-right','#FFF','warning','10000');
  437. console.error('Organizr Function: Recover failed - Wrong Registration Password');
  438. }else if(html.data == 'username taken'){
  439. $.toast().reset('all');
  440. message('Recover Error',' Registration Error - Username/Email Taken','bottom-right','#FFF','warning','10000');
  441. console.error('Organizr Function: Recover Failed - Username/Email Taken');
  442. }
  443. }).fail(function(xhr) {
  444. console.error("Organizr Function: Login Failed");
  445. });
  446. }else{
  447. message('Recover Error','Enter Email','bottom-right','#FFF','warning','10000');
  448. }
  449. });
  450. $(document).on("click", ".open-close", function () {
  451. $("body").toggleClass("show-sidebar");
  452. });
  453. //EDIT GROUP GET ID
  454. $(document).on("click", ".editGroupButton", function () {
  455. $('#edit-group-form [name=groupName]').val($(this).parent().parent().attr("data-group"));
  456. $('#edit-group-form [name=id]').val($(this).parent().parent().attr("data-id"));
  457. $('#edit-group-form [name=groupImage]').val($(this).parent().parent().attr("data-image"));
  458. $('#edit-group-form [name=oldGroupName]').val($(this).parent().parent().attr("data-group"));
  459. });
  460. //EDIT GROUP
  461. $(document).on("click", ".editGroup", function () {
  462. //Create POST Array
  463. var post = {
  464. action:'editUserGroup',
  465. api:'api/?v1/settings/user/manage/groups',
  466. id:$('#edit-group-form [name=id]').val(),
  467. groupName:$('#edit-group-form [name=groupName]').val(),
  468. groupImage:$('#edit-group-form [name=groupImage]').val(),
  469. oldGroupName:$('#edit-group-form [name=oldGroupName]').val(),
  470. messageTitle:'',
  471. messageBody:'Edited User Group '+$('#edit-group-form [name=groupName]').val(),
  472. error:'Organizr Function: User Group API Connection Failed'
  473. };
  474. if (typeof post.id == 'undefined' || post.id == '') {
  475. message('New Group Error',' Could not get Group ID','bottom-right','#FFF','error','5000');
  476. }
  477. if (typeof post.groupName == 'undefined' || post.groupName == '') {
  478. message('New Group Error',' Please set a Group Name','bottom-right','#FFF','warning','5000');
  479. }
  480. if (typeof post.groupImage == 'undefined' || post.groupImage == '') {
  481. message('New Group Error',' Please set a Group Image','bottom-right','#FFF','warning','5000');
  482. }
  483. if(post.id !== '' && post.groupName !== '' && post.groupImage !== '' ){
  484. var callbacks = $.Callbacks();
  485. callbacks.add( buildGroupManagement );
  486. settingsAPI(post,callbacks);
  487. clearForm('#edit-group-form');
  488. $.magnificPopup.close();
  489. }
  490. });
  491. //CHANGE DEFAULT GROUP
  492. $(document).on("click", ".changeDefaultGroup", function () {
  493. //Create POST Array
  494. var post = {
  495. action:'changeDefaultGroup',
  496. api:'api/?v1/settings/user/manage/groups',
  497. id:$(this).parent().parent().attr("data-id"),
  498. oldGroupID:$('#manageGroupTable').find('tr[data-default=true]').attr("data-group-id"),
  499. oldGroupName:$('#manageGroupTable').find('tr[data-default=true]').attr("data-group"),
  500. newGroupID:$(this).parent().parent().attr("data-group-id"),
  501. newGroupName:$(this).parent().parent().attr("data-group"),
  502. messageTitle:'',
  503. messageBody:'Changed Default Group to '+$(this).parent().parent().attr("data-group"),
  504. error:'Organizr Function: User Group API Connection Failed'
  505. };
  506. var callbacks = $.Callbacks();
  507. callbacks.add( buildGroupManagement );
  508. settingsAPI(post,callbacks);
  509. });
  510. //DELETE GROUP
  511. $(document).on("click", ".deleteUserGroup", function () {
  512. //Create POST Array
  513. var post = {
  514. action:'deleteUserGroup',
  515. api:'api/?v1/settings/user/manage/groups',
  516. id:$(this).parent().parent().attr("data-id"),
  517. groupID:$(this).parent().parent().attr("data-group-id"),
  518. groupName:$(this).parent().parent().attr("data-group"),
  519. messageTitle:'',
  520. messageBody:'Deleted User Group '+$(this).parent().parent().attr("data-group"),
  521. error:'Organizr Function: User Group API Connection Failed'
  522. };
  523. var callbacks = $.Callbacks();
  524. callbacks.add( buildGroupManagement );
  525. settingsAPI(post,callbacks);
  526. });
  527. //ADD GROUP
  528. $(document).on("click", ".addNewGroup", function () {
  529. //Create POST Array
  530. var post = {
  531. action:'addUserGroup',
  532. api:'api/?v1/settings/user/manage/groups',
  533. newGroupID:parseInt($('#manageGroupTable').find('tr[data-group-id]:nth-last-child(2)').attr('data-group-id')) + 1,
  534. newGroupName:$('#new-group-form [name=groupName]').val(),
  535. newGroupImage:$('#new-group-form [name=groupImage]').val(),
  536. messageTitle:'',
  537. messageBody:'Created User Group '+$('#new-group-form [name=groupName]').val(),
  538. error:'Organizr Function: User Group API Connection Failed'
  539. };
  540. if (typeof post.newGroupID == 'undefined' || post.newGroupID == '') {
  541. message('New Group Error',' Could not get next Group ID','bottom-right','#FFF','error','5000');
  542. }
  543. if (typeof post.newGroupName == 'undefined' || post.newGroupName == '') {
  544. message('New Group Error',' Please set a Group Name','bottom-right','#FFF','warning','5000');
  545. }
  546. if (typeof post.newGroupImage == 'undefined' || post.newGroupImage == '') {
  547. message('New Group Error',' Please set a Group Image','bottom-right','#FFF','warning','5000');
  548. }
  549. if(post.newGroupID !== '' && post.newGroupName !== '' && post.newGroupImage !== '' ){
  550. var callbacks = $.Callbacks();
  551. callbacks.add( buildGroupManagement );
  552. settingsAPI(post,callbacks);
  553. clearForm('#new-group-form');
  554. $.magnificPopup.close();
  555. }
  556. });
  557. // ADD USER
  558. $(document).on("click", ".addNewUser", function () {
  559. //Create POST Array
  560. var post = {
  561. action:'addNewUser',
  562. api:'api/?v1/settings/user/manage/users',
  563. username:$('#new-user-form [name=username]').val(),
  564. email:$('#new-user-form [name=email]').val(),
  565. password:$('#new-user-form [name=password]').val(),
  566. messageTitle:'',
  567. messageBody:'Added New User: '+$('#new-user-form [name=username]').val(),
  568. error:'Organizr Function: User API Connection Failed'
  569. };
  570. if (typeof post.username == 'undefined' || post.username == '') {
  571. message('New User Error',' Please set a Username','bottom-right','#FFF','error','5000');
  572. }
  573. if (typeof post.email == 'undefined' || post.email == '') {
  574. message('New User Error',' Please set an Email','bottom-right','#FFF','warning','5000');
  575. }
  576. if (typeof post.password == 'undefined' || post.password == '') {
  577. message('New User Error',' Please set a Password','bottom-right','#FFF','warning','5000');
  578. }
  579. if(post.username !== '' && post.email !== '' && post.password !== '' ){
  580. var callbacks = $.Callbacks();
  581. callbacks.add( buildUserManagement );
  582. settingsAPI(post,callbacks);
  583. clearForm('#new-user-form');
  584. $.magnificPopup.close();
  585. }
  586. });
  587. //EDIT GROUP GET ID
  588. $(document).on("click", ".editUserButton", function () {
  589. $('#edit-user-form [name=username]').val($(this).parent().parent().attr("data-username"));
  590. $('#edit-user-form [name=id]').val($(this).parent().parent().attr("data-id"));
  591. $('#edit-user-form [name=email]').val($(this).parent().parent().attr("data-email"));
  592. });
  593. //EDIT GROUP
  594. $(document).on("click", ".editUserAdmin", function () {
  595. //Create POST Array
  596. var post = {
  597. action:'editUser',
  598. api:'api/?v1/settings/user/manage/users',
  599. id:$('#edit-user-form [name=id]').val(),
  600. username:$('#edit-user-form [name=username]').val(),
  601. email:$('#edit-user-form [name=email]').val(),
  602. password:$('#edit-user-form [name=password]').val(),
  603. messageTitle:'',
  604. messageBody:'Edited User '+$('#edit-user-form [name=username]').val(),
  605. error:'Organizr Function: API Connection Failed'
  606. };
  607. if (typeof post.id == 'undefined' || post.id == '') {
  608. message('Edit User Error',' Could not get User ID','bottom-right','#FFF','error','5000');
  609. }
  610. if (typeof post.username == 'undefined' || post.username == '') {
  611. message('Edit User Error',' Please set a Username','bottom-right','#FFF','warning','5000');
  612. }
  613. if (typeof post.email == 'undefined' || post.email == '') {
  614. message('Edit User Error',' Please set a User Email','bottom-right','#FFF','warning','5000');
  615. }
  616. if (post.password !== '' && post.password !== $('#edit-user-form [name=password2]').val()){
  617. message('Edit User Error',' Passwords do not match!','bottom-right','#FFF','warning','5000');
  618. }
  619. if(post.id !== '' && post.username !== '' && post.email !== '' ){
  620. var callbacks = $.Callbacks();
  621. callbacks.add( buildUserManagement );
  622. settingsAPI(post,callbacks);
  623. clearForm('#edit-user-form');
  624. $.magnificPopup.close();
  625. }
  626. });
  627. // CHANGE USER GROUP
  628. $(document).on("change", ".userGroupSelect", function () {
  629. //Create POST Array
  630. var post = {
  631. action:'changeGroup',
  632. api:'api/?v1/settings/user/manage/users',
  633. id:$(this).parent().parent().attr("data-id"),
  634. username:$(this).parent().parent().attr("data-username"),
  635. oldGroup:$(this).parent().parent().attr("data-group"),
  636. newGroupID:$(this).find("option:selected").val(),
  637. newGroupName:$(this).find("option:selected").text(),
  638. messageTitle:'',
  639. messageBody:'User Info updated for '+$(this).parent().parent().attr("data-username"),
  640. error:'Organizr Function: User API Connection Failed'
  641. };
  642. var callbacks = $.Callbacks();
  643. callbacks.add( buildUserManagement );
  644. settingsAPI(post,callbacks);
  645. });
  646. // DELETE USER
  647. //DELETE GROUP
  648. $(document).on("click", ".deleteUser", function () {
  649. var user = $(this);
  650. swal({
  651. title: window.lang.translate('Delete ')+user.parent().parent().attr("data-username")+'?',
  652. type: "warning",
  653. showCancelButton: true,
  654. confirmButtonColor: "#DD6B55",
  655. confirmButtonText: window.lang.translate('Yes'),
  656. cancelButtonText: window.lang.translate('No'),
  657. closeOnConfirm: true,
  658. closeOnCancel: true
  659. }, function(isConfirm){
  660. if (isConfirm) {
  661. //Create POST Array
  662. var post = {
  663. action:'deleteUser',
  664. api:'api/?v1/settings/user/manage/users',
  665. id:user.parent().parent().attr("data-id"),
  666. username:user.parent().parent().attr("data-username"),
  667. messageTitle:'',
  668. messageBody:window.lang.translate('Deleted User')+': '+user.parent().parent().attr("data-username"),
  669. error:'Organizr Function: User API Connection Failed'
  670. };
  671. var callbacks = $.Callbacks();
  672. callbacks.add( buildUserManagement );
  673. settingsAPI(post,callbacks);
  674. }
  675. });
  676. });
  677. // CHANGE TAB GROUP
  678. $(document).on("change", ".tabGroupSelect", function () {
  679. //Create POST Array
  680. var post = {
  681. action:'changeGroup',
  682. api:'api/?v1/settings/tab/editor/tabs',
  683. id:$(this).parent().parent().attr("data-id"),
  684. tab:$(this).parent().parent().attr("data-name"),
  685. oldGroupID:$(this).parent().parent().attr("data-group-id"),
  686. newGroupID:$(this).find("option:selected").val(),
  687. newGroupName:$(this).find("option:selected").text(),
  688. messageTitle:'',
  689. messageBody:'Tab Info updated for '+$(this).parent().parent().attr("data-name"),
  690. error:'Organizr Function: Tab API Connection Failed'
  691. };
  692. var callbacks = $.Callbacks();
  693. callbacks.add( buildTabEditor );
  694. settingsAPI(post,callbacks);
  695. });
  696. // CHANGE TAB CATEGORY
  697. $(document).on("change", ".tabCategorySelect", function () {
  698. //Create POST Array
  699. var post = {
  700. action:'changeCategory',
  701. api:'api/?v1/settings/tab/editor/tabs',
  702. id:$(this).parent().parent().attr("data-id"),
  703. tab:$(this).parent().parent().attr("data-name"),
  704. newCategoryID:$(this).find("option:selected").val(),
  705. newCategoryName:$(this).find("option:selected").text(),
  706. messageTitle:'',
  707. messageBody:'Tab Info updated for '+$(this).parent().parent().attr("data-name"),
  708. error:'Organizr Function: Tab API Connection Failed'
  709. };
  710. var callbacks = $.Callbacks();
  711. callbacks.add( buildTabEditor );
  712. settingsAPI(post,callbacks);
  713. });
  714. // CHANGE TAB TYPE
  715. $(document).on("change", ".tabTypeSelect", function () {
  716. //Create POST Array
  717. var post = {
  718. action:'changeType',
  719. api:'api/?v1/settings/tab/editor/tabs',
  720. id:$(this).parent().parent().attr("data-id"),
  721. tab:$(this).parent().parent().attr("data-name"),
  722. newTypeID:$(this).find("option:selected").val(),
  723. newTypeName:$(this).find("option:selected").text(),
  724. messageTitle:'',
  725. messageBody:'Tab Info updated for '+$(this).parent().parent().attr("data-name"),
  726. error:'Organizr Function: Tab API Connection Failed'
  727. };
  728. var callbacks = $.Callbacks();
  729. callbacks.add( buildTabEditor );
  730. settingsAPI(post,callbacks);
  731. });
  732. // CHANGE ENABLED TAB
  733. $(document).on("change", ".enabledSwitch", function () {
  734. //Create POST Array
  735. var post = {
  736. action:'changeEnabled',
  737. api:'api/?v1/settings/tab/editor/tabs',
  738. id:$(this).parent().parent().attr("data-id"),
  739. tab:$(this).parent().parent().attr("data-name"),
  740. tabEnabled:$(this).prop("checked") ? 1 : 0,
  741. tabEnabledWord:$(this).prop("checked") ? "On" : "Off",
  742. messageTitle:'',
  743. messageBody:'Tab Info updated for '+$(this).parent().parent().attr("data-name"),
  744. error:'Organizr Function: Tab API Connection Failed'
  745. };
  746. var callbacks = $.Callbacks();
  747. callbacks.add( buildTabEditor );
  748. settingsAPI(post,callbacks);
  749. });
  750. // CHANGE SPLASH TAB
  751. $(document).on("change", ".splashSwitch", function () {
  752. //Create POST Array
  753. var post = {
  754. action:'changeSplash',
  755. api:'api/?v1/settings/tab/editor/tabs',
  756. id:$(this).parent().parent().attr("data-id"),
  757. tab:$(this).parent().parent().attr("data-name"),
  758. tabSplash:$(this).prop("checked") ? 1 : 0,
  759. tabSplashWord:$(this).prop("checked") ? "On" : "Off",
  760. messageTitle:'',
  761. messageBody:'Tab Info updated for '+$(this).parent().parent().attr("data-name"),
  762. error:'Organizr Function: Tab API Connection Failed'
  763. };
  764. var callbacks = $.Callbacks();
  765. callbacks.add( buildTabEditor );
  766. settingsAPI(post,callbacks);
  767. });
  768. // CHANGE DEFAULT TAB
  769. $(document).on("change", ".defaultSwitch", function () {
  770. //Create POST Array
  771. var post = {
  772. action:'changeDefault',
  773. api:'api/?v1/settings/tab/editor/tabs',
  774. id:$(this).parent().parent().parent().attr("data-id"),
  775. tab:$(this).parent().parent().parent().attr("data-name"),
  776. messageTitle:'',
  777. messageBody:'Changed Default Tab to: '+$(this).parent().parent().parent().attr("data-name"),
  778. error:'Organizr Function: Tab API Connection Failed'
  779. };
  780. var callbacks = $.Callbacks();
  781. callbacks.add( buildTabEditor );
  782. settingsAPI(post,callbacks);
  783. });
  784. //DELETE TAB
  785. $(document).on("click", ".deleteTab", function () {
  786. var user = $(this);
  787. swal({
  788. title: window.lang.translate('Delete ')+user.parent().parent().attr("data-name")+'?',
  789. type: "warning",
  790. showCancelButton: true,
  791. confirmButtonColor: "#DD6B55",
  792. confirmButtonText: window.lang.translate('Yes'),
  793. cancelButtonText: window.lang.translate('No'),
  794. closeOnConfirm: true,
  795. closeOnCancel: true
  796. }, function(isConfirm){
  797. if (isConfirm) {
  798. //Create POST Array
  799. var post = {
  800. action:'deleteTab',
  801. api:'api/?v1/settings/tab/editor/tabs',
  802. id:user.parent().parent().attr("data-id"),
  803. tab:user.parent().parent().attr("data-name"),
  804. messageTitle:'',
  805. messageBody:window.lang.translate('Deleted Tab')+': '+user.parent().parent().attr("data-name"),
  806. error:'Organizr Function: Tab Editor API Connection Failed'
  807. };
  808. var callbacks = $.Callbacks();
  809. callbacks.add( buildTabEditor );
  810. settingsAPI(post,callbacks);
  811. }
  812. });
  813. });
  814. //EDIT TAB GET ID
  815. $(document).on("click", ".editTabButton", function () {
  816. $('#edit-tab-form [name=tabName]').val($(this).parent().parent().attr("data-name"));
  817. $('#edit-tab-form [name=tabURL]').val($(this).parent().parent().attr("data-url"));
  818. $('#edit-tab-form [name=tabImage]').val($(this).parent().parent().attr("data-image"));
  819. $('#edit-tab-form [name=id]').val($(this).parent().parent().attr("data-id"));
  820. if( $(this).parent().parent().attr("data-url").indexOf('/?v') > 0){
  821. $('#edit-tab-form [name=tabURL]').prop('disabled', 'true');
  822. }else{
  823. $('#edit-tab-form [name=tabURL]').prop('disabled', null);
  824. }
  825. });
  826. //EDIT TAB
  827. $(document).on("click", ".editTab", function () {
  828. //Create POST Array
  829. var post = {
  830. action:'editTab',
  831. api:'api/?v1/settings/tab/editor/tabs',
  832. id:$('#edit-tab-form [name=id]').val(),
  833. tabName:$('#edit-tab-form [name=tabName]').val(),
  834. tabImage:$('#edit-tab-form [name=tabImage]').val(),
  835. tabURL:$('#edit-tab-form [name=tabURL]').val(),
  836. messageTitle:'',
  837. messageBody:'Edited Tab '+$('#edit-tab-form [name=tabName]').val(),
  838. error:'Organizr Function: Tab Editor API Connection Failed'
  839. };
  840. if (typeof post.id == 'undefined' || post.id == '') {
  841. message('Edit Tab Error',' Could not get Tab ID','bottom-right','#FFF','error','5000');
  842. }
  843. if (typeof post.tabName == 'undefined' || post.tabName == '') {
  844. message('Edit Tab Error',' Please set a Tab Name','bottom-right','#FFF','warning','5000');
  845. }
  846. if (typeof post.tabImage == 'undefined' || post.tabImage == '') {
  847. message('Edit Tab Error',' Please set a Tab Image','bottom-right','#FFF','warning','5000');
  848. }
  849. if (typeof post.tabURL == 'undefined' || post.tabURL == '') {
  850. message('Edit Tab Error',' Please set a Tab URL','bottom-right','#FFF','warning','5000');
  851. }
  852. if(post.id !== '' && post.tabName !== '' && post.tabImage !== '' && post.tabURL !== '' ){
  853. var callbacks = $.Callbacks();
  854. callbacks.add( buildTabEditor );
  855. settingsAPI(post,callbacks);
  856. clearForm('#edit-tab-form');
  857. $.magnificPopup.close();
  858. }
  859. });
  860. //ADD NEW TAB
  861. $(document).on("click", ".addNewTab", function () {
  862. //Create POST Array
  863. var post = {
  864. action:'addNewTab',
  865. api:'api/?v1/settings/tab/editor/tabs',
  866. tabOrder:parseInt($('#tabEditorTable').find('tr[data-order]').last().attr('data-order')) + 1,
  867. tabName:$('#new-tab-form [name=tabName]').val(),
  868. tabImage:$('#new-tab-form [name=tabImage]').val(),
  869. tabURL:$('#new-tab-form [name=tabURL]').val(),
  870. tabGroupID:1,
  871. tabEnabled:0,
  872. tabDefault:0,
  873. tabType:1,
  874. messageTitle:'',
  875. messageBody:'Created Tab '+$('#new-tab-form [name=tabName]').val(),
  876. error:'Organizr Function: Tab API Connection Failed'
  877. };
  878. if (typeof post.tabOrder == 'undefined' || post.tabOrder == '') {
  879. message('New Tab Error',' Could not get next Group ID','bottom-right','#FFF','error','5000');
  880. }
  881. if (typeof post.tabName == 'undefined' || post.tabName == '') {
  882. message('New Tab Error',' Please set a Tab Name','bottom-right','#FFF','error','5000');
  883. }
  884. if (typeof post.tabURL == 'undefined' || post.tabURL == '') {
  885. message('New Tab Error',' Please set a Tab URL','bottom-right','#FFF','warning','5000');
  886. }
  887. if (typeof post.tabImage == 'undefined' || post.tabImage == '') {
  888. message('New Tab Error',' Please set a Tab Image','bottom-right','#FFF','warning','5000');
  889. }
  890. if(post.tabOrder !== '' && post.tabName !== '' && post.tabURL !== '' && post.tabImage !== '' ){
  891. var callbacks = $.Callbacks();
  892. callbacks.add( buildTabEditor );
  893. settingsAPI(post,callbacks);
  894. clearForm('#new-tab-form');
  895. $.magnificPopup.close();
  896. }
  897. });
  898. //ADD NEW CATEGORY
  899. $(document).on("click", ".addNewCategory", function () {
  900. //Create POST
  901. var nextID = [];
  902. $($('#categoryEditorTable').find('tr[data-category-id]')).each(function () {
  903. nextID.push($(this).attr('data-category-id'));
  904. });
  905. var post = {
  906. action:'addNewCategory',
  907. api:'api/?v1/settings/tab/editor/categories',
  908. categoryOrder:parseInt($('#categoryEditorTable').find('tr[data-order]').last().attr('data-order')) + 1,
  909. categoryName:$('#new-category-form [name=name]').val(),
  910. categoryImage:$('#new-category-form [name=image]').val(),
  911. categoryID:Math.max.apply( null, nextID ) + 1,
  912. categoryDefault:0,
  913. messageTitle:'',
  914. messageBody:'Created Category '+$('#new-category-form [name=name]').val(),
  915. error:'Organizr Function: API Connection Failed'
  916. };
  917. console.log(post);
  918. if (typeof post.categoryID == 'undefined' || post.categoryID == '') {
  919. message('New Category Error',' Could not get next Category ID','bottom-right','#FFF','error','5000');
  920. }
  921. if (typeof post.categoryName == 'undefined' || post.categoryName == '') {
  922. message('New Category Error',' Please set a Category Name','bottom-right','#FFF','error','5000');
  923. }
  924. if (typeof post.categoryOrder == 'undefined' || post.categoryOrder == '') {
  925. message('New Category Error',' Could not get Category Order','bottom-right','#FFF','warning','5000');
  926. }
  927. if (typeof post.categoryImage == 'undefined' || post.categoryImage == '') {
  928. message('New Category Error',' Please set a Category Image','bottom-right','#FFF','warning','5000');
  929. }
  930. if(post.categoryID !== '' && post.categoryName !== '' && post.categoryOrder !== '' && post.categoryImage !== '' ){
  931. var callbacks = $.Callbacks();
  932. callbacks.add( buildCategoryEditor );
  933. settingsAPI(post,callbacks);
  934. clearForm('#new-category-form');
  935. $.magnificPopup.close();
  936. }
  937. });
  938. //DELETE CATEGORY
  939. $(document).on("click", ".deleteCategory", function () {
  940. var category = $(this);
  941. swal({
  942. title: window.lang.translate('Delete ')+category.parent().parent().attr("data-name")+'?',
  943. type: "warning",
  944. showCancelButton: true,
  945. confirmButtonColor: "#DD6B55",
  946. confirmButtonText: window.lang.translate('Yes'),
  947. cancelButtonText: window.lang.translate('No'),
  948. closeOnConfirm: true,
  949. closeOnCancel: true
  950. }, function(isConfirm){
  951. if (isConfirm) {
  952. //Create POST Array
  953. var post = {
  954. action:'deleteCategory',
  955. api:'api/?v1/settings/tab/editor/categories',
  956. id:category.parent().parent().attr("data-id"),
  957. category:category.parent().parent().attr("data-name"),
  958. messageTitle:'',
  959. messageBody:window.lang.translate('Deleted Category')+': '+category.parent().parent().attr("data-name"),
  960. error:'Organizr Function: API Connection Failed'
  961. };
  962. var callbacks = $.Callbacks();
  963. callbacks.add( buildCategoryEditor );
  964. settingsAPI(post,callbacks);
  965. }
  966. });
  967. });
  968. //EDIT CATEGORY GET ID
  969. $(document).on("click", ".editCategoryButton", function () {
  970. $('#edit-category-form [name=name]').val($(this).parent().parent().attr("data-name"));
  971. $('#edit-category-form [name=image]').val($(this).parent().parent().attr("data-image"));
  972. $('#edit-category-form [name=id]').val($(this).parent().parent().attr("data-id"));
  973. });
  974. //EDIT CATEGORY
  975. $(document).on("click", ".editCategory", function () {
  976. //Create POST Array
  977. var post = {
  978. action:'editCategory',
  979. api:'api/?v1/settings/tab/editor/categories',
  980. id:$('#edit-category-form [name=id]').val(),
  981. name:$('#edit-category-form [name=name]').val(),
  982. image:$('#edit-category-form [name=image]').val(),
  983. messageTitle:'',
  984. messageBody:'Edited Category '+$('#edit-category-form [name=name]').val(),
  985. error:'Organizr Function: API Connection Failed'
  986. };
  987. console.log(post)
  988. if (typeof post.id == 'undefined' || post.id == '') {
  989. message('Edit Tab Error',' Could not get Tab ID','bottom-right','#FFF','error','5000');
  990. }
  991. if (typeof post.name == 'undefined' || post.name == '') {
  992. message('Edit Tab Error',' Please set a Tab Name','bottom-right','#FFF','warning','5000');
  993. }
  994. if (typeof post.image == 'undefined' || post.image == '') {
  995. message('Edit Tab Error',' Please set a Tab Image','bottom-right','#FFF','warning','5000');
  996. }
  997. if(post.id !== '' && post.name !== '' && post.image !== ''){
  998. var callbacks = $.Callbacks();
  999. callbacks.add( buildCategoryEditor );
  1000. settingsAPI(post,callbacks);
  1001. clearForm('#edit-category-form');
  1002. $.magnificPopup.close();
  1003. }
  1004. });
  1005. //CHANGE DEFAULT CATEGORY
  1006. $(document).on("click", ".changeDefaultCategory", function () {
  1007. //Create POST Array
  1008. var post = {
  1009. action:'changeDefault',
  1010. api:'api/?v1/settings/tab/editor/categories',
  1011. id:$(this).parent().parent().attr("data-id"),
  1012. oldCategoryName:$('#categoryEditorTable').find('tr[data-default=true]').attr("data-name"),
  1013. newCategoryName:$(this).parent().parent().attr("data-name"),
  1014. messageTitle:'',
  1015. messageBody:'Changed Default Category to '+$(this).parent().parent().attr("data-name"),
  1016. error:'Organizr Function: API Connection Failed'
  1017. };
  1018. var callbacks = $.Callbacks();
  1019. callbacks.add( buildCategoryEditor );
  1020. settingsAPI(post,callbacks);
  1021. });
  1022. // CHANGE CUSTOMIZE Options and CSS Save
  1023. $(document).on("click", ".saveCss", function () {
  1024. $('.cssTextarea').val(cssEditor.getValue()).trigger('change');
  1025. });
  1026. $(document).on("click", ".savecustomHTMLoneTextarea", function () {
  1027. $('.customHTMLoneTextarea').val(customHTMLoneEditor.getValue()).trigger('change');
  1028. });
  1029. $(document).on("click", ".savecustomHTMLtwoTextarea", function () {
  1030. $('.customHTMLtwoTextarea').val(customHTMLtwoEditor.getValue()).trigger('change');
  1031. });
  1032. $(document).on('change asColorPicker::close', '#customize-appearance-form :input', function(e) {
  1033. $(this).attr('data-changed', true);
  1034. switch ($(this).attr('type')) {
  1035. case 'switch':
  1036. case 'checkbox':
  1037. var value = $(this).prop("checked") ? true : false;
  1038. break;
  1039. default:
  1040. var value = $(this).val();
  1041. }
  1042. var post = {
  1043. action:'editCustomizeAppearance',
  1044. api:'api/?v1/settings/customize/appearance',
  1045. name:$(this).attr("name"),
  1046. value:value,
  1047. messageTitle:'',
  1048. messageBody:'Updated Value for '+$(this).attr("name"),
  1049. error:'Organizr Function: API Connection Failed'
  1050. };
  1051. $('#customize-appearance-reload').removeClass('hidden');
  1052. var callbacks = $.Callbacks();
  1053. //callbacks.add( buildCustomizeAppearance );
  1054. settingsAPI(post,callbacks);
  1055. if($(this).hasClass('themeChanger')){
  1056. changeTheme(value);
  1057. }
  1058. if($(this).hasClass('styleChanger')){
  1059. changeStyle(value);
  1060. }
  1061. });
  1062. //DELETE IMAGE
  1063. $(document).on("click", ".deleteImage", function () {
  1064. var image = $(this);
  1065. swal({
  1066. title: window.lang.translate('Delete ')+image.attr("data-image-name")+'?',
  1067. type: "warning",
  1068. showCancelButton: true,
  1069. confirmButtonColor: "#DD6B55",
  1070. confirmButtonText: window.lang.translate('Yes'),
  1071. cancelButtonText: window.lang.translate('No'),
  1072. closeOnConfirm: true,
  1073. closeOnCancel: true
  1074. }, function(isConfirm){
  1075. if (isConfirm) {
  1076. //Create POST Array
  1077. var post = {
  1078. action:'deleteImage',
  1079. api:'api/?v1/settings/image/manager/view',
  1080. imageName:image.attr("data-image-name"),
  1081. imagePath:image.attr("data-image-path"),
  1082. messageTitle:'',
  1083. messageBody:window.lang.translate('Deleted Image')+': '+image.attr("data-image-name"),
  1084. error:'Organizr Function: User API Connection Failed'
  1085. };
  1086. var callbacks = $.Callbacks();
  1087. callbacks.add( buildImageManagerView );
  1088. settingsAPI(post,callbacks);
  1089. }
  1090. });
  1091. });
  1092. // RELOAD Page
  1093. $(document).on("click", ".reload", function () {
  1094. location.reload();
  1095. });
  1096. // ENABLE PLUGIN
  1097. $(document).on('click', '.enablePlugin', function() {
  1098. var post = {
  1099. action:'enable',
  1100. api:'api/?v1/settings/plugins/list',
  1101. name:$(this).attr('data-plugin-name'),
  1102. configName:$(this).attr('data-config-name'),
  1103. messageTitle:'',
  1104. messageBody:'Enabling '+$(this).attr('data-plugin-name'),
  1105. error:'Organizr Function: API Connection Failed'
  1106. };
  1107. //$('#customize-appearance-reload').removeClass('hidden');
  1108. var callbacks = $.Callbacks();
  1109. //callbacks.add( buildCustomizeAppearance );
  1110. settingsAPI(post,callbacks);
  1111. ajaxloader(".content-wrap","in");
  1112. setTimeout(function(){ buildPlugins();ajaxloader(); }, 3000);
  1113. });
  1114. // DISABLE PLUGIN
  1115. $(document).on('click', '.disablePlugin', function() {
  1116. var plugin = $(this);
  1117. swal({
  1118. title: window.lang.translate('Disable')+' '+plugin.attr("data-plugin-name")+'?',
  1119. type: "warning",
  1120. showCancelButton: true,
  1121. confirmButtonColor: "#DD6B55",
  1122. confirmButtonText: window.lang.translate('Yes'),
  1123. cancelButtonText: window.lang.translate('No'),
  1124. closeOnConfirm: true,
  1125. closeOnCancel: true
  1126. }, function(isConfirm){
  1127. if (isConfirm) {
  1128. //Create POST Array
  1129. var post = {
  1130. action:'disable',
  1131. api:'api/?v1/settings/plugins/list',
  1132. name:plugin.attr('data-plugin-name'),
  1133. configName:plugin.attr('data-config-name'),
  1134. messageTitle:'',
  1135. messageBody:'Disabling '+plugin.attr('data-plugin-name'),
  1136. error:'Organizr Function: API Connection Failed'
  1137. };
  1138. //$('#customize-appearance-reload').removeClass('hidden');
  1139. var callbacks = $.Callbacks();
  1140. //callbacks.add( buildCustomizeAppearance );
  1141. settingsAPI(post,callbacks);
  1142. ajaxloader(".content-wrap","in");
  1143. setTimeout(function(){ buildPlugins();ajaxloader(); }, 3000);
  1144. }
  1145. });
  1146. });
  1147. // SSO Option change
  1148. $(document).on('change', '#sso-form :input', function(e) {
  1149. var input = $(this);
  1150. switch ($(this).attr('type')) {
  1151. case 'switch':
  1152. case 'checkbox':
  1153. var value = $(this).prop("checked") ? true : false;
  1154. break;
  1155. default:
  1156. var value = $(this).val();
  1157. }
  1158. var post = {
  1159. api:'api/?v1/update/config',
  1160. name:$(this).attr("name"),
  1161. type:$(this).attr("data-type"),
  1162. value:value,
  1163. messageTitle:'',
  1164. messageBody:'Updated Value for '+$(this).parent().parent().find('label').text(),
  1165. error:'Organizr Function: API Connection Failed'
  1166. };
  1167. var callbacks = $.Callbacks();
  1168. //callbacks.add( buildCustomizeAppearance );
  1169. settingsAPI(post,callbacks);
  1170. //disable button then renable
  1171. $('#sso-form :input').prop('disabled', 'true');
  1172. setTimeout(
  1173. function(){
  1174. $('#sso-form :input').prop('disabled', null);
  1175. input.emulateTab();
  1176. },
  1177. 2000
  1178. );
  1179. });
  1180. // MAIN SETTINGS PAGE
  1181. $(document).on('change', '#settings-main-form :input', function(e) {
  1182. var input = $(this);
  1183. switch ($(this).attr('type')) {
  1184. case 'switch':
  1185. case 'checkbox':
  1186. var value = $(this).prop("checked") ? true : false;
  1187. break;
  1188. default:
  1189. var value = $(this).val();
  1190. }
  1191. var post = {
  1192. api:'api/?v1/update/config',
  1193. name:$(this).attr("name"),
  1194. type:$(this).attr("data-type"),
  1195. value:value,
  1196. messageTitle:'',
  1197. messageBody:'Updated Value for '+$(this).parent().parent().find('label').text(),
  1198. error:'Organizr Function: API Connection Failed'
  1199. };
  1200. var callbacks = $.Callbacks();
  1201. //callbacks.add( buildCustomizeAppearance );
  1202. settingsAPI(post,callbacks);
  1203. //disable button then renable
  1204. $('#settings-main-form :input').prop('disabled', 'true');
  1205. setTimeout(
  1206. function(){
  1207. $('#settings-main-form :input').prop('disabled', null);
  1208. input.emulateTab();
  1209. },
  1210. 2000
  1211. );
  1212. });
  1213. // AUTH BACKEND HIDE SHOW
  1214. $(document).on('change', '#authSelect, #authBackendSelect', function(e) {
  1215. changeAuth();
  1216. });
  1217. $(document).on("click", ".getSSOPlexToken", function () {
  1218. $('.ssoPlexTokenMessage').text("Grabbing Token");
  1219. $('.ssoPlexTokenHeader').addClass('panel-info').removeClass('panel-warning').removeClass('panel-danger');
  1220. var plex_username = $('#sso-plex-token-form [name=username]').val().trim();
  1221. var plex_password = $('#sso-plex-token-form [name=password]').val().trim();
  1222. if ((plex_password !== '') && (plex_password !== '')) {
  1223. $.ajax({
  1224. type: 'POST',
  1225. headers: {
  1226. 'X-Plex-Product':'Organizr',
  1227. 'X-Plex-Version':'2.0',
  1228. 'X-Plex-Client-Identifier':'01010101-10101010'
  1229. },
  1230. url: 'https://plex.tv/users/sign_in.json',
  1231. data: {
  1232. 'user[login]': plex_username,
  1233. 'user[password]': plex_password,
  1234. force: true
  1235. },
  1236. cache: false,
  1237. async: true,
  1238. complete: function(xhr, status) {
  1239. var result = $.parseJSON(xhr.responseText);
  1240. if (xhr.status === 201) {
  1241. $('.ssoPlexTokenMessage').text(xhr.statusText);
  1242. $('.ssoPlexTokenHeader').addClass('panel-success').removeClass('panel-info').removeClass('panel-warning').removeClass('panel-danger');
  1243. $('#sso-form [name=plexToken]').val(result.user.authToken);
  1244. $('#sso-form [name=plexToken]').change();
  1245. } else {
  1246. $('.ssoPlexTokenMessage').text(xhr.statusText);
  1247. $('.ssoPlexTokenHeader').addClass('panel-danger').removeClass('panel-info').removeClass('panel-warning');
  1248. }
  1249. }
  1250. });
  1251. } else {
  1252. $('.ssoPlexTokenMessage').text("Enter Username and Password");
  1253. $('.ssoPlexTokenHeader').addClass('panel-warning').removeClass('panel-info').removeClass('panel-danger');
  1254. }
  1255. });
  1256. $(document).on("click", ".getPlexMachineSSO", function () {
  1257. var plex_token = $('#sso-form [name=plexToken]').val().trim();
  1258. if (plex_token !== '') {
  1259. $('.ssoPlexMachineMessage').text("Grabbing List");
  1260. $('.ssoPlexMachineHeader').addClass('panel-info').removeClass('panel-warning').removeClass('panel-danger');
  1261. $.ajax({
  1262. type: 'GET',
  1263. headers: {
  1264. 'X-Plex-Product':'Organizr',
  1265. 'X-Plex-Version':'2.0',
  1266. 'X-Plex-Client-Identifier':'01010101-10101010',
  1267. 'X-Plex-Token':plex_token,
  1268. },
  1269. url: 'https://plex.tv/pms/servers.xml',
  1270. cache: false,
  1271. async: true,
  1272. complete: function(xhr, status) {
  1273. var result = $.parseXML(xhr.responseText);
  1274. if (xhr.status === 200) {
  1275. $('.ssoPlexMachineMessage').text('Choose Plex Server');
  1276. $('.ssoPlexMachineHeader').addClass('panel-success').removeClass('panel-info').removeClass('panel-warning');
  1277. var machines = '<option lang="en">Choose Plex Machine</option>';
  1278. $('Server', result).each(function(){
  1279. if($(this).attr('owned') == 1){
  1280. var name = $(this).attr('name');
  1281. var machine = $(this).attr('machineIdentifier');
  1282. machines += '<option value="'+machine+'">'+name+'</option>';
  1283. }
  1284. })
  1285. var listing = `<select class="form-control" id="ssoPlexMachineSelector" data-type="select">`+machines+`</select>`;
  1286. $('.ssoPlexMachineListing').html(listing);
  1287. } else {
  1288. $('.ssoPlexTokenMessage').text(xhr.statusText);
  1289. $('.ssoPlexTokenHeader').addClass('panel-danger').removeClass('panel-info').removeClass('panel-warning');
  1290. }
  1291. }
  1292. });
  1293. } else {
  1294. $('.ssoPlexMachineMessage').text("Plex Token Needed");
  1295. $('.ssoPlexMachineHeader').addClass('panel-warning').removeClass('panel-info').removeClass('panel-danger');
  1296. }
  1297. });
  1298. $(document).on('change', '#ssoPlexMachineSelector', function(e) {
  1299. $('#sso-form [name=plexID]').val($(this).val());
  1300. $('#sso-form [name=plexID]').change();
  1301. });
  1302. $(document).on("click", ".getauthPlexToken", function () {
  1303. $('.authPlexTokenMessage').text("Grabbing Token");
  1304. $('.authPlexTokenHeader').addClass('panel-info').removeClass('panel-warning').removeClass('panel-danger');
  1305. var plex_username = $('#auth-plex-token-form [name=username]').val().trim();
  1306. var plex_password = $('#auth-plex-token-form [name=password]').val().trim();
  1307. if ((plex_password !== '') && (plex_password !== '')) {
  1308. $.ajax({
  1309. type: 'POST',
  1310. headers: {
  1311. 'X-Plex-Product':'Organizr',
  1312. 'X-Plex-Version':'2.0',
  1313. 'X-Plex-Client-Identifier':'01010101-10101010'
  1314. },
  1315. url: 'https://plex.tv/users/sign_in.json',
  1316. data: {
  1317. 'user[login]': plex_username,
  1318. 'user[password]': plex_password,
  1319. force: true
  1320. },
  1321. cache: false,
  1322. async: true,
  1323. complete: function(xhr, status) {
  1324. var result = $.parseJSON(xhr.responseText);
  1325. if (xhr.status === 201) {
  1326. $('.authPlexTokenMessage').text(xhr.statusText);
  1327. $('.authPlexTokenHeader').addClass('panel-success').removeClass('panel-info').removeClass('panel-warning').removeClass('panel-danger');
  1328. $('#settings-main-form [name=plexToken]').val(result.user.authToken);
  1329. $('#settings-main-form [name=plexToken]').change();
  1330. } else {
  1331. $('.authPlexTokenMessage').text(xhr.statusText);
  1332. $('.authPlexTokenHeader').addClass('panel-danger').removeClass('panel-info').removeClass('panel-warning');
  1333. }
  1334. }
  1335. });
  1336. } else {
  1337. $('.authPlexTokenMessage').text("Enter Username and Password");
  1338. $('.authPlexTokenHeader').addClass('panel-warning').removeClass('panel-info').removeClass('panel-danger');
  1339. }
  1340. });
  1341. $(document).on("click", ".getPlexMachineAuth", function () {
  1342. var plex_token = $('#settings-main-form [name=plexToken]').val().trim();
  1343. if (plex_token !== '') {
  1344. $('.authPlexMachineMessage').text("Grabbing List");
  1345. $('.authPlexMachineHeader').addClass('panel-info').removeClass('panel-warning').removeClass('panel-danger');
  1346. $.ajax({
  1347. type: 'GET',
  1348. headers: {
  1349. 'X-Plex-Product':'Organizr',
  1350. 'X-Plex-Version':'2.0',
  1351. 'X-Plex-Client-Identifier':'01010101-10101010',
  1352. 'X-Plex-Token':plex_token,
  1353. },
  1354. url: 'https://plex.tv/pms/servers.xml',
  1355. cache: false,
  1356. async: true,
  1357. complete: function(xhr, status) {
  1358. var result = $.parseXML(xhr.responseText);
  1359. if (xhr.status === 200) {
  1360. $('.authPlexMachineMessage').text('Choose Plex Server');
  1361. $('.authPlexMachineHeader').addClass('panel-success').removeClass('panel-info').removeClass('panel-warning');
  1362. var machines = '<option lang="en">Choose Plex Machine</option>';
  1363. $('Server', result).each(function(){
  1364. if($(this).attr('owned') == 1){
  1365. var name = $(this).attr('name');
  1366. var machine = $(this).attr('machineIdentifier');
  1367. machines += '<option value="'+machine+'">'+name+'</option>';
  1368. }
  1369. })
  1370. var listing = `<select class="form-control" id="authPlexMachineSelector" data-type="select">`+machines+`</select>`;
  1371. $('.authPlexMachineListing').html(listing);
  1372. } else {
  1373. $('.authPlexTokenMessage').text(xhr.statusText);
  1374. $('.authPlexTokenHeader').addClass('panel-danger').removeClass('panel-info').removeClass('panel-warning');
  1375. }
  1376. }
  1377. });
  1378. } else {
  1379. $('.authPlexMachineMessage').text("Plex Token Needed");
  1380. $('.authPlexMachineHeader').addClass('panel-warning').removeClass('panel-info').removeClass('panel-danger');
  1381. }
  1382. });
  1383. $(document).on('change', '#authPlexMachineSelector', function(e) {
  1384. $('#settings-main-form [name=plexID]').val($(this).val());
  1385. $('#settings-main-form [name=plexID]').change();
  1386. });
  1387. $(document).on("click", ".closeErrorPage", function () {
  1388. $('.error-page').html('');
  1389. $('.error-page').fadeOut();
  1390. });
  1391. // test Location
  1392. $(document).on("click", ".testPath", function () {
  1393. var path = $("#form-location").val();
  1394. if (typeof path == 'undefined' || path == '') {
  1395. message('Path Error',' Please enter a path for DB','bottom-right','#FFF','warning','10000');
  1396. }else{
  1397. organizrAPI('POST','api/?v1/wizard_path',{path:path}).success(function(data) {
  1398. var html = JSON.parse(data);
  1399. console.log(html)
  1400. if(html.data == true){
  1401. message('Path',' Path is good to go','bottom-right','#FFF','success','10000');
  1402. }else{
  1403. message('Path Error',' Path is not writable','bottom-right','#FFF','warning','10000');
  1404. }
  1405. }).fail(function(xhr) {
  1406. console.error("Organizr Function: Connection Failed");
  1407. });
  1408. }
  1409. });
  1410. // Save Homepage Form
  1411. $(document).on('change', '.homepageForm :input', function(e) {
  1412. var input = $(this);
  1413. switch ($(this).attr('type')) {
  1414. case 'switch':
  1415. case 'checkbox':
  1416. var value = $(this).prop("checked") ? true : false;
  1417. break;
  1418. default:
  1419. var value = $(this).val();
  1420. }
  1421. var post = {
  1422. api:'api/?v1/update/config',
  1423. name:$(this).attr("name"),
  1424. type:$(this).attr("data-type"),
  1425. value:value,
  1426. messageTitle:'',
  1427. messageBody:'Updated Value for '+$(this).parent().parent().find('label').text(),
  1428. error:'Organizr Function: API Connection Failed'
  1429. };
  1430. var callbacks = $.Callbacks();
  1431. //callbacks.add( buildCustomizeAppearance );
  1432. settingsAPI(post,callbacks);
  1433. //disable button then renable
  1434. $('.homepageForm :input').prop('disabled', 'true');
  1435. setTimeout(
  1436. function(){
  1437. $('.homepageForm :input').prop('disabled', null);
  1438. input.emulateTab();
  1439. },
  1440. 2000
  1441. );
  1442. });
  1443. $(document).on({
  1444. mouseenter: function () {
  1445. $(this).find('.progress').toggleClass('progress-lg');
  1446. $(this).find('.progress').find('span').toggleClass('hidden');
  1447. $(this).find('.white-box').toggleClass('nowPlayingHover');
  1448. },
  1449. mouseleave: function () {
  1450. $(this).find('.progress').toggleClass('progress-lg');
  1451. $(this).find('.progress').find('span').toggleClass('hidden');
  1452. $(this).find('.white-box').toggleClass('nowPlayingHover');
  1453. }
  1454. }, '.nowPlayingItem');
  1455. // recent filter
  1456. $(document).on("click", ".recent-filter li>a", function () {
  1457. var filter = $(this).attr('data-filter');
  1458. var type = $(this).attr('server-filter'); //plex or emby
  1459. //console.log(filter);
  1460. if(filter == 'all'){
  1461. $('.'+type+'-recent').find('.recent-item').parent().removeClass('hidden');
  1462. }else{
  1463. $('.'+type+'-recent').find('.recent-item').parent().removeClass('hidden');
  1464. $('.'+type+'-recent').find('.recent-item:not(.'+ filter + ')').parent().addClass('hidden');
  1465. }
  1466. var owl = $('.'+type+'-recent');
  1467. owl.owlCarousel();
  1468. owl.trigger('refresh.owl.carousel');
  1469. owl.trigger('to.owl.carousel',0);
  1470. });
  1471. // request search filter
  1472. $(document).on("click", ".filter-request-result", function () {
  1473. var filter = $(this).attr('data-filter');
  1474. if(filter == 'request-result-all'){
  1475. $('.request-result-item').removeClass('hidden');
  1476. }else{
  1477. $('.request-result-item').addClass('hidden');
  1478. $('.'+filter).removeClass('hidden');
  1479. }
  1480. });
  1481. //playlist filter
  1482. $(document).on("click", ".playlist-filter li>a", function () {
  1483. var filter = $(this).attr('data-filter');
  1484. var title = decodeURI($(this).attr('data-title'));
  1485. var type = $(this).attr('server-filter'); //plex or emby
  1486. $('.'+type+'-playlistTitle').html(title);
  1487. $('.'+type+'-playlist').addClass('hidden');
  1488. $('.'+filter+'-playlist').removeClass('hidden');
  1489. });
  1490. // refresh cache image
  1491. $(document).on("click", ".refreshImage", function(e) {
  1492. message('',' Refreshing Image...','bottom-right','#FFF','success','1000');
  1493. e.preventDefault;
  1494. var original = $(this).attr('data-image');
  1495. var type = $(this).attr('data-type');
  1496. switch (type) {
  1497. case 'nowPlaying':
  1498. var orginalElement = $(this).parent().parent().parent().parent().find('.imageSource');
  1499. orginalElement.attr('src', original);
  1500. break;
  1501. case 'recent-item':
  1502. var orginalElementAlt = $(this).parent().parent().parent().find('.imageSourceAlt');
  1503. var orginalElement = $(this).parent().parent().parent().find('.imageSource');
  1504. orginalElement.attr('style', 'background-image: url("'+original+'");');
  1505. orginalElementAlt.attr('src', original);
  1506. break;
  1507. default:
  1508. }
  1509. //console.log(orginalElement)
  1510. //console.log('replaced image with : '+original);
  1511. setTimeout(function(){
  1512. message('Image Refreshed ',' Clear Cache Please','bottom-right','#FFF','success','3000');
  1513. }, 1000);
  1514. });
  1515. // open tab code
  1516. $(document).on("click", ".openTab", function(e) {
  1517. if($(this).attr("data-open-tab") === "true") {
  1518. var tabName = $(this).attr("data-tab-name");
  1519. var container = $("#container-"+tabName);
  1520. var activeFrame = container.children('iframe');
  1521. if(activeFrame.length === 1){
  1522. $('#menu-'+tabName+' a').trigger("click");
  1523. activeFrame.attr("src", $(this).attr("data-url"));
  1524. }else{
  1525. container.attr("data-url", $(this).attr("data-url"));
  1526. $('#menu-'+tabName+' a').trigger("click");
  1527. }
  1528. }else{
  1529. var source = $(this).attr("data-url");
  1530. window.open(source, '_blank');
  1531. }
  1532. $.magnificPopup.close();
  1533. });
  1534. //request click
  1535. $(document).on("click", ".request-item", function(e) {
  1536. var target = $(this).attr('data-target');
  1537. $('#link-'+target).trigger('click');
  1538. });
  1539. // metadata start
  1540. $(document).on("click", ".metadata-get", function(e) {
  1541. if($(e.target).hasClass('mdi-refresh')) return;
  1542. $("#preloader").fadeIn();
  1543. var key = $(this).attr('data-key');
  1544. var uid = $(this).attr('data-uid');
  1545. var source = $(this).attr('data-source');
  1546. switch (source) {
  1547. case 'plex':
  1548. var action = 'getPlexMetadata';
  1549. break;
  1550. case 'emby':
  1551. var action = 'getEmbyMetadata';
  1552. break;
  1553. default:
  1554. }
  1555. ajaxloader(".content-wrap","in");
  1556. organizrAPI('POST','api/?v1/homepage/connect',{action:action, key:key}).success(function(data) {
  1557. var response = JSON.parse(data);
  1558. $('.'+uid+'-metadata-info').html('');
  1559. $('.'+uid+'-metadata-info').html(buildMetadata(response.data, source));
  1560. $('.'+uid).trigger('click');
  1561. $(".metadata-actors").owlCarousel({
  1562. autoplay: true,
  1563. slideSpeed : 300,
  1564. paginationSpeed : 400,
  1565. nav:false,
  1566. dots:false,
  1567. margin:10,
  1568. autoWidth:true,
  1569. items:4
  1570. });
  1571. }).fail(function(xhr) {
  1572. console.error("Organizr Function: API Connection Failed");
  1573. });
  1574. ajaxloader();
  1575. $("#preloader").fadeOut();
  1576. });
  1577. // sab play/resume
  1578. $(document).on("click", ".downloader", function(e) {
  1579. var action = $(this).attr('data-action');
  1580. var source = $(this).attr('data-source');
  1581. var target = $(this).attr('data-target');
  1582. //console.log(action);
  1583. //console.log(source);
  1584. //console.log(target);
  1585. ajaxloader(".content-wrap","in");
  1586. organizrAPI('POST','api/?v1/downloader',{action:action, source:source, target:target}).success(function(data) {
  1587. var response = JSON.parse(data);
  1588. //console.log(response);
  1589. homepageDownloader(source);
  1590. }).fail(function(xhr) {
  1591. console.error("Organizr Function: API Connection Failed");
  1592. });
  1593. ajaxloader();
  1594. });
  1595. // new api key
  1596. $(document).on("click", ".newAPIKey", function () {
  1597. $('#settings-main-form [name=organizrAPI]').val(generateCode());
  1598. $('#settings-main-form [name=organizrAPI]').change();
  1599. });
  1600. // purge logvcfdD\o8i 8
  1601. $(document).on("click", ".purgeLog", function () {
  1602. var name = $('.swapLog.active').attr('data-name');
  1603. var path = $('.swapLog.active').attr('data-path');
  1604. if(name !== '' && path !== ''){
  1605. removeFile(path,name);
  1606. setTimeout(function(){ loadSettingsPage('api/?v1/settings/settings/logs','#settings-settings-logs','Log Viewer'); }, 1500);
  1607. }
  1608. });
  1609. //Show Passowrd
  1610. $(document).on("click", ".showPassword", function () {
  1611. var toggle = $(this).parent().parent().find('.password-alt');
  1612. if (toggle.attr('type') === "password") {
  1613. toggle.attr('type', 'text');
  1614. } else {
  1615. toggle.attr('type', 'password');
  1616. }
  1617. $(this).find('.passwordToggle').toggleClass('fa-eye').toggleClass('fa-eye-slash');
  1618. });
  1619. // calendar popups
  1620. $(document).on('click', "a[class*=ID-]", function(){
  1621. //$("#preloader").fadeIn();
  1622. var details = $(this).attr('data-details');
  1623. var target = $(this).attr('data-target')+'-metadata-info';
  1624. var json = JSON.parse(details);
  1625. $('.'+target).html(buildCalendarMetadata(json));
  1626. //$("#preloader").fadeOut();
  1627. myLazyLoad.update();
  1628. });
  1629. // request filter
  1630. $(document).on("change", ".filter-request-input", function () {
  1631. $('.request-item').parent().removeClass('hidden');
  1632. var filterArray = [];
  1633. $('.filter-request-input').each(function () {
  1634. var value = $(this).prop('checked');
  1635. var filter = $(this).attr('data-filter');
  1636. if(value == false){
  1637. filterArray.push('.'+filter);
  1638. }
  1639. });
  1640. $('.request-item').each(function () {
  1641. var element = $(this);
  1642. var string = filterArray.join(', ');
  1643. if(element.is(string)){
  1644. element.parent().addClass('hidden');
  1645. }
  1646. });
  1647. var owl = $('.request-items');
  1648. owl.owlCarousel();
  1649. owl.trigger('refresh.owl.carousel');
  1650. owl.trigger('to.owl.carousel',0);
  1651. });
  1652. //search ombi
  1653. var typingTimer;
  1654. //on keyup, start the countdown
  1655. $(document).on('keyup', '#request-input', function () {
  1656. clearTimeout(typingTimer);
  1657. typingTimer = setTimeout(doneTyping, 750);
  1658. });
  1659. $(document).on('keyup', '#mediaSearchQuery', function () {
  1660. clearTimeout(typingTimer);
  1661. typingTimer = setTimeout(doneTypingMediaSearch, 750);
  1662. });
  1663. //on keydown, clear the countdown
  1664. $(document).on('keydown', '#request-input', function () {
  1665. clearTimeout(typingTimer);
  1666. });
  1667. $(document).on('keydown', '#mediaSearchQuery', function () {
  1668. clearTimeout(typingTimer);
  1669. });
  1670. /* ===== Open-Close Right Sidebar ===== */
  1671. $(document).on("click", ".right-side-toggle", function () {
  1672. $(".right-sidebar").slideDown(50).toggleClass("shw-rside");
  1673. $(".fxhdr").on("click", function () {
  1674. $("body").toggleClass("fix-header"); /* Fix Header JS */
  1675. });
  1676. $(".fxsdr").on("click", function () {
  1677. $("body").toggleClass("fix-sidebar"); /* Fix Sidebar JS */
  1678. });
  1679. /* ===== Service Panel JS ===== */
  1680. var fxhdr = $('.fxhdr');
  1681. if ($("body").hasClass("fix-header")) {
  1682. fxhdr.attr('checked', true);
  1683. } else {
  1684. fxhdr.attr('checked', false);
  1685. }
  1686. });
  1687. $(document).on('mousewheel', '.recent-items .owl-stage', function (e) {
  1688. if (event.shiftKey) {
  1689. if (e.deltaY>0) {
  1690. $('.recent-items').trigger('next.owl');
  1691. } else {
  1692. $('.recent-items').trigger('prev.owl');
  1693. }
  1694. e.preventDefault();
  1695. }
  1696. });
  1697. $(document).on('mousewheel', '.playlist-items .owl-stage', function (e) {
  1698. if (event.shiftKey) {
  1699. if (e.deltaY>0) {
  1700. $('.playlist-items').trigger('next.owl');
  1701. } else {
  1702. $('.playlist-items').trigger('prev.owl');
  1703. }
  1704. e.preventDefault();
  1705. }
  1706. });
  1707. $(document).on('mousewheel', '.request-items .owl-stage', function (e) {
  1708. if (event.shiftKey) {
  1709. if (e.deltaY>0) {
  1710. $('.request-items').trigger('next.owl');
  1711. } else {
  1712. $('.request-items').trigger('prev.owl');
  1713. }
  1714. e.preventDefault();
  1715. }
  1716. });