@ndla/ui 3.0.12 → 3.0.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/es/index.js CHANGED
@@ -46,5 +46,4 @@ export { i18nInstance, formatNestedMessages, formatMessage } from './i18n';
46
46
  export { default as ResourceGroup } from './ResourceGroup';
47
47
  export { default as LayoutItem, OneColumn, PageContainer, Content } from './Layout';
48
48
  export { SubjectAbout, SubjectArchive, SubjectCarousel, SubjectChildContent, SubjectContent, SubjectFilter, SubjectFlexChild, SubjectFlexWrapper, SubjectHeader, SubjectLinks, SubjectNewContent, SubjectSecondaryContent, SubjectSectionTitle, SubjectShortcuts, SubjectSidebarWrapper, SubjectSocialContent, SubjectSocialSection, SubjectTopics, SubjectBanner } from './Subject';
49
- export { default as ContentCard } from './ContentCard';
50
- export { default as MatomoTracker } from './Matomo';
49
+ export { default as ContentCard } from './ContentCard';
@@ -174,7 +174,8 @@ var messages = _objectSpread(_objectSpread({
174
174
  iconLabel: 'in beta',
175
175
  dialogHeader: '{{title}} is under construction',
176
176
  dialogText: 'Read more at'
177
- }
177
+ },
178
+ archived: 'This is an expired and unmaintained subject.'
178
179
  },
179
180
  subjectsPage: {
180
181
  chooseSubject: 'Choose subject',
@@ -362,6 +363,9 @@ var messages = _objectSpread(_objectSpread({
362
363
  copyTitle: 'Copy link',
363
364
  hasCopiedTitle: 'Link copied'
364
365
  },
366
+ image: {
367
+ rules: 'Rules for use of image:'
368
+ },
365
369
  images: {
366
370
  heading: 'How to use images from the article',
367
371
  description: 'Remember to copy the text to be attached to the image where you use it.',
@@ -500,7 +504,8 @@ var messages = _objectSpread(_objectSpread({
500
504
  en: 'English',
501
505
  fr: 'French',
502
506
  de: 'German',
503
- se: 'Sami',
507
+ se: 'Northern Sami',
508
+ sma: 'Southern Sami',
504
509
  es: 'Spanish',
505
510
  zh: 'Chinese',
506
511
  unknown: 'Unknown',
@@ -174,7 +174,8 @@ var messages = _objectSpread(_objectSpread({
174
174
  iconLabel: 'i arbeid',
175
175
  dialogHeader: '{{title}} er under arbeid.',
176
176
  dialogText: 'Du kan lese mer om hva dette betyr på'
177
- }
177
+ },
178
+ archived: 'Dette er et utgått fag som ikke vedlikeholdes.'
178
179
  },
179
180
  subjectsPage: {
180
181
  errorDescription: 'Beklager, en feil oppstod under lasting av fagene.',
@@ -374,6 +375,9 @@ var messages = _objectSpread(_objectSpread({
374
375
  copyTitle: 'Kopier lenke',
375
376
  hasCopiedTitle: 'Lenke kopiert'
376
377
  },
378
+ image: {
379
+ rules: 'Regler for bruk av bildet:'
380
+ },
377
381
  images: {
378
382
  heading: 'Slik bruker du bilder fra artikkelen',
379
383
  description: 'Husk å kopiere teksten som skal legges ved bildet der du bruker det.',
@@ -500,7 +504,8 @@ var messages = _objectSpread(_objectSpread({
500
504
  en: 'Engelsk',
501
505
  fr: 'Fransk',
502
506
  de: 'Tysk',
503
- se: 'Samisk',
507
+ se: 'Nordsamisk',
508
+ sma: 'Sørsamisk',
504
509
  es: 'Spansk',
505
510
  zh: 'Kinesisk',
506
511
  unknown: 'Ukjent',
@@ -174,7 +174,8 @@ var messages = _objectSpread(_objectSpread({
174
174
  iconLabel: 'i arbeid',
175
175
  dialogHeader: '{{title}} er under arbeid.',
176
176
  dialogText: 'Du kan lese meir om kva dette betyr på'
177
- }
177
+ },
178
+ archived: 'Dette er eit utgått fag som ikkje blir halde ved like.'
178
179
  },
179
180
  subjectsPage: {
180
181
  errorDescription: 'Orsak, ein feil oppstod under lasting av faga.',
@@ -374,6 +375,9 @@ var messages = _objectSpread(_objectSpread({
374
375
  copyTitle: 'Kopier lenke',
375
376
  hasCopiedTitle: 'Lenke kopiert'
376
377
  },
378
+ image: {
379
+ rules: 'Reglar for bruk av biletet:'
380
+ },
377
381
  images: {
378
382
  heading: 'Slik bruker du bilete frå artikkelen',
379
383
  description: 'Hugs å kopiere teksten som skal leggjast ved biletet der du bruker det.',
@@ -500,7 +504,8 @@ var messages = _objectSpread(_objectSpread({
500
504
  en: 'Engelsk',
501
505
  fr: 'Fransk',
502
506
  de: 'Tysk',
503
- se: 'Samisk',
507
+ se: 'Nordsamisk',
508
+ sma: 'Sørsamisk',
504
509
  es: 'Spansk',
505
510
  zh: 'Kinesisk',
506
511
  unknown: 'Ukjent',
package/lib/index.d.ts CHANGED
@@ -46,4 +46,3 @@ export { default as ResourceGroup } from './ResourceGroup';
46
46
  export { default as LayoutItem, OneColumn, PageContainer, Content } from './Layout';
47
47
  export { SubjectAbout, SubjectArchive, SubjectCarousel, SubjectChildContent, SubjectContent, SubjectFilter, SubjectFlexChild, SubjectFlexWrapper, SubjectHeader, SubjectLinks, SubjectNewContent, SubjectSecondaryContent, SubjectSectionTitle, SubjectShortcuts, SubjectSidebarWrapper, SubjectSocialContent, SubjectSocialSection, SubjectTopics, SubjectBanner, } from './Subject';
48
48
  export { default as ContentCard } from './ContentCard';
49
- export { default as MatomoTracker } from './Matomo';
package/lib/index.js CHANGED
@@ -103,8 +103,7 @@ var _exportNames = {
103
103
  SubjectSocialSection: true,
104
104
  SubjectTopics: true,
105
105
  SubjectBanner: true,
106
- ContentCard: true,
107
- MatomoTracker: true
106
+ ContentCard: true
108
107
  };
109
108
  Object.defineProperty(exports, "ArticleByline", {
110
109
  enumerable: true,
@@ -694,12 +693,6 @@ Object.defineProperty(exports, "ContentCard", {
694
693
  return _ContentCard["default"];
695
694
  }
696
695
  });
697
- Object.defineProperty(exports, "MatomoTracker", {
698
- enumerable: true,
699
- get: function get() {
700
- return _Matomo["default"];
701
- }
702
- });
703
696
 
704
697
  var _indexJavascript = require("./index-javascript");
705
698
 
@@ -788,8 +781,6 @@ var _Subject = require("./Subject");
788
781
 
789
782
  var _ContentCard = _interopRequireDefault(require("./ContentCard"));
790
783
 
791
- var _Matomo = _interopRequireDefault(require("./Matomo"));
792
-
793
784
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
794
785
 
795
786
  function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; }
@@ -195,6 +195,7 @@ declare const messages: {
195
195
  dialogHeader: string;
196
196
  dialogText: string;
197
197
  };
198
+ archived: string;
198
199
  };
199
200
  subjectsPage: {
200
201
  chooseSubject: string;
@@ -406,6 +407,9 @@ declare const messages: {
406
407
  copyTitle: string;
407
408
  hasCopiedTitle: string;
408
409
  };
410
+ image: {
411
+ rules: string;
412
+ };
409
413
  images: {
410
414
  heading: string;
411
415
  description: string;
@@ -545,6 +549,7 @@ declare const messages: {
545
549
  fr: string;
546
550
  de: string;
547
551
  se: string;
552
+ sma: string;
548
553
  es: string;
549
554
  zh: string;
550
555
  unknown: string;
@@ -179,7 +179,8 @@ var messages = _objectSpread(_objectSpread({
179
179
  iconLabel: 'in beta',
180
180
  dialogHeader: '{{title}} is under construction',
181
181
  dialogText: 'Read more at'
182
- }
182
+ },
183
+ archived: 'This is an expired and unmaintained subject.'
183
184
  },
184
185
  subjectsPage: {
185
186
  chooseSubject: 'Choose subject',
@@ -367,6 +368,9 @@ var messages = _objectSpread(_objectSpread({
367
368
  copyTitle: 'Copy link',
368
369
  hasCopiedTitle: 'Link copied'
369
370
  },
371
+ image: {
372
+ rules: 'Rules for use of image:'
373
+ },
370
374
  images: {
371
375
  heading: 'How to use images from the article',
372
376
  description: 'Remember to copy the text to be attached to the image where you use it.',
@@ -505,7 +509,8 @@ var messages = _objectSpread(_objectSpread({
505
509
  en: 'English',
506
510
  fr: 'French',
507
511
  de: 'German',
508
- se: 'Sami',
512
+ se: 'Northern Sami',
513
+ sma: 'Southern Sami',
509
514
  es: 'Spanish',
510
515
  zh: 'Chinese',
511
516
  unknown: 'Unknown',
@@ -195,6 +195,7 @@ declare const messages: {
195
195
  dialogHeader: string;
196
196
  dialogText: string;
197
197
  };
198
+ archived: string;
198
199
  };
199
200
  subjectsPage: {
200
201
  errorDescription: string;
@@ -418,6 +419,9 @@ declare const messages: {
418
419
  copyTitle: string;
419
420
  hasCopiedTitle: string;
420
421
  };
422
+ image: {
423
+ rules: string;
424
+ };
421
425
  images: {
422
426
  heading: string;
423
427
  description: string;
@@ -545,6 +549,7 @@ declare const messages: {
545
549
  fr: string;
546
550
  de: string;
547
551
  se: string;
552
+ sma: string;
548
553
  es: string;
549
554
  zh: string;
550
555
  unknown: string;
@@ -179,7 +179,8 @@ var messages = _objectSpread(_objectSpread({
179
179
  iconLabel: 'i arbeid',
180
180
  dialogHeader: '{{title}} er under arbeid.',
181
181
  dialogText: 'Du kan lese mer om hva dette betyr på'
182
- }
182
+ },
183
+ archived: 'Dette er et utgått fag som ikke vedlikeholdes.'
183
184
  },
184
185
  subjectsPage: {
185
186
  errorDescription: 'Beklager, en feil oppstod under lasting av fagene.',
@@ -379,6 +380,9 @@ var messages = _objectSpread(_objectSpread({
379
380
  copyTitle: 'Kopier lenke',
380
381
  hasCopiedTitle: 'Lenke kopiert'
381
382
  },
383
+ image: {
384
+ rules: 'Regler for bruk av bildet:'
385
+ },
382
386
  images: {
383
387
  heading: 'Slik bruker du bilder fra artikkelen',
384
388
  description: 'Husk å kopiere teksten som skal legges ved bildet der du bruker det.',
@@ -505,7 +509,8 @@ var messages = _objectSpread(_objectSpread({
505
509
  en: 'Engelsk',
506
510
  fr: 'Fransk',
507
511
  de: 'Tysk',
508
- se: 'Samisk',
512
+ se: 'Nordsamisk',
513
+ sma: 'Sørsamisk',
509
514
  es: 'Spansk',
510
515
  zh: 'Kinesisk',
511
516
  unknown: 'Ukjent',
@@ -195,6 +195,7 @@ declare const messages: {
195
195
  dialogHeader: string;
196
196
  dialogText: string;
197
197
  };
198
+ archived: string;
198
199
  };
199
200
  subjectsPage: {
200
201
  errorDescription: string;
@@ -418,6 +419,9 @@ declare const messages: {
418
419
  copyTitle: string;
419
420
  hasCopiedTitle: string;
420
421
  };
422
+ image: {
423
+ rules: string;
424
+ };
421
425
  images: {
422
426
  heading: string;
423
427
  description: string;
@@ -545,6 +549,7 @@ declare const messages: {
545
549
  fr: string;
546
550
  de: string;
547
551
  se: string;
552
+ sma: string;
548
553
  es: string;
549
554
  zh: string;
550
555
  unknown: string;
@@ -179,7 +179,8 @@ var messages = _objectSpread(_objectSpread({
179
179
  iconLabel: 'i arbeid',
180
180
  dialogHeader: '{{title}} er under arbeid.',
181
181
  dialogText: 'Du kan lese meir om kva dette betyr på'
182
- }
182
+ },
183
+ archived: 'Dette er eit utgått fag som ikkje blir halde ved like.'
183
184
  },
184
185
  subjectsPage: {
185
186
  errorDescription: 'Orsak, ein feil oppstod under lasting av faga.',
@@ -379,6 +380,9 @@ var messages = _objectSpread(_objectSpread({
379
380
  copyTitle: 'Kopier lenke',
380
381
  hasCopiedTitle: 'Lenke kopiert'
381
382
  },
383
+ image: {
384
+ rules: 'Reglar for bruk av biletet:'
385
+ },
382
386
  images: {
383
387
  heading: 'Slik bruker du bilete frå artikkelen',
384
388
  description: 'Hugs å kopiere teksten som skal leggjast ved biletet der du bruker det.',
@@ -505,7 +509,8 @@ var messages = _objectSpread(_objectSpread({
505
509
  en: 'Engelsk',
506
510
  fr: 'Fransk',
507
511
  de: 'Tysk',
508
- se: 'Samisk',
512
+ se: 'Nordsamisk',
513
+ sma: 'Sørsamisk',
509
514
  es: 'Spansk',
510
515
  zh: 'Kinesisk',
511
516
  unknown: 'Ukjent',
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ndla/ui",
3
- "version": "3.0.12",
3
+ "version": "3.0.13",
4
4
  "description": "UI component library for NDLA.",
5
5
  "license": "GPL-3.0",
6
6
  "main": "lib/index.js",
@@ -92,5 +92,5 @@
92
92
  "publishConfig": {
93
93
  "access": "public"
94
94
  },
95
- "gitHead": "358121e2526a252d2b53f010e4b38c17040872dc"
95
+ "gitHead": "815d8d7d88d2a021c35f96421eb357925c0c2b6b"
96
96
  }
package/src/index.ts CHANGED
@@ -135,4 +135,3 @@ export {
135
135
  } from './Subject';
136
136
 
137
137
  export { default as ContentCard } from './ContentCard';
138
- export { default as MatomoTracker } from './Matomo';
@@ -178,6 +178,7 @@ const messages = {
178
178
  dialogHeader: '{{title}} is under construction',
179
179
  dialogText: 'Read more at',
180
180
  },
181
+ archived: 'This is an expired and unmaintained subject.',
181
182
  },
182
183
  subjectsPage: {
183
184
  chooseSubject: 'Choose subject',
@@ -391,6 +392,9 @@ const messages = {
391
392
  copyTitle: 'Copy link',
392
393
  hasCopiedTitle: 'Link copied',
393
394
  },
395
+ image: {
396
+ rules: 'Rules for use of image:',
397
+ },
394
398
  images: {
395
399
  heading: 'How to use images from the article',
396
400
  description: 'Remember to copy the text to be attached to the image where you use it.',
@@ -529,7 +533,8 @@ const messages = {
529
533
  en: 'English',
530
534
  fr: 'French',
531
535
  de: 'German',
532
- se: 'Sami',
536
+ se: 'Northern Sami',
537
+ sma: 'Southern Sami',
533
538
  es: 'Spanish',
534
539
  zh: 'Chinese',
535
540
  unknown: 'Unknown',
@@ -177,6 +177,7 @@ const messages = {
177
177
  dialogHeader: '{{title}} er under arbeid.',
178
178
  dialogText: 'Du kan lese mer om hva dette betyr på',
179
179
  },
180
+ archived: 'Dette er et utgått fag som ikke vedlikeholdes.',
180
181
  },
181
182
  subjectsPage: {
182
183
  errorDescription: 'Beklager, en feil oppstod under lasting av fagene.',
@@ -402,6 +403,9 @@ const messages = {
402
403
  copyTitle: 'Kopier lenke',
403
404
  hasCopiedTitle: 'Lenke kopiert',
404
405
  },
406
+ image: {
407
+ rules: 'Regler for bruk av bildet:',
408
+ },
405
409
  images: {
406
410
  heading: 'Slik bruker du bilder fra artikkelen',
407
411
  description: 'Husk å kopiere teksten som skal legges ved bildet der du bruker det.',
@@ -528,7 +532,8 @@ const messages = {
528
532
  en: 'Engelsk',
529
533
  fr: 'Fransk',
530
534
  de: 'Tysk',
531
- se: 'Samisk',
535
+ se: 'Nordsamisk',
536
+ sma: 'Sørsamisk',
532
537
  es: 'Spansk',
533
538
  zh: 'Kinesisk',
534
539
  unknown: 'Ukjent',
@@ -177,6 +177,7 @@ const messages = {
177
177
  dialogHeader: '{{title}} er under arbeid.',
178
178
  dialogText: 'Du kan lese meir om kva dette betyr på',
179
179
  },
180
+ archived: 'Dette er eit utgått fag som ikkje blir halde ved like.',
180
181
  },
181
182
  subjectsPage: {
182
183
  errorDescription: 'Orsak, ein feil oppstod under lasting av faga.',
@@ -403,6 +404,9 @@ const messages = {
403
404
  copyTitle: 'Kopier lenke',
404
405
  hasCopiedTitle: 'Lenke kopiert',
405
406
  },
407
+ image: {
408
+ rules: 'Reglar for bruk av biletet:',
409
+ },
406
410
  images: {
407
411
  heading: 'Slik bruker du bilete frå artikkelen',
408
412
  description: 'Hugs å kopiere teksten som skal leggjast ved biletet der du bruker det.',
@@ -529,7 +533,8 @@ const messages = {
529
533
  en: 'Engelsk',
530
534
  fr: 'Fransk',
531
535
  de: 'Tysk',
532
- se: 'Samisk',
536
+ se: 'Nordsamisk',
537
+ sma: 'Sørsamisk',
533
538
  es: 'Spansk',
534
539
  zh: 'Kinesisk',
535
540
  unknown: 'Ukjent',
@@ -1,19 +0,0 @@
1
- /*
2
- * Copyright (c) 2021-present, NDLA.
3
- *
4
- * This source code is licensed under the GPLv3 license found in the
5
- * LICENSE file in the root directory of this source tree.
6
- *
7
- */
8
- import React from 'react';
9
- import { jsx as ___EmotionJSX } from "@emotion/core";
10
- export var MatomoTracker = function MatomoTracker(_ref) {
11
- var trackerUrl = _ref.trackerUrl,
12
- siteId = _ref.siteId;
13
- return ___EmotionJSX("script", {
14
- dangerouslySetInnerHTML: {
15
- __html: "\n var _paq = window._paq = window._paq || [];\n _paq.push(['trackPageView']);\n _paq.push(['enableLinkTracking']);\n (function() {\n var u=\"".concat(trackerUrl, "\";\n _paq.push(['setTrackerUrl', u+'matomo.php']);\n _paq.push(['setSiteId', '").concat(siteId, "']);\n var d=document, g=d.createElement('script'), s=d.getElementsByTagName('script')[0];\n g.async=true; g.src=u+'matomo.js'; s.parentNode.insertBefore(g,s);\n })();")
16
- }
17
- });
18
- };
19
- export default MatomoTracker;
@@ -1,9 +0,0 @@
1
- /**
2
- * Copyright (c) 2021-present, NDLA.
3
- *
4
- * This source code is licensed under the GPLv3 license found in the
5
- * LICENSE file in the root directory of this source tree.
6
- *
7
- */
8
- import MatomoTracker from './MatomoTracker';
9
- export default MatomoTracker;
@@ -1,6 +0,0 @@
1
- interface Props {
2
- trackerUrl: string;
3
- siteId: string;
4
- }
5
- export declare const MatomoTracker: ({ trackerUrl, siteId }: Props) => JSX.Element;
6
- export default MatomoTracker;
@@ -1,33 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports["default"] = exports.MatomoTracker = void 0;
7
-
8
- var _react = _interopRequireDefault(require("react"));
9
-
10
- var _core = require("@emotion/core");
11
-
12
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
13
-
14
- /*
15
- * Copyright (c) 2021-present, NDLA.
16
- *
17
- * This source code is licensed under the GPLv3 license found in the
18
- * LICENSE file in the root directory of this source tree.
19
- *
20
- */
21
- var MatomoTracker = function MatomoTracker(_ref) {
22
- var trackerUrl = _ref.trackerUrl,
23
- siteId = _ref.siteId;
24
- return (0, _core.jsx)("script", {
25
- dangerouslySetInnerHTML: {
26
- __html: "\n var _paq = window._paq = window._paq || [];\n _paq.push(['trackPageView']);\n _paq.push(['enableLinkTracking']);\n (function() {\n var u=\"".concat(trackerUrl, "\";\n _paq.push(['setTrackerUrl', u+'matomo.php']);\n _paq.push(['setSiteId', '").concat(siteId, "']);\n var d=document, g=d.createElement('script'), s=d.getElementsByTagName('script')[0];\n g.async=true; g.src=u+'matomo.js'; s.parentNode.insertBefore(g,s);\n })();")
27
- }
28
- });
29
- };
30
-
31
- exports.MatomoTracker = MatomoTracker;
32
- var _default = MatomoTracker;
33
- exports["default"] = _default;
@@ -1,9 +0,0 @@
1
- /**
2
- * Copyright (c) 2021-present, NDLA.
3
- *
4
- * This source code is licensed under the GPLv3 license found in the
5
- * LICENSE file in the root directory of this source tree.
6
- *
7
- */
8
- import MatomoTracker from './MatomoTracker';
9
- export default MatomoTracker;
@@ -1,20 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports["default"] = void 0;
7
-
8
- var _MatomoTracker = _interopRequireDefault(require("./MatomoTracker"));
9
-
10
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
11
-
12
- /**
13
- * Copyright (c) 2021-present, NDLA.
14
- *
15
- * This source code is licensed under the GPLv3 license found in the
16
- * LICENSE file in the root directory of this source tree.
17
- *
18
- */
19
- var _default = _MatomoTracker["default"];
20
- exports["default"] = _default;
@@ -1,36 +0,0 @@
1
- /*
2
- * Copyright (c) 2021-present, NDLA.
3
- *
4
- * This source code is licensed under the GPLv3 license found in the
5
- * LICENSE file in the root directory of this source tree.
6
- *
7
- */
8
-
9
- import React from 'react';
10
-
11
- interface Props {
12
- trackerUrl: string;
13
- siteId: string;
14
- }
15
-
16
- export const MatomoTracker = ({ trackerUrl, siteId }: Props) => {
17
- return (
18
- <script
19
- dangerouslySetInnerHTML={{
20
- __html: `
21
- var _paq = window._paq = window._paq || [];
22
- _paq.push(['trackPageView']);
23
- _paq.push(['enableLinkTracking']);
24
- (function() {
25
- var u="${trackerUrl}";
26
- _paq.push(['setTrackerUrl', u+'matomo.php']);
27
- _paq.push(['setSiteId', '${siteId}']);
28
- var d=document, g=d.createElement('script'), s=d.getElementsByTagName('script')[0];
29
- g.async=true; g.src=u+'matomo.js'; s.parentNode.insertBefore(g,s);
30
- })();`,
31
- }}
32
- />
33
- );
34
- };
35
-
36
- export default MatomoTracker;
@@ -1,11 +0,0 @@
1
- /**
2
- * Copyright (c) 2021-present, NDLA.
3
- *
4
- * This source code is licensed under the GPLv3 license found in the
5
- * LICENSE file in the root directory of this source tree.
6
- *
7
- */
8
-
9
- import MatomoTracker from './MatomoTracker';
10
-
11
- export default MatomoTracker;