🐛 Fixed members list not refreshing after adding yourself

no issue

- passed in the `refreshData` action to the `<GhMembersNoMembers>` component and called it after creating the member
- converted `<GhMembersNoMembers>` to a glimmer component
This commit is contained in:
Kevin Ansfield 2020-06-05 08:49:56 +01:00
parent 7b49d05e96
commit 7ac7e73a05
4 changed files with 31 additions and 24 deletions

View File

@ -1,14 +1,14 @@
<div class="flex flex-column items-stretch">
{{!-- <p class="">Get started with one of the following options</p> --}}
<button class="gh-btn gh-btn-green" onclick={{action "addYourself"}}>
<button class="gh-btn gh-btn-green" {{on "click" this.addYourself}}>
<span>Add yourself as a member to test</span>
</button>
<div class="flex flex-column items-stretch mt8 pt8 pb10 bt b--lightgrey-d1">
<LinkTo @route="member.new" class="gh-btn gh-btn-outline mb3">
<span>Manually add a member</span>
</LinkTo>
<LinkTo @route="members.import" class="gh-btn gh-btn-outline">
<span>Import members from CSV</span>
</LinkTo>

View File

@ -1,38 +1,45 @@
import Component from '@ember/component';
import Component from '@glimmer/component';
import {action} from '@ember/object';
import {inject as service} from '@ember/service';
import {task} from 'ember-concurrency';
import {task} from 'ember-concurrency-decorators';
export default Component.extend({
session: service(),
store: service(),
notifications: service(),
export default class GhMembersNoMembersComponent extends Component {
@service session;
@service store;
@service notifications;
actions: {
addYourself() {
return this.add.perform();
}
},
@action
addYourself() {
return this.addTask.perform();
}
@task({drop: true})
*addTask() {
const user = yield this.session.user;
add: task(function* () {
const member = this.store.createRecord('member', {
email: this.get('session.user.email'),
name: this.get('session.user.name')
email: user.get('email'),
name: user.get('name')
});
try {
// NOTE: has to be before member.save() is performed otherwise component is
// destroyed before notification is shown
yield member.save();
if (this.args.afterCreate) {
this.args.afterCreate();
}
this.notifications.showNotification('Member added'.htmlSafe(),
{
description: 'You\'ve successfully added yourself as a member.'
}
);
return yield member.save();
return member;
} catch (error) {
if (error) {
this.notifications.showAPIError(error, {key: 'member.save'});
}
}
}).drop()
});
}
}

View File

@ -172,7 +172,7 @@ export default class MembersController extends Controller {
}
}
@task
@task({restartable: true})
*fetchMembersTask(params) {
// params is undefined when called as a "refresh" of the model
let {label, searchParam} = typeof params === 'undefined' ? this : params;

View File

@ -71,7 +71,7 @@
{{svg-jar "members-placeholder" class="gh-members-placeholder"}}
{{#if this.showingAll}}
<h3>No members yet</h3>
<GhMembersNoMembers />
<GhMembersNoMembers @afterCreate={{this.refreshData}} />
{{else}}
<h3>No members match the current filter</h3>
{{/if}}