mirror of
https://github.com/laurent22/joplin.git
synced 2025-01-23 18:53:36 +02:00
99 lines
2.6 KiB
TypeScript
99 lines
2.6 KiB
TypeScript
|
// Stores information about the current content of the user's selection
|
||
|
|
||
|
export default class SelectionFormatting {
|
||
|
public bolded: boolean = false;
|
||
|
public italicized: boolean = false;
|
||
|
public inChecklist: boolean = false;
|
||
|
public inCode: boolean = false;
|
||
|
public inUnorderedList: boolean = false;
|
||
|
public inOrderedList: boolean = false;
|
||
|
public inMath: boolean = false;
|
||
|
public inLink: boolean = false;
|
||
|
public spellChecking: boolean = false;
|
||
|
public unspellCheckableRegion: boolean = false;
|
||
|
|
||
|
// Link data, both fields are null if not in a link.
|
||
|
public linkData: { linkText?: string; linkURL?: string } = {
|
||
|
linkText: null,
|
||
|
linkURL: null,
|
||
|
};
|
||
|
|
||
|
// If [headerLevel], [listLevel], etc. are zero, then the
|
||
|
// selection isn't in a header/list
|
||
|
public headerLevel: number = 0;
|
||
|
public listLevel: number = 0;
|
||
|
|
||
|
// Content of the selection
|
||
|
public selectedText: string = '';
|
||
|
|
||
|
// List of data properties (for serializing/deseralizing)
|
||
|
private static propNames: string[] = [
|
||
|
'bolded', 'italicized', 'inChecklist', 'inCode',
|
||
|
'inUnorderedList', 'inOrderedList', 'inMath',
|
||
|
'inLink', 'linkData',
|
||
|
|
||
|
'headerLevel', 'listLevel',
|
||
|
|
||
|
'selectedText',
|
||
|
|
||
|
'spellChecking',
|
||
|
'unspellCheckableRegion',
|
||
|
];
|
||
|
|
||
|
// Returns true iff [this] is equivalent to [other]
|
||
|
public eq(other: SelectionFormatting): boolean {
|
||
|
// Cast to Records to allow usage of the indexing ([])
|
||
|
// operator.
|
||
|
const selfAsRec = this as Record<string, any>;
|
||
|
const otherAsRec = other as Record<string, any>;
|
||
|
|
||
|
for (const prop of SelectionFormatting.propNames) {
|
||
|
if (selfAsRec[prop] !== otherAsRec[prop]) {
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
public static fromJSON(json: string): SelectionFormatting {
|
||
|
const result = new SelectionFormatting();
|
||
|
|
||
|
// Casting result to a Record<string, any> lets us use
|
||
|
// the indexing [] operator.
|
||
|
const resultRecord = result as Record<string, any>;
|
||
|
const obj = JSON.parse(json) as Record<string, any>;
|
||
|
|
||
|
for (const prop of SelectionFormatting.propNames) {
|
||
|
if (obj[prop] !== undefined) {
|
||
|
// Type checking!
|
||
|
if (typeof obj[prop] !== typeof resultRecord[prop]) {
|
||
|
throw new Error([
|
||
|
'Deserialization Error:',
|
||
|
`${obj[prop]} and ${resultRecord[prop]}`,
|
||
|
'have different types.',
|
||
|
].join(' '));
|
||
|
}
|
||
|
|
||
|
resultRecord[prop] = obj[prop];
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return result;
|
||
|
}
|
||
|
|
||
|
public toJSON(): string {
|
||
|
const resultObj: Record<string, any> = {};
|
||
|
|
||
|
// Cast this to a dictionary. This allows us to use
|
||
|
// the indexing [] operator.
|
||
|
const selfAsRecord = this as Record<string, any>;
|
||
|
|
||
|
for (const prop of SelectionFormatting.propNames) {
|
||
|
resultObj[prop] = selfAsRecord[prop];
|
||
|
}
|
||
|
|
||
|
return JSON.stringify(resultObj);
|
||
|
}
|
||
|
}
|