@entur/typography 1.9.13 → 1.10.0-beta.10
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/README.md +101 -4
- package/dist/BaseHeading.d.ts +18 -0
- package/dist/Blockquote.d.ts +12 -0
- package/dist/CodeText.d.ts +16 -0
- package/dist/EmphasizedText.d.ts +20 -0
- package/dist/Heading1.d.ts +20 -0
- package/dist/Heading2.d.ts +20 -0
- package/dist/Heading3.d.ts +20 -0
- package/dist/Heading4.d.ts +20 -0
- package/dist/Heading5.d.ts +20 -0
- package/dist/Heading6.d.ts +20 -0
- package/dist/Label.d.ts +20 -0
- package/dist/LeadParagraph.d.ts +20 -0
- package/dist/Link.d.ts +22 -0
- package/dist/ListItem.d.ts +11 -0
- package/dist/NumberedList.d.ts +8 -0
- package/dist/Paragraph.d.ts +20 -0
- package/dist/PreformattedText.d.ts +16 -0
- package/dist/SmallText.d.ts +20 -0
- package/dist/StrongText.d.ts +20 -0
- package/dist/SubLabel.d.ts +20 -0
- package/dist/SubParagraph.d.ts +20 -0
- package/dist/UnorderedList.d.ts +8 -0
- package/dist/beta/BlockquoteBeta.d.ts +12 -0
- package/dist/beta/Heading.d.ts +21 -0
- package/dist/beta/LinkBeta.d.ts +16 -0
- package/dist/beta/Text.d.ts +21 -0
- package/dist/beta/index.d.ts +6 -0
- package/dist/beta/types.d.ts +5 -0
- package/dist/beta/utils.d.ts +10 -0
- package/dist/index.d.ts +26 -426
- package/dist/index.js +8 -0
- package/dist/styles.css +838 -2
- package/dist/typography.cjs.development.js +528 -0
- package/dist/typography.cjs.development.js.map +1 -0
- package/dist/typography.cjs.production.min.js +2 -0
- package/dist/typography.cjs.production.min.js.map +1 -0
- package/dist/typography.esm.js +474 -392
- package/dist/typography.esm.js.map +1 -1
- package/package.json +21 -25
- package/scripts/migrate-typography.js +1259 -0
- package/dist/typography.cjs.js +0 -416
- package/dist/typography.cjs.js.map +0 -1
|
@@ -0,0 +1,528 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var utils = require('@entur/utils');
|
|
6
|
+
var React = require('react');
|
|
7
|
+
var classNames = require('classnames');
|
|
8
|
+
var icons = require('@entur/icons');
|
|
9
|
+
|
|
10
|
+
function _extends() {
|
|
11
|
+
return _extends = Object.assign ? Object.assign.bind() : function (n) {
|
|
12
|
+
for (var e = 1; e < arguments.length; e++) {
|
|
13
|
+
var t = arguments[e];
|
|
14
|
+
for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]);
|
|
15
|
+
}
|
|
16
|
+
return n;
|
|
17
|
+
}, _extends.apply(null, arguments);
|
|
18
|
+
}
|
|
19
|
+
function _objectWithoutPropertiesLoose(r, e) {
|
|
20
|
+
if (null == r) return {};
|
|
21
|
+
var t = {};
|
|
22
|
+
for (var n in r) if ({}.hasOwnProperty.call(r, n)) {
|
|
23
|
+
if (-1 !== e.indexOf(n)) continue;
|
|
24
|
+
t[n] = r[n];
|
|
25
|
+
}
|
|
26
|
+
return t;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
var _excluded$p = ["className", "ref"],
|
|
30
|
+
_excluded2$1 = ["className"];
|
|
31
|
+
var Blockquote = function Blockquote(_ref) {
|
|
32
|
+
var className = _ref.className,
|
|
33
|
+
ref = _ref.ref,
|
|
34
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded$p);
|
|
35
|
+
return React.createElement("blockquote", _extends({
|
|
36
|
+
className: classNames('eds-blockquote', className),
|
|
37
|
+
ref: ref
|
|
38
|
+
}, rest));
|
|
39
|
+
};
|
|
40
|
+
var BlockquoteFooter = function BlockquoteFooter(_ref2) {
|
|
41
|
+
var className = _ref2.className,
|
|
42
|
+
rest = _objectWithoutPropertiesLoose(_ref2, _excluded2$1);
|
|
43
|
+
return React.createElement("footer", _extends({
|
|
44
|
+
className: classNames('eds-blockquote__footer', className)
|
|
45
|
+
}, rest));
|
|
46
|
+
};
|
|
47
|
+
|
|
48
|
+
var _excluded$o = ["className", "as"];
|
|
49
|
+
var defaultElement$h = 'code';
|
|
50
|
+
var CodeText = function CodeText(_ref) {
|
|
51
|
+
var className = _ref.className,
|
|
52
|
+
as = _ref.as,
|
|
53
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded$o);
|
|
54
|
+
var Element = as || defaultElement$h;
|
|
55
|
+
return React.createElement(Element, _extends({
|
|
56
|
+
className: classNames('eds-code-text', className)
|
|
57
|
+
}, rest));
|
|
58
|
+
};
|
|
59
|
+
|
|
60
|
+
var _excluded$n = ["className", "margin", "as"];
|
|
61
|
+
var defaultElement$g = 'em';
|
|
62
|
+
var EmphasizedText = function EmphasizedText(_ref) {
|
|
63
|
+
var _classNames;
|
|
64
|
+
var className = _ref.className,
|
|
65
|
+
_ref$margin = _ref.margin,
|
|
66
|
+
margin = _ref$margin === void 0 ? 'both' : _ref$margin,
|
|
67
|
+
as = _ref.as,
|
|
68
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded$n);
|
|
69
|
+
var Element = as || defaultElement$g;
|
|
70
|
+
return React.createElement(Element, _extends({
|
|
71
|
+
className: classNames('eds-emphasized-text', (_classNames = {}, _classNames["eds-emphasized-text--margin-top"] = margin === 'top', _classNames["eds-emphasized-text--margin-bottom"] = margin === 'bottom', _classNames["eds-emphasized-text--margin-none"] = margin === 'none', _classNames), className)
|
|
72
|
+
}, rest));
|
|
73
|
+
};
|
|
74
|
+
|
|
75
|
+
var _excluded$m = ["className", "level", "margin", "as"];
|
|
76
|
+
var defaultElement$f = 'h1';
|
|
77
|
+
var BaseHeading = function BaseHeading(_ref) {
|
|
78
|
+
var _classNames;
|
|
79
|
+
var className = _ref.className,
|
|
80
|
+
level = _ref.level,
|
|
81
|
+
margin = _ref.margin,
|
|
82
|
+
as = _ref.as,
|
|
83
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded$m);
|
|
84
|
+
var Element = as || defaultElement$f;
|
|
85
|
+
var baseClass = "eds-h" + level;
|
|
86
|
+
return React.createElement(Element, _extends({
|
|
87
|
+
className: classNames(baseClass, (_classNames = {}, _classNames[baseClass + "--margin-top"] = margin === 'top', _classNames[baseClass + "--margin-bottom"] = margin === 'bottom', _classNames[baseClass + "--margin-none"] = margin === 'none', _classNames), className)
|
|
88
|
+
}, rest));
|
|
89
|
+
};
|
|
90
|
+
|
|
91
|
+
var _excluded$l = ["margin", "children", "as"];
|
|
92
|
+
var defaultElement$e = 'h1';
|
|
93
|
+
var Heading1 = function Heading1(_ref) {
|
|
94
|
+
var _ref$margin = _ref.margin,
|
|
95
|
+
margin = _ref$margin === void 0 ? 'both' : _ref$margin,
|
|
96
|
+
children = _ref.children,
|
|
97
|
+
as = _ref.as,
|
|
98
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded$l);
|
|
99
|
+
var Element = as || defaultElement$e;
|
|
100
|
+
return React.createElement(BaseHeading, _extends({
|
|
101
|
+
as: Element,
|
|
102
|
+
margin: margin
|
|
103
|
+
}, rest, {
|
|
104
|
+
level: 1
|
|
105
|
+
}), children);
|
|
106
|
+
};
|
|
107
|
+
|
|
108
|
+
var _excluded$k = ["margin", "children", "as"];
|
|
109
|
+
var defaultElement$d = 'h2';
|
|
110
|
+
var Heading2 = function Heading2(_ref) {
|
|
111
|
+
var _ref$margin = _ref.margin,
|
|
112
|
+
margin = _ref$margin === void 0 ? 'both' : _ref$margin,
|
|
113
|
+
children = _ref.children,
|
|
114
|
+
as = _ref.as,
|
|
115
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded$k);
|
|
116
|
+
var Element = as || defaultElement$d;
|
|
117
|
+
return React.createElement(BaseHeading, _extends({
|
|
118
|
+
as: Element,
|
|
119
|
+
margin: margin
|
|
120
|
+
}, rest, {
|
|
121
|
+
level: 2
|
|
122
|
+
}), children);
|
|
123
|
+
};
|
|
124
|
+
|
|
125
|
+
var _excluded$j = ["margin", "children", "as"];
|
|
126
|
+
var defaultElement$c = 'h3';
|
|
127
|
+
var Heading3 = function Heading3(_ref) {
|
|
128
|
+
var _ref$margin = _ref.margin,
|
|
129
|
+
margin = _ref$margin === void 0 ? 'both' : _ref$margin,
|
|
130
|
+
children = _ref.children,
|
|
131
|
+
as = _ref.as,
|
|
132
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded$j);
|
|
133
|
+
var Element = as || defaultElement$c;
|
|
134
|
+
return React.createElement(BaseHeading, _extends({
|
|
135
|
+
as: Element,
|
|
136
|
+
margin: margin
|
|
137
|
+
}, rest, {
|
|
138
|
+
level: 3
|
|
139
|
+
}), children);
|
|
140
|
+
};
|
|
141
|
+
|
|
142
|
+
var _excluded$i = ["margin", "children", "as"];
|
|
143
|
+
var defaultElement$b = 'h4';
|
|
144
|
+
var Heading4 = function Heading4(_ref) {
|
|
145
|
+
var _ref$margin = _ref.margin,
|
|
146
|
+
margin = _ref$margin === void 0 ? 'both' : _ref$margin,
|
|
147
|
+
children = _ref.children,
|
|
148
|
+
as = _ref.as,
|
|
149
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded$i);
|
|
150
|
+
var Element = as || defaultElement$b;
|
|
151
|
+
return React.createElement(BaseHeading, _extends({
|
|
152
|
+
as: Element,
|
|
153
|
+
margin: margin
|
|
154
|
+
}, rest, {
|
|
155
|
+
level: 4
|
|
156
|
+
}), children);
|
|
157
|
+
};
|
|
158
|
+
|
|
159
|
+
var _excluded$h = ["margin", "children", "as"];
|
|
160
|
+
var defaultElement$a = 'h5';
|
|
161
|
+
var Heading5 = function Heading5(_ref) {
|
|
162
|
+
var _ref$margin = _ref.margin,
|
|
163
|
+
margin = _ref$margin === void 0 ? 'both' : _ref$margin,
|
|
164
|
+
children = _ref.children,
|
|
165
|
+
as = _ref.as,
|
|
166
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded$h);
|
|
167
|
+
var Element = as || defaultElement$a;
|
|
168
|
+
return React.createElement(BaseHeading, _extends({
|
|
169
|
+
as: Element,
|
|
170
|
+
margin: margin
|
|
171
|
+
}, rest, {
|
|
172
|
+
level: 5
|
|
173
|
+
}), children);
|
|
174
|
+
};
|
|
175
|
+
|
|
176
|
+
var _excluded$g = ["margin", "children", "as"];
|
|
177
|
+
var defaultElement$9 = 'h6';
|
|
178
|
+
var Heading6 = function Heading6(_ref) {
|
|
179
|
+
var _ref$margin = _ref.margin,
|
|
180
|
+
margin = _ref$margin === void 0 ? 'both' : _ref$margin,
|
|
181
|
+
children = _ref.children,
|
|
182
|
+
as = _ref.as,
|
|
183
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded$g);
|
|
184
|
+
var Element = as || defaultElement$9;
|
|
185
|
+
return React.createElement(BaseHeading, _extends({
|
|
186
|
+
as: Element,
|
|
187
|
+
margin: margin
|
|
188
|
+
}, rest, {
|
|
189
|
+
level: 6
|
|
190
|
+
}), children);
|
|
191
|
+
};
|
|
192
|
+
|
|
193
|
+
var _excluded$f = ["className", "margin", "as"];
|
|
194
|
+
var defaultElement$8 = 'label';
|
|
195
|
+
var Label = function Label(_ref) {
|
|
196
|
+
var _classNames;
|
|
197
|
+
var className = _ref.className,
|
|
198
|
+
_ref$margin = _ref.margin,
|
|
199
|
+
margin = _ref$margin === void 0 ? 'both' : _ref$margin,
|
|
200
|
+
as = _ref.as,
|
|
201
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded$f);
|
|
202
|
+
var Element = as || defaultElement$8;
|
|
203
|
+
return React.createElement(Element, _extends({
|
|
204
|
+
className: classNames('eds-label', (_classNames = {}, _classNames["eds-label--margin-top"] = margin === 'top', _classNames["eds-label--margin-bottom"] = margin === 'bottom', _classNames["eds-label--margin-none"] = margin === 'none', _classNames), className)
|
|
205
|
+
}, rest));
|
|
206
|
+
};
|
|
207
|
+
|
|
208
|
+
var _excluded$e = ["className", "margin", "as"];
|
|
209
|
+
var defaultElement$7 = 'p';
|
|
210
|
+
var LeadParagraph = function LeadParagraph(_ref) {
|
|
211
|
+
var _classNames;
|
|
212
|
+
var className = _ref.className,
|
|
213
|
+
_ref$margin = _ref.margin,
|
|
214
|
+
margin = _ref$margin === void 0 ? 'both' : _ref$margin,
|
|
215
|
+
as = _ref.as,
|
|
216
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded$e);
|
|
217
|
+
var Element = as || defaultElement$7;
|
|
218
|
+
return React.createElement(Element, _extends({
|
|
219
|
+
className: classNames('eds-lead-paragraph', (_classNames = {}, _classNames["eds-lead-paragraph--margin-top"] = margin === 'top', _classNames["eds-lead-paragraph--margin-bottom"] = margin === 'bottom', _classNames["eds-lead-paragraph--margin-none"] = margin === 'none', _classNames), className)
|
|
220
|
+
}, rest));
|
|
221
|
+
};
|
|
222
|
+
|
|
223
|
+
var _excluded$d = ["external", "ariaLabelExternalIcon", "className", "margin", "children", "as"];
|
|
224
|
+
var defaultElement$6 = 'a';
|
|
225
|
+
var Link = function Link(_ref) {
|
|
226
|
+
var _classNames;
|
|
227
|
+
var _ref$external = _ref.external,
|
|
228
|
+
external = _ref$external === void 0 ? false : _ref$external,
|
|
229
|
+
_ref$ariaLabelExterna = _ref.ariaLabelExternalIcon,
|
|
230
|
+
ariaLabelExternalIcon = _ref$ariaLabelExterna === void 0 ? '(ekstern lenke)' : _ref$ariaLabelExterna,
|
|
231
|
+
className = _ref.className,
|
|
232
|
+
_ref$margin = _ref.margin,
|
|
233
|
+
margin = _ref$margin === void 0 ? 'both' : _ref$margin,
|
|
234
|
+
children = _ref.children,
|
|
235
|
+
as = _ref.as,
|
|
236
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded$d);
|
|
237
|
+
var Element = as || defaultElement$6;
|
|
238
|
+
return React.createElement(Element, _extends({
|
|
239
|
+
className: classNames('eds-link', (_classNames = {}, _classNames["eds-link--margin-top"] = margin === 'top', _classNames["eds-link--margin-bottom"] = margin === 'bottom', _classNames["eds-link--margin-none"] = margin === 'none', _classNames), className)
|
|
240
|
+
}, rest), children, external ? React.createElement(icons.ExternalIcon, {
|
|
241
|
+
className: "eds-link--ext-icon",
|
|
242
|
+
"aria-label": ariaLabelExternalIcon
|
|
243
|
+
}) : React.createElement(React.Fragment, null));
|
|
244
|
+
};
|
|
245
|
+
|
|
246
|
+
var _excluded$c = ["className", "margin", "as"];
|
|
247
|
+
var defaultElement$5 = 'strong';
|
|
248
|
+
var StrongText = function StrongText(_ref) {
|
|
249
|
+
var _classNames;
|
|
250
|
+
var className = _ref.className,
|
|
251
|
+
_ref$margin = _ref.margin,
|
|
252
|
+
margin = _ref$margin === void 0 ? 'both' : _ref$margin,
|
|
253
|
+
as = _ref.as,
|
|
254
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded$c);
|
|
255
|
+
var Element = as || defaultElement$5;
|
|
256
|
+
return React.createElement(Element, _extends({
|
|
257
|
+
className: classNames('eds-strong-text', (_classNames = {}, _classNames["eds-strong-text--margin-top"] = margin === 'top', _classNames["eds-strong-text--margin-bottom"] = margin === 'bottom', _classNames["eds-strong-text--margin-none"] = margin === 'none', _classNames), className)
|
|
258
|
+
}, rest));
|
|
259
|
+
};
|
|
260
|
+
|
|
261
|
+
var _excluded$b = ["children", "className", "title"];
|
|
262
|
+
var ListItem = function ListItem(_ref) {
|
|
263
|
+
var children = _ref.children,
|
|
264
|
+
className = _ref.className,
|
|
265
|
+
title = _ref.title,
|
|
266
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded$b);
|
|
267
|
+
return React.createElement("li", _extends({
|
|
268
|
+
className: classNames('eds-list-item', className)
|
|
269
|
+
}, rest), title && React.createElement(StrongText, {
|
|
270
|
+
className: "eds-list-item__title"
|
|
271
|
+
}, title), children);
|
|
272
|
+
};
|
|
273
|
+
|
|
274
|
+
var _excluded$a = ["className", "type"];
|
|
275
|
+
var NumberedList = function NumberedList(_ref) {
|
|
276
|
+
var _classNames;
|
|
277
|
+
var className = _ref.className,
|
|
278
|
+
_ref$type = _ref.type,
|
|
279
|
+
type = _ref$type === void 0 ? '1' : _ref$type,
|
|
280
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded$a);
|
|
281
|
+
return React.createElement("ol", _extends({
|
|
282
|
+
className: classNames('eds-numbered-list', (_classNames = {}, _classNames["eds-numbered-list--type-" + type] = type, _classNames), className),
|
|
283
|
+
type: type
|
|
284
|
+
}, rest));
|
|
285
|
+
};
|
|
286
|
+
|
|
287
|
+
var _excluded$9 = ["margin", "className", "as"];
|
|
288
|
+
var defaultElement$4 = 'p';
|
|
289
|
+
var Paragraph = function Paragraph(_ref) {
|
|
290
|
+
var _ref$margin = _ref.margin,
|
|
291
|
+
margin = _ref$margin === void 0 ? 'bottom' : _ref$margin,
|
|
292
|
+
className = _ref.className,
|
|
293
|
+
as = _ref.as,
|
|
294
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded$9);
|
|
295
|
+
var Element = as || defaultElement$4;
|
|
296
|
+
return React.createElement(Element, _extends({
|
|
297
|
+
className: classNames('eds-paragraph', {
|
|
298
|
+
'eds-paragraph--margin-bottom': margin === 'bottom',
|
|
299
|
+
'eds-paragraph--margin-none': margin === 'none'
|
|
300
|
+
}, className)
|
|
301
|
+
}, rest));
|
|
302
|
+
};
|
|
303
|
+
|
|
304
|
+
var _excluded$8 = ["className", "as"];
|
|
305
|
+
var defaultElement$3 = 'pre';
|
|
306
|
+
var PreformattedText = function PreformattedText(_ref) {
|
|
307
|
+
var className = _ref.className,
|
|
308
|
+
as = _ref.as,
|
|
309
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded$8);
|
|
310
|
+
var Element = as || defaultElement$3;
|
|
311
|
+
return React.createElement(Element, _extends({
|
|
312
|
+
className: classNames('eds-preformatted-text', className)
|
|
313
|
+
}, rest));
|
|
314
|
+
};
|
|
315
|
+
|
|
316
|
+
var _excluded$7 = ["className", "margin", "as"];
|
|
317
|
+
var defaultElement$2 = 'span';
|
|
318
|
+
var SmallText = function SmallText(_ref) {
|
|
319
|
+
var _classNames;
|
|
320
|
+
var className = _ref.className,
|
|
321
|
+
_ref$margin = _ref.margin,
|
|
322
|
+
margin = _ref$margin === void 0 ? 'both' : _ref$margin,
|
|
323
|
+
as = _ref.as,
|
|
324
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded$7);
|
|
325
|
+
var Element = as || defaultElement$2;
|
|
326
|
+
return React.createElement(Element, _extends({
|
|
327
|
+
className: classNames('eds-small-text', (_classNames = {}, _classNames["eds-small-text--margin-top"] = margin === 'top', _classNames["eds-small-text--margin-bottom"] = margin === 'bottom', _classNames["eds-small-text--margin-none"] = margin === 'none', _classNames), className)
|
|
328
|
+
}, rest));
|
|
329
|
+
};
|
|
330
|
+
|
|
331
|
+
var _excluded$6 = ["className", "margin", "as"];
|
|
332
|
+
var defaultElement$1 = 'span';
|
|
333
|
+
var SubLabel = function SubLabel(_ref) {
|
|
334
|
+
var _classNames;
|
|
335
|
+
var className = _ref.className,
|
|
336
|
+
_ref$margin = _ref.margin,
|
|
337
|
+
margin = _ref$margin === void 0 ? 'both' : _ref$margin,
|
|
338
|
+
as = _ref.as,
|
|
339
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded$6);
|
|
340
|
+
var Element = as || defaultElement$1;
|
|
341
|
+
return React.createElement(Element, _extends({
|
|
342
|
+
className: classNames('eds-sub-label', (_classNames = {}, _classNames["eds-sub-label--margin-top"] = margin === 'top', _classNames["eds-sub-label--margin-bottom"] = margin === 'bottom', _classNames["eds-sub-label--margin-none"] = margin === 'none', _classNames), className)
|
|
343
|
+
}, rest));
|
|
344
|
+
};
|
|
345
|
+
|
|
346
|
+
var _excluded$5 = ["className", "margin", "as"];
|
|
347
|
+
var defaultElement = 'p';
|
|
348
|
+
var SubParagraph = function SubParagraph(_ref) {
|
|
349
|
+
var _classNames;
|
|
350
|
+
var className = _ref.className,
|
|
351
|
+
margin = _ref.margin,
|
|
352
|
+
as = _ref.as,
|
|
353
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded$5);
|
|
354
|
+
var Element = as || defaultElement;
|
|
355
|
+
return React.createElement(Element, _extends({
|
|
356
|
+
className: classNames('eds-sub-paragraph', (_classNames = {}, _classNames["eds-sub-paragraph--margin-top"] = margin === 'top', _classNames["eds-sub-paragraph--margin-bottom"] = margin === 'bottom', _classNames["eds-sub-paragraph--margin-none"] = margin === 'none', _classNames), className)
|
|
357
|
+
}, rest));
|
|
358
|
+
};
|
|
359
|
+
|
|
360
|
+
var _excluded$4 = ["className"];
|
|
361
|
+
var UnorderedList = function UnorderedList(_ref) {
|
|
362
|
+
var className = _ref.className,
|
|
363
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded$4);
|
|
364
|
+
return React.createElement("ul", _extends({
|
|
365
|
+
className: classNames('eds-unordered-list', className)
|
|
366
|
+
}, rest));
|
|
367
|
+
};
|
|
368
|
+
|
|
369
|
+
function getHeadingVariantFromSemanticType(semanticType) {
|
|
370
|
+
// Handle string element types (like 'h1', 'div', 'span')
|
|
371
|
+
if (typeof semanticType === 'string') {
|
|
372
|
+
switch (semanticType) {
|
|
373
|
+
case 'h1':
|
|
374
|
+
return 'title-1';
|
|
375
|
+
case 'h2':
|
|
376
|
+
return 'title-2';
|
|
377
|
+
case 'h3':
|
|
378
|
+
return 'subtitle-1';
|
|
379
|
+
case 'h4':
|
|
380
|
+
return 'subtitle-2';
|
|
381
|
+
case 'p':
|
|
382
|
+
return 'paragraph';
|
|
383
|
+
default:
|
|
384
|
+
return 'title-1';
|
|
385
|
+
}
|
|
386
|
+
}
|
|
387
|
+
// Handle React component types (functions/classes) - default to 'title-1'
|
|
388
|
+
return 'title-1';
|
|
389
|
+
}
|
|
390
|
+
function getSemanticTypeFromTextVariant(variant) {
|
|
391
|
+
switch (variant) {
|
|
392
|
+
case 'paragraph':
|
|
393
|
+
case 'subparagraph':
|
|
394
|
+
case 'leading':
|
|
395
|
+
case 'quote':
|
|
396
|
+
return 'p';
|
|
397
|
+
case 'caption':
|
|
398
|
+
case 'sublabel':
|
|
399
|
+
return 'small';
|
|
400
|
+
case 'label':
|
|
401
|
+
return 'span';
|
|
402
|
+
case 'overline':
|
|
403
|
+
return 'em';
|
|
404
|
+
case 'emphasized':
|
|
405
|
+
case 'code-text':
|
|
406
|
+
return 'code';
|
|
407
|
+
default:
|
|
408
|
+
return 'p';
|
|
409
|
+
}
|
|
410
|
+
}
|
|
411
|
+
/**
|
|
412
|
+
* Generates spacing class names for typography components
|
|
413
|
+
* @param spacing - The spacing value from TypographySpacing
|
|
414
|
+
* @param componentPrefix - The CSS class prefix (e.g., 'eds-heading', 'eds-text')
|
|
415
|
+
* @returns Object with class names for the spacing prop
|
|
416
|
+
*/
|
|
417
|
+
function getSpacingClasses(spacing, componentPrefix) {
|
|
418
|
+
var _ref;
|
|
419
|
+
if (!spacing) return undefined;
|
|
420
|
+
return _ref = {}, _ref[componentPrefix + "--spacing-none"] = spacing === 'none', _ref[componentPrefix + "--spacing-xs2"] = spacing === 'xs2', _ref[componentPrefix + "--spacing-xs2-top"] = spacing === 'xs2-top', _ref[componentPrefix + "--spacing-xs2-bottom"] = spacing === 'xs2-bottom', _ref[componentPrefix + "--spacing-xs"] = spacing === 'xs', _ref[componentPrefix + "--spacing-xs-top"] = spacing === 'xs-top', _ref[componentPrefix + "--spacing-xs-bottom"] = spacing === 'xs-bottom', _ref[componentPrefix + "--spacing-sm"] = spacing === 'sm', _ref[componentPrefix + "--spacing-sm-top"] = spacing === 'sm-top', _ref[componentPrefix + "--spacing-sm-bottom"] = spacing === 'sm-bottom', _ref[componentPrefix + "--spacing-md"] = spacing === 'md', _ref[componentPrefix + "--spacing-md-top"] = spacing === 'md-top', _ref[componentPrefix + "--spacing-md-bottom"] = spacing === 'md-bottom', _ref[componentPrefix + "--spacing-lg"] = spacing === 'lg', _ref[componentPrefix + "--spacing-lg-top"] = spacing === 'lg-top', _ref[componentPrefix + "--spacing-lg-bottom"] = spacing === 'lg-bottom', _ref[componentPrefix + "--spacing-xl"] = spacing === 'xl', _ref[componentPrefix + "--spacing-xl-top"] = spacing === 'xl-top', _ref[componentPrefix + "--spacing-xl-bottom"] = spacing === 'xl-bottom', _ref;
|
|
421
|
+
}
|
|
422
|
+
|
|
423
|
+
var _excluded$3 = ["children", "as", "size", "variant", "weight", "spacing", "className"];
|
|
424
|
+
var TypographyText = function TypographyText(_ref) {
|
|
425
|
+
var children = _ref.children,
|
|
426
|
+
as = _ref.as,
|
|
427
|
+
size = _ref.size,
|
|
428
|
+
variant = _ref.variant,
|
|
429
|
+
_ref$weight = _ref.weight,
|
|
430
|
+
weight = _ref$weight === void 0 ? 'medium' : _ref$weight,
|
|
431
|
+
spacing = _ref.spacing,
|
|
432
|
+
className = _ref.className,
|
|
433
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded$3);
|
|
434
|
+
var BodyElement = as || getSemanticTypeFromTextVariant(variant);
|
|
435
|
+
return React.createElement(BodyElement, _extends({
|
|
436
|
+
className: classNames('eds-text', variant && "eds-text--" + variant, size && "eds-text--" + size, weight && "eds-text--weight-" + weight, getSpacingClasses(spacing, 'eds-text'), className)
|
|
437
|
+
}, rest), children);
|
|
438
|
+
};
|
|
439
|
+
// Export as Text to avoid DOM conflicts
|
|
440
|
+
var Text = TypographyText;
|
|
441
|
+
|
|
442
|
+
var _excluded$2 = ["children", "as", "size", "variant", "spacing", "className"];
|
|
443
|
+
var Heading = function Heading(_ref) {
|
|
444
|
+
var _classNames, _classNames2;
|
|
445
|
+
var children = _ref.children,
|
|
446
|
+
as = _ref.as,
|
|
447
|
+
size = _ref.size,
|
|
448
|
+
variant = _ref.variant,
|
|
449
|
+
spacing = _ref.spacing,
|
|
450
|
+
className = _ref.className,
|
|
451
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded$2);
|
|
452
|
+
var HeadingElement = as || 'h1';
|
|
453
|
+
// Function to determine the variant based on the semantic type
|
|
454
|
+
var usedVariant = variant != null ? variant : getHeadingVariantFromSemanticType(HeadingElement);
|
|
455
|
+
// When size is explicitly provided, it should override variant styling
|
|
456
|
+
var shouldUseSize = size !== undefined;
|
|
457
|
+
return React.createElement(HeadingElement, _extends({
|
|
458
|
+
className: classNames('eds-heading', (_classNames = {}, _classNames["eds-heading--" + usedVariant] = !shouldUseSize, _classNames), (_classNames2 = {}, _classNames2["eds-heading--" + size] = shouldUseSize && size, _classNames2), getSpacingClasses(spacing, 'eds-heading'), className)
|
|
459
|
+
}, rest), children);
|
|
460
|
+
};
|
|
461
|
+
|
|
462
|
+
var _excluded$1 = ["className"],
|
|
463
|
+
_excluded2 = ["className"];
|
|
464
|
+
var BlockquoteBeta = function BlockquoteBeta(_ref) {
|
|
465
|
+
var className = _ref.className,
|
|
466
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded$1);
|
|
467
|
+
return React.createElement("blockquote", _extends({
|
|
468
|
+
className: classNames('eds-text--blockquote', className)
|
|
469
|
+
}, rest));
|
|
470
|
+
};
|
|
471
|
+
var BlockquoteFooterBeta = function BlockquoteFooterBeta(_ref2) {
|
|
472
|
+
var className = _ref2.className,
|
|
473
|
+
rest = _objectWithoutPropertiesLoose(_ref2, _excluded2);
|
|
474
|
+
return React.createElement("footer", _extends({
|
|
475
|
+
className: classNames('eds-text--blockquote__footer', className)
|
|
476
|
+
}, rest));
|
|
477
|
+
};
|
|
478
|
+
|
|
479
|
+
var _excluded = ["external", "ariaLabelExternalIcon", "className", "spacing", "children", "as"];
|
|
480
|
+
var LinkBeta = function LinkBeta(_ref) {
|
|
481
|
+
var _ref$external = _ref.external,
|
|
482
|
+
external = _ref$external === void 0 ? false : _ref$external,
|
|
483
|
+
_ref$ariaLabelExterna = _ref.ariaLabelExternalIcon,
|
|
484
|
+
ariaLabelExternalIcon = _ref$ariaLabelExterna === void 0 ? '(ekstern lenke)' : _ref$ariaLabelExterna,
|
|
485
|
+
className = _ref.className,
|
|
486
|
+
spacing = _ref.spacing,
|
|
487
|
+
children = _ref.children,
|
|
488
|
+
as = _ref.as,
|
|
489
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded);
|
|
490
|
+
var LinkElement = as || 'a';
|
|
491
|
+
return React.createElement(LinkElement, _extends({
|
|
492
|
+
className: classNames('eds-text--link', getSpacingClasses(spacing, 'eds-text--link'), className)
|
|
493
|
+
}, rest), children, external ? React.createElement(icons.ExternalIcon, {
|
|
494
|
+
className: "eds-text--link--ext-icon",
|
|
495
|
+
"aria-label": ariaLabelExternalIcon
|
|
496
|
+
}) : null);
|
|
497
|
+
};
|
|
498
|
+
|
|
499
|
+
utils.warnAboutMissingStyles('typography');
|
|
500
|
+
|
|
501
|
+
exports.Blockquote = Blockquote;
|
|
502
|
+
exports.BlockquoteBeta = BlockquoteBeta;
|
|
503
|
+
exports.BlockquoteFooter = BlockquoteFooter;
|
|
504
|
+
exports.BlockquoteFooterBeta = BlockquoteFooterBeta;
|
|
505
|
+
exports.CodeText = CodeText;
|
|
506
|
+
exports.EmphasizedText = EmphasizedText;
|
|
507
|
+
exports.Heading = Heading;
|
|
508
|
+
exports.Heading1 = Heading1;
|
|
509
|
+
exports.Heading2 = Heading2;
|
|
510
|
+
exports.Heading3 = Heading3;
|
|
511
|
+
exports.Heading4 = Heading4;
|
|
512
|
+
exports.Heading5 = Heading5;
|
|
513
|
+
exports.Heading6 = Heading6;
|
|
514
|
+
exports.Label = Label;
|
|
515
|
+
exports.LeadParagraph = LeadParagraph;
|
|
516
|
+
exports.Link = Link;
|
|
517
|
+
exports.LinkBeta = LinkBeta;
|
|
518
|
+
exports.ListItem = ListItem;
|
|
519
|
+
exports.NumberedList = NumberedList;
|
|
520
|
+
exports.Paragraph = Paragraph;
|
|
521
|
+
exports.PreformattedText = PreformattedText;
|
|
522
|
+
exports.SmallText = SmallText;
|
|
523
|
+
exports.StrongText = StrongText;
|
|
524
|
+
exports.SubLabel = SubLabel;
|
|
525
|
+
exports.SubParagraph = SubParagraph;
|
|
526
|
+
exports.Text = Text;
|
|
527
|
+
exports.UnorderedList = UnorderedList;
|
|
528
|
+
//# sourceMappingURL=typography.cjs.development.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"typography.cjs.development.js","sources":["../src/Blockquote.tsx","../src/CodeText.tsx","../src/EmphasizedText.tsx","../src/BaseHeading.tsx","../src/Heading1.tsx","../src/Heading2.tsx","../src/Heading3.tsx","../src/Heading4.tsx","../src/Heading5.tsx","../src/Heading6.tsx","../src/Label.tsx","../src/LeadParagraph.tsx","../src/Link.tsx","../src/StrongText.tsx","../src/ListItem.tsx","../src/NumberedList.tsx","../src/Paragraph.tsx","../src/PreformattedText.tsx","../src/SmallText.tsx","../src/SubLabel.tsx","../src/SubParagraph.tsx","../src/UnorderedList.tsx","../src/beta/utils.ts","../src/beta/Text.tsx","../src/beta/Heading.tsx","../src/beta/BlockquoteBeta.tsx","../src/beta/LinkBeta.tsx","../src/index.tsx"],"sourcesContent":["import React from 'react';\nimport classNames from 'classnames';\n\ntype BlockquoteProps = {\n /** Ekstra klassenavn */\n className?: string;\n} & React.DetailedHTMLProps<\n React.BlockquoteHTMLAttributes<HTMLElement>,\n HTMLQuoteElement\n>;\n\nexport const Blockquote = ({ className, ref, ...rest }: BlockquoteProps) => {\n return (\n <blockquote\n className={classNames('eds-blockquote', className)}\n ref={ref}\n {...rest}\n />\n );\n};\n\ntype BlockquoteFooterProps = {\n /** Ekstra klassenavn */\n className?: string;\n} & React.DetailedHTMLProps<React.HTMLAttributes<HTMLElement>, HTMLElement>;\n\nexport const BlockquoteFooter: React.FunctionComponent<BlockquoteFooterProps> =\n ({ className, ...rest }) => {\n return (\n <footer\n className={classNames('eds-blockquote__footer', className)}\n {...rest}\n />\n );\n };\n","import React from 'react';\nimport classNames from 'classnames';\nimport { PolymorphicComponentProps } from '@entur/utils';\n\nexport type CodeTextOwnProps = {\n /** HTML-elementet eller React-komponenten som rendres\n * @default \"code\"\n */\n as?: string | React.ElementType;\n /** Ekstra klassenavn */\n className?: string;\n /** Innholdet */\n children: React.ReactNode;\n};\n\nexport type CodeTextProps<T extends React.ElementType = typeof defaultElement> =\n PolymorphicComponentProps<T, CodeTextOwnProps>;\n\nconst defaultElement = 'code';\n\nexport const CodeText = <E extends React.ElementType = typeof defaultElement>({\n className,\n as,\n ...rest\n}: CodeTextProps<E>): JSX.Element => {\n const Element: React.ElementType = as || defaultElement;\n return (\n <Element className={classNames('eds-code-text', className)} {...rest} />\n );\n};\n","import React from 'react';\nimport classNames from 'classnames';\nimport { PolymorphicComponentProps } from '@entur/utils';\n\nexport type EmphasizedTextOwnProps = {\n /** HTML-elementet eller React-komponenten som rendres\n * @default \"em\"\n */\n as?: string | React.ElementType;\n /** Ekstra klassenavn */\n className?: string;\n /** Innholdet */\n children: React.ReactNode;\n /** Hvor du vil ha marginer\n * @default \"both\"\n */\n margin?: 'top' | 'bottom' | 'both' | 'none';\n};\n\nexport type EmphasizedTextProps<\n T extends React.ElementType = typeof defaultElement,\n> = PolymorphicComponentProps<T, EmphasizedTextOwnProps>;\n\nconst defaultElement = 'em';\n\nexport const EmphasizedText = <\n E extends React.ElementType = typeof defaultElement,\n>({\n className,\n margin = 'both',\n as,\n ...rest\n}: EmphasizedTextProps<E>): JSX.Element => {\n const Element: React.ElementType = as || defaultElement;\n return (\n <Element\n className={classNames(\n 'eds-emphasized-text',\n {\n [`eds-emphasized-text--margin-top`]: margin === 'top',\n [`eds-emphasized-text--margin-bottom`]: margin === 'bottom',\n [`eds-emphasized-text--margin-none`]: margin === 'none',\n },\n className,\n )}\n {...rest}\n />\n );\n};\n","import React from 'react';\nimport classNames from 'classnames';\nimport { PolymorphicComponentProps } from '@entur/utils';\n\ntype BaseHeadingOwnProps = {\n /** HTML-elementet eller React-komponenten som rendres */\n as: string | React.ElementType;\n /** Ekstra klassenavn */\n className?: string;\n /** Innholdet */\n children: React.ReactNode;\n /** Hvor du vil ha marginer */\n margin: 'top' | 'bottom' | 'both' | 'none';\n /** Nivået på overskriften */\n level: 1 | 2 | 3 | 4 | 5 | 6;\n};\nconst defaultElement = 'h1';\n\nexport type BaseHeadingProps<\n T extends React.ElementType = typeof defaultElement,\n> = PolymorphicComponentProps<T, BaseHeadingOwnProps>;\n\nexport const BaseHeading = <\n E extends React.ElementType = typeof defaultElement,\n>({\n className,\n level,\n margin,\n as,\n ...rest\n}: BaseHeadingProps<E>): JSX.Element => {\n const Element: React.ElementType = as || defaultElement;\n const baseClass = `eds-h${level}`;\n return (\n <Element\n className={classNames(\n baseClass,\n {\n [`${baseClass}--margin-top`]: margin === 'top',\n [`${baseClass}--margin-bottom`]: margin === 'bottom',\n [`${baseClass}--margin-none`]: margin === 'none',\n },\n className,\n )}\n {...rest}\n />\n );\n};\n","import React from 'react';\nimport { BaseHeading } from './BaseHeading';\nimport { PolymorphicComponentProps } from '@entur/utils';\n\nexport type Heading1OwnProps = {\n /** HTML-elementet eller React-komponenten som rendres\n * @default \"h1\"\n */\n as?: string | React.ElementType;\n /** Ekstra klassenavn */\n className?: string;\n /** Innholdet */\n children: React.ReactNode;\n /** Hvor du vil ha marginer\n * @default \"both\"\n */\n margin?: 'top' | 'bottom' | 'both' | 'none';\n};\n\nconst defaultElement = 'h1';\n\nexport type Heading1Props<T extends React.ElementType = typeof defaultElement> =\n PolymorphicComponentProps<T, Heading1OwnProps>;\n\nexport const Heading1 = <E extends React.ElementType = typeof defaultElement>({\n margin = 'both',\n children,\n as,\n ...rest\n}: Heading1Props<E>): JSX.Element => {\n const Element: React.ElementType = as || defaultElement;\n return (\n <BaseHeading as={Element} margin={margin} {...rest} level={1}>\n {children}\n </BaseHeading>\n );\n};\n","import React from 'react';\nimport { BaseHeading } from './BaseHeading';\nimport { PolymorphicComponentProps } from '@entur/utils';\n\nexport type Heading2OwnProps = {\n /** HTML-elementet eller React-komponenten som rendres\n * @default \"h2\"\n */\n as?: string | React.ElementType;\n /** Ekstra klassenavn */\n className?: string;\n /** Innholdet */\n children: React.ReactNode;\n /** Hvor du vil ha marginer\n * @default \"both\"\n */\n margin?: 'top' | 'bottom' | 'both' | 'none';\n};\n\nexport type Heading2Props<T extends React.ElementType = typeof defaultElement> =\n PolymorphicComponentProps<T, Heading2OwnProps>;\n\nconst defaultElement = 'h2';\n\nexport const Heading2 = <E extends React.ElementType = typeof defaultElement>({\n margin = 'both',\n children,\n as,\n ...rest\n}: Heading2Props<E>): JSX.Element => {\n const Element: React.ElementType = as || defaultElement;\n return (\n <BaseHeading as={Element} margin={margin} {...rest} level={2}>\n {children}\n </BaseHeading>\n );\n};\n","import React from 'react';\nimport { BaseHeading } from './BaseHeading';\nimport { PolymorphicComponentProps } from '@entur/utils';\n\nexport type Heading3OwnProps = {\n /** HTML-elementet eller React-komponenten som rendres\n * @default \"h3\"\n */\n as?: string | React.ElementType;\n /** Ekstra klassenavn */\n className?: string;\n /** Innholdet */\n children: React.ReactNode;\n /** Hvor du vil ha marginer\n * @default \"both\"\n */\n margin?: 'top' | 'bottom' | 'both' | 'none';\n};\n\nexport type Heading3Props<T extends React.ElementType = typeof defaultElement> =\n PolymorphicComponentProps<T, Heading3OwnProps>;\n\nconst defaultElement = 'h3';\n\nexport const Heading3 = <E extends React.ElementType = typeof defaultElement>({\n margin = 'both',\n children,\n as,\n ...rest\n}: Heading3Props<E>): JSX.Element => {\n const Element: React.ElementType = as || defaultElement;\n return (\n <BaseHeading as={Element} margin={margin} {...rest} level={3}>\n {children}\n </BaseHeading>\n );\n};\n","import React from 'react';\nimport { BaseHeading } from './BaseHeading';\nimport { PolymorphicComponentProps } from '@entur/utils';\n\nexport type Heading4OwnProps = {\n /** HTML-elementet eller React-komponenten som rendres\n * @default \"h4\"\n */\n as?: string | React.ElementType;\n /** Ekstra klassenavn */\n className?: string;\n /** Innholdet */\n children: React.ReactNode;\n /** Hvor du vil ha marginer\n * @default \"both\"\n */\n margin?: 'top' | 'bottom' | 'both' | 'none';\n};\n\nexport type Heading4Props<T extends React.ElementType = typeof defaultElement> =\n PolymorphicComponentProps<T, Heading4OwnProps>;\n\nconst defaultElement = 'h4';\nexport const Heading4 = <E extends React.ElementType = typeof defaultElement>({\n margin = 'both',\n children,\n as,\n ...rest\n}: Heading4Props<E>): JSX.Element => {\n const Element: React.ElementType = as || defaultElement;\n return (\n <BaseHeading as={Element} margin={margin} {...rest} level={4}>\n {children}\n </BaseHeading>\n );\n};\n","import React from 'react';\nimport { BaseHeading } from './BaseHeading';\nimport { PolymorphicComponentProps } from '@entur/utils';\n\nexport type Heading5OwnProps = {\n /** HTML-elementet eller React-komponenten som rendres\n * @default \"h5\"\n */\n as?: string | React.ElementType;\n /** Ekstra klassenavn */\n className?: string;\n /** Innholdet */\n children: React.ReactNode;\n /** Hvor du vil ha marginer\n * @default \"both\"\n */\n margin?: 'top' | 'bottom' | 'both' | 'none';\n};\n\nexport type Heading5Props<T extends React.ElementType = typeof defaultElement> =\n PolymorphicComponentProps<T, Heading5OwnProps>;\n\nconst defaultElement = 'h5';\n\nexport const Heading5 = <E extends React.ElementType = typeof defaultElement>({\n margin = 'both',\n children,\n as,\n ...rest\n}: Heading5Props<E>): JSX.Element => {\n const Element: React.ElementType = as || defaultElement;\n return (\n <BaseHeading as={Element} margin={margin} {...rest} level={5}>\n {children}\n </BaseHeading>\n );\n};\n","import React from 'react';\nimport { BaseHeading } from './BaseHeading';\nimport { PolymorphicComponentProps } from '@entur/utils';\n\nexport type Heading6OwnProps = {\n /** HTML-elementet eller React-komponenten som rendres\n * @default \"h6\"\n */\n as?: string | React.ElementType;\n /** Ekstra klassenavn */\n className?: string;\n /** Innholdet */\n children: React.ReactNode;\n /** Hvor du vil ha marginer\n * @default \"both\"\n */\n margin?: 'top' | 'bottom' | 'both' | 'none';\n};\n\nexport type Heading6Props<T extends React.ElementType = typeof defaultElement> =\n PolymorphicComponentProps<T, Heading6OwnProps>;\n\nconst defaultElement = 'h6';\n\nexport const Heading6 = <E extends React.ElementType = typeof defaultElement>({\n margin = 'both',\n children,\n as,\n ...rest\n}: Heading6Props<E>): JSX.Element => {\n const Element: React.ElementType = as || defaultElement;\n return (\n <BaseHeading as={Element} margin={margin} {...rest} level={6}>\n {children}\n </BaseHeading>\n );\n};\n","import React from 'react';\nimport classNames from 'classnames';\nimport { PolymorphicComponentProps } from '@entur/utils';\n\nexport type LabelOwnProps = {\n /** HTML-elementet eller React-komponenten som rendres\n * @default \"label\"\n */\n as?: string | React.ElementType;\n /** Ekstra klassenavn */\n className?: string;\n /** Innholdet */\n children: React.ReactNode;\n /** Hvor du vil ha marginer\n * @default \"both\"\n */\n margin?: 'top' | 'bottom' | 'both' | 'none';\n};\n\nexport type LabelProps<T extends React.ElementType = typeof defaultElement> =\n PolymorphicComponentProps<T, LabelOwnProps>;\n\nconst defaultElement = 'label';\n\nexport const Label = <E extends React.ElementType = typeof defaultElement>({\n className,\n margin = 'both',\n as,\n ...rest\n}: LabelProps<E>): JSX.Element => {\n const Element: React.ElementType = as || defaultElement;\n return (\n <Element\n className={classNames(\n 'eds-label',\n {\n [`eds-label--margin-top`]: margin === 'top',\n [`eds-label--margin-bottom`]: margin === 'bottom',\n [`eds-label--margin-none`]: margin === 'none',\n },\n className,\n )}\n {...rest}\n />\n );\n};\n","import React from 'react';\nimport classNames from 'classnames';\nimport { PolymorphicComponentProps } from '@entur/utils';\n\nexport type LeadParagraphOwnProps = {\n /** HTML-elementet eller React-komponenten som rendres\n * @default \"p\"\n */\n as?: string | React.ElementType;\n /** Ekstra klassenavn */\n className?: string;\n /** Innholdet */\n children: React.ReactNode;\n /** Hvor du vil ha marginer\n * @default \"both\"\n */\n margin?: 'top' | 'bottom' | 'both' | 'none';\n};\n\nexport type LeadParagraphProps<\n T extends React.ElementType = typeof defaultElement,\n> = PolymorphicComponentProps<T, LeadParagraphOwnProps>;\n\nconst defaultElement = 'p';\n\nexport const LeadParagraph = <\n E extends React.ElementType = typeof defaultElement,\n>({\n className,\n margin = 'both',\n as,\n ...rest\n}: LeadParagraphProps<E>): JSX.Element => {\n const Element: React.ElementType = as || defaultElement;\n return (\n <Element\n className={classNames(\n 'eds-lead-paragraph',\n {\n [`eds-lead-paragraph--margin-top`]: margin === 'top',\n [`eds-lead-paragraph--margin-bottom`]: margin === 'bottom',\n [`eds-lead-paragraph--margin-none`]: margin === 'none',\n },\n className,\n )}\n {...rest}\n />\n );\n};\n","import React from 'react';\nimport classNames from 'classnames';\nimport { PolymorphicComponentProps } from '@entur/utils';\nimport { ExternalIcon } from '@entur/icons';\n\nexport type LinkOwnProps = {\n external?: boolean;\n /** HTML-elementet eller React-komponenten som rendres\n * @default \"a\"\n */\n as?: string | React.ElementType;\n /** Ekstra klassenavn */\n className?: string;\n /** Innholdet */\n children: React.ReactNode;\n /** Hvor du vil ha marginer\n * @default \"both\"\n */\n margin?: 'top' | 'bottom' | 'both' | 'none';\n ariaLabelExternalIcon?: string;\n};\n\nexport type LinkProps<T extends React.ElementType = typeof defaultElement> =\n PolymorphicComponentProps<T, LinkOwnProps>;\n\nconst defaultElement = 'a';\n\nexport const Link = <E extends React.ElementType = typeof defaultElement>({\n external = false,\n ariaLabelExternalIcon = '(ekstern lenke)',\n className,\n margin = 'both',\n children,\n as,\n ...rest\n}: LinkProps<E>): JSX.Element => {\n const Element: React.ElementType = as || defaultElement;\n return (\n <Element\n className={classNames(\n 'eds-link',\n {\n [`eds-link--margin-top`]: margin === 'top',\n [`eds-link--margin-bottom`]: margin === 'bottom',\n [`eds-link--margin-none`]: margin === 'none',\n },\n className,\n )}\n {...rest}\n >\n {children}\n {external ? (\n <ExternalIcon\n className=\"eds-link--ext-icon\"\n aria-label={ariaLabelExternalIcon}\n />\n ) : (\n <></>\n )}\n </Element>\n );\n};\n","import React from 'react';\nimport classNames from 'classnames';\nimport { PolymorphicComponentProps } from '@entur/utils';\n\nexport type StrongTextOwnProps = {\n /** HTML-elementet eller React-komponenten som rendres\n * @default \"strong\"\n */\n as?: string | React.ElementType;\n /** Ekstra klassenavn */\n className?: string;\n /** Innholdet */\n children: React.ReactNode;\n /** Hvor du vil ha marginer\n * @default \"both\"\n */\n margin?: 'top' | 'bottom' | 'both' | 'none';\n};\n\nexport type StrongTextProps<\n T extends React.ElementType = typeof defaultElement,\n> = PolymorphicComponentProps<T, StrongTextOwnProps>;\n\nconst defaultElement = 'strong';\n\nexport const StrongText = <\n E extends React.ElementType = typeof defaultElement,\n>({\n className,\n margin = 'both',\n as,\n ...rest\n}: StrongTextProps<E>): JSX.Element => {\n const Element: React.ElementType = as || defaultElement;\n return (\n <Element\n className={classNames(\n 'eds-strong-text',\n {\n [`eds-strong-text--margin-top`]: margin === 'top',\n [`eds-strong-text--margin-bottom`]: margin === 'bottom',\n [`eds-strong-text--margin-none`]: margin === 'none',\n },\n className,\n )}\n {...rest}\n />\n );\n};\n","import React from 'react';\nimport classNames from 'classnames';\nimport { StrongText } from './StrongText';\n\nexport type ListItemProps = {\n /** Ekstra klassenavn */\n className?: string;\n /** Innholdet */\n children: React.ReactNode;\n /** Tittel */\n title?: React.ReactNode;\n [key: string]: any;\n};\n\nexport const ListItem: React.FC<ListItemProps> = ({\n children,\n className,\n title,\n ...rest\n}) => (\n <li className={classNames('eds-list-item', className)} {...rest}>\n {title && <StrongText className=\"eds-list-item__title\">{title}</StrongText>}\n {children}\n </li>\n);\n","import React from 'react';\nimport classNames from 'classnames';\n\nexport type NumberedListProps = {\n /** Ekstra klassenavn */\n className?: string;\n /** Innholdet */\n children: React.ReactNode;\n} & React.OlHTMLAttributes<HTMLOListElement>;\n\nexport const NumberedList: React.FC<NumberedListProps> = ({\n className,\n type = '1',\n ...rest\n}) => (\n <ol\n className={classNames(\n 'eds-numbered-list',\n { [`eds-numbered-list--type-${type}`]: type },\n className,\n )}\n type={type}\n {...rest}\n />\n);\n","import React from 'react';\nimport classNames from 'classnames';\nimport { PolymorphicComponentProps } from '@entur/utils';\n\nexport type ParagraphOwnProps = {\n /** HTML-elementet eller React-komponenten som rendres\n * @default \"p\"\n */\n as?: string | React.ElementType;\n /** Ekstra klassenavn */\n className?: string;\n /** Innholdet */\n children: React.ReactNode;\n /** Hvor du vil ha marginer\n * @default \"bottom\"\n */\n margin?: 'bottom' | 'none';\n};\n\nexport type ParagraphProps<\n T extends React.ElementType = typeof defaultElement,\n> = PolymorphicComponentProps<T, ParagraphOwnProps>;\n\nconst defaultElement = 'p';\n\nexport const Paragraph = <E extends React.ElementType = typeof defaultElement>({\n margin = 'bottom',\n className,\n as,\n ...rest\n}: ParagraphProps<E>): JSX.Element => {\n const Element: React.ElementType = as || defaultElement;\n return (\n <Element\n className={classNames(\n 'eds-paragraph',\n {\n 'eds-paragraph--margin-bottom': margin === 'bottom',\n 'eds-paragraph--margin-none': margin === 'none',\n },\n className,\n )}\n {...rest}\n />\n );\n};\n","import React from 'react';\nimport classNames from 'classnames';\nimport { PolymorphicComponentProps } from '@entur/utils';\n\nexport type PreformattedTextOwnProps = {\n /** HTML-elementet eller React-komponenten som rendres\n * @default \"pre\"\n */\n as?: string | React.ElementType;\n /** Ekstra klassenavn */\n className?: string;\n /** Innholdet */\n children: React.ReactNode;\n};\n\nexport type PreformattedTextProps<T extends React.ElementType> =\n PolymorphicComponentProps<T, PreformattedTextOwnProps>;\n\nconst defaultElement = 'pre';\n\nexport const PreformattedText = <\n E extends React.ElementType = typeof defaultElement,\n>({\n className,\n as,\n ...rest\n}: PreformattedTextProps<E>): JSX.Element => {\n const Element: React.ElementType = as || defaultElement;\n return (\n <Element\n className={classNames('eds-preformatted-text', className)}\n {...rest}\n />\n );\n};\n","import React from 'react';\nimport classNames from 'classnames';\nimport { PolymorphicComponentProps } from '@entur/utils';\n\nexport type SmallTextOwnProps = {\n /** HTML-elementet eller React-komponenten som rendres\n * @default \"span\"\n */\n as?: string | React.ElementType;\n /** Ekstra klassenavn */\n className?: string;\n /** Innholdet */\n children: React.ReactNode;\n /** Hvor du vil ha marginer\n * @default \"both\"\n */\n margin?: 'top' | 'bottom' | 'both' | 'none';\n};\n\nexport type SmallTextProps<\n T extends React.ElementType = typeof defaultElement,\n> = PolymorphicComponentProps<T, SmallTextOwnProps>;\nconst defaultElement = 'span';\n\nexport const SmallText = <E extends React.ElementType = typeof defaultElement>({\n className,\n margin = 'both',\n as,\n ...rest\n}: SmallTextProps<E>): JSX.Element => {\n const Element: React.ElementType = as || defaultElement;\n return (\n <Element\n className={classNames(\n 'eds-small-text',\n {\n [`eds-small-text--margin-top`]: margin === 'top',\n [`eds-small-text--margin-bottom`]: margin === 'bottom',\n [`eds-small-text--margin-none`]: margin === 'none',\n },\n className,\n )}\n {...rest}\n />\n );\n};\n","import React from 'react';\nimport classNames from 'classnames';\nimport { PolymorphicComponentProps } from '@entur/utils';\n\nexport type SubLabelOwnProps = {\n /** HTML-elementet eller React-komponenten som rendres\n * @default \"span\"\n */\n as?: string | React.ElementType;\n /** Ekstra klassenavn */\n className?: string;\n /** Innholdet */\n children: React.ReactNode;\n /** Hvor du vil ha marginer\n * @default \"both\"\n */\n margin?: 'top' | 'bottom' | 'both' | 'none';\n};\n\nexport type SubLabelProps<T extends React.ElementType = typeof defaultElement> =\n PolymorphicComponentProps<T, SubLabelOwnProps>;\n\nconst defaultElement = 'span';\n\nexport const SubLabel = <E extends React.ElementType = typeof defaultElement>({\n className,\n margin = 'both',\n as,\n ...rest\n}: SubLabelProps<E>): JSX.Element => {\n const Element: React.ElementType = as || defaultElement;\n return (\n <Element\n className={classNames(\n 'eds-sub-label',\n {\n [`eds-sub-label--margin-top`]: margin === 'top',\n [`eds-sub-label--margin-bottom`]: margin === 'bottom',\n [`eds-sub-label--margin-none`]: margin === 'none',\n },\n className,\n )}\n {...rest}\n />\n );\n};\n","import React from 'react';\nimport classNames from 'classnames';\nimport { PolymorphicComponentProps } from '@entur/utils';\n\nexport type SubParagraphOwnProps = {\n /** HTML-elementet eller React-komponenten som rendres\n * @default \"p\"\n */\n as?: string | React.ElementType;\n /** Ekstra klassenavn */\n className?: string;\n /** Innholdet */\n children: React.ReactNode;\n /** Hvor du vil ha marginer\n * @default \"both\"\n */\n margin?: 'top' | 'bottom' | 'both' | 'none';\n};\n\nexport type SubParagraphProps<\n T extends React.ElementType = typeof defaultElement,\n> = PolymorphicComponentProps<T, SubParagraphOwnProps>;\n\nconst defaultElement = 'p';\n\nexport const SubParagraph = <\n E extends React.ElementType = typeof defaultElement,\n>({\n className,\n margin,\n as,\n ...rest\n}: SubParagraphProps<E>): JSX.Element => {\n const Element: React.ElementType = as || defaultElement;\n return (\n <Element\n className={classNames(\n 'eds-sub-paragraph',\n {\n [`eds-sub-paragraph--margin-top`]: margin === 'top',\n [`eds-sub-paragraph--margin-bottom`]: margin === 'bottom',\n [`eds-sub-paragraph--margin-none`]: margin === 'none',\n },\n className,\n )}\n {...rest}\n />\n );\n};\n","import React from 'react';\nimport classNames from 'classnames';\n\nexport type UnorderedListProps = {\n /** Ekstra klassenavn */\n className?: string;\n /** Innholdet */\n children: React.ReactNode;\n} & React.DetailedHTMLProps<\n React.HTMLAttributes<HTMLUListElement>,\n HTMLUListElement\n>;\n\nexport const UnorderedList: React.FC<UnorderedListProps> = ({\n className,\n ...rest\n}) => <ul className={classNames('eds-unordered-list', className)} {...rest} />;\n","import { TypographySpacing, TypographyTextVariant } from './types';\n\nexport function getHeadingVariantFromSemanticType(\n semanticType: string | React.ElementType,\n) {\n // Handle string element types (like 'h1', 'div', 'span')\n if (typeof semanticType === 'string') {\n switch (semanticType) {\n case 'h1':\n return 'title-1';\n case 'h2':\n return 'title-2';\n case 'h3':\n return 'subtitle-1';\n case 'h4':\n return 'subtitle-2';\n case 'p':\n return 'paragraph';\n default:\n return 'title-1';\n }\n }\n\n // Handle React component types (functions/classes) - default to 'title-1'\n return 'title-1';\n}\n\nexport function getSemanticTypeFromTextVariant(\n variant?: TypographyTextVariant,\n): React.ElementType {\n switch (variant) {\n case 'paragraph':\n case 'subparagraph':\n case 'leading':\n case 'quote':\n return 'p';\n case 'caption':\n case 'sublabel':\n return 'small';\n case 'label':\n return 'span';\n case 'overline':\n return 'em';\n case 'emphasized':\n case 'code-text':\n return 'code';\n default:\n return 'p';\n }\n}\n\n/**\n * Generates spacing class names for typography components\n * @param spacing - The spacing value from TypographySpacing\n * @param componentPrefix - The CSS class prefix (e.g., 'eds-heading', 'eds-text')\n * @returns Object with class names for the spacing prop\n */\nexport function getSpacingClasses(\n spacing: TypographySpacing | undefined,\n componentPrefix: string,\n): Record<string, boolean> | undefined {\n if (!spacing) return undefined;\n\n return {\n [`${componentPrefix}--spacing-none`]: spacing === 'none',\n [`${componentPrefix}--spacing-xs2`]: spacing === 'xs2',\n [`${componentPrefix}--spacing-xs2-top`]: spacing === 'xs2-top',\n [`${componentPrefix}--spacing-xs2-bottom`]: spacing === 'xs2-bottom',\n [`${componentPrefix}--spacing-xs`]: spacing === 'xs',\n [`${componentPrefix}--spacing-xs-top`]: spacing === 'xs-top',\n [`${componentPrefix}--spacing-xs-bottom`]: spacing === 'xs-bottom',\n [`${componentPrefix}--spacing-sm`]: spacing === 'sm',\n [`${componentPrefix}--spacing-sm-top`]: spacing === 'sm-top',\n [`${componentPrefix}--spacing-sm-bottom`]: spacing === 'sm-bottom',\n [`${componentPrefix}--spacing-md`]: spacing === 'md',\n [`${componentPrefix}--spacing-md-top`]: spacing === 'md-top',\n [`${componentPrefix}--spacing-md-bottom`]: spacing === 'md-bottom',\n [`${componentPrefix}--spacing-lg`]: spacing === 'lg',\n [`${componentPrefix}--spacing-lg-top`]: spacing === 'lg-top',\n [`${componentPrefix}--spacing-lg-bottom`]: spacing === 'lg-bottom',\n [`${componentPrefix}--spacing-xl`]: spacing === 'xl',\n [`${componentPrefix}--spacing-xl-top`]: spacing === 'xl-top',\n [`${componentPrefix}--spacing-xl-bottom`]: spacing === 'xl-bottom',\n };\n}\n","import React from 'react';\n\nimport './styles.scss';\nimport classNames from 'classnames';\nimport {\n TypographySize,\n TypographyTextVariant,\n TypographyWeight,\n TypographySpacing,\n} from './types';\nimport { getSpacingClasses, getSemanticTypeFromTextVariant } from './utils';\nimport { PolymorphicComponentProps } from '@entur/utils';\n\ntype TextBaseProps = {\n /** Visuell tekststørrelse (typografi-token) */\n size?: TypographySize;\n /** Fontvekt */\n weight?: TypographyWeight;\n /** Variant (kan brukes til spesielle typer tekst som for eksempel caption) */\n variant?: TypographyTextVariant;\n /** Innhold */\n children: React.ReactNode;\n /** Spacing around the component */\n spacing?: TypographySpacing;\n /** Ekstra klassenavn */\n className?: string;\n};\n\nexport type TextProps<C extends React.ElementType> = PolymorphicComponentProps<\n C,\n TextBaseProps\n>;\n\nconst TypographyText = <C extends React.ElementType = 'p'>({\n children,\n as,\n size,\n variant,\n weight = 'medium',\n spacing,\n className,\n ...rest\n}: TextProps<C>) => {\n const BodyElement = as || getSemanticTypeFromTextVariant(variant);\n\n return (\n <BodyElement\n className={classNames(\n 'eds-text',\n variant && `eds-text--${variant}`,\n size && `eds-text--${size}`,\n weight && `eds-text--weight-${weight}`,\n getSpacingClasses(spacing, 'eds-text'),\n className,\n )}\n {...rest}\n >\n {children}\n </BodyElement>\n );\n};\n\n// Export as Text to avoid DOM conflicts\nexport const Text = TypographyText;\n","import React from 'react';\n\nimport classNames from 'classnames';\nimport {\n TypographyHeadingVariant,\n TypographySize,\n TypographySpacing,\n} from './types';\nimport { getHeadingVariantFromSemanticType, getSpacingClasses } from './utils';\nimport { PolymorphicComponentProps } from '@entur/utils';\nimport './styles.scss';\n\ntype HeadingBaseProps = {\n /** Visuell variant som bestemmer styling (anbefalt over size) */\n variant?: TypographyHeadingVariant;\n /** Visuell tekststørrelse som overstyrer variant-styling */\n size?: TypographySize;\n /** Innholdet som skal vises */\n children: React.ReactNode;\n /** Ekstra klassenavn for tilpasset styling */\n className?: string;\n /** Inline CSS-stiler */\n style?: React.CSSProperties;\n /** Spacing around the component */\n spacing?: TypographySpacing;\n};\n\nexport type HeadingProps<C extends React.ElementType> =\n PolymorphicComponentProps<C, HeadingBaseProps>;\n\nexport const Heading = <C extends React.ElementType = 'h1'>({\n children,\n as,\n size,\n variant,\n spacing,\n className,\n ...rest\n}: HeadingProps<C>) => {\n const HeadingElement = as || 'h1';\n\n // Function to determine the variant based on the semantic type\n const usedVariant =\n variant ?? getHeadingVariantFromSemanticType(HeadingElement);\n\n // When size is explicitly provided, it should override variant styling\n const shouldUseSize = size !== undefined;\n\n return (\n <HeadingElement\n className={classNames(\n 'eds-heading',\n // Only apply variant if size is not specified\n { [`eds-heading--${usedVariant}`]: !shouldUseSize },\n // Size takes precedence when specified\n { [`eds-heading--${size}`]: shouldUseSize && size },\n getSpacingClasses(spacing, 'eds-heading'),\n className,\n )}\n {...rest}\n >\n {children}\n </HeadingElement>\n );\n};\n","import React from 'react';\nimport classNames from 'classnames';\n\nexport type BlockquotePropsBeta = {\n /** Ekstra klassenavn */\n className?: string;\n} & React.DetailedHTMLProps<\n React.BlockquoteHTMLAttributes<HTMLQuoteElement>,\n HTMLQuoteElement\n>;\n\nexport const BlockquoteBeta = ({ className, ...rest }: BlockquotePropsBeta) => {\n return (\n <blockquote\n className={classNames('eds-text--blockquote', className)}\n {...rest}\n />\n );\n};\n\ntype BlockquoteFooterPropsBeta = {\n /** Ekstra klassenavn */\n className?: string;\n} & React.DetailedHTMLProps<React.HTMLAttributes<HTMLElement>, HTMLElement>;\n\nexport const BlockquoteFooterBeta = ({\n className,\n ...rest\n}: BlockquoteFooterPropsBeta) => {\n return (\n <footer\n className={classNames('eds-text--blockquote__footer', className)}\n {...rest}\n />\n );\n};\n","import React from 'react';\nimport classNames from 'classnames';\nimport { PolymorphicComponentProps } from '@entur/utils';\nimport { ExternalIcon } from '@entur/icons';\nimport { TypographySpacing } from './types';\nimport { getSpacingClasses } from './utils';\n\ntype LinkBaseProps = {\n external?: boolean;\n\n /** Ekstra klassenavn */\n className?: string;\n /** Innholdet */\n children: React.ReactNode;\n /** Spacing around the component (same as Text and Heading components) */\n spacing?: TypographySpacing;\n ariaLabelExternalIcon?: string;\n};\n\nexport type LinkPropsBeta<C extends React.ElementType> =\n PolymorphicComponentProps<C, LinkBaseProps>;\n\nexport const LinkBeta = <C extends React.ElementType = 'a'>({\n external = false,\n ariaLabelExternalIcon = '(ekstern lenke)',\n className,\n spacing,\n children,\n as,\n ...rest\n}: LinkPropsBeta<C>): JSX.Element => {\n const LinkElement: React.ElementType = as || 'a';\n return (\n <LinkElement\n className={classNames(\n 'eds-text--link',\n getSpacingClasses(spacing, 'eds-text--link'),\n className,\n )}\n {...rest}\n >\n {children}\n {external ? (\n <ExternalIcon\n className=\"eds-text--link--ext-icon\"\n aria-label={ariaLabelExternalIcon}\n />\n ) : null}\n </LinkElement>\n );\n};\n","import { warnAboutMissingStyles } from '@entur/utils';\nimport './index.scss';\n\nwarnAboutMissingStyles('typography');\n\nexport * from './Blockquote';\nexport * from './CodeText';\nexport * from './EmphasizedText';\nexport * from './Heading1';\nexport * from './Heading2';\nexport * from './Heading3';\nexport * from './Heading4';\nexport * from './Heading5';\nexport * from './Heading6';\nexport * from './Label';\nexport * from './LeadParagraph';\nexport * from './Link';\nexport * from './ListItem';\nexport * from './NumberedList';\nexport * from './Paragraph';\nexport * from './PreformattedText';\nexport * from './SmallText';\nexport * from './StrongText';\nexport * from './SubLabel';\nexport * from './SubParagraph';\nexport * from './UnorderedList';\n\n// beta\nexport * from './beta/Text';\nexport * from './beta/Heading';\nexport * from './beta/BlockquoteBeta';\nexport * from './beta/LinkBeta';\n"],"names":["Blockquote","_ref","className","ref","rest","_objectWithoutPropertiesLoose","_excluded","React","createElement","_extends","classNames","BlockquoteFooter","_ref2","_excluded2","defaultElement","CodeText","as","Element","EmphasizedText","_classNames","_ref$margin","margin","BaseHeading","level","baseClass","Heading1","children","Heading2","Heading3","Heading4","Heading5","Heading6","Label","LeadParagraph","Link","_ref$external","external","_ref$ariaLabelExterna","ariaLabelExternalIcon","ExternalIcon","Fragment","StrongText","ListItem","title","NumberedList","_ref$type","type","Paragraph","PreformattedText","SmallText","SubLabel","SubParagraph","UnorderedList","getHeadingVariantFromSemanticType","semanticType","getSemanticTypeFromTextVariant","variant","getSpacingClasses","spacing","componentPrefix","undefined","TypographyText","size","_ref$weight","weight","BodyElement","Text","Heading","_classNames2","HeadingElement","usedVariant","shouldUseSize","BlockquoteBeta","BlockquoteFooterBeta","LinkBeta","LinkElement","warnAboutMissingStyles"],"mappings":"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"}
|