diff --git a/src/views/list/views/Kanban.vue b/src/views/list/views/Kanban.vue index 63f18bd9..3da55c8e 100644 --- a/src/views/list/views/Kanban.vue +++ b/src/views/list/views/Kanban.vue @@ -26,7 +26,6 @@ @end="updateBucketPosition" group="buckets" :disabled="!canWrite" - :class="{'dragging-disabled': !canWrite}" tag="transition-group" :item-key="({id}) => `bucket${id}`" :component-data="bucketDraggableComponentData" @@ -45,9 +44,9 @@

-
+
@@ -255,6 +256,8 @@ const DRAG_OPTIONS = { delay: 150, } +const MIN_SCROLL_HEIGHT_PERCENT = 0.25 + export default { name: 'Kanban', components: { @@ -265,6 +268,8 @@ export default { }, data() { return { + taskContainerRefs: {}, + dragOptions: DRAG_OPTIONS, drag: false, @@ -313,7 +318,10 @@ export default { type: 'transition', tag: 'div', name: !this.dragBucket ? 'move-bucket': null, - class: 'kanban-bucket-container', + class: [ + 'kanban-bucket-container', + { 'dragging-disabled': !this.canWrite }, + ], } }, taskDraggableTaskComponentData() { @@ -321,6 +329,10 @@ export default { type: 'transition', tag: 'div', name: !this.drag ? 'move-card': null, + class: [ + 'dropper', + { 'dragging-disabled': !this.canWrite }, + ], } }, buckets: { @@ -361,30 +373,26 @@ export default { console.debug(`Loading buckets, loadedListId = ${this.loadedListId}, $route.params =`, this.$route.params) this.filtersChanged = false - const minScrollHeightPercent = 0.25 - this.$store.dispatch('kanban/loadBucketsForList', {listId: this.$route.params.listId, params: this.params}) - .then(bs => { - bs.forEach(b => { - const e = this.$refs[`tasks-container${b.id}`][0] - e.addEventListener('scroll', () => { - const scrollTopMax = e.scrollHeight - e.clientHeight - if (scrollTopMax <= e.scrollTop + e.scrollTop * minScrollHeightPercent) { - this.$store.dispatch('kanban/loadNextTasksForBucket', { - listId: this.$route.params.listId, - params: this.params, - bucketId: b.id, - }) - .catch(e => { - this.$message.error(e) - }) - } - }) - }) - }) - .catch(e => { - this.$message.error(e) - }) + }, + + setTaskContainerRef(id, el) { + if (!el) return + this.taskContainerRefs[id] = el + }, + + handleTaskContainerScroll(id, el) { + const scrollTopMax = el.scrollHeight - el.clientHeight + const threshold = el.scrollTop + el.scrollTop * MIN_SCROLL_HEIGHT_PERCENT + if (scrollTopMax > threshold) { + return + } + + this.$store.dispatch('kanban/loadNextTasksForBucket', { + listId: this.$route.params.listId, + params: this.params, + bucketId: id, + }) }, updateTaskPosition(e) { this.drag = false @@ -392,7 +400,7 @@ export default { // While we could just pass the bucket index in through the function call, this would not give us the // new bucket id when a task has been moved between buckets, only the new bucket. Using the data-bucket-id // of the drop target works all the time. - const bucketIndex = parseInt(e.to.parentNode.dataset.bucketIndex) + const bucketIndex = parseInt(e.to.dataset.bucketIndex) const newBucket = this.buckets[bucketIndex] const task = newBucket.tasks[e.newIndex] @@ -430,16 +438,15 @@ export default { .then(r => { this.newTaskText = '' this.$store.commit('kanban/addTaskToBucket', r) + this.scrollTaskContainerToBottom(bucketId) }) - .catch(e => { - this.$message.error(e) - }) - .finally(() => { - if (!this.$refs[`tasks-container${bucketId}`][0]) { - return - } - this.$refs[`tasks-container${bucketId}`][0].scrollTop = this.$refs[`tasks-container${bucketId}`][0].scrollHeight - }) + }, + scrollTaskContainerToBottom(bucketId) { + const bucketEl = this.taskContainerRefs[bucketId] + if (!bucketEl) { + return + } + bucketEl.scrollTop = bucketEl.scrollHeight }, createNewBucket() { if (this.newBucketTitle === '') { @@ -490,10 +497,8 @@ export default { this.bucketTitleEditable = true this.$nextTick(() => e.target.focus()) }, - saveBucketTitle(bucketId) { + saveBucketTitle(bucketId, bucketTitle) { this.bucketTitleEditable = false - const bucketTitleElement = this.$refs[`bucket${bucketId}title`][0] - const bucketTitle = bucketTitleElement.textContent const bucket = new BucketModel({ id: bucketId, title: bucketTitle, @@ -511,7 +516,6 @@ export default { this.$store.dispatch('kanban/updateBucket', bucket) .then(r => { realBucket.title = r.title - bucketTitleElement.blur() this.$message.success({message: this.$t('list.kanban.bucketTitleSavedSuccess')}) }) .catch(e => {