This repository has been archived on 2023-03-18. You can view files and clone it, but cannot push or open issues or pull requests.
osr-discourse-src/app/assets/javascripts/discourse/components/groups-form-profile-fields.js.es6
Dan Ungureanu 352d43b101
FIX: Better handling of Group model state (#8356)
The group card and group members page were affecting each other and were
leaking members list and the query parameters which led to bad UX
experience and sub-optimal performance (client made more queries because
it was loading fewer members).

This commit refactors the group model to make it more consistent, remove
dead code, move error handling outside of model.
2019-11-18 14:59:28 +02:00

110 lines
2.8 KiB
JavaScript

import { isEmpty } from "@ember/utils";
import { not } from "@ember/object/computed";
import Component from "@ember/component";
import {
default as discourseComputed,
observes
} from "discourse-common/utils/decorators";
import Group from "discourse/models/group";
import { popupAjaxError } from "discourse/lib/ajax-error";
import discourseDebounce from "discourse/lib/debounce";
import EmberObject from "@ember/object";
export default Component.extend({
disableSave: null,
nameInput: null,
didInsertElement() {
this._super(...arguments);
const name = this.get("model.name");
if (name) {
this.set("nameInput", name);
} else {
this.set("disableSave", true);
}
},
canEdit: not("model.automatic"),
@discourseComputed("basicNameValidation", "uniqueNameValidation")
nameValidation(basicNameValidation, uniqueNameValidation) {
return uniqueNameValidation ? uniqueNameValidation : basicNameValidation;
},
@observes("nameInput")
_validateName() {
name = this.nameInput;
if (name === this.get("model.name")) return;
if (name === undefined) {
return this._failedInputValidation();
}
if (name === "") {
this.set("uniqueNameValidation", null);
return this._failedInputValidation(I18n.t("admin.groups.new.name.blank"));
}
if (name.length < this.siteSettings.min_username_length) {
return this._failedInputValidation(
I18n.t("admin.groups.new.name.too_short")
);
}
if (name.length > this.siteSettings.max_username_length) {
return this._failedInputValidation(
I18n.t("admin.groups.new.name.too_long")
);
}
this.checkGroupName();
return this._failedInputValidation(
I18n.t("admin.groups.new.name.checking")
);
},
checkGroupName: discourseDebounce(function() {
name = this.nameInput;
if (isEmpty(name)) return;
Group.checkName(name)
.then(response => {
const validationName = "uniqueNameValidation";
if (response.available) {
this.set(
validationName,
EmberObject.create({
ok: true,
reason: I18n.t("admin.groups.new.name.available")
})
);
this.set("disableSave", false);
this.set("model.name", this.nameInput);
} else {
let reason;
if (response.errors) {
reason = response.errors.join(" ");
} else {
reason = I18n.t("admin.groups.new.name.not_available");
}
this.set(validationName, this._failedInputValidation(reason));
}
})
.catch(popupAjaxError);
}, 500),
_failedInputValidation(reason) {
this.set("disableSave", true);
const options = { failed: true };
if (reason) options.reason = reason;
this.set("basicNameValidation", EmberObject.create(options));
}
});