123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285 |
- var lychee = {
- init: function() {
- this.version = "1.3";
- this.api_path = "php/api.php";
- this.update_path = "http://lychee.electerious.com/version/index.php";
- this.updateURL = "https://github.com/electerious/Lychee";
- this.upload_path_thumb = "uploads/thumb/";
- this.upload_path_big = "uploads/big/";
- this.publicMode = false;
- this.viewMode = false;
- this.checkForUpdates = false;
- this.dropbox = false;
- this.loadingBar = $("#loading");
- this.header = $("header");
- this.content = $("#content");
- this.imageview = $("#imageview");
- this.infobox = $("#infobox");
- },
- run: function() {
- lychee.api("init", "json", function(data) {
- lychee.checkForUpdates = data.config.checkForUpdates;
- if (!data.loggedIn) lychee.setMode("public");
- $(window).bind("popstate", lychee.load);
- lychee.load();
- });
- },
- api: function(params, type, callback, loading) {
- if (loading==undefined) loadingBar.show();
- $.ajax({
- type: "POST",
- url: lychee.api_path,
- data: "function=" + params,
- dataType: type,
- success:
- function(data) {
- $.timer(100, function(){ loadingBar.hide() });
- callback(data);
- },
- error: lychee.error
- });
- },
- login: function() {
- var user = $("input#username").val(),
- password = hex_md5($("input#password").val()),
- params;
- params = "login&user=" + user + "&password=" + password;
- lychee.api(params, "text", function(data) {
- if (data) {
- localStorage.setItem("username", user);
- window.location.reload();
- } else {
- $("#password").val("").addClass("error");
- $(".message .button.active").removeClass("pressed");
- }
- });
- },
- loginDialog: function() {
- $("body").append(build.signInModal());
- $("#username").focus();
- if (localStorage) {
- local_username = localStorage.getItem("username");
- if (local_username!=null) {
- if (local_username.length>0) $("#username").val(local_username);
- $("#password").focus();
- }
- }
- if (lychee.checkForUpdates) lychee.getUpdate();
- },
- logout: function() {
- lychee.api("logout", "text", function(data) {
- window.location.reload();
- });
- },
- goto: function(url) {
- if (url==undefined) url = "";
- document.location.hash = url;
- },
- load: function() {
- var albumID = "",
- photoID = "",
- hash = document.location.hash.replace("#", "");
- contextMenu.close();
- if (hash.indexOf("a")!=-1) albumID = hash.split("p")[0].replace("a", "");
- if (hash.indexOf("p")!=-1) photoID = hash.split("p")[1];
- if (albumID&&photoID) {
-
- albums.json = null;
- photo.json = null;
-
- if (lychee.content.html()==""||($("#search").length&&$("#search").val().length!=0)) {
- lychee.content.hide();
- album.load(albumID, true);
- }
- if (!visible.photo()) view.photo.show();
- photo.load(photoID, albumID);
- } else if (albumID) {
-
- albums.json = null;
- photo.json = null;
-
- if (visible.photo()) view.photo.hide();
- if (album.json&&albumID==album.json.id) view.album.title();
- else album.load(albumID);
- } else {
-
- albums.json = null;
- album.json = null;
- photo.json = null;
- search.code = "";
-
- if (visible.photo()) view.photo.hide();
- albums.load();
- }
- },
- getUpdate: function() {
- $.ajax({
- url: lychee.update_path,
- success: function(data) { if (data!=lychee.version) $("#version span").show(); }
- });
- },
- setTitle: function(title, count, editable) {
- if (title=="Albums") document.title = "Lychee";
- else document.title = "Lychee - " + title;
- if (count) title += "<span> - " + count + " photos</span>";
- if (editable) $("#title").addClass("editable");
- else $("#title").removeClass("editable");
- $("#title").html(title);
- },
- setMode: function(mode) {
- $("#button_signout, #search, #button_trash_album, #button_share_album, #button_edit_album, .button_add, #button_archive, .button_divider").remove();
- $("#button_trash, #button_move, #button_edit, #button_share, #button_star").remove();
- $(document)
- .on("mouseenter", "#title.editable", function() { $(this).removeClass("editable") })
- .off("click", "#title.editable")
- .off("touchend", "#title.editable")
- .off("contextmenu", ".photo")
- .off("contextmenu", ".album")
- .off("drop");
- Mousetrap
- .unbind('n')
- .unbind('u')
- .unbind('s')
- .unbind('backspace');
- if (mode=="public") {
- $("#button_signin").show();
- lychee.publicMode = true;
- } else if (mode=="view") {
- Mousetrap.unbind('esc');
- $("#button_back, a#next, a#previous").remove();
- lychee.publicMode = true;
- lychee.viewMode = true;
- }
- },
- animate: function(obj, animation) {
- var animations = [
- ["fadeIn", "fadeOut"],
- ["contentZoomIn", "contentZoomOut"]
- ];
- if (!obj.jQuery) obj = $(obj);
- for (var i = 0; i < animations.length; i++) {
- for (var x = 0; x < animations[i].length; x++) {
- if (animations[i][x]==animation) {
- obj.removeClass(animations[i][0] + " " + animations[i][1]).addClass(animation);
- return true;
- }
- }
- }
- return false;
- },
- loadDropbox: function(callback) {
- if (!lychee.dropbox) {
- loadingBar.show();
- var g = document.createElement("script"),
- s = document.getElementsByTagName("script")[0];
- g.src = "https://www.dropbox.com/static/api/1/dropins.js";
- g.id = "dropboxjs";
- g.type = "text/javascript";
- g.async = "true";
- g.setAttribute("data-app-key", "iq7lioj9wu0ieqs");
- g.onload = g.onreadystatechange = function() {
- var rs = this.readyState;
- if (rs&&rs!="complete"&&rs!="loaded") return;
- lychee.dropbox = true;
- loadingBar.hide();
- callback();
- };
- s.parentNode.insertBefore(g, s);
- } else callback();
- },
- error: function(jqXHR, textStatus, errorThrown) {
- console.log(jqXHR);
- console.log(textStatus);
- console.log(errorThrown);
- loadingBar.show("error", textStatus, errorThrown);
- }
- }
|