Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

refactor(sheets-ui): cell-editor & formula-editor #4209

Open
wants to merge 57 commits into
base: dev
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
57 commits
Select commit Hold shift + click to select a range
9e0d7dc
fix: SelectionMoveType default to be ONLY_SET
lumixraku Nov 27, 2024
a03a347
fix: move range should add SelectionMoveType.move_end
lumixraku Nov 27, 2024
cb285cf
fix: playwright prompt undefined
lumixraku Nov 27, 2024
98a78e0
feat: update
weird94 Nov 27, 2024
0a9b30d
fix: rename
lumixraku Nov 27, 2024
c96e249
fix: add a comma after selection would change sheetId !!!
lumixraku Nov 28, 2024
19aba7a
feat: update
weird94 Nov 28, 2024
a09e679
feat: update
weird94 Nov 28, 2024
c0d1029
feat: update
weird94 Nov 28, 2024
5625f1a
Merge remote-tracking branch 'origin/dev' into refactor/cell-editor-1125
weird94 Nov 28, 2024
35b697d
Merge remote-tracking branch 'origin/fix/selection-expand-with-shift'…
weird94 Nov 28, 2024
2f3d44f
feat: update
weird94 Nov 28, 2024
dcc3def
feat: update
weird94 Nov 28, 2024
8ea49fa
feat: update
weird94 Nov 29, 2024
f96a3b1
feat: update
weird94 Nov 29, 2024
1e9ce8c
feat: update
weird94 Nov 29, 2024
c9b9e21
feat: update
weird94 Nov 29, 2024
ee807ea
feat: update
weird94 Nov 29, 2024
50ff8d9
feat: update
weird94 Nov 29, 2024
0b8b591
feat: update
weird94 Nov 30, 2024
c64296e
feat: update
weird94 Nov 30, 2024
af86125
feat: update
weird94 Nov 30, 2024
d78902c
feat: update
weird94 Nov 30, 2024
0b7cfdc
feat: update
weird94 Nov 30, 2024
dfd394a
feat: update
weird94 Nov 30, 2024
60f1311
feat: update
weird94 Nov 30, 2024
a4bcc4d
feat: update
weird94 Nov 30, 2024
9e7c359
feat: update
weird94 Dec 2, 2024
0cf2959
feat: update
weird94 Dec 2, 2024
1a92b30
feat: update
weird94 Dec 2, 2024
5c65608
feat: update
weird94 Dec 2, 2024
5834818
feat: update
weird94 Dec 2, 2024
32f3d27
feat: update
weird94 Dec 2, 2024
fa2f8f3
feat: update
weird94 Dec 2, 2024
e58e8e5
Merge remote-tracking branch 'origin/dev' into refactor/cell-editor-1125
weird94 Dec 2, 2024
84cc13f
chore(snapshots): update snapshots
actions-user Dec 2, 2024
6e1f1d6
feat: update
weird94 Dec 2, 2024
b12bc92
Merge branch 'refactor/cell-editor-1125' of github.com:dream-num/univ…
weird94 Dec 2, 2024
88efb89
feat: update
weird94 Dec 2, 2024
e27eb81
feat: update
weird94 Dec 2, 2024
fbfa9d0
feat: update
weird94 Dec 2, 2024
b700251
feat: update
weird94 Dec 3, 2024
a84f0f7
Merge branch dev into refactor/cell-editor-1125
weird94 Dec 3, 2024
9093fcd
chore(snapshots): update snapshots
actions-user Dec 3, 2024
cc4a146
Merge remote-tracking branch 'origin/dev' into refactor/cell-editor-1125
weird94 Dec 3, 2024
47967ae
feat: update
weird94 Dec 3, 2024
06687cb
feat: update
weird94 Dec 3, 2024
3f92f36
feat: update
weird94 Dec 3, 2024
eeebad6
feat: update
weird94 Dec 3, 2024
3cf1c55
feat: update
weird94 Dec 3, 2024
a4c136f
feat: update
weird94 Dec 4, 2024
5b5716a
feat: update
weird94 Dec 4, 2024
bd7dbb7
Merge branch 'dev' into refactor/cell-editor-1125
weird94 Dec 11, 2024
3583755
Merge branch 'dev' into refactor/cell-editor-1125
weird94 Dec 11, 2024
2f94d88
fix: https://github.com/dream-num/univer-pro/issues/3752
weird94 Dec 11, 2024
ce24c06
feat: update
weird94 Dec 11, 2024
9ef9f63
feat: update
weird94 Dec 11, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
17 changes: 10 additions & 7 deletions packages/core/src/docs/data-model/document-data-model.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,13 +14,6 @@
* limitations under the License.
*/

import { BehaviorSubject } from 'rxjs';
import { UnitModel, UniverInstanceType } from '../../common/unit';
import { Tools } from '../../shared/tools';
import { getEmptySnapshot } from './empty-snapshot';
import { JSONX } from './json-x/json-x';
import { PRESET_LIST_TYPE } from './preset-list-type';
import { getBodySlice, SliceBodyType } from './text-x/utils';
import type { Nullable } from '../../shared';
import type {
IDocumentBody,
Expand All @@ -32,6 +25,13 @@ import type {
} from '../../types/interfaces/i-document-data';
import type { IPaddingData } from '../../types/interfaces/i-style-data';
import type { JSONXActions } from './json-x/json-x';
import { BehaviorSubject } from 'rxjs';
import { UnitModel, UniverInstanceType } from '../../common/unit';
import { Tools } from '../../shared/tools';
import { getEmptySnapshot } from './empty-snapshot';
import { JSONX } from './json-x/json-x';
import { PRESET_LIST_TYPE } from './preset-list-type';
import { getBodySlice, SliceBodyType } from './text-x/utils';

export const DEFAULT_DOC = {
id: 'default_doc',
Expand Down Expand Up @@ -228,6 +228,7 @@ export class DocumentDataModel extends DocumentDataModelSimple {
headerModelMap: Map<string, DocumentDataModel> = new Map();

footerModelMap: Map<string, DocumentDataModel> = new Map();
change$ = new BehaviorSubject<number>(0);

constructor(snapshot: Partial<IDocumentData>) {
super(Tools.isEmptyObject(snapshot) ? getEmptySnapshot() : snapshot);
Expand Down Expand Up @@ -281,6 +282,7 @@ export class DocumentDataModel extends DocumentDataModelSimple {

this.snapshot = { ...DEFAULT_DOC, ...snapshot };
this._initializeHeaderFooterModel();
this.change$.next(this.change$.value + 1);
}

getSelfOrHeaderFooterModel(segmentId?: string) {
Expand Down Expand Up @@ -315,6 +317,7 @@ export class DocumentDataModel extends DocumentDataModelSimple {
this._initializeHeaderFooterModel();
}

this.change$.next(this.change$.value + 1);
return this.snapshot;
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ import { addDrawing } from './drawings';
import { changeParagraphBulletNestLevel, setParagraphBullet, switchParagraphBullet, toggleChecklistParagraph } from './paragraph';
import { fromPlainText, getPlainText, isEmptyDocument } from './parse';
import { isSegmentIntersects, makeSelection, normalizeSelection } from './selection';
import { addCustomRangeTextX, deleteCustomRangeTextX, deleteSelectionTextX, replaceSelectionTextX } from './text-x-utils';
import { addCustomRangeTextX, deleteCustomRangeTextX, deleteSelectionTextX, replaceSelectionTextRuns, replaceSelectionTextX } from './text-x-utils';

export class BuildTextUtils {
static customRange = {
Expand All @@ -41,6 +41,7 @@ export class BuildTextUtils {
makeSelection,
normalizeSelection,
delete: deleteSelectionTextX,
replaceTextRuns: replaceSelectionTextRuns,
};

static range = {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,15 +16,15 @@

import type { IAccessor } from '@wendellhu/redi';
import type { ITextRange, ITextRangeParam } from '../../../../sheets/typedef';
import type { CustomRangeType, IDocumentBody } from '../../../../types/interfaces';
import type { CustomRangeType, IDocumentBody, ITextRun } from '../../../../types/interfaces';
import type { DocumentDataModel } from '../../document-data-model';
import type { TextXAction } from '../action-types';
import type { TextXSelection } from '../text-x';
import { type Nullable, UpdateDocsAttributeType } from '../../../../shared';
import { textDiff } from '../../../../shared/text-diff';
import { TextXActionType } from '../action-types';
import { TextX } from '../text-x';
import { getBodySlice } from '../utils';
import { getBodySlice, getTextRunSlice } from '../utils';
import { excludePointsFromRange, getIntersectingCustomRanges, getSelectionForAddCustomRange } from './custom-range';

export interface IDeleteCustomRangeParam {
Expand Down Expand Up @@ -301,3 +301,73 @@ export const replaceSelectionTextX = (params: IReplaceSelectionTextXParams) => {
textX.push(...actions);
return textX;
};

function isTextRunsEqual(textRuns: ITextRun[] | undefined, oldTextRuns: ITextRun[] | undefined) {
if (textRuns?.length === oldTextRuns?.length && textRuns?.every((textRun, index) => JSON.stringify(textRun) === JSON.stringify(oldTextRuns?.[index]))) {
return true;
}

return false;
}

export const replaceSelectionTextRuns = (params: IReplaceSelectionTextXParams) => {
const { selection, body: insertBody, doc } = params;
const segmentId = selection.segmentId;
const body = doc.getSelfOrHeaderFooterModel(segmentId)?.getBody();
if (!body) return false;

const oldBody = selection.collapsed ? null : getBodySlice(body, selection.startOffset, selection.endOffset);
const diffs = textDiff(oldBody ? oldBody.dataStream : '', insertBody.dataStream);
let cursor = 0;
const actions = diffs.map(([type, text]) => {
switch (type) {
// retain
case 0: {
const textRunsSlice = getTextRunSlice(insertBody, cursor, cursor + text.length, false);
const oldTextRunsSlice = getTextRunSlice(oldBody!, cursor, cursor + text.length, false);
const action: TextXAction = {
t: TextXActionType.RETAIN,
body: isTextRunsEqual(textRunsSlice, oldTextRunsSlice)
? undefined
: {
textRuns: textRunsSlice,
dataStream: '',
},
len: text.length,
};
cursor += text.length;
return action;
}
// insert
case 1: {
const action: TextXAction = {
t: TextXActionType.INSERT,
body: getBodySlice(insertBody, cursor, cursor + text.length),
len: text.length,
};
cursor += text.length;
return action;
}
// delete
default: {
const action: TextXAction = {
t: TextXActionType.DELETE,
len: text.length,
};
return action;
}
}
});

if (actions.every((action) => action.t === TextXActionType.RETAIN && !action.body)) {
return false;
}

const textX = new TextX();
textX.push({
t: TextXActionType.RETAIN,
len: selection.startOffset,
});
textX.push(...actions);
return textX;
};
113 changes: 78 additions & 35 deletions packages/core/src/docs/data-model/text-x/utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -26,19 +26,13 @@ export enum SliceBodyType {
cut,
}

// eslint-disable-next-line max-lines-per-function, complexity
export function getBodySlice(
export function getTextRunSlice(
body: IDocumentBody,
startOffset: number,
endOffset: number,
returnEmptyArray = true,
type = SliceBodyType.cut
): IDocumentBody {
const { dataStream, textRuns, paragraphs = [], customBlocks = [], tables = [], sectionBreaks = [] } = body;

const docBody: IDocumentBody = {
dataStream: dataStream.slice(startOffset, endOffset),
};
returnEmptyTextRuns = true
) {
const { textRuns } = body;

if (textRuns) {
const newTextRuns: ITextRun[] = [];
Expand Down Expand Up @@ -66,7 +60,7 @@ export function getBodySlice(
}
}

docBody.textRuns = normalizeTextRuns(
return normalizeTextRuns(
newTextRuns.map((tr) => {
const { st, ed } = tr;
return {
Expand All @@ -76,18 +70,24 @@ export function getBodySlice(
};
})
);
} else if (returnEmptyArray) {
} else if (returnEmptyTextRuns) {
// In the case of no style before, add the style, removeTextRuns will be empty,
// in this case, you need to add an empty textRun for undo.
docBody.textRuns = [{
return [{
st: 0,
ed: endOffset - startOffset,
ts: {},
}];
}
}

export function getTableSlice(
body: IDocumentBody,
startOffset: number,
endOffset: number
) {
const { tables = [] } = body;
const newTables = [];

for (const table of tables) {
const clonedTable = Tools.deepClone(table);
const { startIndex, endIndex } = clonedTable;
Expand All @@ -100,11 +100,15 @@ export function getBodySlice(
});
}
}
return newTables;
}

if (newTables.length) {
docBody.tables = newTables;
}

export function getParagraphsSlice(
body: IDocumentBody,
startOffset: number,
endOffset: number
) {
const { paragraphs = [] } = body;
const newParagraphs: IParagraph[] = [];

for (const paragraph of paragraphs) {
Expand All @@ -115,12 +119,19 @@ export function getBodySlice(
}

if (newParagraphs.length) {
docBody.paragraphs = newParagraphs.map((p) => ({
return newParagraphs.map((p) => ({
...p,
startIndex: p.startIndex - startOffset,
}));
}
}

export function getSectionBreakSlice(
body: IDocumentBody,
startOffset: number,
endOffset: number
) {
const { sectionBreaks = [] } = body;
const newSectionBreaks: ISectionBreak[] = [];

for (const sectionBreak of sectionBreaks) {
Expand All @@ -131,11 +142,57 @@ export function getBodySlice(
}

if (newSectionBreaks.length) {
docBody.sectionBreaks = newSectionBreaks.map((sb) => ({
return newSectionBreaks.map((sb) => ({
...sb,
startIndex: sb.startIndex - startOffset,
}));
}
}

export function getCustomBlockSlice(
body: IDocumentBody,
startOffset: number,
endOffset: number
) {
const { customBlocks = [] } = body;
const newCustomBlocks: ICustomBlock[] = [];

for (const block of customBlocks) {
const { startIndex } = block;
if (startIndex >= startOffset && startIndex <= endOffset) {
newCustomBlocks.push(Tools.deepClone(block));
}
}

if (newCustomBlocks.length) {
return newCustomBlocks.map((b) => ({
...b,
startIndex: b.startIndex - startOffset,
}));
}
}

export function getBodySlice(
body: IDocumentBody,
startOffset: number,
endOffset: number,
returnEmptyArray = true,
type = SliceBodyType.cut
): IDocumentBody {
const { dataStream } = body;

const docBody: IDocumentBody = {
dataStream: dataStream.slice(startOffset, endOffset),
};

docBody.textRuns = getTextRunSlice(body, startOffset, endOffset, returnEmptyArray);

const newTables = getTableSlice(body, startOffset, endOffset);
if (newTables.length) {
docBody.tables = newTables;
}

docBody.paragraphs = getParagraphsSlice(body, startOffset, endOffset);

if (type === SliceBodyType.cut) {
const customDecorations = getCustomDecorationSlice(body, startOffset, endOffset);
Expand All @@ -152,21 +209,7 @@ export function getBodySlice(
docBody.customRanges = [];
}

const newCustomBlocks: ICustomBlock[] = [];

for (const block of customBlocks) {
const { startIndex } = block;
if (startIndex >= startOffset && startIndex <= endOffset) {
newCustomBlocks.push(Tools.deepClone(block));
}
}

if (newCustomBlocks.length) {
docBody.customBlocks = newCustomBlocks.map((b) => ({
...b,
startIndex: b.startIndex - startOffset,
}));
}
docBody.customBlocks = getCustomBlockSlice(body, startOffset, endOffset);

return docBody;
}
Expand Down
15 changes: 13 additions & 2 deletions packages/core/src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -67,8 +67,19 @@ export { updateAttributeByDelete } from './docs/data-model/text-x/apply-utils/de
export { updateAttributeByInsert } from './docs/data-model/text-x/apply-utils/insert-apply';
export { TextX } from './docs/data-model/text-x/text-x';
export type { TPriority } from './docs/data-model/text-x/text-x';
export { composeBody, getBodySlice, SliceBodyType } from './docs/data-model/text-x/utils';
export { getCustomDecorationSlice, getCustomRangeSlice, normalizeBody } from './docs/data-model/text-x/utils';
export {
composeBody,
getBodySlice,
getCustomBlockSlice,
getCustomDecorationSlice,
getCustomRangeSlice,
getParagraphsSlice,
getSectionBreakSlice,
getTableSlice,
getTextRunSlice,
normalizeBody,
SliceBodyType,
} from './docs/data-model/text-x/utils';
export { EventState, EventSubject, fromEventSubject, type IEventObserver } from './observer/observable';
export { AuthzIoLocalService } from './services/authz-io/authz-io-local.service';
export { IAuthzIoService } from './services/authz-io/type';
Expand Down
1 change: 1 addition & 0 deletions packages/core/src/services/context/context.ts
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@ export const FOCUSING_EDITOR_INPUT_FORMULA = 'FOCUSING_EDITOR_INPUT_FORMULA';
/** The focusing state of the formula editor (Fx bar). */
export const FOCUSING_FX_BAR_EDITOR = 'FOCUSING_FX_BAR_EDITOR';

/** The focusing state of the cell editor. */
export const FOCUSING_UNIVER_EDITOR = 'FOCUSING_UNIVER_EDITOR';

export const FOCUSING_EDITOR_STANDALONE = 'FOCUSING_EDITOR_INPUT_FORMULA';
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -132,7 +132,7 @@ export const StartAddCommentOperation: ICommand = {
threadId: commentId,
};

docSelectionRenderManager?.blurEditor();
docSelectionRenderManager?.blur();
docCommentService.startAdd(comment);
panelService.setActiveComment({
unitId,
Expand Down
Loading
Loading