UNPKG

@hmcts/media-viewer

Version:
158 lines 21.3 kB
import * as fromActions from '../actions/document.actions'; export const initialDocumentState = { convertedDocument: undefined, documentId: undefined, pdfPosition: undefined, pages: {}, hasDifferentPageSize: false, rotation: undefined, rotationLoaded: false, loading: false, loaded: false }; export function docReducer(state = initialDocumentState, action) { switch (action.type) { case fromActions.CONVERT_SUCCESS: { const convertedDocument = { url: action.payload, error: undefined }; return { ...state, convertedDocument }; } case fromActions.CONVERT_FAIL: { const convertedDocument = { url: undefined, error: action.payload }; return { ...state, convertedDocument }; } case fromActions.CLEAR_CONVERT_DOC_URL: { const convertedDocument = undefined; return { ...state, convertedDocument }; } case fromActions.LOAD_ROTATION: { return { ...state, rotationLoaded: false }; } case fromActions.LOAD_ROTATION_SUCCESS: { const metadata = action.payload; const rotation = metadata ? metadata.rotationAngle : 0; return { ...state, rotation, rotationLoaded: true }; } case fromActions.LOAD_ROTATION_FAIL: { return { ...state, rotation: 0, rotationLoaded: true }; } case fromActions.SAVE_ROTATION_SUCCESS: { const metadata = action.payload; const rotation = metadata.rotationAngle; return { ...state, rotation }; } case fromActions.SET_DOCUMENT_ID: { return { ...state, documentId: action.payload }; } case fromActions.ADD_PAGES: { const payload = action.payload; let pages = {}; let pageHeight; let pageWidth; let hasDifferentPageSize = state.hasDifferentPageSize; const pageNumberInput = document.getElementById('pageNumber'); const pageIndex = pageNumberInput?.value ? parseInt(pageNumberInput.value, 10) - 1 : 0; const loadedPage = payload[pageIndex]?.div['attributes']?.style?.value ?? ''; payload.forEach(page => { const sizingValue = page.div?.['attributes']?.style?.value ?? ''; const widthMatch = sizingValue.match(/width:\s*round\(down,\s*var\(--scale-factor\)\s*\*\s*([\d.]+)([a-z%]+)?,.*var\(--scale-round-x, ([\d.]+)([a-z%]+)?\)\)/); const heightMatch = sizingValue.match(/height:\s*round\(down,\s*var\(--scale-factor\)\s*\*\s*([\d.]+)([a-z%]+)?,.*var\(--scale-round-y, ([\d.]+)([a-z%]+)?\)\)/); const scaleRoundXMatch = loadedPage.match(/--scale-round-x:\s*([\d.]+)([a-z%]+)?/); const scaleRoundYMatch = loadedPage.match(/--scale-round-y:\s*([\d.]+)([a-z%]+)?/); // You can now use widthUnit, heightUnit, scaleRoundXUnit, scaleRoundYUnit as needed const scaleFactor = page.viewportScale ?? 1; const scaleRoundX = scaleRoundXMatch ? parseFloat(scaleRoundXMatch[1]) : 1; const scaleRoundY = scaleRoundYMatch ? parseFloat(scaleRoundYMatch[1]) : 1; const baseWidth = widthMatch ? parseFloat(widthMatch[1]) : undefined; const baseHeight = heightMatch ? parseFloat(heightMatch[1]) : undefined; function roundDown(value, step) { return Math.floor(value / step) * step; } const computedWidth = baseWidth !== undefined ? roundDown(scaleFactor * baseWidth, scaleRoundX) : page.div['clientWidth']; const computedHeight = baseHeight !== undefined ? roundDown(scaleFactor * baseHeight, scaleRoundY) : page.div['clientHeight']; if (!hasDifferentPageSize && pageHeight && pageWidth && (pageHeight !== computedHeight || pageWidth !== computedWidth)) { hasDifferentPageSize = true; } else { pageHeight = computedHeight; pageWidth = computedWidth; } const styles = { left: page.div['offsetLeft'], height: computedHeight, width: computedWidth }; const scaleRotation = { scale: page.scale, rotation: page.rotation }; const p = { styles, scaleRotation, viewportScale: page.viewportScale }; pages = { ...pages, [page.id]: p }; }); return { ...state, pages, hasDifferentPageSize }; } case fromActions.POSITION_UPDATED: { const pdfPosition = action.payload; return { ...state, pdfPosition }; } } return state; } export const getDocPages = (state) => state.pages; export const getDocId = (state) => state.documentId; export const getPdfPos = (state) => state.pdfPosition; export const getHasDifferentPageSizes = (state) => state.hasDifferentPageSize; export const getRotation = (state) => state.rotation; export const rotationLoaded = (state) => state.rotationLoaded; export const getConvertedDocument = (state) => state.convertedDocument; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"document.reducer.js","sourceRoot":"","sources":["../../../../../../projects/media-viewer/src/lib/store/reducers/document.reducer.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fromActions from '../actions/document.actions';\n\nexport interface DocumentState {\n  convertedDocument: {\n    url: string;\n    error: string;\n  };\n  documentId: string;\n  pdfPosition: PdfPosition;\n  pages: {[id: string]: DocumentPages};\n  hasDifferentPageSize: boolean;\n  rotation: number;\n  rotationLoaded: boolean;\n  loaded: boolean;\n  loading: boolean;\n}\n\nexport interface DocumentPages {\n numberOfPages: number;\n styles: { left: number, height: number, width: number };\n scaleRotation: { scale: string; rotation: string };\n viewportScale: number;\n}\n\nexport interface PdfPosition {\n  pageNumber: number;\n  scale: number;\n  top: number;\n  left: number;\n  rotation: number;\n}\n\nexport const initialDocumentState: DocumentState = {\n  convertedDocument: undefined,\n  documentId: undefined,\n  pdfPosition: undefined,\n  pages: {},\n  hasDifferentPageSize: false,\n  rotation: undefined,\n  rotationLoaded: false,\n  loading: false,\n  loaded: false\n};\n\nexport function docReducer (state = initialDocumentState,\n                            action: fromActions.DocumentActions): DocumentState {\n\n  switch (action.type) {\n\n    case fromActions.CONVERT_SUCCESS: {\n      const convertedDocument = {\n        url: action.payload,\n        error: undefined\n      };\n      return {\n        ...state,\n        convertedDocument\n      };\n    }\n\n    case fromActions.CONVERT_FAIL: {\n      const convertedDocument = {\n        url: undefined,\n        error: action.payload\n      };\n      return {\n        ...state,\n        convertedDocument\n      };\n    }\n\n    case fromActions.CLEAR_CONVERT_DOC_URL: {\n      const convertedDocument = undefined;\n      return {\n        ...state,\n        convertedDocument\n      };\n    }\n\n    case fromActions.LOAD_ROTATION: {\n      return {\n        ...state,\n        rotationLoaded: false\n      };\n    }\n\n    case fromActions.LOAD_ROTATION_SUCCESS: {\n      const metadata = action.payload;\n      const rotation = metadata ? metadata.rotationAngle : 0;\n      return {\n        ...state,\n        rotation,\n        rotationLoaded: true\n      };\n    }\n\n    case fromActions.LOAD_ROTATION_FAIL: {\n      return {\n        ...state,\n        rotation: 0,\n        rotationLoaded: true\n      };\n    }\n\n    case fromActions.SAVE_ROTATION_SUCCESS: {\n      const metadata = action.payload;\n      const rotation = metadata.rotationAngle;\n      return {\n        ...state,\n        rotation\n      };\n    }\n\n    case fromActions.SET_DOCUMENT_ID : {\n      return {\n        ...state,\n        documentId: action.payload\n      };\n    }\n\n    case fromActions.ADD_PAGES: {\n      const payload = action.payload;\n      let pages = {};\n      let pageHeight;\n      let pageWidth;\n      let hasDifferentPageSize = state.hasDifferentPageSize;\n      const pageNumberInput = document.getElementById('pageNumber') as HTMLInputElement;\n      const pageIndex = pageNumberInput?.value ? parseInt(pageNumberInput.value, 10) - 1 : 0;\n      const loadedPage = payload[pageIndex]?.div['attributes']?.style?.value ?? '';\n      payload.forEach(page => {\n        const sizingValue = page.div?.['attributes']?.style?.value ?? '';\n        const widthMatch  = sizingValue.match(/width:\\s*round\\(down,\\s*var\\(--scale-factor\\)\\s*\\*\\s*([\\d.]+)([a-z%]+)?,.*var\\(--scale-round-x, ([\\d.]+)([a-z%]+)?\\)\\)/);\n        const heightMatch = sizingValue.match(/height:\\s*round\\(down,\\s*var\\(--scale-factor\\)\\s*\\*\\s*([\\d.]+)([a-z%]+)?,.*var\\(--scale-round-y, ([\\d.]+)([a-z%]+)?\\)\\)/);\n        const scaleRoundXMatch = loadedPage.match(/--scale-round-x:\\s*([\\d.]+)([a-z%]+)?/);\n        const scaleRoundYMatch = loadedPage.match(/--scale-round-y:\\s*([\\d.]+)([a-z%]+)?/);\n        // You can now use widthUnit, heightUnit, scaleRoundXUnit, scaleRoundYUnit as needed\n        const scaleFactor = page.viewportScale ?? 1;\n        const scaleRoundX = scaleRoundXMatch ? parseFloat(scaleRoundXMatch[1]) : 1;\n        const scaleRoundY = scaleRoundYMatch ? parseFloat(scaleRoundYMatch[1]) : 1;\n        const baseWidth = widthMatch ? parseFloat(widthMatch[1]) : undefined;\n        const baseHeight = heightMatch ? parseFloat(heightMatch[1]) : undefined;\n        function roundDown(value: number, step: number): number {\n          return Math.floor(value / step) * step;\n        }\n        const computedWidth = baseWidth !== undefined\n          ? roundDown(scaleFactor * baseWidth, scaleRoundX)\n          : page.div['clientWidth'];\n        const computedHeight = baseHeight !== undefined\n          ? roundDown(scaleFactor * baseHeight, scaleRoundY)\n          : page.div['clientHeight'];\n\n        if (!hasDifferentPageSize && pageHeight && pageWidth &&\n          (pageHeight !== computedHeight || pageWidth !== computedWidth)) {\n          hasDifferentPageSize = true;\n        } else {\n          pageHeight = computedHeight;\n          pageWidth = computedWidth;\n        }\n        const styles = {\n          left: page.div['offsetLeft'],\n          height: computedHeight,\n          width: computedWidth\n        };\n\n        const scaleRotation = {\n          scale: page.scale,\n          rotation: page.rotation\n        };\n\n        const p = {\n          styles,\n          scaleRotation,\n          viewportScale: page.viewportScale\n        };\n\n        pages = {\n          ...pages,\n          [page.id]: p\n        };\n\n      });\n      return {\n        ...state,\n        pages,\n        hasDifferentPageSize\n      };\n    }\n\n    case fromActions.POSITION_UPDATED: {\n      const pdfPosition = action.payload;\n      return {\n        ...state,\n        pdfPosition\n      };\n    }\n  }\n  return state;\n}\nexport const getDocPages = (state: DocumentState) => state.pages;\nexport const getDocId = (state: DocumentState) => state.documentId;\nexport const getPdfPos = (state: DocumentState) => state.pdfPosition;\nexport const getHasDifferentPageSizes = (state: DocumentState) => state.hasDifferentPageSize;\nexport const getRotation = (state: DocumentState) => state.rotation;\nexport const rotationLoaded = (state: DocumentState) => state.rotationLoaded;\nexport const getConvertedDocument = (state: DocumentState) => state.convertedDocument;\n"]}