Appearance
@shbernal/pptxgenjs / index / TextPropsOptions
Interface: TextPropsOptions
Defined in: core-interfaces.ts:1765
Reusable optional data/path fields. Use DataOrPathRequiredProps for APIs that require at least one source.
Extends
Extended by
Properties
_bodyProp?
optional_bodyProp?:object
Defined in: core-interfaces.ts:1766
align?
optionalalign?:TEXT_HALIGN
anchor?
optionalanchor?:TEXT_VALIGN
autoFit?
optionalautoFit?:boolean
bIns?
optionalbIns?:number
lIns?
optionallIns?:number
numCol?
optionalnumCol?:number
prstTxWarp?
optionalprstTxWarp?:string
rIns?
optionalrIns?:number
spcCol?
optionalspcCol?:number
tIns?
optionaltIns?:number
vert?
optionalvert?:TextVertType
wrap?
optionalwrap?:boolean
_lineIdx?
optional_lineIdx?:number
Defined in: core-interfaces.ts:1781
align?
optionalalign?:HAlign
Defined in: core-interfaces.ts:521
Horizontal alignment
Default
ts
'left'Inherited from
altText?
optionalaltText?:string
Defined in: core-interfaces.ts:807
Alt Text value ("How would you describe this object and its contents to someone who is blind?")
- serialized to the generated object's
p:cNvPrdescrattribute - PowerPoint: [right-click on the object] > "Edit Alt Text..."
Since
v4.0.0
Example
ts
'Quarterly revenue bar chart'Inherited from
autoFit?
optionalautoFit?:boolean
Defined in: core-interfaces.ts:1927
Whether "Fit to Shape?" is enabled
Deprecated
v3.3.0 - use fit
baseline?
optionalbaseline?:number
Defined in: core-interfaces.ts:1783
bold?
optionalbold?:boolean
Defined in: core-interfaces.ts:526
Bold style
Default
ts
falseInherited from
breakLine?
optionalbreakLine?:boolean
Defined in: core-interfaces.ts:531
Add a line-break
Default
ts
falseInherited from
bullet?
optionalbullet?:boolean| {characterCode?:string;code?:string;color?:string;fontFace?:string;image?: {data?:string;path?:string; };indent?:number;marginPt?:number;numberStartAt?:number;numberType?:"alphaLcParenBoth"|"alphaLcParenR"|"alphaLcPeriod"|"alphaUcParenBoth"|"alphaUcParenR"|"alphaUcPeriod"|"arabicParenBoth"|"arabicParenR"|"arabicPeriod"|"arabicPlain"|"romanLcParenBoth"|"romanLcParenR"|"romanLcPeriod"|"romanUcParenBoth"|"romanUcParenR"|"romanUcPeriod";size?:number;startAt?:number;style?:string;type?:"number"|"bullet"; }
Defined in: core-interfaces.ts:547
Add standard or custom bullet
- use
truefor standard bullet - pass object options for custom bullet
Union Members
boolean
Type Literal
{ characterCode?: string; code?: string; color?: string; fontFace?: string; image?: { data?: string; path?: string; }; indent?: number; marginPt?: number; numberStartAt?: number; numberType?: "alphaLcParenBoth" | "alphaLcParenR" | "alphaLcPeriod" | "alphaUcParenBoth" | "alphaUcParenR" | "alphaUcPeriod" | "arabicParenBoth" | "arabicParenR" | "arabicPeriod" | "arabicPlain" | "romanLcParenBoth" | "romanLcParenR" | "romanLcPeriod" | "romanUcParenBoth" | "romanUcParenR" | "romanUcPeriod"; size?: number; startAt?: number; style?: string; type?: "number" | "bullet"; }
characterCode?
optionalcharacterCode?:string
Bullet character code (unicode)
Since
v3.3.0
Example
ts
'25BA' // 'BLACK RIGHT-POINTING POINTER' (U+25BA)code?
optionalcode?:string
Bullet code (unicode)
Deprecated
v3.3.0 - use characterCode
color?
optionalcolor?:string
Bullet glyph color (separate from the text run color)
Since
v4.0.0
Example
ts
'FF0000' // red bulletfontFace?
optionalfontFace?:string
Bullet glyph font typeface (<a:buFont/>), e.g. for symbol-font bullets
Since
v4.0.0
Example
ts
'Wingdings' // render `characterCode` using the Wingdings fontimage?
optionalimage?:object
Image to use as the bullet glyph ("picture bullet", <a:buBlip>)
- supply an image
path(filesystem/URL) or base64data(same forms asaddImage()) - raster formats (PNG/JPG/GIF) are recommended; use
sizeto scale relative to the text height - takes precedence over
type/characterCodewhen set
Since
v4.0.0
Examples
ts
image: { path: 'images/star.png' }ts
image: { data: 'image/png;base64,iVBOR...' }image.data?
optionaldata?:string
image.path?
optionalpath?:string
indent?
optionalindent?:number
Indentation (space between bullet and text) (points)
Since
v3.3.0
Default
ts
27 // DEF_BULLET_MARGINExample
ts
10 // Indents text 10 points from bulletmarginPt?
optionalmarginPt?:number
Margin between bullet and text
Since
v3.2.1
Deprecated
v3.3.0 - use indent
numberStartAt?
optionalnumberStartAt?:number
Number bullets start at
Since
v3.3.0
Default
ts
1Example
ts
10 // numbered bullets start with 10numberType?
optionalnumberType?:"alphaLcParenBoth"|"alphaLcParenR"|"alphaLcPeriod"|"alphaUcParenBoth"|"alphaUcParenR"|"alphaUcPeriod"|"arabicParenBoth"|"arabicParenR"|"arabicPeriod"|"arabicPlain"|"romanLcParenBoth"|"romanLcParenR"|"romanLcPeriod"|"romanUcParenBoth"|"romanUcParenR"|"romanUcPeriod"
Number type
Since
v3.3.0
Example
ts
'romanLcParenR' // roman numerals lower-case with paranthesis rightsize?
optionalsize?:number
Bullet glyph size as a percentage of the run's text size (25–400)
Since
v4.0.0
Default
ts
100Example
ts
80 // bullet glyph is 80% of the text sizestartAt?
optionalstartAt?:number
Number to start with (only applies to type:number)
Deprecated
v3.3.0 - use numberStartAt
style?
optionalstyle?:string
Number type
Deprecated
v3.3.0 - use numberType
type?
optionaltype?:"number"|"bullet"
Bullet type
Default
ts
bulletDefault
ts
falseInherited from
caps?
optionalcaps?:"small"|"all"|"none"
Defined in: core-interfaces.ts:663
Text capitalization
'all'= ALL CAPS'small'= Small Caps'none'= no override (default)- PowerPoint: Font > Effects > All Caps / Small Caps
Inherited from
charSpacing?
optionalcharSpacing?:number
Defined in: core-interfaces.ts:1787
Character spacing
color?
optionalcolor?:string
Defined in: core-interfaces.ts:671
Text color
HexColororThemeColor- MS-PPT > Format Shape > Text Options > Text Fill & Outline > Text Fill > Color
Examples
ts
'FF0000' // hex color (red)ts
pptx.SchemeColor.text1 // Theme color (Text1)Inherited from
columns?
optionalcolumns?:number
Defined in: core-interfaces.ts:1796
Number of text columns in the text body
- PowerPoint: Format Shape > Shape Options > Size & Properties > Text Box > Columns > "Number"
- range: 1-16
Since
v5.3.0
Default
ts
1Example
ts
2 // flow text into two columnscolumnSpacing?
optionalcolumnSpacing?:number
Defined in: core-interfaces.ts:1805
Spacing between text columns (points)
- PowerPoint: Format Shape > Shape Options > Size & Properties > Text Box > Columns > "Spacing"
- only applies when
columns> 1
Since
v5.3.0
Default
ts
0Example
ts
10 // 10pt gap between columnsdata?
optionaldata?:string
Defined in: core-interfaces.ts:74
base64-encoded string
- Useful for avoiding potential path/server issues
Example
ts
'image/png;base64,iVtDafDrBF[...]=' // pre-encoded image in base-64Inherited from
fill?
optionalfill?:ShapeFillProps
Defined in: core-interfaces.ts:1832
Shape fill
Examples
ts
{ color:'FF0000' } // hex color (red)ts
{ color:'0088CC', transparency:50 } // hex color, 50% transparentts
{ color:pptx.SchemeColor.accent1 } // theme color Accent1fit?
optionalfit?:"resize"|"none"|TextFitShrinkProps|"shrink"
Defined in: core-interfaces.ts:1825
Text fit options
MS-PPT > Format Shape > Shape Options > Text Box > "[unlabeled group]": [3 options below]
- 'none' = Do not Autofit
- 'shrink' = Shrink text on overflow
- 'resize' = Resize shape to fit text
Note 'shrink' and 'resize' only take effect after editing text/resize shape. Both PowerPoint and Word dynamically calculate a scaling factor and apply it when edit/resize occurs.
There is no way for this library to trigger that behavior, sorry. As a workaround, pass an object form of 'shrink' to bake explicit fontScale/lnSpcReduction values into the file so the text renders pre-shrunk without an edit/resize.
Since
v3.3.0
Examples
ts
'shrink' // emit a bare <a:normAutofit/>ts
{ type: 'shrink', fontScale: 85, lnSpcReduction: 20 } // pre-shrink textDefault
ts
"none"flipH?
optionalflipH?:boolean
Defined in: core-interfaces.ts:1837
Flip shape horizontally?
Default
ts
falseflipV?
optionalflipV?:boolean
Defined in: core-interfaces.ts:1842
Flip shape vertical?
Default
ts
falsefontFace?
optionalfontFace?:string
Defined in: core-interfaces.ts:681
Font face name
Applied to the Latin (<a:latin>) and complex-script (<a:cs>) font slots, matching how PowerPoint writes a font picked from the UI. The East Asian slot (<a:ea>) is left to inherit from the theme unless fontFaceEA is set — forcing a Latin-only face into the East Asian slot duplicates/ghosts text in Office 365.
Example
ts
'Arial' // Arial fontInherited from
fontFaceEA?
optionalfontFaceEA?:string
Defined in: core-interfaces.ts:689
East Asian font face name (<a:ea> slot), used to render CJK (Chinese/Japanese/Korean) glyphs
Set this when the East Asian font differs from fontFace. When omitted, <a:ea> inherits the theme East Asian font, which is what PowerPoint does for Latin fonts.
Example
ts
'微軟正黑體' // render East Asian glyphs with Microsoft JhengHeiInherited from
fontSize?
optionalfontSize?:number
Defined in: core-interfaces.ts:694
Font size
Example
ts
12 // Font size 12Inherited from
glow?
optionalglow?:TextGlowProps
Defined in: core-interfaces.ts:1843
h?
optionalh?:Coord
Defined in: core-interfaces.ts:47
Height
- inches or percentage
Examples
ts
10.25 // height in inchests
'75%' // height as percentage of slide sizeInherited from
highlight?
optionalhighlight?:string
Defined in: core-interfaces.ts:699
Text highlight color (hex format)
Example
ts
'FFFF00' // yellowInherited from
hyperlink?
optionalhyperlink?:HyperlinkProps
Defined in: core-interfaces.ts:1844
indentLevel?
optionalindentLevel?:number
Defined in: core-interfaces.ts:1845
inset?
optionalinset?:number
Defined in: core-interfaces.ts:1937
Inset
Deprecated
v3.10.0 - use margin
isTextBox?
optionalisTextBox?:boolean
Defined in: core-interfaces.ts:1846
italic?
optionalitalic?:boolean
Defined in: core-interfaces.ts:704
italic style
Default
ts
falseInherited from
lang?
optionallang?:string
Defined in: core-interfaces.ts:711
language
- ISO 639-1 standard language code
Default
ts
'en-US' // english USExample
ts
'fr-CA' // french CanadianInherited from
line?
optionalline?:ShapeLineProps
Defined in: core-interfaces.ts:1847
lineDash?
optionallineDash?:"dash"|"solid"|"dashDot"|"lgDash"|"lgDashDot"|"lgDashDotDot"|"sysDash"|"sysDot"
Defined in: core-interfaces.ts:1942
Dash type
Deprecated
v3.3.0 - use line.dashType
lineHead?
optionallineHead?:"none"|"triangle"|"arrow"|"diamond"|"oval"|"stealth"
Defined in: core-interfaces.ts:1946
Deprecated
v3.3.0 - use line.beginArrowType
lineSize?
optionallineSize?:number
Defined in: core-interfaces.ts:1950
Deprecated
v3.3.0 - use line.width
lineSpacing?
optionallineSpacing?:number
Defined in: core-interfaces.ts:1853
Line spacing (pt)
- PowerPoint: Paragraph > Indents and Spacing > Line Spacing: > "Exactly"
Example
ts
28 // 28ptlineSpacingMultiple?
optionallineSpacingMultiple?:number
Defined in: core-interfaces.ts:1861
line spacing multiple (percent)
- range: 0.0-9.99
- PowerPoint: Paragraph > Indents and Spacing > Line Spacing: > "Multiple"
Example
ts
1.5 // 1.5X line spacingSince
v3.5.0
lineTail?
optionallineTail?:"none"|"triangle"|"arrow"|"diamond"|"oval"|"stealth"
Defined in: core-interfaces.ts:1954
Deprecated
v3.3.0 - use line.endArrowType
margin?
optionalmargin?:Margin
Defined in: core-interfaces.ts:1871
Margin (points)
- PowerPoint: Format Shape > Shape Options > Size & Properties > Text Box > Left/Right/Top/Bottom margin
Default
ts
"Normal" margin in PowerPoint [3.5, 7.0, 3.5, 7.0] // (this library sets no value, but PowerPoint defaults to "Normal" [0.05", 0.1", 0.05", 0.1"])Examples
ts
0 // Top/Right/Bottom/Left margin 0 [0.0" in powerpoint]ts
10 // Top/Right/Bottom/Left margin 10 [0.14" in powerpoint]ts
[10,5,10,5] // Top margin 10, Right margin 5, Bottom margin 10, Left margin 5objectLock?
optionalobjectLock?:ObjectLockProps
Defined in: core-interfaces.ts:819
Object lock flags (DrawingML a:spLocks / a:picLocks / a:graphicFrameLocks)
- restrict how the object can be manipulated in PowerPoint (e.g. prevent moving, resizing, or grouping)
- each flag maps 1:1 to the OOXML attribute of the same name; only flags set to
trueare emitted - PowerPoint UI: Selection Pane / right-click protections (most locks are honored at edit time, not as a password)
- flags only apply to the object types that support them (see each flag); flags set on an unsupported object type are ignored with a console warning
Since
v4.0.0
Examples
ts
{ noMove: true, noResize: true } // pin an object in placets
{ noGrp: true } // exclude from groupingInherited from
objectName?
optionalobjectName?:string
Defined in: core-interfaces.ts:799
Object name
- used instead of default "Object N" name
- PowerPoint: Home > Arrange > Selection Pane...
Since
v3.10.0
Default
ts
'Object 1'Example
ts
'Antenna Design 9'Inherited from
outline?
optionaloutline?:object
Defined in: core-interfaces.ts:1872
color
color:
string
size
size:
number
paraSpaceAfter?
optionalparaSpaceAfter?:number
Defined in: core-interfaces.ts:1873
paraSpaceBefore?
optionalparaSpaceBefore?:number
Defined in: core-interfaces.ts:1874
path?
optionalpath?:string
Defined in: core-interfaces.ts:67
URL or relative path
Example
ts
'https://onedrives.com/myimg.png` // retrieve image via URL
@example '/home/gitbrent/images/myimg.png` // retrieve image via local pathInherited from
placeholder?
optionalplaceholder?:string
Defined in: core-interfaces.ts:1886
Placeholder type
- when the value matches a placeholder defined on the slide layout/master, this text inherits that placeholder's position and formatting
- otherwise the text shape is promoted to a standalone placeholder of this type, emitting a real
<p:ph type="...">. Useplaceholder: 'title'to give a slide an accessible title (PowerPoint's accessibility checker otherwise reports "Missing Slide Title") - values: 'title' | 'body' | et. al.
Example
ts
'title'See
https://learn.microsoft.com/en-us/office/vba/api/powerpoint.ppplaceholdertype
rectRadius?
optionalrectRadius?:number
Defined in: core-interfaces.ts:1892
Rounded rectangle radius (only for pptx.shapes.ROUNDED_RECTANGLE)
- values: 0.0 to 1.0
Default
ts
0rotate?
optionalrotate?:number
Defined in: core-interfaces.ts:1899
Rotation (degrees)
- range: -360 to 360
Default
ts
0Example
ts
180 // rotate 180 degreesrtlMode?
optionalrtlMode?:boolean
Defined in: core-interfaces.ts:1904
Whether to enable right-to-left mode
Default
ts
falseshadow?
optionalshadow?:ShadowProps
Defined in: core-interfaces.ts:1905
shape?
optionalshape?:SHAPE_NAME
Defined in: core-interfaces.ts:1906
shrinkText?
optionalshrinkText?:boolean
Defined in: core-interfaces.ts:1932
Whather "Shrink Text on Overflow?" is enabled
Deprecated
v3.3.0 - use fit
softBreakBefore?
optionalsoftBreakBefore?:boolean
Defined in: core-interfaces.ts:717
Add a soft line-break (shift+enter) before line text content
Default
ts
falseSince
v3.5.0
Inherited from
strike?
optionalstrike?:boolean|"dblStrike"|"sngStrike"
Defined in: core-interfaces.ts:1907
subscript?
optionalsubscript?:boolean
Defined in: core-interfaces.ts:1908
superscript?
optionalsuperscript?:boolean
Defined in: core-interfaces.ts:1909
tabStops?
optionaltabStops?:object[]
Defined in: core-interfaces.ts:723
tab stops
- PowerPoint: Paragraph > Tabs > Tab stop position
alignment?
optionalalignment?:"r"|"ctr"|"l"|"dec"
position
position:
number
Example
ts
[{ position:1 }, { position:3 }] // Set first tab stop to 1 inch, set second tab stop to 3 inchesInherited from
textDirection?
optionaltextDirection?:"horz"|"vert"|"vert270"|"wordArtVert"
Defined in: core-interfaces.ts:732
text direction horz = horizontal vert = rotate 90^ vert270 = rotate 270^ wordArtVert = stacked
Default
ts
'horz'Inherited from
textWarp?
optionaltextWarp?:string
Defined in: core-interfaces.ts:540
Preset text warp / WordArt shape (<a:bodyPr><a:prstTxWarp prst="..">), which bends the text along a preset path (arch, circle, wave, …). The value is an OOXML ST_TextShapeType preset name.
Since
v4.0.0
Examples
ts
'textArchUp' // bend text along an upward arch (e.g. a label following a ring/arc)ts
'textCircle'Inherited from
transparency?
optionaltransparency?:number
Defined in: core-interfaces.ts:739
Transparency (percent)
- MS-PPT > Format Shape > Text Options > Text Fill & Outline > Text Fill > Transparency
- range: 0-100
Default
ts
0Inherited from
underline?
optionalunderline?:object
Defined in: core-interfaces.ts:745
underline properties
- PowerPoint: Font > Color & Underline > Underline Style/Underline Color
color?
optionalcolor?:string
style?
optionalstyle?:"none"|"dash"|"dashHeavy"|"dashLong"|"dashLongHeavy"|"dbl"|"dotDash"|"dotDashHeave"|"dotDotDash"|"dotDotDashHeavy"|"dotted"|"dottedHeavy"|"heavy"|"sng"|"wavy"|"wavyDbl"|"wavyHeavy"
Default
ts
(none)Inherited from
valign?
optionalvalign?:VAlign
Defined in: core-interfaces.ts:1914
Vertical alignment
Default
ts
middleOverrides
vert?
optionalvert?:TextVertType
Defined in: core-interfaces.ts:1915
w?
optionalw?:Coord
Defined in: core-interfaces.ts:54
Width
- inches or percentage
Examples
ts
10.25 // width in inchests
'75%' // width as percentage of slide sizeInherited from
wrap?
optionalwrap?:boolean
Defined in: core-interfaces.ts:1921
Text wrap
Since
v3.3.0
Default
ts
truex?
optionalx?:Coord
Defined in: core-interfaces.ts:33
Horizontal position
- inches or percentage
Examples
ts
10.25 // position in inchests
'75%' // position as percentage of slide sizeInherited from
y?
optionaly?:Coord
Defined in: core-interfaces.ts:40
Vertical position
- inches or percentage
Examples
ts
10.25 // position in inchests
'75%' // position as percentage of slide size