Skip to content

Commit

Permalink
chore: types
Browse files Browse the repository at this point in the history
  • Loading branch information
anncwb committed Mar 26, 2021
1 parent 5b4a41c commit a98835e
Show file tree
Hide file tree
Showing 15 changed files with 122 additions and 255 deletions.
127 changes: 0 additions & 127 deletions src/components/Form/src/components/ApiSelect copy.vue

This file was deleted.

2 changes: 1 addition & 1 deletion src/components/Scrollbar/src/bar.ts
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ export default defineComponent({
const bar = computed(() => {
return BAR_MAP[props.vertical ? 'vertical' : 'horizontal'];
});
const barStore = ref<Indexable>({});
const barStore = ref<Recordable>({});
const cursorDown = ref<any>(null);
const clickThumbHandler = (e: any) => {
// prevent click event of right button
Expand Down
2 changes: 1 addition & 1 deletion src/components/Table/src/components/editable/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ export function renderEditCell(column: BasicColumn) {
};
}

export type EditRecordRow<T = Hash<any>> = Partial<
export type EditRecordRow<T = Recordable> = Partial<
{
onEdit: (editable: boolean, submit?: boolean) => Promise<boolean>;
editable: boolean;
Expand Down
2 changes: 1 addition & 1 deletion src/components/Table/src/types/table.ts
Original file line number Diff line number Diff line change
Expand Up @@ -402,7 +402,7 @@ export interface BasicColumn extends ColumnProps {
flag?: 'INDEX' | 'DEFAULT' | 'CHECKBOX' | 'RADIO' | 'ACTION';
customTitle?: VueNode;

slots?: Indexable;
slots?: Recordable;

// Whether to hide the column by default, it can be displayed in the column configuration
defaultHidden?: boolean;
Expand Down
2 changes: 1 addition & 1 deletion src/directives/ripple/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -181,7 +181,7 @@ function rippler({
};
}

function setProps(modifiers: Hash<any>, props: Recordable) {
function setProps(modifiers: Recordable, props: Recordable) {
modifiers.forEach((item: Recordable) => {
if (isNaN(Number(item))) props.event = item;
else props.transition = item;
Expand Down
2 changes: 1 addition & 1 deletion src/hooks/component/useFormItem.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import { reactive, readonly, computed, getCurrentInstance, watchEffect } from 'v

import { isEqual } from 'lodash-es';

export function useRuleFormItem<T extends Indexable>(
export function useRuleFormItem<T extends Recordable>(
props: T,
key: keyof T = 'value',
changeEvent = 'change'
Expand Down
2 changes: 1 addition & 1 deletion src/layouts/page/transition.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import type { FunctionalComponent } from 'vue';
import type { RouteLocation } from 'vue-router';

export interface DefaultContext {
Component: FunctionalComponent & { type: Indexable };
Component: FunctionalComponent & { type: Recordable };
route: RouteLocation;
}

Expand Down
2 changes: 1 addition & 1 deletion src/router/guard/permissionGuard.ts
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ export function createPermissionGuard(router: Router) {
return;
}
// redirect login page
const redirectData: { path: string; replace: boolean; query?: Indexable<string> } = {
const redirectData: { path: string; replace: boolean; query?: Recordable<string> } = {
path: LOGIN_PATH,
replace: true,
};
Expand Down
2 changes: 1 addition & 1 deletion src/utils/http/axios/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ export interface Result<T = any> {
// multipart/form-data: upload file
export interface UploadFileParams {
// Other parameters
data?: Indexable;
data?: Recordable;
// File parameter interface field name
name?: string;
// file name
Expand Down
170 changes: 82 additions & 88 deletions types/global.d.ts
Original file line number Diff line number Diff line change
@@ -1,91 +1,85 @@
declare interface Fn<T = any, R = T> {
(...arg: T[]): R;
import type {
App,
ComponentRenderProxy,
VNode,
ComponentPublicInstance,
FunctionalComponent,
} from 'vue';
declare global {
declare interface Window {
// Global vue app instance
__APP__: App<Element>;
}

export type Writable<T> = {
-readonly [P in keyof T]: T[P];
};

declare type Nullable<T> = T | null;
declare type NonNullable<T> = T extends null | undefined ? never : T;
declare type Recordable<T = any> = Record<string, T>;
declare type ReadonlyRecordable<T = any> = {
readonly [key: string]: T;
};
declare type Indexable<T = any> = {
[key: string]: T;
};
declare type DeepPartial<T> = {
[P in keyof T]?: DeepPartial<T[P]>;
};
declare type TimeoutHandle = ReturnType<typeof setTimeout>;
declare type IntervalHandle = ReturnType<typeof setInterval>;

declare interface ChangeEvent extends Event {
target: HTMLInputElement;
}

declare interface WheelEvent {
path?: EventTarget[];
}
interface ImportMetaEnv extends ViteEnv {
__: unknown;
}

declare interface ViteEnv {
VITE_PORT: number;
VITE_USE_MOCK: boolean;
VITE_USE_PWA: boolean;
VITE_PUBLIC_PATH: string;
VITE_PROXY: [string, string][];
VITE_GLOB_APP_TITLE: string;
VITE_GLOB_APP_SHORT_NAME: string;
VITE_USE_CDN: boolean;
VITE_DROP_CONSOLE: boolean;
VITE_BUILD_COMPRESS: 'gzip' | 'brotli' | 'none';
VITE_LEGACY: boolean;
VITE_USE_IMAGEMIN: boolean;
VITE_GENERATE_UI: string;
}

declare function parseInt(s: string | number, radix?: number): number;

declare function parseFloat(string: string | number): number;

namespace JSX {
// tslint:disable no-empty-interface
type Element = VNode;
// tslint:disable no-empty-interface
type ElementClass = ComponentRenderProxy;
interface ElementAttributesProperty {
$props: any;
}
interface IntrinsicElements {
[elem: string]: any;
}
interface IntrinsicAttributes {
[elem: string]: any;
}
}
}

declare interface PromiseFn<T = any, R = T> {
(...arg: T[]): Promise<R>;
}

declare interface IObj<T = any> {
[key: string]: T;
[key: number]: T;
}

declare function parseInt(s: string | number, radix?: number): number;

declare function parseFloat(string: string | number): number;

declare type Nullable<T> = T | null;

declare type NonNullable<T> = T extends null | undefined ? never : T;

declare type RefType<T> = T | null;

declare type CustomizedHTMLElement<T> = HTMLElement & T;

declare type Indexable<T extends any = any> = {
[key: string]: T;
};

declare type Recordable<T extends any = any> = Record<string, T>;

declare type ReadonlyRecordable<T extends any = any> = {
readonly [key: string]: T;
};

declare type Hash<T> = Indexable<T>;

declare type DeepPartial<T> = {
[P in keyof T]?: DeepPartial<T[P]>;
};

declare type LabelValueOptions = {
label: string;
value: any;
}[];

declare type EmitType = (event: string, ...args: any[]) => void;

declare type TargetContext = '_self' | '_blank';

declare type TimeoutHandle = ReturnType<typeof setTimeout>;

declare type IntervalHandle = ReturnType<typeof setInterval>;

declare interface ComponentElRef<T extends HTMLElement = HTMLDivElement> {
$el: T;
}

declare type ComponentRef<T extends HTMLElement = HTMLDivElement> = ComponentElRef<T> | null;

declare type ElRef<T extends HTMLElement = HTMLDivElement> = Nullable<T>;

type IsSame<A, B> = A | B extends A & B ? true : false;

declare interface ChangeEvent extends Event {
target: HTMLInputElement;
}

declare interface WheelEvent {
path?: EventTarget[];
}

interface ImportMetaEnv extends ViteEnv {
__: unknown;
}

declare interface ViteEnv {
VITE_PORT: number;
VITE_USE_MOCK: boolean;
VITE_USE_PWA: boolean;
VITE_PUBLIC_PATH: string;
VITE_PROXY: [string, string][];
VITE_GLOB_APP_TITLE: string;
VITE_GLOB_APP_SHORT_NAME: string;
VITE_USE_CDN: boolean;
VITE_DROP_CONSOLE: boolean;
VITE_BUILD_COMPRESS: 'gzip' | 'brotli' | 'none';
VITE_LEGACY: boolean;
VITE_USE_IMAGEMIN: boolean;
VITE_GENERATE_UI: string;
declare module 'vue' {
export type JSXComponent<Props = any> =
| { new (): ComponentPublicInstance<Props> }
| FunctionalComponent<Props>;
}
Loading

0 comments on commit a98835e

Please sign in to comment.