Example #1
0
class MilestoneTask(db.Model):
    __tablename__ = "milestone_tasks"

    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(150), index=False, nullable=False)
    comment = db.Column(db.String(300), index=False)
    parent_task_id = db.Column(db.Integer)
    datetime_added = db.Column(db.DateTime)
    datetime_completed = db.Column(db.DateTime, nullable=True)
    milestone_id = db.Column(db.Integer,
                             db.ForeignKey("milestones.id"),
                             nullable=False)

    def __init__(self, name):
        self.name = name
Example #2
0
class Milestone(db.Model):
    __tablename__ = "milestones"

    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(150), index=False, nullable=False)

    def __init__(self, name):
        self.name = name
Example #3
0
class Post(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    task = db.Column(db.String(100), nullable=False)
    due_date = db.Column(db.DateTime)
    description = db.Column(db.Text)
    user_id = db.Column(db.Integer, db.ForeignKey('user.id'), nullable=False)

    def __repr__(self):
        return f"Post('{self.task}', '{self.due_date}')"
Example #4
0
class User(db.Model, UserMixin):
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String(20), unique=True, nullable=False)
    email = db.Column(db.String(120), unique=True, nullable=False)
    password = db.Column(db.String(60), nullable=False)
    posts = db.relationship('Post', backref='author', lazy=True)

    def get_reset_token(self, expires_sec=1800):
        s =  Serializer(app.config['SECRET_KEY'], expires_sec)
        return s.dumps({'user_id': self.id}).decode('utf-8')
    
    @staticmethod
    def verify_reset_token(token):
        s =  Serializer(app.config['SECRET_KEY'])
        try:
            user_id = s.loads(token)['user_id']
        except:
            return None
        return User.query.get(user_id)

    def __repr__(self):
        return f"User('{self.username}', '{self.email}')"
Example #5
0
class Task(db.Model):
    __tablename__ = "tasks"

    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(150), index=False, nullable=False)
    comment = db.Column(db.String(300), index=False)
    parent_task_id = db.Column(db.Integer)
    datetime_added = db.Column(db.DateTime(timezone=True))
    datetime_completed = db.Column(db.DateTime(timezone=True), nullable=True)
    is_today = db.Column(db.Boolean, nullable=False)
    view_id = db.Column(db.Integer)

    def __init__(self, name, comment="", is_today=False, **kwargs):
        self.name = name
        self.is_today = is_today
        self.comment = comment
        for k, v in kwargs.items():
            setattr(self, k, v)

        self.children = []
        self.hidden = False

    def has_parent(self):
        return type(
            self.parent_task_id) == int and self.parent_task_id != self.id

    def collectChildren(self):
        self.children = Task.query.filter_by(parent_task_id=self.id).all()
        return self.children

    def deleteFromSession(self, deleteDescendants=False, deleteView=True):
        """delete this model from db.session (without committing)"""

        if deleteDescendants:
            for child in self.collectChildren():
                child.deleteFromSession(True)

        if deleteView:
            db.session.delete(TaskView.query.filter_by(task_id=self.id).one())
        db.session.delete(self)

    def markComplete(self, markDescendants=False):

        self.datetime_completed = datetime.datetime.utcnow()
        if markDescendants:
            for child in self.collectChildren():
                child.markComplete(True)

    def createView(self):

        parentID = None
        column = 1
        if self.parent_task_id:
            tmp = db.session.query(TaskView).filter_by(
                task_id=self.parent_task_id).one()
            parentID = tmp.id
            column = tmp.task_column

        #find the highest view_index of any view with the same parent, and add 1 (parent can be None)
        viewIndex = db.session.query(func.max(TaskView.view_index))\
         .filter_by(parent_view_id=parentID, task_column=column)\
         .one()[0] or -1
        viewIndex += 1

        # print column
        view = TaskView(self.id, viewIndex, parentID, column)

        return view

    def updateView(self, delta, column=None, updateDescendants=False):

        view = TaskView.query.filter_by(task_id=self.id).one()
        if delta:
            view.setViewIndex(view.view_index + delta)

        c = view.task_column
        if column != None and column != c:
            #if column has changed and view has no parent, send to the end of the list
            if not (view.parent_view_id or view.parent_view_id == 0):
                print "changing"
                view.view_index = (db.session.query(func.max(TaskView.view_index))\
                 .filter(TaskView.parent_view_id==None)\
                 .filter(TaskView.task_column==column)\
                 .one()[0] or 0) + 1
            view.task_column = column
        print self.name, ":", view.task_column

        if updateDescendants:
            for child in self.collectChildren():
                print "child", child.name
                child.updateView(0, column, True)