@hmcts/media-viewer
Version:
158 lines • 21.3 kB
JavaScript
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"]}