mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-07 19:46:37 +03:00
cb59388c5b
no issue - adds `eslint-plugin-sort-imports-es6-autofix` dependency - implements ESLint's base `sort-imports` rule but has a distinction in that `import {foo} from 'bar';` is considered `multiple` rather than `single` - fixes ESLint's autofix behaviour so `eslint --fix` will actually fix the sort order - updates all unordered import rules by using `eslint --fix` With the increased number of `import` statements since Ember+ecosystem started moving towards es6 modules I've found it frustrating at times trying to search through randomly ordered import statements. Recently I've been sorting imports manually when I've added new code or touched old code so I thought I'd add an ESLint rule to codify it.
168 lines
5.2 KiB
JavaScript
168 lines
5.2 KiB
JavaScript
import $ from 'jquery';
|
|
import Controller from 'ember-controller';
|
|
import PaginationMixin from 'ghost-admin/mixins/pagination';
|
|
import Table from 'ember-light-table';
|
|
import computed from 'ember-computed';
|
|
import ghostPaths from 'ghost-admin/utils/ghost-paths';
|
|
import injectService from 'ember-service/inject';
|
|
import {assign} from 'ember-platform';
|
|
|
|
export default Controller.extend(PaginationMixin, {
|
|
|
|
queryParams: ['order', 'direction'],
|
|
order: 'created_at',
|
|
direction: 'desc',
|
|
|
|
paginationModel: 'subscriber',
|
|
|
|
total: 0,
|
|
table: null,
|
|
subscriberToDelete: null,
|
|
|
|
session: injectService(),
|
|
|
|
// paginationSettings is replaced by the pagination mixin so we need a
|
|
// getter/setter CP here so that we don't lose the dynamic order param
|
|
paginationSettings: computed('order', 'direction', {
|
|
get() {
|
|
let order = this.get('order');
|
|
let direction = this.get('direction');
|
|
|
|
let currentSettings = this._paginationSettings || {
|
|
limit: 30
|
|
};
|
|
|
|
return assign({}, currentSettings, {
|
|
order: `${order} ${direction}`
|
|
});
|
|
},
|
|
set(key, value) {
|
|
this._paginationSettings = value;
|
|
return value;
|
|
}
|
|
}),
|
|
|
|
columns: computed('order', 'direction', function () {
|
|
let order = this.get('order');
|
|
let direction = this.get('direction');
|
|
|
|
return [{
|
|
label: 'Email address',
|
|
valuePath: 'email',
|
|
sorted: order === 'email',
|
|
ascending: direction === 'asc',
|
|
classNames: ['gh-subscribers-table-email-cell'],
|
|
cellClassNames: ['gh-subscribers-table-email-cell']
|
|
}, {
|
|
label: 'Subscription Date',
|
|
valuePath: 'createdAtUTC',
|
|
format(value) {
|
|
return value.format('MMMM DD, YYYY');
|
|
},
|
|
sorted: order === 'created_at',
|
|
ascending: direction === 'asc',
|
|
classNames: ['gh-subscribers-table-date-cell'],
|
|
cellClassNames: ['gh-subscribers-table-date-cell']
|
|
}, {
|
|
label: 'Status',
|
|
valuePath: 'status',
|
|
sorted: order === 'status',
|
|
ascending: direction === 'asc',
|
|
classNames: ['gh-subscribers-table-status-cell'],
|
|
cellClassNames: ['gh-subscribers-table-status-cell']
|
|
}, {
|
|
label: '',
|
|
sortable: false,
|
|
cellComponent: 'gh-subscribers-table-delete-cell',
|
|
align: 'right',
|
|
classNames: ['gh-subscribers-table-delete-cell'],
|
|
cellClassNames: ['gh-subscribers-table-delete-cell']
|
|
}];
|
|
}),
|
|
|
|
initializeTable() {
|
|
this.set('table', new Table(this.get('columns'), this.get('subscribers')));
|
|
},
|
|
|
|
// capture the total from the server any time we fetch a new page
|
|
didReceivePaginationMeta(meta) {
|
|
if (meta && meta.pagination) {
|
|
this.set('total', meta.pagination.total);
|
|
}
|
|
},
|
|
|
|
actions: {
|
|
loadFirstPage() {
|
|
let table = this.get('table');
|
|
|
|
return this._super(...arguments).then((results) => {
|
|
table.addRows(results);
|
|
return results;
|
|
});
|
|
},
|
|
|
|
loadNextPage() {
|
|
let table = this.get('table');
|
|
|
|
return this._super(...arguments).then((results) => {
|
|
table.addRows(results);
|
|
return results;
|
|
});
|
|
},
|
|
|
|
sortByColumn(column) {
|
|
let table = this.get('table');
|
|
|
|
if (column.sorted) {
|
|
this.setProperties({
|
|
order: column.get('valuePath').trim().replace(/UTC$/, '').underscore(),
|
|
direction: column.ascending ? 'asc' : 'desc'
|
|
});
|
|
table.setRows([]);
|
|
this.send('loadFirstPage');
|
|
}
|
|
},
|
|
|
|
addSubscriber(subscriber) {
|
|
this.get('table').insertRowAt(0, subscriber);
|
|
this.incrementProperty('total');
|
|
},
|
|
|
|
deleteSubscriber(subscriber) {
|
|
this.set('subscriberToDelete', subscriber);
|
|
},
|
|
|
|
confirmDeleteSubscriber() {
|
|
let subscriber = this.get('subscriberToDelete');
|
|
|
|
return subscriber.destroyRecord().then(() => {
|
|
this.set('subscriberToDelete', null);
|
|
this.get('table').removeRow(subscriber);
|
|
this.decrementProperty('total');
|
|
});
|
|
},
|
|
|
|
cancelDeleteSubscriber() {
|
|
this.set('subscriberToDelete', null);
|
|
},
|
|
|
|
reset() {
|
|
this.get('table').setRows([]);
|
|
this.send('loadFirstPage');
|
|
},
|
|
|
|
exportData() {
|
|
let exportUrl = ghostPaths().url.api('subscribers/csv');
|
|
let accessToken = this.get('session.data.authenticated.access_token');
|
|
let downloadURL = `${exportUrl}?access_token=${accessToken}`;
|
|
let iframe = $('#iframeDownload');
|
|
|
|
if (iframe.length === 0) {
|
|
iframe = $('<iframe>', {id: 'iframeDownload'}).hide().appendTo('body');
|
|
}
|
|
|
|
iframe.attr('src', downloadURL);
|
|
}
|
|
}
|
|
});
|