You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
63 lines
2.1 KiB
TypeScript
63 lines
2.1 KiB
TypeScript
export * from './utils';
|
|
export { default as Notification } from './components/notification';
|
|
export * from './components/dialog';
|
|
export * as bus from './bus';
|
|
export { default as AnsiUp } from 'ansi_up';
|
|
export { default as loadMonaco } from './components/monaco/loader';
|
|
export * as redux from 'react-redux';
|
|
export * from './components/zipDownloader';
|
|
export { default as $ } from 'jquery';
|
|
export { default as _ } from 'lodash';
|
|
export { default as React } from 'react';
|
|
export { default as ReactDOM } from 'react-dom/client';
|
|
export * from './misc/Page';
|
|
|
|
export default async function load(name: string) {
|
|
if (window.node_modules[name]) return window.node_modules[name];
|
|
if (name === 'echarts') return import('echarts');
|
|
if (name === 'moment') return import('moment');
|
|
throw new Error(`Module ${name} not found`);
|
|
}
|
|
|
|
import AutoComplete from './components/autocomplete';
|
|
import CustomSelectAutoComplete from './components/autocomplete/CustomSelectAutoComplete';
|
|
import DomainSelectAutoComplete from './components/autocomplete/DomainSelectAutoComplete';
|
|
import ProblemSelectAutoComplete from './components/autocomplete/ProblemSelectAutoComplete';
|
|
import UserSelectAutoComplete from './components/autocomplete/UserSelectAutoComplete';
|
|
|
|
export {
|
|
load, AutoComplete, UserSelectAutoComplete, ProblemSelectAutoComplete, DomainSelectAutoComplete, CustomSelectAutoComplete,
|
|
};
|
|
export function addPage(page: import('./misc/Page').Page | (() => Promise<void> | void)) {
|
|
window.Hydro.extraPages.push(page);
|
|
}
|
|
|
|
declare global {
|
|
interface Window {
|
|
LANGS: Record<string, any>;
|
|
}
|
|
|
|
let UserContext: Record<string, any>;
|
|
let UiContext: Record<string, any>;
|
|
}
|
|
|
|
// Below are old version api compat
|
|
/* eslint-disable import/order */
|
|
import $ from 'jquery';
|
|
import _ from 'lodash';
|
|
import React from 'react';
|
|
import ReactDOM from 'react-dom/client';
|
|
import * as redux from 'react-redux';
|
|
|
|
const modules = {
|
|
_, $, React, redux, ReactDOM, load,
|
|
};
|
|
|
|
declare global {
|
|
interface Window {
|
|
node_modules: typeof modules;
|
|
}
|
|
}
|
|
|
|
Object.assign(window, { node_modules: modules, $, jQuery: $ });
|