diff --git a/src/design-system/index.css b/src/design-system/index.css
index 9654c861..aad6426d 100644
--- a/src/design-system/index.css
+++ b/src/design-system/index.css
@@ -11,3 +11,4 @@
@import './highlight.css';
@import './abbreviate.css';
@import './keyboard-input.css';
+@import './preformattedText.css';
diff --git a/src/design-system/preformattedText.css b/src/design-system/preformattedText.css
new file mode 100644
index 00000000..ef851f16
--- /dev/null
+++ b/src/design-system/preformattedText.css
@@ -0,0 +1,7 @@
+.dcx-pre {
+ color: token('color-text-pre_body');
+ background-color: token('color-background-pre_box');
+ font-size: token('font-size-pre_body');
+ font-family: token('font-family-pre_body');
+ font-weight: token('font-weight-pre_body');
+}
\ No newline at end of file
diff --git a/src/design-system/tokens.json b/src/design-system/tokens.json
index 91373fc8..fad182a3 100644
--- a/src/design-system/tokens.json
+++ b/src/design-system/tokens.json
@@ -41,6 +41,7 @@
"color-background-formcontrol_label": "transparent",
"color-background-formcontrol_label-floating": "white",
"color-background-highlight_body": "yellow",
+ "color-background-pre_box": "white",
"color-chevron-formcontrol": "#000",
"color-chevron-formcontrol-filled": "#000",
"color-chevron-formcontrol-floating": "#000",
@@ -98,7 +99,7 @@
"font-family-body": "Arial, Helvetica, sans-serif",
"font-family-highlight_body": "Arial, Helvetica, sans-serif",
"font-family-paragraph": "Arial, Helvetica, sans-serif",
- "font-family-pre_body": "Arial, Helvetica, sans-serif",
+ "font-family-pre_body": "monospace",
"font-formcontrol-line-height": "20px",
"font-formcontrol-size": "16px",
"font-formcontrol-size-floating": "16px",
@@ -118,7 +119,7 @@
"font-size-formcontrol_label": "16px",
"font-size-highlight_body": "12px",
"font-size-paragraph": "12px",
- "font-size-pre_body": "12px",
+ "font-size-pre_body": "16px",
"font-weight-body": "normal",
"font-weight-formcontrol_label": "normal",
"font-weight-highlight_body": "normal",
diff --git a/stories/PreformattedText/design-system/AccessibleTheme.stories.js b/stories/PreformattedText/design-system/AccessibleTheme.stories.js
new file mode 100644
index 00000000..6588aab5
--- /dev/null
+++ b/stories/PreformattedText/design-system/AccessibleTheme.stories.js
@@ -0,0 +1,53 @@
+import { PreformattedText } from '../../../src/preformattedText/PreformattedText';
+import style from '!raw-loader!../../themes/accessible.theme.css';
+import { LiveProvider, LiveEditor } from 'react-live';
+import { StorybookUtils } from '../../../core/storybook/StorybookUtils';
+
+/**
+ * This a theme aimed at easing the vizualization of the different elements of the component in order to improve the experience for people that have visual impairments.
+ */
+export default {
+ title: 'DCXLibrary/Typography/PreformattedText/Design system/Accessible',
+ component: PreformattedText,
+ decorators: [
+ getStory => {
+ require('../../../dist/design-system/index.css');
+ require('../../themes/accessible.theme.css');
+ return getStory();
+ },
+ ],
+ parameters: {
+ options: { showPanel: true },
+ actions: { disable: true },
+ },
+ tags: ['autodocs'],
+};
+
+export const ShowCase = {
+ parameters: {
+ backgrounds: {
+ default: 'dark',
+ values: [
+ { name: 'dark', value: '#282c34' },
+ { name: 'light', value: '#fff' },
+ ],
+ },
+ },
+ render: () => (
+
+
+
+ ),
+};
+
+export const Default = {
+ name: 'Default',
+ args: {
+ value: `Text in a pre element is displayed in a fixed-width font, and it preserves both spaces and
+ line breaks.`,
+ },
+};
diff --git a/stories/PreformattedText/design-system/DarkTheme.stories.js b/stories/PreformattedText/design-system/DarkTheme.stories.js
new file mode 100644
index 00000000..93ee070d
--- /dev/null
+++ b/stories/PreformattedText/design-system/DarkTheme.stories.js
@@ -0,0 +1,63 @@
+import { PreformattedText } from '../../../src/preformattedText/PreformattedText';
+// eslint-disable-next-line import/no-webpack-loader-syntax
+import style from '!raw-loader!../../themes/dark.theme.css';
+import { LiveProvider, LiveEditor } from 'react-live';
+import { StorybookUtils } from '../../../core/storybook/StorybookUtils';
+
+/**
+ * This a theme showcases how to customize the component so it can be used on dark backgrounds.
+ */
+export default {
+ title: 'DCXLibrary/Typography/PreformattedText/Design system/Dark',
+ component: PreformattedText,
+ decorators: [
+ getStory => {
+ require('../../../dist/design-system/index.css');
+ require('../../themes/dark.theme.css');
+ return getStory();
+ },
+ ],
+ parameters: {
+ options: { showPanel: true },
+ actions: { disable: true },
+ },
+ tags: ['autodocs'],
+};
+
+export const ShowCase = {
+ parameters: {
+ backgrounds: {
+ default: 'dark',
+ values: [
+ { name: 'dark', value: '#282c34' },
+ { name: 'light', value: '#fff' },
+ ],
+ },
+ },
+ render: () => (
+
+
+
+ ),
+};
+
+export const Default = {
+ name: 'Default',
+ parameters: {
+ backgrounds: {
+ default: 'dark',
+ values: [
+ { name: 'dark', value: '#282c34' },
+ { name: 'light', value: '#fff' },
+ ],
+ },
+ },
+ args: {
+ value: `Text in a pre element is displayed in a fixed-width font, and it preserves both spaces and
+line breaks.`,
+ },
+};
diff --git a/stories/PreformattedText/design-system/Default.stories.js b/stories/PreformattedText/design-system/Default.stories.js
new file mode 100644
index 00000000..3df33478
--- /dev/null
+++ b/stories/PreformattedText/design-system/Default.stories.js
@@ -0,0 +1,27 @@
+import { PreformattedText } from '../../../src/preformattedText/PreformattedText';
+/**
+ * Here we display the component in its natural preformattedText, importing only the base Design System styles.
+ */
+export default {
+ title: 'DCXLibrary/Typography/PreformattedText/Design system/Default',
+ component: PreformattedText,
+ decorators: [
+ getStory => {
+ require('../../../dist/design-system/index.css');
+ return getStory();
+ },
+ ],
+ parameters: {
+ options: { showPanel: true },
+ actions: { disable: true },
+ },
+ tags: ['autodocs'],
+};
+
+export const Default = {
+ name: 'Default',
+ args: {
+ value: `Text in a pre element is displayed in a fixed-width font, and it preserves both spaces and
+line breaks.`,
+ },
+};
diff --git a/stories/PreformattedText/design-system/MaterialTheme.stories.js b/stories/PreformattedText/design-system/MaterialTheme.stories.js
new file mode 100644
index 00000000..dde014ad
--- /dev/null
+++ b/stories/PreformattedText/design-system/MaterialTheme.stories.js
@@ -0,0 +1,55 @@
+import { PreformattedText } from '../../../src/preformattedText/PreformattedText';
+import { LiveProvider, LiveEditor } from 'react-live';
+// eslint-disable-next-line import/no-webpack-loader-syntax
+import style from '!raw-loader!../../themes/material.theme.css';
+import { StorybookUtils } from '../../../core/storybook/StorybookUtils';
+
+/**
+ * This a theme showcases an appearance similar to Material UI can be achieved.
+ * If you copy paste this snippet inside your css file you'll get a material design style
+ */
+export default {
+ title: 'DCXLibrary/Typography/PreformattedText/Design system/Material',
+ component: PreformattedText,
+ decorators: [
+ getStory => {
+ require('../../../dist/design-system/index.css');
+ require('../../themes/material.theme.css');
+ return getStory();
+ },
+ ],
+ parameters: {
+ options: { showPanel: true },
+ actions: { disable: true },
+ },
+ tags: ['autodocs'],
+};
+
+export const ShowCase = {
+ parameters: {
+ backgrounds: {
+ default: 'dark',
+ values: [
+ { name: 'dark', value: '#282c34' },
+ { name: 'light', value: '#fff' },
+ ],
+ },
+ },
+ render: () => (
+
+
+
+ ),
+};
+
+export const Default = {
+ name: 'Default',
+ args: {
+ value: `Text in a pre element is displayed in a fixed-width font, and it preserves both spaces and
+line breaks.`,
+ },
+};
diff --git a/stories/PreformattedText/design-system/Playground.stories.js b/stories/PreformattedText/design-system/Playground.stories.js
new file mode 100644
index 00000000..86e7a38e
--- /dev/null
+++ b/stories/PreformattedText/design-system/Playground.stories.js
@@ -0,0 +1,24 @@
+/* eslint-disable import/no-webpack-loader-syntax */
+import style from '!raw-loader!../../../dist/design-system/preformattedText.css';
+import TokensDecorator from '../../../core/storybook/TokensDecorator';
+import { PreformattedText } from '../../../src/preformattedText/PreformattedText';
+
+export default {
+ title: 'DCXLibrary/Typography/PreformattedText/Design system',
+ component: PreformattedText,
+ decorators: [
+ getStory => {getStory()},
+ ],
+ parameters: {
+ options: { showPanel: true },
+ actions: { disable: true },
+ },
+};
+
+export const Playground = {
+ name: 'Playground',
+ args: {
+ value: `Text in a pre element is displayed in a fixed-width font, and it preserves both spaces and
+line breaks.`,
+ },
+};
diff --git a/stories/themes/dark.theme.css b/stories/themes/dark.theme.css
index 413a01dd..c7523d8f 100644
--- a/stories/themes/dark.theme.css
+++ b/stories/themes/dark.theme.css
@@ -59,6 +59,11 @@
--dcx-color-text-body: white;
}
+.dcx-pre {
+ --dcx-color-text-pre_body: white;
+ --dcx-color-background-pre_box: transparent;
+}
+
.dcx-insert-text {
--dcx-color-text-body: white;
}
diff --git a/stories/themes/material.theme.css b/stories/themes/material.theme.css
index c114154e..b546a6b8 100644
--- a/stories/themes/material.theme.css
+++ b/stories/themes/material.theme.css
@@ -20,7 +20,10 @@
--dcx-color-marker: rgba(0, 0, 0, 0.6);
}
+.dcx-pre {
+ --dcx-color-text-pre_body: rgba(0, 0, 0, 0.6);
+}
.dcx-abbreviate {
--dcx-border-radius-abbreviate: 8px;
-}
\ No newline at end of file
+}