Commit ddddfe2b authored by Denys Mishunov's avatar Denys Mishunov

Merge branch 'blob-lcp-improvement' into 'master'

Blob refactor: Improve LCP when viewing large blobs

See merge request gitlab-org/gitlab!82615
parents 2a9efeec 7f80c5af
...@@ -94,6 +94,7 @@ export default { ...@@ -94,6 +94,7 @@ export default {
legacySimpleViewer: null, legacySimpleViewer: null,
isBinary: false, isBinary: false,
isLoadingLegacyViewer: false, isLoadingLegacyViewer: false,
isRenderingLegacyTextViewer: false,
activeViewerType: SIMPLE_BLOB_VIEWER, activeViewerType: SIMPLE_BLOB_VIEWER,
project: DEFAULT_BLOB_INFO.project, project: DEFAULT_BLOB_INFO.project,
gitpodEnabled: DEFAULT_BLOB_INFO.gitpodEnabled, gitpodEnabled: DEFAULT_BLOB_INFO.gitpodEnabled,
...@@ -185,7 +186,13 @@ export default { ...@@ -185,7 +186,13 @@ export default {
.get(`${this.blobInfo.webPath}?format=json&viewer=${type}`) .get(`${this.blobInfo.webPath}?format=json&viewer=${type}`)
.then(({ data: { html, binary } }) => { .then(({ data: { html, binary } }) => {
if (type === SIMPLE_BLOB_VIEWER) { if (type === SIMPLE_BLOB_VIEWER) {
this.isRenderingLegacyTextViewer = true;
this.legacySimpleViewer = html; this.legacySimpleViewer = html;
window.requestIdleCallback(() => {
this.isRenderingLegacyTextViewer = false;
});
} else { } else {
this.legacyRichViewer = html; this.legacyRichViewer = html;
} }
...@@ -286,6 +293,7 @@ export default { ...@@ -286,6 +293,7 @@ export default {
:active-viewer="viewer" :active-viewer="viewer"
:hide-line-numbers="true" :hide-line-numbers="true"
:loading="isLoadingLegacyViewer" :loading="isLoadingLegacyViewer"
:data-loading="isRenderingLegacyTextViewer"
/> />
<component :is="blobViewer" v-else :blob="blobInfo" class="blob-viewer" /> <component :is="blobViewer" v-else :blob="blobInfo" class="blob-viewer" />
<code-intelligence <code-intelligence
......
...@@ -121,6 +121,10 @@ const createComponent = async (mockData = {}, mountFn = shallowMount) => { ...@@ -121,6 +121,10 @@ const createComponent = async (mockData = {}, mountFn = shallowMount) => {
await waitForPromises(); await waitForPromises();
}; };
const execImmediately = (callback) => {
callback();
};
describe('Blob content viewer component', () => { describe('Blob content viewer component', () => {
const findLoadingIcon = () => wrapper.findComponent(GlLoadingIcon); const findLoadingIcon = () => wrapper.findComponent(GlLoadingIcon);
const findBlobHeader = () => wrapper.findComponent(BlobHeader); const findBlobHeader = () => wrapper.findComponent(BlobHeader);
...@@ -131,6 +135,7 @@ describe('Blob content viewer component', () => { ...@@ -131,6 +135,7 @@ describe('Blob content viewer component', () => {
const findCodeIntelligence = () => wrapper.findComponent(CodeIntelligence); const findCodeIntelligence = () => wrapper.findComponent(CodeIntelligence);
beforeEach(() => { beforeEach(() => {
jest.spyOn(window, 'requestIdleCallback').mockImplementation(execImmediately);
isLoggedIn.mockReturnValue(true); isLoggedIn.mockReturnValue(true);
}); });
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment