-
Notifications
You must be signed in to change notification settings - Fork 456
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #1280 from cornerstonejs/fix/text-style-api
Fixing textStyle API inconsistency between font size and font style
- Loading branch information
Showing
1 changed file
with
87 additions
and
11 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,38 +1,114 @@ | ||
let defaultFontSize = 15, | ||
defaultFont = `${defaultFontSize}px Arial`, | ||
defaultBackgroundColor = 'transparent'; | ||
const textStyle = { | ||
fontSize: 15, | ||
fontFamily: 'Arial', | ||
backgroundColor: 'transparent', | ||
}; | ||
|
||
/** | ||
* @deprecated | ||
* This function will be deprecated and users must use `setFontSize` and | ||
* `setFontFamily` to set the font configuration independently. | ||
* | ||
* @param {string} font Font string with font size and font family | ||
* @returns {void} | ||
*/ | ||
function setFont(font) { | ||
defaultFont = font; | ||
const split = font.split('px '); | ||
|
||
if (split.length === 2) { | ||
setFontSize(parseFloat(split[0])); | ||
setFontFamily(split[1]); | ||
} | ||
} | ||
|
||
/** | ||
* Returns all the font styling properties combined into a single string | ||
* following the CSS font property pattern. | ||
* @see {@link https://www.w3.org/TR/css-fonts-3/#font-prop|3.7. Shorthand font property: the font property} | ||
* | ||
* @returns {string} CSS font property | ||
*/ | ||
function getFont() { | ||
return defaultFont; | ||
return `${textStyle.fontSize}px ${textStyle.fontFamily}`; | ||
} | ||
|
||
/** | ||
* Sets the font family that will be used for general font rendering. | ||
* @see {@link https://www.w3.org/TR/css-fonts-3/#font-family-prop|3.1. Font family: the font-family property} | ||
* | ||
* @param {string} fontFamily Name of the font to be used | ||
* @returns {void} | ||
*/ | ||
function setFontFamily(fontFamily) { | ||
if (typeof fontFamily !== 'string') { | ||
throw new Error('Font family must be a valid string'); | ||
} | ||
|
||
textStyle.fontFamily = fontFamily; | ||
} | ||
|
||
/** | ||
* Returns the defined font family for rendering text boxes. | ||
* | ||
* @returns {string} The font family used for rendering text boxes | ||
*/ | ||
function getFontFamily() { | ||
return textStyle.fontFamily; | ||
} | ||
|
||
/** | ||
* Sets the font size in pixels that will be used for general font rendering. | ||
* | ||
* @param {number} fontSize Font size in pixels | ||
* @returns {void} | ||
*/ | ||
function setFontSize(fontSize) { | ||
defaultFontSize = fontSize; | ||
if (typeof fontSize !== 'number' || isNaN(fontSize) || !isFinite(fontSize)) { | ||
throw new Error('Font size must be a valid number'); | ||
} | ||
|
||
textStyle.fontSize = parseFloat(fontSize); | ||
} | ||
|
||
/** | ||
* Returns the font size in pixels that will be used for general font rendering. | ||
* | ||
* @returns {number} Font size in pixels | ||
*/ | ||
function getFontSize() { | ||
return defaultFontSize; | ||
return textStyle.fontSize; | ||
} | ||
|
||
/** | ||
* Changes the background color of the text's bounding box. | ||
* The default background color is transparent, that's why it doesn't display | ||
* any background for the text box. | ||
* | ||
* @param {string} backgroundColor Background color for the text | ||
* @returns {void} | ||
*/ | ||
function setBackgroundColor(backgroundColor) { | ||
defaultBackgroundColor = backgroundColor; | ||
textStyle.backgroundColor = backgroundColor; | ||
} | ||
|
||
/** | ||
* Returns the background color that is being used for rendering text boxes. | ||
* | ||
* @returns {string} The background color for the text's bounding box | ||
*/ | ||
function getBackgroundColor() { | ||
return defaultBackgroundColor; | ||
return textStyle.backgroundColor; | ||
} | ||
|
||
const textStyle = { | ||
const textStyleApi = { | ||
setFont, | ||
getFont, | ||
setFontSize, | ||
getFontSize, | ||
setFontFamily, | ||
getFontFamily, | ||
setBackgroundColor, | ||
getBackgroundColor, | ||
}; | ||
|
||
export default textStyle; | ||
export default textStyleApi; |