Refactor and add tests for category editing
This commit is contained in:
parent
2d2e2b9924
commit
23daa9d8ce
|
@ -100,16 +100,12 @@ export default ObjectController.extend(ModalFunctionality, {
|
||||||
return name.trim().length > 0 ? name : I18n.t("preview");
|
return name.trim().length > 0 ? name : I18n.t("preview");
|
||||||
}.property('name'),
|
}.property('name'),
|
||||||
|
|
||||||
buttonTitle: function() {
|
saveLabel: function() {
|
||||||
if (this.get('saving')) return I18n.t("saving");
|
if (this.get('saving')) return "saving";
|
||||||
if (this.get('model.isUncategorizedCategory')) return I18n.t("save");
|
if (this.get('model.isUncategorizedCategory')) return "save";
|
||||||
return (this.get('model.id') ? I18n.t("category.save") : I18n.t("category.create"));
|
return this.get('model.id') ? "category.save" : "category.create";
|
||||||
}.property('saving', 'model.id'),
|
}.property('saving', 'model.id'),
|
||||||
|
|
||||||
deleteButtonTitle: function() {
|
|
||||||
return I18n.t('category.delete');
|
|
||||||
}.property(),
|
|
||||||
|
|
||||||
showDescription: function() {
|
showDescription: function() {
|
||||||
return !this.get('model.isUncategorizedCategory') && this.get('model.id');
|
return !this.get('model.isUncategorizedCategory') && this.get('model.id');
|
||||||
}.property('model.isUncategorizedCategory', 'model.id'),
|
}.property('model.isUncategorizedCategory', 'model.id'),
|
||||||
|
@ -149,7 +145,6 @@ export default ObjectController.extend(ModalFunctionality, {
|
||||||
self.send('closeModal');
|
self.send('closeModal');
|
||||||
model.setProperties({slug: result.category.slug, id: result.category.id });
|
model.setProperties({slug: result.category.slug, id: result.category.id });
|
||||||
Discourse.URL.redirectTo("/c/" + Discourse.Category.slugFor(model));
|
Discourse.URL.redirectTo("/c/" + Discourse.Category.slugFor(model));
|
||||||
|
|
||||||
}).catch(function(error) {
|
}).catch(function(error) {
|
||||||
if (error && error.responseText) {
|
if (error && error.responseText) {
|
||||||
self.flash($.parseJSON(error.responseText).errors[0], 'error');
|
self.flash($.parseJSON(error.responseText).errors[0], 'error');
|
||||||
|
|
|
@ -53,7 +53,7 @@
|
||||||
<div class='input-prepend input-append'>
|
<div class='input-prepend input-append'>
|
||||||
<span class='color-title'>{{i18n 'category.foreground_color'}}:</span>
|
<span class='color-title'>{{i18n 'category.foreground_color'}}:</span>
|
||||||
<span class='add-on'>#</span>{{text-field value=model.text_color placeholderKey="category.color_placeholder" maxlength="6"}}
|
<span class='add-on'>#</span>{{text-field value=model.text_color placeholderKey="category.color_placeholder" maxlength="6"}}
|
||||||
{{color-picker colors=foregroundColors value=model.text_color}}
|
{{color-picker colors=foregroundColors value=model.text_color id='edit-text-color'}}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</section>
|
</section>
|
||||||
|
|
|
@ -9,15 +9,20 @@
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
<div class="modal-body">
|
<div class="modal-body">
|
||||||
{{#each tab in view.panels}}
|
{{#each view.panels as |tab|}}
|
||||||
{{view 'edit-category-panel' tab=tab}}
|
{{view 'edit-category-panel' tab=tab}}
|
||||||
{{/each}}
|
{{/each}}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="modal-footer">
|
<div class="modal-footer">
|
||||||
<button class='btn btn-primary' {{bind-attr disabled="disabled"}} {{action "saveCategory"}}>{{buttonTitle}}</button>
|
{{d-button id="save-category" class="btn-primary" disabled=disabled action="saveCategory" label=saveLabel}}
|
||||||
|
|
||||||
{{#if model.can_delete}}
|
{{#if model.can_delete}}
|
||||||
<button class='btn btn-danger pull-right' {{bind-attr disabled="deleteDisabled"}} {{action "deleteCategory"}}><i class="fa fa-trash-o"></i>{{deleteButtonTitle}}</button>
|
{{d-button class="btn-danger pull-right"
|
||||||
|
disabled=deleteDisabled
|
||||||
|
action="deleteCategory"
|
||||||
|
icon="trash-o"
|
||||||
|
label="category.delete"}}
|
||||||
{{else}}
|
{{else}}
|
||||||
<div class="cannot_delete_reason">
|
<div class="cannot_delete_reason">
|
||||||
{{{model.cannot_delete_reason}}}
|
{{{model.cannot_delete_reason}}}
|
||||||
|
|
|
@ -2,7 +2,7 @@ import { acceptance } from "helpers/qunit-helpers";
|
||||||
|
|
||||||
acceptance("Category Edit", { loggedIn: true });
|
acceptance("Category Edit", { loggedIn: true });
|
||||||
|
|
||||||
test("Can edit a category", (assert) => {
|
test("Can open the category modal", (assert) => {
|
||||||
visit("/c/bug");
|
visit("/c/bug");
|
||||||
|
|
||||||
click('.edit-category');
|
click('.edit-category');
|
||||||
|
@ -15,3 +15,15 @@ test("Can edit a category", (assert) => {
|
||||||
assert.ok(!visible('#discourse-modal'), 'it closes the modal');
|
assert.ok(!visible('#discourse-modal'), 'it closes the modal');
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
test("Change the category color", (assert) => {
|
||||||
|
visit("/c/bug");
|
||||||
|
|
||||||
|
click('.edit-category');
|
||||||
|
fillIn('#edit-text-color', '#ff0000');
|
||||||
|
click('#save-category');
|
||||||
|
andThen(() => {
|
||||||
|
assert.ok(!visible('#discourse-modal'), 'it closes the modal');
|
||||||
|
assert.equal(Discourse.URL.redirectedTo, '/c/bug', 'it does one of the rare full page redirects');
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
|
@ -119,6 +119,11 @@ export default function() {
|
||||||
|
|
||||||
this.get('/users/:username/staff-info.json', () => response({}));
|
this.get('/users/:username/staff-info.json', () => response({}));
|
||||||
|
|
||||||
|
this.put('/categories/:category_id', function(request) {
|
||||||
|
const category = parsePostData(request.requestBody);
|
||||||
|
return response({category});
|
||||||
|
});
|
||||||
|
|
||||||
this.get('/draft.json', function() {
|
this.get('/draft.json', function() {
|
||||||
return response({});
|
return response({});
|
||||||
});
|
});
|
||||||
|
|
|
@ -90,6 +90,12 @@ QUnit.testStart(function(ctx) {
|
||||||
Discourse.BaseUrl = "localhost";
|
Discourse.BaseUrl = "localhost";
|
||||||
Discourse.User.resetCurrent();
|
Discourse.User.resetCurrent();
|
||||||
Discourse.Site.resetCurrent(Discourse.Site.create(fixtures['site.json'].site));
|
Discourse.Site.resetCurrent(Discourse.Site.create(fixtures['site.json'].site));
|
||||||
|
|
||||||
|
Discourse.URL.redirectedTo = null;
|
||||||
|
Discourse.URL.redirectTo = function(url) {
|
||||||
|
Discourse.URL.redirectedTo = url;
|
||||||
|
};
|
||||||
|
|
||||||
PreloadStore.reset();
|
PreloadStore.reset();
|
||||||
|
|
||||||
window.sandbox = sinon.sandbox.create();
|
window.sandbox = sinon.sandbox.create();
|
||||||
|
|
Loading…
Reference in New Issue