functions.js 52 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561
  1. /* TEST SHIT */
  2. // Create language switcher instance
  3. var lang = new Lang();
  4. loadLanguageList();
  5. lang.init({
  6. defaultLang: 'en',
  7. currentLang: language(moment.locale(navigator.languages[0])),
  8. cookie: {
  9. name: 'organizrLanguage',
  10. expiry: 365,
  11. path: '/'
  12. },
  13. allowCookieOverride: true
  14. });
  15. // Start Organizr
  16. launch();
  17. /* NORMAL FUNCTIONS */
  18. function loadLanguageList(){
  19. var languages = languageList();
  20. $.each(languages, function(i,v) {
  21. lang.dynamic(i, 'js/langpack/'+i+'.json');
  22. });
  23. lang.dynamic('strings', 'js/langpack/strings.json');
  24. }
  25. function languageList(){
  26. return {
  27. 'en':{
  28. 'lang':'English',
  29. 'image':'plugins/images/languages/en.png'
  30. },
  31. 'nb':{
  32. 'lang':'Bokmål',
  33. 'image':'plugins/images/languages/nb.png'
  34. },
  35. 'nl':{
  36. 'lang':'Deutsch',
  37. 'image':'plugins/images/languages/nl.png'
  38. },
  39. 'fr':{
  40. 'lang':'French',
  41. 'image':'plugins/images/languages/fr.png'
  42. },
  43. 'de':{
  44. 'lang':'German',
  45. 'image':'plugins/images/languages/de.png'
  46. },
  47. 'de-ch':{
  48. 'lang':'German (Switzerland)',
  49. 'image':'plugins/images/languages/de-ch.png'
  50. },
  51. 'it':{
  52. 'lang':'Italian',
  53. 'image':'plugins/images/languages/it.png'
  54. }
  55. };
  56. }
  57. function sleep(ms) {
  58. return new Promise(resolve => setTimeout(resolve, ms));
  59. }
  60. function timerIncrement() {
  61. idleTime = idleTime + 1;
  62. if (idleTime > 19) { // 20 minutes
  63. //window.location.reload();
  64. console.log('timedout!');
  65. }
  66. //check for cookieExpiry
  67. if(hasCookie){
  68. if(getCookie('organizrToken')){
  69. //do nothing
  70. }else{
  71. location.reload();
  72. };
  73. }
  74. }
  75. function ajaxloader(element=null, action='out'){
  76. var loader = `
  77. <div class="ajaxloader">
  78. <svg class="circular" viewBox="25 25 50 50">
  79. <circle class="path" cx="50" cy="50" fill="none" r="20" stroke-miterlimit="10" stroke-width="5"></circle>
  80. </svg>
  81. </div>`;
  82. switch (action) {
  83. case 'in':
  84. case 'fadein':
  85. $(loader).appendTo(element);
  86. break;
  87. case 'out':
  88. case 'fadeout':
  89. $('.ajaxloader').remove();
  90. break;
  91. default:
  92. }
  93. }
  94. function getDefault(tabName,tabType){
  95. if(getHash() === false){
  96. if(tabName !== null && tabType !== null){
  97. switchTab(tabName,tabType);
  98. }else{
  99. $('#side-menu').children().first().children().click()
  100. }
  101. }else{
  102. var hashTab = getHash();
  103. var hashType = getTabType(hashTab);
  104. if (typeof hashTab !== 'undefined' && typeof hashType !== 'undefined') {
  105. switchTab(hashTab,hashType);
  106. }else{
  107. console.warn("Tab Function: "+hashTab+" is not a defined tab");
  108. }
  109. }
  110. }
  111. function getTabType(tabName){
  112. var tabType = $('#menu-'+tabName);
  113. if (typeof tabType !== 'undefined') {
  114. return tabType.attr('type');
  115. }else{
  116. return false;
  117. }
  118. }
  119. function getHash(){
  120. if ($(location).attr('hash')){
  121. return $(location).attr('hash').substr(1);
  122. }
  123. return false;
  124. }
  125. function setHash(hash){
  126. window.location.hash = '#'+hash;
  127. }
  128. function getQueryVariable(variable){
  129. var query = window.location.search.substring(1);
  130. console.log(query);
  131. var vars = query.split("&");
  132. console.log(vars);
  133. for (var i=0;i<vars.length;i++) {
  134. var pair = vars[i].split("=");
  135. if(pair[0] == variable){return pair[1];}
  136. }
  137. return(false);
  138. }
  139. function iconPrefix(source){
  140. var tabIcon = source.split("::");
  141. var icons = {
  142. "materialize":"mdi mdi-",
  143. "fontawesome":"fa fa-",
  144. "themify":"ti-",
  145. "simpleline":"icon-",
  146. "weathericon":"wi wi-",
  147. };
  148. if(Array.isArray(tabIcon) && tabIcon.length === 2){
  149. if(tabIcon[0] !== 'url'){
  150. return '<i class="'+icons[tabIcon[0]]+tabIcon[1]+' fa-fw"></i>';
  151. }else{
  152. return '<img class="fa-fw" src="'+tabIcon[1]+'" alt="tabIcon" />';
  153. }
  154. }else{
  155. return '<img class="fa-fw" src="'+source+'" alt="tabIcon" />';
  156. }
  157. }
  158. function cleanClass(string){
  159. return string.replace(/ +/g, "-").replace(/\W+/g, "-");
  160. }
  161. function noTabs(arrayItems){
  162. if (arrayItems.data.user.loggedin === true) {
  163. organizrConnect('api/?v1/no_tabs').success(function(data) {
  164. var json = JSON.parse(data);
  165. console.log("Organizr Function: No Tabs Available");
  166. $(json.data).appendTo($('.organizr-area'));
  167. }).fail(function(xhr) {
  168. console.error("Organizr Function: API Connection Failed");
  169. });
  170. }else {
  171. buildLogin();
  172. }
  173. }
  174. function logout(){
  175. message('',' Goodbye!','bottom-right','#FFF','success','10000')
  176. organizrAPI('GET','api/?v1/logout').success(function(data) {
  177. var html = JSON.parse(data);
  178. if(html.data == true){
  179. location.reload();
  180. }else{
  181. $.toast().reset('all');
  182. message('Logout Error',' An Error Occured','bottom-right','#FFF','warning','10000');
  183. console.error('Organizr Function: Logout failed');
  184. }
  185. }).fail(function(xhr) {
  186. console.error("Organizr Function: Logout Failed");
  187. });
  188. }
  189. function reloadOrganizr(){
  190. location.reload();
  191. }
  192. function hideFrames(){
  193. $(".iFrame-listing div[class^='frame-container']").addClass("hidden").removeClass('show');
  194. }
  195. function closeSideMenu(){
  196. $('.fix-header').removeClass('show-sidebar');
  197. }
  198. function removeMenuActive(){
  199. $("#side-menu a").removeClass('active');
  200. }
  201. function swapDisplay(type){
  202. switch (type) {
  203. case 'internal':
  204. $('.iFrame-listing').addClass('hidden').removeClass('show');
  205. $('.internal-listing').addClass('show').removeClass('hidden');
  206. $('.login-area').addClass('hidden').removeClass('show');
  207. break;
  208. case 'iframe':
  209. $('.iFrame-listing').addClass('show').removeClass('hidden');
  210. $('.internal-listing').addClass('hidden').removeClass('show');
  211. $('.login-area').addClass('hidden').removeClass('show');
  212. break;
  213. case 'login':
  214. $('.iFrame-listing').addClass('hidden').removeClass('show');
  215. $('.internal-listing').addClass('hidden').removeClass('show');
  216. $('.login-area').addClass('show').removeClass('hidden');
  217. break;
  218. default:
  219. }
  220. }
  221. function toggleParentActive(tab){
  222. var childTab = $('#menu-'+tab);
  223. if(childTab.parent().hasClass('nav-second-level')){
  224. if(!childTab.parent().hasClass('in')){
  225. childTab.parent().addClass('collapse in');
  226. childTab.parent().parent().addClass('active');
  227. }
  228. }
  229. }
  230. function switchTab(tab, type){
  231. hideFrames();
  232. closeSideMenu();
  233. removeMenuActive();
  234. toggleParentActive(tab);
  235. switch (type) {
  236. case 0:
  237. case '0':
  238. case 'internal':
  239. swapDisplay('internal');
  240. $('#menu-'+cleanClass(tab)).find('a').addClass("active");
  241. var newTab = $('#internal-'+tab);
  242. var tabURL = newTab.attr('data-url');
  243. if(newTab.hasClass('loaded')){
  244. console.log('Tab Function: Switching to tab: '+tab);
  245. newTab.addClass("show").removeClass('hidden');
  246. }else{
  247. $("#preloader").fadeIn();
  248. console.log('Tab Function: Loading new tab for: '+tab);
  249. newTab.addClass("show loaded").removeClass('hidden');
  250. loadInternal(tabURL,cleanClass(tab));
  251. $("#preloader").fadeOut();
  252. }
  253. break;
  254. case 1:
  255. case '1':
  256. case 'iframe':
  257. swapDisplay('iframe');
  258. var newTab = $('#container-'+tab);
  259. var tabURL = newTab.attr('data-url');
  260. $('#menu-'+cleanClass(tab)).find('a').addClass("active");
  261. if(newTab.hasClass('loaded')){
  262. console.log('Tab Function: Switching to tab: '+tab);
  263. newTab.addClass("show").removeClass('hidden');
  264. }else{
  265. $("#preloader").fadeIn();
  266. console.log('Tab Function: Loading new tab for: '+tab);
  267. newTab.addClass("show loaded").removeClass('hidden');
  268. $(buildFrame(tab,tabURL)).appendTo(newTab);
  269. $("#preloader").fadeOut();
  270. }
  271. break;
  272. case 2:
  273. case 3:
  274. case '2':
  275. case '3':
  276. case '_blank':
  277. case 'popout':
  278. popTab(cleanClass(tab), type);
  279. break;
  280. default:
  281. console.error('Tab Function: Action not set');
  282. }
  283. setHash(tab);
  284. }
  285. function popTab(tab, type){
  286. switch (type) {
  287. case 0:
  288. case '0':
  289. case 'internal':
  290. console.warn('Tab Function: New window not supported for tab: '+tab);
  291. break;
  292. case 1:
  293. case '1':
  294. case 'iframe':
  295. case 2:
  296. case 3:
  297. case '2':
  298. case '3':
  299. case '_blank':
  300. case 'popout':
  301. console.log('Tab Function: Creating New Window for tab: '+tab);
  302. var url = $('#container-'+cleanClass(tab)).attr('data-url');
  303. window.open(url, '_blank');
  304. break;
  305. default:
  306. console.error('Tab Function: Action not set');
  307. }
  308. }
  309. function closeTab(tab, type){
  310. }
  311. function reloadTab(tab, type){
  312. $("#preloader").fadeIn();
  313. console.log('Tab Function: Reloading tab: '+tab);
  314. switch (type) {
  315. case 0:
  316. case '0':
  317. case 'internal':
  318. break;
  319. case 1:
  320. case '1':
  321. case 'iframe':
  322. $('#frame-'+cleanClass(tab)).attr('src', $('#frame-'+cleanClass(tab)).attr('src'));
  323. break;
  324. case 2:
  325. case 3:
  326. case '2':
  327. case '3':
  328. case '_blank':
  329. case 'popout':
  330. break;
  331. default:
  332. console.error('Tab Function: Action not set');
  333. }
  334. $("#preloader").fadeOut();
  335. }
  336. function reloadCurrentTab(){
  337. $("#preloader").fadeIn();
  338. console.log('Tab Function: Reloading Current tab');
  339. var iframe = $('.iFrame-listing').find('.show');
  340. var internal = $('.internal-listing').find('.show');
  341. if(iframe.length > 0){
  342. var type = 'iframe';
  343. }else if(internal.length > 0){
  344. var type = 'internal';
  345. }else{
  346. var type = 'not set';
  347. }
  348. switch (type) {
  349. case 0:
  350. case '0':
  351. case 'internal':
  352. var activeInternal = $('.internal-listing').find('.show');
  353. $(activeInternal).html('');
  354. loadInternal(activeInternal.attr('data-url'),activeInternal.attr('data-name'));
  355. break;
  356. case 1:
  357. case '1':
  358. case 'iframe':
  359. var activeFrame = $('.iFrame-listing').find('.show').children('iframe');
  360. activeFrame.attr('src', activeFrame.attr('src'));
  361. break;
  362. case 2:
  363. case 3:
  364. case '2':
  365. case '3':
  366. case '_blank':
  367. case 'popout':
  368. break;
  369. default:
  370. console.error('Tab Function: Action not set');
  371. }
  372. $("#preloader").fadeOut();
  373. }
  374. function loadNextTab(){
  375. var next = $('.iFrame-listing').find('.loaded').attr('data-name');
  376. if (typeof next !== 'undefined') {
  377. var type = $('.iFrame-listing').find('.loaded').attr('data-type');
  378. switchTab(next,type);
  379. }else{
  380. console.log("Tab Function: No Available Tab to open");
  381. }
  382. }
  383. function closeCurrentTab(){
  384. var iframe = $('.iFrame-listing').find('.show');
  385. var internal = $('.internal-listing').find('.show');
  386. if(iframe.length > 0){
  387. var type = 'iframe';
  388. }else if(internal.length > 0){
  389. var type = 'internal';
  390. }else{
  391. var type = 'not set';
  392. }
  393. switch (type) {
  394. case 0:
  395. case '0':
  396. case 'internal':
  397. var tab = $('.internal-listing').find('.show').attr('data-name');
  398. console.log('Tab Function: Closing tab: '+tab);
  399. $('#internal-'+cleanClass(tab)).html('');
  400. $('#internal-'+cleanClass(tab)).removeClass("loaded show");
  401. $('#menu-'+cleanClass(tab)).removeClass("active");
  402. loadNextTab();
  403. break;
  404. case 1:
  405. case '1':
  406. case 'iframe':
  407. var tab = $('.iFrame-listing').find('.show').children('iframe').attr('data-name');
  408. console.log('Tab Function: Closing tab: '+tab);
  409. $('#menu-'+cleanClass(tab)).removeClass("active");
  410. $('#container-'+cleanClass(tab)).removeClass("loaded show");
  411. $('#frame-'+cleanClass(tab)).remove();
  412. loadNextTab();
  413. break;
  414. case 2:
  415. case 3:
  416. case '2':
  417. case '3':
  418. case '_blank':
  419. case 'popout':
  420. break;
  421. default:
  422. console.error('Tab Function: Action not set');
  423. }
  424. }
  425. function message(heading,text,position,color,icon,timeout){
  426. $.toast({
  427. heading: heading,
  428. text: text,
  429. position: position,
  430. loaderBg: color,
  431. icon: icon,
  432. hideAfter: timeout,
  433. stack: 6,
  434. showHideTransition: 'slide',
  435. });
  436. }
  437. function messageSingle(heading,text,position,color,icon,timeout){
  438. $.toast({
  439. heading: heading,
  440. text: text,
  441. position: position,
  442. loaderBg: color,
  443. icon: icon,
  444. hideAfter: timeout,
  445. stack: 1,
  446. showHideTransition: 'slide',
  447. });
  448. }
  449. function tabActions(event,name, type){
  450. if(event.ctrlKey){
  451. popTab(cleanClass(name), type);
  452. }else if(event.altKey){
  453. console.log('alt key');
  454. }else if(event.shiftKey){
  455. reloadTab(cleanClass(name), type);
  456. }else{
  457. switchTab(cleanClass(name), type);
  458. }
  459. }
  460. function reverseObject(object) {
  461. var newObject = {};
  462. var keys = [];
  463. for (var key in object) {
  464. keys.push(key);
  465. }
  466. for (var i = keys.length - 1; i >= 0; i--) {
  467. var value = object[keys[i]];
  468. newObject[keys[i]]= value;
  469. }
  470. return newObject;
  471. }
  472. function hasValue(test){
  473. if(Array.isArray(test) && test[0] !== ''){
  474. return true;
  475. }else{
  476. return false;
  477. }
  478. return false;
  479. }
  480. /* END NORMAL FUNCTIONS */
  481. /* BUILD FUNCTIONS */
  482. /* END BUILD FUNCTIONS */
  483. /* ORGANIZR API FUNCTIONS */
  484. function buildFormItem(item){
  485. var placeholder = (item.placeholder) ? ' placeholder="'+item.placeholder+'"' : '';
  486. var id = (item.id) ? ' id="'+item.placeholder+'"' : '';
  487. var value = (item.value) ? ' value="'+item.value+'"' : '';
  488. var name = (item.name) ? ' name="'+item.name+'"' : '';
  489. var extraClass = (item.class) ? ' '+item.class : '';
  490. var disabled = (item.disabled) ? ' disabled' : '';
  491. //+tof(item.value,'c')+`
  492. switch (item.type) {
  493. case 'input':
  494. return '<input data-changed="false" lang=en" type="text" class="form-control'+extraClass+'"'+placeholder+value+id+name+disabled+' />';
  495. break;
  496. case 'switch':
  497. case 'checkbox':
  498. return '<input data-changed="false" type="checkbox" class="js-switch'+extraClass+'" data-size="small" data-color="#99d683" data-secondary-color="#f96262"'+name+value+tof(item.value,'c')+id+disabled+' /><input data-changed="false" type="hidden"'+name+'value="false">';
  499. break;
  500. default:
  501. return false;
  502. }
  503. }
  504. function buildCustomizeAppearanceItem(array){
  505. if (Array.isArray(array.config)) {
  506. var preRowConfig = `
  507. <!-- FORM GROUP -->
  508. <h3 class="box-title" lang="en">Config Items</h3>
  509. <hr class="m-t-0 m-b-40">
  510. <div class="row">
  511. `;
  512. var customizeItems = preRowConfig;
  513. $.each(array.config, function(i,v) {
  514. customizeItems += `
  515. <!-- INPUT BOX -->
  516. <div class="col-md-6">
  517. <div class="form-group">
  518. <label class="control-label col-md-3" lang="en">`+v.label+`</label>
  519. <div class="col-md-9">
  520. `+buildFormItem(v)+`
  521. </div>
  522. </div>
  523. </div>
  524. <!--/ INPUT BOX -->
  525. `;
  526. });
  527. customizeItems += '</div>';
  528. }
  529. return customizeItems;
  530. }
  531. function buildImageManagerViewItem(array){
  532. var imageListing = '';
  533. if (Array.isArray(array)) {
  534. $.each(array, function(i,v) {
  535. var filepath = v.split("/");
  536. var name = filepath[3].split(".");
  537. imageListing += `
  538. <div class="col-lg-1 col-md-1 col-sm-2 col-xs-4">
  539. <div class="white-box bg-theme-dark m-0">
  540. <div class="el-card-item p-0">
  541. <div class="el-card-avatar el-overlay-1"> <img class="lazyload tabImages" data-src="`+v+`" width="22" height="22">
  542. <div class="el-overlay">
  543. <ul class="el-info">
  544. <li><a class="btn default btn-outline clipboard p-5" data-clipboard-text="`+v+`" href="javascript:void(0);"><i class="ti-clipboard"></i></a></li>
  545. <li><a class="btn default btn-outline deleteImage p-5" href="javascript:void(0);" data-image-path="`+v+`" data-image-name="`+name[0]+`"><i class="icon-trash"></i></a></li>
  546. </ul>
  547. </div>
  548. </div>
  549. <div class="el-card-content">
  550. <small class="elip text-uppercase">`+name[0]+`</small><br>
  551. </div>
  552. </div>
  553. </div>
  554. </div>
  555. `;
  556. });
  557. }
  558. return imageListing;
  559. }
  560. function buildImageManagerView(){
  561. ajaxloader(".content-wrap","in");
  562. organizrAPI('GET','api/?v1/image/list').success(function(data) {
  563. var response = JSON.parse(data);
  564. $('#settings-image-manager-list').html(buildImageManagerViewItem(response.data));
  565. ;
  566. }).fail(function(xhr) {
  567. console.error("Organizr Function: API Connection Failed");
  568. });
  569. ajaxloader();
  570. }
  571. function buildCustomizeAppearance(){
  572. ajaxloader(".content-wrap","in");
  573. organizrAPI('GET','api/?v1/customize/appearance').success(function(data) {
  574. var response = JSON.parse(data);
  575. $('#customize-appearance-form').html(buildCustomizeAppearanceItem(response.data));
  576. ;
  577. }).fail(function(xhr) {
  578. console.error("Organizr Function: API Connection Failed");
  579. });
  580. ajaxloader();
  581. }
  582. function buildUserManagement(){
  583. ajaxloader(".content-wrap","in");
  584. organizrAPI('GET','api/?v1/user/list').success(function(data) {
  585. var response = JSON.parse(data);
  586. $('#manageUserTable').html(buildUserManagementItem(response.data));
  587. }).fail(function(xhr) {
  588. console.error("Organizr Function: API Connection Failed");
  589. });
  590. ajaxloader();
  591. }
  592. function buildGroupManagement(){
  593. ajaxloader(".content-wrap","in");
  594. organizrAPI('GET','api/?v1/user/list').success(function(data) {
  595. var response = JSON.parse(data);
  596. $('#manageGroupTable').html(buildGroupManagementItem(response.data));
  597. }).fail(function(xhr) {
  598. console.error("Organizr Function: API Connection Failed");
  599. });
  600. ajaxloader();
  601. }
  602. function buildTabEditor(){
  603. ajaxloader(".content-wrap","in");
  604. organizrAPI('GET','api/?v1/tab/list').success(function(data) {
  605. var response = JSON.parse(data);
  606. $('#tabEditorTable').html(buildTabEditorItem(response.data));
  607. }).fail(function(xhr) {
  608. console.error("Organizr Function: API Connection Failed");
  609. });
  610. ajaxloader();
  611. }
  612. function buildCategoryEditor(){
  613. ajaxloader(".content-wrap","in");
  614. organizrAPI('GET','api/?v1/tab/list').success(function(data) {
  615. var response = JSON.parse(data);
  616. $('#categoryEditorTable').html(buildCategoryEditorItem(response.data));
  617. }).fail(function(xhr) {
  618. console.error("Organizr Function: API Connection Failed");
  619. });
  620. ajaxloader();
  621. }
  622. function settingsAPI(post, callbacks=null){
  623. ajaxloader(".content-wrap","in");
  624. organizrAPI('POST',post.api,post).success(function(data) {
  625. var response = JSON.parse(data);
  626. console.log(response);
  627. message(post.messageTitle,post.messageBody,"bottom-right","#FFF","success","5000");
  628. if(callbacks){ callbacks.fire(); console.log('fired'); }
  629. }).fail(function(xhr) {
  630. console.error(post.error);
  631. });
  632. ajaxloader();
  633. }
  634. /* END ORGANIZR API FUNCTIONS */
  635. function buildLanguage(replace=false,newLang=null){
  636. var languages = languageList();
  637. var languageItems = '';
  638. var currentLanguage = (getCookie('organizrLanguage')) ? getCookie('organizrLanguage') : window.lang.currentLang;
  639. $.each(languages, function(i,v) {
  640. var active = (i == currentLanguage) ? '' : '';
  641. languageItems += `
  642. <a onclick="window.lang.change('`+i+`');buildLanguage(true,'`+v.lang+`')" href="javascript:void(0);" class="`+active+`">
  643. <div class="mail-contnet"><h5>`+v.lang+`</h5><span class="mail-desc" lang="en">`+active+`</span></div>
  644. </a>
  645. `;
  646. });
  647. var lang = `
  648. <li class="dropdown" id="languageDropdown">
  649. <a class="dropdown-toggle waves-effect waves-light" data-toggle="dropdown" href="#" aria-expanded="false"> <i class="fa fa-language fa-lg fa-fw"></i><span></span></a>
  650. <ul class="dropdown-menu mailbox animated bounceInDown">
  651. <li>
  652. <div class="drop-title" lang="en">Choose Language</div>
  653. </li>
  654. <li>
  655. <div class="message-center">`+languageItems+`</div>
  656. </li>
  657. </ul>
  658. <!-- /.dropdown-messages -->
  659. </li>
  660. `;
  661. if(replace == true){
  662. $('#languageDropdown').replaceWith(lang);
  663. message("",window.lang.translate('Changed Language To')+": "+newLang,"bottom-right","#FFF","success","3500");
  664. }else if(replace == 'wizard'){
  665. $(lang).appendTo('.navbar-right');
  666. }else{
  667. return lang;
  668. }
  669. }
  670. function userMenu(user){
  671. var menuList = buildLanguage();
  672. if (user.data.user.loggedin === true) {
  673. menuList += `
  674. <li class="dropdown">
  675. <a class="dropdown-toggle profile-pic" data-toggle="dropdown" href="javascript:void(0)"><img alt="user-img" class="img-circle" src="`+user.data.user.image+`" width="36"><b class="hidden-xs">`+user.data.user.username+`</b><span class="caret"></span></a>
  676. <ul class="dropdown-menu dropdown-user animated flipInY">
  677. <li>
  678. <div class="dw-user-box">
  679. <div class="u-img"><img alt="user" src="`+user.data.user.image+`"></div>
  680. <div class="u-text"><h4>`+user.data.user.username+`</h4><p class="text-muted">`+user.data.user.email+`</p><p class="text-muted">`+user.data.user.group+`</p></div>
  681. </div>
  682. </li>
  683. <li class="divider" role="separator"></li>
  684. <li><a href="javascript:void(0)"><i class="ti-user fa-fw"></i> <span lang="en">My Profile</span></a></li>
  685. <li><a href="javascript:void(0)"><i class="ti-email fa-fw"></i> <span lang="en">Inbox</span></a></li>
  686. <li class="divider" role="separator"></li>
  687. <li><a href="javascript:void(0)"><i class="ti-settings fa-fw"></i> <span lang="en">Account Settings</span></a></li>
  688. <li class="divider" role="separator"></li>
  689. <li><a href="javascript:void(0)" onclick="logout();"><i class="fa fa-sign-out fa-fw"></i> <span lang="en">Logout</span></a></li>
  690. </ul><!-- /.dropdown-user -->
  691. </li><!-- /.dropdown -->
  692. `;
  693. }else{
  694. menuList += `
  695. <li class="dropdown">
  696. <a class="dropdown-toggle profile-pic" data-toggle="dropdown" href="javascript:void(0)"><img alt="user-img" class="img-circle" src="`+user.data.user.image+`" width="36"><b class="hidden-xs">`+user.data.user.username+`</b><span class="caret"></span></a>
  697. <ul class="dropdown-menu dropdown-user animated flipInY">
  698. <li>
  699. <div class="dw-user-box">
  700. <div class="u-img"><img alt="user" src="`+user.data.user.image+`"></div>
  701. <div class="u-text"><h4>`+user.data.user.username+`</h4></div>
  702. </div>
  703. </li>
  704. <li class="divider" role="separator"></li>
  705. <li><a href="javascript:void(0)" class="show-login"><i class="fa fa-sign-in fa-fw"></i> <span lang="en">Login/Register</span></a></li>
  706. </ul><!-- /.dropdown-user -->
  707. </li><!-- /.dropdown -->
  708. `;
  709. }
  710. $(menuList).appendTo('.navbar-right').html;
  711. message("",window.lang.translate('Welcome')+" "+user.data.user.username,"bottom-right","#FFF","success","3500");
  712. console.log(window.lang.translate('Welcome')+" "+user.data.user.username);
  713. }
  714. function menuExtras(active){
  715. if(active === true){
  716. return `
  717. <li class="devider"></li>
  718. <li><a class="waves-effect" onclick="logout();"><i class="fa fa-sign-out fa-fw"></i> <span class="hide-menu" lang="en">Logout</span></a></li>
  719. <li class="devider"></li>
  720. <li><a href="https://github.com/causefx/organizr" class="waves-effect"><i class="fa fa-circle-o fa-fw text-success"></i> <span class="hide-menu">GitHub</span></a></li>
  721. `;
  722. }else{
  723. return `
  724. <li class="devider"></li>
  725. <li id="menu-login"><a class="waves-effect show-login" href="javascript:void(0)"><i class="mdi mdi-login fa-fw"></i> <span class="hide-menu" lang="en">Login/Register</span></a></li>
  726. `;
  727. }
  728. }
  729. function categoryProcess(arrayItems){
  730. var menuList = '';
  731. if (Array.isArray(arrayItems['data']['categories']) && Array.isArray(arrayItems['data']['tabs'])) {
  732. $.each(arrayItems['data']['categories'], function(i,v) {
  733. if(v.count !== 0 && v.category_id !== 0){
  734. menuList += `
  735. <li>
  736. <a class="waves-effect" href="javascript:void(0)">`+iconPrefix(v.image)+`<span class="hide-menu">`+v.category+` <span class="fa arrow"></span> <span class="label label-rouded label-inverse pull-right">`+v.count+`</span></span></a>
  737. <ul class="nav nav-second-level category-`+v.category_id+` collapse"></ul>
  738. </li>
  739. `;
  740. }
  741. });
  742. $(menuList).appendTo($('#side-menu'));
  743. }
  744. }
  745. function buildFrame(name,url){
  746. return `
  747. <iframe allowfullscreen="true" frameborder="0" id="frame-`+cleanClass(name)+`" data-name="`+cleanClass(name)+`" sandbox="allow-presentation allow-forms allow-same-origin allow-pointer-lock allow-scripts allow-popups allow-modals allow-top-navigation" scrolling="auto" src="`+url+`" class="iframe"></iframe>
  748. `;
  749. }
  750. function buildFrameContainer(name,url,type){
  751. return `<div id="container-`+cleanClass(name)+`" data-type="`+type+`" class="frame-container frame-`+cleanClass(name)+` hidden" data-url="`+url+`" data-name="`+cleanClass(name)+`"></div>`;
  752. }
  753. function buildInternalContainer(name,url,type){
  754. return `<div id="internal-`+cleanClass(name)+`" data-type="`+type+`" class="internal-container frame-`+cleanClass(name)+` hidden" data-url="`+url+`" data-name="`+cleanClass(name)+`"></div>`;
  755. }
  756. function buildMenuList(name,url,type,icon){
  757. return `<li id="menu-`+cleanClass(name)+`" type="`+type+`"><a class="waves-effect" onclick="tabActions(event,'`+cleanClass(name)+`',`+type+`);">`+iconPrefix(icon)+`<span class="hide-menu">`+name+`</span></a></li>`;
  758. }
  759. function tabProcess(arrayItems) {
  760. var iFrameList = '';
  761. var internalList = '';
  762. var defaultTabName = null;
  763. var defaultTabType = null;
  764. if (Array.isArray(arrayItems['data']['tabs']) && arrayItems['data']['tabs'].length > 0) {
  765. $.each(arrayItems['data']['tabs'], function(i,v) {
  766. if(v.enabled === 1){
  767. switch (v.type) {
  768. case 0:
  769. case '0':
  770. case 'internal':
  771. internalList += buildInternalContainer(v.name,v.url,v.type);
  772. $(internalList).appendTo($('.internal-listing'));
  773. break;
  774. case 1:
  775. case '1':
  776. case 'iframe':
  777. if(v.default === 1){
  778. defaultTabName = cleanClass(v.name);
  779. defaultTabType = v.type;
  780. }
  781. iFrameList = buildFrameContainer(v.name,v.url,v.type);
  782. $(iFrameList).appendTo($('.iFrame-listing'));
  783. break;
  784. case 2:
  785. case 3:
  786. case '2':
  787. case '3':
  788. case '_blank':
  789. case 'popout':
  790. break;
  791. default:
  792. console.error('Tab Process: Action not set');
  793. }
  794. menuList = buildMenuList(v.name,v.url,v.type,v.image);
  795. if(v.category_id === 0){
  796. $(menuList).prependTo($('#side-menu'));
  797. }else{
  798. $(menuList).prependTo($('.category-'+v.category_id));
  799. }
  800. }
  801. });
  802. getDefault(defaultTabName,defaultTabType);
  803. }else{
  804. noTabs(arrayItems);
  805. }
  806. $(menuExtras(arrayItems.data.user.loggedin)).appendTo($('#side-menu'));
  807. }
  808. function buildLogin(){
  809. swapDisplay('login');
  810. closeSideMenu();
  811. removeMenuActive();
  812. $('#menu-login a').addClass('active');
  813. organizrConnect('api/?v1/login_page').success(function(data) {
  814. var json = JSON.parse(data);
  815. console.log("Organizr Function: Opening Login Page");
  816. $('.login-area').html(json.data);
  817. }).fail(function(xhr) {
  818. console.error("Organizr Function: Login Connection Failed");
  819. });
  820. $("#preloader").fadeOut();
  821. }
  822. function buildLockscreen(){
  823. $("#preloader").fadeIn();
  824. closeSideMenu();
  825. organizrConnect('api/?v1/lockscreen').success(function(data) {
  826. var json = JSON.parse(data);
  827. console.log("Organizr Function: Adding Lockscreen");
  828. $(json.data).appendTo($('body'));
  829. }).fail(function(xhr) {
  830. console.error("Organizr Function: Lockscreen Connection Failed");
  831. });
  832. $("#preloader").fadeOut();
  833. }
  834. function buildUserGroupSelect(array, userID, groupID){
  835. var groupSelect = '';
  836. var selected = '';
  837. var disabled = '';
  838. if(groupID == 0 && userID == 1){
  839. disabled = 'disabled';
  840. }
  841. $.each(array, function(i,v) {
  842. selected = '';
  843. if(v.group_id == groupID){
  844. selected = 'selected';
  845. }
  846. var selectDisable = (v.group_id == 0 || v.group_id == 999) ? 'disabled' : '';
  847. groupSelect += '<option '+selected+' '+selectDisable+' value="'+v.group_id+'">'+v.group+'</option>';
  848. });
  849. return '<td><select name="userGroupSelect" class="form-control userGroupSelect" '+disabled+'>'+groupSelect+'</select></td>';
  850. }
  851. function buildTabGroupSelect(array, tabID, groupID){
  852. var groupSelect = '';
  853. var selected = '';
  854. $.each(array, function(i,v) {
  855. selected = '';
  856. if(v.group_id == groupID){
  857. selected = 'selected';
  858. }
  859. groupSelect += '<option '+selected+' value="'+v.group_id+'">'+v.group+'</option>';
  860. });
  861. return '<td><select name="tab['+tabID+'].group_id" class="form-control tabGroupSelect">'+groupSelect+'</select></td>';
  862. }
  863. function buildTabTypeSelect(tabID, typeID){
  864. var array = [
  865. {
  866. 'type_id':0,
  867. 'type':'Internal'
  868. },
  869. {
  870. 'type_id':1,
  871. 'type':'iFrame'
  872. },
  873. {
  874. 'type_id':2,
  875. 'type':'New Window'
  876. }
  877. ]
  878. var typeSelect = '';
  879. var selected = '';
  880. $.each(array, function(i,v) {
  881. selected = '';
  882. if(v.type_id == typeID){
  883. selected = 'selected';
  884. }
  885. typeSelect += '<option '+selected+' value="'+v.type_id+'">'+v.type+'</option>';
  886. });
  887. return '<td><select name="tab['+tabID+'].type" class="form-control tabTypeSelect">'+typeSelect+'</select></td>';
  888. }
  889. function buildTabCategorySelect(array,tabID, categoryID){
  890. var categorySelect = '';
  891. var selected = '';
  892. $.each(array, function(i,v) {
  893. selected = '';
  894. if(v.category_id == categoryID){
  895. selected = 'selected';
  896. }
  897. categorySelect += '<option '+selected+' value="'+v.category_id+'">'+v.category+'</option>';
  898. });
  899. return '<td><select name="tab['+tabID+'].category_id" class="form-control tabCategorySelect">'+categorySelect+'</select></td>';
  900. }
  901. function buildUserManagementItem(array){
  902. var userList = '';
  903. $.each(array.users, function(i,v) {
  904. var disabledDelete = (v.group_id == 999 || v.group_id == 0) ? 'disabled' : 'deleteUser';
  905. userList += `
  906. <tr class="userManagement" data-id="`+v.id+`" data-username="`+v.username+`" data-group="`+v.group+`">
  907. <td class="text-center el-element-overlay">
  908. <div class="el-card-item p-0">
  909. <div class="el-card-avatar el-overlay-1 m-0">
  910. <img alt="user-img" class="img-circle" src="`+v.image+`" width="45">
  911. <div class="el-overlay">
  912. <ul class="el-info">
  913. `+v.id+`
  914. </ul>
  915. </div>
  916. </div>
  917. </div>
  918. </td>
  919. <td>`+v.username+`
  920. <br/><span class="text-muted">`+v.email+`</span></td>
  921. <td>`+moment(v.register_date).format('ll')+`
  922. <br/><span class="text-muted">`+moment(v.register_date).format('LT')+`</span></td>
  923. `+buildUserGroupSelect(array.groups,v.id,v.group_id)+`
  924. <td><button type="button" class="btn btn-info btn-outline btn-circle btn-lg m-r-5 editUser"><i class="ti-pencil-alt"></i></button></td>
  925. <td><button type="button" class="btn btn-info btn-outline btn-circle btn-lg m-r-20"><i class="ti-email"></i></button></td>
  926. <td><button type="button" class="btn btn-danger btn-outline btn-circle btn-lg m-r-5 `+disabledDelete+`"><i class="ti-trash"></i></button></td>
  927. </tr>
  928. `;
  929. });
  930. return userList;
  931. }
  932. function buildGroupManagementItem(array){
  933. var userList = '';
  934. $.each(array.groups, function(i,v) {
  935. var userCount = array.users.reduce(function (n, group) {
  936. return n + (group.group_id == v.group_id);
  937. }, 0);
  938. var disabledDefault = (v.group_id == 0 || v.group_id == 999) ? 'disabled' : '';
  939. var disabledDelete = (userCount > 0 || v.default == 1 || v.group_id == 999 || v.group_id == 0) ? 'disabled' : '';
  940. var defaultIcon = (v.default == 1) ? 'icon-user-following' : 'icon-user-follow';
  941. var defaultColor = (v.default == 1) ? 'btn-info disabled' : 'btn-warning';
  942. userList += `
  943. <tr class="userManagement" data-id="`+v.id+`" data-group-id="`+v.group_id+`" data-group="`+v.group+`" data-default="`+tof(v.default)+`" data-image="`+v.image+`" data-user-count="`+userCount+`">
  944. <td class="text-center el-element-overlay">
  945. <div class="el-card-item p-0">
  946. <div class="el-card-avatar el-overlay-1 m-0">
  947. <div class="tabEditorIcon">`+iconPrefix(v.image)+`</div>
  948. <div class="el-overlay">
  949. <ul class="el-info">
  950. `+v.group_id+`
  951. </ul>
  952. </div>
  953. </div>
  954. </div>
  955. </td>
  956. <td>`+v.group+`</td>
  957. <td>`+userCount+`</td>
  958. <td><button type="button" class="btn `+defaultColor+` btn-outline btn-circle btn-lg m-r-5 changeDefaultGroup" `+disabledDefault+`><i class="`+defaultIcon+`"></i></button></td>
  959. <td><button type="button" class="btn btn-info btn-outline btn-circle btn-lg m-r-5 editGroupButton popup-with-form" href="#edit-group-form" data-effect="mfp-3d-unfold"><i class="ti-pencil-alt"></i></button></td>
  960. <td><button type="button" class="btn btn-danger btn-outline btn-circle btn-lg m-r-5 deleteUserGroup" `+disabledDelete+`><i class="ti-trash"></i></button></td>
  961. </tr>
  962. `;
  963. });
  964. return userList;
  965. }
  966. function buildCategoryEditorItem(array){
  967. var categoryList = '';
  968. $.each(array.categories, function(i,v) {
  969. var tabCount = array.tabs.reduce(function (n, category) {
  970. return n + (category.category_id == v.category_id);
  971. }, 0);
  972. var disabledDefault = (v.category_id == 0) ? 'disabled' : '';
  973. var disabledDelete = (tabCount > 0 || v.default == 1 || v.category_id == 0) ? 'disabled' : '';
  974. var defaultIcon = (v.default == 1) ? 'icon-user-following' : 'icon-user-follow';
  975. var defaultColor = (v.default == 1) ? 'btn-info disabled' : 'btn-warning';
  976. categoryList += `
  977. <tr class="categoryEditor" data-id="`+v.id+`" data-order="`+v.order+`" data-category-id="`+v.category_id+`" data-name="`+v.category+`" data-default="`+tof(v.default)+`" data-image="`+v.image+`" data-tab-count="`+tabCount+`">
  978. <input type="hidden" class="form-control order" name="category[`+v.id+`].order" value="`+v.order+`">
  979. <input type="hidden" class="form-control" name="category[`+v.id+`].originalOrder" value="`+v.order+`">
  980. <input type="hidden" class="form-control" name="category[`+v.id+`].name" value="`+v.category+`">
  981. <input type="hidden" class="form-control" name="category[`+v.id+`].id" value="`+v.id+`">
  982. <td class="text-center el-element-overlay">
  983. <div class="el-card-item p-0">
  984. <div class="el-card-avatar el-overlay-1 m-0">
  985. <div class="tabEditorIcon">`+iconPrefix(v.image)+`</div>
  986. <div class="el-overlay bg-theme-dark">
  987. <ul class="el-info">
  988. <i class="fa fa-bars"></i>
  989. </ul>
  990. </div>
  991. </div>
  992. </div>
  993. </td>
  994. <td>`+v.category+`</td>
  995. <td style="text-align:center">`+tabCount+`</td>
  996. <td style="text-align:center"><button type="button" class="btn `+defaultColor+` btn-outline btn-circle btn-lg m-r-5 changeDefaultCategory" `+disabledDefault+`><i class="`+defaultIcon+`"></i></button></td>
  997. <td style="text-align:center"><button type="button" class="btn btn-info btn-outline btn-circle btn-lg m-r-5 editCategoryButton popup-with-form" href="#edit-category-form" data-effect="mfp-3d-unfold"><i class="ti-pencil-alt"></i></button></td>
  998. <td style="text-align:center"><button type="button" class="btn btn-danger btn-outline btn-circle btn-lg m-r-5 deleteCategory" `+disabledDelete+`><i class="ti-trash"></i></button></td>
  999. </tr>
  1000. `;
  1001. });
  1002. return categoryList;
  1003. }
  1004. function buildTabEditorItem(array){
  1005. var tabList = '';
  1006. $.each(array.tabs, function(i,v) {
  1007. var deleteDisabled = v.url.indexOf('/?v') > 0 ? 'disabled' : 'deleteTab';
  1008. tabList += `
  1009. <tr class="tabEditor" data-order="`+v.order+`" data-id="`+v.id+`" data-group-id="`+v.group_id+`" data-category-id="`+v.category_id+`" data-name="`+v.name+`" data-url="`+v.url+`" data-image="`+v.image+`">
  1010. <input type="hidden" class="form-control" name="tab[`+v.id+`].id" value="`+v.id+`">
  1011. <input type="hidden" class="form-control order" name="tab[`+v.id+`].order" value="`+v.order+`">
  1012. <input type="hidden" class="form-control" name="tab[`+v.id+`].originalOrder" value="`+v.order+`">
  1013. <input type="hidden" class="form-control" name="tab[`+v.id+`].url_local" value="`+v.url_local+`">
  1014. <input type="hidden" class="form-control" name="tab[`+v.id+`].name" value="`+v.name+`">
  1015. <input type="hidden" class="form-control" name="tab[`+v.id+`].url" value="`+v.url+`">
  1016. <input type="hidden" class="form-control" name="tab[`+v.id+`].image" value="`+v.image+`">
  1017. <td style="text-align:center" class="text-center el-element-overlay">
  1018. <div class="el-card-item p-0">
  1019. <div class="el-card-avatar el-overlay-1 m-0">
  1020. <div class="tabEditorIcon">`+iconPrefix(v.image)+`</div>
  1021. <div class="el-overlay bg-theme-dark">
  1022. <ul class="el-info">
  1023. <i class="fa fa-bars"></i>
  1024. </ul>
  1025. </div>
  1026. </div>
  1027. </div>
  1028. </td>
  1029. <td>`+v.name+`</td>
  1030. `+buildTabCategorySelect(array.categories,v.id, v.category_id)+`
  1031. `+buildTabGroupSelect(array.groups,v.id, v.group_id)+`
  1032. `+buildTabTypeSelect(v.id, v.type)+`
  1033. <td style="text-align:center"><div class="radio radio-purple"><input onclick="radioLoop(this);" type="radio" class="defaultSwitch" id="tab[`+v.id+`].default" name="tab[`+v.id+`].default" value="true" `+tof(v.default,'c')+`><label for="tab[`+v.id+`].default"></label></div></td>
  1034. <td style="text-align:center"><input type="checkbox" class="js-switch enabledSwitch" data-size="small" data-color="#99d683" data-secondary-color="#f96262" name="tab[`+v.id+`].enabled" value="true" `+tof(v.enabled,'c')+`/><input type="hidden" class="form-control" name="tab[`+v.id+`].enabled" value="false"></td>
  1035. <td style="text-align:center"><input type="checkbox" class="js-switch splashSwitch" data-size="small" data-color="#99d683" data-secondary-color="#f96262" name="tab[`+v.id+`].splash" value="true" `+tof(v.splash,'c')+`/><input type="hidden" class="form-control" name="tab[`+v.id+`].splash" value="false"></td>
  1036. <td style="text-align:center"><button type="button" class="btn btn-info btn-outline btn-circle btn-lg m-r-5 editTabButton popup-with-form" href="#edit-tab-form" data-effect="mfp-3d-unfold"><i class="ti-pencil-alt"></i></button></td>
  1037. <td style="text-align:center"><button type="button" class="btn btn-danger btn-outline btn-circle btn-lg m-r-5 `+deleteDisabled+`"><i class="ti-trash"></i></button></td>
  1038. </tr>
  1039. `;
  1040. });
  1041. return tabList;
  1042. }
  1043. function submitTabOrder(){
  1044. var post = {
  1045. action:'changeOrder',
  1046. api:'api/?v1/settings/tab/editor/tabs',
  1047. tabs:$( "#submit-tabs-form" ).serializeToJSON(),
  1048. messageTitle:'',
  1049. messageBody:window.lang.translate('Tab Order Saved'),
  1050. error:'Organizr Function: API Connection Failed'
  1051. };
  1052. settingsAPI(post);
  1053. buildTabEditor();
  1054. }
  1055. function submitCategoryOrder(){
  1056. var post = {
  1057. action:'changeOrder',
  1058. api:'api/?v1/settings/tab/editor/categories',
  1059. categories:$( "#submit-categories-form" ).serializeToJSON(),
  1060. messageTitle:'',
  1061. messageBody:window.lang.translate('Category Order Saved'),
  1062. error:'Organizr Function: API Connection Failed'
  1063. };
  1064. console.log(post);
  1065. settingsAPI(post);
  1066. buildCategoryEditor();
  1067. }
  1068. function buildTR(array,type,badge){
  1069. var listing = '';
  1070. var arrayItems = array.split("|");
  1071. if(hasValue(arrayItems) === true){
  1072. $.each(arrayItems, function(i,v) {
  1073. listing += `
  1074. <tr>
  1075. <td width="70"><span class="label label-`+badge+`"><span lang="en">`+type+`</span></span></td>
  1076. <td>`+v+`</td>
  1077. </tr>
  1078. `;
  1079. });
  1080. return listing;
  1081. }
  1082. return ' ';
  1083. }
  1084. function buildVersion(array){
  1085. var x = 0;
  1086. var versions = '<h3 class="p-l-10 m-b-0 box-title" lang="en">Organizr Versions</h3>';
  1087. var listing = '';
  1088. var currentV = currentVersion;
  1089. var installed = '';
  1090. var spanClass = '';
  1091. var button = '';
  1092. $.each(array, function(i,v) {
  1093. listing += buildTR(v.new,'NEW','info');
  1094. listing += buildTR(v.fixed,'FIXED','success');
  1095. listing += buildTR(v.notes,'NOTE','warning');
  1096. if(currentV === i){
  1097. button = '<button class="btn btn-sm btn-success btn-rounded waves-effect waves-light disabled pull-right row b-none" type="button"><span class="btn-label"><i class="fa fa-check"></i></span><span lang="en">Installed</span></button>';
  1098. }else if (x === 0){
  1099. button = '<button class="btn btn-sm btn-info btn-rounded waves-effect waves-light pull-right row b-none" type="button" onclick="updateNow();"><span class="btn-label"><i class="fa fa-download"></i></span><span lang="en">Install Update</span></button>';
  1100. }
  1101. versions += `
  1102. <div class="white-box bg-theme-dark">
  1103. <div class="col-md-3 col-sm-4 col-xs-6 pull-right">`+button+`</div>
  1104. <h3 class="box-title">`+i+`</h3>
  1105. <div class="row sales-report">
  1106. <div class="col-md-12 col-sm-12 col-xs-12">
  1107. <span class="tooltip-info" data-toggle="tooltip" data-placement="right" title="" data-original-title="`+moment(v.date).format('LL')+`">`+moment.utc(v.date, "YYYY-MM-DD hh:mm[Z]").local().fromNow()+`</span>
  1108. <p class="text-info p-0">`+v.title+`</p>
  1109. </div>
  1110. </div>
  1111. <div class="table-responsive">
  1112. <table class="table inverse-bordered-table">
  1113. <tbody>
  1114. `+listing+`
  1115. </tbody>
  1116. </table>
  1117. </div>
  1118. </div>
  1119. `;
  1120. listing = '';
  1121. button = '';
  1122. x++;
  1123. });
  1124. return versions;
  1125. }
  1126. function loadInternal(url,tabName){
  1127. organizrAPI('get',url).success(function(data) {
  1128. var html = JSON.parse(data);
  1129. $('#internal-'+tabName).html(html.data);
  1130. }).fail(function(xhr) {
  1131. console.error("Organizr Function: Connection Failed");
  1132. });
  1133. }
  1134. function loadSettingsPage(api,element,organizrFn){
  1135. organizrAPI('get',api).success(function(data) {
  1136. var json = JSON.parse(data);
  1137. console.log('Organizr Function: Loading '+organizrFn);
  1138. $(element).html(json.data);
  1139. }).fail(function(xhr) {
  1140. console.error("Organizr Function: API Connection Failed");
  1141. });
  1142. }
  1143. function updateCheck(){
  1144. githubVersions().success(function(data) {
  1145. var json = JSON.parse(data);
  1146. for (var a in reverseObject(json)){
  1147. var latest = a;
  1148. break;
  1149. }
  1150. if(latest !== currentVersion){
  1151. console.log('Update Function: Update to '+latest+' is available');
  1152. message(window.lang.translate('Update Available'),latest+' '+window.lang.translate('is available, goto')+' <a href="javascript:void(0)" onclick="tabActions(event,\'Settings\',0);$.toast().reset(\'all\');"><span lang="en">Update Tab</span></a>','bottom-right','#FFF','update','60000');
  1153. }else{
  1154. console.log('Update Function: '+latest+' is the newest version');
  1155. }
  1156. $('#githubVersions').html(buildVersion(reverseObject(json)));
  1157. }).fail(function(xhr) {
  1158. console.error("Organizr Function: Github Connection Failed");
  1159. });
  1160. }
  1161. function updateBar(){
  1162. return `
  1163. <div class="white-box m-0">
  1164. <div class="row">
  1165. <div class="col-lg-12 p-r-40">
  1166. <h3 lang="en" id="update-title" class="box-title pull-left"></h3><h3 id="update-time" class="box-title pull-right hidden"><span id="update-seconds"></span>&nbsp;<span lang="en">Seconds</span></h3>
  1167. <div class="clearfix"></div>
  1168. <div class="progress progress-lg">
  1169. <div id="update-bar" class="progress-bar progress-bar-primary progress-bar-striped active" style="width: 0%;" role="progressbar">0%</div>
  1170. </div>
  1171. </div>
  1172. </div>
  1173. </div>
  1174. `;
  1175. }
  1176. function updateUpdateBar(title,percent,update=false){
  1177. $('#update-title').text(title);
  1178. $('#update-bar').text(percent);
  1179. $('#update-bar').css('width',percent);
  1180. if(update){
  1181. $('#update-time').removeClass('hidden');
  1182. countdown(10);
  1183. }
  1184. }
  1185. function countdown(remaining) {
  1186. if(remaining === 0){
  1187. local('set','message','Organizr Update|Update Successful|update');
  1188. location.reload();
  1189. }
  1190. $('#update-seconds').text(remaining);
  1191. setTimeout(function(){ countdown(remaining - 1); }, 1000);
  1192. }
  1193. function updateNow(){
  1194. console.log('Organizr Function: Starting Update Process');
  1195. $(updateBar()).appendTo('.organizr-area');
  1196. updateUpdateBar('Starting Download','5%');
  1197. messageSingle(window.lang.translate('[DO NOT CLOSE WINDOW]'),window.lang.translate('Starting Update Process'),'bottom-right','#FFF','success','60000');
  1198. organizrAPI('POST','api/?v1/update', {branch:activeInfo.branch,stage:1}).success(function(data) {
  1199. var json = JSON.parse(data);
  1200. if(json.data == true){
  1201. updateUpdateBar('Starting Unzip','50%');
  1202. messageSingle(window.lang.translate('[DO NOT CLOSE WINDOW]'),window.lang.translate('Update File Downloaded'),'bottom-right','#FFF','success','60000');
  1203. organizrAPI('POST','api/?v1/update', {branch:activeInfo.branch,stage:2}).success(function(data) {
  1204. var json = JSON.parse(data);
  1205. if(json.data == true){
  1206. updateUpdateBar('Starting Copy','70%');
  1207. messageSingle(window.lang.translate('[DO NOT CLOSE WINDOW]'),window.lang.translate('Update File Unzipped'),'bottom-right','#FFF','success','60000');
  1208. organizrAPI('POST','api/?v1/update', {branch:activeInfo.branch,stage:3}).success(function(data) {
  1209. var json = JSON.parse(data);
  1210. if(json.data == true){
  1211. updateUpdateBar('Starting Cleanup','90%');
  1212. messageSingle(window.lang.translate('[DO NOT CLOSE WINDOW]'),window.lang.translate('Update Files Copied'),'bottom-right','#FFF','success','60000');
  1213. organizrAPI('POST','api/?v1/update', {branch:activeInfo.branch,stage:4}).success(function(data) {
  1214. var json = JSON.parse(data);
  1215. if(json.data == true){
  1216. updateUpdateBar('Restarting Organizr in','100%', true);
  1217. messageSingle(window.lang.translate('[DO NOT CLOSE WINDOW]'),window.lang.translate('Update Cleanup Finished'),'bottom-right','#FFF','success','60000');
  1218. setTimeout(location.reload.bind(location), 10000);
  1219. }else{
  1220. message('',window.lang.translate('Update Cleanup Failed'),'bottom-right','#FFF','error','10000');
  1221. }
  1222. }).fail(function(xhr) {
  1223. console.error("Organizr Function: API Connection Failed");
  1224. });
  1225. }else{
  1226. message('',window.lang.translate('Update File Copy Failed'),'bottom-right','#FFF','error','10000');
  1227. }
  1228. }).fail(function(xhr) {
  1229. console.error("Organizr Function: API Connection Failed");
  1230. });
  1231. }else{
  1232. message('',window.lang.translate('Update File Unzip Failed'),'bottom-right','#FFF','error','10000');
  1233. }
  1234. }).fail(function(xhr) {
  1235. console.error("Organizr Function: API Connection Failed");
  1236. });
  1237. }else{
  1238. message('',window.lang.translate('Update File Download Failed'),'bottom-right','#FFF','error','10000');
  1239. }
  1240. }).fail(function(xhr) {
  1241. console.error("Organizr Function: API Connection Failed");
  1242. });
  1243. }
  1244. function organizrAPI(type,path,data=null){
  1245. //console.log('Organizr API: Calling API: '+path);
  1246. switch (type) {
  1247. case 'get':
  1248. case 'GET':
  1249. case 'g':
  1250. return $.ajax({
  1251. url:path,
  1252. method:"GET",
  1253. beforeSend: function(request) {
  1254. request.setRequestHeader("Token", activeInfo.token);
  1255. },
  1256. });
  1257. break;
  1258. case 'post':
  1259. case 'POST':
  1260. case 'p':
  1261. return $.ajax({
  1262. url:path,
  1263. method:"POST",
  1264. beforeSend: function(request) {
  1265. request.setRequestHeader("Token", activeInfo.token);
  1266. },
  1267. data:{
  1268. data: data,
  1269. }
  1270. });
  1271. default:
  1272. console.warn('Organizr API: Method Not Supported');
  1273. }
  1274. }
  1275. function githubVersions() {
  1276. return $.ajax({
  1277. url: "https://raw.githubusercontent.com/causefx/Organizr/"+activeInfo.branch+"/js/version.json",
  1278. });
  1279. }
  1280. function organizrConnect(path){
  1281. return $.ajax({
  1282. url: path,
  1283. });
  1284. }
  1285. function changeSettingsMenu(path){
  1286. var menuItems = path.split("::");
  1287. var menu = '';
  1288. if(Array.isArray(menuItems)){
  1289. $.each(menuItems, function(i,v) {
  1290. menu += '<li><a lang="en">'+v+'</a></li>';
  1291. });
  1292. }
  1293. $('#settingsBreadcrumb').html(menu);
  1294. }
  1295. function buildWizard(){
  1296. organizrConnect('api/?v1/wizard_page').success(function(data) {
  1297. var json = JSON.parse(data);
  1298. console.log("Organizr Function: Starting Install Wizard");
  1299. $(json.data).appendTo($('.organizr-area'));
  1300. }).fail(function(xhr) {
  1301. console.error("Organizr Function: Wizard Connection Failed");
  1302. });
  1303. $("#preloader").fadeOut();
  1304. }
  1305. function buildDependencyCheck(orgdata){
  1306. organizrConnect('api/?v1/dependencies_page').success(function(data) {
  1307. var json = JSON.parse(data);
  1308. console.log("Organizr Function: Starting Dependencies Check");
  1309. $(json.data).appendTo($('.organizr-area'));
  1310. $(buildBrowserInfo()).appendTo($('#browser-info'));
  1311. $('#web-folder').html(buildWebFolder(orgdata));
  1312. $(buildDependencyInfo(orgdata)).appendTo($('#depenency-info'));
  1313. }).fail(function(xhr) {
  1314. console.error("Organizr Function: Dependencies Connection Failed");
  1315. });
  1316. $("#preloader").fadeOut();
  1317. }
  1318. function buildDependencyInfo(arrayItems){
  1319. var listing = '';
  1320. $.each(arrayItems.data.status.dependenciesActive, function(i,v) {
  1321. listing += '<li class="depenency-item" data-name="'+v+'"><a href="javascript:void(0)"><i class="fa fa-check text-success"></i> '+v+'</a></li>';
  1322. });
  1323. $.each(arrayItems.data.status.dependenciesInactive, function(i,v) {
  1324. listing += '<li class="depenency-item" data-name="'+v+'"><a href="javascript:void(0)"><i class="fa fa-close text-danger"><div class="notify"><span class="heartbit"></span></div></i> '+v+'</a></li>';
  1325. });
  1326. return listing;
  1327. }
  1328. function buildWebFolder(arrayItems){
  1329. var writable = (arrayItems.data.status.writable == 'yes') ? 'Writable - All Good' : 'Not Writable - Please fix permissions';
  1330. var className = (writable == 'Writable - All Good') ? 'bg-primary' : 'bg-danger text-warning';
  1331. $('#web-folder').addClass(className);
  1332. return writable;
  1333. }
  1334. function buildBrowserInfo(){
  1335. var listing = '';
  1336. $.each(activeInfo, function(i,v) {
  1337. listing += `
  1338. <tr>
  1339. <td>`+i+`</td>
  1340. <td>`+tof(v)+`</td>
  1341. </tr>
  1342. `;
  1343. });
  1344. return `
  1345. <table class="table table-hover">
  1346. <tbody>
  1347. `+listing+`
  1348. </tbody>
  1349. </table>
  1350. `;
  1351. }
  1352. function tof(string,type){
  1353. var result;
  1354. if (typeof string == 'undefined' || string == 'false' || string == false || string == null || string == 0 || string == 'off' || string == 'no') {
  1355. result = "0";
  1356. }else if (string == 'true' || string == true || string == 1 || string == 'on' || string == 'yes') {
  1357. result = "1";
  1358. }
  1359. switch (type) {
  1360. case 'bool':
  1361. case 'b':
  1362. return (result == "0") ? (false) : ((result == "1") ? (true) : (string));
  1363. break;
  1364. case 'switch':
  1365. case 's':
  1366. return (result == "0") ? ('off') : ((result == "1") ? ('on') : (string));
  1367. break;
  1368. case 'checkbox':
  1369. case 'c':
  1370. return (result == "0") ? ('') : ((result == "1") ? ('checked') : (string));
  1371. break;
  1372. case 'integer':
  1373. case 'number':
  1374. case 'i':
  1375. case 'n':
  1376. return (result == "0") ? (0) : ((result == "1") ? (1) : (string));
  1377. break;
  1378. case 'question':
  1379. case 'q':
  1380. return (result == "0") ? ('yes') : ((result == "1") ? ('no') : (string));
  1381. break;
  1382. default:
  1383. return (result == "0") ? ("false") : ((result == "1") ? ("true") : (string));
  1384. }
  1385. }
  1386. function createRandomString( length ) {
  1387. var str = "";
  1388. for ( ; str.length < length; str += Math.random().toString( 36 ).substr( 2 ) );
  1389. return str.substr( 0, length );
  1390. }
  1391. function generateAPI(){
  1392. var string = createRandomString(20);
  1393. $('#form-api').focus();
  1394. $('#form-api').val(string);
  1395. $('#form-api').focusout();
  1396. $('#verify-api').text(string);
  1397. $('#form-username').focus();
  1398. }
  1399. function getCookie(cname) {
  1400. var name = cname + "=";
  1401. var decodedCookie = decodeURIComponent(document.cookie);
  1402. var ca = decodedCookie.split(';');
  1403. for(var i = 0; i <ca.length; i++) {
  1404. var c = ca[i];
  1405. while (c.charAt(0) == ' ') {
  1406. c = c.substring(1);
  1407. }
  1408. if (c.indexOf(name) == 0) {
  1409. return c.substring(name.length, c.length);
  1410. }
  1411. }
  1412. return "";
  1413. }
  1414. function localStorageSupport() {
  1415. return (('localStorage' in window) && window['localStorage'] !== null)
  1416. }
  1417. function local(type,key,value=null){
  1418. if (localStorageSupport) {
  1419. switch (type) {
  1420. case 'set':
  1421. case 's':
  1422. localStorage.setItem(key,value);
  1423. break;
  1424. case 'get':
  1425. case 'g':
  1426. return localStorage.getItem(key);
  1427. break;
  1428. case 'remove':
  1429. case 'r':
  1430. localStorage.removeItem(key);
  1431. break;
  1432. default:
  1433. console.warn('Organizr Function: localStorage action not defined');
  1434. }
  1435. }
  1436. }
  1437. function language(language){
  1438. var language = language.split("-");
  1439. return language[0];
  1440. }
  1441. function logIcon(type){
  1442. switch (type) {
  1443. case "success":
  1444. return '<i class="fa fa-check text-success"></i>';
  1445. break;
  1446. case "warning":
  1447. return '<i class="fa fa-exclamation-triangle text-warning"></i>';
  1448. break;
  1449. case "error":
  1450. return '<i class="fa fa-close text-danger"></i>';
  1451. break;
  1452. default:
  1453. }
  1454. }
  1455. function radioLoop(element){
  1456. $('[type=radio][id!="'+element.id+'"]').each(function() { this.checked=false });
  1457. }
  1458. function loadAppearance(appearance){
  1459. //console.log(appearance);
  1460. if(appearance.useLogo === false){
  1461. $('#main-logo').html(appearance.title);
  1462. $('#side-logo').html(appearance.title);
  1463. }else{
  1464. $('#main-logo').html('<img alt="home" class="dark-logo" height="60px" src="'+appearance.logo+'">');
  1465. $('#side-logo').html('<img alt="home" height="35px" src="'+appearance.logo+'">');
  1466. }
  1467. if(appearance.headerColor !== ''){
  1468. $('.navbar-header').css("background", appearance.headerColor);
  1469. }
  1470. if(appearance.loginWallpaper !== ''){
  1471. $('#user-appearance').html(`
  1472. .login-register {
  1473. background: url(`+appearance.loginWallpaper+`) center center/cover no-repeat!important;
  1474. height: 100%;
  1475. position: fixed;
  1476. }
  1477. .lock-screen {
  1478. background: url(`+appearance.loginWallpaper+`) center center/cover no-repeat!important;
  1479. height: 100%;
  1480. position: fixed;
  1481. z-index: 999999;
  1482. top: 0;
  1483. width: 100%;
  1484. -webkit-user-select: none;
  1485. -moz-user-select: none;
  1486. -ms-user-select: none;
  1487. -o-user-select: none;
  1488. user-select: none;
  1489. }
  1490. `);
  1491. }
  1492. }
  1493. function clearForm(form){
  1494. $(form+" input[type=text]", form+" input[type=password]").each(function() {
  1495. $(this).val('');
  1496. })
  1497. }
  1498. function checkMessage(){
  1499. var check = (local('get','message')) ? local('get','message') : false;
  1500. if(check){
  1501. local('remove', 'message');
  1502. var message = check.split('|');
  1503. messageSingle(window.lang.translate(message[0]),window.lang.translate(message[1]),'bottom-right','#FFF',message[2],'10000');
  1504. }
  1505. }
  1506. function launch(){
  1507. organizrConnect('api/?v1/launch_organizr').success(function (data) {
  1508. var json = JSON.parse(data);
  1509. if(json.data.user == false){ location.reload(); }
  1510. currentVersion = json.data.status.version;
  1511. activeInfo = {
  1512. timezone:Intl.DateTimeFormat().resolvedOptions().timeZone,
  1513. offest:new Date().getTimezoneOffset(),
  1514. language:language(moment.locale(navigator.languages[0])),
  1515. browserVersion:bowser.name,
  1516. browserName:bowser.version,
  1517. mobile:bowser.mobile,
  1518. tablet:bowser.tablet,
  1519. osName:bowser.osname,
  1520. osVersion:bowser.osversion,
  1521. serverOS:json.data.status.os,
  1522. phpVersion:json.data.status.php,
  1523. token:json.data.user.token,
  1524. branch:json.branch
  1525. };
  1526. console.log("%cOrganizr","color: #66D9EF; font-size: 24px; font-family: Monospace;");
  1527. console.log("%cVersion: "+currentVersion,"color: #AD80FD; font-size: 12px; font-family: Monospace;");
  1528. console.log("%cStarting Up...","color: #F92671; font-size: 12px; font-family: Monospace;")
  1529. switch (json.data.status.status) {
  1530. case "wizard":
  1531. buildWizard();
  1532. buildLanguage('wizard');
  1533. break;
  1534. case "dependencies":
  1535. buildDependencyCheck(json);
  1536. break;
  1537. case "ok":
  1538. loadAppearance(json.appearance);
  1539. userMenu(json);
  1540. categoryProcess(json);
  1541. tabProcess(json);
  1542. break;
  1543. default:
  1544. console.error('Organizr Function: Action not set or defined');
  1545. }
  1546. });
  1547. checkMessage();
  1548. }