Files
SCM-Manager/scm-ui/ui-webapp/src/repos/sources/modules/sources.ts

155 lines
3.7 KiB
TypeScript
Raw Normal View History

import * as types from '../../../modules/types';
import { Repository, File, Action } from '@scm-manager/ui-types';
import { apiClient } from '@scm-manager/ui-components';
import { isPending } from '../../../modules/pending';
import { getFailure } from '../../../modules/failure';
2018-09-27 16:32:37 +02:00
export const FETCH_SOURCES = 'scm/repos/FETCH_SOURCES';
2018-09-27 16:32:37 +02:00
export const FETCH_SOURCES_PENDING = `${FETCH_SOURCES}_${types.PENDING_SUFFIX}`;
export const FETCH_SOURCES_SUCCESS = `${FETCH_SOURCES}_${types.SUCCESS_SUFFIX}`;
export const FETCH_SOURCES_FAILURE = `${FETCH_SOURCES}_${types.FAILURE_SUFFIX}`;
export function fetchSources(
repository: Repository,
revision: string,
path: string,
) {
2018-09-27 16:32:37 +02:00
return function(dispatch: any) {
dispatch(fetchSourcesPending(repository, revision, path));
2018-09-27 16:32:37 +02:00
return apiClient
.get(createUrl(repository, revision, path))
2018-09-27 16:32:37 +02:00
.then(response => response.json())
.then(sources => {
dispatch(fetchSourcesSuccess(repository, revision, path, sources));
2018-09-27 16:32:37 +02:00
})
.catch(err => {
dispatch(fetchSourcesFailure(repository, revision, path, err));
2018-09-27 16:32:37 +02:00
});
};
}
function createUrl(repository: Repository, revision: string, path: string) {
const base = repository._links.sources.href;
if (!revision && !path) {
return base;
}
// TODO handle trailing slash
const pathDefined = path ? path : '';
2018-10-23 13:03:15 +02:00
return `${base}${encodeURIComponent(revision)}/${pathDefined}`;
}
export function fetchSourcesPending(
repository: Repository,
revision: string,
path: string,
): Action {
2018-09-27 16:32:37 +02:00
return {
type: FETCH_SOURCES_PENDING,
itemId: createItemId(repository, revision, path),
2018-09-27 16:32:37 +02:00
};
}
export function fetchSourcesSuccess(
repository: Repository,
revision: string,
path: string,
sources: File,
2018-09-27 16:32:37 +02:00
) {
return {
type: FETCH_SOURCES_SUCCESS,
payload: sources,
itemId: createItemId(repository, revision, path),
2018-09-27 16:32:37 +02:00
};
}
export function fetchSourcesFailure(
repository: Repository,
revision: string,
path: string,
error: Error,
2018-09-27 16:32:37 +02:00
): Action {
return {
type: FETCH_SOURCES_FAILURE,
payload: error,
itemId: createItemId(repository, revision, path),
2018-09-27 16:32:37 +02:00
};
}
function createItemId(repository: Repository, revision: string, path: string) {
const revPart = revision ? revision : '_';
const pathPart = path ? path : '';
return `${repository.namespace}/${repository.name}/${revPart}/${pathPart}`;
2018-09-27 16:32:37 +02:00
}
// reducer
export default function reducer(
state: any = {},
action: Action = {
type: 'UNKNOWN',
},
2018-09-27 16:32:37 +02:00
): any {
2018-11-07 16:42:26 +01:00
if (action.itemId && action.type === FETCH_SOURCES_SUCCESS) {
2018-09-27 16:32:37 +02:00
return {
...state,
[action.itemId]: action.payload,
2018-09-27 16:32:37 +02:00
};
}
return state;
}
// selectors
export function isDirectory(
state: any,
repository: Repository,
revision: string,
path: string,
): boolean {
const currentFile = getSources(state, repository, revision, path);
if (currentFile && !currentFile.directory) {
return false;
} else {
return true; //also return true if no currentFile is found since it is the "default" path
}
}
2018-09-27 16:32:37 +02:00
export function getSources(
state: any,
repository: Repository,
revision: string,
path: string,
): File | null | undefined {
2018-09-27 16:32:37 +02:00
if (state.sources) {
return state.sources[createItemId(repository, revision, path)];
2018-09-27 16:32:37 +02:00
}
return null;
}
export function isFetchSourcesPending(
state: any,
repository: Repository,
revision: string,
path: string,
2018-09-27 16:32:37 +02:00
): boolean {
return isPending(
state,
FETCH_SOURCES,
createItemId(repository, revision, path),
);
2018-09-27 16:32:37 +02:00
}
export function getFetchSourcesFailure(
state: any,
repository: Repository,
revision: string,
path: string,
): Error | null | undefined {
return getFailure(
state,
FETCH_SOURCES,
createItemId(repository, revision, path),
);
2018-09-27 16:32:37 +02:00
}