mirror of
https://github.com/bigcapitalhq/bigcapital.git
synced 2026-02-16 04:40:32 +00:00
- feat: Favicon setup. - feat: Fix accounts inactivate/activate 1 account. - feat: Seed accounts, expenses and manual journals resource fields. - feat: Validate make journal receivable/payable without contact. - feat: Validate make journal contact without receivable or payable. - feat: More components abstractions. - feat: Use reselect.js to memorize components properties. - fix: Journal type of manual journal. - fix: Sidebar style optimization. - fix: Data-table check-box style optimization. - fix: Data-table spinner style dimensions. - fix: Submit journal with contact_id and contact_type.
50 lines
1.5 KiB
JavaScript
50 lines
1.5 KiB
JavaScript
import { pick, at, mapValues } from 'lodash';
|
|
|
|
export const getItemById = (items, id) => {
|
|
return items[id] || null;
|
|
};
|
|
|
|
export const pickItemsFromIds = (items, ids) => {
|
|
return at(items, ids).filter(i => i);
|
|
}
|
|
|
|
export const getCurrentPageResults = (items, pages, pageNumber) => {
|
|
const currentPage = pages[pageNumber]
|
|
return typeof currentPage == 'undefined' ?
|
|
[] : pickItemsFromIds(items, currentPage.ids);
|
|
}
|
|
|
|
export const getCurrentTotalResultsCount = (pagination, name) => {
|
|
const currentPageUrl = pagination.currentPages[name]
|
|
const currentPage = pagination.pages[currentPageUrl]
|
|
return typeof currentPageUrl == 'undefined' ? 0 : pagination.params[currentPage.params]
|
|
}
|
|
|
|
export const getAllResults = (items, pagination, name) => {
|
|
const currentPage = pagination.pages[pagination.currentPages[name]]
|
|
if (typeof currentPage == 'undefined') {
|
|
return []
|
|
}
|
|
let allPagesKeys = Object.keys(pagination.pages)
|
|
let allPagesIds = []
|
|
for (let key of allPagesKeys) {
|
|
if (pagination.pages[key].params == currentPage.params) {
|
|
allPagesIds = allPagesIds.concat(pagination.pages[key].ids)
|
|
}
|
|
}
|
|
return Object.values(pick(items || [], allPagesIds))
|
|
}
|
|
|
|
export const paginationLocationQuery = (state, props) => {
|
|
const queryParams = props.location
|
|
? new URLSearchParams(props.location.search)
|
|
: null;
|
|
|
|
const queryParamsKeys = ['page_size', 'page'];
|
|
|
|
return queryParams
|
|
? mapValues(pick(Object.fromEntries(queryParams), queryParamsKeys), (v) =>
|
|
parseInt(v, 10),
|
|
)
|
|
: null;
|
|
} |