form.js 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. const Mn = require('backbone.marionette');
  2. const App = require('../main');
  3. const UserModel = require('../../models/user');
  4. const template = require('./form.ejs');
  5. require('jquery-serializejson');
  6. module.exports = Mn.View.extend({
  7. template: template,
  8. className: 'modal-dialog',
  9. ui: {
  10. form: 'form',
  11. buttons: '.modal-footer button',
  12. cancel: 'button.cancel',
  13. save: 'button.save',
  14. error: '.secret-error'
  15. },
  16. events: {
  17. 'click @ui.save': function (e) {
  18. e.preventDefault();
  19. this.ui.error.hide();
  20. let view = this;
  21. let data = this.ui.form.serializeJSON();
  22. let show_password = this.model.get('email') === '[email protected]';
  23. // [email protected] is not allowed
  24. if (data.email === '[email protected]') {
  25. this.ui.error.text(App.i18n('users', 'default_error')).show();
  26. this.ui.buttons.prop('disabled', false).removeClass('btn-disabled');
  27. return;
  28. }
  29. // Manipulate
  30. data.roles = [];
  31. if ((this.model.get('id') === App.Cache.User.get('id') && this.model.isAdmin()) || (typeof data.is_admin !== 'undefined' && data.is_admin)) {
  32. data.roles.push('admin');
  33. delete data.is_admin;
  34. }
  35. data.is_disabled = typeof data.is_disabled !== 'undefined' ? !!data.is_disabled : false;
  36. this.ui.buttons.prop('disabled', true).addClass('btn-disabled');
  37. let method = App.Api.Users.create;
  38. if (this.model.get('id')) {
  39. // edit
  40. method = App.Api.Users.update;
  41. data.id = this.model.get('id');
  42. }
  43. method(data)
  44. .then(result => {
  45. if (result.id === App.Cache.User.get('id')) {
  46. App.Cache.User.set(result);
  47. }
  48. if (view.model.get('id') !== App.Cache.User.get('id')) {
  49. App.Controller.showUsers();
  50. }
  51. view.model.set(result);
  52. App.UI.closeModal(function () {
  53. if (method === App.Api.Users.create) {
  54. // Show permissions dialog immediately
  55. App.Controller.showUserPermissions(view.model);
  56. } else if (show_password) {
  57. App.Controller.showUserPasswordForm(view.model);
  58. }
  59. });
  60. })
  61. .catch(err => {
  62. this.ui.error.text(err.message).show();
  63. this.ui.buttons.prop('disabled', false).removeClass('btn-disabled');
  64. });
  65. }
  66. },
  67. templateContext: function () {
  68. let view = this;
  69. return {
  70. isSelf: function () {
  71. return view.model.get('id') === App.Cache.User.get('id');
  72. },
  73. isAdmin: function () {
  74. return App.Cache.User.isAdmin();
  75. },
  76. isAdminUser: function () {
  77. return view.model.isAdmin();
  78. },
  79. isDisabled: function () {
  80. return view.model.isDisabled();
  81. }
  82. };
  83. },
  84. initialize: function (options) {
  85. if (typeof options.model === 'undefined' || !options.model) {
  86. this.model = new UserModel.Model();
  87. }
  88. }
  89. });