forked from Ivasoft/mattermost-mobile
* started with the diagrams
* removed redundant tables
next step:
1. reconstruct id ( local id vs server id )
2. annotate fields with examples
3. recreate relationship
* work in progress
* work in progress
* fix association
* update postsInChannel
* removed SlashCommands from the Server database schema
* added missing associations in the models and updated docs/database
* exported server database
* update test
* code corrections following review
* update relationship
* update docs
* removed cyclic relationship
* Revert "removed cyclic relationship"
This reverts commit 4d784efb81.
* removed isOptional from Draft
* linked myChannelSettings to myChannel instead of Channel
* update diagrams
* store null instead of empty string
* update thread association
Co-authored-by: Elias Nahum <nahumhbl@gmail.com>
64 lines
2.6 KiB
TypeScript
64 lines
2.6 KiB
TypeScript
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See LICENSE.txt for license information.
|
|
|
|
import {Relation} from '@nozbe/watermelondb';
|
|
import {field, immutableRelation} from '@nozbe/watermelondb/decorators';
|
|
import Model, {Associations} from '@nozbe/watermelondb/Model';
|
|
|
|
import {MM_TABLES} from '@constants/database';
|
|
import MyChannelSettingsModel from '@typings/database/models/servers/my_channel_settings';
|
|
|
|
import type ChannelModel from '@typings/database/models/servers/channel';
|
|
import type MyChannelModelInterface from '@typings/database/models/servers/my_channel';
|
|
|
|
const {CATEGORY_CHANNEL, CHANNEL, MY_CHANNEL, MY_CHANNEL_SETTINGS} = MM_TABLES.SERVER;
|
|
|
|
/**
|
|
* MyChannel is an extension of the Channel model but it lists only the Channels the app's user belongs to
|
|
*/
|
|
export default class MyChannelModel extends Model implements MyChannelModelInterface {
|
|
/** table (name) : MyChannel */
|
|
static table = MY_CHANNEL;
|
|
|
|
static associations: Associations = {
|
|
[CHANNEL]: {type: 'belongs_to', key: 'id'},
|
|
[CATEGORY_CHANNEL]: {type: 'has_many', foreignKey: 'channel_id'},
|
|
};
|
|
|
|
/** last_post_at : The timestamp for any last post on this channel */
|
|
@field('last_post_at') lastPostAt!: number;
|
|
|
|
/** last_viewed_at : The timestamp showing the user's last viewed post on this channel */
|
|
@field('last_viewed_at') lastViewedAt!: number;
|
|
|
|
/** manually_unread : Determine if the user marked a post as unread */
|
|
@field('manually_unread') manuallyUnread!: boolean;
|
|
|
|
/** message_count : The derived number of unread messages on this channel */
|
|
@field('message_count') messageCount!: number;
|
|
|
|
/** mentions_count : The number of mentions on this channel */
|
|
@field('mentions_count') mentionsCount!: number;
|
|
|
|
/** is_unread : Whether the channel has unread messages */
|
|
@field('is_unread') isUnread!: boolean;
|
|
|
|
/** roles : The user's privileges on this channel */
|
|
@field('roles') roles!: string;
|
|
|
|
/** viewed_at : The timestamp showing when the user's last opened this channel (this is used for the new line message indicator) */
|
|
@field('viewed_at') viewedAt!: number;
|
|
|
|
/** channel : The relation pointing to the CHANNEL table */
|
|
@immutableRelation(CHANNEL, 'id') channel!: Relation<ChannelModel>;
|
|
|
|
/** settings: User specific settings/preferences for this channel */
|
|
@immutableRelation(MY_CHANNEL_SETTINGS, 'id') settings!: Relation<MyChannelSettingsModel>;
|
|
|
|
async destroyPermanently() {
|
|
const settings = await this.settings.fetch();
|
|
settings?.destroyPermanently();
|
|
super.destroyPermanently();
|
|
}
|
|
}
|