ngx-edu-sharing-metaqs2 0.9.35 → 0.9.36

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 CHANGED
@@ -122,6 +122,18 @@ selector: `<metaqs2--quality-matrix-v2 />`
122
122
  Übersicht über die Anzahl der Materialien in Sammlungen über die Zeit.
123
123
  [CollectionCountHistoryComponent](./src/lib/collection-count-history/collection-count-history.component.ts)
124
124
 
125
+ ### Lizenzübersicht für Sammlungen
126
+ Übersicht der verwendeten Lizenzen in einer Sammlung und ihren Unter-Sammlungen.
127
+ Diese Komponente leitet sich von [CountsWithHistoryComponent](#counts-with-history) ab und benutzt auch deren Template
128
+ Sie überschreibt die `apiMethod` und `sourceType` Eingaben.
129
+ Sie überschreibt die `getCountByDate()` Methode und benutzt eigenes css um die icons darzustellen.
130
+
131
+ [TreeLicenseComponent](./src/lib/tree-license/tree-license.component.ts)
132
+ - selector: `<metaqs2-tree-license />`
133
+ - inputs:
134
+ - `collectionId` (required) - the id of the collection to display
135
+
136
+
125
137
  ### Counts with History
126
138
  [CountHistoryComponent](./src/lib/counts-with-history/counts-with-history.component.ts)
127
139
  - selector: `<metaqs2-counts-with-history />`.
@@ -204,13 +216,16 @@ Currently the following manifestations are implemented:
204
216
  },
205
217
  ```
206
218
 
219
+
207
220
  ## Build
208
221
 
209
222
  Run `ng build ng-meta-widgets-lib -c production` to build the project. The build artifacts will be stored in the `dist/` directory.
210
223
 
211
- ## Publishing
212
- The gitlab pipeline is configured to publish the library to npm on every tag.
213
- Run the `publish` job in the pipeline manually to publish the library to npm.
224
+ ## Publishing to npm
225
+ 1. in gitlab create a new tag
226
+ 2. in the pipeline select the job `publish` and run it manually
227
+ 3. this will update the version in the `lib/package.json` file and publish to npm
228
+
214
229
 
215
230
  ## Running unit tests
216
231
 
@@ -13,6 +13,9 @@ const ICONS = {
13
13
  'types/video': '<svg width="36" height="27" viewBox="0 0 36 27" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M6.45 0.169922C2.89915 0.169922 0 3.06907 0 6.61992V20.3799C0 23.9308 2.89915 26.8299 6.45 26.8299H28.81C32.3609 26.8299 35.26 23.9308 35.26 20.3799V6.61992C35.26 3.06907 32.3609 0.169922 28.81 0.169922H6.45ZM6.45 2.74992H28.81C30.9768 2.74992 32.68 4.45311 32.68 6.61992V20.3799C32.68 22.5467 30.9768 24.2499 28.81 24.2499H6.45C4.28319 24.2499 2.58 22.5467 2.58 20.3799V6.61992C2.58 4.45311 4.28319 2.74992 6.45 2.74992ZM13.8004 6.61992C13.451 6.60816 13.1134 6.73918 12.8615 6.98273C12.6112 7.22629 12.4701 7.56057 12.4701 7.9099V19.0899C12.4667 19.7517 12.9656 20.311 13.6257 20.3799C13.8861 20.4068 14.1481 20.3564 14.3782 20.2321L24.6982 14.6421C25.1165 14.417 25.3751 13.9803 25.3751 13.5066C25.3751 13.0313 25.1165 12.5962 24.6982 12.3712L14.3782 6.78117C14.2002 6.68207 14.0037 6.62664 13.8004 6.61992H13.8004ZM15.0501 10.0868L21.3659 13.4999L15.0501 16.9265V10.0868Z" fill="black"/></svg>',
14
14
  'types/worksheet': '<svg width="29" height="28" viewBox="0 0 29 28" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M27.4071 8.81132C26.4479 7.8521 24.886 7.8521 23.9267 8.81132C23.6314 9.10664 21.7469 10.9934 21.4592 11.281L21.4581 4.78081C21.4581 4.12345 21.2022 3.50549 20.7373 3.04066L18.4175 0.720807C17.9526 0.255951 17.3347 3.05176e-05 16.6773 3.05176e-05H2.59083C1.23347 3.05176e-05 0.129883 1.10362 0.129883 2.46098V25.5391C0.129883 26.8965 1.23347 28.0001 2.59083 28.0001H18.9971C20.3545 28.0001 21.4581 26.8965 21.4581 25.5391V18.246L27.407 12.2915C28.3684 11.3301 28.3684 9.77368 27.407 8.8111L27.4071 8.81132ZM16.5364 1.6408C16.6917 1.6408 16.9903 1.61346 17.2572 1.88143L19.577 4.20129C19.8373 4.4616 19.8177 4.74706 19.8177 4.92206H16.5363L16.5364 1.6408ZM19.8177 25.5394C19.8177 25.9922 19.4502 26.3597 18.9974 26.3597H2.59108C2.13827 26.3597 1.77077 25.9922 1.77077 25.5394V2.4612C1.77077 2.00839 2.13827 1.64089 2.59108 1.64089H14.8957V5.74233C14.8957 6.19514 15.2632 6.56264 15.716 6.56264H19.8174V12.924L17.397 15.3466L16.2376 16.506C16.1479 16.5957 16.0801 16.7061 16.0396 16.8264L14.8792 20.3068C14.7807 20.6022 14.8573 20.927 15.0772 21.1468C15.297 21.3667 15.6218 21.4432 15.9172 21.3448L19.3975 20.1843C19.5179 20.1439 19.6283 20.0761 19.718 19.9864L19.8175 19.8868L19.8177 25.5394ZM17.978 17.0859L19.1385 18.2463L18.6955 18.6893L16.9554 19.269L17.5351 17.5288L17.978 17.0859ZM20.2979 17.0859L19.1374 15.9254C19.7554 15.3075 22.4985 12.5609 23.0804 11.9791L24.2408 13.1396L20.2979 17.0859ZM26.2468 11.1325L25.4013 11.9791L24.2408 10.8186L25.0863 9.97206C25.4068 9.6527 25.9263 9.6527 26.2468 9.97206C26.5661 10.2925 26.5683 10.811 26.2468 11.1325Z" fill="black"/><path d="M15.7159 8.20319H4.23145C3.77863 8.20319 3.41113 8.57069 3.41113 9.0235C3.41113 9.47632 3.77863 9.84382 4.23145 9.84382H15.7159C16.1687 9.84382 16.5362 9.47632 16.5362 9.0235C16.5362 8.57069 16.1687 8.20319 15.7159 8.20319Z" fill="black"/><path d="M12.4346 11.4845H4.23145C3.77863 11.4845 3.41113 11.852 3.41113 12.3048C3.41113 12.7576 3.77863 13.1251 4.23145 13.1251H12.4346C12.8874 13.1251 13.2549 12.7576 13.2549 12.3048C13.2549 11.852 12.8874 11.4845 12.4346 11.4845Z" fill="black"/><path d="M12.4346 14.7655H4.23145C3.77863 14.7655 3.41113 15.133 3.41113 15.5859C3.41113 16.0387 3.77863 16.4062 4.23145 16.4062H12.4346C12.8874 16.4062 13.2549 16.0387 13.2549 15.5859C13.2549 15.133 12.8874 14.7655 12.4346 14.7655Z" fill="black"/><path d="M12.4346 18.0468H4.23145C3.77863 18.0468 3.41113 18.4143 3.41113 18.8672C3.41113 19.32 3.77863 19.6875 4.23145 19.6875H12.4346C12.8874 19.6875 13.2549 19.32 13.2549 18.8672C13.2549 18.4143 12.8874 18.0468 12.4346 18.0468Z" fill="black"/><path d="M15.7163 23.0782H10.7944C10.3416 23.0782 9.97412 23.4457 9.97412 23.8985C9.97412 24.3513 10.3416 24.7188 10.7944 24.7188H15.7163C16.1691 24.7188 16.5366 24.3513 16.5366 23.8985C16.5366 23.4457 16.1691 23.0782 15.7163 23.0782V23.0782Z" fill="black"/></svg>',
15
15
  layers: '<svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 -960 960 960" width="24px" fill="#5f6368"><path d="M480-118 120-398l66-50 294 228 294-228 66 50-360 280Zm0-202L120-600l360-280 360 280-360 280Zm0-280Zm0 178 230-178-230-178-230 178 230 178Z"/></svg>',
16
+ 'level-1': '<svg width="24" height="24" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M4 12.9L3 13.8L11 20.7C11.6 21.2 12.4 21.2 13 20.7L21 13.8L20 12.9L12 19.8L4 12.9ZM11 3.40002L4 9.40002C3.4 9.90002 3.4 10.7 4 11.1L11 17.2C11.6 17.7 12.4 17.7 13 17.2L20 11.1C20.5 10.6 20.5 9.80002 20 9.40002L13 3.30002C12.4 2.90002 11.6 2.90002 11 3.40002Z" fill="#003B7C"/></svg>',
17
+ 'level-2': '<svg width="24" height="24" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M20.3 9.90005C20.2 9.70005 20.1 9.60005 20 9.40005L13 3.30005C12.5 2.80005 11.5 2.80005 11 3.30005L4 9.40005C3.5 9.90005 3.5 10.7 4 11.1L11 17.2C11.5 17.7 12.5 17.7 13 17.2L20 11.1C20.3 10.8 20.4 10.5 20.4 10.2C20.4 10.1 20.4 10 20.3 9.90005ZM5 10.3L12 4.20005L19 10.3L12 16.4L5 10.3ZM20 12.9L12 19.8L4 12.9L3 13.8L11 20.7001C11.5 21.2001 12.5 21.2001 13 20.7001L21 13.8L20 12.9Z" fill="#003B7C"/><path opacity="0.3" d="M19 10.3L12 16.3L5 10.3L12 4.19995L19 10.3Z" fill="#003B7C"/></svg>',
18
+ 'level-3': '<svg width="24" height="24" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M20.3 9.90005C20.2 9.70005 20.1 9.60005 20 9.40005L13 3.30005C12.5 2.80005 11.5 2.80005 11 3.30005L4 9.40005C3.5 9.90005 3.5 10.7 4 11.1L11 17.2C11.5 17.7 12.5 17.7 13 17.2L20 11.1C20.3 10.8 20.4 10.5 20.4 10.2C20.4 10.1 20.4 10 20.3 9.90005ZM5 10.3L12 4.20005L19 10.3L12 16.4L5 10.3ZM20 12.9L12 19.8L4 12.9L3 13.8L11 20.7001C11.5 21.2001 12.5 21.2001 13 20.7001L21 13.8L20 12.9Z" fill="#003B7C"/></svg>',
16
19
  };
17
20
  export class SvgIconsService {
18
21
  constructor(matIconRegistry, domSanitizer) {
@@ -38,4 +41,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
38
41
  type: Injectable,
39
42
  args: [{ providedIn: 'root' }]
40
43
  }], ctorParameters: () => [{ type: i1.MatIconRegistry }, { type: i2.DomSanitizer }] });
41
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"svg-icons.service.js","sourceRoot":"","sources":["../../../../../projects/ng-meta-widgets-lib/src/lib/core/svg-icons.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;;;;AAI3C,MAAM,KAAK,GAAG;IACZ,KAAK,EACH,63DAA63D;IAC/3D,IAAI,EAAE,m6EAAm6E;IACz6E,aAAa,EACX,keAAke;IACpe,gBAAgB,EACd,01CAA01C;IAC51C,aAAa,EACX,81CAA81C;IACh2C,uBAAuB,EACrB,ivBAAivB;IACnvB,aAAa,EACX,2nBAA2nB;IAC7nB,aAAa,EACX,2+BAA2+B;IAC7+B,iBAAiB,EACf,o3FAAo3F;IACt3F,MAAM,EACJ,yQAAyQ;CAC5Q,CAAC;AAGF,MAAM,OAAO,eAAe;IAG1B,YAAoB,eAAgC,EAAU,YAA0B;QAApE,oBAAe,GAAf,eAAe,CAAiB;QAAU,iBAAY,GAAZ,YAAY,CAAc;QAFhF,gBAAW,GAAG,KAAK,CAAC;QAG1B,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,IAAI;QACF,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,OAAO;QACT,CAAC;QACD,KAAK,MAAM,IAAI,IAAI,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;YACtC,gFAAgF;YAChF,IAAI,CAAC,eAAe,CAAC,iBAAiB,CACpC,IAAI,EACJ,IAAI,CAAC,YAAY,CAAC,uBAAuB,CAAE,KAAa,CAAC,IAAI,CAAW,CAAC,CAC1E,CAAC;QACJ,CAAC;QACD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC1B,CAAC;+GAnBU,eAAe;mHAAf,eAAe,cADF,MAAM;;4FACnB,eAAe;kBAD3B,UAAU;mBAAC,EAAE,UAAU,EAAE,MAAM,EAAE","sourcesContent":["import { Injectable } from '@angular/core';\nimport { MatIconRegistry } from '@angular/material/icon';\nimport { DomSanitizer } from '@angular/platform-browser';\n\nconst ICONS = {\n  child:\n    '<svg width=\"37\" height=\"37\" viewBox=\"0 0 37 37\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M12.7188 24.2813H3.46875C2.82991 24.2813 2.3125 23.7638 2.3125 23.125V13.875C2.3125 13.2362 2.82991 12.7188 3.46875 12.7188H12.7188C13.3576 12.7188 13.875 13.2362 13.875 13.875V23.125C13.875 23.7638 13.3576 24.2813 12.7188 24.2813ZM4.625 21.9688H11.5625V15.0313H4.625V21.9688Z\" fill=\"black\"/><path d=\"M33.5313 32.375H24.2813C23.6424 32.375 23.125 31.8576 23.125 31.2188V21.9688C23.125 21.3299 23.6424 20.8125 24.2813 20.8125H33.5313C34.1701 20.8125 34.6875 21.3299 34.6875 21.9688V31.2188C34.6875 31.8576 34.1701 32.375 33.5313 32.375ZM25.4375 30.0625H32.375V23.125H25.4375V30.0625Z\" fill=\"black\"/><path d=\"M33.5313 13.875H24.2813C23.6424 13.875 23.125 13.3576 23.125 12.7188V3.46875C23.125 2.82991 23.6424 2.3125 24.2813 2.3125H33.5313C34.1701 2.3125 34.6875 2.82991 34.6875 3.46875V12.7188C34.6875 13.3576 34.1701 13.875 33.5313 13.875ZM25.4375 11.5625H32.375V4.625H25.4375V11.5625Z\" fill=\"black\"/><path d=\"M18.5 37C17.8612 37 17.3438 36.4826 17.3438 35.8438V1.15625C17.3438 0.517408 17.8612 0 18.5 0C19.1388 0 19.6563 0.517408 19.6563 1.15625V35.8438C19.6563 36.4826 19.1388 37 18.5 37Z\" fill=\"black\"/><path d=\"M18.5 19.6563H12.7188C12.0799 19.6563 11.5625 19.1388 11.5625 18.5C11.5625 17.8612 12.0799 17.3438 12.7188 17.3438H18.5C19.1388 17.3438 19.6563 17.8612 19.6563 18.5C19.6563 19.1388 19.1388 19.6563 18.5 19.6563Z\" fill=\"black\"/><path d=\"M24.2813 9.25H18.5C17.8612 9.25 17.3438 8.73259 17.3438 8.09375C17.3438 7.45491 17.8612 6.9375 18.5 6.9375H24.2813C24.9201 6.9375 25.4375 7.45491 25.4375 8.09375C25.4375 8.73259 24.9201 9.25 24.2813 9.25Z\" fill=\"black\"/><path d=\"M24.2813 27.75H18.5C17.8612 27.75 17.3438 27.2326 17.3438 26.5938C17.3438 25.9549 17.8612 25.4375 18.5 25.4375H24.2813C24.9201 25.4375 25.4375 25.9549 25.4375 26.5938C25.4375 27.2326 24.9201 27.75 24.2813 27.75Z\" fill=\"black\"/></svg>',\n  tree: '<svg width=\"43\" height=\"43\" viewBox=\"0 0 43 43\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M36.3082 24.5605C34.6184 24.5605 33.2478 23.1899 33.2478 21.5001C33.2478 19.8086 34.6184 18.4397 36.3082 18.4397C37.9996 18.4397 39.3686 19.8086 39.3686 21.5001C39.3686 23.1899 37.9996 24.5605 36.3082 24.5605V24.5605ZM6.62486 37.0842C4.93341 37.0842 3.56279 35.7136 3.56279 34.0238C3.56279 32.3324 4.93341 30.9634 6.62486 30.9634C8.31463 30.9634 9.68526 32.3324 9.68526 34.0238C9.68526 35.7136 8.31463 37.0842 6.62486 37.0842ZM6.62486 12.0367C4.93341 12.0367 3.56279 10.6661 3.56279 8.97467C3.56279 7.28489 4.93341 5.91427 6.62486 5.91427C8.31463 5.91427 9.68526 7.28489 9.68526 8.97467C9.68526 10.6661 8.31463 12.0367 6.62486 12.0367ZM36.3082 16.3032C34.3261 16.3032 32.6028 17.4151 31.7261 19.0478C30.3387 19.0461 28.4793 19.0511 27.5957 19.0461C25.5633 19.0343 23.8836 17.4017 23.8584 15.3692C23.8316 13.3889 23.3243 11.5782 22.0981 10.0028C20.7006 8.20892 18.9336 6.9811 16.6608 6.58636C16.0863 6.48726 15.4951 6.45534 14.9105 6.44694C13.6609 6.43015 12.4095 6.43518 11.1598 6.4419C10.2712 4.85292 8.57306 3.7796 6.62456 3.7796C3.75397 3.7796 1.42758 6.10599 1.42758 8.97486C1.42758 11.8455 3.75397 14.1718 6.62456 14.1718C8.5713 14.1718 10.2695 13.0985 11.1581 11.5129C12.4901 11.5146 13.822 11.5079 15.154 11.5247C15.4933 11.528 15.8427 11.5935 16.1669 11.6977C17.6937 12.1864 18.7402 13.6192 18.7586 15.2468C18.7855 17.3263 19.3801 19.1975 20.7407 20.7964C20.9523 21.0467 21.1824 21.2818 21.4025 21.522C21.379 21.5506 21.3655 21.5707 21.3487 21.5875C19.7362 23.1665 18.888 25.0846 18.7839 27.3371C18.762 27.7856 18.7671 28.2441 18.6747 28.6791C18.3119 30.3672 16.7817 31.58 15.0348 31.59C13.7617 31.5968 12.4901 31.5917 11.2186 31.5951C10.3452 29.949 8.61675 28.8269 6.62275 28.8269C3.75383 28.8269 1.42749 31.1533 1.42749 34.0239C1.42749 36.8928 3.75388 39.2192 6.62275 39.2192C8.5544 39.2192 10.2374 38.166 11.1343 36.6022C12.4596 36.609 13.7866 36.6123 15.1135 36.5989C15.5771 36.5939 16.0457 36.5569 16.5043 36.4847C18.5031 36.1756 20.1559 35.2165 21.525 33.7501C22.9208 32.2569 23.7052 30.4983 23.8194 28.4491C23.8446 28.009 23.8479 27.5639 23.9135 27.1289C24.162 25.4828 25.7914 24.0752 27.4526 24.0634C28.3949 24.055 30.35 24.0584 31.7878 24.0584C32.6797 25.6323 34.3695 26.6955 36.308 26.6955C39.1786 26.6955 41.505 24.3691 41.505 21.5002C41.505 18.6296 39.1786 16.3033 36.308 16.3033\" fill=\"black\"/></svg>',\n  'types/audio':\n    '<svg width=\"35\" height=\"35\" viewBox=\"0 0 35 35\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M17.5 1.45834C10.2521 1.45834 4.375 7.33543 4.375 14.5833V24.7917C4.375 27.2125 6.32917 29.1667 8.75 29.1667H13.125V17.5H7.29167V14.5833C7.29167 8.93959 11.8563 4.37501 17.5 4.37501C23.1438 4.37501 27.7083 8.93959 27.7083 14.5833V17.5H21.875V29.1667H26.25C28.6708 29.1667 30.625 27.2125 30.625 24.7917V14.5833C30.625 7.33543 24.7479 1.45834 17.5 1.45834Z\" fill=\"black\"/></svg>',\n  'types/exercise':\n    '<svg width=\"27\" height=\"33\" viewBox=\"0 0 27 33\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M19.9836 14.3248L13.3957 7.61539H2.49795C1.12408 7.61539 0.0124901 8.75769 0.0124901 10.1538L0 30.4615C0 31.8577 1.11159 33 2.48546 33H17.4857C18.8596 33 19.9836 31.8577 19.9836 30.4615V14.3248ZM1.87347 30.462C1.87371 30.8189 2.15862 31.0962 2.48546 31.0962H17.4857C17.8249 31.0962 18.1102 30.8062 18.1102 30.4615V16.2287H11.5222V9.51923H2.49795C2.17097 9.51923 1.88596 9.79672 1.88596 10.1538L1.87347 30.462ZM13.3957 14.3248H17.3462L13.3957 10.1538V14.3248Z\" fill=\"black\"/><path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M20.1647 0L26.7526 6.70945V22.8462C26.7526 24.2423 25.6285 25.3846 24.2546 25.3846H19.4616V23.4808H24.2546C24.5938 23.4808 24.8791 23.1908 24.8791 22.8462V8.6133H18.2912V1.90385H9.26691C8.93992 1.90385 8.65491 2.18133 8.65491 2.53846L8.65179 7.61538H6.77832L6.78144 2.53846C6.78144 1.14231 7.89303 0 9.26691 0H20.1647ZM24.1151 6.70945H20.1647V2.53846L24.1151 6.70945Z\" fill=\"black\"/><line x1=\"4\" y1=\"19.25\" x2=\"16\" y2=\"19.25\" stroke=\"black\" stroke-width=\"1.5\"/><line x1=\"4\" y1=\"22.25\" x2=\"16\" y2=\"22.25\" stroke=\"black\" stroke-width=\"1.5\"/><line x1=\"4\" y1=\"25.25\" x2=\"16\" y2=\"25.25\" stroke=\"black\" stroke-width=\"1.5\"/><line x1=\"4\" y1=\"28.25\" x2=\"16\" y2=\"28.25\" stroke=\"black\" stroke-width=\"1.5\"/></svg>',\n  'types/image':\n    '<svg width=\"34\" height=\"26\" viewBox=\"0 0 34 26\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M3.08885 0.400024C1.71214 0.400024 0.568848 1.54331 0.568848 2.92002V23.08C0.568848 24.4567 1.71214 25.6 3.08885 25.6H31.1688C32.5456 25.6 33.6888 24.4567 33.6888 23.08V2.92002C33.6888 1.54331 32.5456 0.400024 31.1688 0.400024H3.08885ZM3.08885 2.56002H31.1688C31.3868 2.56002 31.5288 2.70206 31.5288 2.92002V17.23L26.0838 12.8762C25.7281 12.5879 25.181 12.564 24.8013 12.8199L19.6937 16.3299L12.7637 10.7161C12.5429 10.5361 12.249 10.4489 11.9649 10.4798C11.7877 10.5009 11.6161 10.567 11.4699 10.6711L2.72874 16.7011V2.91993C2.72874 2.70197 2.87077 2.55993 3.08874 2.55993L3.08885 2.56002ZM19.6488 5.44002C17.8728 5.44002 16.4088 6.90393 16.4088 8.68002C16.4088 10.4561 17.8728 11.92 19.6488 11.92C21.4249 11.92 22.8888 10.4561 22.8888 8.68002C22.8888 6.90393 21.4249 5.44002 19.6488 5.44002ZM19.6488 7.60002C20.2578 7.60002 20.7288 8.07112 20.7288 8.68002C20.7288 9.28893 20.2578 9.76002 19.6488 9.76002C19.0399 9.76002 18.5688 9.28893 18.5688 8.68002C18.5688 8.07112 19.0399 7.60002 19.6488 7.60002ZM12.0438 12.91L18.9738 18.5123C19.3296 18.8006 19.8767 18.8245 20.2563 18.5686L25.3525 15.0586L31.5287 19.9974V23.0799C31.5287 23.2979 31.3866 23.4399 31.1687 23.4399H3.08867C2.8707 23.4399 2.72867 23.2979 2.72867 23.0799V19.3338L12.0438 12.91Z\" fill=\"black\"/></svg>',\n  'types/lesson_planning':\n    '<svg width=\"24\" height=\"30\" viewBox=\"0 0 24 30\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M23.617 7.92935L15.8313 0H2.95213C1.32846 0 0.014761 1.35 0.014761 3L0 27C0 28.65 1.3137 30 2.93737 30H20.6649C22.2886 30 23.617 28.65 23.617 27V7.92935ZM2.2141 27.0005C2.21438 27.4223 2.55109 27.75 2.93737 27.75H20.6649C21.0658 27.75 21.4029 27.4074 21.4029 27V10.1794H13.6172V2.25H2.95213C2.56569 2.25 2.22886 2.57793 2.22886 3L2.2141 27.0005ZM15.8313 7.92935H20.5L15.8313 3V7.92935Z\" fill=\"black\"/><path d=\"M4 19.8H5.66667V18.2H4V19.8ZM4 23H5.66667V21.4H4V23ZM4 16.6H5.66667V15H4V16.6ZM7.33333 19.8H19V18.2H7.33333V19.8ZM7.33333 23H19V21.4H7.33333V23ZM7.33333 15V16.6H19V15H7.33333Z\" fill=\"black\"/></svg>',\n  'types/total':\n    '<svg width=\"36\" height=\"36\" viewBox=\"0 0 36 36\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><rect width=\"36\" height=\"36\" fill=\"white\"/><rect x=\"3\" y=\"3\" width=\"8\" height=\"8\" fill=\"black\"/><rect x=\"3\" y=\"14\" width=\"8\" height=\"8\" fill=\"black\"/><rect x=\"3\" y=\"25\" width=\"8\" height=\"8\" fill=\"black\"/><rect x=\"14\" y=\"3\" width=\"8\" height=\"8\" fill=\"black\"/><rect x=\"14\" y=\"14\" width=\"8\" height=\"8\" fill=\"black\"/><rect x=\"14\" y=\"25\" width=\"8\" height=\"8\" fill=\"black\"/><rect x=\"25\" y=\"3\" width=\"8\" height=\"8\" fill=\"black\"/><rect x=\"25\" y=\"14\" width=\"8\" height=\"8\" fill=\"black\"/><rect x=\"25\" y=\"25\" width=\"8\" height=\"8\" fill=\"black\"/></svg>',\n  'types/video':\n    '<svg width=\"36\" height=\"27\" viewBox=\"0 0 36 27\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M6.45 0.169922C2.89915 0.169922 0 3.06907 0 6.61992V20.3799C0 23.9308 2.89915 26.8299 6.45 26.8299H28.81C32.3609 26.8299 35.26 23.9308 35.26 20.3799V6.61992C35.26 3.06907 32.3609 0.169922 28.81 0.169922H6.45ZM6.45 2.74992H28.81C30.9768 2.74992 32.68 4.45311 32.68 6.61992V20.3799C32.68 22.5467 30.9768 24.2499 28.81 24.2499H6.45C4.28319 24.2499 2.58 22.5467 2.58 20.3799V6.61992C2.58 4.45311 4.28319 2.74992 6.45 2.74992ZM13.8004 6.61992C13.451 6.60816 13.1134 6.73918 12.8615 6.98273C12.6112 7.22629 12.4701 7.56057 12.4701 7.9099V19.0899C12.4667 19.7517 12.9656 20.311 13.6257 20.3799C13.8861 20.4068 14.1481 20.3564 14.3782 20.2321L24.6982 14.6421C25.1165 14.417 25.3751 13.9803 25.3751 13.5066C25.3751 13.0313 25.1165 12.5962 24.6982 12.3712L14.3782 6.78117C14.2002 6.68207 14.0037 6.62664 13.8004 6.61992H13.8004ZM15.0501 10.0868L21.3659 13.4999L15.0501 16.9265V10.0868Z\" fill=\"black\"/></svg>',\n  'types/worksheet':\n    '<svg width=\"29\" height=\"28\" viewBox=\"0 0 29 28\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M27.4071 8.81132C26.4479 7.8521 24.886 7.8521 23.9267 8.81132C23.6314 9.10664 21.7469 10.9934 21.4592 11.281L21.4581 4.78081C21.4581 4.12345 21.2022 3.50549 20.7373 3.04066L18.4175 0.720807C17.9526 0.255951 17.3347 3.05176e-05 16.6773 3.05176e-05H2.59083C1.23347 3.05176e-05 0.129883 1.10362 0.129883 2.46098V25.5391C0.129883 26.8965 1.23347 28.0001 2.59083 28.0001H18.9971C20.3545 28.0001 21.4581 26.8965 21.4581 25.5391V18.246L27.407 12.2915C28.3684 11.3301 28.3684 9.77368 27.407 8.8111L27.4071 8.81132ZM16.5364 1.6408C16.6917 1.6408 16.9903 1.61346 17.2572 1.88143L19.577 4.20129C19.8373 4.4616 19.8177 4.74706 19.8177 4.92206H16.5363L16.5364 1.6408ZM19.8177 25.5394C19.8177 25.9922 19.4502 26.3597 18.9974 26.3597H2.59108C2.13827 26.3597 1.77077 25.9922 1.77077 25.5394V2.4612C1.77077 2.00839 2.13827 1.64089 2.59108 1.64089H14.8957V5.74233C14.8957 6.19514 15.2632 6.56264 15.716 6.56264H19.8174V12.924L17.397 15.3466L16.2376 16.506C16.1479 16.5957 16.0801 16.7061 16.0396 16.8264L14.8792 20.3068C14.7807 20.6022 14.8573 20.927 15.0772 21.1468C15.297 21.3667 15.6218 21.4432 15.9172 21.3448L19.3975 20.1843C19.5179 20.1439 19.6283 20.0761 19.718 19.9864L19.8175 19.8868L19.8177 25.5394ZM17.978 17.0859L19.1385 18.2463L18.6955 18.6893L16.9554 19.269L17.5351 17.5288L17.978 17.0859ZM20.2979 17.0859L19.1374 15.9254C19.7554 15.3075 22.4985 12.5609 23.0804 11.9791L24.2408 13.1396L20.2979 17.0859ZM26.2468 11.1325L25.4013 11.9791L24.2408 10.8186L25.0863 9.97206C25.4068 9.6527 25.9263 9.6527 26.2468 9.97206C26.5661 10.2925 26.5683 10.811 26.2468 11.1325Z\" fill=\"black\"/><path d=\"M15.7159 8.20319H4.23145C3.77863 8.20319 3.41113 8.57069 3.41113 9.0235C3.41113 9.47632 3.77863 9.84382 4.23145 9.84382H15.7159C16.1687 9.84382 16.5362 9.47632 16.5362 9.0235C16.5362 8.57069 16.1687 8.20319 15.7159 8.20319Z\" fill=\"black\"/><path d=\"M12.4346 11.4845H4.23145C3.77863 11.4845 3.41113 11.852 3.41113 12.3048C3.41113 12.7576 3.77863 13.1251 4.23145 13.1251H12.4346C12.8874 13.1251 13.2549 12.7576 13.2549 12.3048C13.2549 11.852 12.8874 11.4845 12.4346 11.4845Z\" fill=\"black\"/><path d=\"M12.4346 14.7655H4.23145C3.77863 14.7655 3.41113 15.133 3.41113 15.5859C3.41113 16.0387 3.77863 16.4062 4.23145 16.4062H12.4346C12.8874 16.4062 13.2549 16.0387 13.2549 15.5859C13.2549 15.133 12.8874 14.7655 12.4346 14.7655Z\" fill=\"black\"/><path d=\"M12.4346 18.0468H4.23145C3.77863 18.0468 3.41113 18.4143 3.41113 18.8672C3.41113 19.32 3.77863 19.6875 4.23145 19.6875H12.4346C12.8874 19.6875 13.2549 19.32 13.2549 18.8672C13.2549 18.4143 12.8874 18.0468 12.4346 18.0468Z\" fill=\"black\"/><path d=\"M15.7163 23.0782H10.7944C10.3416 23.0782 9.97412 23.4457 9.97412 23.8985C9.97412 24.3513 10.3416 24.7188 10.7944 24.7188H15.7163C16.1691 24.7188 16.5366 24.3513 16.5366 23.8985C16.5366 23.4457 16.1691 23.0782 15.7163 23.0782V23.0782Z\" fill=\"black\"/></svg>',\n  layers:\n    '<svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"#5f6368\"><path d=\"M480-118 120-398l66-50 294 228 294-228 66 50-360 280Zm0-202L120-600l360-280 360 280-360 280Zm0-280Zm0 178 230-178-230-178-230 178 230 178Z\"/></svg>',\n};\n\n@Injectable({ providedIn: 'root' })\nexport class SvgIconsService {\n  private initialized = false;\n\n  constructor(private matIconRegistry: MatIconRegistry, private domSanitizer: DomSanitizer) {\n    this.init();\n  }\n\n  init() {\n    if (this.initialized) {\n      return;\n    }\n    for (const icon of Object.keys(ICONS)) {\n      //console.log('!svg-inline-loader?classPrefix!src/assets/svg/' + icon + '.svg');\n      this.matIconRegistry.addSvgIconLiteral(\n        icon,\n        this.domSanitizer.bypassSecurityTrustHtml((ICONS as any)[icon] as string)\n      );\n    }\n    this.initialized = true;\n  }\n}\n"]}
44
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"svg-icons.service.js","sourceRoot":"","sources":["../../../../../projects/ng-meta-widgets-lib/src/lib/core/svg-icons.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;;;;AAI3C,MAAM,KAAK,GAAG;IACZ,KAAK,EACH,63DAA63D;IAC/3D,IAAI,EAAE,m6EAAm6E;IACz6E,aAAa,EACX,keAAke;IACpe,gBAAgB,EACd,01CAA01C;IAC51C,aAAa,EACX,81CAA81C;IACh2C,uBAAuB,EACrB,ivBAAivB;IACnvB,aAAa,EACX,2nBAA2nB;IAC7nB,aAAa,EACX,2+BAA2+B;IAC7+B,iBAAiB,EACf,o3FAAo3F;IACt3F,MAAM,EACJ,yQAAyQ;IAC3Q,SAAS,EACP,oYAAoY;IACtY,SAAS,EACP,ilBAAilB;IACnlB,SAAS,EACP,6fAA6f;CAChgB,CAAC;AAGF,MAAM,OAAO,eAAe;IAG1B,YAAoB,eAAgC,EAAU,YAA0B;QAApE,oBAAe,GAAf,eAAe,CAAiB;QAAU,iBAAY,GAAZ,YAAY,CAAc;QAFhF,gBAAW,GAAG,KAAK,CAAC;QAG1B,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,IAAI;QACF,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,OAAO;QACT,CAAC;QACD,KAAK,MAAM,IAAI,IAAI,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;YACtC,gFAAgF;YAChF,IAAI,CAAC,eAAe,CAAC,iBAAiB,CACpC,IAAI,EACJ,IAAI,CAAC,YAAY,CAAC,uBAAuB,CAAE,KAAa,CAAC,IAAI,CAAW,CAAC,CAC1E,CAAC;QACJ,CAAC;QACD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC1B,CAAC;+GAnBU,eAAe;mHAAf,eAAe,cADF,MAAM;;4FACnB,eAAe;kBAD3B,UAAU;mBAAC,EAAE,UAAU,EAAE,MAAM,EAAE","sourcesContent":["import { Injectable } from '@angular/core';\nimport { MatIconRegistry } from '@angular/material/icon';\nimport { DomSanitizer } from '@angular/platform-browser';\n\nconst ICONS = {\n  child:\n    '<svg width=\"37\" height=\"37\" viewBox=\"0 0 37 37\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M12.7188 24.2813H3.46875C2.82991 24.2813 2.3125 23.7638 2.3125 23.125V13.875C2.3125 13.2362 2.82991 12.7188 3.46875 12.7188H12.7188C13.3576 12.7188 13.875 13.2362 13.875 13.875V23.125C13.875 23.7638 13.3576 24.2813 12.7188 24.2813ZM4.625 21.9688H11.5625V15.0313H4.625V21.9688Z\" fill=\"black\"/><path d=\"M33.5313 32.375H24.2813C23.6424 32.375 23.125 31.8576 23.125 31.2188V21.9688C23.125 21.3299 23.6424 20.8125 24.2813 20.8125H33.5313C34.1701 20.8125 34.6875 21.3299 34.6875 21.9688V31.2188C34.6875 31.8576 34.1701 32.375 33.5313 32.375ZM25.4375 30.0625H32.375V23.125H25.4375V30.0625Z\" fill=\"black\"/><path d=\"M33.5313 13.875H24.2813C23.6424 13.875 23.125 13.3576 23.125 12.7188V3.46875C23.125 2.82991 23.6424 2.3125 24.2813 2.3125H33.5313C34.1701 2.3125 34.6875 2.82991 34.6875 3.46875V12.7188C34.6875 13.3576 34.1701 13.875 33.5313 13.875ZM25.4375 11.5625H32.375V4.625H25.4375V11.5625Z\" fill=\"black\"/><path d=\"M18.5 37C17.8612 37 17.3438 36.4826 17.3438 35.8438V1.15625C17.3438 0.517408 17.8612 0 18.5 0C19.1388 0 19.6563 0.517408 19.6563 1.15625V35.8438C19.6563 36.4826 19.1388 37 18.5 37Z\" fill=\"black\"/><path d=\"M18.5 19.6563H12.7188C12.0799 19.6563 11.5625 19.1388 11.5625 18.5C11.5625 17.8612 12.0799 17.3438 12.7188 17.3438H18.5C19.1388 17.3438 19.6563 17.8612 19.6563 18.5C19.6563 19.1388 19.1388 19.6563 18.5 19.6563Z\" fill=\"black\"/><path d=\"M24.2813 9.25H18.5C17.8612 9.25 17.3438 8.73259 17.3438 8.09375C17.3438 7.45491 17.8612 6.9375 18.5 6.9375H24.2813C24.9201 6.9375 25.4375 7.45491 25.4375 8.09375C25.4375 8.73259 24.9201 9.25 24.2813 9.25Z\" fill=\"black\"/><path d=\"M24.2813 27.75H18.5C17.8612 27.75 17.3438 27.2326 17.3438 26.5938C17.3438 25.9549 17.8612 25.4375 18.5 25.4375H24.2813C24.9201 25.4375 25.4375 25.9549 25.4375 26.5938C25.4375 27.2326 24.9201 27.75 24.2813 27.75Z\" fill=\"black\"/></svg>',\n  tree: '<svg width=\"43\" height=\"43\" viewBox=\"0 0 43 43\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M36.3082 24.5605C34.6184 24.5605 33.2478 23.1899 33.2478 21.5001C33.2478 19.8086 34.6184 18.4397 36.3082 18.4397C37.9996 18.4397 39.3686 19.8086 39.3686 21.5001C39.3686 23.1899 37.9996 24.5605 36.3082 24.5605V24.5605ZM6.62486 37.0842C4.93341 37.0842 3.56279 35.7136 3.56279 34.0238C3.56279 32.3324 4.93341 30.9634 6.62486 30.9634C8.31463 30.9634 9.68526 32.3324 9.68526 34.0238C9.68526 35.7136 8.31463 37.0842 6.62486 37.0842ZM6.62486 12.0367C4.93341 12.0367 3.56279 10.6661 3.56279 8.97467C3.56279 7.28489 4.93341 5.91427 6.62486 5.91427C8.31463 5.91427 9.68526 7.28489 9.68526 8.97467C9.68526 10.6661 8.31463 12.0367 6.62486 12.0367ZM36.3082 16.3032C34.3261 16.3032 32.6028 17.4151 31.7261 19.0478C30.3387 19.0461 28.4793 19.0511 27.5957 19.0461C25.5633 19.0343 23.8836 17.4017 23.8584 15.3692C23.8316 13.3889 23.3243 11.5782 22.0981 10.0028C20.7006 8.20892 18.9336 6.9811 16.6608 6.58636C16.0863 6.48726 15.4951 6.45534 14.9105 6.44694C13.6609 6.43015 12.4095 6.43518 11.1598 6.4419C10.2712 4.85292 8.57306 3.7796 6.62456 3.7796C3.75397 3.7796 1.42758 6.10599 1.42758 8.97486C1.42758 11.8455 3.75397 14.1718 6.62456 14.1718C8.5713 14.1718 10.2695 13.0985 11.1581 11.5129C12.4901 11.5146 13.822 11.5079 15.154 11.5247C15.4933 11.528 15.8427 11.5935 16.1669 11.6977C17.6937 12.1864 18.7402 13.6192 18.7586 15.2468C18.7855 17.3263 19.3801 19.1975 20.7407 20.7964C20.9523 21.0467 21.1824 21.2818 21.4025 21.522C21.379 21.5506 21.3655 21.5707 21.3487 21.5875C19.7362 23.1665 18.888 25.0846 18.7839 27.3371C18.762 27.7856 18.7671 28.2441 18.6747 28.6791C18.3119 30.3672 16.7817 31.58 15.0348 31.59C13.7617 31.5968 12.4901 31.5917 11.2186 31.5951C10.3452 29.949 8.61675 28.8269 6.62275 28.8269C3.75383 28.8269 1.42749 31.1533 1.42749 34.0239C1.42749 36.8928 3.75388 39.2192 6.62275 39.2192C8.5544 39.2192 10.2374 38.166 11.1343 36.6022C12.4596 36.609 13.7866 36.6123 15.1135 36.5989C15.5771 36.5939 16.0457 36.5569 16.5043 36.4847C18.5031 36.1756 20.1559 35.2165 21.525 33.7501C22.9208 32.2569 23.7052 30.4983 23.8194 28.4491C23.8446 28.009 23.8479 27.5639 23.9135 27.1289C24.162 25.4828 25.7914 24.0752 27.4526 24.0634C28.3949 24.055 30.35 24.0584 31.7878 24.0584C32.6797 25.6323 34.3695 26.6955 36.308 26.6955C39.1786 26.6955 41.505 24.3691 41.505 21.5002C41.505 18.6296 39.1786 16.3033 36.308 16.3033\" fill=\"black\"/></svg>',\n  'types/audio':\n    '<svg width=\"35\" height=\"35\" viewBox=\"0 0 35 35\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M17.5 1.45834C10.2521 1.45834 4.375 7.33543 4.375 14.5833V24.7917C4.375 27.2125 6.32917 29.1667 8.75 29.1667H13.125V17.5H7.29167V14.5833C7.29167 8.93959 11.8563 4.37501 17.5 4.37501C23.1438 4.37501 27.7083 8.93959 27.7083 14.5833V17.5H21.875V29.1667H26.25C28.6708 29.1667 30.625 27.2125 30.625 24.7917V14.5833C30.625 7.33543 24.7479 1.45834 17.5 1.45834Z\" fill=\"black\"/></svg>',\n  'types/exercise':\n    '<svg width=\"27\" height=\"33\" viewBox=\"0 0 27 33\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M19.9836 14.3248L13.3957 7.61539H2.49795C1.12408 7.61539 0.0124901 8.75769 0.0124901 10.1538L0 30.4615C0 31.8577 1.11159 33 2.48546 33H17.4857C18.8596 33 19.9836 31.8577 19.9836 30.4615V14.3248ZM1.87347 30.462C1.87371 30.8189 2.15862 31.0962 2.48546 31.0962H17.4857C17.8249 31.0962 18.1102 30.8062 18.1102 30.4615V16.2287H11.5222V9.51923H2.49795C2.17097 9.51923 1.88596 9.79672 1.88596 10.1538L1.87347 30.462ZM13.3957 14.3248H17.3462L13.3957 10.1538V14.3248Z\" fill=\"black\"/><path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M20.1647 0L26.7526 6.70945V22.8462C26.7526 24.2423 25.6285 25.3846 24.2546 25.3846H19.4616V23.4808H24.2546C24.5938 23.4808 24.8791 23.1908 24.8791 22.8462V8.6133H18.2912V1.90385H9.26691C8.93992 1.90385 8.65491 2.18133 8.65491 2.53846L8.65179 7.61538H6.77832L6.78144 2.53846C6.78144 1.14231 7.89303 0 9.26691 0H20.1647ZM24.1151 6.70945H20.1647V2.53846L24.1151 6.70945Z\" fill=\"black\"/><line x1=\"4\" y1=\"19.25\" x2=\"16\" y2=\"19.25\" stroke=\"black\" stroke-width=\"1.5\"/><line x1=\"4\" y1=\"22.25\" x2=\"16\" y2=\"22.25\" stroke=\"black\" stroke-width=\"1.5\"/><line x1=\"4\" y1=\"25.25\" x2=\"16\" y2=\"25.25\" stroke=\"black\" stroke-width=\"1.5\"/><line x1=\"4\" y1=\"28.25\" x2=\"16\" y2=\"28.25\" stroke=\"black\" stroke-width=\"1.5\"/></svg>',\n  'types/image':\n    '<svg width=\"34\" height=\"26\" viewBox=\"0 0 34 26\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M3.08885 0.400024C1.71214 0.400024 0.568848 1.54331 0.568848 2.92002V23.08C0.568848 24.4567 1.71214 25.6 3.08885 25.6H31.1688C32.5456 25.6 33.6888 24.4567 33.6888 23.08V2.92002C33.6888 1.54331 32.5456 0.400024 31.1688 0.400024H3.08885ZM3.08885 2.56002H31.1688C31.3868 2.56002 31.5288 2.70206 31.5288 2.92002V17.23L26.0838 12.8762C25.7281 12.5879 25.181 12.564 24.8013 12.8199L19.6937 16.3299L12.7637 10.7161C12.5429 10.5361 12.249 10.4489 11.9649 10.4798C11.7877 10.5009 11.6161 10.567 11.4699 10.6711L2.72874 16.7011V2.91993C2.72874 2.70197 2.87077 2.55993 3.08874 2.55993L3.08885 2.56002ZM19.6488 5.44002C17.8728 5.44002 16.4088 6.90393 16.4088 8.68002C16.4088 10.4561 17.8728 11.92 19.6488 11.92C21.4249 11.92 22.8888 10.4561 22.8888 8.68002C22.8888 6.90393 21.4249 5.44002 19.6488 5.44002ZM19.6488 7.60002C20.2578 7.60002 20.7288 8.07112 20.7288 8.68002C20.7288 9.28893 20.2578 9.76002 19.6488 9.76002C19.0399 9.76002 18.5688 9.28893 18.5688 8.68002C18.5688 8.07112 19.0399 7.60002 19.6488 7.60002ZM12.0438 12.91L18.9738 18.5123C19.3296 18.8006 19.8767 18.8245 20.2563 18.5686L25.3525 15.0586L31.5287 19.9974V23.0799C31.5287 23.2979 31.3866 23.4399 31.1687 23.4399H3.08867C2.8707 23.4399 2.72867 23.2979 2.72867 23.0799V19.3338L12.0438 12.91Z\" fill=\"black\"/></svg>',\n  'types/lesson_planning':\n    '<svg width=\"24\" height=\"30\" viewBox=\"0 0 24 30\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M23.617 7.92935L15.8313 0H2.95213C1.32846 0 0.014761 1.35 0.014761 3L0 27C0 28.65 1.3137 30 2.93737 30H20.6649C22.2886 30 23.617 28.65 23.617 27V7.92935ZM2.2141 27.0005C2.21438 27.4223 2.55109 27.75 2.93737 27.75H20.6649C21.0658 27.75 21.4029 27.4074 21.4029 27V10.1794H13.6172V2.25H2.95213C2.56569 2.25 2.22886 2.57793 2.22886 3L2.2141 27.0005ZM15.8313 7.92935H20.5L15.8313 3V7.92935Z\" fill=\"black\"/><path d=\"M4 19.8H5.66667V18.2H4V19.8ZM4 23H5.66667V21.4H4V23ZM4 16.6H5.66667V15H4V16.6ZM7.33333 19.8H19V18.2H7.33333V19.8ZM7.33333 23H19V21.4H7.33333V23ZM7.33333 15V16.6H19V15H7.33333Z\" fill=\"black\"/></svg>',\n  'types/total':\n    '<svg width=\"36\" height=\"36\" viewBox=\"0 0 36 36\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><rect width=\"36\" height=\"36\" fill=\"white\"/><rect x=\"3\" y=\"3\" width=\"8\" height=\"8\" fill=\"black\"/><rect x=\"3\" y=\"14\" width=\"8\" height=\"8\" fill=\"black\"/><rect x=\"3\" y=\"25\" width=\"8\" height=\"8\" fill=\"black\"/><rect x=\"14\" y=\"3\" width=\"8\" height=\"8\" fill=\"black\"/><rect x=\"14\" y=\"14\" width=\"8\" height=\"8\" fill=\"black\"/><rect x=\"14\" y=\"25\" width=\"8\" height=\"8\" fill=\"black\"/><rect x=\"25\" y=\"3\" width=\"8\" height=\"8\" fill=\"black\"/><rect x=\"25\" y=\"14\" width=\"8\" height=\"8\" fill=\"black\"/><rect x=\"25\" y=\"25\" width=\"8\" height=\"8\" fill=\"black\"/></svg>',\n  'types/video':\n    '<svg width=\"36\" height=\"27\" viewBox=\"0 0 36 27\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M6.45 0.169922C2.89915 0.169922 0 3.06907 0 6.61992V20.3799C0 23.9308 2.89915 26.8299 6.45 26.8299H28.81C32.3609 26.8299 35.26 23.9308 35.26 20.3799V6.61992C35.26 3.06907 32.3609 0.169922 28.81 0.169922H6.45ZM6.45 2.74992H28.81C30.9768 2.74992 32.68 4.45311 32.68 6.61992V20.3799C32.68 22.5467 30.9768 24.2499 28.81 24.2499H6.45C4.28319 24.2499 2.58 22.5467 2.58 20.3799V6.61992C2.58 4.45311 4.28319 2.74992 6.45 2.74992ZM13.8004 6.61992C13.451 6.60816 13.1134 6.73918 12.8615 6.98273C12.6112 7.22629 12.4701 7.56057 12.4701 7.9099V19.0899C12.4667 19.7517 12.9656 20.311 13.6257 20.3799C13.8861 20.4068 14.1481 20.3564 14.3782 20.2321L24.6982 14.6421C25.1165 14.417 25.3751 13.9803 25.3751 13.5066C25.3751 13.0313 25.1165 12.5962 24.6982 12.3712L14.3782 6.78117C14.2002 6.68207 14.0037 6.62664 13.8004 6.61992H13.8004ZM15.0501 10.0868L21.3659 13.4999L15.0501 16.9265V10.0868Z\" fill=\"black\"/></svg>',\n  'types/worksheet':\n    '<svg width=\"29\" height=\"28\" viewBox=\"0 0 29 28\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M27.4071 8.81132C26.4479 7.8521 24.886 7.8521 23.9267 8.81132C23.6314 9.10664 21.7469 10.9934 21.4592 11.281L21.4581 4.78081C21.4581 4.12345 21.2022 3.50549 20.7373 3.04066L18.4175 0.720807C17.9526 0.255951 17.3347 3.05176e-05 16.6773 3.05176e-05H2.59083C1.23347 3.05176e-05 0.129883 1.10362 0.129883 2.46098V25.5391C0.129883 26.8965 1.23347 28.0001 2.59083 28.0001H18.9971C20.3545 28.0001 21.4581 26.8965 21.4581 25.5391V18.246L27.407 12.2915C28.3684 11.3301 28.3684 9.77368 27.407 8.8111L27.4071 8.81132ZM16.5364 1.6408C16.6917 1.6408 16.9903 1.61346 17.2572 1.88143L19.577 4.20129C19.8373 4.4616 19.8177 4.74706 19.8177 4.92206H16.5363L16.5364 1.6408ZM19.8177 25.5394C19.8177 25.9922 19.4502 26.3597 18.9974 26.3597H2.59108C2.13827 26.3597 1.77077 25.9922 1.77077 25.5394V2.4612C1.77077 2.00839 2.13827 1.64089 2.59108 1.64089H14.8957V5.74233C14.8957 6.19514 15.2632 6.56264 15.716 6.56264H19.8174V12.924L17.397 15.3466L16.2376 16.506C16.1479 16.5957 16.0801 16.7061 16.0396 16.8264L14.8792 20.3068C14.7807 20.6022 14.8573 20.927 15.0772 21.1468C15.297 21.3667 15.6218 21.4432 15.9172 21.3448L19.3975 20.1843C19.5179 20.1439 19.6283 20.0761 19.718 19.9864L19.8175 19.8868L19.8177 25.5394ZM17.978 17.0859L19.1385 18.2463L18.6955 18.6893L16.9554 19.269L17.5351 17.5288L17.978 17.0859ZM20.2979 17.0859L19.1374 15.9254C19.7554 15.3075 22.4985 12.5609 23.0804 11.9791L24.2408 13.1396L20.2979 17.0859ZM26.2468 11.1325L25.4013 11.9791L24.2408 10.8186L25.0863 9.97206C25.4068 9.6527 25.9263 9.6527 26.2468 9.97206C26.5661 10.2925 26.5683 10.811 26.2468 11.1325Z\" fill=\"black\"/><path d=\"M15.7159 8.20319H4.23145C3.77863 8.20319 3.41113 8.57069 3.41113 9.0235C3.41113 9.47632 3.77863 9.84382 4.23145 9.84382H15.7159C16.1687 9.84382 16.5362 9.47632 16.5362 9.0235C16.5362 8.57069 16.1687 8.20319 15.7159 8.20319Z\" fill=\"black\"/><path d=\"M12.4346 11.4845H4.23145C3.77863 11.4845 3.41113 11.852 3.41113 12.3048C3.41113 12.7576 3.77863 13.1251 4.23145 13.1251H12.4346C12.8874 13.1251 13.2549 12.7576 13.2549 12.3048C13.2549 11.852 12.8874 11.4845 12.4346 11.4845Z\" fill=\"black\"/><path d=\"M12.4346 14.7655H4.23145C3.77863 14.7655 3.41113 15.133 3.41113 15.5859C3.41113 16.0387 3.77863 16.4062 4.23145 16.4062H12.4346C12.8874 16.4062 13.2549 16.0387 13.2549 15.5859C13.2549 15.133 12.8874 14.7655 12.4346 14.7655Z\" fill=\"black\"/><path d=\"M12.4346 18.0468H4.23145C3.77863 18.0468 3.41113 18.4143 3.41113 18.8672C3.41113 19.32 3.77863 19.6875 4.23145 19.6875H12.4346C12.8874 19.6875 13.2549 19.32 13.2549 18.8672C13.2549 18.4143 12.8874 18.0468 12.4346 18.0468Z\" fill=\"black\"/><path d=\"M15.7163 23.0782H10.7944C10.3416 23.0782 9.97412 23.4457 9.97412 23.8985C9.97412 24.3513 10.3416 24.7188 10.7944 24.7188H15.7163C16.1691 24.7188 16.5366 24.3513 16.5366 23.8985C16.5366 23.4457 16.1691 23.0782 15.7163 23.0782V23.0782Z\" fill=\"black\"/></svg>',\n  layers:\n    '<svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"#5f6368\"><path d=\"M480-118 120-398l66-50 294 228 294-228 66 50-360 280Zm0-202L120-600l360-280 360 280-360 280Zm0-280Zm0 178 230-178-230-178-230 178 230 178Z\"/></svg>',\n  'level-1':\n    '<svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M4 12.9L3 13.8L11 20.7C11.6 21.2 12.4 21.2 13 20.7L21 13.8L20 12.9L12 19.8L4 12.9ZM11 3.40002L4 9.40002C3.4 9.90002 3.4 10.7 4 11.1L11 17.2C11.6 17.7 12.4 17.7 13 17.2L20 11.1C20.5 10.6 20.5 9.80002 20 9.40002L13 3.30002C12.4 2.90002 11.6 2.90002 11 3.40002Z\" fill=\"#003B7C\"/></svg>',\n  'level-2':\n    '<svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M20.3 9.90005C20.2 9.70005 20.1 9.60005 20 9.40005L13 3.30005C12.5 2.80005 11.5 2.80005 11 3.30005L4 9.40005C3.5 9.90005 3.5 10.7 4 11.1L11 17.2C11.5 17.7 12.5 17.7 13 17.2L20 11.1C20.3 10.8 20.4 10.5 20.4 10.2C20.4 10.1 20.4 10 20.3 9.90005ZM5 10.3L12 4.20005L19 10.3L12 16.4L5 10.3ZM20 12.9L12 19.8L4 12.9L3 13.8L11 20.7001C11.5 21.2001 12.5 21.2001 13 20.7001L21 13.8L20 12.9Z\" fill=\"#003B7C\"/><path opacity=\"0.3\" d=\"M19 10.3L12 16.3L5 10.3L12 4.19995L19 10.3Z\" fill=\"#003B7C\"/></svg>',\n  'level-3':\n    '<svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M20.3 9.90005C20.2 9.70005 20.1 9.60005 20 9.40005L13 3.30005C12.5 2.80005 11.5 2.80005 11 3.30005L4 9.40005C3.5 9.90005 3.5 10.7 4 11.1L11 17.2C11.5 17.7 12.5 17.7 13 17.2L20 11.1C20.3 10.8 20.4 10.5 20.4 10.2C20.4 10.1 20.4 10 20.3 9.90005ZM5 10.3L12 4.20005L19 10.3L12 16.4L5 10.3ZM20 12.9L12 19.8L4 12.9L3 13.8L11 20.7001C11.5 21.2001 12.5 21.2001 13 20.7001L21 13.8L20 12.9Z\" fill=\"#003B7C\"/></svg>',\n};\n\n@Injectable({ providedIn: 'root' })\nexport class SvgIconsService {\n  private initialized = false;\n\n  constructor(private matIconRegistry: MatIconRegistry, private domSanitizer: DomSanitizer) {\n    this.init();\n  }\n\n  init() {\n    if (this.initialized) {\n      return;\n    }\n    for (const icon of Object.keys(ICONS)) {\n      //console.log('!svg-inline-loader?classPrefix!src/assets/svg/' + icon + '.svg');\n      this.matIconRegistry.addSvgIconLiteral(\n        icon,\n        this.domSanitizer.bypassSecurityTrustHtml((ICONS as any)[icon] as string)\n      );\n    }\n    this.initialized = true;\n  }\n}\n"]}
@@ -144,7 +144,7 @@ export class CountsWithHistoryComponent {
144
144
  }));
145
145
  }
146
146
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CountsWithHistoryComponent, deps: [{ token: i1.MetaApiService }, { token: i0.DestroyRef }, { token: i2.EditorialLinkService }], target: i0.ɵɵFactoryTarget.Component }); }
147
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CountsWithHistoryComponent, isStandalone: true, selector: "metaqs2-counts-with-history", inputs: { apiMethod: "apiMethod", columnTranslationkey: "columnTranslationkey", pageTitle: "pageTitle", sourceType: "sourceType" }, ngImport: i0, template: "<mat-card appearance=\"raised\">\n <mat-card-header *ngIf=\"pageTitle\">\n <mat-card-title data-test-id=\"page-title\">\n Qualit\u00E4tsmetrik: {{ pageTitle | translate }}{{ isLoading() ? \": Lade neue Daten.\" : \"\" }}\n </mat-card-title>\n </mat-card-header>\n <!-- consider to put the filter in the table header to avoid that it is scrolled out of view-->\n <!-- show the filter after the values are loaded to avoid loading current data twice -->\n <mat-card-content class=\"toolbar\">\n <metaqs2-datepicker [disabled]=\"isLoading() || !isHistoryEnabled()\" [inputGroup]=\"range\" *ngIf=\"timeFilterLoaded() && isHistoryEnabled()\"></metaqs2-datepicker>\n <div style=\"flex: 1 1 auto\"></div>\n <mat-slide-toggle [ngModel]=\"isHistoryEnabled()\" (ngModelChange)=\"isHistoryEnabled.set($event)\" [disabled]=\"isLoading()\" *ngIf=\"timeFilterLoaded()\">\n <label>Zeige historische Daten</label>\n </mat-slide-toggle>\n </mat-card-content>\n</mat-card>\n<mat-card>\n <metaqs2-progress-spinner [displayProgressSpinner]=\"isLoading()\"></metaqs2-progress-spinner>\n <table [class.while-loading]=\"isLoading()\" mat-table [dataSource]=\"recentTypeCount$.value.rows\"\n class=\"quality-matrix\">\n <!-- Define columns of table -->\n <!-- Row Header Column -->\n <ng-container matColumnDef=\"label-col\" sticky>\n <th [attr.rowspan]=\"isHistoryEnabled() ? '2' : '1'\" mat-header-cell *matHeaderCellDef>\n <div>Quelle</div>\n </th>\n <td\n mat-cell\n *matCellDef=\"let row\"\n [matTooltip]=\"row.meta.alt_label\"\n class=\"label-col\"\n >\n {{ row.meta.label }}\n </td>\n </ng-container>\n <!-- one column for each type -->\n <ng-container *ngFor=\"let col of (recentTypeCount$ | async)?.columns; trackBy:columnIdent\"\n [matColumnDef]=\"col.id + '_type'\">\n <th [attr.colspan]=\"isHistoryEnabled() ? '2' : '1'\" mat-header-cell *matHeaderCellDef [matTooltip]=\"col.label\">\n {{ columnTranslationkey ? (columnTranslationkey + col.label | translate) : col.label }}\n </th>\n </ng-container>\n <!-- one column for each type for the most current date-->\n <ng-container *ngFor=\"let col of (recentTypeCount$ | async)?.columns; trackBy:columnIdent\"\n [matColumnDef]=\"col.id + '_recent'\">\n <th class=\"recent-data-cell\" mat-header-cell *matHeaderCellDef\n matTooltip=\"no tooltip\">{{ range.controls.end.value.toLocaleString(DateTime.DATE_SHORT) }}\n </th>\n <td class=\"recent-data-cell\" mat-cell *matCellDef=\"let row\">\n <a [attr.href]=\"openInEditor(row.meta.id, col.id) | async\" target=\"editor_frontend\">{{ row.counts[col.id] ?? '\u2013' }}</a>\n </td>\n </ng-container>\n <!-- one column for each type for the older date-->\n <ng-container *ngFor=\"let col of (recentTypeCount$ | async)?.columns; trackBy:columnIdent\"\n [matColumnDef]=\"col.id + '_past'\">\n <th class=\"past-data-cell\" mat-header-cell *matHeaderCellDef matTooltip=\"no tooltip\">\n {{ (pastTypeCount$ | async)?.rows?.length ? range.controls.start.value.toLocaleString(DateTime.DATE_SHORT) : 'no past data' }}\n </th>\n <td class=\"past-data-cell\" mat-cell *matCellDef=\"let row;\" >\n <ng-container *ngIf=\"(pastTypeCount$ | async)?.rows?.length && pastTypeCount(row, col.id) as trend\">\n <span [class]=\"trend.trend\"> {{ trend.value ?? '\u2013' }}\n <mat-icon *ngIf=\"trend.value\" aria-hidden=\"false\" [attr.aria-label]=\"trend.trend\" [fontIcon]=\"trend.trend!\" /></span>\n <span class=\"cdk-visually-hidden\">{{ trend.trend }}</span>\n </ng-container>\n </td>\n </ng-container>\n <!-- generate actual table -->\n <tr mat-header-row *matHeaderRowDef=\"['label-col'].concat(typeColumns()); sticky:true;\"></tr>\n <tr [hidden]=\"!isHistoryEnabled()\" mat-header-row *matHeaderRowDef=\"allColumns(); sticky: true;\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: ['label-col'].concat(allColumns())\"></tr>\n\n </table>\n</mat-card>\n", styles: [".while-loading{filter:blur(2px)}tr:nth-child(2n){background-color:#e4e4e4}tr:nth-child(2n)>td.label-col,tr:nth-child(2n) td.recent-data-cell{border-right:1px solid white}tr:nth-child(odd){background-color:#fff}tr:nth-child(odd)>td.label-col,tr:nth-child(odd) td.recent-data-cell{border-right:1px solid #e4e4e4}td.label-col{text-align:left}.mat-mdc-header-cell,.mat-mdc-cell{text-align:center}.mat-mdc-header-cell a[href],.mat-mdc-cell a[href]{color:var(--mat-table-row-item-label-text-color);cursor:pointer;text-decoration:underline}.mat-mdc-header-cell a[href]:hover,.mat-mdc-cell a[href]:hover{text-decoration:underline}.mat-mdc-header-cell mat-icon,.mat-mdc-cell mat-icon{margin-left:5px;vertical-align:middle}.trending_down{color:#4abeff}.trending_up{color:#c20808}.actionbar{display:flex;flex-direction:row;justify-content:flex-start;align-items:center;gap:.5rem}\n"], dependencies: [{ kind: "ngmodule", type: MatCardModule }, { kind: "component", type: i3.MatCard, selector: "mat-card", inputs: ["appearance"], exportAs: ["matCard"] }, { kind: "directive", type: i3.MatCardContent, selector: "mat-card-content" }, { kind: "component", type: i3.MatCardHeader, selector: "mat-card-header" }, { kind: "directive", type: i3.MatCardTitle, selector: "mat-card-title, [mat-card-title], [matCardTitle]" }, { kind: "directive", type: MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "ngmodule", type: MatTableModule }, { kind: "component", type: i4.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i4.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i4.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i4.MatColumnDef, selector: "[matColumnDef]", inputs: ["matColumnDef"] }, { kind: "directive", type: i4.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i4.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i4.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i4.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i4.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i4.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }, { kind: "directive", type: NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: DatepickerComponent, selector: "metaqs2-datepicker", inputs: ["disabled", "inputGroup"] }, { kind: "component", type: MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: MatSlideToggle, selector: "mat-slide-toggle", inputs: ["name", "id", "labelPosition", "aria-label", "aria-labelledby", "aria-describedby", "required", "color", "disabled", "disableRipple", "tabIndex", "checked", "hideIcon", "disabledInteractive"], outputs: ["change", "toggleChange"], exportAs: ["matSlideToggle"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "component", type: ProgressSpinnerComponent, selector: "metaqs2-progress-spinner", inputs: ["color", "diameter", "strokeWidth", "backdropEnabled", "positionGloballyCenter", "displayProgressSpinner"] }] }); }
147
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CountsWithHistoryComponent, isStandalone: true, selector: "metaqs2-counts-with-history", inputs: { apiMethod: "apiMethod", columnTranslationkey: "columnTranslationkey", pageTitle: "pageTitle", sourceType: "sourceType" }, ngImport: i0, template: "<mat-card appearance=\"raised\">\n <mat-card-header *ngIf=\"pageTitle\">\n <mat-card-title data-test-id=\"page-title\">\n Qualit\u00E4tsmetrik: {{ pageTitle | translate }}{{ isLoading() ? \": Lade neue Daten.\" : \"\" }}\n </mat-card-title>\n </mat-card-header>\n <!-- consider to put the filter in the table header to avoid that it is scrolled out of view-->\n <!-- show the filter after the values are loaded to avoid loading current data twice -->\n <mat-card-content class=\"toolbar\">\n <metaqs2-datepicker [disabled]=\"isLoading() || !isHistoryEnabled()\" [inputGroup]=\"range\" *ngIf=\"timeFilterLoaded() && isHistoryEnabled()\"></metaqs2-datepicker>\n <div style=\"flex: 1 1 auto\"></div>\n <mat-slide-toggle [ngModel]=\"isHistoryEnabled()\" (ngModelChange)=\"isHistoryEnabled.set($event)\" [disabled]=\"isLoading()\" *ngIf=\"timeFilterLoaded()\">\n <label>Zeige historische Daten</label>\n </mat-slide-toggle>\n </mat-card-content>\n</mat-card>\n<mat-card>\n <metaqs2-progress-spinner [displayProgressSpinner]=\"isLoading()\"></metaqs2-progress-spinner>\n <table [class.while-loading]=\"isLoading()\" mat-table [dataSource]=\"recentTypeCount$.value.rows\"\n class=\"quality-matrix\">\n <!-- Define columns of table -->\n <!-- Row Header Column -->\n <ng-container matColumnDef=\"label-col\" sticky>\n <th [attr.rowspan]=\"isHistoryEnabled() ? '2' : '1'\" mat-header-cell *matHeaderCellDef>\n <div>Quelle</div>\n </th>\n <td\n mat-cell\n *matCellDef=\"let row\"\n [matTooltip]=\"row.meta.alt_label\"\n class=\"label-col mat-cell-level-{{row.meta.level + 1}}\"\n >\n {{ row.meta.label }}\n </td>\n </ng-container>\n <!-- one column for each type -->\n <ng-container *ngFor=\"let col of (recentTypeCount$ | async)?.columns; trackBy:columnIdent\"\n [matColumnDef]=\"col.id + '_type'\">\n <th [attr.colspan]=\"isHistoryEnabled() ? '2' : '1'\" mat-header-cell *matHeaderCellDef [matTooltip]=\"col.label\">\n {{ columnTranslationkey ? (columnTranslationkey + col.label | translate) : col.label }}\n </th>\n </ng-container>\n <!-- one column for each type for the most current date-->\n <ng-container *ngFor=\"let col of (recentTypeCount$ | async)?.columns; trackBy:columnIdent\"\n [matColumnDef]=\"col.id + '_recent'\">\n <th class=\"recent-data-cell\" mat-header-cell *matHeaderCellDef\n matTooltip=\"no tooltip\">{{ range.controls.end.value.toLocaleString(DateTime.DATE_SHORT) }}\n </th>\n <td class=\"recent-data-cell\" mat-cell *matCellDef=\"let row\">\n <a [attr.href]=\"openInEditor(row.meta.id, col.id) | async\" target=\"editor_frontend\">{{ row.counts[col.id] ?? '\u2013' }}</a>\n </td>\n </ng-container>\n <!-- one column for each type for the older date-->\n <ng-container *ngFor=\"let col of (recentTypeCount$ | async)?.columns; trackBy:columnIdent\"\n [matColumnDef]=\"col.id + '_past'\">\n <th class=\"past-data-cell\" mat-header-cell *matHeaderCellDef matTooltip=\"no tooltip\">\n {{ (pastTypeCount$ | async)?.rows?.length ? range.controls.start.value.toLocaleString(DateTime.DATE_SHORT) : 'no past data' }}\n </th>\n <td class=\"past-data-cell\" mat-cell *matCellDef=\"let row;\" >\n <ng-container *ngIf=\"(pastTypeCount$ | async)?.rows?.length && pastTypeCount(row, col.id) as trend\">\n <span [class]=\"trend.trend\"> {{ trend.value ?? '\u2013' }}\n <mat-icon *ngIf=\"trend.value\" aria-hidden=\"false\" [attr.aria-label]=\"trend.trend\" [fontIcon]=\"trend.trend!\" /></span>\n <span class=\"cdk-visually-hidden\">{{ trend.trend }}</span>\n </ng-container>\n </td>\n </ng-container>\n <!-- generate actual table -->\n <tr mat-header-row *matHeaderRowDef=\"['label-col'].concat(typeColumns()); sticky:true;\"></tr>\n <tr [hidden]=\"!isHistoryEnabled()\" mat-header-row *matHeaderRowDef=\"allColumns(); sticky: true;\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: ['label-col'].concat(allColumns())\"></tr>\n\n </table>\n</mat-card>\n", styles: [".while-loading{filter:blur(2px)}tr:nth-child(2n){background-color:#e4e4e4}tr:nth-child(2n)>td.label-col,tr:nth-child(2n) td.recent-data-cell{border-right:1px solid white}tr:nth-child(odd){background-color:#fff}tr:nth-child(odd)>td.label-col,tr:nth-child(odd) td.recent-data-cell{border-right:1px solid #e4e4e4}td.label-col{text-align:left}.mat-mdc-header-cell,.mat-mdc-cell{text-align:center}.mat-mdc-header-cell a[href],.mat-mdc-cell a[href]{color:var(--mat-table-row-item-label-text-color);cursor:pointer;text-decoration:underline}.mat-mdc-header-cell a[href]:hover,.mat-mdc-cell a[href]:hover{text-decoration:underline}.mat-mdc-header-cell mat-icon,.mat-mdc-cell mat-icon{margin-left:5px;vertical-align:middle}.trending_down{color:#4abeff}.trending_up{color:#c20808}.actionbar{display:flex;flex-direction:row;justify-content:flex-start;align-items:center;gap:.5rem}\n"], dependencies: [{ kind: "ngmodule", type: MatCardModule }, { kind: "component", type: i3.MatCard, selector: "mat-card", inputs: ["appearance"], exportAs: ["matCard"] }, { kind: "directive", type: i3.MatCardContent, selector: "mat-card-content" }, { kind: "component", type: i3.MatCardHeader, selector: "mat-card-header" }, { kind: "directive", type: i3.MatCardTitle, selector: "mat-card-title, [mat-card-title], [matCardTitle]" }, { kind: "directive", type: MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "ngmodule", type: MatTableModule }, { kind: "component", type: i4.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i4.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i4.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i4.MatColumnDef, selector: "[matColumnDef]", inputs: ["matColumnDef"] }, { kind: "directive", type: i4.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i4.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i4.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i4.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i4.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i4.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }, { kind: "directive", type: NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: DatepickerComponent, selector: "metaqs2-datepicker", inputs: ["disabled", "inputGroup"] }, { kind: "component", type: MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: MatSlideToggle, selector: "mat-slide-toggle", inputs: ["name", "id", "labelPosition", "aria-label", "aria-labelledby", "aria-describedby", "required", "color", "disabled", "disableRipple", "tabIndex", "checked", "hideIcon", "disabledInteractive"], outputs: ["change", "toggleChange"], exportAs: ["matSlideToggle"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "component", type: ProgressSpinnerComponent, selector: "metaqs2-progress-spinner", inputs: ["color", "diameter", "strokeWidth", "backdropEnabled", "positionGloballyCenter", "displayProgressSpinner"] }] }); }
148
148
  }
149
149
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CountsWithHistoryComponent, decorators: [{
150
150
  type: Component,
@@ -170,7 +170,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
170
170
  MatSlideToggle,
171
171
  AsyncPipe,
172
172
  ProgressSpinnerComponent,
173
- ], template: "<mat-card appearance=\"raised\">\n <mat-card-header *ngIf=\"pageTitle\">\n <mat-card-title data-test-id=\"page-title\">\n Qualit\u00E4tsmetrik: {{ pageTitle | translate }}{{ isLoading() ? \": Lade neue Daten.\" : \"\" }}\n </mat-card-title>\n </mat-card-header>\n <!-- consider to put the filter in the table header to avoid that it is scrolled out of view-->\n <!-- show the filter after the values are loaded to avoid loading current data twice -->\n <mat-card-content class=\"toolbar\">\n <metaqs2-datepicker [disabled]=\"isLoading() || !isHistoryEnabled()\" [inputGroup]=\"range\" *ngIf=\"timeFilterLoaded() && isHistoryEnabled()\"></metaqs2-datepicker>\n <div style=\"flex: 1 1 auto\"></div>\n <mat-slide-toggle [ngModel]=\"isHistoryEnabled()\" (ngModelChange)=\"isHistoryEnabled.set($event)\" [disabled]=\"isLoading()\" *ngIf=\"timeFilterLoaded()\">\n <label>Zeige historische Daten</label>\n </mat-slide-toggle>\n </mat-card-content>\n</mat-card>\n<mat-card>\n <metaqs2-progress-spinner [displayProgressSpinner]=\"isLoading()\"></metaqs2-progress-spinner>\n <table [class.while-loading]=\"isLoading()\" mat-table [dataSource]=\"recentTypeCount$.value.rows\"\n class=\"quality-matrix\">\n <!-- Define columns of table -->\n <!-- Row Header Column -->\n <ng-container matColumnDef=\"label-col\" sticky>\n <th [attr.rowspan]=\"isHistoryEnabled() ? '2' : '1'\" mat-header-cell *matHeaderCellDef>\n <div>Quelle</div>\n </th>\n <td\n mat-cell\n *matCellDef=\"let row\"\n [matTooltip]=\"row.meta.alt_label\"\n class=\"label-col\"\n >\n {{ row.meta.label }}\n </td>\n </ng-container>\n <!-- one column for each type -->\n <ng-container *ngFor=\"let col of (recentTypeCount$ | async)?.columns; trackBy:columnIdent\"\n [matColumnDef]=\"col.id + '_type'\">\n <th [attr.colspan]=\"isHistoryEnabled() ? '2' : '1'\" mat-header-cell *matHeaderCellDef [matTooltip]=\"col.label\">\n {{ columnTranslationkey ? (columnTranslationkey + col.label | translate) : col.label }}\n </th>\n </ng-container>\n <!-- one column for each type for the most current date-->\n <ng-container *ngFor=\"let col of (recentTypeCount$ | async)?.columns; trackBy:columnIdent\"\n [matColumnDef]=\"col.id + '_recent'\">\n <th class=\"recent-data-cell\" mat-header-cell *matHeaderCellDef\n matTooltip=\"no tooltip\">{{ range.controls.end.value.toLocaleString(DateTime.DATE_SHORT) }}\n </th>\n <td class=\"recent-data-cell\" mat-cell *matCellDef=\"let row\">\n <a [attr.href]=\"openInEditor(row.meta.id, col.id) | async\" target=\"editor_frontend\">{{ row.counts[col.id] ?? '\u2013' }}</a>\n </td>\n </ng-container>\n <!-- one column for each type for the older date-->\n <ng-container *ngFor=\"let col of (recentTypeCount$ | async)?.columns; trackBy:columnIdent\"\n [matColumnDef]=\"col.id + '_past'\">\n <th class=\"past-data-cell\" mat-header-cell *matHeaderCellDef matTooltip=\"no tooltip\">\n {{ (pastTypeCount$ | async)?.rows?.length ? range.controls.start.value.toLocaleString(DateTime.DATE_SHORT) : 'no past data' }}\n </th>\n <td class=\"past-data-cell\" mat-cell *matCellDef=\"let row;\" >\n <ng-container *ngIf=\"(pastTypeCount$ | async)?.rows?.length && pastTypeCount(row, col.id) as trend\">\n <span [class]=\"trend.trend\"> {{ trend.value ?? '\u2013' }}\n <mat-icon *ngIf=\"trend.value\" aria-hidden=\"false\" [attr.aria-label]=\"trend.trend\" [fontIcon]=\"trend.trend!\" /></span>\n <span class=\"cdk-visually-hidden\">{{ trend.trend }}</span>\n </ng-container>\n </td>\n </ng-container>\n <!-- generate actual table -->\n <tr mat-header-row *matHeaderRowDef=\"['label-col'].concat(typeColumns()); sticky:true;\"></tr>\n <tr [hidden]=\"!isHistoryEnabled()\" mat-header-row *matHeaderRowDef=\"allColumns(); sticky: true;\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: ['label-col'].concat(allColumns())\"></tr>\n\n </table>\n</mat-card>\n", styles: [".while-loading{filter:blur(2px)}tr:nth-child(2n){background-color:#e4e4e4}tr:nth-child(2n)>td.label-col,tr:nth-child(2n) td.recent-data-cell{border-right:1px solid white}tr:nth-child(odd){background-color:#fff}tr:nth-child(odd)>td.label-col,tr:nth-child(odd) td.recent-data-cell{border-right:1px solid #e4e4e4}td.label-col{text-align:left}.mat-mdc-header-cell,.mat-mdc-cell{text-align:center}.mat-mdc-header-cell a[href],.mat-mdc-cell a[href]{color:var(--mat-table-row-item-label-text-color);cursor:pointer;text-decoration:underline}.mat-mdc-header-cell a[href]:hover,.mat-mdc-cell a[href]:hover{text-decoration:underline}.mat-mdc-header-cell mat-icon,.mat-mdc-cell mat-icon{margin-left:5px;vertical-align:middle}.trending_down{color:#4abeff}.trending_up{color:#c20808}.actionbar{display:flex;flex-direction:row;justify-content:flex-start;align-items:center;gap:.5rem}\n"] }]
173
+ ], template: "<mat-card appearance=\"raised\">\n <mat-card-header *ngIf=\"pageTitle\">\n <mat-card-title data-test-id=\"page-title\">\n Qualit\u00E4tsmetrik: {{ pageTitle | translate }}{{ isLoading() ? \": Lade neue Daten.\" : \"\" }}\n </mat-card-title>\n </mat-card-header>\n <!-- consider to put the filter in the table header to avoid that it is scrolled out of view-->\n <!-- show the filter after the values are loaded to avoid loading current data twice -->\n <mat-card-content class=\"toolbar\">\n <metaqs2-datepicker [disabled]=\"isLoading() || !isHistoryEnabled()\" [inputGroup]=\"range\" *ngIf=\"timeFilterLoaded() && isHistoryEnabled()\"></metaqs2-datepicker>\n <div style=\"flex: 1 1 auto\"></div>\n <mat-slide-toggle [ngModel]=\"isHistoryEnabled()\" (ngModelChange)=\"isHistoryEnabled.set($event)\" [disabled]=\"isLoading()\" *ngIf=\"timeFilterLoaded()\">\n <label>Zeige historische Daten</label>\n </mat-slide-toggle>\n </mat-card-content>\n</mat-card>\n<mat-card>\n <metaqs2-progress-spinner [displayProgressSpinner]=\"isLoading()\"></metaqs2-progress-spinner>\n <table [class.while-loading]=\"isLoading()\" mat-table [dataSource]=\"recentTypeCount$.value.rows\"\n class=\"quality-matrix\">\n <!-- Define columns of table -->\n <!-- Row Header Column -->\n <ng-container matColumnDef=\"label-col\" sticky>\n <th [attr.rowspan]=\"isHistoryEnabled() ? '2' : '1'\" mat-header-cell *matHeaderCellDef>\n <div>Quelle</div>\n </th>\n <td\n mat-cell\n *matCellDef=\"let row\"\n [matTooltip]=\"row.meta.alt_label\"\n class=\"label-col mat-cell-level-{{row.meta.level + 1}}\"\n >\n {{ row.meta.label }}\n </td>\n </ng-container>\n <!-- one column for each type -->\n <ng-container *ngFor=\"let col of (recentTypeCount$ | async)?.columns; trackBy:columnIdent\"\n [matColumnDef]=\"col.id + '_type'\">\n <th [attr.colspan]=\"isHistoryEnabled() ? '2' : '1'\" mat-header-cell *matHeaderCellDef [matTooltip]=\"col.label\">\n {{ columnTranslationkey ? (columnTranslationkey + col.label | translate) : col.label }}\n </th>\n </ng-container>\n <!-- one column for each type for the most current date-->\n <ng-container *ngFor=\"let col of (recentTypeCount$ | async)?.columns; trackBy:columnIdent\"\n [matColumnDef]=\"col.id + '_recent'\">\n <th class=\"recent-data-cell\" mat-header-cell *matHeaderCellDef\n matTooltip=\"no tooltip\">{{ range.controls.end.value.toLocaleString(DateTime.DATE_SHORT) }}\n </th>\n <td class=\"recent-data-cell\" mat-cell *matCellDef=\"let row\">\n <a [attr.href]=\"openInEditor(row.meta.id, col.id) | async\" target=\"editor_frontend\">{{ row.counts[col.id] ?? '\u2013' }}</a>\n </td>\n </ng-container>\n <!-- one column for each type for the older date-->\n <ng-container *ngFor=\"let col of (recentTypeCount$ | async)?.columns; trackBy:columnIdent\"\n [matColumnDef]=\"col.id + '_past'\">\n <th class=\"past-data-cell\" mat-header-cell *matHeaderCellDef matTooltip=\"no tooltip\">\n {{ (pastTypeCount$ | async)?.rows?.length ? range.controls.start.value.toLocaleString(DateTime.DATE_SHORT) : 'no past data' }}\n </th>\n <td class=\"past-data-cell\" mat-cell *matCellDef=\"let row;\" >\n <ng-container *ngIf=\"(pastTypeCount$ | async)?.rows?.length && pastTypeCount(row, col.id) as trend\">\n <span [class]=\"trend.trend\"> {{ trend.value ?? '\u2013' }}\n <mat-icon *ngIf=\"trend.value\" aria-hidden=\"false\" [attr.aria-label]=\"trend.trend\" [fontIcon]=\"trend.trend!\" /></span>\n <span class=\"cdk-visually-hidden\">{{ trend.trend }}</span>\n </ng-container>\n </td>\n </ng-container>\n <!-- generate actual table -->\n <tr mat-header-row *matHeaderRowDef=\"['label-col'].concat(typeColumns()); sticky:true;\"></tr>\n <tr [hidden]=\"!isHistoryEnabled()\" mat-header-row *matHeaderRowDef=\"allColumns(); sticky: true;\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: ['label-col'].concat(allColumns())\"></tr>\n\n </table>\n</mat-card>\n", styles: [".while-loading{filter:blur(2px)}tr:nth-child(2n){background-color:#e4e4e4}tr:nth-child(2n)>td.label-col,tr:nth-child(2n) td.recent-data-cell{border-right:1px solid white}tr:nth-child(odd){background-color:#fff}tr:nth-child(odd)>td.label-col,tr:nth-child(odd) td.recent-data-cell{border-right:1px solid #e4e4e4}td.label-col{text-align:left}.mat-mdc-header-cell,.mat-mdc-cell{text-align:center}.mat-mdc-header-cell a[href],.mat-mdc-cell a[href]{color:var(--mat-table-row-item-label-text-color);cursor:pointer;text-decoration:underline}.mat-mdc-header-cell a[href]:hover,.mat-mdc-cell a[href]:hover{text-decoration:underline}.mat-mdc-header-cell mat-icon,.mat-mdc-cell mat-icon{margin-left:5px;vertical-align:middle}.trending_down{color:#4abeff}.trending_up{color:#c20808}.actionbar{display:flex;flex-direction:row;justify-content:flex-start;align-items:center;gap:.5rem}\n"] }]
174
174
  }], ctorParameters: () => [{ type: i1.MetaApiService }, { type: i0.DestroyRef }, { type: i2.EditorialLinkService }], propDecorators: { apiMethod: [{
175
175
  type: Input,
176
176
  args: [{ required: true }]
@@ -182,4 +182,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
182
182
  type: Input,
183
183
  args: [{ required: true }]
184
184
  }] } });
185
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"counts-with-history.component.js","sourceRoot":"","sources":["../../../../../projects/ng-meta-widgets-lib/src/lib/counts-with-history/counts-with-history.component.ts","../../../../../projects/ng-meta-widgets-lib/src/lib/counts-with-history/counts-with-history.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, DestroyRef, effect, Input, OnInit, signal } from '@angular/core';\nimport { MatCard, MatCardContent, MatCardHeader, MatCardModule, MatCardTitle } from '@angular/material/card';\nimport { MatTooltip } from '@angular/material/tooltip';\nimport { MatHeaderRow, MatHeaderRowDef, MatRow, MatRowDef, MatTable, MatTableModule } from '@angular/material/table';\nimport { BehaviorSubject, Observable, zip } from 'rxjs';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { AsyncPipe, NgForOf, NgIf } from '@angular/common';\nimport { MetaApiService } from '../meta-api.service';\nimport { Filter, MatrixRowWithCounts, MatrixWithCounts, QualityMatrixHeader } from '../java-api';\nimport { DateTime } from 'luxon';\nimport { filter, finalize, map, skipWhile, switchMap, take, tap } from 'rxjs/operators';\nimport { FormControl, FormGroup, FormsModule } from '@angular/forms';\nimport { DatepickerComponent } from '../components/filter/datepicker/datepicker.component';\nimport { MatIcon } from '@angular/material/icon';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { MatSlideToggle } from '@angular/material/slide-toggle';\nimport { ProgressSpinnerComponent } from '../components/loading_indicator/progress-spinner/progress-spinner.component';\nimport { EditorialLinkService } from '../components/editorial-link-service/editorial-link.service';\n\ntype PickKeysByPropertyType<TObject extends object, TPropertyType> = {\n  [TKey in keyof TObject]: TObject[TKey] extends TPropertyType ? TKey : never;\n}[keyof TObject];\n\n@Component({\n  selector: 'metaqs2-counts-with-history',\n  standalone: true,\n  imports: [\n    MatCardModule,\n    MatCard,\n    MatCardHeader,\n    MatCardTitle,\n    MatCardContent,\n    MatTooltip,\n    MatTableModule,\n    MatTable,\n    TranslateModule,\n    MatHeaderRow,\n    MatHeaderRowDef,\n    MatRow,\n    MatRowDef,\n    NgForOf,\n    DatepickerComponent,\n    MatIcon,\n    NgIf,\n    FormsModule,\n    MatSlideToggle,\n    AsyncPipe,\n    ProgressSpinnerComponent,\n  ],\n  templateUrl: './counts-with-history.component.html',\n  styleUrl: './counts-with-history.component.scss',\n})\nexport class CountsWithHistoryComponent implements OnInit {\n  protected readonly loadingCount = signal(0);\n  protected readonly isLoading = computed(() => this.loadingCount() > 0);\n  protected readonly timeFilterLoaded = signal(false);\n  protected readonly recentTypeCount$ = new BehaviorSubject<MatrixWithCounts>({ columns: [], rows: [] });\n  protected readonly pastTypeCount$ = new BehaviorSubject<MatrixWithCounts>({ columns: [], rows: [] });\n  protected readonly DateTime = DateTime;\n  public columns = signal([] as Array<QualityMatrixHeader>);\n\n  @Input({ required: true })\n  apiMethod: PickKeysByPropertyType<MetaApiService, (it: Array<Filter>) => Observable<MatrixWithCounts>> =\n    'getMaterialTypeCountsByReplicationSource';\n  @Input()\n  columnTranslationkey: string | null = null;\n  @Input()\n  pageTitle: string;\n  @Input({ required: true })\n  sourceType: 'replicationSource' | 'collection';\n\n  /* In this widget's backend we do have data for today\n   * therefore we set the end date to today and use the timerange() endpoint to only set the start date\n   */\n  readonly range: FormGroup<{\n    start: FormControl<DateTime<boolean>>;\n    end: FormControl<DateTime<boolean>>;\n  }> = new FormGroup({\n    start: new FormControl(),\n    end: new FormControl(DateTime.utc().startOf('day'), { nonNullable: true }),\n  });\n  readonly isHistoryEnabled = signal<boolean>(false);\n\n  readonly allColumns = computed<Array<string>>(() => {\n    if (!this.isHistoryEnabled()) {\n      return this.recentColumns();\n    }\n    return this.pastColumns().flatMap((e, i) => [e, this.recentColumns()[i]]);\n  });\n\n  readonly typeColumns = computed(() => {\n    return this.columns().map((c) => c.id + '_type');\n  });\n\n  readonly recentColumns = computed(() => {\n    return this.columns().map((c) => c.id + '_recent');\n  });\n\n  readonly pastColumns = computed(() => {\n    return this.columns().map((c) => c.id + '_past');\n  });\n\n  constructor(\n    protected readonly metaApi: MetaApiService,\n    protected readonly destroyRef: DestroyRef,\n    private readonly linkService: EditorialLinkService\n  ) {\n    effect(() => {\n      this.range.controls.end.reset();\n      if (!this.isHistoryEnabled()) {\n        this.range.controls.start.setValue(this.range.controls.end.value.startOf('day'));\n      } else {\n        this.range.controls.start.reset();\n      }\n    });\n  }\n\n  ngOnInit(): void {\n    this.getAvailableDateRange()\n      .pipe(\n        tap((rangeFilter) => {\n          const startDate = this.getStartDateOfRange(rangeFilter);\n          //this is to have a default value for the start date => the min date of the range\n          this.range.setControl('start', new FormControl<DateTime<true>>(startDate, { nonNullable: true }));\n        }),\n        finalize(() => {\n          this.timeFilterLoaded.set(true);\n          this.range.controls.start.reset();\n        }),\n        takeUntilDestroyed(this.destroyRef)\n      )\n      .subscribe();\n    this.getCountByDate(this.range.controls.end.value)\n      .pipe(\n        tap((response) => {\n          this.columns.set(response.columns.slice());\n          this.recentTypeCount$.next(response);\n        }),\n        takeUntilDestroyed(this.destroyRef)\n      )\n      .subscribe();\n    this.getValuesInDateRange()\n      .pipe(\n        tap(([past, recent]) => {\n          this.pastTypeCount$.next(past);\n          this.recentTypeCount$.next(recent);\n        }),\n        takeUntilDestroyed(this.destroyRef)\n      )\n      .subscribe();\n  }\n\n  private getStartDateOfRange(rangeFilter: Filter) {\n    return DateTime.fromISO(rangeFilter.values.find((v) => v.id === 'rangeStart')?.label!, {\n      zone: 'utc',\n    }).startOf('day') as DateTime<true>;\n  }\n\n  columnIdent(_index: number, col: QualityMatrixHeader) {\n    return col.id;\n  }\n\n  private getAvailableDateRange() {\n    this.loadingCount.update((it) => it + 1);\n    return this.metaApi.getTimerangeFilter().pipe(\n      filter((filter): filter is Filter => filter != null),\n      finalize(() => this.loadingCount.update((it) => it - 1))\n    );\n  }\n\n  private getValuesInDateRange() {\n    return this.range.valueChanges.pipe(\n      filter(\n        (range): range is { start: DateTime<true>; end: DateTime<true> } =>\n          !!range.start?.isValid && !!range.end?.isValid\n      ),\n      switchMap((range) => {\n        return zip(this.getCountByDate(range.start), this.getCountByDate(range.end));\n      })\n    );\n  }\n\n  private getCountByDate(date: DateTime): Observable<MatrixWithCounts> {\n    this.loadingCount.update((it) => it + 1);\n    const filter: Filter = {\n      field: 'asOf',\n      values: [{ id: date.toISO({ includeOffset: false })!, label: '' }],\n    };\n    return this.metaApi[this.apiMethod]([filter]).pipe(\n      finalize(() => this.loadingCount.update((it) => it - 1)),\n      map((response) => ({\n        ...response,\n        rows: response.rows.toSorted((a, b) => a.meta.label.localeCompare(b.meta.label)),\n      }))\n    );\n  }\n\n  protected pastTypeCount(\n    row: MatrixRowWithCounts,\n    columnid: string\n  ): { delta?: number; trend?: string; value?: number } {\n    if (!this.pastTypeCount$.value.rows.length) {\n      return {};\n    }\n    const past_row = this.pastTypeCount$.value.rows.find((pr) => pr.meta.id == row.meta.id);\n    const past_column = this.pastTypeCount$.value.columns.find((c) => c.id == columnid);\n    if (!past_row || !past_column) {\n      return {};\n    }\n\n    const currentValue = row.counts[columnid];\n    const pastValue = past_row.counts[columnid];\n\n    const delta = (currentValue || 0) - (pastValue || 0);\n    const trend = delta === 0 ? 'trending_flat' : delta < 0 ? 'trending_down' : 'trending_up';\n    return { delta, trend, value: pastValue };\n  }\n\n  protected openInEditor(sourceId: string, issueId: string) {\n    if (this.sourceType === 'replicationSource') {\n      // find the long name for the source\n      sourceId = this.recentTypeCount$.value.rows.find((r) => r.meta.id === sourceId)?.meta.label || sourceId;\n    }\n    return this.linkService.typesLoaded$.pipe(\n      skipWhile((loaded) => !loaded),\n      take(1),\n      map(() => {\n        return this.linkService.createLinkForCountsWithHistory(this.sourceType, sourceId, issueId);\n      })\n    );\n  }\n}\n","<mat-card appearance=\"raised\">\n  <mat-card-header *ngIf=\"pageTitle\">\n    <mat-card-title data-test-id=\"page-title\">\n      Qualitätsmetrik: {{ pageTitle | translate }}{{ isLoading() ? \": Lade neue Daten.\" : \"\" }}\n    </mat-card-title>\n  </mat-card-header>\n  <!-- consider to put the filter in the table header to avoid that it is scrolled out of view-->\n  <!-- show the filter after the values are loaded to avoid loading current data twice -->\n  <mat-card-content class=\"toolbar\">\n    <metaqs2-datepicker [disabled]=\"isLoading() || !isHistoryEnabled()\" [inputGroup]=\"range\" *ngIf=\"timeFilterLoaded() && isHistoryEnabled()\"></metaqs2-datepicker>\n    <div style=\"flex: 1 1 auto\"></div>\n    <mat-slide-toggle [ngModel]=\"isHistoryEnabled()\" (ngModelChange)=\"isHistoryEnabled.set($event)\" [disabled]=\"isLoading()\" *ngIf=\"timeFilterLoaded()\">\n      <label>Zeige historische Daten</label>\n    </mat-slide-toggle>\n  </mat-card-content>\n</mat-card>\n<mat-card>\n  <metaqs2-progress-spinner [displayProgressSpinner]=\"isLoading()\"></metaqs2-progress-spinner>\n  <table [class.while-loading]=\"isLoading()\" mat-table [dataSource]=\"recentTypeCount$.value.rows\"\n         class=\"quality-matrix\">\n    <!-- Define columns of table -->\n    <!-- Row Header Column -->\n    <ng-container matColumnDef=\"label-col\" sticky>\n      <th [attr.rowspan]=\"isHistoryEnabled() ? '2' : '1'\" mat-header-cell *matHeaderCellDef>\n        <div>Quelle</div>\n      </th>\n      <td\n        mat-cell\n        *matCellDef=\"let row\"\n        [matTooltip]=\"row.meta.alt_label\"\n        class=\"label-col\"\n      >\n        {{ row.meta.label }}\n      </td>\n    </ng-container>\n    <!-- one column for each type -->\n    <ng-container *ngFor=\"let col of (recentTypeCount$ | async)?.columns; trackBy:columnIdent\"\n                  [matColumnDef]=\"col.id + '_type'\">\n      <th [attr.colspan]=\"isHistoryEnabled() ? '2' : '1'\" mat-header-cell *matHeaderCellDef [matTooltip]=\"col.label\">\n        {{ columnTranslationkey ? (columnTranslationkey + col.label | translate) : col.label }}\n      </th>\n    </ng-container>\n    <!-- one column for each type for the most current date-->\n    <ng-container *ngFor=\"let col of (recentTypeCount$ | async)?.columns; trackBy:columnIdent\"\n                  [matColumnDef]=\"col.id + '_recent'\">\n      <th class=\"recent-data-cell\" mat-header-cell *matHeaderCellDef\n          matTooltip=\"no tooltip\">{{ range.controls.end.value.toLocaleString(DateTime.DATE_SHORT) }}\n      </th>\n      <td class=\"recent-data-cell\" mat-cell *matCellDef=\"let row\">\n        <a [attr.href]=\"openInEditor(row.meta.id, col.id) | async\" target=\"editor_frontend\">{{ row.counts[col.id] ?? '–' }}</a>\n      </td>\n    </ng-container>\n    <!-- one column for each type for the older date-->\n    <ng-container *ngFor=\"let col of (recentTypeCount$ | async)?.columns; trackBy:columnIdent\"\n                  [matColumnDef]=\"col.id + '_past'\">\n      <th class=\"past-data-cell\" mat-header-cell *matHeaderCellDef matTooltip=\"no tooltip\">\n        {{ (pastTypeCount$ | async)?.rows?.length ? range.controls.start.value.toLocaleString(DateTime.DATE_SHORT) : 'no past data' }}\n      </th>\n      <td class=\"past-data-cell\" mat-cell *matCellDef=\"let row;\" >\n        <ng-container *ngIf=\"(pastTypeCount$ | async)?.rows?.length && pastTypeCount(row, col.id) as trend\">\n          <span [class]=\"trend.trend\"> {{ trend.value ?? '–' }}\n            <mat-icon *ngIf=\"trend.value\" aria-hidden=\"false\" [attr.aria-label]=\"trend.trend\" [fontIcon]=\"trend.trend!\" /></span>\n          <span class=\"cdk-visually-hidden\">{{ trend.trend }}</span>\n        </ng-container>\n      </td>\n    </ng-container>\n    <!-- generate actual table -->\n    <tr mat-header-row *matHeaderRowDef=\"['label-col'].concat(typeColumns()); sticky:true;\"></tr>\n    <tr [hidden]=\"!isHistoryEnabled()\" mat-header-row *matHeaderRowDef=\"allColumns(); sticky: true;\"></tr>\n    <tr mat-row *matRowDef=\"let row; columns: ['label-col'].concat(allColumns())\"></tr>\n\n  </table>\n</mat-card>\n"]}
185
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"counts-with-history.component.js","sourceRoot":"","sources":["../../../../../projects/ng-meta-widgets-lib/src/lib/counts-with-history/counts-with-history.component.ts","../../../../../projects/ng-meta-widgets-lib/src/lib/counts-with-history/counts-with-history.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, DestroyRef, effect, Input, OnInit, signal } from '@angular/core';\nimport { MatCard, MatCardContent, MatCardHeader, MatCardModule, MatCardTitle } from '@angular/material/card';\nimport { MatTooltip } from '@angular/material/tooltip';\nimport { MatHeaderRow, MatHeaderRowDef, MatRow, MatRowDef, MatTable, MatTableModule } from '@angular/material/table';\nimport { BehaviorSubject, Observable, zip } from 'rxjs';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { AsyncPipe, NgForOf, NgIf } from '@angular/common';\nimport { MetaApiService } from '../meta-api.service';\nimport { Filter, MatrixRowWithCounts, MatrixWithCounts, QualityMatrixHeader } from '../java-api';\nimport { DateTime } from 'luxon';\nimport { filter, finalize, map, skipWhile, switchMap, take, tap } from 'rxjs/operators';\nimport { FormControl, FormGroup, FormsModule } from '@angular/forms';\nimport { DatepickerComponent } from '../components/filter/datepicker/datepicker.component';\nimport { MatIcon } from '@angular/material/icon';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { MatSlideToggle } from '@angular/material/slide-toggle';\nimport { ProgressSpinnerComponent } from '../components/loading_indicator/progress-spinner/progress-spinner.component';\nimport { EditorialLinkService } from '../components/editorial-link-service/editorial-link.service';\n\nexport type MethodType =\n  | ((it: Filter[]) => Observable<MatrixWithCounts>)\n  | ((x: string, it: Filter[]) => Observable<MatrixWithCounts>);\n\nexport type PickKeysByPropertyType<TObject extends object, TPropertyType> = {\n  [TKey in keyof TObject]: TObject[TKey] extends TPropertyType ? TKey : never;\n}[keyof TObject];\n\n@Component({\n  selector: 'metaqs2-counts-with-history',\n  standalone: true,\n  imports: [\n    MatCardModule,\n    MatCard,\n    MatCardHeader,\n    MatCardTitle,\n    MatCardContent,\n    MatTooltip,\n    MatTableModule,\n    MatTable,\n    TranslateModule,\n    MatHeaderRow,\n    MatHeaderRowDef,\n    MatRow,\n    MatRowDef,\n    NgForOf,\n    DatepickerComponent,\n    MatIcon,\n    NgIf,\n    FormsModule,\n    MatSlideToggle,\n    AsyncPipe,\n    ProgressSpinnerComponent,\n  ],\n  templateUrl: './counts-with-history.component.html',\n  styleUrl: './counts-with-history.component.scss',\n})\nexport class CountsWithHistoryComponent implements OnInit {\n  protected readonly loadingCount = signal(0);\n  protected readonly isLoading = computed(() => this.loadingCount() > 0);\n  protected readonly timeFilterLoaded = signal(false);\n  protected readonly recentTypeCount$ = new BehaviorSubject<MatrixWithCounts>({ columns: [], rows: [] });\n  protected readonly pastTypeCount$ = new BehaviorSubject<MatrixWithCounts>({ columns: [], rows: [] });\n  protected readonly DateTime = DateTime;\n  public columns = signal([] as Array<QualityMatrixHeader>);\n\n  @Input({ required: true })\n  apiMethod: PickKeysByPropertyType<MetaApiService, MethodType> = 'getMaterialTypeCountsByReplicationSource';\n\n  @Input()\n  columnTranslationkey: string | null = null;\n  @Input()\n  pageTitle: string;\n  @Input({ required: true })\n  sourceType: 'replicationSource' | 'collection';\n\n  /* In this widget's backend we do have data for today\n   * therefore we set the end date to today and use the timerange() endpoint to only set the start date\n   */\n  readonly range: FormGroup<{\n    start: FormControl<DateTime<boolean>>;\n    end: FormControl<DateTime<boolean>>;\n  }> = new FormGroup({\n    start: new FormControl(),\n    end: new FormControl(DateTime.utc().startOf('day'), { nonNullable: true }),\n  });\n  readonly isHistoryEnabled = signal<boolean>(false);\n\n  readonly allColumns = computed<Array<string>>(() => {\n    if (!this.isHistoryEnabled()) {\n      return this.recentColumns();\n    }\n    return this.pastColumns().flatMap((e, i) => [e, this.recentColumns()[i]]);\n  });\n\n  readonly typeColumns = computed(() => {\n    return this.columns().map((c) => c.id + '_type');\n  });\n\n  readonly recentColumns = computed(() => {\n    return this.columns().map((c) => c.id + '_recent');\n  });\n\n  readonly pastColumns = computed(() => {\n    return this.columns().map((c) => c.id + '_past');\n  });\n\n  constructor(\n    protected readonly metaApi: MetaApiService,\n    protected readonly destroyRef: DestroyRef,\n    private readonly linkService: EditorialLinkService\n  ) {\n    effect(() => {\n      this.range.controls.end.reset();\n      if (!this.isHistoryEnabled()) {\n        this.range.controls.start.setValue(this.range.controls.end.value.startOf('day'));\n      } else {\n        this.range.controls.start.reset();\n      }\n    });\n  }\n\n  ngOnInit(): void {\n    this.getAvailableDateRange()\n      .pipe(\n        tap((rangeFilter) => {\n          const startDate = this.getStartDateOfRange(rangeFilter);\n          //this is to have a default value for the start date => the min date of the range\n          this.range.setControl('start', new FormControl<DateTime<true>>(startDate, { nonNullable: true }));\n        }),\n        finalize(() => {\n          this.timeFilterLoaded.set(true);\n          this.range.controls.start.reset();\n        }),\n        takeUntilDestroyed(this.destroyRef)\n      )\n      .subscribe();\n    this.getCountByDate(this.range.controls.end.value)\n      .pipe(\n        tap((response) => {\n          this.columns.set(response.columns.slice());\n          this.recentTypeCount$.next(response);\n        }),\n        takeUntilDestroyed(this.destroyRef)\n      )\n      .subscribe();\n    this.getValuesInDateRange()\n      .pipe(\n        tap(([past, recent]) => {\n          this.pastTypeCount$.next(past);\n          this.recentTypeCount$.next(recent);\n        }),\n        takeUntilDestroyed(this.destroyRef)\n      )\n      .subscribe();\n  }\n\n  private getStartDateOfRange(rangeFilter: Filter) {\n    return DateTime.fromISO(rangeFilter.values.find((v) => v.id === 'rangeStart')?.label!, {\n      zone: 'utc',\n    }).startOf('day') as DateTime<true>;\n  }\n\n  columnIdent(_index: number, col: QualityMatrixHeader) {\n    return col.id;\n  }\n\n  private getAvailableDateRange() {\n    this.loadingCount.update((it) => it + 1);\n    return this.metaApi.getTimerangeFilter().pipe(\n      filter((filter): filter is Filter => filter != null),\n      finalize(() => this.loadingCount.update((it) => it - 1))\n    );\n  }\n\n  protected getValuesInDateRange() {\n    return this.range.valueChanges.pipe(\n      filter(\n        (range): range is { start: DateTime<true>; end: DateTime<true> } =>\n          !!range.start?.isValid && !!range.end?.isValid\n      ),\n      switchMap((range) => {\n        return zip(this.getCountByDate(range.start), this.getCountByDate(range.end));\n      })\n    );\n  }\n\n  protected getCountByDate(date: DateTime): Observable<MatrixWithCounts> {\n    this.loadingCount.update((it) => it + 1);\n    const filter: Filter = {\n      field: 'asOf',\n      values: [{ id: date.toISO({ includeOffset: false })!, label: '' }],\n    };\n\n    return (this.metaApi[this.apiMethod] as (filters: Filter[]) => Observable<MatrixWithCounts>)([filter]).pipe(\n      finalize(() => this.loadingCount.update((it) => it - 1)),\n      map((response) => ({\n        ...response,\n        rows: response.rows.toSorted((a, b) => a.meta.label.localeCompare(b.meta.label)),\n      }))\n    );\n  }\n\n  protected pastTypeCount(\n    row: MatrixRowWithCounts,\n    columnid: string\n  ): { delta?: number; trend?: string; value?: number } {\n    if (!this.pastTypeCount$.value.rows.length) {\n      return {};\n    }\n    const past_row = this.pastTypeCount$.value.rows.find((pr) => pr.meta.id == row.meta.id);\n    const past_column = this.pastTypeCount$.value.columns.find((c) => c.id == columnid);\n    if (!past_row || !past_column) {\n      return {};\n    }\n\n    const currentValue = row.counts[columnid];\n    const pastValue = past_row.counts[columnid];\n\n    const delta = (currentValue || 0) - (pastValue || 0);\n    const trend = delta === 0 ? 'trending_flat' : delta < 0 ? 'trending_down' : 'trending_up';\n    return { delta, trend, value: pastValue };\n  }\n\n  protected openInEditor(sourceId: string, issueId: string) {\n    if (this.sourceType === 'replicationSource') {\n      // find the long name for the source\n      sourceId = this.recentTypeCount$.value.rows.find((r) => r.meta.id === sourceId)?.meta.label || sourceId;\n    }\n    return this.linkService.typesLoaded$.pipe(\n      skipWhile((loaded) => !loaded),\n      take(1),\n      map(() => {\n        return this.linkService.createLinkForCountsWithHistory(this.sourceType, sourceId, issueId);\n      })\n    );\n  }\n}\n","<mat-card appearance=\"raised\">\n  <mat-card-header *ngIf=\"pageTitle\">\n    <mat-card-title data-test-id=\"page-title\">\n      Qualitätsmetrik: {{ pageTitle | translate }}{{ isLoading() ? \": Lade neue Daten.\" : \"\" }}\n    </mat-card-title>\n  </mat-card-header>\n  <!-- consider to put the filter in the table header to avoid that it is scrolled out of view-->\n  <!-- show the filter after the values are loaded to avoid loading current data twice -->\n  <mat-card-content class=\"toolbar\">\n    <metaqs2-datepicker [disabled]=\"isLoading() || !isHistoryEnabled()\" [inputGroup]=\"range\" *ngIf=\"timeFilterLoaded() && isHistoryEnabled()\"></metaqs2-datepicker>\n    <div style=\"flex: 1 1 auto\"></div>\n    <mat-slide-toggle [ngModel]=\"isHistoryEnabled()\" (ngModelChange)=\"isHistoryEnabled.set($event)\" [disabled]=\"isLoading()\" *ngIf=\"timeFilterLoaded()\">\n      <label>Zeige historische Daten</label>\n    </mat-slide-toggle>\n  </mat-card-content>\n</mat-card>\n<mat-card>\n  <metaqs2-progress-spinner [displayProgressSpinner]=\"isLoading()\"></metaqs2-progress-spinner>\n  <table [class.while-loading]=\"isLoading()\" mat-table [dataSource]=\"recentTypeCount$.value.rows\"\n         class=\"quality-matrix\">\n    <!-- Define columns of table -->\n    <!-- Row Header Column -->\n    <ng-container matColumnDef=\"label-col\" sticky>\n      <th [attr.rowspan]=\"isHistoryEnabled() ? '2' : '1'\" mat-header-cell *matHeaderCellDef>\n        <div>Quelle</div>\n      </th>\n      <td\n        mat-cell\n        *matCellDef=\"let row\"\n        [matTooltip]=\"row.meta.alt_label\"\n        class=\"label-col mat-cell-level-{{row.meta.level + 1}}\"\n      >\n        {{ row.meta.label }}\n      </td>\n    </ng-container>\n    <!-- one column for each type -->\n    <ng-container *ngFor=\"let col of (recentTypeCount$ | async)?.columns; trackBy:columnIdent\"\n                  [matColumnDef]=\"col.id + '_type'\">\n      <th [attr.colspan]=\"isHistoryEnabled() ? '2' : '1'\" mat-header-cell *matHeaderCellDef [matTooltip]=\"col.label\">\n        {{ columnTranslationkey ? (columnTranslationkey + col.label | translate) : col.label }}\n      </th>\n    </ng-container>\n    <!-- one column for each type for the most current date-->\n    <ng-container *ngFor=\"let col of (recentTypeCount$ | async)?.columns; trackBy:columnIdent\"\n                  [matColumnDef]=\"col.id + '_recent'\">\n      <th class=\"recent-data-cell\" mat-header-cell *matHeaderCellDef\n          matTooltip=\"no tooltip\">{{ range.controls.end.value.toLocaleString(DateTime.DATE_SHORT) }}\n      </th>\n      <td class=\"recent-data-cell\" mat-cell *matCellDef=\"let row\">\n        <a [attr.href]=\"openInEditor(row.meta.id, col.id) | async\" target=\"editor_frontend\">{{ row.counts[col.id] ?? '–' }}</a>\n      </td>\n    </ng-container>\n    <!-- one column for each type for the older date-->\n    <ng-container *ngFor=\"let col of (recentTypeCount$ | async)?.columns; trackBy:columnIdent\"\n                  [matColumnDef]=\"col.id + '_past'\">\n      <th class=\"past-data-cell\" mat-header-cell *matHeaderCellDef matTooltip=\"no tooltip\">\n        {{ (pastTypeCount$ | async)?.rows?.length ? range.controls.start.value.toLocaleString(DateTime.DATE_SHORT) : 'no past data' }}\n      </th>\n      <td class=\"past-data-cell\" mat-cell *matCellDef=\"let row;\" >\n        <ng-container *ngIf=\"(pastTypeCount$ | async)?.rows?.length && pastTypeCount(row, col.id) as trend\">\n          <span [class]=\"trend.trend\"> {{ trend.value ?? '–' }}\n            <mat-icon *ngIf=\"trend.value\" aria-hidden=\"false\" [attr.aria-label]=\"trend.trend\" [fontIcon]=\"trend.trend!\" /></span>\n          <span class=\"cdk-visually-hidden\">{{ trend.trend }}</span>\n        </ng-container>\n      </td>\n    </ng-container>\n    <!-- generate actual table -->\n    <tr mat-header-row *matHeaderRowDef=\"['label-col'].concat(typeColumns()); sticky:true;\"></tr>\n    <tr [hidden]=\"!isHistoryEnabled()\" mat-header-row *matHeaderRowDef=\"allColumns(); sticky: true;\"></tr>\n    <tr mat-row *matRowDef=\"let row; columns: ['label-col'].concat(allColumns())\"></tr>\n\n  </table>\n</mat-card>\n"]}