From 7342b1f3850299264b571d1d63778173c9a30703 Mon Sep 17 00:00:00 2001 From: ulrich <not disclosed> Date: Mon, 20 Feb 2017 10:53:46 +0000 Subject: [PATCH] list in Arbeit --- web/ui/ui.js | 126 ++++++++++++++++++++++++++++++++++++----- 1 files changed, 110 insertions(+), 16 deletions(-) diff --git a/web/ui/ui.js b/web/ui/ui.js index 3e80f3c..c2a6c42 100644 --- a/web/ui/ui.js +++ b/web/ui/ui.js @@ -4,7 +4,14 @@ $('.codeeditor-space').hide(); $('.code-editor-container').hide(); $('#newTextFile').on('click', fm_menu_neue_textdatei); + $('#saveFile').on('click', fm_menu_datei_speichern); $('#closeFile').on('click', fm_menu_datei_schliessen); + $('#myModal').on('hidden.bs.modal', function (e) { + $('#modal_ok').attr('onclick','').unbind('click'); + }); + $('#logout').click(fm_logout); + fm_get_login(); + fm_get_list(''); } function fm_menu_neue_textdatei() { @@ -21,11 +28,79 @@ $('#dateiansicht').show(); } +/* ----- API Calls ------------- */ + +function fm_get_login() { + var m = '?c=de.uhilger.um.pub.SessionManager&m=getSessionUser'; + var u = '../../um/pub' + m; + fm_get(u, "json", function(resp) { + $('#userMenu').text(resp.UserData.firstName); + }); +} + +// http://localhost:8079/file-cms/svc?c=de.uhilger.filecms.api.FileMgr&f=JSONNICE&m=list&p= +function fm_get_list(relPath) { + var m = '?c=de.uhilger.filecms.api.FileMgr&m=list&p=' + relPath; + var u = '../svc' + m; + fm_get(u, "json", function(resp) { + var files = new Array(); + for(var i = 0; i < resp.List[0].FileRef.length; i++) { + files.push(new FileRef(resp.List[0].FileRef[i])); + } + var fl = new FileList(files); + var template = $('#tpl-kacheln').html(); + Mustache.parse(template); // optional, speeds up future uses + $('#dateien').empty(); + $('#dateien').html(Mustache.render(template, fl)); + }); +} + +function fm_menu_datei_speichern() { + + $('#modal_ok').click(function() { + // hier speichern + var m = '?c=de.uhilger.filecms.api.FileMgr&m=saveTextFile'; + var u = '../svc' + m; + fm_post(u, {p1: '', p2: $('#dateiname').val(), p3: cm.getValue()}, function(resp) { + + }); + }); + $('#saveModal').modal({ + keyboard: false, + show: true + }); + + + // FileRef saveTextFile(String relPath, String fileName, String contents) + + + /* + var t = new Template(-2, $('#filename').val(), self.cm.getValue(), 3); + var u = '../api/tr/?c=de.uhilger.webbox.api.ContentApi&m=newTemplate'; + self.post(u, {p: self.serialise(t)}, function (resp) { + self.isnew = false; + self.editid = resp.Template.id; + $('#contlist').append(self.buildContListItem(3, resp.Template.name, resp.Template.id)); + $('#templateeditor').addClass('hidden'); + }); + */ +} + +function fm_logout() { + var m = '?c=de.uhilger.filecms.pub.SessionManager&m=expireSession'; + var u = '../pub' + m; + + fm_get(u, "text", function(resp) { + $('#userMenu').text('nicht angemeldet'); + window.location.href = '../logout.html'; + }); +} + + /* ---- codemirror editor handling -------- */ function fm_code_edit(content) { - var windowHeight = $(window).height(); - + //var windowHeight = $(window).height(); //$("editspace").empty(); //self.cm.toTextArea(); @@ -34,29 +109,26 @@ mode: "xml", viewportMargin : Infinity, extraKeys: { - "F9": function(cm) { - cm.setOption("fullScreen", !cm.getOption("fullScreen")); - }, - "Esc": function(cm) { - if (cm.getOption("fullScreen")) cm.setOption("fullScreen", false); - } + "F9": function(cm) { + cm.setOption("fullScreen", !cm.getOption("fullScreen")); + }, + "Esc": function(cm) { + if (cm.getOption("fullScreen")) cm.setOption("fullScreen", false); + } } }); - - // cm.setSize("100%", windowHeight - 100); // w, h cm.setValue(content); - -}; +} /* -------- helper functions ----------- */ -function fm_get(u, scallback) { +function fm_get(u, dtype, scallback) { $.ajax({ url: u, type: "GET", - dataType: "json", + dataType: dtype, success: scallback, error: function (xhr, status, errorThrown) { alert("Error: " + errorThrown + " Status: " + status + " URL: " + u); @@ -66,7 +138,7 @@ } }); -}; +} function fm_post(u, d, scallback) { $.ajax({ @@ -82,5 +154,27 @@ //alert( "The request is complete!" ); } }); -}; +} +function fm_serialise(obj) { + return '{"' + obj.constructor.name + '":' + JSON.stringify(obj) + '}'; +} + +/* ----- Objekte ----- */ + +function FileList(fl) { + this.files = fl; +} + +function FileRef(obj) { + var self = this; + this.fr = obj; + + this.typeClass = function() { + if(self.fr.isDirectory) { + return 'fa-folder'; + } else { + return 'fa-file'; + } + } +} -- Gitblit v1.9.3