Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
475 changes: 475 additions & 0 deletions EVENTS_SERVICE.md

Large diffs are not rendered by default.

1 change: 1 addition & 0 deletions addon/exports/host-services.js
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ export const hostServices = [
'sidebar',
'dashboard',
'universe',
'events',
'intl',
'abilities',
'language',
Expand Down
1 change: 1 addition & 0 deletions addon/exports/services.js
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ export const services = [
'sidebar',
'dashboard',
'universe',
'events',
'intl',
'abilities',
'language',
Expand Down
20 changes: 20 additions & 0 deletions addon/services/crud.js
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,8 @@ export default class CrudService extends Service {
@service notifications;
@service store;
@service currentUser;
@service universe;
@service events;

/**
* Generic deletion modal with options
Expand All @@ -43,6 +45,10 @@ export default class CrudService extends Service {
try {
const response = await model.destroyRecord();
this.notifications.success(successNotification);

// Track deletion event
this.events.trackResourceDeleted(model);

if (typeof options.onSuccess === 'function') {
options.onSuccess(model);
}
Expand Down Expand Up @@ -161,6 +167,10 @@ export default class CrudService extends Service {
);

this.notifications.success(response.message ?? successMessage);

// Track bulk action event
this.events.trackBulkAction(verb, selected);

if (typeof options.onSuccess === 'function') {
options.onSuccess(selected);
}
Expand Down Expand Up @@ -224,6 +234,9 @@ export default class CrudService extends Service {
}
)
.then(() => {
// Track export event
this.events.trackResourceExported(modelName, format, exportParams);

later(
this,
() => {
Expand All @@ -248,6 +261,8 @@ export default class CrudService extends Service {
* @param {Object} [options={}]
* @memberof CrudService
*/


@action import(modelName, options = {}) {
// always lowercase modelname
modelName = modelName.toLowerCase();
Expand Down Expand Up @@ -337,6 +352,11 @@ export default class CrudService extends Service {

try {
const response = await this.fetch.post(importEndpoint, { files }, fetchOptions);

// Track import event
const importCount = response?.imported?.length || response?.count || files.length;
this.events.trackResourceImported(modelName, importCount);

if (typeof options.onImportCompleted === 'function') {
options.onImportCompleted(response, files);
}
Expand Down
1 change: 1 addition & 0 deletions addon/services/current-user.js
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ export default class CurrentUserService extends Service.extend(Evented) {
@service theme;
@service notifications;
@service intl;
@service events;

@tracked user = { id: 'anon' };
@tracked userSnapshot = { id: 'anon' };
Expand Down
Loading