|
1 | 1 | import Controller from '@ember/controller'; |
| 2 | +import { inject as service } from '@ember/service'; |
2 | 3 | import { tracked } from '@glimmer/tracking'; |
3 | 4 |
|
| 5 | +import { dropTask } from 'ember-concurrency'; |
| 6 | +import { alias } from 'macro-decorators'; |
| 7 | + |
| 8 | +function defaultVersionsContext() { |
| 9 | + return { data: [], next_page: undefined }; |
| 10 | +} |
| 11 | + |
4 | 12 | export default class SearchController extends Controller { |
5 | | - queryParams = ['sort']; |
| 13 | + @service store; |
6 | 14 |
|
| 15 | + queryParams = ['per_page', 'sort']; |
7 | 16 | @tracked sort; |
| 17 | + @tracked per_page = 100; |
8 | 18 |
|
| 19 | + @tracked byDate; |
| 20 | + @tracked bySemver; |
9 | 21 | /** @type {import("../../models/crate").default} */ |
10 | 22 | @tracked crate; |
11 | 23 |
|
| 24 | + @alias('versionsContext.data') data; |
| 25 | + @alias('versionsContext.next_page') next_page; |
| 26 | + |
| 27 | + constructor() { |
| 28 | + super(...arguments); |
| 29 | + this.reset(); |
| 30 | + } |
| 31 | + |
12 | 32 | get currentSortBy() { |
13 | 33 | return this.sort === 'semver' ? 'SemVer' : 'Date'; |
14 | 34 | } |
15 | 35 |
|
| 36 | + get versionsContext() { |
| 37 | + return this.sort === 'semver' ? this.bySemver : this.byDate; |
| 38 | + } |
| 39 | + |
16 | 40 | get sortedVersions() { |
17 | | - let { versionIdsBySemver, versionIdsByDate, loadedVersionsById: versions } = this.crate; |
| 41 | + let { loadedVersionsById: versions } = this.crate; |
| 42 | + return this.data.map(id => versions.get(id)); |
| 43 | + } |
| 44 | + |
| 45 | + loadMoreTask = dropTask(async () => { |
| 46 | + let { crate, data, next_page, per_page, sort, versionsContext } = this; |
| 47 | + let query; |
| 48 | + |
| 49 | + if (next_page) { |
| 50 | + let params = new URLSearchParams(next_page); |
| 51 | + params.set('name', crate.name); |
| 52 | + query = Object.fromEntries(params.entries()); |
| 53 | + } else { |
| 54 | + if (sort !== 'semver') { |
| 55 | + sort = 'date'; |
| 56 | + } |
| 57 | + query = { |
| 58 | + name: crate.name, |
| 59 | + sort, |
| 60 | + per_page, |
| 61 | + }; |
| 62 | + } |
| 63 | + let versions = await this.store.query('version', query); |
| 64 | + let meta = versions.meta; |
| 65 | + |
| 66 | + let ids = versions.map(it => it.id); |
| 67 | + if (sort === 'semver') { |
| 68 | + this.bySemver = { |
| 69 | + ...versionsContext, |
| 70 | + data: data.concat(ids), |
| 71 | + next_page: meta.next_page, |
| 72 | + }; |
| 73 | + } else { |
| 74 | + this.byDate = { |
| 75 | + ...versionsContext, |
| 76 | + data: data.concat(ids), |
| 77 | + next_page: meta.next_page, |
| 78 | + }; |
| 79 | + } |
| 80 | + return versions; |
| 81 | + }); |
18 | 82 |
|
19 | | - return (this.sort === 'semver' ? versionIdsBySemver : versionIdsByDate).map(id => versions.get(id)); |
| 83 | + reset() { |
| 84 | + this.crate = undefined; |
| 85 | + this.byDate = defaultVersionsContext(); |
| 86 | + this.bySemver = defaultVersionsContext(); |
20 | 87 | } |
21 | 88 | } |
0 commit comments