mobx-lark 2.6.4 → 2.7.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,5 +1,5 @@
1
1
  import { ListModel, NewData } from 'mobx-restful';
2
- import { ChatMessage, ChatMeta, SendChatMessage } from './type';
2
+ import { ChatMessage, ChatMeta, CreateChatOption, SendChatMessage } from './type';
3
3
  export * from './type';
4
4
  declare const ChatListModel_base: (abstract new (...args: any[]) => {
5
5
  stream?: AsyncGenerator<ChatMeta, void, any> | undefined;
@@ -54,9 +54,10 @@ export declare abstract class ChatListModel extends ChatListModel_base {
54
54
  */
55
55
  openStream(): AsyncGenerator<ChatMeta, void, unknown>;
56
56
  /**
57
- * @see https://open.feishu.cn/document/uAjLw4CM/ukTMukTMukTM/reference/im-v1/chat/create
57
+ * @see {@link https://open.feishu.cn/document/server-docs/group/chat/create}
58
+ * @see {@link https://open.feishu.cn/document/server-docs/group/chat/update-2}
58
59
  */
59
- updateOne({ chat_id }: NewData<ChatMeta>): Promise<ChatMeta>;
60
+ updateOne({ chat_id, ...data }: Partial<NewData<ChatMeta>>, option?: CreateChatOption): Promise<ChatMeta>;
60
61
  }
61
62
  declare const MessageListModel_base: (abstract new (...args: any[]) => {
62
63
  stream?: AsyncGenerator<ChatMessage, void, any> | undefined;
@@ -1,18 +1,31 @@
1
1
  import { TranslationMap } from '../../../type';
2
+ import { UserIdType } from '../../User/type';
2
3
  import { ChatMessageContent } from './message';
3
4
  export * from './message';
4
5
  export type ChatPermission = 'all_members' | 'only_owner' | 'not_anyone';
5
- export interface CreateChatMeta extends Record<'owner_id' | 'avatar' | 'name' | 'description', string>, Record<`${'join' | 'leave'}_message_visibility`, ChatPermission>, Record<`${'user' | 'bot'}_id_list`, string[]> {
6
+ export type ChatManagerPermission = Exclude<ChatPermission, 'not_anyone'>;
7
+ export type ChatMemberPermission = Exclude<ChatPermission, 'only_owner'>;
8
+ export interface RestrictedModeSetting extends Partial<Record<`${'screenshot' | 'download' | 'message'}_has_permission_setting`, ChatMemberPermission>> {
9
+ status?: boolean;
10
+ }
11
+ export interface CreateChatMeta extends Record<'owner_id' | 'avatar' | 'name' | 'description', string>, Record<`${'join' | 'leave'}_message_visibility`, ChatPermission>, Record<`${'user' | 'bot'}_id_list`, string[]>, Record<`${'urgent' | 'video_conference' | 'hide_member_count'}_setting` | 'edit_permission', ChatManagerPermission> {
6
12
  chat_mode: 'group';
7
13
  chat_type: 'private' | 'public';
14
+ group_message_type: 'chat' | 'thread';
8
15
  i18n_names: TranslationMap;
9
- external: boolean;
10
- membership_approval: 'no_approval_required' | 'approval_required';
16
+ membership_approval: `${'no_' | ''}approval_required`;
17
+ restricted_mode_setting: RestrictedModeSetting;
11
18
  }
12
- export interface ChatMeta extends CreateChatMeta, Record<'tenant_key' | 'chat_id', string>, Record<`${'add_member' | 'at_all' | 'edit' | 'moderation'}_permission`, ChatPermission> {
13
- owner_id_type: 'user_id';
14
- chat_tag: 'inner';
15
- share_card_permission: 'allowed';
19
+ export interface CreateChatOption {
20
+ user_id_type?: UserIdType;
21
+ set_bot_manager?: boolean;
22
+ uuid?: string;
23
+ }
24
+ export interface ChatMeta extends CreateChatMeta, Record<'tenant_key' | 'chat_id', string>, Record<`${'add_member' | 'at_all' | 'moderation'}_permission`, ChatPermission> {
25
+ owner_id_type: UserIdType;
26
+ chat_tag: 'inner' | 'tenant' | 'department' | 'edu' | 'meeting' | 'customer_service';
27
+ external: boolean;
28
+ share_card_permission: `${'not_' | ''}allowed`;
16
29
  }
17
30
  export type ChatMessageType = 'text' | 'card';
18
31
  export interface SendChatMessage {
@@ -0,0 +1,70 @@
1
+ import { Filter, IDType, ListModel, NewData } from 'mobx-restful';
2
+ import { MailMessage } from './type';
3
+ export * from './type';
4
+ export type MailMessageFilter = Filter<MailMessage> & {
5
+ folder_id?: string;
6
+ only_unread?: boolean;
7
+ };
8
+ declare const MailMessageModel_base: (abstract new (...args: any[]) => {
9
+ stream?: AsyncGenerator<MailMessage, void, any> | undefined;
10
+ openStream(filter: MailMessageFilter): AsyncGenerator<MailMessage, void, any>;
11
+ clearList(): void;
12
+ clear(): void;
13
+ restoreList({ filter, pageIndex, pageSize, allItems, totalCount }?: Partial<Pick<ListModel<MailMessage, Partial<NewData<MailMessage>>>, "filter" | "pageIndex" | "pageSize" | "allItems" | "totalCount">> | undefined): Promise<void>;
14
+ loadStream(filter: MailMessageFilter, newCount: number): Promise<MailMessage[]>;
15
+ loadPage(pageIndex: number, pageSize: number, filter: MailMessageFilter): Promise<{
16
+ pageData: MailMessage[];
17
+ totalCount: number;
18
+ }>;
19
+ pageIndex: number;
20
+ pageSize: number;
21
+ filter: MailMessageFilter;
22
+ totalCount: number;
23
+ pageList: MailMessage[][];
24
+ readonly currentPage: MailMessage[];
25
+ readonly pageCount: number;
26
+ readonly allItems: MailMessage[];
27
+ readonly noMore: boolean;
28
+ statistic: Partial<Record<import("web-utility").TypeKeys<MailMessage, import("web-utility").IndexKey>, Record<string, number>>>;
29
+ turnTo(pageIndex: number, pageSize?: number): ListModel<MailMessage, MailMessageFilter>;
30
+ loadNewPage(pageIndex: number, pageSize: number, filter: MailMessageFilter): Promise<{
31
+ pageData: MailMessage[];
32
+ totalCount: number;
33
+ }>;
34
+ getList(filter?: MailMessageFilter | undefined, pageIndex?: number, pageSize?: number): Promise<MailMessage[]>;
35
+ refreshList(): Promise<MailMessage[]>;
36
+ getAllInStream(filter?: MailMessageFilter | undefined, pageSize?: number): AsyncGenerator<MailMessage, void, unknown>;
37
+ getAll(filter?: MailMessageFilter | undefined, pageSize?: number): Promise<MailMessage[]>;
38
+ countAll(keys: import("web-utility").TypeKeys<MailMessage, import("web-utility").IndexKey>[], filter?: MailMessageFilter | undefined, pageSize?: number): Promise<Partial<Record<import("web-utility").TypeKeys<MailMessage, import("web-utility").IndexKey>, Record<string, number>>>>;
39
+ indexOf(id: IDType): number;
40
+ changeOne(data: Partial<MailMessage>, id: IDType, patch?: boolean): void;
41
+ updateOne(data: Partial<NewData<MailMessage>>, id?: IDType): Promise<MailMessage>;
42
+ removeOne(id: IDType): Promise<void>;
43
+ deleteOne(id: IDType): Promise<void>;
44
+ client: import("mobx-restful").RESTClient;
45
+ baseURI: string;
46
+ indexKey: "message_id" | "smtp_message_id" | "body_plain_text" | "body_html" | "thread_id" | "internal_date" | "subject" | "to" | "cc" | "bcc" | "dedupe_key" | "message_state" | "head_from" | "raw" | "attachments";
47
+ currentOne: MailMessage;
48
+ clearCurrent(): void;
49
+ getOne(id: IDType): Promise<MailMessage>;
50
+ downloading: number;
51
+ uploading: number;
52
+ [Symbol.asyncIterator]: (filter?: MailMessageFilter | undefined, pageSize?: number) => AsyncGenerator<MailMessage, void, unknown>;
53
+ }) & import("web-utility").AbstractClass<ListModel<MailMessage, MailMessageFilter>>;
54
+ export declare abstract class MailMessageModel extends MailMessageModel_base {
55
+ mailboxId: string;
56
+ baseURI: string;
57
+ constructor(mailboxId: string);
58
+ /**
59
+ * @see {@link https://open.feishu.cn/document/mail-v1/user_mailbox-message/list}
60
+ */
61
+ openStream(filter?: MailMessageFilter): AsyncGenerator<MailMessage, void, unknown>;
62
+ /**
63
+ * @see {@link https://open.feishu.cn/document/mail-v1/user_mailbox-message/get}
64
+ */
65
+ getOne(id: IDType): Promise<MailMessage>;
66
+ /**
67
+ * @see {@link https://open.feishu.cn/document/server-docs/mail-v1/user_mailbox-message/send}
68
+ */
69
+ updateOne(mail: Partial<NewData<MailMessage>>): Promise<MailMessage>;
70
+ }
@@ -0,0 +1,27 @@
1
+ export interface MailAddress {
2
+ mail_address: string;
3
+ name?: string;
4
+ }
5
+ export declare enum MailAttachmentType {
6
+ Normal = 1,
7
+ Large = 2
8
+ }
9
+ export interface MailAttachment {
10
+ attachment_type: MailAttachmentType;
11
+ id: string;
12
+ cid?: string;
13
+ filename: string;
14
+ is_inline: boolean;
15
+ }
16
+ export declare enum MailMessageState {
17
+ Received = 1,
18
+ Sent = 2,
19
+ Draft = 3
20
+ }
21
+ export type MailMessage = Record<`${'smtp_' | ''}message_id` | 'thread_id' | 'internal_date' | 'subject' | `body_${'plain_text' | 'html'}`, string> & Record<'to' | 'cc' | 'bcc', MailAddress[]> & {
22
+ dedupe_key?: string;
23
+ message_state: MailMessageState;
24
+ head_from: MailAddress;
25
+ raw?: string;
26
+ attachments: MailAttachment[];
27
+ };
@@ -1,2 +1,2 @@
1
1
  import { DataObject, RESTClient } from 'mobx-restful';
2
- export declare function createPageStream<T extends DataObject>(client: RESTClient, path: string, onCount: (total: number) => any, filter?: DataObject): AsyncGenerator<T, void, unknown>;
2
+ export declare function createPageStream<T = DataObject>(client: RESTClient, path: string, onCount: (total: number) => any, filter?: DataObject): AsyncGenerator<Awaited<T>, void, unknown>;
@@ -1,6 +1,7 @@
1
1
  export * from './base';
2
2
  export * from './User/type';
3
3
  export * from './InstantMessenger';
4
+ export * from './Mail';
4
5
  export * from './Task';
5
6
  export * from './Document';
6
7
  export * from './SpreadSheet';
package/dist/type.d.ts CHANGED
@@ -8,7 +8,7 @@ export type LarkData<D extends Record<string, any> = {}, E extends Record<string
8
8
  [key: string]: any;
9
9
  };
10
10
  };
11
- export type LarkPageData<D extends Record<string, any> = {}> = LarkData<{
11
+ export type LarkPageData<D = {}> = LarkData<{
12
12
  page_token: string;
13
13
  items: D[];
14
14
  has_more: boolean;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "mobx-lark",
3
- "version": "2.6.4",
3
+ "version": "2.7.0",
4
4
  "license": "LGPL-3.0",
5
5
  "author": "shiy2008@gmail.com",
6
6
  "description": "Unofficial TypeScript SDK for FeiShu/Lark API, which is based on MobX-RESTful.",
@@ -25,8 +25,8 @@
25
25
  "url": "https://github.com/idea2app/MobX-Lark/issues"
26
26
  },
27
27
  "dependencies": {
28
- "@swc/helpers": "^0.5.18",
29
- "@types/react": "^19.2.7",
28
+ "@swc/helpers": "^0.5.19",
29
+ "@types/react": "^19.2.14",
30
30
  "koajax": "^3.1.2",
31
31
  "lodash.memoize": "^4.1.2",
32
32
  "mobx": "^6.15.0",
@@ -38,25 +38,25 @@
38
38
  "react": ">=16"
39
39
  },
40
40
  "devDependencies": {
41
- "@parcel/config-default": "~2.16.3",
42
- "@parcel/transformer-typescript-tsc": "~2.16.3",
41
+ "@parcel/config-default": "~2.16.4",
42
+ "@parcel/transformer-typescript-tsc": "~2.16.4",
43
43
  "@types/fs-extra": "^11.0.4",
44
44
  "@types/lodash.memoize": "^4.1.9",
45
- "@types/node": "^22.19.3",
45
+ "@types/node": "^24.10.13",
46
46
  "@types/react-dom": "^19.2.3",
47
47
  "@types/turndown": "^5.0.6",
48
- "dotenv": "^17.2.3",
48
+ "dotenv": "^17.3.1",
49
49
  "fs-extra": "^11.3.3",
50
50
  "husky": "^9.1.7",
51
51
  "lint-staged": "^16.2.7",
52
- "parcel": "~2.16.3",
53
- "prettier": "^3.7.4",
54
- "react": "^19.2.3",
55
- "react-dom": "^19.2.3",
52
+ "parcel": "~2.16.4",
53
+ "prettier": "^3.8.1",
54
+ "react": "^19.2.4",
55
+ "react-dom": "^19.2.4",
56
56
  "ts-node": "^10.9.2",
57
57
  "turndown": "^7.2.2",
58
- "typedoc": "^0.28.15",
59
- "typedoc-plugin-mdn-links": "^5.0.10",
58
+ "typedoc": "^0.28.17",
59
+ "typedoc-plugin-mdn-links": "^5.1.1",
60
60
  "typescript": "~5.8.3"
61
61
  },
62
62
  "pnpm": {
@@ -3,7 +3,7 @@ import { buildURLData } from 'web-utility';
3
3
 
4
4
  import { LarkData } from '../../type';
5
5
  import { createPageStream } from '../base';
6
- import { ChatMessage, ChatMeta, SendChatMessage } from './type';
6
+ import { ChatMessage, ChatMeta, CreateChatOption, SendChatMessage } from './type';
7
7
 
8
8
  export * from './type';
9
9
 
@@ -22,16 +22,19 @@ export abstract class ChatListModel extends Stream<ChatMeta>(ListModel) {
22
22
  }
23
23
 
24
24
  /**
25
- * @see https://open.feishu.cn/document/uAjLw4CM/ukTMukTMukTM/reference/im-v1/chat/create
25
+ * @see {@link https://open.feishu.cn/document/server-docs/group/chat/create}
26
+ * @see {@link https://open.feishu.cn/document/server-docs/group/chat/update-2}
26
27
  */
27
28
  @toggle('uploading')
28
- async updateOne({ chat_id }: NewData<ChatMeta>) {
29
+ async updateOne(
30
+ { chat_id, ...data }: Partial<NewData<ChatMeta>>,
31
+ option: CreateChatOption = {}
32
+ ) {
29
33
  const { body } = await (chat_id
30
- ? this.client.put<LarkData<ChatMeta>>(`${this.baseURI}/chats/${chat_id}`)
34
+ ? this.client.put<LarkData<ChatMeta>>(`${this.baseURI}/${chat_id}`, data)
31
35
  : this.client.post<LarkData<ChatMeta>>(
32
- `${this.baseURI}/chats?${buildURLData({
33
- set_bot_manager: true
34
- })}`
36
+ `${this.baseURI}?${buildURLData(option)}`,
37
+ data
35
38
  ));
36
39
  return (this.currentOne = body!.data!);
37
40
  }
@@ -1,31 +1,53 @@
1
1
  import { TranslationMap } from '../../../type';
2
+ import { UserIdType } from '../../User/type';
2
3
  import { ChatMessageContent } from './message';
3
4
 
4
5
  export * from './message';
5
6
 
6
7
  export type ChatPermission = 'all_members' | 'only_owner' | 'not_anyone';
7
8
 
9
+ export type ChatManagerPermission = Exclude<ChatPermission, 'not_anyone'>;
10
+
11
+ export type ChatMemberPermission = Exclude<ChatPermission, 'only_owner'>;
12
+
13
+ export interface RestrictedModeSetting extends Partial<
14
+ Record<`${'screenshot' | 'download' | 'message'}_has_permission_setting`, ChatMemberPermission>
15
+ > {
16
+ status?: boolean;
17
+ }
18
+
8
19
  export interface CreateChatMeta
9
- extends Record<'owner_id' | 'avatar' | 'name' | 'description', string>,
20
+ extends
21
+ Record<'owner_id' | 'avatar' | 'name' | 'description', string>,
10
22
  Record<`${'join' | 'leave'}_message_visibility`, ChatPermission>,
11
- Record<`${'user' | 'bot'}_id_list`, string[]> {
23
+ Record<`${'user' | 'bot'}_id_list`, string[]>,
24
+ Record<
25
+ `${'urgent' | 'video_conference' | 'hide_member_count'}_setting` | 'edit_permission',
26
+ ChatManagerPermission
27
+ > {
12
28
  chat_mode: 'group';
13
29
  chat_type: 'private' | 'public';
30
+ group_message_type: 'chat' | 'thread';
14
31
  i18n_names: TranslationMap;
15
- external: boolean;
16
- membership_approval: 'no_approval_required' | 'approval_required';
32
+ membership_approval: `${'no_' | ''}approval_required`;
33
+ restricted_mode_setting: RestrictedModeSetting;
34
+ }
35
+
36
+ export interface CreateChatOption {
37
+ user_id_type?: UserIdType;
38
+ set_bot_manager?: boolean;
39
+ uuid?: string;
17
40
  }
18
41
 
19
42
  export interface ChatMeta
20
- extends CreateChatMeta,
43
+ extends
44
+ CreateChatMeta,
21
45
  Record<'tenant_key' | 'chat_id', string>,
22
- Record<
23
- `${'add_member' | 'at_all' | 'edit' | 'moderation'}_permission`,
24
- ChatPermission
25
- > {
26
- owner_id_type: 'user_id';
27
- chat_tag: 'inner';
28
- share_card_permission: 'allowed';
46
+ Record<`${'add_member' | 'at_all' | 'moderation'}_permission`, ChatPermission> {
47
+ owner_id_type: UserIdType;
48
+ chat_tag: 'inner' | 'tenant' | 'department' | 'edu' | 'meeting' | 'customer_service';
49
+ external: boolean;
50
+ share_card_permission: `${'not_' | ''}allowed`;
29
51
  }
30
52
 
31
53
  export type ChatMessageType = 'text' | 'card';
@@ -45,13 +67,11 @@ export type ChatMetion = Pick<ChatSender, 'id' | 'id_type' | 'tenant_key'> &
45
67
  Record<'key' | 'name', string>;
46
68
 
47
69
  export interface ChatMessage
48
- extends Pick<SendChatMessage, 'msg_type'>,
70
+ extends
71
+ Pick<SendChatMessage, 'msg_type'>,
49
72
  Record<`${'create' | 'update'}_time`, string>,
50
73
  Record<'deleted' | 'updated', boolean>,
51
- Record<
52
- `${'chat' | 'message' | 'upper_message' | 'root' | 'parent'}_id`,
53
- string
54
- > {
74
+ Record<`${'chat' | 'message' | 'upper_message' | 'root' | 'parent'}_id`, string> {
55
75
  sender: ChatSender;
56
76
  mentions: ChatMetion[];
57
77
  body: {
@@ -0,0 +1,57 @@
1
+ import { Filter, IDType, ListModel, NewData, Stream, toggle } from 'mobx-restful';
2
+
3
+ import { LarkData } from '../../type';
4
+ import { createPageStream } from '../base';
5
+ import { MailMessage } from './type';
6
+
7
+ export * from './type';
8
+
9
+ export type MailMessageFilter = Filter<MailMessage> & {
10
+ folder_id?: string;
11
+ only_unread?: boolean;
12
+ };
13
+
14
+ export abstract class MailMessageModel extends Stream<MailMessage, MailMessageFilter>(ListModel) {
15
+ baseURI = '';
16
+
17
+ constructor(public mailboxId: string) {
18
+ super();
19
+ this.baseURI = `mail/v1/user_mailboxes/${mailboxId}/messages`;
20
+ }
21
+
22
+ /**
23
+ * @see {@link https://open.feishu.cn/document/mail-v1/user_mailbox-message/list}
24
+ */
25
+ async *openStream(filter: MailMessageFilter = { folder_id: 'INBOX' }) {
26
+ const stream = createPageStream<string>(
27
+ this.client,
28
+ this.baseURI,
29
+ total => (this.totalCount = total),
30
+ filter
31
+ );
32
+ for await (const message_id of stream) yield this.getOne(message_id);
33
+ }
34
+
35
+ /**
36
+ * @see {@link https://open.feishu.cn/document/mail-v1/user_mailbox-message/get}
37
+ */
38
+ @toggle('downloading')
39
+ async getOne(id: IDType) {
40
+ const { body } = await this.client.get<LarkData<{ message: MailMessage }>>(
41
+ `${this.baseURI}/${id}`
42
+ );
43
+ return (this.currentOne = body!.data!.message);
44
+ }
45
+
46
+ /**
47
+ * @see {@link https://open.feishu.cn/document/server-docs/mail-v1/user_mailbox-message/send}
48
+ */
49
+ @toggle('uploading')
50
+ async updateOne(mail: Partial<NewData<MailMessage>>) {
51
+ const { body } = await this.client.post<
52
+ LarkData<Record<`${'message' | 'thread'}_id`, string>>
53
+ >(`${this.baseURI}/send`, mail);
54
+
55
+ return (this.currentOne = await this.getOne(body!.data!.message_id));
56
+ }
57
+ }
@@ -0,0 +1,39 @@
1
+ export interface MailAddress {
2
+ mail_address: string;
3
+ name?: string;
4
+ }
5
+
6
+ export enum MailAttachmentType {
7
+ Normal = 1,
8
+ Large = 2
9
+ }
10
+
11
+ export interface MailAttachment {
12
+ attachment_type: MailAttachmentType;
13
+ id: string;
14
+ cid?: string;
15
+ filename: string;
16
+ is_inline: boolean;
17
+ }
18
+
19
+ export enum MailMessageState {
20
+ Received = 1,
21
+ Sent = 2,
22
+ Draft = 3
23
+ }
24
+
25
+ export type MailMessage = Record<
26
+ | `${'smtp_' | ''}message_id`
27
+ | 'thread_id'
28
+ | 'internal_date'
29
+ | 'subject'
30
+ | `body_${'plain_text' | 'html'}`,
31
+ string
32
+ > &
33
+ Record<'to' | 'cc' | 'bcc', MailAddress[]> & {
34
+ dedupe_key?: string;
35
+ message_state: MailMessageState;
36
+ head_from: MailAddress;
37
+ raw?: string;
38
+ attachments: MailAttachment[];
39
+ };
@@ -3,7 +3,7 @@ import { buildURLData } from 'web-utility';
3
3
 
4
4
  import { LarkPageData } from '../type';
5
5
 
6
- export async function* createPageStream<T extends DataObject>(
6
+ export async function* createPageStream<T = DataObject>(
7
7
  client: RESTClient,
8
8
  path: string,
9
9
  onCount: (total: number) => any,
@@ -1,6 +1,7 @@
1
1
  export * from './base';
2
2
  export * from './User/type';
3
3
  export * from './InstantMessenger';
4
+ export * from './Mail';
4
5
  export * from './Task';
5
6
  export * from './Document';
6
7
  export * from './SpreadSheet';
package/src/type.ts CHANGED
@@ -10,7 +10,7 @@ export type LarkData<D extends Record<string, any> = {}, E extends Record<string
10
10
  };
11
11
  };
12
12
 
13
- export type LarkPageData<D extends Record<string, any> = {}> = LarkData<{
13
+ export type LarkPageData<D = {}> = LarkData<{
14
14
  page_token: string;
15
15
  items: D[];
16
16
  has_more: boolean;