Press n or j to go to the next uncovered block, b, p or k for the previous block.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 | 1x | import _ from 'lodash'; import UsersFiltersDao from '../../database/dao/usersFilters'; import { models } from '../../../config/database'; async function getOptionsUsersFilters(query = {}, userId, opts = {}) { const usersFilters = await UsersFiltersDao.findUsersFilters(query, { include: [{ required: true, model: models.User, as: 'user', attributes: ['name'] }], attributes: [ 'id', 'type', 'userId', 'permission', 'filterName', 'filter', ], ...opts }); const reduced = usersFilters.reduce((acum, it) => { const filter = { id: it.id, filterName: `${it.user.name} - ${it.filterName}`, filterNameValue: it.filterName, type: it.type, permission: it.permission, filter: JSON.parse(it.filter), }; if (it.userId === userId && it.permission === 'private') { acum.filterPrivate.push(filter); acum.userFilters.push(filter); } else if (it.permission === 'public') { acum.filterPublic.push(filter); if (it.userId === userId) acum.userFilters.push(filter); } return acum; }, { filterPrivate: [], filterPublic: [], userFilters: [] }); // Orders reduced.filterPrivate = _.orderBy(reduced.filterPrivate, ['filterName'], 'asc'); reduced.filterPublic = _.orderBy(reduced.filterPublic, ['filterName'], 'asc'); reduced.userFilters = _.orderBy(reduced.userFilters, ['filterName'], 'asc'); return reduced; } async function getFilter(query = {}, opts = {}) { return await UsersFiltersDao.findUserFilter(query, opts); } export default { getOptionsUsersFilters, getFilter, } |