|
| 1 | +# Task list checkboxes are rendered as disabled by default |
| 2 | +# because rendered user content is cached without regard |
| 3 | +# for the viewer. Enables the checkboxes and applies the |
| 4 | +# correct list style, if the viewer is able to edit the comment. |
| 5 | +enableTaskList = (comment) -> |
| 6 | + if comment.find('.js-comment-edit-button').length > 0 |
| 7 | + comment.addClass('context-loader-container') |
| 8 | + comment.find('.js-comment-body').addClass('context-loader-overlay') |
| 9 | + comment. |
| 10 | + find('.task-list-item').addClass('enabled'). |
| 11 | + find('.task-list-item-checkbox').attr('disabled', null) |
| 12 | + comment.closest('.context-loader-container').find('.context-loader:first'). |
| 13 | + removeClass 'is-context-loading' |
| 14 | + |
| 15 | +disableTaskList = (comment) -> |
| 16 | + comment. |
| 17 | + find('.task-list-item').removeClass('enabled'). |
| 18 | + find('.task-list-item-checkbox').attr('disabled', 'disabled') |
| 19 | + comment.closest('.context-loader-container').find('.context-loader:first'). |
| 20 | + addClass 'is-context-loading' |
| 21 | + |
| 22 | +# Submit updates to task list items asynchronously. |
| 23 | +# Successful updates won't require re-rendering to represent reality. |
| 24 | +updateTaskListItem = (item) -> |
| 25 | + comment = item.parents('.js-comment') |
| 26 | + form = comment.find('form.js-comment-update') |
| 27 | + body = comment.find('.js-comment-body') |
| 28 | + data = |
| 29 | + item: item.attr('data-item-index') |
| 30 | + checked: if item.prop('checked') then 1 else 0 |
| 31 | + body_version: body.attr('data-body-version') |
| 32 | + |
| 33 | + disableTaskList(comment) |
| 34 | + |
| 35 | + $.ajax |
| 36 | + type: 'post' |
| 37 | + url: form.attr('action')+'/task' |
| 38 | + data: data |
| 39 | + dataType: 'json' |
| 40 | + success: (data) -> |
| 41 | + console.log 'success', data |
| 42 | + if data.stale |
| 43 | + window.location.href = window.location.href |
| 44 | + else |
| 45 | + body.attr('data-body-version', data.new_body_version) |
| 46 | + comment.find('.form-content .js-comment-field').val(data.new_body) |
| 47 | + error: (e) -> |
| 48 | + console.log 'error', e |
| 49 | + complete: -> |
| 50 | + enableTaskList(comment) |
| 51 | + |
| 52 | +# When the task list item checkbox is updated, submit the change |
| 53 | +$(document).on 'change', 'input.task-list-item-checkbox[type=checkbox]', -> |
| 54 | + updateTaskListItem $(this) |
| 55 | + |
| 56 | +$.pageUpdate -> |
| 57 | + $('.js-comment').each -> |
| 58 | + enableTaskList($(this)) |
0 commit comments