listHeader.js 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. BlazeComponent.extendComponent({
  2. template() {
  3. return 'listHeader';
  4. },
  5. editTitle(evt) {
  6. evt.preventDefault();
  7. const newTitle = this.componentChildren('inlinedForm')[0].getValue();
  8. const list = this.currentData();
  9. if ($.trim(newTitle)) {
  10. list.rename(newTitle);
  11. }
  12. },
  13. events() {
  14. return [{
  15. 'click .js-open-list-menu': Popup.open('listAction'),
  16. submit: this.editTitle,
  17. }];
  18. },
  19. }).register('listHeader');
  20. Template.listActionPopup.events({
  21. 'click .js-add-card'() {
  22. const listDom = document.getElementById(`js-list-${this._id}`);
  23. const listComponent = BlazeComponent.getComponentForElement(listDom);
  24. listComponent.openForm({ position: 'top' });
  25. Popup.close();
  26. },
  27. 'click .js-list-subscribe'() {},
  28. 'click .js-select-cards'() {
  29. const cardIds = this.allCards().map((card) => card._id);
  30. MultiSelection.add(cardIds);
  31. Popup.close();
  32. },
  33. 'click .js-move-cards': Popup.open('listMoveCards'),
  34. 'click .js-archive-cards': Popup.afterConfirm('listArchiveCards', () => {
  35. this.allCards().forEach((card) => {
  36. card.archive();
  37. });
  38. Popup.close();
  39. }),
  40. 'click .js-close-list'(evt) {
  41. evt.preventDefault();
  42. this.archive();
  43. Popup.close();
  44. },
  45. });
  46. Template.listMoveCardsPopup.events({
  47. 'click .js-select-list'() {
  48. const fromList = Template.parentData(2).data;
  49. const toList = this._id;
  50. fromList.allCards().forEach((card) => {
  51. card.move(toList);
  52. });
  53. Popup.close();
  54. },
  55. });