@mantine/code-highlight 7.0.0-alpha.11 → 7.0.0-alpha.13
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/cjs/CodeHighlight.js +83 -31
- package/cjs/CodeHighlight.js.map +1 -1
- package/cjs/CodeHighlightTabs.js +150 -60
- package/cjs/CodeHighlightTabs.js.map +1 -1
- package/cjs/CopyIcon.js +44 -9
- package/cjs/CopyIcon.js.map +1 -1
- package/cjs/ExpandIcon.js +43 -15
- package/cjs/ExpandIcon.js.map +1 -1
- package/cjs/FileIcon.js +7 -7
- package/cjs/FileIcon.js.map +1 -1
- package/cjs/InlineCodeHighlight.js +57 -19
- package/cjs/InlineCodeHighlight.js.map +1 -1
- package/cjs/use-highlight.js +13 -13
- package/cjs/use-highlight.js.map +1 -1
- package/esm/CodeHighlight.js +83 -31
- package/esm/CodeHighlight.js.map +1 -1
- package/esm/CodeHighlightTabs.js +150 -60
- package/esm/CodeHighlightTabs.js.map +1 -1
- package/esm/CopyIcon.js +44 -9
- package/esm/CopyIcon.js.map +1 -1
- package/esm/ExpandIcon.js +43 -15
- package/esm/ExpandIcon.js.map +1 -1
- package/esm/FileIcon.js +7 -7
- package/esm/FileIcon.js.map +1 -1
- package/esm/InlineCodeHighlight.js +57 -19
- package/esm/InlineCodeHighlight.js.map +1 -1
- package/esm/use-highlight.js +13 -13
- package/esm/use-highlight.js.map +1 -1
- package/package.json +3 -3
- package/tsconfig.build.tsbuildinfo +1 -1
- package/cjs/src/mantine-code-highlight/src/CodeHighlight.js +0 -55
- package/cjs/src/mantine-code-highlight/src/CodeHighlight.js.map +0 -1
- package/cjs/src/mantine-code-highlight/src/CodeHighlight.module.css.js +0 -8
- package/cjs/src/mantine-code-highlight/src/CodeHighlight.module.css.js.map +0 -1
- package/cjs/src/mantine-code-highlight/src/CodeHighlight.theme.module.css.js +0 -8
- package/cjs/src/mantine-code-highlight/src/CodeHighlight.theme.module.css.js.map +0 -1
- package/cjs/src/mantine-code-highlight/src/CodeHighlightTabs.js +0 -90
- package/cjs/src/mantine-code-highlight/src/CodeHighlightTabs.js.map +0 -1
- package/cjs/src/mantine-code-highlight/src/CopyIcon.js +0 -25
- package/cjs/src/mantine-code-highlight/src/CopyIcon.js.map +0 -1
- package/cjs/src/mantine-code-highlight/src/ExpandIcon.js +0 -31
- package/cjs/src/mantine-code-highlight/src/ExpandIcon.js.map +0 -1
- package/cjs/src/mantine-code-highlight/src/FileIcon.js +0 -22
- package/cjs/src/mantine-code-highlight/src/FileIcon.js.map +0 -1
- package/cjs/src/mantine-code-highlight/src/InlineCodeHighlight.js +0 -43
- package/cjs/src/mantine-code-highlight/src/InlineCodeHighlight.js.map +0 -1
- package/cjs/src/mantine-code-highlight/src/index.js +0 -14
- package/cjs/src/mantine-code-highlight/src/index.js.map +0 -1
- package/cjs/src/mantine-code-highlight/src/use-highlight.js +0 -29
- package/cjs/src/mantine-code-highlight/src/use-highlight.js.map +0 -1
- package/esm/src/mantine-code-highlight/src/CodeHighlight.js +0 -46
- package/esm/src/mantine-code-highlight/src/CodeHighlight.js.map +0 -1
- package/esm/src/mantine-code-highlight/src/CodeHighlight.module.css.js +0 -4
- package/esm/src/mantine-code-highlight/src/CodeHighlight.module.css.js.map +0 -1
- package/esm/src/mantine-code-highlight/src/CodeHighlight.theme.module.css.js +0 -4
- package/esm/src/mantine-code-highlight/src/CodeHighlight.theme.module.css.js.map +0 -1
- package/esm/src/mantine-code-highlight/src/CodeHighlightTabs.js +0 -80
- package/esm/src/mantine-code-highlight/src/CodeHighlightTabs.js.map +0 -1
- package/esm/src/mantine-code-highlight/src/CopyIcon.js +0 -17
- package/esm/src/mantine-code-highlight/src/CopyIcon.js.map +0 -1
- package/esm/src/mantine-code-highlight/src/ExpandIcon.js +0 -23
- package/esm/src/mantine-code-highlight/src/ExpandIcon.js.map +0 -1
- package/esm/src/mantine-code-highlight/src/FileIcon.js +0 -14
- package/esm/src/mantine-code-highlight/src/FileIcon.js.map +0 -1
- package/esm/src/mantine-code-highlight/src/InlineCodeHighlight.js +0 -33
- package/esm/src/mantine-code-highlight/src/InlineCodeHighlight.js.map +0 -1
- package/esm/src/mantine-code-highlight/src/index.js +0 -4
- package/esm/src/mantine-code-highlight/src/index.js.map +0 -1
- package/esm/src/mantine-code-highlight/src/use-highlight.js +0 -21
- package/esm/src/mantine-code-highlight/src/use-highlight.js.map +0 -1
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
-
|
|
5
|
-
var tslib_es6 = require('../../../node_modules/tslib/tslib.es6.js');
|
|
6
|
-
var React = require('react');
|
|
7
|
-
var cx = require('clsx');
|
|
8
|
-
var core = require('@mantine/core');
|
|
9
|
-
var useHighlight = require('./use-highlight.js');
|
|
10
|
-
var CopyIcon = require('./CopyIcon.js');
|
|
11
|
-
var CodeHighlight_module = require('./CodeHighlight.module.css.js');
|
|
12
|
-
var CodeHighlight_theme_module = require('./CodeHighlight.theme.module.css.js');
|
|
13
|
-
|
|
14
|
-
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e['default'] : e; }
|
|
15
|
-
|
|
16
|
-
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
17
|
-
var cx__default = /*#__PURE__*/_interopDefaultLegacy(cx);
|
|
18
|
-
|
|
19
|
-
const classes = Object.assign(Object.assign({}, CodeHighlight_module['default']), { root: cx__default(CodeHighlight_module['default'].root, CodeHighlight_theme_module['default'].theme) });
|
|
20
|
-
const defaultProps = {
|
|
21
|
-
copyLabel: 'Copy code',
|
|
22
|
-
copiedLabel: 'Copied',
|
|
23
|
-
language: 'tsx',
|
|
24
|
-
withCopyButton: true,
|
|
25
|
-
};
|
|
26
|
-
const CodeHighlight = core.factory((_props, ref) => {
|
|
27
|
-
const props = core.useProps('CodeHighlight', defaultProps, _props);
|
|
28
|
-
const { classNames, className, style, styles, unstyled, vars, children, code, copiedLabel, copyLabel, language, withCopyButton, highlightOnClient } = props, others = tslib_es6.__rest(props, ["classNames", "className", "style", "styles", "unstyled", "vars", "children", "code", "copiedLabel", "copyLabel", "language", "withCopyButton", "highlightOnClient"]);
|
|
29
|
-
const getStyles = core.useStyles({
|
|
30
|
-
name: 'CodeHighlight',
|
|
31
|
-
props,
|
|
32
|
-
classes,
|
|
33
|
-
className,
|
|
34
|
-
style,
|
|
35
|
-
classNames,
|
|
36
|
-
styles,
|
|
37
|
-
unstyled,
|
|
38
|
-
});
|
|
39
|
-
const getCodeProps = useHighlight.useHighlight({
|
|
40
|
-
code,
|
|
41
|
-
language: language,
|
|
42
|
-
highlightOnClient,
|
|
43
|
-
});
|
|
44
|
-
return (React__default.createElement(core.Box, Object.assign({}, getStyles('root'), { ref: ref }, others, { dir: "ltr" }),
|
|
45
|
-
withCopyButton && (React__default.createElement(core.CopyButton, { value: code.trim() }, ({ copied, copy }) => (React__default.createElement(core.Tooltip, { label: copied ? copiedLabel : copyLabel, fz: "sm", position: "left" },
|
|
46
|
-
React__default.createElement(core.ActionIcon, Object.assign({ onClick: copy, variant: "none" }, getStyles('copy')),
|
|
47
|
-
React__default.createElement(CopyIcon.CopyIcon, { copied: copied })))))),
|
|
48
|
-
React__default.createElement(core.ScrollArea, { type: "auto", dir: "ltr", offsetScrollbars: false },
|
|
49
|
-
React__default.createElement("pre", Object.assign({}, getStyles('pre')),
|
|
50
|
-
React__default.createElement("code", Object.assign({}, getStyles('code'), getCodeProps()))))));
|
|
51
|
-
});
|
|
52
|
-
CodeHighlight.displayName = '@mantine/core/CodeHighlight';
|
|
53
|
-
|
|
54
|
-
exports.CodeHighlight = CodeHighlight;
|
|
55
|
-
//# sourceMappingURL=CodeHighlight.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"CodeHighlight.js","sources":["../../../../src/CodeHighlight.tsx"],"sourcesContent":["import React from 'react';\nimport cx from 'clsx';\nimport {\n Box,\n BoxProps,\n StylesApiProps,\n factory,\n ElementProps,\n useProps,\n useStyles,\n CopyButton,\n Tooltip,\n ActionIcon,\n ScrollArea,\n Factory,\n} from '@mantine/core';\nimport { useHighlight } from './use-highlight';\nimport { CopyIcon } from './CopyIcon';\nimport _classes from './CodeHighlight.module.css';\nimport themeClasses from './CodeHighlight.theme.module.css';\n\nconst classes = { ..._classes, root: cx(_classes.root, themeClasses.theme) };\n\nexport type CodeHighlightStylesNames = 'root' | 'code' | 'pre' | 'copy';\nexport type CodeHighlightVariant = string;\n\nexport interface CodeHighlightProps\n extends BoxProps,\n StylesApiProps<CodeHighlightFactory>,\n ElementProps<'div'> {\n /** Code to highlight */\n code: string;\n\n /** Code language, `'tsx'` by default */\n language?: string;\n\n /** Determines whether copy button should be displayed, `true` by default */\n withCopyButton?: boolean;\n\n /** Copy tooltip label, `'Copy code'` by default */\n copyLabel?: string;\n\n /** Copied tooltip label, `'Copied'` by default */\n copiedLabel?: string;\n\n /** Determines whether code should be highlighted only after component is mounted to the dom (disables code highlight on server), `false` by default */\n highlightOnClient?: boolean;\n}\n\nexport type CodeHighlightFactory = Factory<{\n props: CodeHighlightProps;\n ref: HTMLDivElement;\n stylesNames: CodeHighlightStylesNames;\n variant: CodeHighlightVariant;\n}>;\n\nconst defaultProps: Partial<CodeHighlightProps> = {\n copyLabel: 'Copy code',\n copiedLabel: 'Copied',\n language: 'tsx',\n withCopyButton: true,\n};\n\nexport const CodeHighlight = factory<CodeHighlightFactory>((_props, ref) => {\n const props = useProps('CodeHighlight', defaultProps, _props);\n const {\n classNames,\n className,\n style,\n styles,\n unstyled,\n vars,\n children,\n code,\n copiedLabel,\n copyLabel,\n language,\n withCopyButton,\n highlightOnClient,\n ...others\n } = props;\n\n const getStyles = useStyles<CodeHighlightFactory>({\n name: 'CodeHighlight',\n props,\n classes,\n className,\n style,\n classNames,\n styles,\n unstyled,\n });\n\n const getCodeProps = useHighlight({\n code,\n language: language!,\n highlightOnClient,\n });\n\n return (\n <Box {...getStyles('root')} ref={ref} {...others} dir=\"ltr\">\n {withCopyButton && (\n <CopyButton value={code.trim()}>\n {({ copied, copy }) => (\n <Tooltip label={copied ? copiedLabel : copyLabel} fz=\"sm\" position=\"left\">\n <ActionIcon onClick={copy} variant=\"none\" {...getStyles('copy')}>\n <CopyIcon copied={copied} />\n </ActionIcon>\n </Tooltip>\n )}\n </CopyButton>\n )}\n\n <ScrollArea type=\"auto\" dir=\"ltr\" offsetScrollbars={false}>\n <pre {...getStyles('pre')}>\n <code {...getStyles('code')} {...getCodeProps()} />\n </pre>\n </ScrollArea>\n </Box>\n );\n});\n\nCodeHighlight.displayName = '@mantine/core/CodeHighlight';\n"],"names":["_classes","cx","themeClasses","factory","useProps","useStyles","useHighlight","React","Box","CopyButton","Tooltip","ActionIcon","CopyIcon","ScrollArea"],"mappings":";;;;;;;;;;;;;;;;;;AAqBA,MAAM,OAAO,mCAAQA,+BAAQ,KAAE,IAAI,EAAEC,WAAE,CAACD,+BAAQ,CAAC,IAAI,EAAEE,qCAAY,CAAC,KAAK,CAAC,GAAE,CAAC;AAmC7E,MAAM,YAAY,GAAgC;IAChD,SAAS,EAAE,WAAW;IACtB,WAAW,EAAE,QAAQ;IACrB,QAAQ,EAAE,KAAK;IACf,cAAc,EAAE,IAAI;CACrB,CAAC;MAEW,aAAa,GAAGC,YAAO,CAAuB,CAAC,MAAM,EAAE,GAAG;IACrE,MAAM,KAAK,GAAGC,aAAQ,CAAC,eAAe,EAAE,YAAY,EAAE,MAAM,CAAC,CAAC;IAC9D,MAAM,EACJ,UAAU,EACV,SAAS,EACT,KAAK,EACL,MAAM,EACN,QAAQ,EACR,IAAI,EACJ,QAAQ,EACR,IAAI,EACJ,WAAW,EACX,SAAS,EACT,QAAQ,EACR,cAAc,EACd,iBAAiB,KAEf,KAAK,EADJ,MAAM,oBACP,KAAK,EAfH,qKAeL,CAAQ,CAAC;IAEV,MAAM,SAAS,GAAGC,cAAS,CAAuB;QAChD,IAAI,EAAE,eAAe;QACrB,KAAK;QACL,OAAO;QACP,SAAS;QACT,KAAK;QACL,UAAU;QACV,MAAM;QACN,QAAQ;KACT,CAAC,CAAC;IAEH,MAAM,YAAY,GAAGC,yBAAY,CAAC;QAChC,IAAI;QACJ,QAAQ,EAAE,QAAS;QACnB,iBAAiB;KAClB,CAAC,CAAC;IAEH,QACEC,6BAACC,QAAG,oBAAK,SAAS,CAAC,MAAM,CAAC,IAAE,GAAG,EAAE,GAAG,IAAM,MAAM,IAAE,GAAG,EAAC,KAAK;QACxD,cAAc,KACbD,6BAACE,eAAU,IAAC,KAAK,EAAE,IAAI,CAAC,IAAI,EAAE,IAC3B,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,MAChBF,6BAACG,YAAO,IAAC,KAAK,EAAE,MAAM,GAAG,WAAW,GAAG,SAAS,EAAE,EAAE,EAAC,IAAI,EAAC,QAAQ,EAAC,MAAM;YACvEH,6BAACI,eAAU,kBAAC,OAAO,EAAE,IAAI,EAAE,OAAO,EAAC,MAAM,IAAK,SAAS,CAAC,MAAM,CAAC;gBAC7DJ,6BAACK,iBAAQ,IAAC,MAAM,EAAE,MAAM,GAAI,CACjB,CACL,CACX,CACU,CACd;QAEDL,6BAACM,eAAU,IAAC,IAAI,EAAC,MAAM,EAAC,GAAG,EAAC,KAAK,EAAC,gBAAgB,EAAE,KAAK;YACvDN,sDAAS,SAAS,CAAC,KAAK,CAAC;gBACvBA,uDAAU,SAAS,CAAC,MAAM,CAAC,EAAM,YAAY,EAAE,EAAI,CAC/C,CACK,CACT,EACN;AACJ,CAAC,EAAE;AAEH,aAAa,CAAC,WAAW,GAAG,6BAA6B;;;;"}
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
-
|
|
5
|
-
var _classes = {"code":"mantine-XIBJZDt","pre":"mantine-RDvBcjB","header":"mantine-cmEtjrV","controls":"mantine-059sM-t","copy":"mantine-tB-P5PD","control":"mantine-NTm-nGn","file":"mantine-PBrPXnu","files":"mantine-IvOddiX","codeWrapper":"mantine-YfYyOiA","showCodeButton":"mantine-haNyFRC","root":"mantine-k6OJW8l"};
|
|
6
|
-
|
|
7
|
-
exports.default = _classes;
|
|
8
|
-
//# sourceMappingURL=CodeHighlight.module.css.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"CodeHighlight.module.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"CodeHighlight.theme.module.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;"}
|
|
@@ -1,90 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
-
|
|
5
|
-
var tslib_es6 = require('../../../node_modules/tslib/tslib.es6.js');
|
|
6
|
-
var React = require('react');
|
|
7
|
-
var hljs = require('highlight.js');
|
|
8
|
-
var cx = require('clsx');
|
|
9
|
-
var hooks = require('@mantine/hooks');
|
|
10
|
-
var core = require('@mantine/core');
|
|
11
|
-
var CopyIcon = require('./CopyIcon.js');
|
|
12
|
-
var FileIcon = require('./FileIcon.js');
|
|
13
|
-
var ExpandIcon = require('./ExpandIcon.js');
|
|
14
|
-
var CodeHighlight_module = require('./CodeHighlight.module.css.js');
|
|
15
|
-
var CodeHighlight_theme_module = require('./CodeHighlight.theme.module.css.js');
|
|
16
|
-
|
|
17
|
-
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e['default'] : e; }
|
|
18
|
-
|
|
19
|
-
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
20
|
-
var hljs__default = /*#__PURE__*/_interopDefaultLegacy(hljs);
|
|
21
|
-
var cx__default = /*#__PURE__*/_interopDefaultLegacy(cx);
|
|
22
|
-
|
|
23
|
-
const classes = Object.assign(Object.assign({}, CodeHighlight_module['default']), { root: cx__default(CodeHighlight_module['default'].root, CodeHighlight_theme_module['default'].theme) });
|
|
24
|
-
const defaultProps = {
|
|
25
|
-
withHeader: true,
|
|
26
|
-
copyLabel: 'Copy code',
|
|
27
|
-
copiedLabel: 'Copied',
|
|
28
|
-
maxCollapsedHeight: core.rem('8rem'),
|
|
29
|
-
expandCodeLabel: 'Expand code',
|
|
30
|
-
collapseCodeLabel: 'Collapse code',
|
|
31
|
-
};
|
|
32
|
-
const varsResolver = core.createVarsResolver((_, { maxCollapsedHeight }) => ({
|
|
33
|
-
root: { '--ch-max-collapsed-height': core.rem(maxCollapsedHeight) },
|
|
34
|
-
}));
|
|
35
|
-
const CodeHighlightTabs = core.factory((_props, ref) => {
|
|
36
|
-
const props = core.useProps('CodeHighlightTabs', defaultProps, _props);
|
|
37
|
-
const { classNames, className, style, styles, unstyled, vars, children, code, defaultActiveTab, activeTab, onTabChange, withHeader, copiedLabel, copyLabel, getFileIcon, maxCollapsedHeight, expanded, defaultExpanded, onExpandedChange, expandCodeLabel, collapseCodeLabel, withExpandButton } = props, others = tslib_es6.__rest(props, ["classNames", "className", "style", "styles", "unstyled", "vars", "children", "code", "defaultActiveTab", "activeTab", "onTabChange", "withHeader", "copiedLabel", "copyLabel", "getFileIcon", "maxCollapsedHeight", "expanded", "defaultExpanded", "onExpandedChange", "expandCodeLabel", "collapseCodeLabel", "withExpandButton"]);
|
|
38
|
-
const getStyles = core.useStyles({
|
|
39
|
-
name: 'CodeHighlightTabs',
|
|
40
|
-
props,
|
|
41
|
-
classes,
|
|
42
|
-
className,
|
|
43
|
-
style,
|
|
44
|
-
classNames,
|
|
45
|
-
styles,
|
|
46
|
-
unstyled,
|
|
47
|
-
vars,
|
|
48
|
-
varsResolver,
|
|
49
|
-
});
|
|
50
|
-
const [value, setValue] = hooks.useUncontrolled({
|
|
51
|
-
defaultValue: defaultActiveTab,
|
|
52
|
-
value: activeTab,
|
|
53
|
-
finalValue: 0,
|
|
54
|
-
onChange: onTabChange,
|
|
55
|
-
});
|
|
56
|
-
const [_expanded, setExpanded] = hooks.useUncontrolled({
|
|
57
|
-
defaultValue: defaultExpanded,
|
|
58
|
-
value: expanded,
|
|
59
|
-
finalValue: true,
|
|
60
|
-
onChange: onExpandedChange,
|
|
61
|
-
});
|
|
62
|
-
const nodes = Array.isArray(code) ? code : [code];
|
|
63
|
-
const currentCode = nodes[value];
|
|
64
|
-
const highlighted = hljs__default.highlight(currentCode.code.trim(), {
|
|
65
|
-
language: currentCode.language,
|
|
66
|
-
}).value;
|
|
67
|
-
const files = nodes.map((node, index) => (React__default.createElement(core.UnstyledButton, Object.assign({}, getStyles('file'), { key: node.fileName, mod: { active: index === value }, onClick: () => setValue(index) }),
|
|
68
|
-
React__default.createElement(FileIcon.FileIcon, { fileIcon: node.icon, getFileIcon: getFileIcon, fileName: node.fileName }),
|
|
69
|
-
React__default.createElement("span", null, node.fileName))));
|
|
70
|
-
return (React__default.createElement(core.Box, Object.assign({}, getStyles('root'), { ref: ref }, others, { dir: "ltr" }),
|
|
71
|
-
withHeader && (React__default.createElement("div", Object.assign({}, getStyles('header')),
|
|
72
|
-
React__default.createElement(core.ScrollArea, { type: "never", dir: "ltr", offsetScrollbars: false },
|
|
73
|
-
React__default.createElement("div", Object.assign({}, getStyles('files')), files)),
|
|
74
|
-
React__default.createElement("div", Object.assign({}, getStyles('controls')),
|
|
75
|
-
withExpandButton && (React__default.createElement(core.Tooltip, { label: _expanded ? collapseCodeLabel : expandCodeLabel, fz: "sm", position: "left" },
|
|
76
|
-
React__default.createElement(core.ActionIcon, Object.assign({ onClick: () => setExpanded(!_expanded), variant: "none" }, getStyles('control')),
|
|
77
|
-
React__default.createElement(ExpandIcon.ExpandIcon, { expanded: _expanded })))),
|
|
78
|
-
React__default.createElement(core.CopyButton, { value: currentCode.code.trim() }, ({ copied, copy }) => (React__default.createElement(core.Tooltip, { label: copied ? copiedLabel : copyLabel, fz: "sm", position: "left" },
|
|
79
|
-
React__default.createElement(core.ActionIcon, Object.assign({ onClick: copy, variant: "none" }, getStyles('control')),
|
|
80
|
-
React__default.createElement(CopyIcon.CopyIcon, { copied: copied })))))))),
|
|
81
|
-
React__default.createElement(core.ScrollArea, { type: "auto", dir: "ltr", offsetScrollbars: false },
|
|
82
|
-
React__default.createElement(core.Box, Object.assign({}, getStyles('codeWrapper'), { mod: { expanded: _expanded } }),
|
|
83
|
-
React__default.createElement("pre", Object.assign({}, getStyles('pre')),
|
|
84
|
-
React__default.createElement("code", Object.assign({}, getStyles('code'), { dangerouslySetInnerHTML: { __html: highlighted } }))))),
|
|
85
|
-
React__default.createElement(core.UnstyledButton, Object.assign({}, getStyles('showCodeButton'), { mod: { hidden: _expanded }, onClick: () => setExpanded(true) }), "Expand code")));
|
|
86
|
-
});
|
|
87
|
-
CodeHighlightTabs.displayName = '@mantine/core/CodeHighlightTabs';
|
|
88
|
-
|
|
89
|
-
exports.CodeHighlightTabs = CodeHighlightTabs;
|
|
90
|
-
//# sourceMappingURL=CodeHighlightTabs.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"CodeHighlightTabs.js","sources":["../../../../src/CodeHighlightTabs.tsx"],"sourcesContent":["import React from 'react';\nimport hljs from 'highlight.js';\nimport cx from 'clsx';\nimport { useUncontrolled } from '@mantine/hooks';\nimport {\n Box,\n BoxProps,\n StylesApiProps,\n factory,\n ElementProps,\n useProps,\n useStyles,\n CopyButton,\n Tooltip,\n ActionIcon,\n UnstyledButton,\n ScrollArea,\n createVarsResolver,\n rem,\n Factory,\n} from '@mantine/core';\nimport { CopyIcon } from './CopyIcon';\nimport { FileIcon } from './FileIcon';\nimport { ExpandIcon } from './ExpandIcon';\nimport _classes from './CodeHighlight.module.css';\nimport themeClasses from './CodeHighlight.theme.module.css';\n\nconst classes = { ..._classes, root: cx(_classes.root, themeClasses.theme) };\n\nexport type CodeHighlightTabsStylesNames =\n | 'root'\n | 'code'\n | 'codeWrapper'\n | 'showCodeButton'\n | 'pre'\n | 'controls'\n | 'control'\n | 'header'\n | 'file'\n | 'files';\n\nexport type CodeHighlightTabsVariant = string;\nexport type CodeHighlightTabsCssVariables = {\n root: '--ch-max-collapsed-height';\n};\n\nexport interface CodeHighlightTabsCode {\n language?: string;\n code: string;\n fileName?: string;\n icon?: React.ReactNode;\n}\n\nexport interface CodeHighlightTabsProps\n extends BoxProps,\n StylesApiProps<CodeHighlightTabsFactory>,\n ElementProps<'div'> {\n /** Code to highlight with meta data (file name and icon) */\n code: CodeHighlightTabsCode | CodeHighlightTabsCode[];\n\n /** Default active tab index */\n defaultActiveTab?: number;\n\n /** Index of controlled active tab state */\n activeTab?: number;\n\n /** Called when tab changes */\n onTabChange?(tab: number): void;\n\n /** Determines whether header with file names and copy button should be rendered, `true` by default */\n withHeader?: boolean;\n\n /** Copy tooltip label, `'Copy code'` by default */\n copyLabel?: string;\n\n /** Copied tooltip label, `'Copied'` by default */\n copiedLabel?: string;\n\n /** Function that returns icon based on file name */\n getFileIcon?(fileName: string): React.ReactNode;\n\n /** `max-height` of code in collapsed state */\n maxCollapsedHeight?: React.CSSProperties['maxHeight'];\n\n /** Controlled expanded state */\n expanded?: boolean;\n\n /** Uncontrolled expanded state initial value */\n defaultExpanded?: boolean;\n\n /** Called when expanded state changes */\n onExpandedChange?(expanded: boolean): void;\n\n /** Expand button label and tooltip, `'Expand code'` by default */\n expandCodeLabel?: string;\n\n /** Collapse button label and tooltip, `'Collapse code'` by default */\n collapseCodeLabel?: string;\n\n /** Determines whether to show the expand button, `false` by default */\n withExpandButton?: boolean;\n}\n\nexport type CodeHighlightTabsFactory = Factory<{\n props: CodeHighlightTabsProps;\n ref: HTMLDivElement;\n stylesNames: CodeHighlightTabsStylesNames;\n}>;\n\nconst defaultProps: Partial<CodeHighlightTabsProps> = {\n withHeader: true,\n copyLabel: 'Copy code',\n copiedLabel: 'Copied',\n maxCollapsedHeight: rem('8rem'),\n expandCodeLabel: 'Expand code',\n collapseCodeLabel: 'Collapse code',\n};\n\nconst varsResolver = createVarsResolver<CodeHighlightTabsFactory>((_, { maxCollapsedHeight }) => ({\n root: { '--ch-max-collapsed-height': rem(maxCollapsedHeight) },\n}));\n\nexport const CodeHighlightTabs = factory<CodeHighlightTabsFactory>((_props, ref) => {\n const props = useProps('CodeHighlightTabs', defaultProps, _props);\n const {\n classNames,\n className,\n style,\n styles,\n unstyled,\n vars,\n children,\n code,\n defaultActiveTab,\n activeTab,\n onTabChange,\n withHeader,\n copiedLabel,\n copyLabel,\n getFileIcon,\n maxCollapsedHeight,\n expanded,\n defaultExpanded,\n onExpandedChange,\n expandCodeLabel,\n collapseCodeLabel,\n withExpandButton,\n ...others\n } = props;\n\n const getStyles = useStyles<CodeHighlightTabsFactory>({\n name: 'CodeHighlightTabs',\n props,\n classes,\n className,\n style,\n classNames,\n styles,\n unstyled,\n vars,\n varsResolver,\n });\n\n const [value, setValue] = useUncontrolled({\n defaultValue: defaultActiveTab,\n value: activeTab,\n finalValue: 0,\n onChange: onTabChange,\n });\n\n const [_expanded, setExpanded] = useUncontrolled({\n defaultValue: defaultExpanded,\n value: expanded,\n finalValue: true,\n onChange: onExpandedChange,\n });\n\n const nodes = Array.isArray(code) ? code : [code];\n const currentCode = nodes[value];\n\n const highlighted = hljs.highlight(currentCode.code.trim(), {\n language: currentCode.language!,\n }).value;\n\n const files = nodes.map((node, index) => (\n <UnstyledButton\n {...getStyles('file')}\n key={node.fileName}\n mod={{ active: index === value }}\n onClick={() => setValue(index)}\n >\n <FileIcon fileIcon={node.icon} getFileIcon={getFileIcon} fileName={node.fileName} />\n <span>{node.fileName}</span>\n </UnstyledButton>\n ));\n\n return (\n <Box {...getStyles('root')} ref={ref} {...others} dir=\"ltr\">\n {withHeader && (\n <div {...getStyles('header')}>\n <ScrollArea type=\"never\" dir=\"ltr\" offsetScrollbars={false}>\n <div {...getStyles('files')}>{files}</div>\n </ScrollArea>\n <div {...getStyles('controls')}>\n {withExpandButton && (\n <Tooltip\n label={_expanded ? collapseCodeLabel : expandCodeLabel}\n fz=\"sm\"\n position=\"left\"\n >\n <ActionIcon\n onClick={() => setExpanded(!_expanded)}\n variant=\"none\"\n {...getStyles('control')}\n >\n <ExpandIcon expanded={_expanded} />\n </ActionIcon>\n </Tooltip>\n )}\n\n <CopyButton value={currentCode.code.trim()}>\n {({ copied, copy }) => (\n <Tooltip label={copied ? copiedLabel : copyLabel} fz=\"sm\" position=\"left\">\n <ActionIcon onClick={copy} variant=\"none\" {...getStyles('control')}>\n <CopyIcon copied={copied} />\n </ActionIcon>\n </Tooltip>\n )}\n </CopyButton>\n </div>\n </div>\n )}\n\n <ScrollArea type=\"auto\" dir=\"ltr\" offsetScrollbars={false}>\n <Box {...getStyles('codeWrapper')} mod={{ expanded: _expanded }}>\n <pre {...getStyles('pre')}>\n <code {...getStyles('code')} dangerouslySetInnerHTML={{ __html: highlighted }} />\n </pre>\n </Box>\n </ScrollArea>\n <UnstyledButton\n {...getStyles('showCodeButton')}\n mod={{ hidden: _expanded }}\n onClick={() => setExpanded(true)}\n >\n Expand code\n </UnstyledButton>\n </Box>\n );\n});\n\nCodeHighlightTabs.displayName = '@mantine/core/CodeHighlightTabs';\n"],"names":["_classes","cx","themeClasses","rem","createVarsResolver","factory","useProps","useStyles","useUncontrolled","hljs","React","UnstyledButton","FileIcon","Box","ScrollArea","Tooltip","ActionIcon","ExpandIcon","CopyButton","CopyIcon"],"mappings":"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"}
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
-
|
|
5
|
-
var tslib_es6 = require('../../../node_modules/tslib/tslib.es6.js');
|
|
6
|
-
var core = require('@mantine/core');
|
|
7
|
-
var React = require('react');
|
|
8
|
-
|
|
9
|
-
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e['default'] : e; }
|
|
10
|
-
|
|
11
|
-
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
12
|
-
|
|
13
|
-
function CopyIcon(_a) {
|
|
14
|
-
var { copied, style } = _a, others = tslib_es6.__rest(_a, ["copied", "style"]);
|
|
15
|
-
return (React__default.createElement("svg", Object.assign({ xmlns: "http://www.w3.org/2000/svg", style: Object.assign({ width: core.rem(18), height: core.rem(18) }, style), viewBox: "0 0 24 24", strokeWidth: "2", stroke: "currentColor", fill: "none", strokeLinecap: "round", strokeLinejoin: "round" }, others), copied ? (React__default.createElement(React__default.Fragment, null,
|
|
16
|
-
React__default.createElement("path", { stroke: "none", d: "M0 0h24v24H0z", fill: "none" }),
|
|
17
|
-
React__default.createElement("path", { d: "M5 12l5 5l10 -10" }))) : (React__default.createElement(React__default.Fragment, null,
|
|
18
|
-
React__default.createElement("path", { stroke: "none", d: "M0 0h24v24H0z", fill: "none" }),
|
|
19
|
-
React__default.createElement("path", { d: "M8 8m0 2a2 2 0 0 1 2 -2h8a2 2 0 0 1 2 2v8a2 2 0 0 1 -2 2h-8a2 2 0 0 1 -2 -2z" }),
|
|
20
|
-
React__default.createElement("path", { d: "M16 8v-2a2 2 0 0 0 -2 -2h-8a2 2 0 0 0 -2 2v8a2 2 0 0 0 2 2h2" })))));
|
|
21
|
-
}
|
|
22
|
-
CopyIcon.displayName = '@mantine/code-highlight/CopyIcon';
|
|
23
|
-
|
|
24
|
-
exports.CopyIcon = CopyIcon;
|
|
25
|
-
//# sourceMappingURL=CopyIcon.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"CopyIcon.js","sources":["../../../../src/CopyIcon.tsx"],"sourcesContent":["import { rem } from '@mantine/core';\nimport React from 'react';\n\ninterface CopyIconProps extends React.ComponentPropsWithoutRef<'svg'> {\n copied: boolean;\n}\n\nexport function CopyIcon({ copied, style, ...others }: CopyIconProps) {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n style={{ width: rem(18), height: rem(18), ...style }}\n viewBox=\"0 0 24 24\"\n strokeWidth=\"2\"\n stroke=\"currentColor\"\n fill=\"none\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n {...others}\n >\n {copied ? (\n <>\n <path stroke=\"none\" d=\"M0 0h24v24H0z\" fill=\"none\"></path>\n <path d=\"M5 12l5 5l10 -10\"></path>\n </>\n ) : (\n <>\n <path stroke=\"none\" d=\"M0 0h24v24H0z\" fill=\"none\"></path>\n <path d=\"M8 8m0 2a2 2 0 0 1 2 -2h8a2 2 0 0 1 2 2v8a2 2 0 0 1 -2 2h-8a2 2 0 0 1 -2 -2z\"></path>\n <path d=\"M16 8v-2a2 2 0 0 0 -2 -2h-8a2 2 0 0 0 -2 2v8a2 2 0 0 0 2 2h2\"></path>\n </>\n )}\n </svg>\n );\n}\n\nCopyIcon.displayName = '@mantine/code-highlight/CopyIcon';\n"],"names":["React","rem"],"mappings":";;;;;;;;;;;;SAOgB,QAAQ,CAAC,EAA2C;QAA3C,EAAE,MAAM,EAAE,KAAK,OAA4B,EAAvB,MAAM,wBAA1B,mBAA4B,CAAF;IACjD,QACEA,oDACE,KAAK,EAAC,4BAA4B,EAClC,KAAK,kBAAI,KAAK,EAAEC,QAAG,CAAC,EAAE,CAAC,EAAE,MAAM,EAAEA,QAAG,CAAC,EAAE,CAAC,IAAK,KAAK,GAClD,OAAO,EAAC,WAAW,EACnB,WAAW,EAAC,GAAG,EACf,MAAM,EAAC,cAAc,EACrB,IAAI,EAAC,MAAM,EACX,aAAa,EAAC,OAAO,EACrB,cAAc,EAAC,OAAO,IAClB,MAAM,GAET,MAAM,IACLD;QACEA,uCAAM,MAAM,EAAC,MAAM,EAAC,CAAC,EAAC,eAAe,EAAC,IAAI,EAAC,MAAM,GAAQ;QACzDA,uCAAM,CAAC,EAAC,kBAAkB,GAAQ,CACjC,KAEHA;QACEA,uCAAM,MAAM,EAAC,MAAM,EAAC,CAAC,EAAC,eAAe,EAAC,IAAI,EAAC,MAAM,GAAQ;QACzDA,uCAAM,CAAC,EAAC,8EAA8E,GAAQ;QAC9FA,uCAAM,CAAC,EAAC,8DAA8D,GAAQ,CAC7E,CACJ,CACG,EACN;AACJ,CAAC;AAED,QAAQ,CAAC,WAAW,GAAG,kCAAkC;;;;"}
|
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
-
|
|
5
|
-
var tslib_es6 = require('../../../node_modules/tslib/tslib.es6.js');
|
|
6
|
-
var core = require('@mantine/core');
|
|
7
|
-
var React = require('react');
|
|
8
|
-
|
|
9
|
-
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e['default'] : e; }
|
|
10
|
-
|
|
11
|
-
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
12
|
-
|
|
13
|
-
function ExpandIcon(_a) {
|
|
14
|
-
var { expanded, style } = _a, others = tslib_es6.__rest(_a, ["expanded", "style"]);
|
|
15
|
-
return (React__default.createElement("svg", Object.assign({ xmlns: "http://www.w3.org/2000/svg", style: Object.assign({ width: core.rem(18), height: core.rem(18) }, style), viewBox: "0 0 24 24", strokeWidth: "2", stroke: "currentColor", fill: "none", strokeLinecap: "round", strokeLinejoin: "round" }, others), expanded ? (React__default.createElement(React__default.Fragment, null,
|
|
16
|
-
React__default.createElement("path", { stroke: "none", d: "M0 0h24v24H0z", fill: "none" }),
|
|
17
|
-
React__default.createElement("path", { d: "M12 13v-8l-3 3m6 0l-3 -3" }),
|
|
18
|
-
React__default.createElement("path", { d: "M9 17l1 0" }),
|
|
19
|
-
React__default.createElement("path", { d: "M14 17l1 0" }),
|
|
20
|
-
React__default.createElement("path", { d: "M19 17l1 0" }),
|
|
21
|
-
React__default.createElement("path", { d: "M4 17l1 0" }))) : (React__default.createElement(React__default.Fragment, null,
|
|
22
|
-
React__default.createElement("path", { stroke: "none", d: "M0 0h24v24H0z", fill: "none" }),
|
|
23
|
-
React__default.createElement("path", { d: "M12 11v8l3 -3m-6 0l3 3" }),
|
|
24
|
-
React__default.createElement("path", { d: "M9 7l1 0" }),
|
|
25
|
-
React__default.createElement("path", { d: "M14 7l1 0" }),
|
|
26
|
-
React__default.createElement("path", { d: "M19 7l1 0" }),
|
|
27
|
-
React__default.createElement("path", { d: "M4 7l1 0" })))));
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
exports.ExpandIcon = ExpandIcon;
|
|
31
|
-
//# sourceMappingURL=ExpandIcon.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ExpandIcon.js","sources":["../../../../src/ExpandIcon.tsx"],"sourcesContent":["import { rem } from '@mantine/core';\nimport React from 'react';\n\ninterface ExpandIconProps extends React.ComponentPropsWithoutRef<'svg'> {\n expanded: boolean;\n}\n\nexport function ExpandIcon({ expanded, style, ...others }: ExpandIconProps) {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n style={{ width: rem(18), height: rem(18), ...style }}\n viewBox=\"0 0 24 24\"\n strokeWidth=\"2\"\n stroke=\"currentColor\"\n fill=\"none\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n {...others}\n >\n {expanded ? (\n <>\n <path stroke=\"none\" d=\"M0 0h24v24H0z\" fill=\"none\" />\n <path d=\"M12 13v-8l-3 3m6 0l-3 -3\" />\n <path d=\"M9 17l1 0\" />\n <path d=\"M14 17l1 0\" />\n <path d=\"M19 17l1 0\" />\n <path d=\"M4 17l1 0\" />\n </>\n ) : (\n <>\n <path stroke=\"none\" d=\"M0 0h24v24H0z\" fill=\"none\" />\n <path d=\"M12 11v8l3 -3m-6 0l3 3\" />\n <path d=\"M9 7l1 0\" />\n <path d=\"M14 7l1 0\" />\n <path d=\"M19 7l1 0\" />\n <path d=\"M4 7l1 0\" />\n </>\n )}\n </svg>\n );\n}\n"],"names":["React","rem"],"mappings":";;;;;;;;;;;;SAOgB,UAAU,CAAC,EAA+C;QAA/C,EAAE,QAAQ,EAAE,KAAK,OAA8B,EAAzB,MAAM,wBAA5B,qBAA8B,CAAF;IACrD,QACEA,oDACE,KAAK,EAAC,4BAA4B,EAClC,KAAK,kBAAI,KAAK,EAAEC,QAAG,CAAC,EAAE,CAAC,EAAE,MAAM,EAAEA,QAAG,CAAC,EAAE,CAAC,IAAK,KAAK,GAClD,OAAO,EAAC,WAAW,EACnB,WAAW,EAAC,GAAG,EACf,MAAM,EAAC,cAAc,EACrB,IAAI,EAAC,MAAM,EACX,aAAa,EAAC,OAAO,EACrB,cAAc,EAAC,OAAO,IAClB,MAAM,GAET,QAAQ,IACPD;QACEA,uCAAM,MAAM,EAAC,MAAM,EAAC,CAAC,EAAC,eAAe,EAAC,IAAI,EAAC,MAAM,GAAG;QACpDA,uCAAM,CAAC,EAAC,0BAA0B,GAAG;QACrCA,uCAAM,CAAC,EAAC,WAAW,GAAG;QACtBA,uCAAM,CAAC,EAAC,YAAY,GAAG;QACvBA,uCAAM,CAAC,EAAC,YAAY,GAAG;QACvBA,uCAAM,CAAC,EAAC,WAAW,GAAG,CACrB,KAEHA;QACEA,uCAAM,MAAM,EAAC,MAAM,EAAC,CAAC,EAAC,eAAe,EAAC,IAAI,EAAC,MAAM,GAAG;QACpDA,uCAAM,CAAC,EAAC,wBAAwB,GAAG;QACnCA,uCAAM,CAAC,EAAC,UAAU,GAAG;QACrBA,uCAAM,CAAC,EAAC,WAAW,GAAG;QACtBA,uCAAM,CAAC,EAAC,WAAW,GAAG;QACtBA,uCAAM,CAAC,EAAC,UAAU,GAAG,CACpB,CACJ,CACG,EACN;AACJ;;;;"}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
-
|
|
5
|
-
var React = require('react');
|
|
6
|
-
|
|
7
|
-
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e['default'] : e; }
|
|
8
|
-
|
|
9
|
-
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
10
|
-
|
|
11
|
-
function FileIcon({ fileIcon, fileName, getFileIcon }) {
|
|
12
|
-
if (fileIcon) {
|
|
13
|
-
return React__default.createElement(React__default.Fragment, null, fileIcon);
|
|
14
|
-
}
|
|
15
|
-
if (getFileIcon && fileName) {
|
|
16
|
-
return React__default.createElement(React__default.Fragment, null, getFileIcon(fileName));
|
|
17
|
-
}
|
|
18
|
-
return null;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
exports.FileIcon = FileIcon;
|
|
22
|
-
//# sourceMappingURL=FileIcon.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"FileIcon.js","sources":["../../../../src/FileIcon.tsx"],"sourcesContent":["import React from 'react';\n\ninterface FileIconProps {\n fileName: string | undefined;\n getFileIcon?: ((fileName: string) => React.ReactNode) | undefined;\n fileIcon: React.ReactNode | undefined;\n}\n\nexport function FileIcon({ fileIcon, fileName, getFileIcon }: FileIconProps) {\n if (fileIcon) {\n return <>{fileIcon}</>;\n }\n\n if (getFileIcon && fileName) {\n return <>{getFileIcon(fileName)}</>;\n }\n\n return null;\n}\n"],"names":["React"],"mappings":";;;;;;;;;;SAQgB,QAAQ,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,WAAW,EAAiB;IACzE,IAAI,QAAQ,EAAE;QACZ,OAAOA,4DAAG,QAAQ,CAAI,CAAC;KACxB;IAED,IAAI,WAAW,IAAI,QAAQ,EAAE;QAC3B,OAAOA,4DAAG,WAAW,CAAC,QAAQ,CAAC,CAAI,CAAC;KACrC;IAED,OAAO,IAAI,CAAC;AACd;;;;"}
|
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
-
|
|
5
|
-
var tslib_es6 = require('../../../node_modules/tslib/tslib.es6.js');
|
|
6
|
-
var React = require('react');
|
|
7
|
-
var cx = require('clsx');
|
|
8
|
-
var core = require('@mantine/core');
|
|
9
|
-
var hljs = require('highlight.js');
|
|
10
|
-
var CodeHighlight_module = require('./CodeHighlight.module.css.js');
|
|
11
|
-
var CodeHighlight_theme_module = require('./CodeHighlight.theme.module.css.js');
|
|
12
|
-
|
|
13
|
-
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e['default'] : e; }
|
|
14
|
-
|
|
15
|
-
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
16
|
-
var cx__default = /*#__PURE__*/_interopDefaultLegacy(cx);
|
|
17
|
-
var hljs__default = /*#__PURE__*/_interopDefaultLegacy(hljs);
|
|
18
|
-
|
|
19
|
-
const classes = Object.assign(Object.assign({}, CodeHighlight_module['default']), { code: cx__default(CodeHighlight_module['default'].code, CodeHighlight_theme_module['default'].theme) });
|
|
20
|
-
const defaultProps = {
|
|
21
|
-
language: 'tsx',
|
|
22
|
-
};
|
|
23
|
-
const InlineCodeHighlight = core.factory((_props, ref) => {
|
|
24
|
-
const props = core.useProps('InlineCodeHighlight', defaultProps, _props);
|
|
25
|
-
const { classNames, className, style, styles, unstyled, vars, code, language } = props, others = tslib_es6.__rest(props, ["classNames", "className", "style", "styles", "unstyled", "vars", "code", "language"]);
|
|
26
|
-
const getStyles = core.useStyles({
|
|
27
|
-
name: 'InlineCodeHighlight',
|
|
28
|
-
props,
|
|
29
|
-
classes,
|
|
30
|
-
className,
|
|
31
|
-
style,
|
|
32
|
-
classNames,
|
|
33
|
-
styles,
|
|
34
|
-
unstyled,
|
|
35
|
-
rootSelector: 'code',
|
|
36
|
-
});
|
|
37
|
-
const highlighted = hljs__default.highlight(code.trim(), { language: language }).value;
|
|
38
|
-
return (React__default.createElement(core.Box, Object.assign({}, getStyles('code'), { component: "code", ref: ref }, others, { dangerouslySetInnerHTML: { __html: highlighted } })));
|
|
39
|
-
});
|
|
40
|
-
InlineCodeHighlight.displayName = '@mantine/core/InlineCodeHighlight';
|
|
41
|
-
|
|
42
|
-
exports.InlineCodeHighlight = InlineCodeHighlight;
|
|
43
|
-
//# sourceMappingURL=InlineCodeHighlight.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"InlineCodeHighlight.js","sources":["../../../../src/InlineCodeHighlight.tsx"],"sourcesContent":["import React from 'react';\nimport cx from 'clsx';\nimport {\n Box,\n BoxProps,\n StylesApiProps,\n factory,\n ElementProps,\n useProps,\n useStyles,\n Factory,\n} from '@mantine/core';\nimport hljs from 'highlight.js';\nimport _classes from './CodeHighlight.module.css';\nimport themeClasses from './CodeHighlight.theme.module.css';\n\nconst classes = { ..._classes, code: cx(_classes.code, themeClasses.theme) };\n\nexport type InlineCodeHighlightStylesNames = 'code';\nexport type InlineCodeHighlightVariant = string;\n\nexport interface InlineCodeHighlightProps\n extends BoxProps,\n StylesApiProps<InlineCodeHighlightFactory>,\n ElementProps<'div'> {\n /** Code to highlight */\n code: string;\n\n /** Code language, `'tsx'` by default */\n language?: string;\n}\n\nexport type InlineCodeHighlightFactory = Factory<{\n props: InlineCodeHighlightProps;\n ref: HTMLElement;\n stylesNames: InlineCodeHighlightStylesNames;\n}>;\n\nconst defaultProps: Partial<InlineCodeHighlightProps> = {\n language: 'tsx',\n};\n\nexport const InlineCodeHighlight = factory<InlineCodeHighlightFactory>((_props, ref) => {\n const props = useProps('InlineCodeHighlight', defaultProps, _props);\n const { classNames, className, style, styles, unstyled, vars, code, language, ...others } = props;\n\n const getStyles = useStyles<InlineCodeHighlightFactory>({\n name: 'InlineCodeHighlight',\n props,\n classes,\n className,\n style,\n classNames,\n styles,\n unstyled,\n rootSelector: 'code',\n });\n\n const highlighted = hljs.highlight(code.trim(), { language: language! }).value;\n\n return (\n <Box\n {...getStyles('code')}\n component=\"code\"\n ref={ref}\n {...others}\n dangerouslySetInnerHTML={{ __html: highlighted }}\n />\n );\n});\n\nInlineCodeHighlight.displayName = '@mantine/core/InlineCodeHighlight';\n"],"names":["_classes","cx","themeClasses","factory","useProps","useStyles","hljs","React","Box"],"mappings":";;;;;;;;;;;;;;;;;;AAgBA,MAAM,OAAO,mCAAQA,+BAAQ,KAAE,IAAI,EAAEC,WAAE,CAACD,+BAAQ,CAAC,IAAI,EAAEE,qCAAY,CAAC,KAAK,CAAC,GAAE,CAAC;AAsB7E,MAAM,YAAY,GAAsC;IACtD,QAAQ,EAAE,KAAK;CAChB,CAAC;MAEW,mBAAmB,GAAGC,YAAO,CAA6B,CAAC,MAAM,EAAE,GAAG;IACjF,MAAM,KAAK,GAAGC,aAAQ,CAAC,qBAAqB,EAAE,YAAY,EAAE,MAAM,CAAC,CAAC;IACpE,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE,IAAI,EAAE,QAAQ,KAAgB,KAAK,EAAhB,MAAM,oBAAK,KAAK,EAA3F,sFAAmF,CAAQ,CAAC;IAElG,MAAM,SAAS,GAAGC,cAAS,CAA6B;QACtD,IAAI,EAAE,qBAAqB;QAC3B,KAAK;QACL,OAAO;QACP,SAAS;QACT,KAAK;QACL,UAAU;QACV,MAAM;QACN,QAAQ;QACR,YAAY,EAAE,MAAM;KACrB,CAAC,CAAC;IAEH,MAAM,WAAW,GAAGC,aAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,EAAE,QAAQ,EAAE,QAAS,EAAE,CAAC,CAAC,KAAK,CAAC;IAE/E,QACEC,6BAACC,QAAG,oBACE,SAAS,CAAC,MAAM,CAAC,IACrB,SAAS,EAAC,MAAM,EAChB,GAAG,EAAE,GAAG,IACJ,MAAM,IACV,uBAAuB,EAAE,EAAE,MAAM,EAAE,WAAW,EAAE,IAChD,EACF;AACJ,CAAC,EAAE;AAEH,mBAAmB,CAAC,WAAW,GAAG,mCAAmC;;;;"}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
-
|
|
5
|
-
var CodeHighlightTabs = require('./CodeHighlightTabs.js');
|
|
6
|
-
var CodeHighlight = require('./CodeHighlight.js');
|
|
7
|
-
var InlineCodeHighlight = require('./InlineCodeHighlight.js');
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
exports.CodeHighlightTabs = CodeHighlightTabs.CodeHighlightTabs;
|
|
12
|
-
exports.CodeHighlight = CodeHighlight.CodeHighlight;
|
|
13
|
-
exports.InlineCodeHighlight = InlineCodeHighlight.InlineCodeHighlight;
|
|
14
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;"}
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
-
|
|
5
|
-
var React = require('react');
|
|
6
|
-
var hljs = require('highlight.js');
|
|
7
|
-
|
|
8
|
-
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e['default'] : e; }
|
|
9
|
-
|
|
10
|
-
var hljs__default = /*#__PURE__*/_interopDefaultLegacy(hljs);
|
|
11
|
-
|
|
12
|
-
function useHighlight({ code, language, highlightOnClient }) {
|
|
13
|
-
const getHighlightedCode = () => hljs__default.highlight(code.trim(), { language: language }).value;
|
|
14
|
-
const [highlighted, setHighlighted] = React.useState(!highlightOnClient);
|
|
15
|
-
const [highlightedCode, setHighlightedCode] = React.useState(highlightOnClient ? code : getHighlightedCode());
|
|
16
|
-
const getCodeProps = () => highlighted
|
|
17
|
-
? { dangerouslySetInnerHTML: { __html: highlightedCode } }
|
|
18
|
-
: { children: code.trim() };
|
|
19
|
-
React.useEffect(() => {
|
|
20
|
-
if (highlightOnClient) {
|
|
21
|
-
setHighlightedCode(getHighlightedCode());
|
|
22
|
-
setHighlighted(true);
|
|
23
|
-
}
|
|
24
|
-
}, []);
|
|
25
|
-
return getCodeProps;
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
exports.useHighlight = useHighlight;
|
|
29
|
-
//# sourceMappingURL=use-highlight.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"use-highlight.js","sources":["../../../../src/use-highlight.ts"],"sourcesContent":["import { useState, useEffect } from 'react';\nimport hljs from 'highlight.js';\n\ninterface UseHighlightInput {\n code: string;\n language: string;\n highlightOnClient: boolean | undefined;\n}\n\nexport function useHighlight({ code, language, highlightOnClient }: UseHighlightInput) {\n const getHighlightedCode = () => hljs.highlight(code.trim(), { language: language! }).value;\n const [highlighted, setHighlighted] = useState(!highlightOnClient);\n const [highlightedCode, setHighlightedCode] = useState(\n highlightOnClient ? code : getHighlightedCode()\n );\n\n const getCodeProps = () =>\n highlighted\n ? { dangerouslySetInnerHTML: { __html: highlightedCode } }\n : { children: code.trim() };\n\n useEffect(() => {\n if (highlightOnClient) {\n setHighlightedCode(getHighlightedCode());\n setHighlighted(true);\n }\n }, []);\n\n return getCodeProps;\n}\n"],"names":["hljs","useState","useEffect"],"mappings":";;;;;;;;;;;SASgB,YAAY,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,iBAAiB,EAAqB;IACnF,MAAM,kBAAkB,GAAG,MAAMA,aAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,EAAE,QAAQ,EAAE,QAAS,EAAE,CAAC,CAAC,KAAK,CAAC;IAC5F,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAGC,cAAQ,CAAC,CAAC,iBAAiB,CAAC,CAAC;IACnE,MAAM,CAAC,eAAe,EAAE,kBAAkB,CAAC,GAAGA,cAAQ,CACpD,iBAAiB,GAAG,IAAI,GAAG,kBAAkB,EAAE,CAChD,CAAC;IAEF,MAAM,YAAY,GAAG,MACnB,WAAW;UACP,EAAE,uBAAuB,EAAE,EAAE,MAAM,EAAE,eAAe,EAAE,EAAE;UACxD,EAAE,QAAQ,EAAE,IAAI,CAAC,IAAI,EAAE,EAAE,CAAC;IAEhCC,eAAS,CAAC;QACR,IAAI,iBAAiB,EAAE;YACrB,kBAAkB,CAAC,kBAAkB,EAAE,CAAC,CAAC;YACzC,cAAc,CAAC,IAAI,CAAC,CAAC;SACtB;KACF,EAAE,EAAE,CAAC,CAAC;IAEP,OAAO,YAAY,CAAC;AACtB;;;;"}
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
import { __rest } from '../../../node_modules/tslib/tslib.es6.js';
|
|
2
|
-
import React from 'react';
|
|
3
|
-
import cx from 'clsx';
|
|
4
|
-
import { factory, useProps, useStyles, Box, CopyButton, Tooltip, ActionIcon, ScrollArea } from '@mantine/core';
|
|
5
|
-
import { useHighlight } from './use-highlight.js';
|
|
6
|
-
import { CopyIcon } from './CopyIcon.js';
|
|
7
|
-
import _classes from './CodeHighlight.module.css.js';
|
|
8
|
-
import themeClasses from './CodeHighlight.theme.module.css.js';
|
|
9
|
-
|
|
10
|
-
const classes = Object.assign(Object.assign({}, _classes), { root: cx(_classes.root, themeClasses.theme) });
|
|
11
|
-
const defaultProps = {
|
|
12
|
-
copyLabel: 'Copy code',
|
|
13
|
-
copiedLabel: 'Copied',
|
|
14
|
-
language: 'tsx',
|
|
15
|
-
withCopyButton: true,
|
|
16
|
-
};
|
|
17
|
-
const CodeHighlight = factory((_props, ref) => {
|
|
18
|
-
const props = useProps('CodeHighlight', defaultProps, _props);
|
|
19
|
-
const { classNames, className, style, styles, unstyled, vars, children, code, copiedLabel, copyLabel, language, withCopyButton, highlightOnClient } = props, others = __rest(props, ["classNames", "className", "style", "styles", "unstyled", "vars", "children", "code", "copiedLabel", "copyLabel", "language", "withCopyButton", "highlightOnClient"]);
|
|
20
|
-
const getStyles = useStyles({
|
|
21
|
-
name: 'CodeHighlight',
|
|
22
|
-
props,
|
|
23
|
-
classes,
|
|
24
|
-
className,
|
|
25
|
-
style,
|
|
26
|
-
classNames,
|
|
27
|
-
styles,
|
|
28
|
-
unstyled,
|
|
29
|
-
});
|
|
30
|
-
const getCodeProps = useHighlight({
|
|
31
|
-
code,
|
|
32
|
-
language: language,
|
|
33
|
-
highlightOnClient,
|
|
34
|
-
});
|
|
35
|
-
return (React.createElement(Box, Object.assign({}, getStyles('root'), { ref: ref }, others, { dir: "ltr" }),
|
|
36
|
-
withCopyButton && (React.createElement(CopyButton, { value: code.trim() }, ({ copied, copy }) => (React.createElement(Tooltip, { label: copied ? copiedLabel : copyLabel, fz: "sm", position: "left" },
|
|
37
|
-
React.createElement(ActionIcon, Object.assign({ onClick: copy, variant: "none" }, getStyles('copy')),
|
|
38
|
-
React.createElement(CopyIcon, { copied: copied })))))),
|
|
39
|
-
React.createElement(ScrollArea, { type: "auto", dir: "ltr", offsetScrollbars: false },
|
|
40
|
-
React.createElement("pre", Object.assign({}, getStyles('pre')),
|
|
41
|
-
React.createElement("code", Object.assign({}, getStyles('code'), getCodeProps()))))));
|
|
42
|
-
});
|
|
43
|
-
CodeHighlight.displayName = '@mantine/core/CodeHighlight';
|
|
44
|
-
|
|
45
|
-
export { CodeHighlight };
|
|
46
|
-
//# sourceMappingURL=CodeHighlight.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"CodeHighlight.js","sources":["../../../../src/CodeHighlight.tsx"],"sourcesContent":["import React from 'react';\nimport cx from 'clsx';\nimport {\n Box,\n BoxProps,\n StylesApiProps,\n factory,\n ElementProps,\n useProps,\n useStyles,\n CopyButton,\n Tooltip,\n ActionIcon,\n ScrollArea,\n Factory,\n} from '@mantine/core';\nimport { useHighlight } from './use-highlight';\nimport { CopyIcon } from './CopyIcon';\nimport _classes from './CodeHighlight.module.css';\nimport themeClasses from './CodeHighlight.theme.module.css';\n\nconst classes = { ..._classes, root: cx(_classes.root, themeClasses.theme) };\n\nexport type CodeHighlightStylesNames = 'root' | 'code' | 'pre' | 'copy';\nexport type CodeHighlightVariant = string;\n\nexport interface CodeHighlightProps\n extends BoxProps,\n StylesApiProps<CodeHighlightFactory>,\n ElementProps<'div'> {\n /** Code to highlight */\n code: string;\n\n /** Code language, `'tsx'` by default */\n language?: string;\n\n /** Determines whether copy button should be displayed, `true` by default */\n withCopyButton?: boolean;\n\n /** Copy tooltip label, `'Copy code'` by default */\n copyLabel?: string;\n\n /** Copied tooltip label, `'Copied'` by default */\n copiedLabel?: string;\n\n /** Determines whether code should be highlighted only after component is mounted to the dom (disables code highlight on server), `false` by default */\n highlightOnClient?: boolean;\n}\n\nexport type CodeHighlightFactory = Factory<{\n props: CodeHighlightProps;\n ref: HTMLDivElement;\n stylesNames: CodeHighlightStylesNames;\n variant: CodeHighlightVariant;\n}>;\n\nconst defaultProps: Partial<CodeHighlightProps> = {\n copyLabel: 'Copy code',\n copiedLabel: 'Copied',\n language: 'tsx',\n withCopyButton: true,\n};\n\nexport const CodeHighlight = factory<CodeHighlightFactory>((_props, ref) => {\n const props = useProps('CodeHighlight', defaultProps, _props);\n const {\n classNames,\n className,\n style,\n styles,\n unstyled,\n vars,\n children,\n code,\n copiedLabel,\n copyLabel,\n language,\n withCopyButton,\n highlightOnClient,\n ...others\n } = props;\n\n const getStyles = useStyles<CodeHighlightFactory>({\n name: 'CodeHighlight',\n props,\n classes,\n className,\n style,\n classNames,\n styles,\n unstyled,\n });\n\n const getCodeProps = useHighlight({\n code,\n language: language!,\n highlightOnClient,\n });\n\n return (\n <Box {...getStyles('root')} ref={ref} {...others} dir=\"ltr\">\n {withCopyButton && (\n <CopyButton value={code.trim()}>\n {({ copied, copy }) => (\n <Tooltip label={copied ? copiedLabel : copyLabel} fz=\"sm\" position=\"left\">\n <ActionIcon onClick={copy} variant=\"none\" {...getStyles('copy')}>\n <CopyIcon copied={copied} />\n </ActionIcon>\n </Tooltip>\n )}\n </CopyButton>\n )}\n\n <ScrollArea type=\"auto\" dir=\"ltr\" offsetScrollbars={false}>\n <pre {...getStyles('pre')}>\n <code {...getStyles('code')} {...getCodeProps()} />\n </pre>\n </ScrollArea>\n </Box>\n );\n});\n\nCodeHighlight.displayName = '@mantine/core/CodeHighlight';\n"],"names":[],"mappings":";;;;;;;;;AAqBA,MAAM,OAAO,mCAAQ,QAAQ,KAAE,IAAI,EAAE,EAAE,CAAC,QAAQ,CAAC,IAAI,EAAE,YAAY,CAAC,KAAK,CAAC,GAAE,CAAC;AAmC7E,MAAM,YAAY,GAAgC;IAChD,SAAS,EAAE,WAAW;IACtB,WAAW,EAAE,QAAQ;IACrB,QAAQ,EAAE,KAAK;IACf,cAAc,EAAE,IAAI;CACrB,CAAC;MAEW,aAAa,GAAG,OAAO,CAAuB,CAAC,MAAM,EAAE,GAAG;IACrE,MAAM,KAAK,GAAG,QAAQ,CAAC,eAAe,EAAE,YAAY,EAAE,MAAM,CAAC,CAAC;IAC9D,MAAM,EACJ,UAAU,EACV,SAAS,EACT,KAAK,EACL,MAAM,EACN,QAAQ,EACR,IAAI,EACJ,QAAQ,EACR,IAAI,EACJ,WAAW,EACX,SAAS,EACT,QAAQ,EACR,cAAc,EACd,iBAAiB,KAEf,KAAK,EADJ,MAAM,UACP,KAAK,EAfH,qKAeL,CAAQ,CAAC;IAEV,MAAM,SAAS,GAAG,SAAS,CAAuB;QAChD,IAAI,EAAE,eAAe;QACrB,KAAK;QACL,OAAO;QACP,SAAS;QACT,KAAK;QACL,UAAU;QACV,MAAM;QACN,QAAQ;KACT,CAAC,CAAC;IAEH,MAAM,YAAY,GAAG,YAAY,CAAC;QAChC,IAAI;QACJ,QAAQ,EAAE,QAAS;QACnB,iBAAiB;KAClB,CAAC,CAAC;IAEH,QACE,oBAAC,GAAG,oBAAK,SAAS,CAAC,MAAM,CAAC,IAAE,GAAG,EAAE,GAAG,IAAM,MAAM,IAAE,GAAG,EAAC,KAAK;QACxD,cAAc,KACb,oBAAC,UAAU,IAAC,KAAK,EAAE,IAAI,CAAC,IAAI,EAAE,IAC3B,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,MAChB,oBAAC,OAAO,IAAC,KAAK,EAAE,MAAM,GAAG,WAAW,GAAG,SAAS,EAAE,EAAE,EAAC,IAAI,EAAC,QAAQ,EAAC,MAAM;YACvE,oBAAC,UAAU,kBAAC,OAAO,EAAE,IAAI,EAAE,OAAO,EAAC,MAAM,IAAK,SAAS,CAAC,MAAM,CAAC;gBAC7D,oBAAC,QAAQ,IAAC,MAAM,EAAE,MAAM,GAAI,CACjB,CACL,CACX,CACU,CACd;QAED,oBAAC,UAAU,IAAC,IAAI,EAAC,MAAM,EAAC,GAAG,EAAC,KAAK,EAAC,gBAAgB,EAAE,KAAK;YACvD,6CAAS,SAAS,CAAC,KAAK,CAAC;gBACvB,8CAAU,SAAS,CAAC,MAAM,CAAC,EAAM,YAAY,EAAE,EAAI,CAC/C,CACK,CACT,EACN;AACJ,CAAC,EAAE;AAEH,aAAa,CAAC,WAAW,GAAG,6BAA6B;;;;"}
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
var _classes = {"code":"mantine-XIBJZDt","pre":"mantine-RDvBcjB","header":"mantine-cmEtjrV","controls":"mantine-059sM-t","copy":"mantine-tB-P5PD","control":"mantine-NTm-nGn","file":"mantine-PBrPXnu","files":"mantine-IvOddiX","codeWrapper":"mantine-YfYyOiA","showCodeButton":"mantine-haNyFRC","root":"mantine-k6OJW8l"};
|
|
2
|
-
|
|
3
|
-
export default _classes;
|
|
4
|
-
//# sourceMappingURL=CodeHighlight.module.css.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"CodeHighlight.module.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"CodeHighlight.theme.module.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
|
|
@@ -1,80 +0,0 @@
|
|
|
1
|
-
import { __rest } from '../../../node_modules/tslib/tslib.es6.js';
|
|
2
|
-
import React from 'react';
|
|
3
|
-
import hljs from 'highlight.js';
|
|
4
|
-
import cx from 'clsx';
|
|
5
|
-
import { useUncontrolled } from '@mantine/hooks';
|
|
6
|
-
import { rem, createVarsResolver, factory, useProps, useStyles, UnstyledButton, Box, ScrollArea, Tooltip, ActionIcon, CopyButton } from '@mantine/core';
|
|
7
|
-
import { CopyIcon } from './CopyIcon.js';
|
|
8
|
-
import { FileIcon } from './FileIcon.js';
|
|
9
|
-
import { ExpandIcon } from './ExpandIcon.js';
|
|
10
|
-
import _classes from './CodeHighlight.module.css.js';
|
|
11
|
-
import themeClasses from './CodeHighlight.theme.module.css.js';
|
|
12
|
-
|
|
13
|
-
const classes = Object.assign(Object.assign({}, _classes), { root: cx(_classes.root, themeClasses.theme) });
|
|
14
|
-
const defaultProps = {
|
|
15
|
-
withHeader: true,
|
|
16
|
-
copyLabel: 'Copy code',
|
|
17
|
-
copiedLabel: 'Copied',
|
|
18
|
-
maxCollapsedHeight: rem('8rem'),
|
|
19
|
-
expandCodeLabel: 'Expand code',
|
|
20
|
-
collapseCodeLabel: 'Collapse code',
|
|
21
|
-
};
|
|
22
|
-
const varsResolver = createVarsResolver((_, { maxCollapsedHeight }) => ({
|
|
23
|
-
root: { '--ch-max-collapsed-height': rem(maxCollapsedHeight) },
|
|
24
|
-
}));
|
|
25
|
-
const CodeHighlightTabs = factory((_props, ref) => {
|
|
26
|
-
const props = useProps('CodeHighlightTabs', defaultProps, _props);
|
|
27
|
-
const { classNames, className, style, styles, unstyled, vars, children, code, defaultActiveTab, activeTab, onTabChange, withHeader, copiedLabel, copyLabel, getFileIcon, maxCollapsedHeight, expanded, defaultExpanded, onExpandedChange, expandCodeLabel, collapseCodeLabel, withExpandButton } = props, others = __rest(props, ["classNames", "className", "style", "styles", "unstyled", "vars", "children", "code", "defaultActiveTab", "activeTab", "onTabChange", "withHeader", "copiedLabel", "copyLabel", "getFileIcon", "maxCollapsedHeight", "expanded", "defaultExpanded", "onExpandedChange", "expandCodeLabel", "collapseCodeLabel", "withExpandButton"]);
|
|
28
|
-
const getStyles = useStyles({
|
|
29
|
-
name: 'CodeHighlightTabs',
|
|
30
|
-
props,
|
|
31
|
-
classes,
|
|
32
|
-
className,
|
|
33
|
-
style,
|
|
34
|
-
classNames,
|
|
35
|
-
styles,
|
|
36
|
-
unstyled,
|
|
37
|
-
vars,
|
|
38
|
-
varsResolver,
|
|
39
|
-
});
|
|
40
|
-
const [value, setValue] = useUncontrolled({
|
|
41
|
-
defaultValue: defaultActiveTab,
|
|
42
|
-
value: activeTab,
|
|
43
|
-
finalValue: 0,
|
|
44
|
-
onChange: onTabChange,
|
|
45
|
-
});
|
|
46
|
-
const [_expanded, setExpanded] = useUncontrolled({
|
|
47
|
-
defaultValue: defaultExpanded,
|
|
48
|
-
value: expanded,
|
|
49
|
-
finalValue: true,
|
|
50
|
-
onChange: onExpandedChange,
|
|
51
|
-
});
|
|
52
|
-
const nodes = Array.isArray(code) ? code : [code];
|
|
53
|
-
const currentCode = nodes[value];
|
|
54
|
-
const highlighted = hljs.highlight(currentCode.code.trim(), {
|
|
55
|
-
language: currentCode.language,
|
|
56
|
-
}).value;
|
|
57
|
-
const files = nodes.map((node, index) => (React.createElement(UnstyledButton, Object.assign({}, getStyles('file'), { key: node.fileName, mod: { active: index === value }, onClick: () => setValue(index) }),
|
|
58
|
-
React.createElement(FileIcon, { fileIcon: node.icon, getFileIcon: getFileIcon, fileName: node.fileName }),
|
|
59
|
-
React.createElement("span", null, node.fileName))));
|
|
60
|
-
return (React.createElement(Box, Object.assign({}, getStyles('root'), { ref: ref }, others, { dir: "ltr" }),
|
|
61
|
-
withHeader && (React.createElement("div", Object.assign({}, getStyles('header')),
|
|
62
|
-
React.createElement(ScrollArea, { type: "never", dir: "ltr", offsetScrollbars: false },
|
|
63
|
-
React.createElement("div", Object.assign({}, getStyles('files')), files)),
|
|
64
|
-
React.createElement("div", Object.assign({}, getStyles('controls')),
|
|
65
|
-
withExpandButton && (React.createElement(Tooltip, { label: _expanded ? collapseCodeLabel : expandCodeLabel, fz: "sm", position: "left" },
|
|
66
|
-
React.createElement(ActionIcon, Object.assign({ onClick: () => setExpanded(!_expanded), variant: "none" }, getStyles('control')),
|
|
67
|
-
React.createElement(ExpandIcon, { expanded: _expanded })))),
|
|
68
|
-
React.createElement(CopyButton, { value: currentCode.code.trim() }, ({ copied, copy }) => (React.createElement(Tooltip, { label: copied ? copiedLabel : copyLabel, fz: "sm", position: "left" },
|
|
69
|
-
React.createElement(ActionIcon, Object.assign({ onClick: copy, variant: "none" }, getStyles('control')),
|
|
70
|
-
React.createElement(CopyIcon, { copied: copied })))))))),
|
|
71
|
-
React.createElement(ScrollArea, { type: "auto", dir: "ltr", offsetScrollbars: false },
|
|
72
|
-
React.createElement(Box, Object.assign({}, getStyles('codeWrapper'), { mod: { expanded: _expanded } }),
|
|
73
|
-
React.createElement("pre", Object.assign({}, getStyles('pre')),
|
|
74
|
-
React.createElement("code", Object.assign({}, getStyles('code'), { dangerouslySetInnerHTML: { __html: highlighted } }))))),
|
|
75
|
-
React.createElement(UnstyledButton, Object.assign({}, getStyles('showCodeButton'), { mod: { hidden: _expanded }, onClick: () => setExpanded(true) }), "Expand code")));
|
|
76
|
-
});
|
|
77
|
-
CodeHighlightTabs.displayName = '@mantine/core/CodeHighlightTabs';
|
|
78
|
-
|
|
79
|
-
export { CodeHighlightTabs };
|
|
80
|
-
//# sourceMappingURL=CodeHighlightTabs.js.map
|