todo-webclient/client/task.ls

74 lines
1.6 KiB
Plaintext
Raw Normal View History

2019-11-22 16:52:50 +01:00
h = require 'maquette' .h
bulma = require "./bulma.ls"
nmd = require "nano-markdown"
2019-12-06 04:10:00 +01:00
TaskCreationModal = require './task-creation-modal.ls'
2019-12-06 04:07:19 +01:00
TaskRemovalModal = require './task-removal-modal.ls'
2019-11-22 16:52:50 +01:00
2019-12-20 01:34:41 +01:00
{icon} = require "./font-awesome.ls"
2019-12-06 01:56:32 +01:00
Task = (self, project, todod-ws) ->
modal = void
self.render-login = (uid) ->
h \p [ '@' + uid.to-string! ]
2019-12-12 21:49:15 +01:00
self.render = (args) ->
args or= {}
2019-12-09 03:31:11 +01:00
background-color = "grey"
if self.extra_properties && self.extra_properties.background-color
background-color = self.extra_properties.background-color
2019-12-09 03:09:06 +01:00
2019-12-12 21:49:15 +01:00
h "div.card.is-#{background-color}" {
classes: {
"is-selected": args.is-selected
}
2019-12-09 03:09:06 +01:00
key: self.id
2019-12-12 21:49:15 +01:00
onclick: (e) ->
if args.onclick
args.onclick(e)
2019-12-09 03:09:06 +01:00
} [
2019-12-06 04:07:19 +01:00
h \div.card-content [
2019-12-20 01:34:41 +01:00
h \div.title.is-5 [
h \a.has-text-grey.is-pulled-right {
onclick: ->
modal := TaskCreationModal project, todod-ws, self, project.users
} [
icon \cog
]
self.title
]
2019-12-06 04:07:19 +01:00
h \div.media [
h \div.media-left [
2019-12-09 03:31:11 +01:00
# FIXME: assignee card image
2019-12-12 21:49:15 +01:00
]
h \div.media-content [
if uid = self.assigned_to
self.render-login uid
2019-12-06 04:07:19 +01:00
]
2019-12-12 21:49:15 +01:00
]
2019-12-09 03:31:11 +01:00
2019-12-12 21:49:15 +01:00
if args.is-selected
h \div.content {
key: "task-description-#{self.id}"
after-create: (dom) ->
dom.innerHTML = nmd self.description
} [ ]
2019-12-09 03:31:11 +01:00
2019-12-12 21:49:15 +01:00
if args.is-selected
h \div.card-footer [
h \a.card-footer-item.has-text-danger {
onclick: ->
modal := TaskRemovalModal project.id, todod-ws, self
} [ "Destroy" ]
]
2019-12-06 04:07:19 +01:00
]
2019-12-12 21:49:15 +01:00
2019-12-06 01:56:32 +01:00
if modal
modal.render!
]
2019-12-05 02:28:17 +01:00
self
2019-11-22 16:52:50 +01:00
2019-12-05 02:28:17 +01:00
module.exports = Task