mirror of
https://github.com/flarum/framework.git
synced 2025-01-19 07:42:48 +08:00
Fix global typings for extensions (#2992)
* Fix global typings for extensions * Deprecate global `app` typings See https://github.com/flarum/core/issues/2857#issuecomment-889841326 * Add `app` export for common namespace * Add missing `app` imports within core * Add missing `app` imports to JS files * Fix incorrect import * Fix admin file importing forum `app` * Add `flarum` global variable * Format * Update JSDoc comment * Update JSDoc comment Co-authored-by: Alexander Skvortsov <sasha.skvortsov109@gmail.com> * Fix frontend JS error * Empty commit Co-authored-by: Alexander Skvortsov <sasha.skvortsov109@gmail.com>
This commit is contained in:
parent
8fe2332f98
commit
2831ce226c
53
js/@types/global/index.d.ts
vendored
53
js/@types/global/index.d.ts
vendored
|
@ -1,53 +0,0 @@
|
|||
// Mithril
|
||||
import Mithril from 'mithril';
|
||||
|
||||
// Other third-party libs
|
||||
import * as _dayjs from 'dayjs';
|
||||
import 'dayjs/plugin/relativeTime';
|
||||
import * as _$ from 'jquery';
|
||||
|
||||
// Globals from flarum/core
|
||||
import Application from '../../src/common/Application';
|
||||
|
||||
import type { TooltipJQueryFunction } from '../tooltips';
|
||||
|
||||
/**
|
||||
* flarum/core exposes several extensions globally:
|
||||
*
|
||||
* - jQuery for convenient DOM manipulation
|
||||
* - Mithril for VDOM and components
|
||||
* - dayjs for date/time operations
|
||||
*
|
||||
* Since these are already part of the global namespace, extensions won't need
|
||||
* to (and should not) bundle these themselves.
|
||||
*/
|
||||
declare global {
|
||||
// $ is already defined by `@types/jquery`
|
||||
const m: Mithril.Static;
|
||||
const dayjs: typeof _dayjs;
|
||||
|
||||
// Extend JQuery with our custom functions, defined with $.fn
|
||||
interface JQuery {
|
||||
tooltip: TooltipJQueryFunction;
|
||||
}
|
||||
|
||||
/**
|
||||
* For more info, see: https://www.typescriptlang.org/docs/handbook/jsx.html#attribute-type-checking
|
||||
*
|
||||
* In a nutshell, we need to add `ElementAttributesProperty` to tell Typescript
|
||||
* what property on component classes to look at for attribute typings. For our
|
||||
* Component class, this would be `attrs` (e.g. `this.attrs...`)
|
||||
*/
|
||||
namespace JSX {
|
||||
interface ElementAttributesProperty {
|
||||
attrs: Record<string, unknown>;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* All global variables owned by flarum/core.
|
||||
*/
|
||||
declare global {
|
||||
const app: Application;
|
||||
}
|
|
@ -41,6 +41,6 @@
|
|||
"format": "prettier --write src",
|
||||
"format-check": "prettier --check src",
|
||||
"clean-typings": "npx rimraf dist-typings && mkdir dist-typings",
|
||||
"build-typings": "npm run clean-typings && cp -r @types dist-typings/@types && tsc"
|
||||
"build-typings": "npm run clean-typings && cp -r src/@types dist-typings/@types && tsc"
|
||||
}
|
||||
}
|
||||
|
|
82
js/src/@types/global.d.ts
vendored
Normal file
82
js/src/@types/global.d.ts
vendored
Normal file
|
@ -0,0 +1,82 @@
|
|||
/**
|
||||
* @deprecated Please import `app` from a namespace instead of using it as a global variable.
|
||||
*
|
||||
* @example App in forum JS
|
||||
* ```
|
||||
* import app from 'flarum/forum/app';
|
||||
* ```
|
||||
*
|
||||
* @example App in admin JS
|
||||
* ```
|
||||
* import app from 'flarum/admin/app';
|
||||
* ```
|
||||
*
|
||||
* @example App in common JS
|
||||
* ```
|
||||
* import app from 'flarum/common/app';
|
||||
* ```
|
||||
*/
|
||||
declare const app: never;
|
||||
|
||||
declare const m: import('mithril').Static;
|
||||
declare const dayjs: typeof import('dayjs');
|
||||
|
||||
type ESModule = { __esModule: true; [key: string]: unknown };
|
||||
|
||||
/**
|
||||
* The global `flarum` variable.
|
||||
*
|
||||
* Contains the compiled ES Modules for all Flarum extensions and core.
|
||||
*
|
||||
* @example <caption>Check if `flarum-tags` is present</captions>
|
||||
* if ('flarum-tags' in flarum.extensions) {
|
||||
* // Tags is installed and enabled!
|
||||
* }
|
||||
*/
|
||||
interface FlarumObject {
|
||||
/**
|
||||
* Contains the compiled ES Module for Flarum's core.
|
||||
*
|
||||
* You shouldn't need to access this directly for any reason.
|
||||
*/
|
||||
core: Readonly<ESModule>;
|
||||
/**
|
||||
* Contains the compiled ES Modules for all Flarum extensions.
|
||||
*
|
||||
* @example <caption>Check if `flarum-tags` is present</captions>
|
||||
* if ('flarum-tags' in flarum.extensions) {
|
||||
* // Tags is installed and enabled!
|
||||
* }
|
||||
*/
|
||||
extensions: Readonly<Record<string, ESModule>>;
|
||||
}
|
||||
|
||||
declare const flarum: FlarumObject;
|
||||
|
||||
// Extend JQuery with our custom functions, defined with $.fn
|
||||
interface JQuery {
|
||||
/**
|
||||
* Flarum's tooltip JQuery plugin.
|
||||
*
|
||||
* Do not use this directly. Instead use the `<Tooltip>` component that
|
||||
* is exported from `flarum/common/components/Tooltip`.
|
||||
*
|
||||
* This will be removed in a future version of Flarum.
|
||||
*
|
||||
* @deprecated
|
||||
*/
|
||||
tooltip: import('./tooltips/index').TooltipJQueryFunction;
|
||||
}
|
||||
|
||||
/**
|
||||
* For more info, see: https://www.typescriptlang.org/docs/handbook/jsx.html#attribute-type-checking
|
||||
*
|
||||
* In a nutshell, we need to add `ElementAttributesProperty` to tell Typescript
|
||||
* what property on component classes to look at for attribute typings. For our
|
||||
* Component class, this would be `attrs` (e.g. `this.attrs...`)
|
||||
*/
|
||||
interface JSX {
|
||||
ElementAttributesProperty: {
|
||||
attrs: Record<string, unknown>;
|
||||
};
|
||||
}
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../admin/app';
|
||||
import ExtensionLinkButton from './ExtensionLinkButton';
|
||||
import Component from '../../common/Component';
|
||||
import LinkButton from '../../common/components/LinkButton';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../admin/app';
|
||||
import Page from '../../common/components/Page';
|
||||
import Button from '../../common/components/Button';
|
||||
import Switch from '../../common/components/Switch';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../admin/app';
|
||||
import Button from '../../common/components/Button';
|
||||
import EditCustomCssModal from './EditCustomCssModal';
|
||||
import EditCustomHeaderModal from './EditCustomHeaderModal';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../admin/app';
|
||||
import FieldSet from '../../common/components/FieldSet';
|
||||
import ItemList from '../../common/utils/ItemList';
|
||||
import AdminPage from './AdminPage';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../admin/app';
|
||||
import StatusWidget from './StatusWidget';
|
||||
import ExtensionsWidget from './ExtensionsWidget';
|
||||
import ItemList from '../../common/utils/ItemList';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../admin/app';
|
||||
import SettingsModal from './SettingsModal';
|
||||
|
||||
export default class EditCustomCssModal extends SettingsModal {
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../admin/app';
|
||||
import SettingsModal from './SettingsModal';
|
||||
|
||||
export default class EditCustomFooterModal extends SettingsModal {
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../admin/app';
|
||||
import SettingsModal from './SettingsModal';
|
||||
|
||||
export default class EditCustomHeaderModal extends SettingsModal {
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../admin/app';
|
||||
import Modal from '../../common/components/Modal';
|
||||
import Button from '../../common/components/Button';
|
||||
import Badge from '../../common/components/Badge';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../admin/app';
|
||||
import isExtensionEnabled from '../utils/isExtensionEnabled';
|
||||
import LinkButton from '../../common/components/LinkButton';
|
||||
import icon from '../../common/helpers/icon';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../admin/app';
|
||||
import Button from '../../common/components/Button';
|
||||
import Link from '../../common/components/Link';
|
||||
import LinkButton from '../../common/components/LinkButton';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../admin/app';
|
||||
import PermissionGrid from './PermissionGrid';
|
||||
import Button from '../../common/components/Button';
|
||||
import ItemList from '../../common/utils/ItemList';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../admin/app';
|
||||
import DashboardWidget from './DashboardWidget';
|
||||
import isExtensionEnabled from '../utils/isExtensionEnabled';
|
||||
import getCategorizedExtensions from '../utils/getCategorizedExtensions';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../admin/app';
|
||||
import Component from '../../common/Component';
|
||||
import LinkButton from '../../common/components/LinkButton';
|
||||
import SessionDropdown from './SessionDropdown';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../admin/app';
|
||||
import Modal from '../../common/components/Modal';
|
||||
|
||||
export default class LoadingModal extends Modal {
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../admin/app';
|
||||
import FieldSet from '../../common/components/FieldSet';
|
||||
import Button from '../../common/components/Button';
|
||||
import Alert from '../../common/components/Alert';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../admin/app';
|
||||
import Dropdown from '../../common/components/Dropdown';
|
||||
import Button from '../../common/components/Button';
|
||||
import Separator from '../../common/components/Separator';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../admin/app';
|
||||
import Component from '../../common/Component';
|
||||
import PermissionDropdown from './PermissionDropdown';
|
||||
import SettingDropdown from './SettingDropdown';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../admin/app';
|
||||
import GroupBadge from '../../common/components/GroupBadge';
|
||||
import EditGroupModal from './EditGroupModal';
|
||||
import Group from '../../common/models/Group';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../admin/app';
|
||||
import avatar from '../../common/helpers/avatar';
|
||||
import username from '../../common/helpers/username';
|
||||
import Dropdown from '../../common/components/Dropdown';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../admin/app';
|
||||
import SelectDropdown from '../../common/components/SelectDropdown';
|
||||
import Button from '../../common/components/Button';
|
||||
import saveSettings from '../utils/saveSettings';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../admin/app';
|
||||
import Modal from '../../common/components/Modal';
|
||||
import Button from '../../common/components/Button';
|
||||
import Stream from '../../common/utils/Stream';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../admin/app';
|
||||
import DashboardWidget from './DashboardWidget';
|
||||
import listItems from '../../common/helpers/listItems';
|
||||
import ItemList from '../../common/utils/ItemList';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../admin/app';
|
||||
import Button from '../../common/components/Button';
|
||||
|
||||
export default class UploadImageButton extends Button {
|
||||
|
|
|
@ -1,3 +1,5 @@
|
|||
import app from '../../admin/app';
|
||||
|
||||
import EditUserModal from '../../common/components/EditUserModal';
|
||||
import LoadingIndicator from '../../common/components/LoadingIndicator';
|
||||
import Button from '../../common/components/Button';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../admin/app';
|
||||
import DefaultResolver from '../../common/resolvers/DefaultResolver';
|
||||
|
||||
/**
|
||||
|
|
|
@ -1,3 +1,5 @@
|
|||
import app from '../../admin/app';
|
||||
|
||||
export default function getCategorizedExtensions() {
|
||||
let extensions = {};
|
||||
|
||||
|
|
|
@ -1,3 +1,5 @@
|
|||
import app from '../../admin/app';
|
||||
|
||||
export default function isExtensionEnabled(name) {
|
||||
const enabled = JSON.parse(app.data.settings.extensions_enabled);
|
||||
|
||||
|
|
|
@ -1,3 +1,5 @@
|
|||
import app from '../../admin/app';
|
||||
|
||||
export default function saveSettings(settings) {
|
||||
const oldSettings = JSON.parse(JSON.stringify(app.data.settings));
|
||||
|
||||
|
|
|
@ -1,3 +1,5 @@
|
|||
import app from '../common/app';
|
||||
|
||||
import ItemList from './utils/ItemList';
|
||||
import Button from './components/Button';
|
||||
import ModalManager from './components/ModalManager';
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
import * as Mithril from 'mithril';
|
||||
import type Mithril from 'mithril';
|
||||
|
||||
export interface ComponentAttrs extends Mithril.Attributes {}
|
||||
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
import * as Mithril from 'mithril';
|
||||
import type Mithril from 'mithril';
|
||||
|
||||
/**
|
||||
* The `Fragment` class represents a chunk of DOM that is rendered once with Mithril and then takes
|
||||
|
|
|
@ -1,3 +1,5 @@
|
|||
import app from '../common/app';
|
||||
|
||||
/**
|
||||
* The `Model` class represents a local data resource. It provides methods to
|
||||
* persist changes via the API.
|
||||
|
|
|
@ -1,3 +1,5 @@
|
|||
import app from '../common/app';
|
||||
|
||||
/**
|
||||
* The `Session` class defines the current user session. It stores a reference
|
||||
* to the current authenticated user, and provides methods to log in/out.
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../common/app';
|
||||
/**
|
||||
* The `Store` class defines a local data store, and provides methods to
|
||||
* retrieve data from the API.
|
||||
|
|
31
js/src/common/app.ts
Normal file
31
js/src/common/app.ts
Normal file
|
@ -0,0 +1,31 @@
|
|||
import type Application from './Application';
|
||||
|
||||
// Used to fix typings
|
||||
const w = window as any;
|
||||
|
||||
/**
|
||||
* Proxy app. Common JS is run first, at which point `window.app` is not
|
||||
* set as this is done by the namespaced JS.
|
||||
*
|
||||
* When the corrent value is set, this code would retain the reference to
|
||||
* the original invalid value.
|
||||
*
|
||||
* By using a proxy, we can ensure that our `window.app` value is always
|
||||
* up-to-date with the latest reference.
|
||||
*/
|
||||
const appProxy = new Proxy(
|
||||
{},
|
||||
{
|
||||
get(_, properties) {
|
||||
return Reflect.get(w.app, properties, w.app);
|
||||
},
|
||||
set(_, properties, value) {
|
||||
return Reflect.set(w.app, properties, value, w.app);
|
||||
},
|
||||
}
|
||||
);
|
||||
|
||||
/**
|
||||
* The instance of Application within the common namespace.
|
||||
*/
|
||||
export default appProxy as Application;
|
|
@ -2,7 +2,7 @@ import Component, { ComponentAttrs } from '../Component';
|
|||
import Button from './Button';
|
||||
import listItems from '../helpers/listItems';
|
||||
import extract from '../utils/extract';
|
||||
import Mithril from 'mithril';
|
||||
import type Mithril from 'mithril';
|
||||
|
||||
export interface AlertAttrs extends ComponentAttrs {
|
||||
/** The type of alert this is. Will be used to give the alert a class name of `Alert--{type}`. */
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../common/app';
|
||||
import Component from '../Component';
|
||||
import icon from '../helpers/icon';
|
||||
import listItems from '../helpers/listItems';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../common/app';
|
||||
import Modal from './Modal';
|
||||
import Button from './Button';
|
||||
import GroupBadge from './GroupBadge';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../common/app';
|
||||
import Component, { ComponentAttrs } from '../Component';
|
||||
import classList from '../utils/classList';
|
||||
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../common/app';
|
||||
import Component from '../Component';
|
||||
import Button from './Button';
|
||||
import LinkButton from './LinkButton';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../common/app';
|
||||
import Component from '../Component';
|
||||
import PageState from '../states/PageState';
|
||||
|
||||
|
|
|
@ -1,3 +1,5 @@
|
|||
import app from '../../common/app';
|
||||
|
||||
import Component from '../Component';
|
||||
import ItemList from '../utils/ItemList';
|
||||
import listItems from '../helpers/listItems';
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
import * as Mithril from 'mithril';
|
||||
import type Mithril from 'mithril';
|
||||
import User from '../models/User';
|
||||
|
||||
/**
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
import dayjs from 'dayjs';
|
||||
import * as Mithril from 'mithril';
|
||||
import type Mithril from 'mithril';
|
||||
|
||||
/**
|
||||
* The `fullTime` helper displays a formatted time string wrapped in a <time>
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
import * as Mithril from 'mithril';
|
||||
import type Mithril from 'mithril';
|
||||
import { truncate } from '../utils/string';
|
||||
|
||||
/**
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
import dayjs from 'dayjs';
|
||||
import * as Mithril from 'mithril';
|
||||
import type Mithril from 'mithril';
|
||||
import humanTimeUtil from '../utils/humanTime';
|
||||
|
||||
/**
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
import * as Mithril from 'mithril';
|
||||
import type Mithril from 'mithril';
|
||||
|
||||
/**
|
||||
* The `icon` helper displays an icon.
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
import * as Mithril from 'mithril';
|
||||
import type Mithril from 'mithril';
|
||||
import Separator from '../components/Separator';
|
||||
import classList from '../utils/classList';
|
||||
|
||||
|
|
|
@ -1,3 +1,5 @@
|
|||
import app from '../../common/app';
|
||||
|
||||
/**
|
||||
* The `punctuateSeries` helper formats a list of strings (e.g. names) to read
|
||||
* fluently in the application's locale.
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
import * as Mithril from 'mithril';
|
||||
import type Mithril from 'mithril';
|
||||
import User from '../models/User';
|
||||
import icon from './icon';
|
||||
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
import * as Mithril from 'mithril';
|
||||
import app from '../../common/app';
|
||||
import type Mithril from 'mithril';
|
||||
import User from '../models/User';
|
||||
|
||||
/**
|
||||
|
|
|
@ -21,8 +21,9 @@ import patchMithril from './utils/patchMithril';
|
|||
patchMithril(window);
|
||||
|
||||
import * as Extend from './extend/index';
|
||||
import app from './app';
|
||||
|
||||
export { Extend };
|
||||
export { Extend, app };
|
||||
|
||||
import './utils/arrayFlatPolyfill';
|
||||
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../common/app';
|
||||
import Model from '../Model';
|
||||
import computed from '../utils/computed';
|
||||
import ItemList from '../utils/ItemList';
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
import Mithril from 'mithril';
|
||||
import type Mithril from 'mithril';
|
||||
|
||||
/**
|
||||
* Generates a route resolver for a given component.
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
import Mithril from 'mithril';
|
||||
import type Mithril from 'mithril';
|
||||
import Alert, { AlertAttrs } from '../components/Alert';
|
||||
|
||||
/**
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../common/app';
|
||||
import Model from '../Model';
|
||||
|
||||
export interface Page<TModel> {
|
||||
|
|
|
@ -1,3 +1,5 @@
|
|||
import app from '../../common/app';
|
||||
|
||||
/**
|
||||
* The `abbreviateNumber` utility converts a number to a shorter localized form.
|
||||
*
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
import Mithril from 'mithril';
|
||||
import type Mithril from 'mithril';
|
||||
|
||||
/**
|
||||
* Mithril 2 does not completely rerender the page if a route change leads to the same route
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../forum/app';
|
||||
import History from './utils/History';
|
||||
import Pane from './utils/Pane';
|
||||
import DiscussionPage from './components/DiscussionPage';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import Component from '../../common/Component';
|
||||
import avatar from '../../common/helpers/avatar';
|
||||
import icon from '../../common/helpers/icon';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import Modal from '../../common/components/Modal';
|
||||
import Button from '../../common/components/Button';
|
||||
import Stream from '../../common/utils/Stream';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import Modal from '../../common/components/Modal';
|
||||
import Button from '../../common/components/Button';
|
||||
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import Post from './Post';
|
||||
import classList from '../../common/utils/classList';
|
||||
import PostUser from './PostUser';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import Component from '../../common/Component';
|
||||
import ItemList from '../../common/utils/ItemList';
|
||||
import ComposerButton from './ComposerButton';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import ComposerBody from './ComposerBody';
|
||||
import extractText from '../../common/utils/extractText';
|
||||
import Stream from '../../common/utils/Stream';
|
||||
|
|
|
@ -1,9 +1,9 @@
|
|||
import app from '../../forum/app';
|
||||
import Component from '../../common/Component';
|
||||
import DiscussionListItem from './DiscussionListItem';
|
||||
import Button from '../../common/components/Button';
|
||||
import LoadingIndicator from '../../common/components/LoadingIndicator';
|
||||
import Placeholder from '../../common/components/Placeholder';
|
||||
import Discussion from '../../common/models/Discussion';
|
||||
|
||||
/**
|
||||
* The `DiscussionList` component displays a list of discussions.
|
||||
|
@ -15,7 +15,7 @@ import Discussion from '../../common/models/Discussion';
|
|||
export default class DiscussionList extends Component {
|
||||
view() {
|
||||
/**
|
||||
* @type DiscussionListState
|
||||
* @type {import('../states/DiscussionListState').default}
|
||||
*/
|
||||
const state = this.attrs.state;
|
||||
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import Component from '../../common/Component';
|
||||
import Link from '../../common/components/Link';
|
||||
import avatar from '../../common/helpers/avatar';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import DiscussionList from './DiscussionList';
|
||||
import Component from '../../common/Component';
|
||||
import DiscussionPage from './DiscussionPage';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import Page from '../../common/components/Page';
|
||||
import ItemList from '../../common/utils/ItemList';
|
||||
import DiscussionHero from './DiscussionHero';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import Notification from './Notification';
|
||||
|
||||
/**
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import EventPost from './EventPost';
|
||||
import extractText from '../../common/utils/extractText';
|
||||
|
||||
|
|
|
@ -1,8 +1,9 @@
|
|||
import app from '../../forum/app';
|
||||
import highlight from '../../common/helpers/highlight';
|
||||
import LinkButton from '../../common/components/LinkButton';
|
||||
import Link from '../../common/components/Link';
|
||||
import { SearchSource } from './Search';
|
||||
import Mithril from 'mithril';
|
||||
import type Mithril from 'mithril';
|
||||
|
||||
/**
|
||||
* The `DiscussionsSearchSource` finds and displays discussion search results in
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import ComposerBody from './ComposerBody';
|
||||
import Button from '../../common/components/Button';
|
||||
import Link from '../../common/components/Link';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import Post from './Post';
|
||||
import { ucfirst } from '../../common/utils/string';
|
||||
import usernameHelper from '../../common/helpers/username';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import Modal from '../../common/components/Modal';
|
||||
import Button from '../../common/components/Button';
|
||||
import extractText from '../../common/utils/extractText';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import Component from '../../common/Component';
|
||||
import Button from '../../common/components/Button';
|
||||
import LogInModal from './LogInModal';
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
import { extend } from '../../common/extend';
|
||||
import app from '../../forum/app';
|
||||
import Page from '../../common/components/Page';
|
||||
import ItemList from '../../common/utils/ItemList';
|
||||
import listItems from '../../common/helpers/listItems';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import Button from '../../common/components/Button';
|
||||
|
||||
/**
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import Modal from '../../common/components/Modal';
|
||||
import ForgotPasswordModal from './ForgotPasswordModal';
|
||||
import SignUpModal from './SignUpModal';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import Component from '../../common/Component';
|
||||
import avatar from '../../common/helpers/avatar';
|
||||
import icon from '../../common/helpers/icon';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import Component from '../../common/Component';
|
||||
import Checkbox from '../../common/components/Checkbox';
|
||||
import icon from '../../common/helpers/icon';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import Component from '../../common/Component';
|
||||
import listItems from '../../common/helpers/listItems';
|
||||
import Button from '../../common/components/Button';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import Dropdown from '../../common/components/Dropdown';
|
||||
import icon from '../../common/helpers/icon';
|
||||
import classList from '../../common/utils/classList';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import Page from '../../common/components/Page';
|
||||
import NotificationList from './NotificationList';
|
||||
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import Component from '../../common/Component';
|
||||
import SubtreeRetainer from '../../common/utils/SubtreeRetainer';
|
||||
import Dropdown from '../../common/components/Dropdown';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import Component from '../../common/Component';
|
||||
import humanTime from '../../common/utils/humanTime';
|
||||
import Tooltip from '../../common/components/Tooltip';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import Component from '../../common/Component';
|
||||
import humanTime from '../../common/helpers/humanTime';
|
||||
import fullTime from '../../common/helpers/fullTime';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import Component from '../../common/Component';
|
||||
import Link from '../../common/components/Link';
|
||||
import avatar from '../../common/helpers/avatar';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import Component from '../../common/Component';
|
||||
import ScrollListener from '../../common/utils/ScrollListener';
|
||||
import PostLoading from './LoadingPost';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import Component from '../../common/Component';
|
||||
import icon from '../../common/helpers/icon';
|
||||
import formatNumber from '../../common/utils/formatNumber';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import Component from '../../common/Component';
|
||||
import Link from '../../common/components/Link';
|
||||
import UserCard from './UserCard';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import UserPage from './UserPage';
|
||||
import LoadingIndicator from '../../common/components/LoadingIndicator';
|
||||
import Button from '../../common/components/Button';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import Modal from '../../common/components/Modal';
|
||||
import Button from '../../common/components/Button';
|
||||
import Stream from '../../common/utils/Stream';
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import app from '../../forum/app';
|
||||
import ComposerBody from './ComposerBody';
|
||||
import Button from '../../common/components/Button';
|
||||
import Link from '../../common/components/Link';
|
||||
|
|
|
@ -1,5 +1,4 @@
|
|||
/*global s9e*/
|
||||
|
||||
import app from '../../forum/app';
|
||||
import Component from '../../common/Component';
|
||||
import avatar from '../../common/helpers/avatar';
|
||||
import username from '../../common/helpers/username';
|
||||
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user