diff --git a/examples/members.txt b/examples/members.txt
index 67eb1ee..87969b0 100644
--- a/examples/members.txt
+++ b/examples/members.txt
@@ -88,3 +88,15 @@ POST /members/api/request/:id
//reject member request (== delete request and delete member)
DELETE /members/api/request/:id
+
+
+// mass import from csv
+POST /members/api/csvimport
+//csvformat first_name,last_name,email,POR,AYY,JAS
+// example data
+Pekka,Pöytä,pekka.p.pouta@mosh.pit,Tuska,1,0
+
+// example response on success
+{"status": "success", "errors": []}
+// example response on failure (code will be 400)
+{"status": "failure", "errors": ["failure adding item Pekka, P\u00f6yt\u00e42, pekka.p.pouta@mosh.pit, Tuska, Eip"]}
diff --git a/members/models.py b/members/models.py
index 436a73d..97398e0 100644
--- a/members/models.py
+++ b/members/models.py
@@ -1,5 +1,7 @@
from django.db import models
from django.utils import timezone
+from io import StringIO
+import csv
class Member(models.Model):
'''
@@ -45,9 +47,33 @@ class Member(models.Model):
except KeyError:
pass
self.save()
+ @classmethod
+ def import_csv(cls, csv_string):
+ reader = csv.reader(StringIO(csv_string.strip()))
+ response = {"status": "success", "errors": []};
+ try:
+ data = list(reader)
+ except ValueError:
+ return {"status": "failure", "errors": ["could not parse csv file"]}
+ for row in data:
+ try:
+ obj = cls.objects.create(
+ first_name=row[0],
+ last_name=row[1],
+ email=row[2],
+ POR=row[3],
+ AYY=row[4].lower() in ['yes','y','1','true',"kyllä", "khyl"],
+ jas=row[5].lower() in ['yes','y','1','true',"kyllä", "khyl"],
+ )
+ print("added obj {}".format(obj))
+ except:
+ response["status"] = "failure"
+ response["errors"].append("failure adding item {}".format(", ".join(row)))
+
+ return response
def __str__(self):
- return "{} {}".format(first_name, last_name)
+ return "{} {}".format(self.first_name, self.last_name)
class MemberRequest(models.Model):
member = models.ForeignKey(Member)
diff --git a/members/static/html/rekisteri.html b/members/static/html/rekisteri.html
deleted file mode 100644
index c8b0e7b..0000000
--- a/members/static/html/rekisteri.html
+++ /dev/null
@@ -1,26 +0,0 @@
-
-
-
- Haku
-
-
-
-
-
-
-
-
-
-
Jäsenrekisteri
-
Hae jäsen
-
Syötä jäsenen nimi:
-
-
-
-
\ No newline at end of file
diff --git a/members/static/js/appconfig.js b/members/static/js/appconfig.js
new file mode 100644
index 0000000..382521e
--- /dev/null
+++ b/members/static/js/appconfig.js
@@ -0,0 +1,6 @@
+var app = angular.module('memberApp', ['ngRoute']);
+
+app.config(['$httpProvider', function ($httpProvider) {
+ $httpProvider.defaults.xsrfCookieName = 'csrftoken';
+ $httpProvider.defaults.xsrfHeaderName = 'X-CSRFToken';
+}]);
\ No newline at end of file
diff --git a/members/static/js/jquery.noty.packaged.js b/members/static/js/jquery.noty.packaged.js
new file mode 100644
index 0000000..c799814
--- /dev/null
+++ b/members/static/js/jquery.noty.packaged.js
@@ -0,0 +1,1442 @@
+!function(root, factory) {
+ if (typeof define === 'function' && define.amd) {
+ define(['jquery'], factory);
+ } else if (typeof exports === 'object') {
+ module.exports = factory(require('jquery'));
+ } else {
+ factory(root.jQuery);
+ }
+}(this, function($) {
+
+/*!
+ @package noty - jQuery Notification Plugin
+ @version version: 2.3.8
+ @contributors https://github.com/needim/noty/graphs/contributors
+
+ @documentation Examples and Documentation - http://needim.github.com/noty/
+
+ @license Licensed under the MIT licenses: http://www.opensource.org/licenses/mit-license.php
+ */
+
+ if(typeof Object.create !== 'function') {
+ Object.create = function(o) {
+ function F() {
+ }
+
+ F.prototype = o;
+ return new F();
+ };
+ }
+
+ var NotyObject = {
+
+ init: function(options) {
+
+ // Mix in the passed in options with the default options
+ this.options = $.extend({}, $.noty.defaults, options);
+
+ this.options.layout = (this.options.custom) ? $.noty.layouts['inline'] : $.noty.layouts[this.options.layout];
+
+ if($.noty.themes[this.options.theme])
+ this.options.theme = $.noty.themes[this.options.theme];
+ else
+ this.options.themeClassName = this.options.theme;
+
+ this.options = $.extend({}, this.options, this.options.layout.options);
+ this.options.id = 'noty_' + (new Date().getTime() * Math.floor(Math.random() * 1000000));
+
+ // Build the noty dom initial structure
+ this._build();
+
+ // return this so we can chain/use the bridge with less code.
+ return this;
+ }, // end init
+
+ _build: function() {
+
+ // Generating noty bar
+ var $bar = $('').attr('id', this.options.id);
+ $bar.append(this.options.template).find('.noty_text').html(this.options.text);
+
+ this.$bar = (this.options.layout.parent.object !== null) ? $(this.options.layout.parent.object).css(this.options.layout.parent.css).append($bar) : $bar;
+
+ if(this.options.themeClassName)
+ this.$bar.addClass(this.options.themeClassName).addClass('noty_container_type_' + this.options.type);
+
+ // Set buttons if available
+ if(this.options.buttons) {
+
+ // If we have button disable closeWith & timeout options
+ this.options.closeWith = [];
+ this.options.timeout = false;
+
+ var $buttons = $('').addClass('noty_buttons');
+
+ (this.options.layout.parent.object !== null) ? this.$bar.find('.noty_bar').append($buttons) : this.$bar.append($buttons);
+
+ var self = this;
+
+ $.each(this.options.buttons, function(i, button) {
+ var $button = $('').addClass((button.addClass) ? button.addClass : 'gray').html(button.text).attr('id', button.id ? button.id : 'button-' + i)
+ .attr('title', button.title)
+ .appendTo(self.$bar.find('.noty_buttons'))
+ .on('click', function(event) {
+ if($.isFunction(button.onClick)) {
+ button.onClick.call($button, self, event);
+ }
+ });
+ });
+ }
+
+ // For easy access
+ this.$message = this.$bar.find('.noty_message');
+ this.$closeButton = this.$bar.find('.noty_close');
+ this.$buttons = this.$bar.find('.noty_buttons');
+
+ $.noty.store[this.options.id] = this; // store noty for api
+
+ }, // end _build
+
+ show: function() {
+
+ var self = this;
+
+ (self.options.custom) ? self.options.custom.find(self.options.layout.container.selector).append(self.$bar) : $(self.options.layout.container.selector).append(self.$bar);
+
+ if(self.options.theme && self.options.theme.style)
+ self.options.theme.style.apply(self);
+
+ ($.type(self.options.layout.css) === 'function') ? this.options.layout.css.apply(self.$bar) : self.$bar.css(this.options.layout.css || {});
+
+ self.$bar.addClass(self.options.layout.addClass);
+
+ self.options.layout.container.style.apply($(self.options.layout.container.selector), [self.options.within]);
+
+ self.showing = true;
+
+ if(self.options.theme && self.options.theme.style)
+ self.options.theme.callback.onShow.apply(this);
+
+ if($.inArray('click', self.options.closeWith) > -1)
+ self.$bar.css('cursor', 'pointer').one('click', function(evt) {
+ self.stopPropagation(evt);
+ if(self.options.callback.onCloseClick) {
+ self.options.callback.onCloseClick.apply(self);
+ }
+ self.close();
+ });
+
+ if($.inArray('hover', self.options.closeWith) > -1)
+ self.$bar.one('mouseenter', function() {
+ self.close();
+ });
+
+ if($.inArray('button', self.options.closeWith) > -1)
+ self.$closeButton.one('click', function(evt) {
+ self.stopPropagation(evt);
+ self.close();
+ });
+
+ if($.inArray('button', self.options.closeWith) == -1)
+ self.$closeButton.remove();
+
+ if(self.options.callback.onShow)
+ self.options.callback.onShow.apply(self);
+
+ if (typeof self.options.animation.open == 'string') {
+ self.$bar.css('height', self.$bar.innerHeight());
+ self.$bar.on('click',function(e){
+ self.wasClicked = true;
+ });
+ self.$bar.show().addClass(self.options.animation.open).one('webkitAnimationEnd mozAnimationEnd MSAnimationEnd oanimationend animationend', function() {
+ if(self.options.callback.afterShow) self.options.callback.afterShow.apply(self);
+ self.showing = false;
+ self.shown = true;
+ if(self.hasOwnProperty('wasClicked')){
+ self.$bar.off('click',function(e){
+ self.wasClicked = true;
+ });
+ self.close();
+ }
+ });
+
+ } else {
+ self.$bar.animate(
+ self.options.animation.open,
+ self.options.animation.speed,
+ self.options.animation.easing,
+ function() {
+ if(self.options.callback.afterShow) self.options.callback.afterShow.apply(self);
+ self.showing = false;
+ self.shown = true;
+ });
+ }
+
+ // If noty is have a timeout option
+ if(self.options.timeout)
+ self.$bar.delay(self.options.timeout).promise().done(function() {
+ self.close();
+ });
+
+ return this;
+
+ }, // end show
+
+ close: function() {
+
+ if(this.closed) return;
+ if(this.$bar && this.$bar.hasClass('i-am-closing-now')) return;
+
+ var self = this;
+
+ if(this.showing) {
+ self.$bar.queue(
+ function() {
+ self.close.apply(self);
+ }
+ );
+ return;
+ }
+
+ if(!this.shown && !this.showing) { // If we are still waiting in the queue just delete from queue
+ var queue = [];
+ $.each($.noty.queue, function(i, n) {
+ if(n.options.id != self.options.id) {
+ queue.push(n);
+ }
+ });
+ $.noty.queue = queue;
+ return;
+ }
+
+ self.$bar.addClass('i-am-closing-now');
+
+ if(self.options.callback.onClose) {
+ self.options.callback.onClose.apply(self);
+ }
+
+ if (typeof self.options.animation.close == 'string') {
+ self.$bar.addClass(self.options.animation.close).one('webkitAnimationEnd mozAnimationEnd MSAnimationEnd oanimationend animationend', function() {
+ if(self.options.callback.afterClose) self.options.callback.afterClose.apply(self);
+ self.closeCleanUp();
+ });
+ } else {
+ self.$bar.clearQueue().stop().animate(
+ self.options.animation.close,
+ self.options.animation.speed,
+ self.options.animation.easing,
+ function() {
+ if(self.options.callback.afterClose) self.options.callback.afterClose.apply(self);
+ })
+ .promise().done(function() {
+ self.closeCleanUp();
+ });
+ }
+
+ }, // end close
+
+ closeCleanUp: function() {
+
+ var self = this;
+
+ // Modal Cleaning
+ if(self.options.modal) {
+ $.notyRenderer.setModalCount(-1);
+ if($.notyRenderer.getModalCount() == 0) $('.noty_modal').fadeOut(self.options.animation.fadeSpeed, function() {
+ $(this).remove();
+ });
+ }
+
+ // Layout Cleaning
+ $.notyRenderer.setLayoutCountFor(self, -1);
+ if($.notyRenderer.getLayoutCountFor(self) == 0) $(self.options.layout.container.selector).remove();
+
+ // Make sure self.$bar has not been removed before attempting to remove it
+ if(typeof self.$bar !== 'undefined' && self.$bar !== null) {
+
+ if (typeof self.options.animation.close == 'string') {
+ self.$bar.css('transition', 'all 100ms ease').css('border', 0).css('margin', 0).height(0);
+ self.$bar.one('transitionend webkitTransitionEnd oTransitionEnd MSTransitionEnd', function() {
+ self.$bar.remove();
+ self.$bar = null;
+ self.closed = true;
+
+ if(self.options.theme.callback && self.options.theme.callback.onClose) {
+ self.options.theme.callback.onClose.apply(self);
+ }
+ });
+ } else {
+ self.$bar.remove();
+ self.$bar = null;
+ self.closed = true;
+ }
+ }
+
+ delete $.noty.store[self.options.id]; // deleting noty from store
+
+ if(self.options.theme.callback && self.options.theme.callback.onClose) {
+ self.options.theme.callback.onClose.apply(self);
+ }
+
+ if(!self.options.dismissQueue) {
+ // Queue render
+ $.noty.ontap = true;
+
+ $.notyRenderer.render();
+ }
+
+ if(self.options.maxVisible > 0 && self.options.dismissQueue) {
+ $.notyRenderer.render();
+ }
+
+ }, // end close clean up
+
+ setText: function(text) {
+ if(!this.closed) {
+ this.options.text = text;
+ this.$bar.find('.noty_text').html(text);
+ }
+ return this;
+ },
+
+ setType: function(type) {
+ if(!this.closed) {
+ this.options.type = type;
+ this.options.theme.style.apply(this);
+ this.options.theme.callback.onShow.apply(this);
+ }
+ return this;
+ },
+
+ setTimeout: function(time) {
+ if(!this.closed) {
+ var self = this;
+ this.options.timeout = time;
+ self.$bar.delay(self.options.timeout).promise().done(function() {
+ self.close();
+ });
+ }
+ return this;
+ },
+
+ stopPropagation: function(evt) {
+ evt = evt || window.event;
+ if(typeof evt.stopPropagation !== "undefined") {
+ evt.stopPropagation();
+ }
+ else {
+ evt.cancelBubble = true;
+ }
+ },
+
+ closed : false,
+ showing: false,
+ shown : false
+
+ }; // end NotyObject
+
+ $.notyRenderer = {};
+
+ $.notyRenderer.init = function(options) {
+
+ // Renderer creates a new noty
+ var notification = Object.create(NotyObject).init(options);
+
+ if(notification.options.killer)
+ $.noty.closeAll();
+
+ (notification.options.force) ? $.noty.queue.unshift(notification) : $.noty.queue.push(notification);
+
+ $.notyRenderer.render();
+
+ return ($.noty.returns == 'object') ? notification : notification.options.id;
+ };
+
+ $.notyRenderer.render = function() {
+
+ var instance = $.noty.queue[0];
+
+ if($.type(instance) === 'object') {
+ if(instance.options.dismissQueue) {
+ if(instance.options.maxVisible > 0) {
+ if($(instance.options.layout.container.selector + ' > li').length < instance.options.maxVisible) {
+ $.notyRenderer.show($.noty.queue.shift());
+ }
+ else {
+
+ }
+ }
+ else {
+ $.notyRenderer.show($.noty.queue.shift());
+ }
+ }
+ else {
+ if($.noty.ontap) {
+ $.notyRenderer.show($.noty.queue.shift());
+ $.noty.ontap = false;
+ }
+ }
+ }
+ else {
+ $.noty.ontap = true; // Queue is over
+ }
+
+ };
+
+ $.notyRenderer.show = function(notification) {
+
+ if(notification.options.modal) {
+ $.notyRenderer.createModalFor(notification);
+ $.notyRenderer.setModalCount(+1);
+ }
+
+ // Where is the container?
+ if(notification.options.custom) {
+ if(notification.options.custom.find(notification.options.layout.container.selector).length == 0) {
+ notification.options.custom.append($(notification.options.layout.container.object).addClass('i-am-new'));
+ }
+ else {
+ notification.options.custom.find(notification.options.layout.container.selector).removeClass('i-am-new');
+ }
+ }
+ else {
+ if($(notification.options.layout.container.selector).length == 0) {
+ $('body').append($(notification.options.layout.container.object).addClass('i-am-new'));
+ }
+ else {
+ $(notification.options.layout.container.selector).removeClass('i-am-new');
+ }
+ }
+
+ $.notyRenderer.setLayoutCountFor(notification, +1);
+
+ notification.show();
+ };
+
+ $.notyRenderer.createModalFor = function(notification) {
+ if($('.noty_modal').length == 0) {
+ var modal = $('').addClass('noty_modal').addClass(notification.options.theme).data('noty_modal_count', 0);
+
+ if(notification.options.theme.modal && notification.options.theme.modal.css)
+ modal.css(notification.options.theme.modal.css);
+
+ modal.prependTo($('body')).fadeIn(notification.options.animation.fadeSpeed);
+
+ if($.inArray('backdrop', notification.options.closeWith) > -1)
+ modal.on('click', function(e) {
+ $.noty.closeAll();
+ });
+ }
+ };
+
+ $.notyRenderer.getLayoutCountFor = function(notification) {
+ return $(notification.options.layout.container.selector).data('noty_layout_count') || 0;
+ };
+
+ $.notyRenderer.setLayoutCountFor = function(notification, arg) {
+ return $(notification.options.layout.container.selector).data('noty_layout_count', $.notyRenderer.getLayoutCountFor(notification) + arg);
+ };
+
+ $.notyRenderer.getModalCount = function() {
+ return $('.noty_modal').data('noty_modal_count') || 0;
+ };
+
+ $.notyRenderer.setModalCount = function(arg) {
+ return $('.noty_modal').data('noty_modal_count', $.notyRenderer.getModalCount() + arg);
+ };
+
+ // This is for custom container
+ $.fn.noty = function(options) {
+ options.custom = $(this);
+ return $.notyRenderer.init(options);
+ };
+
+ $.noty = {};
+ $.noty.queue = [];
+ $.noty.ontap = true;
+ $.noty.layouts = {};
+ $.noty.themes = {};
+ $.noty.returns = 'object';
+ $.noty.store = {};
+
+ $.noty.get = function(id) {
+ return $.noty.store.hasOwnProperty(id) ? $.noty.store[id] : false;
+ };
+
+ $.noty.close = function(id) {
+ return $.noty.get(id) ? $.noty.get(id).close() : false;
+ };
+
+ $.noty.setText = function(id, text) {
+ return $.noty.get(id) ? $.noty.get(id).setText(text) : false;
+ };
+
+ $.noty.setType = function(id, type) {
+ return $.noty.get(id) ? $.noty.get(id).setType(type) : false;
+ };
+
+ $.noty.clearQueue = function() {
+ $.noty.queue = [];
+ };
+
+ $.noty.closeAll = function() {
+ $.noty.clearQueue();
+ $.each($.noty.store, function(id, noty) {
+ noty.close();
+ });
+ };
+
+ var windowAlert = window.alert;
+
+ $.noty.consumeAlert = function(options) {
+ window.alert = function(text) {
+ if(options)
+ options.text = text;
+ else
+ options = {text: text};
+
+ $.notyRenderer.init(options);
+ };
+ };
+
+ $.noty.stopConsumeAlert = function() {
+ window.alert = windowAlert;
+ };
+
+ $.noty.defaults = {
+ layout : 'top',
+ theme : 'defaultTheme',
+ type : 'alert',
+ text : '',
+ dismissQueue: true,
+ template : '',
+ animation : {
+ open : {height: 'toggle'},
+ close : {height: 'toggle'},
+ easing: 'swing',
+ speed : 500,
+ fadeSpeed: 'fast',
+ },
+ timeout : false,
+ force : false,
+ modal : false,
+ maxVisible : 5,
+ killer : false,
+ closeWith : ['click'],
+ callback : {
+ onShow : function() {
+ },
+ afterShow : function() {
+ },
+ onClose : function() {
+ },
+ afterClose : function() {
+ },
+ onCloseClick: function() {
+ }
+ },
+ buttons : false
+ };
+
+ $(window).on('resize', function() {
+ $.each($.noty.layouts, function(index, layout) {
+ layout.container.style.apply($(layout.container.selector));
+ });
+ });
+
+ // Helpers
+ window.noty = function noty(options) {
+ return $.notyRenderer.init(options);
+ };
+
+$.noty.layouts.bottom = {
+ name : 'bottom',
+ options : {},
+ container: {
+ object : '',
+ selector: 'ul#noty_bottom_layout_container',
+ style : function() {
+ $(this).css({
+ bottom : 0,
+ left : '5%',
+ position : 'fixed',
+ width : '90%',
+ height : 'auto',
+ margin : 0,
+ padding : 0,
+ listStyleType: 'none',
+ zIndex : 9999999
+ });
+ }
+ },
+ parent : {
+ object : '',
+ selector: 'li',
+ css : {}
+ },
+ css : {
+ display: 'none'
+ },
+ addClass : ''
+};
+
+$.noty.layouts.bottomCenter = {
+ name : 'bottomCenter',
+ options : { // overrides options
+
+ },
+ container: {
+ object : '',
+ selector: 'ul#noty_bottomCenter_layout_container',
+ style : function() {
+ $(this).css({
+ bottom : 20,
+ left : 0,
+ position : 'fixed',
+ width : '310px',
+ height : 'auto',
+ margin : 0,
+ padding : 0,
+ listStyleType: 'none',
+ zIndex : 10000000
+ });
+
+ $(this).css({
+ left: ($(window).width() - $(this).outerWidth(false)) / 2 + 'px'
+ });
+ }
+ },
+ parent : {
+ object : '',
+ selector: 'li',
+ css : {}
+ },
+ css : {
+ display: 'none',
+ width : '310px'
+ },
+ addClass : ''
+};
+
+
+$.noty.layouts.bottomLeft = {
+ name : 'bottomLeft',
+ options : { // overrides options
+
+ },
+ container: {
+ object : '',
+ selector: 'ul#noty_bottomLeft_layout_container',
+ style : function() {
+ $(this).css({
+ bottom : 20,
+ left : 20,
+ position : 'fixed',
+ width : '310px',
+ height : 'auto',
+ margin : 0,
+ padding : 0,
+ listStyleType: 'none',
+ zIndex : 10000000
+ });
+
+ if(window.innerWidth < 600) {
+ $(this).css({
+ left: 5
+ });
+ }
+ }
+ },
+ parent : {
+ object : '',
+ selector: 'li',
+ css : {}
+ },
+ css : {
+ display: 'none',
+ width : '310px'
+ },
+ addClass : ''
+};
+$.noty.layouts.bottomRight = {
+ name : 'bottomRight',
+ options : { // overrides options
+
+ },
+ container: {
+ object : '',
+ selector: 'ul#noty_bottomRight_layout_container',
+ style : function() {
+ $(this).css({
+ bottom : 20,
+ right : 20,
+ position : 'fixed',
+ width : '310px',
+ height : 'auto',
+ margin : 0,
+ padding : 0,
+ listStyleType: 'none',
+ zIndex : 10000000
+ });
+
+ if(window.innerWidth < 600) {
+ $(this).css({
+ right: 5
+ });
+ }
+ }
+ },
+ parent : {
+ object : '',
+ selector: 'li',
+ css : {}
+ },
+ css : {
+ display: 'none',
+ width : '310px'
+ },
+ addClass : ''
+};
+$.noty.layouts.center = {
+ name : 'center',
+ options : { // overrides options
+
+ },
+ container: {
+ object : '',
+ selector: 'ul#noty_center_layout_container',
+ style : function() {
+ $(this).css({
+ position : 'fixed',
+ width : '310px',
+ height : 'auto',
+ margin : 0,
+ padding : 0,
+ listStyleType: 'none',
+ zIndex : 10000000
+ });
+
+ // getting hidden height
+ var dupe = $(this).clone().css({visibility: "hidden", display: "block", position: "absolute", top: 0, left: 0}).attr('id', 'dupe');
+ $("body").append(dupe);
+ dupe.find('.i-am-closing-now').remove();
+ dupe.find('li').css('display', 'block');
+ var actual_height = dupe.height();
+ dupe.remove();
+
+ if($(this).hasClass('i-am-new')) {
+ $(this).css({
+ left: ($(window).width() - $(this).outerWidth(false)) / 2 + 'px',
+ top : ($(window).height() - actual_height) / 2 + 'px'
+ });
+ }
+ else {
+ $(this).animate({
+ left: ($(window).width() - $(this).outerWidth(false)) / 2 + 'px',
+ top : ($(window).height() - actual_height) / 2 + 'px'
+ }, 500);
+ }
+
+ }
+ },
+ parent : {
+ object : '',
+ selector: 'li',
+ css : {}
+ },
+ css : {
+ display: 'none',
+ width : '310px'
+ },
+ addClass : ''
+};
+$.noty.layouts.centerLeft = {
+ name : 'centerLeft',
+ options : { // overrides options
+
+ },
+ container: {
+ object : '',
+ selector: 'ul#noty_centerLeft_layout_container',
+ style : function() {
+ $(this).css({
+ left : 20,
+ position : 'fixed',
+ width : '310px',
+ height : 'auto',
+ margin : 0,
+ padding : 0,
+ listStyleType: 'none',
+ zIndex : 10000000
+ });
+
+ // getting hidden height
+ var dupe = $(this).clone().css({visibility: "hidden", display: "block", position: "absolute", top: 0, left: 0}).attr('id', 'dupe');
+ $("body").append(dupe);
+ dupe.find('.i-am-closing-now').remove();
+ dupe.find('li').css('display', 'block');
+ var actual_height = dupe.height();
+ dupe.remove();
+
+ if($(this).hasClass('i-am-new')) {
+ $(this).css({
+ top: ($(window).height() - actual_height) / 2 + 'px'
+ });
+ }
+ else {
+ $(this).animate({
+ top: ($(window).height() - actual_height) / 2 + 'px'
+ }, 500);
+ }
+
+ if(window.innerWidth < 600) {
+ $(this).css({
+ left: 5
+ });
+ }
+
+ }
+ },
+ parent : {
+ object : '',
+ selector: 'li',
+ css : {}
+ },
+ css : {
+ display: 'none',
+ width : '310px'
+ },
+ addClass : ''
+};
+
+$.noty.layouts.centerRight = {
+ name : 'centerRight',
+ options : { // overrides options
+
+ },
+ container: {
+ object : '',
+ selector: 'ul#noty_centerRight_layout_container',
+ style : function() {
+ $(this).css({
+ right : 20,
+ position : 'fixed',
+ width : '310px',
+ height : 'auto',
+ margin : 0,
+ padding : 0,
+ listStyleType: 'none',
+ zIndex : 10000000
+ });
+
+ // getting hidden height
+ var dupe = $(this).clone().css({visibility: "hidden", display: "block", position: "absolute", top: 0, left: 0}).attr('id', 'dupe');
+ $("body").append(dupe);
+ dupe.find('.i-am-closing-now').remove();
+ dupe.find('li').css('display', 'block');
+ var actual_height = dupe.height();
+ dupe.remove();
+
+ if($(this).hasClass('i-am-new')) {
+ $(this).css({
+ top: ($(window).height() - actual_height) / 2 + 'px'
+ });
+ }
+ else {
+ $(this).animate({
+ top: ($(window).height() - actual_height) / 2 + 'px'
+ }, 500);
+ }
+
+ if(window.innerWidth < 600) {
+ $(this).css({
+ right: 5
+ });
+ }
+
+ }
+ },
+ parent : {
+ object : '',
+ selector: 'li',
+ css : {}
+ },
+ css : {
+ display: 'none',
+ width : '310px'
+ },
+ addClass : ''
+};
+$.noty.layouts.inline = {
+ name : 'inline',
+ options : {},
+ container: {
+ object : '',
+ selector: 'ul.noty_inline_layout_container',
+ style : function() {
+ $(this).css({
+ width : '100%',
+ height : 'auto',
+ margin : 0,
+ padding : 0,
+ listStyleType: 'none',
+ zIndex : 9999999
+ });
+ }
+ },
+ parent : {
+ object : '',
+ selector: 'li',
+ css : {}
+ },
+ css : {
+ display: 'none'
+ },
+ addClass : ''
+};
+$.noty.layouts.top = {
+ name : 'top',
+ options : {},
+ container: {
+ object : '',
+ selector: 'ul#noty_top_layout_container',
+ style : function() {
+ $(this).css({
+ top : 0,
+ left : '5%',
+ position : 'fixed',
+ width : '90%',
+ height : 'auto',
+ margin : 0,
+ padding : 0,
+ listStyleType: 'none',
+ zIndex : 9999999
+ });
+ }
+ },
+ parent : {
+ object : '',
+ selector: 'li',
+ css : {}
+ },
+ css : {
+ display: 'none'
+ },
+ addClass : ''
+};
+$.noty.layouts.topCenter = {
+ name : 'topCenter',
+ options : { // overrides options
+
+ },
+ container: {
+ object : '',
+ selector: 'ul#noty_topCenter_layout_container',
+ style : function() {
+ $(this).css({
+ top : 20,
+ left : 0,
+ position : 'fixed',
+ width : '310px',
+ height : 'auto',
+ margin : 0,
+ padding : 0,
+ listStyleType: 'none',
+ zIndex : 10000000
+ });
+
+ $(this).css({
+ left: ($(window).width() - $(this).outerWidth(false)) / 2 + 'px'
+ });
+ }
+ },
+ parent : {
+ object : '',
+ selector: 'li',
+ css : {}
+ },
+ css : {
+ display: 'none',
+ width : '310px'
+ },
+ addClass : ''
+};
+
+$.noty.layouts.topLeft = {
+ name : 'topLeft',
+ options : { // overrides options
+
+ },
+ container: {
+ object : '',
+ selector: 'ul#noty_topLeft_layout_container',
+ style : function() {
+ $(this).css({
+ top : 20,
+ left : 20,
+ position : 'fixed',
+ width : '310px',
+ height : 'auto',
+ margin : 0,
+ padding : 0,
+ listStyleType: 'none',
+ zIndex : 10000000
+ });
+
+ if(window.innerWidth < 600) {
+ $(this).css({
+ left: 5
+ });
+ }
+ }
+ },
+ parent : {
+ object : '',
+ selector: 'li',
+ css : {}
+ },
+ css : {
+ display: 'none',
+ width : '310px'
+ },
+ addClass : ''
+};
+$.noty.layouts.topRight = {
+ name : 'topRight',
+ options : { // overrides options
+
+ },
+ container: {
+ object : '',
+ selector: 'ul#noty_topRight_layout_container',
+ style : function() {
+ $(this).css({
+ top : 20,
+ right : 20,
+ position : 'fixed',
+ width : '310px',
+ height : 'auto',
+ margin : 0,
+ padding : 0,
+ listStyleType: 'none',
+ zIndex : 10000000
+ });
+
+ if(window.innerWidth < 600) {
+ $(this).css({
+ right: 5
+ });
+ }
+ }
+ },
+ parent : {
+ object : '',
+ selector: 'li',
+ css : {}
+ },
+ css : {
+ display: 'none',
+ width : '310px'
+ },
+ addClass : ''
+};
+$.noty.themes.bootstrapTheme = {
+ name: 'bootstrapTheme',
+ modal: {
+ css: {
+ position: 'fixed',
+ width: '100%',
+ height: '100%',
+ backgroundColor: '#000',
+ zIndex: 10000,
+ opacity: 0.6,
+ display: 'none',
+ left: 0,
+ top: 0
+ }
+ },
+ style: function() {
+
+ var containerSelector = this.options.layout.container.selector;
+ $(containerSelector).addClass('list-group');
+
+ this.$closeButton.append('×Close');
+ this.$closeButton.addClass('close');
+
+ this.$bar.addClass( "list-group-item" ).css('padding', '0px');
+
+ switch (this.options.type) {
+ case 'alert': case 'notification':
+ this.$bar.addClass( "list-group-item-info" );
+ break;
+ case 'warning':
+ this.$bar.addClass( "list-group-item-warning" );
+ break;
+ case 'error':
+ this.$bar.addClass( "list-group-item-danger" );
+ break;
+ case 'information':
+ this.$bar.addClass("list-group-item-info");
+ break;
+ case 'success':
+ this.$bar.addClass( "list-group-item-success" );
+ break;
+ }
+
+ this.$message.css({
+ fontSize: '13px',
+ lineHeight: '16px',
+ textAlign: 'center',
+ padding: '8px 10px 9px',
+ width: 'auto',
+ position: 'relative'
+ });
+ },
+ callback: {
+ onShow: function() { },
+ onClose: function() { }
+ }
+};
+
+
+$.noty.themes.defaultTheme = {
+ name : 'defaultTheme',
+ helpers : {
+ borderFix: function() {
+ if(this.options.dismissQueue) {
+ var selector = this.options.layout.container.selector + ' ' + this.options.layout.parent.selector;
+ switch(this.options.layout.name) {
+ case 'top':
+ $(selector).css({borderRadius: '0px 0px 0px 0px'});
+ $(selector).last().css({borderRadius: '0px 0px 5px 5px'});
+ break;
+ case 'topCenter':
+ case 'topLeft':
+ case 'topRight':
+ case 'bottomCenter':
+ case 'bottomLeft':
+ case 'bottomRight':
+ case 'center':
+ case 'centerLeft':
+ case 'centerRight':
+ case 'inline':
+ $(selector).css({borderRadius: '0px 0px 0px 0px'});
+ $(selector).first().css({'border-top-left-radius': '5px', 'border-top-right-radius': '5px'});
+ $(selector).last().css({'border-bottom-left-radius': '5px', 'border-bottom-right-radius': '5px'});
+ break;
+ case 'bottom':
+ $(selector).css({borderRadius: '0px 0px 0px 0px'});
+ $(selector).first().css({borderRadius: '5px 5px 0px 0px'});
+ break;
+ default:
+ break;
+ }
+ }
+ }
+ },
+ modal : {
+ css: {
+ position : 'fixed',
+ width : '100%',
+ height : '100%',
+ backgroundColor: '#000',
+ zIndex : 10000,
+ opacity : 0.6,
+ display : 'none',
+ left : 0,
+ top : 0
+ }
+ },
+ style : function() {
+
+ this.$bar.css({
+ overflow : 'hidden',
+ background: "url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABsAAAAoCAQAAAClM0ndAAAAhklEQVR4AdXO0QrCMBBE0bttkk38/w8WRERpdyjzVOc+HxhIHqJGMQcFFkpYRQotLLSw0IJ5aBdovruMYDA/kT8plF9ZKLFQcgF18hDj1SbQOMlCA4kao0iiXmah7qBWPdxpohsgVZyj7e5I9KcID+EhiDI5gxBYKLBQYKHAQoGFAoEks/YEGHYKB7hFxf0AAAAASUVORK5CYII=') repeat-x scroll left top #fff"
+ });
+
+ this.$message.css({
+ fontSize : '13px',
+ lineHeight: '16px',
+ textAlign : 'center',
+ padding : '8px 10px 9px',
+ width : 'auto',
+ position : 'relative'
+ });
+
+ this.$closeButton.css({
+ position : 'absolute',
+ top : 4, right: 4,
+ width : 10, height: 10,
+ background: "url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAoAAAAKCAQAAAAnOwc2AAAAxUlEQVR4AR3MPUoDURSA0e++uSkkOxC3IAOWNtaCIDaChfgXBMEZbQRByxCwk+BasgQRZLSYoLgDQbARxry8nyumPcVRKDfd0Aa8AsgDv1zp6pYd5jWOwhvebRTbzNNEw5BSsIpsj/kurQBnmk7sIFcCF5yyZPDRG6trQhujXYosaFoc+2f1MJ89uc76IND6F9BvlXUdpb6xwD2+4q3me3bysiHvtLYrUJto7PD/ve7LNHxSg/woN2kSz4txasBdhyiz3ugPGetTjm3XRokAAAAASUVORK5CYII=)",
+ display : 'none',
+ cursor : 'pointer'
+ });
+
+ this.$buttons.css({
+ padding : 5,
+ textAlign : 'right',
+ borderTop : '1px solid #ccc',
+ backgroundColor: '#fff'
+ });
+
+ this.$buttons.find('button').css({
+ marginLeft: 5
+ });
+
+ this.$buttons.find('button:first').css({
+ marginLeft: 0
+ });
+
+ this.$bar.on({
+ mouseenter: function() {
+ $(this).find('.noty_close').stop().fadeTo('normal', 1);
+ },
+ mouseleave: function() {
+ $(this).find('.noty_close').stop().fadeTo('normal', 0);
+ }
+ });
+
+ switch(this.options.layout.name) {
+ case 'top':
+ this.$bar.css({
+ borderRadius: '0px 0px 5px 5px',
+ borderBottom: '2px solid #eee',
+ borderLeft : '2px solid #eee',
+ borderRight : '2px solid #eee',
+ boxShadow : "0 2px 4px rgba(0, 0, 0, 0.1)"
+ });
+ break;
+ case 'topCenter':
+ case 'center':
+ case 'bottomCenter':
+ case 'inline':
+ this.$bar.css({
+ borderRadius: '5px',
+ border : '1px solid #eee',
+ boxShadow : "0 2px 4px rgba(0, 0, 0, 0.1)"
+ });
+ this.$message.css({fontSize: '13px', textAlign: 'center'});
+ break;
+ case 'topLeft':
+ case 'topRight':
+ case 'bottomLeft':
+ case 'bottomRight':
+ case 'centerLeft':
+ case 'centerRight':
+ this.$bar.css({
+ borderRadius: '5px',
+ border : '1px solid #eee',
+ boxShadow : "0 2px 4px rgba(0, 0, 0, 0.1)"
+ });
+ this.$message.css({fontSize: '13px', textAlign: 'left'});
+ break;
+ case 'bottom':
+ this.$bar.css({
+ borderRadius: '5px 5px 0px 0px',
+ borderTop : '2px solid #eee',
+ borderLeft : '2px solid #eee',
+ borderRight : '2px solid #eee',
+ boxShadow : "0 -2px 4px rgba(0, 0, 0, 0.1)"
+ });
+ break;
+ default:
+ this.$bar.css({
+ border : '2px solid #eee',
+ boxShadow: "0 2px 4px rgba(0, 0, 0, 0.1)"
+ });
+ break;
+ }
+
+ switch(this.options.type) {
+ case 'alert':
+ case 'notification':
+ this.$bar.css({backgroundColor: '#FFF', borderColor: '#CCC', color: '#444'});
+ break;
+ case 'warning':
+ this.$bar.css({backgroundColor: '#FFEAA8', borderColor: '#FFC237', color: '#826200'});
+ this.$buttons.css({borderTop: '1px solid #FFC237'});
+ break;
+ case 'error':
+ this.$bar.css({backgroundColor: 'red', borderColor: 'darkred', color: '#FFF'});
+ this.$message.css({fontWeight: 'bold'});
+ this.$buttons.css({borderTop: '1px solid darkred'});
+ break;
+ case 'information':
+ this.$bar.css({backgroundColor: '#57B7E2', borderColor: '#0B90C4', color: '#FFF'});
+ this.$buttons.css({borderTop: '1px solid #0B90C4'});
+ break;
+ case 'success':
+ this.$bar.css({backgroundColor: 'lightgreen', borderColor: '#50C24E', color: 'darkgreen'});
+ this.$buttons.css({borderTop: '1px solid #50C24E'});
+ break;
+ default:
+ this.$bar.css({backgroundColor: '#FFF', borderColor: '#CCC', color: '#444'});
+ break;
+ }
+ },
+ callback: {
+ onShow : function() {
+ $.noty.themes.defaultTheme.helpers.borderFix.apply(this);
+ },
+ onClose: function() {
+ $.noty.themes.defaultTheme.helpers.borderFix.apply(this);
+ }
+ }
+};
+
+$.noty.themes.relax = {
+ name : 'relax',
+ helpers : {},
+ modal : {
+ css: {
+ position : 'fixed',
+ width : '100%',
+ height : '100%',
+ backgroundColor: '#000',
+ zIndex : 10000,
+ opacity : 0.6,
+ display : 'none',
+ left : 0,
+ top : 0
+ }
+ },
+ style : function() {
+
+ this.$bar.css({
+ overflow : 'hidden',
+ margin : '4px 0',
+ borderRadius: '2px'
+ });
+
+ this.$message.css({
+ fontSize : '14px',
+ lineHeight: '16px',
+ textAlign : 'center',
+ padding : '10px',
+ width : 'auto',
+ position : 'relative'
+ });
+
+ this.$closeButton.css({
+ position : 'absolute',
+ top : 4, right: 4,
+ width : 10, height: 10,
+ background: "url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAoAAAAKCAQAAAAnOwc2AAAAxUlEQVR4AR3MPUoDURSA0e++uSkkOxC3IAOWNtaCIDaChfgXBMEZbQRByxCwk+BasgQRZLSYoLgDQbARxry8nyumPcVRKDfd0Aa8AsgDv1zp6pYd5jWOwhvebRTbzNNEw5BSsIpsj/kurQBnmk7sIFcCF5yyZPDRG6trQhujXYosaFoc+2f1MJ89uc76IND6F9BvlXUdpb6xwD2+4q3me3bysiHvtLYrUJto7PD/ve7LNHxSg/woN2kSz4txasBdhyiz3ugPGetTjm3XRokAAAAASUVORK5CYII=)",
+ display : 'none',
+ cursor : 'pointer'
+ });
+
+ this.$buttons.css({
+ padding : 5,
+ textAlign : 'right',
+ borderTop : '1px solid #ccc',
+ backgroundColor: '#fff'
+ });
+
+ this.$buttons.find('button').css({
+ marginLeft: 5
+ });
+
+ this.$buttons.find('button:first').css({
+ marginLeft: 0
+ });
+
+ this.$bar.on({
+ mouseenter: function() {
+ $(this).find('.noty_close').stop().fadeTo('normal', 1);
+ },
+ mouseleave: function() {
+ $(this).find('.noty_close').stop().fadeTo('normal', 0);
+ }
+ });
+
+ switch(this.options.layout.name) {
+ case 'top':
+ this.$bar.css({
+ borderBottom: '2px solid #eee',
+ borderLeft : '2px solid #eee',
+ borderRight : '2px solid #eee',
+ borderTop : '2px solid #eee',
+ boxShadow : "0 2px 4px rgba(0, 0, 0, 0.1)"
+ });
+ break;
+ case 'topCenter':
+ case 'center':
+ case 'bottomCenter':
+ case 'inline':
+ this.$bar.css({
+ border : '1px solid #eee',
+ boxShadow: "0 2px 4px rgba(0, 0, 0, 0.1)"
+ });
+ this.$message.css({fontSize: '13px', textAlign: 'center'});
+ break;
+ case 'topLeft':
+ case 'topRight':
+ case 'bottomLeft':
+ case 'bottomRight':
+ case 'centerLeft':
+ case 'centerRight':
+ this.$bar.css({
+ border : '1px solid #eee',
+ boxShadow: "0 2px 4px rgba(0, 0, 0, 0.1)"
+ });
+ this.$message.css({fontSize: '13px', textAlign: 'left'});
+ break;
+ case 'bottom':
+ this.$bar.css({
+ borderTop : '2px solid #eee',
+ borderLeft : '2px solid #eee',
+ borderRight : '2px solid #eee',
+ borderBottom: '2px solid #eee',
+ boxShadow : "0 -2px 4px rgba(0, 0, 0, 0.1)"
+ });
+ break;
+ default:
+ this.$bar.css({
+ border : '2px solid #eee',
+ boxShadow: "0 2px 4px rgba(0, 0, 0, 0.1)"
+ });
+ break;
+ }
+
+ switch(this.options.type) {
+ case 'alert':
+ case 'notification':
+ this.$bar.css({backgroundColor: '#FFF', borderColor: '#dedede', color: '#444'});
+ break;
+ case 'warning':
+ this.$bar.css({backgroundColor: '#FFEAA8', borderColor: '#FFC237', color: '#826200'});
+ this.$buttons.css({borderTop: '1px solid #FFC237'});
+ break;
+ case 'error':
+ this.$bar.css({backgroundColor: '#FF8181', borderColor: '#e25353', color: '#FFF'});
+ this.$message.css({fontWeight: 'bold'});
+ this.$buttons.css({borderTop: '1px solid darkred'});
+ break;
+ case 'information':
+ this.$bar.css({backgroundColor: '#78C5E7', borderColor: '#3badd6', color: '#FFF'});
+ this.$buttons.css({borderTop: '1px solid #0B90C4'});
+ break;
+ case 'success':
+ this.$bar.css({backgroundColor: '#BCF5BC', borderColor: '#7cdd77', color: 'darkgreen'});
+ this.$buttons.css({borderTop: '1px solid #50C24E'});
+ break;
+ default:
+ this.$bar.css({backgroundColor: '#FFF', borderColor: '#CCC', color: '#444'});
+ break;
+ }
+ },
+ callback: {
+ onShow : function() {
+
+ },
+ onClose: function() {
+
+ }
+ }
+};
+
+
+return window.noty;
+
+});
\ No newline at end of file
diff --git a/members/static/js/members_controllers.js b/members/static/js/members_controllers.js
index 3cbbb56..233dc50 100644
--- a/members/static/js/members_controllers.js
+++ b/members/static/js/members_controllers.js
@@ -11,17 +11,18 @@ app.controller("getController", function($scope, $http, $window, $location){
$scope.delete_member = function(id) {
$http.delete("/members/api/member/" + id).then(
function(response) {
- $window.alert("Onnistui! Hyvä Harry!");
+ noty({ text: "Onnistui! Hyvä Harry!"});
$location.path("#/list");
},
function(response) {
- $window.alert("Epäonnistui. Yritä uudelleen.");
+ noty({ text: "Epäonnistui. Yritä uudelleen."});
$location.path("#/list");
}
);
};
-})
-.directive('ngConfirmClick',
+});
+
+app.directive('ngConfirmClick',
[
function()
{ return {
@@ -38,7 +39,7 @@ function()
}
}}]);
-app.controller("postController", function($scope, $http) {
+app.controller("postController", function($scope, $http, $location) {
$scope.firstName = "";
$scope.lastName = "";
$scope.email = "";
@@ -46,7 +47,10 @@ app.controller("postController", function($scope, $http) {
$scope.JAS = "";
$scope.POR = "";
$scope.send = function() {
- $http.post("/members/api/member/", {"first_name":$scope.firstName, "last_name":$scope.lastName, "email":$scope.email, "AYY":$scope.AYY, "jas":$scope.JAS, "POR":$scope.POR});
+ $http.post("/members/api/member/", {"first_name":$scope.firstName, "last_name":$scope.lastName, "email":$scope.email, "AYY":$scope.AYY, "jas":$scope.JAS, "POR":$scope.POR}).then(function(data){
+ noty({ text: "Jäsenhakemus lähetetty"});
+ $location.path("#/list");
+ });
}
});
app.controller("editController", function($scope, $http, $route, $routeParams, $window, $location) {
@@ -57,7 +61,7 @@ app.controller("editController", function($scope, $http, $route, $routeParams, $
$scope.send = function() {
$http.put("/members/api/member/"+$scope.member.id, $scope.member).then(function(data){
- $window.alert("Jäsentiedot tallennettu");
+ noty({ text: "Jäsentiedot tallennettu"});
$location.path("#/list");
});
}
diff --git a/members/static/js/members_routers.js b/members/static/js/members_routers.js
index 0776e4e..663bfed 100644
--- a/members/static/js/members_routers.js
+++ b/members/static/js/members_routers.js
@@ -1,11 +1,3 @@
-var app = angular.module('memberApp', ['ngRoute']);
-
-
-app.config(['$httpProvider', function ($httpProvider) {
- $httpProvider.defaults.xsrfCookieName = 'csrftoken';
- $httpProvider.defaults.xsrfHeaderName = 'X-CSRFToken';
-}]);
-
app.config(['$routeProvider', function($routeProvider){
$routeProvider
.when('/',{
diff --git a/members/templates/members_index.html b/members/templates/members_index.html
index 890e92b..3317a5f 100644
--- a/members/templates/members_index.html
+++ b/members/templates/members_index.html
@@ -10,13 +10,14 @@
-
-
-
+
+
{%load staticfiles %}
+
+
@@ -42,6 +43,6 @@
-
+