2018-08-30 16:24:28 -04:00
|
|
|
/**
|
|
|
|
* This module is currently concerned only with external media libraries
|
|
|
|
* registered via `registerMediaLibrary`.
|
|
|
|
*/
|
|
|
|
import { once } from 'lodash';
|
2019-12-18 18:16:02 +02:00
|
|
|
import { getMediaLibrary } from './lib/registry';
|
2021-05-30 18:49:33 +02:00
|
|
|
import { store } from './redux';
|
2020-02-14 22:32:36 +02:00
|
|
|
import { configFailed } from './actions/config';
|
2019-12-18 18:16:02 +02:00
|
|
|
import { createMediaLibrary, insertMedia } from './actions/mediaLibrary';
|
2021-05-31 14:23:16 +02:00
|
|
|
import type { MediaLibraryInstance } from './types/redux';
|
2019-12-18 18:16:02 +02:00
|
|
|
|
|
|
|
type MediaLibraryOptions = {};
|
|
|
|
|
|
|
|
interface MediaLibrary {
|
|
|
|
init: (args: {
|
|
|
|
options: MediaLibraryOptions;
|
|
|
|
handleInsert: (url: string) => void;
|
|
|
|
}) => MediaLibraryInstance;
|
|
|
|
}
|
|
|
|
|
2021-02-08 20:01:21 +02:00
|
|
|
function handleInsert(url: string) {
|
2021-05-31 14:23:16 +02:00
|
|
|
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
2021-02-08 20:01:21 +02:00
|
|
|
// @ts-ignore
|
|
|
|
return store.dispatch(insertMedia(url, undefined));
|
|
|
|
}
|
|
|
|
|
2018-08-30 16:24:28 -04:00
|
|
|
const initializeMediaLibrary = once(async function initializeMediaLibrary(name, options) {
|
2021-05-19 14:39:35 +02:00
|
|
|
const lib = getMediaLibrary(name) as unknown as MediaLibrary | undefined;
|
2020-02-14 22:32:36 +02:00
|
|
|
if (!lib) {
|
|
|
|
const err = new Error(
|
|
|
|
`Missing external media library '${name}'. Please use 'registerMediaLibrary' to register it.`,
|
|
|
|
);
|
|
|
|
store.dispatch(configFailed(err));
|
|
|
|
} else {
|
|
|
|
const instance = await lib.init({ options, handleInsert });
|
|
|
|
store.dispatch(createMediaLibrary(instance));
|
|
|
|
}
|
2018-08-30 16:24:28 -04:00
|
|
|
});
|
|
|
|
|
|
|
|
store.subscribe(() => {
|
2021-03-11 12:08:46 +02:00
|
|
|
const state = store.getState();
|
|
|
|
if (state) {
|
|
|
|
const mediaLibraryName = state.config.media_library?.name;
|
|
|
|
if (mediaLibraryName && !state.mediaLibrary.get('externalLibrary')) {
|
|
|
|
const mediaLibraryConfig = state.config.media_library;
|
|
|
|
initializeMediaLibrary(mediaLibraryName, mediaLibraryConfig);
|
|
|
|
}
|
2018-08-30 16:24:28 -04:00
|
|
|
}
|
|
|
|
});
|