-
Notifications
You must be signed in to change notification settings - Fork 8.2k
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
TypeScript Reporting Layouts #22454
TypeScript Reporting Layouts #22454
Changes from 1 commit
6e7c5fb
f2108a3
704d79f
b9e7482
6d805c5
9e83af3
8979f2e
4d0d3d0
af4257a
4464fb2
ca4b974
a285cbf
ced32f9
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -6,12 +6,12 @@ | |
import { Size } from '../../../../../types'; | ||
|
||
export interface CaptureConfig { | ||
zoom: number; | ||
viewport: Size; | ||
zoom: number; | ||
viewport: Size; | ||
} | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. -2 spaces for the |
||
|
||
export interface ViewZoomWidthHeight { | ||
zoom: number; | ||
width: number; | ||
height: number; | ||
} | ||
zoom: number; | ||
width: number; | ||
height: number; | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -4,29 +4,22 @@ | |
* you may not use this file except in compliance with the Elastic License. | ||
*/ | ||
import { KbnServer } from '../../../../../../../../src/server/index'; | ||
import { Size } from '../../../../../types'; | ||
import { LayoutTypes } from '../../../common/constants'; | ||
import { Layout } from './layout'; | ||
import { PreserveLayout } from './preserve_layout'; | ||
import { PrintLayout } from './print_layout'; | ||
|
||
// you'll notice that we aren't passing the zoom at this time, while it'd be possible to use | ||
// window.pixelDensity to figure out what the current user is seeing, if they're going to send the | ||
// PDF to someone else, I can see there being benefit to using a higher pixel density, so we're | ||
// going to leave this hard-coded for the time being | ||
|
||
interface LayoutParams { | ||
id: string; | ||
dimensions: { | ||
height: number; | ||
width: number; | ||
}; | ||
dimensions: Size; | ||
} | ||
|
||
export function createlayout(server: KbnServer, LayoutParamsin: LayoutParams): Layout { | ||
if (LayoutParamsin && LayoutParamsin.id === LayoutTypes.PRESERVE_LAYOUT) { | ||
return new PreserveLayout(LayoutParamsin.id, LayoutParamsin.dimensions); | ||
export function createLayout(server: KbnServer, layoutParams: LayoutParams): Layout { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. let's call this file |
||
if (layoutParams && layoutParams.id === LayoutTypes.PRESERVE_LAYOUT) { | ||
return new PreserveLayout(layoutParams.id, layoutParams.dimensions); | ||
} | ||
|
||
// this is the default because some jobs won't have anything specified | ||
return new PrintLayout(server, LayoutParamsin.id); | ||
return new PrintLayout(server, layoutParams.id); | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -10,7 +10,7 @@ import { Layout, PageSizeParams } from './layout'; | |
const ZOOM: number = 2; | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Zoom used to be a param that could be passed in from a caller, but 2 was the default. This makes it completely hardcoded. Also, you've removed the explanatory comments: https://github.com/elastic/kibana/blob/master/x-pack/plugins/reporting/export_types/printable_pdf/server/lib/layouts/preserve_layout.js#L9-L12 There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Intentional. This setting was never exposed to the user as configurable - #20091 I don't think we ever will expose it. The only reason we use it is to make sure the resolution is a little bigger on the screenshots. From Brandon in that above issue:
|
||
|
||
export class PreserveLayout extends Layout { | ||
public selectors = { | ||
public readonly selectors = { | ||
screenshot: '[data-shared-items-container]', | ||
renderComplete: '[data-shared-item]', | ||
itemsCountAttribute: 'data-shared-items-count', | ||
|
@@ -66,16 +66,16 @@ export class PreserveLayout extends Layout { | |
return undefined; | ||
} | ||
|
||
public getPdfPageSize(pagesizeparams: PageSizeParams) { | ||
public getPdfPageSize(pageSizeParams: PageSizeParams) { | ||
return { | ||
height: | ||
this.height + | ||
pagesizeparams.pageMarginTop + | ||
pagesizeparams.pageMarginBottom + | ||
pagesizeparams.tableBorderWidth * 2 + | ||
pagesizeparams.headingHeight + | ||
pagesizeparams.subheadingHeight, | ||
width: this.width + pagesizeparams.pageMarginWidth * 2 + pagesizeparams.tableBorderWidth * 2, | ||
pageSizeParams.pageMarginTop + | ||
pageSizeParams.pageMarginBottom + | ||
pageSizeParams.tableBorderWidth * 2 + | ||
pageSizeParams.headingHeight + | ||
pageSizeParams.subheadingHeight, | ||
width: this.width + pageSizeParams.pageMarginWidth * 2 + pageSizeParams.tableBorderWidth * 2, | ||
}; | ||
} | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,10 +1,10 @@ | ||
export interface Size { | ||
width: number; | ||
height: number; | ||
} | ||
width: number; | ||
height: number; | ||
} | ||
|
||
export interface Logger { | ||
debug: (message: string) => void; | ||
error: (message: string) => void; | ||
warning: (message: string) => void; | ||
} | ||
debug: (message: string) => void; | ||
error: (message: string) => void; | ||
warning: (message: string) => void; | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
configObject
=>ConfigObject