UNPKG

@hmcts/media-viewer

Version:
131 lines 18.6 kB
import moment from 'moment-timezone'; /* @dynamic marking class as dynamic to stop compiler throwing error for lambda in static function see https://github.com/angular/angular/issues/19698#issuecomment-338340211 */ export class StoreUtils { static groupByKeyEntities(annotations, key) { return annotations.reduce((h, obj) => Object.assign(h, { [obj[key]]: (h[obj[key]] || []).concat(obj) }), {}); } static generateCommentsEntities(annotations) { return annotations.reduce((commentEntities, annotation) => { if (annotation.comments.length) { const comment = { ...annotation.comments[0] || '', tags: [...annotation.tags || []] }; return { ...commentEntities, [annotation.id]: comment }; } return { ...commentEntities }; }, {}); } static genTagNameEntities(annotations) { const filterAnnoWithoutCommentsTags = annotations.filter(a => (a.comments.length && a.tags.length)); const allTags = filterAnnoWithoutCommentsTags.map(anno => this.groupByKeyEntities(anno.tags, 'name')); const groupedByName = allTags.reduce((tagEntitiy, tagItem) => { return { ...tagEntitiy, ...tagItem }; }, {}); return this.genNameEnt(annotations, groupedByName); } static genNameEnt(annos, groupedByName) { return Object.keys(groupedByName).reduce((tagNameEnt, key) => { const readyAnno = annos.filter(anno => anno.tags.find(tag => tag.name === key)) .map(anno => anno.id) .reduce((obj, anno) => ({ ...obj, [anno]: anno }), {}); return { ...tagNameEnt, [key]: readyAnno }; }, {}); } static generateAnnotationEntities(anno) { return anno.reduce((annoEntities, annotation) => { const annot = { ...annotation, positionTop: annotation.rectangles[0].y // todo remove this }; return { ...annoEntities, [annotation.id]: annot }; }, {}); } static generateRedactionEntities(redactions) { return redactions.reduce((redactEntities, redaction) => { return { ...redactEntities, [redaction.redactionId]: redaction }; }, {}); } static resetCommentEntSelect(ent) { return Object.keys(ent).reduce((object, key) => { object[key] = { ...ent[key], editable: false, selected: false }; return object; }, {}); } static filterCommentsSummary(comments, filters) { if (Object.keys(filters).length) { const tagFilterApplied = Object.keys(filters.tagFilters) .filter(key => filters.tagFilters[key] === true).length; const dateFilterApplied = (filters.dateRangeFrom || filters.dateRangeTo); const filteredComments = comments.filter(comment => { let hasTagFilter = false; let hasDateFilter = false; // check tags if (filters.hasOwnProperty('tagFilters')) { Object.keys(filters.tagFilters).forEach(filter => { const label = filters.tagFilters[filter]; if (label) { return comment.tags.forEach(tag => { if (tag.name === filter && !hasTagFilter) { hasTagFilter = true; } }); } }); } // check for dates if (dateFilterApplied) { const commentDate = moment(comment.lastModifiedDate); const dateFrom = filters.dateRangeFrom !== null ? moment(filters.dateRangeFrom) : undefined; const dateTo = filters.dateRangeTo !== null ? moment(filters.dateRangeTo) : undefined; if (dateTo && dateFrom) { if (commentDate > dateFrom && commentDate < dateTo) { hasDateFilter = true; } } if (dateTo && !dateFrom) { if (commentDate <= dateTo) { hasDateFilter = true; } } if (dateFrom && !dateTo) { if (commentDate > dateFrom) { hasDateFilter = true; } } } return (hasTagFilter || hasDateFilter); }); return (tagFilterApplied || dateFilterApplied) ? filteredComments : comments; } else { return comments; } } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"store-utils.js","sourceRoot":"","sources":["../../../../../projects/media-viewer/src/lib/store/store-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { Annotation } from '../annotations/annotation-set/annotation-view/annotation.model';\nimport moment from 'moment-timezone';\nimport { Redaction } from '../redaction/services/redaction.model';\nimport { Filters } from './models/filters.interface';\nimport { Comment } from '../annotations/comment-set/comment/comment.model';\n\n/*\n  @dynamic\n  marking class as dynamic to stop compiler throwing error for lambda in static function\n  see https://github.com/angular/angular/issues/19698#issuecomment-338340211\n */\nexport class StoreUtils {\n\n  static groupByKeyEntities(annotations, key): {[id: string]: any[]} {\n    return annotations.reduce((h, obj) =>\n      Object.assign(h, { [obj[key]]: ( h[obj[key]] || [] ).concat(obj) }), {});\n  }\n\n  static generateCommentsEntities(annotations): {[id: string]: Comment} {\n     return annotations.reduce(\n      (commentEntities: { [id: string]: Annotation }, annotation: Annotation) => {\n        if (annotation.comments.length) {\n          const comment = {\n            ...annotation.comments[0] || '',\n            tags: [...annotation.tags || []]\n          };\n          return {\n            ...commentEntities,\n            [annotation.id]: comment\n          };\n        }\n        return {\n          ...commentEntities\n        };\n      }, {});\n  }\n\n  static genTagNameEntities(annotations) {\n    const filterAnnoWithoutCommentsTags = annotations.filter(a => (a.comments.length && a.tags.length));\n    const allTags = filterAnnoWithoutCommentsTags.map(anno => this.groupByKeyEntities(anno.tags, 'name'));\n    const groupedByName = allTags.reduce(\n      (tagEntitiy: { [id: string]: Annotation }, tagItem) => {\n        return {\n          ...tagEntitiy,\n          ...tagItem\n        };\n      }, {});\n\n    return this.genNameEnt(annotations, groupedByName);\n  }\n\n  static genNameEnt(annos, groupedByName) {\n     return Object.keys(groupedByName).reduce(\n      (tagNameEnt, key) => {\n        const readyAnno = annos.filter(anno => anno.tags.find(tag => tag.name === key))\n          .map(anno => anno.id)\n          .reduce((obj: {[id: string]: string}, anno: string) => ({ ...obj, [anno]: anno }), {});\n\n        return {\n          ...tagNameEnt,\n          [key]: readyAnno\n        };\n      }, {});\n\n  }\n\n  static generateAnnotationEntities(anno): {[id: string]: Annotation} {\n    return anno.reduce(\n      (annoEntities: { [id: string]: Annotation }, annotation: Annotation) => {\n        const annot = {\n          ...annotation,\n          positionTop: annotation.rectangles[0].y // todo remove this\n        };\n        return {\n          ...annoEntities,\n          [annotation.id]: annot\n        };\n      }, {});\n  }\n\n  static generateRedactionEntities(redactions: Redaction[]): { [id: string]: Redaction } {\n    return redactions.reduce(\n      (redactEntities: { [id: string]: Redaction }, redaction: Redaction) => {\n        return {\n          ...redactEntities,\n          [redaction.redactionId]: redaction\n        };\n      }, {});\n  }\n\n  static resetCommentEntSelect(ent: { [id: string]: Comment }) {\n    return Object.keys(ent).reduce((object, key) => {\n      object[key] = {\n        ...ent[key],\n        editable: false,\n        selected: false\n      };\n      return object;\n    }, {});\n  }\n\n  static filterCommentsSummary(comments: Array<Comment>, filters: Filters) {\n    if (Object.keys(filters).length) {\n      const tagFilterApplied = Object.keys(filters.tagFilters)\n        .filter(key => filters.tagFilters[key] === true).length;\n      const dateFilterApplied = (filters.dateRangeFrom || filters.dateRangeTo);\n      const filteredComments = comments.filter(comment => {\n        let hasTagFilter = false;\n        let hasDateFilter = false;\n        // check tags\n        if (filters.hasOwnProperty('tagFilters')) {\n          Object.keys(filters.tagFilters).forEach(filter => {\n            const label = filters.tagFilters[filter];\n            if (label) {\n              return comment.tags.forEach(tag => {\n                if (tag.name === filter && !hasTagFilter) {\n                  hasTagFilter = true;\n                }\n              });\n            }});\n        }\n        // check for dates\n        if (dateFilterApplied) {\n          const commentDate = moment(comment.lastModifiedDate);\n          const dateFrom =  filters.dateRangeFrom !== null ? moment(filters.dateRangeFrom) : undefined;\n          const dateTo = filters.dateRangeTo !== null ? moment(filters.dateRangeTo) : undefined;\n\n          if (dateTo && dateFrom) {\n            if (commentDate > dateFrom && commentDate < dateTo) {\n              hasDateFilter = true;\n            }\n          }\n          if (dateTo && !dateFrom) {\n            if (commentDate <= dateTo) {\n              hasDateFilter = true;\n            }\n          }\n          if (dateFrom && !dateTo) {\n            if (commentDate > dateFrom) {\n              hasDateFilter = true;\n            }\n          }\n        }\n\n        return (hasTagFilter || hasDateFilter);\n      });\n      return (tagFilterApplied || dateFilterApplied) ? filteredComments : comments;\n    } else {\n      return comments;\n    }\n  }\n}\n"]}