mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-01 13:14:16 +08:00
149b389508
* Switch to using Typescript instead of Babel * Switch all es6 / jsx file extensions to ts / tsx * Convert Utils to a TS module from module.exports style module * Move everything from module.exports to typescript exports * Define .d.ts files for mailspring-exports and component kit… Yes it seems this is the best option :( * Load up on those @types * Synthesize TS types from PropTypes for standard components * Add types to Model classes and move constructor constants to instance vars * 9800 => 7700 TS errors * 7700 => 5600 TS errors * 5600 => 5330 TS errors * 5330 => 4866 TS errors * 4866 => 4426 TS errors * 4426 => 2411 TS errors * 2411 > 1598 TS errors * 1598 > 769 TS errors * 769 > 129 TS errors * 129 > 22 TS errors * Fix runtime errors * More runtime error fixes * Remove support for custom .es6 file extension * Remove a few odd remaining references to Nylas * Don’t ship Typescript support in the compiled app for now * Fix issues in compiled app - module resolution in TS is case sensitive? * README updates * Fix a few more TS errors * Make “No Signature” option clickable + selectable * Remove flicker when saving file and reloading keymaps * Fix mail rule item height in preferences * Fix missing spacing in thread sharing popover * Fix scrollbar ticks being nested incorrectly * Add Japanese as a manually reviewed language * Prevent the thread list from “sticking” * Re-use Sheet when switching root tabs, prevent sidebar from resetting * Ensure specs run * Update package configuration to avoid shpping types * Turn eslint back on - we will opt-in to the TS rules one by one
144 lines
3.2 KiB
TypeScript
144 lines
3.2 KiB
TypeScript
/*
|
|
* decaffeinate suggestions:
|
|
* DS102: Remove unnecessary code created because of implicit returns
|
|
* Full docs: https://github.com/decaffeinate/decaffeinate/blob/master/docs/suggestions.md
|
|
*/
|
|
import { Model } from '../../src/flux/models/model';
|
|
import { Category } from '../../src/flux/models/category';
|
|
import Attributes from '../../src/flux/attributes';
|
|
|
|
class TestModel extends Model {
|
|
static attributes = {
|
|
id: Attributes.String({
|
|
queryable: true,
|
|
modelKey: 'id',
|
|
}),
|
|
|
|
clientId: Attributes.String({
|
|
queryable: true,
|
|
modelKey: 'clientId',
|
|
jsonKey: 'client_id',
|
|
}),
|
|
|
|
serverId: Attributes.String({
|
|
queryable: true,
|
|
modelKey: 'serverId',
|
|
jsonKey: 'server_id',
|
|
}),
|
|
};
|
|
}
|
|
|
|
TestModel.configureBasic = () =>
|
|
(TestModel.attributes = {
|
|
id: Attributes.String({
|
|
queryable: true,
|
|
modelKey: 'id',
|
|
}),
|
|
clientId: Attributes.String({
|
|
queryable: true,
|
|
modelKey: 'clientId',
|
|
jsonKey: 'client_id',
|
|
}),
|
|
serverId: Attributes.String({
|
|
queryable: true,
|
|
modelKey: 'serverId',
|
|
jsonKey: 'server_id',
|
|
}),
|
|
});
|
|
|
|
TestModel.configureWithAllAttributes = () =>
|
|
(TestModel.attributes = {
|
|
datetime: Attributes.DateTime({
|
|
queryable: true,
|
|
modelKey: 'datetime',
|
|
}),
|
|
string: Attributes.String({
|
|
queryable: true,
|
|
modelKey: 'string',
|
|
jsonKey: 'string-json-key',
|
|
}),
|
|
boolean: Attributes.Boolean({
|
|
queryable: true,
|
|
modelKey: 'boolean',
|
|
}),
|
|
number: Attributes.Number({
|
|
queryable: true,
|
|
modelKey: 'number',
|
|
}),
|
|
other: Attributes.String({
|
|
modelKey: 'other',
|
|
}),
|
|
});
|
|
|
|
TestModel.configureWithCollectionAttribute = () =>
|
|
(TestModel.attributes = {
|
|
id: Attributes.String({
|
|
queryable: true,
|
|
modelKey: 'id',
|
|
}),
|
|
clientId: Attributes.String({
|
|
queryable: true,
|
|
modelKey: 'clientId',
|
|
jsonKey: 'client_id',
|
|
}),
|
|
serverId: Attributes.String({
|
|
queryable: true,
|
|
modelKey: 'serverId',
|
|
jsonKey: 'server_id',
|
|
}),
|
|
other: Attributes.String({
|
|
queryable: true,
|
|
modelKey: 'other',
|
|
}),
|
|
categories: Attributes.Collection({
|
|
queryable: true,
|
|
modelKey: 'categories',
|
|
itemClass: Category,
|
|
joinOnField: 'id',
|
|
joinQueryableBy: ['other'],
|
|
}),
|
|
});
|
|
|
|
TestModel.configureWithJoinedDataAttribute = function() {
|
|
TestModel.attributes = {
|
|
id: Attributes.String({
|
|
queryable: true,
|
|
modelKey: 'id',
|
|
}),
|
|
clientId: Attributes.String({
|
|
queryable: true,
|
|
modelKey: 'clientId',
|
|
jsonKey: 'client_id',
|
|
}),
|
|
serverId: Attributes.String({
|
|
queryable: true,
|
|
modelKey: 'serverId',
|
|
jsonKey: 'server_id',
|
|
}),
|
|
body: Attributes.JoinedData({
|
|
modelTable: 'TestModelBody',
|
|
modelKey: 'body',
|
|
}),
|
|
};
|
|
|
|
TestModel.attributes = {
|
|
id: Attributes.String({
|
|
queryable: true,
|
|
modelKey: 'id',
|
|
}),
|
|
clientId: Attributes.String({
|
|
modelKey: 'clientId',
|
|
jsonKey: 'client_id',
|
|
}),
|
|
serverId: Attributes.String({
|
|
modelKey: 'serverId',
|
|
jsonKey: 'server_id',
|
|
}),
|
|
body: Attributes.JoinedData({
|
|
modelTable: 'TestModelBody',
|
|
modelKey: 'body',
|
|
}),
|
|
};
|
|
};
|
|
|
|
export default TestModel;
|