mirror of
				https://codeberg.org/yeentown/barkey.git
				synced 2025-10-25 02:34:51 +00:00 
			
		
		
		
	* wip
* wip
* wip
* wip
* wip
* wip
* Update types.ts
* Create 1742203321812-chat.js
* wip
* wip
* Update room.vue
* Update home.vue
* Update home.vue
* Update ja-JP.yml
* Update index.d.ts
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* Update CHANGELOG.md
* wip
* Update home.vue
* clean up
* Update misskey-js.api.md
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* lint fixes
* lint
* Update UserEntityService.ts
* search
* wip
* 🎨
* wip
* Update home.ownedRooms.vue
* wip
* Update CHANGELOG.md
* Update style.scss
* wip
* improve performance
* improve performance
* Update timeline.test.ts
		
	
			
		
			
				
	
	
		
			85 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			85 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| /*
 | |
|  * SPDX-FileCopyrightText: syuilo and misskey-project
 | |
|  * SPDX-License-Identifier: AGPL-3.0-only
 | |
|  */
 | |
| 
 | |
| import { PrimaryColumn, Entity, Index, JoinColumn, Column, ManyToOne } from 'typeorm';
 | |
| import { id } from './util/id.js';
 | |
| import { MiUser } from './User.js';
 | |
| import { MiDriveFile } from './DriveFile.js';
 | |
| import { MiChatRoom } from './ChatRoom.js';
 | |
| 
 | |
| @Entity('chat_message')
 | |
| export class MiChatMessage {
 | |
| 	@PrimaryColumn(id())
 | |
| 	public id: string;
 | |
| 
 | |
| 	@Index()
 | |
| 	@Column({
 | |
| 		...id(),
 | |
| 	})
 | |
| 	public fromUserId: MiUser['id'];
 | |
| 
 | |
| 	@ManyToOne(type => MiUser, {
 | |
| 		onDelete: 'CASCADE',
 | |
| 	})
 | |
| 	@JoinColumn()
 | |
| 	public fromUser: MiUser | null;
 | |
| 
 | |
| 	@Index()
 | |
| 	@Column({
 | |
| 		...id(), nullable: true,
 | |
| 	})
 | |
| 	public toUserId: MiUser['id'] | null;
 | |
| 
 | |
| 	@ManyToOne(type => MiUser, {
 | |
| 		onDelete: 'CASCADE',
 | |
| 	})
 | |
| 	@JoinColumn()
 | |
| 	public toUser: MiUser | null;
 | |
| 
 | |
| 	@Index()
 | |
| 	@Column({
 | |
| 		...id(), nullable: true,
 | |
| 	})
 | |
| 	public toRoomId: MiChatRoom['id'] | null;
 | |
| 
 | |
| 	@ManyToOne(type => MiChatRoom, {
 | |
| 		onDelete: 'CASCADE',
 | |
| 	})
 | |
| 	@JoinColumn()
 | |
| 	public toRoom: MiChatRoom | null;
 | |
| 
 | |
| 	@Column('varchar', {
 | |
| 		length: 4096, nullable: true,
 | |
| 	})
 | |
| 	public text: string | null;
 | |
| 
 | |
| 	@Column('varchar', {
 | |
| 		length: 512, nullable: true,
 | |
| 	})
 | |
| 	public uri: string | null;
 | |
| 
 | |
| 	@Column({
 | |
| 		...id(),
 | |
| 		array: true, default: '{}',
 | |
| 	})
 | |
| 	public reads: MiUser['id'][];
 | |
| 
 | |
| 	@Column({
 | |
| 		...id(),
 | |
| 		nullable: true,
 | |
| 	})
 | |
| 	public fileId: MiDriveFile['id'] | null;
 | |
| 
 | |
| 	@ManyToOne(type => MiDriveFile, {
 | |
| 		onDelete: 'SET NULL',
 | |
| 	})
 | |
| 	@JoinColumn()
 | |
| 	public file: MiDriveFile | null;
 | |
| 
 | |
| 	@Column('varchar', {
 | |
| 		length: 1024, array: true, default: '{}',
 | |
| 	})
 | |
| 	public reactions: string[];
 | |
| }
 |