retro-react
Version:
A React component library for building retro-style websites
10 lines • 256 kB
JavaScript
"use strict";var c=require("@emotion/styled/base"),X=require("@emotion/react"),l=require("../../utils/alterColor.js"),x=require("../../utils/getColorScheme.js"),H=require("../../constants/colors.js"),b=require("../../constants/fonts.js");function G(){return"You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."}const d=X.keyframes`
0%, 50% { opacity: 1; }
51%, 100% { opacity: 0; }
`,Z=X.keyframes`
0% { top: -2px; }
100% { top: 100%; }
`,V=X.keyframes`
0%, 98%, 100% { opacity: 1; }
99% { opacity: 0.98; }
`,J=c("label","production"===process.env.NODE_ENV?{target:"ezy0we120"}:{target:"ezy0we120",label:"DropzoneWrapper"})("position:relative;display:flex;align-items:center;justify-content:",(c=>c.$hasFile?"flex-start":"center"),";padding:16px;width:100%;max-width:100%;min-height:120px;box-sizing:border-box;background:",(c=>c.$isDragOver?H.WIN31_BUTTON_FACE:H.VGA_WHITE),";border:2px solid;border-color:",(c=>c.$isPressed?`${H.WIN31_BUTTON_HIGHLIGHT} ${H.WIN31_BUTTON_SHADOW} ${H.WIN31_BUTTON_SHADOW} ${H.WIN31_BUTTON_HIGHLIGHT}`:`${H.WIN31_BUTTON_SHADOW} ${H.WIN31_BUTTON_HIGHLIGHT} ${H.WIN31_BUTTON_HIGHLIGHT} ${H.WIN31_BUTTON_SHADOW}`),";box-shadow:",(c=>c.$isPressed?"none":"inset 1px 1px 2px rgba(0, 0, 0, 0.1)"),";color:",H.VGA_BLACK,";font-family:",b.SYSTEM_FONT,";font-size:",b.FONT_SIZES.NORMAL,";font-weight:normal;cursor:",(c=>c.$isUploading?"wait":"pointer"),";transition:none;outline:none;border-radius:0;@media (max-width: 768px){padding:12px;min-height:100px;}@media (max-width: 480px){padding:8px;min-height:80px;}&:focus{outline:1px dotted ",H.VGA_BLACK,";outline-offset:-3px;}&:hover:not(:disabled){background:",H.WIN31_BUTTON_FACE,";}&:disabled{background:",H.WIN31_BUTTON_FACE,";color:",H.WIN31_BUTTON_SHADOW,";cursor:not-allowed;border-color:",H.WIN31_BUTTON_SHADOW," ",H.WIN31_BUTTON_HIGHLIGHT," ",H.WIN31_BUTTON_HIGHLIGHT," ",H.WIN31_BUTTON_SHADOW,";}&::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(\n\t\t\t90deg,\n\t\t\ttransparent,\n\t\t\t",H.CRT_GREEN,"40,\n\t\t\ttransparent\n\t\t);animation:",Z," 2s linear infinite;opacity:",(c=>c.$isUploading?1:0),";transition:opacity 0.3s;}"+("production"===process.env.NODE_ENV?"":"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["DocumentUpload.styled.tsx"],"names":[],"mappings":"AAmB4C","file":"DocumentUpload.styled.tsx","sourcesContent":["import { keyframes } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { alterColorEnhanced } from \"../../utils/alterColor\";\r\nimport getColorScheme from \"../../utils/getColorScheme\";\r\nimport { CRT_GREEN, VGA_BLACK, VGA_WHITE, WIN31_BUTTON_FACE, WIN31_BUTTON_HIGHLIGHT, WIN31_BUTTON_SHADOW, } from \"../../constants/colors\";\r\nimport { FONT_SIZES, SYSTEM_FONT } from \"../../constants/fonts\";\r\n// Retro animations\r\nconst blink = keyframes `\r\n\t0%, 50% { opacity: 1; }\r\n\t51%, 100% { opacity: 0; }\r\n`;\r\nconst scanLine = keyframes `\r\n\t0% { top: -2px; }\r\n\t100% { top: 100%; }\r\n`;\r\nconst crtFlicker = keyframes `\r\n\t0%, 98%, 100% { opacity: 1; }\r\n\t99% { opacity: 0.98; }\r\n`;\r\nexport const DropzoneWrapper = styled.label `\r\n\tposition: relative;\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\tjustify-content: ${(props) => (props.$hasFile ? 'flex-start' : 'center')};\r\n\tpadding: 16px;\r\n\twidth: 100%;\r\n\tmax-width: 100%;\r\n\tmin-height: 120px;\r\n\tbox-sizing: border-box;\r\n\tbackground: ${(props) => (props.$isDragOver ? WIN31_BUTTON_FACE : VGA_WHITE)};\r\n\tborder: 2px solid;\r\n\tborder-color: ${(props) => props.$isPressed\r\n    ? `${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT}`\r\n    : `${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}`};\r\n\tbox-shadow: ${(props) => props.$isPressed ? 'none' : 'inset 1px 1px 2px rgba(0, 0, 0, 0.1)'};\r\n\tcolor: ${VGA_BLACK};\r\n\tfont-family: ${SYSTEM_FONT};\r\n\tfont-size: ${FONT_SIZES.NORMAL};\r\n\tfont-weight: normal;\r\n\tcursor: ${(props) => (props.$isUploading ? 'wait' : 'pointer')};\r\n\ttransition: none;\r\n\toutline: none;\r\n\r\n\t/* Remove modern styling */\r\n\tborder-radius: 0;\r\n\r\n\t/* Responsive adjustments */\r\n\t@media (max-width: 768px) {\r\n\t\tpadding: 12px;\r\n\t\tmin-height: 100px;\r\n\t}\r\n\r\n\t@media (max-width: 480px) {\r\n\t\tpadding: 8px;\r\n\t\tmin-height: 80px;\r\n\t}\r\n\r\n\t&:focus {\r\n\t\toutline: 1px dotted ${VGA_BLACK};\r\n\t\toutline-offset: -3px;\r\n\t}\r\n\r\n\t&:hover:not(:disabled) {\r\n\t\tbackground: ${WIN31_BUTTON_FACE};\r\n\t}\r\n\r\n\t&:disabled {\r\n\t\tbackground: ${WIN31_BUTTON_FACE};\r\n\t\tcolor: ${WIN31_BUTTON_SHADOW};\r\n\t\tcursor: not-allowed;\r\n\t\tborder-color: ${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT}\r\n\t\t\t${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW};\r\n\t}\r\n\r\n\t/* Add CRT scan line effect */\r\n\t&::after {\r\n\t\tcontent: '';\r\n\t\tposition: absolute;\r\n\t\ttop: 0;\r\n\t\tleft: 0;\r\n\t\tright: 0;\r\n\t\theight: 2px;\r\n\t\tbackground: linear-gradient(\r\n\t\t\t90deg,\r\n\t\t\ttransparent,\r\n\t\t\t${CRT_GREEN}40,\r\n\t\t\ttransparent\r\n\t\t);\r\n\t\tanimation: ${scanLine} 2s linear infinite;\r\n\t\topacity: ${(props) => (props.$isUploading ? 1 : 0)};\r\n\t\ttransition: opacity 0.3s;\r\n\t}\r\n`;\r\nexport const HiddenInput = styled.input `\r\n\tdisplay: none;\r\n`;\r\n// --- Initial State Styles ---\r\nexport const UploadPrompt = styled.div `\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\talign-items: center;\r\n\tgap: 0.75rem;\r\n\ttext-align: center;\r\n\tposition: relative;\r\n\tz-index: 1;\r\n`;\r\nexport const UploadIconWrapper = styled.div `\r\n\tcolor: ${(props) => {\r\n    const baseColor = getColorScheme(props.$color || 'primary', props.theme);\r\n    return alterColorEnhanced(baseColor, -30);\r\n}};\r\n\tfilter: drop-shadow(2px 2px 0px rgba(0, 0, 0, 0.3));\r\n\r\n\tsvg {\r\n\t\tanimation: ${crtFlicker} 4s infinite;\r\n\t}\r\n`;\r\nexport const UploadText = styled.p `\r\n\tmargin: 0;\r\n\tfont-weight: bold;\r\n\tcolor: ${VGA_BLACK};\r\n\ttext-shadow: 1px 1px 0px rgba(255, 255, 255, 0.8);\r\n\tfont-size: 1.1rem;\r\n\tfont-family: ${SYSTEM_FONT};\r\n`;\r\nexport const SubText = styled.p `\r\n\tmargin: 0;\r\n\tfont-size: 0.85rem;\r\n\tcolor: ${WIN31_BUTTON_SHADOW};\r\n\ttext-shadow: 1px 1px 0px rgba(255, 255, 255, 0.8);\r\n\tfont-family: ${SYSTEM_FONT};\r\n`;\r\nexport const BlinkingCursor = styled.span `\r\n\tfont-size: 1.5rem;\r\n\tanimation: ${blink} 1s infinite;\r\n\tcolor: ${VGA_BLACK};\r\n`;\r\n// --- Progress Bar Styles ---\r\nexport const ProgressWrapper = styled.div `\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\talign-items: center;\r\n\tgap: 0.5rem;\r\n\tfont-family: ${SYSTEM_FONT};\r\n\tcolor: ${VGA_BLACK};\r\n`;\r\nexport const ProgressText = styled.div `\r\n\tfont-size: 0.9rem;\r\n\tfont-weight: bold;\r\n\tletter-spacing: 1px;\r\n\tfont-family: ${SYSTEM_FONT};\r\n`;\r\nexport const ProgressBar = styled.div `\r\n\tfont-family: ${SYSTEM_FONT};\r\n\tfont-size: 0.8rem;\r\n\tletter-spacing: 1px;\r\n\tcolor: ${VGA_BLACK};\r\n\ttext-shadow: 1px 1px 0px rgba(255, 255, 255, 0.5);\r\n`;\r\n// --- File Selected State Styles ---\r\nexport const FileSelectedWrapper = styled.div `\r\n\tdisplay: flex;\r\n\talign-items: flex-start;\r\n\tgap: 1rem;\r\n\twidth: 100%;\r\n\tmax-width: 100%;\r\n\tcolor: ${VGA_BLACK};\r\n\tposition: relative;\r\n\tz-index: 1;\r\n\tbox-sizing: border-box;\r\n\toverflow: hidden;\r\n\r\n\t@media (max-width: 768px) {\r\n\t\tgap: 0.75rem;\r\n\t}\r\n\r\n\t@media (max-width: 480px) {\r\n\t\tgap: 0.5rem;\r\n\t}\r\n\r\n\tsvg {\r\n\t\tflex-shrink: 0;\r\n\t\tfilter: drop-shadow(1px 1px 0px rgba(0, 0, 0, 0.3));\r\n\t}\r\n`;\r\nexport const FileInfo = styled.div `\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\tgap: 0.25rem;\r\n\tmin-width: 0;\r\n\tflex-grow: 1;\r\n\tflex-shrink: 1;\r\n\toverflow: hidden;\r\n`;\r\nexport const FileHeader = styled.div `\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\tgap: 0.5rem;\r\n\tmargin-bottom: 0.25rem;\r\n`;\r\nexport const FileType = styled.span `\r\n\tfont-size: 0.7rem;\r\n\tcolor: ${(props) => {\r\n    const baseColor = getColorScheme(props.$color || 'primary', props.theme);\r\n    return alterColorEnhanced(baseColor, -40);\r\n}};\r\n\tfont-weight: bold;\r\n\tbackground: ${VGA_WHITE};\r\n\tpadding: 2px 4px;\r\n\tborder: 1px solid ${WIN31_BUTTON_SHADOW};\r\n\tfont-family: ${SYSTEM_FONT};\r\n`;\r\nexport const FileStatus = styled.span `\r\n\tfont-size: 0.7rem;\r\n\tcolor: ${CRT_GREEN};\r\n\tfont-weight: bold;\r\n\tfont-family: ${SYSTEM_FONT};\r\n`;\r\nexport const FileName = styled.span `\r\n\twhite-space: nowrap;\r\n\toverflow: hidden;\r\n\ttext-overflow: ellipsis;\r\n\tfont-weight: bold;\r\n\tfont-size: 1rem;\r\n\ttext-shadow: 1px 1px 0px rgba(255, 255, 255, 0.8);\r\n\tfont-family: ${SYSTEM_FONT};\r\n`;\r\nexport const FileSize = styled.span `\r\n\tfont-size: 0.8rem;\r\n\tcolor: ${WIN31_BUTTON_SHADOW};\r\n\tfont-weight: bold;\r\n\ttext-shadow: 1px 1px 0px rgba(255, 255, 255, 0.8);\r\n\tfont-family: ${SYSTEM_FONT};\r\n`;\r\nexport const FileDate = styled.span `\r\n\tfont-size: 0.75rem;\r\n\tcolor: ${WIN31_BUTTON_SHADOW};\r\n\tfont-family: ${SYSTEM_FONT};\r\n`;\r\nexport const RemoveButton = styled.button `\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\tjustify-content: center;\r\n\twidth: 3rem;\r\n\theight: 2rem;\r\n\tflex-shrink: 0;\r\n\tmargin-left: auto;\r\n\tpadding: 0;\r\n\tborder: 2px solid;\r\n\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\tbackground: ${WIN31_BUTTON_FACE};\r\n\tcolor: ${VGA_BLACK};\r\n\tfont-size: 0.75rem;\r\n\tfont-weight: bold;\r\n\tfont-family: ${SYSTEM_FONT};\r\n\ttext-shadow: 1px 1px 0px rgba(255, 255, 255, 0.8);\r\n\tcursor: pointer;\r\n\ttransition: none;\r\n\ttext-transform: uppercase;\r\n\tletter-spacing: 1px;\r\n\r\n\t@media (max-width: 480px) {\r\n\t\twidth: 2.5rem;\r\n\t\theight: 1.8rem;\r\n\t\tfont-size: 0.7rem;\r\n\t}\r\n\r\n\t&:hover:not(:disabled) {\r\n\t\tbackground: ${(props) => getColorScheme('error', props.theme)};\r\n\t\tcolor: ${VGA_WHITE};\r\n\t\ttext-shadow: 1px 1px 0px rgba(0, 0, 0, 0.5);\r\n\t}\r\n\r\n\t&:active:not(:disabled) {\r\n\t\tborder-color: ${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT}\r\n\t\t\t${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW};\r\n\t}\r\n\r\n\t&:focus-visible {\r\n\t\toutline: 1px dotted ${VGA_BLACK};\r\n\t\toutline-offset: -3px;\r\n\t}\r\n`;\r\nexport const ButtonLabel = styled.span `\r\n\tposition: relative;\r\n\ttop: -1px;\r\n`;\r\nexport const ScanLine = styled.div `\r\n\tposition: absolute;\r\n\ttop: 0;\r\n\tleft: 0;\r\n\tright: 0;\r\n\tbottom: 0;\r\n\tbackground: linear-gradient(90deg, transparent, ${CRT_GREEN}40, transparent);\r\n\theight: 2px;\r\n\tanimation: ${scanLine} 2s linear infinite;\r\n\tpointer-events: none;\r\n\tz-index: 1;\r\n`;\r\n//# sourceMappingURL=DocumentUpload.styled.js.map"]} */")),R=c("input","production"===process.env.NODE_ENV?{target:"ezy0we119"}:{target:"ezy0we119",label:"HiddenInput"})("production"===process.env.NODE_ENV?{name:"eivff4",styles:"display:none"}:{name:"eivff4",styles:"display:none",map:"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["DocumentUpload.styled.tsx"],"names":[],"mappings":"AA6FwC","file":"DocumentUpload.styled.tsx","sourcesContent":["import { keyframes } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { alterColorEnhanced } from \"../../utils/alterColor\";\r\nimport getColorScheme from \"../../utils/getColorScheme\";\r\nimport { CRT_GREEN, VGA_BLACK, VGA_WHITE, WIN31_BUTTON_FACE, WIN31_BUTTON_HIGHLIGHT, WIN31_BUTTON_SHADOW, } from \"../../constants/colors\";\r\nimport { FONT_SIZES, SYSTEM_FONT } from \"../../constants/fonts\";\r\n// Retro animations\r\nconst blink = keyframes `\r\n\t0%, 50% { opacity: 1; }\r\n\t51%, 100% { opacity: 0; }\r\n`;\r\nconst scanLine = keyframes `\r\n\t0% { top: -2px; }\r\n\t100% { top: 100%; }\r\n`;\r\nconst crtFlicker = keyframes `\r\n\t0%, 98%, 100% { opacity: 1; }\r\n\t99% { opacity: 0.98; }\r\n`;\r\nexport const DropzoneWrapper = styled.label `\r\n\tposition: relative;\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\tjustify-content: ${(props) => (props.$hasFile ? 'flex-start' : 'center')};\r\n\tpadding: 16px;\r\n\twidth: 100%;\r\n\tmax-width: 100%;\r\n\tmin-height: 120px;\r\n\tbox-sizing: border-box;\r\n\tbackground: ${(props) => (props.$isDragOver ? WIN31_BUTTON_FACE : VGA_WHITE)};\r\n\tborder: 2px solid;\r\n\tborder-color: ${(props) => props.$isPressed\r\n    ? `${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT}`\r\n    : `${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}`};\r\n\tbox-shadow: ${(props) => props.$isPressed ? 'none' : 'inset 1px 1px 2px rgba(0, 0, 0, 0.1)'};\r\n\tcolor: ${VGA_BLACK};\r\n\tfont-family: ${SYSTEM_FONT};\r\n\tfont-size: ${FONT_SIZES.NORMAL};\r\n\tfont-weight: normal;\r\n\tcursor: ${(props) => (props.$isUploading ? 'wait' : 'pointer')};\r\n\ttransition: none;\r\n\toutline: none;\r\n\r\n\t/* Remove modern styling */\r\n\tborder-radius: 0;\r\n\r\n\t/* Responsive adjustments */\r\n\t@media (max-width: 768px) {\r\n\t\tpadding: 12px;\r\n\t\tmin-height: 100px;\r\n\t}\r\n\r\n\t@media (max-width: 480px) {\r\n\t\tpadding: 8px;\r\n\t\tmin-height: 80px;\r\n\t}\r\n\r\n\t&:focus {\r\n\t\toutline: 1px dotted ${VGA_BLACK};\r\n\t\toutline-offset: -3px;\r\n\t}\r\n\r\n\t&:hover:not(:disabled) {\r\n\t\tbackground: ${WIN31_BUTTON_FACE};\r\n\t}\r\n\r\n\t&:disabled {\r\n\t\tbackground: ${WIN31_BUTTON_FACE};\r\n\t\tcolor: ${WIN31_BUTTON_SHADOW};\r\n\t\tcursor: not-allowed;\r\n\t\tborder-color: ${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT}\r\n\t\t\t${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW};\r\n\t}\r\n\r\n\t/* Add CRT scan line effect */\r\n\t&::after {\r\n\t\tcontent: '';\r\n\t\tposition: absolute;\r\n\t\ttop: 0;\r\n\t\tleft: 0;\r\n\t\tright: 0;\r\n\t\theight: 2px;\r\n\t\tbackground: linear-gradient(\r\n\t\t\t90deg,\r\n\t\t\ttransparent,\r\n\t\t\t${CRT_GREEN}40,\r\n\t\t\ttransparent\r\n\t\t);\r\n\t\tanimation: ${scanLine} 2s linear infinite;\r\n\t\topacity: ${(props) => (props.$isUploading ? 1 : 0)};\r\n\t\ttransition: opacity 0.3s;\r\n\t}\r\n`;\r\nexport const HiddenInput = styled.input `\r\n\tdisplay: none;\r\n`;\r\n// --- Initial State Styles ---\r\nexport const UploadPrompt = styled.div `\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\talign-items: center;\r\n\tgap: 0.75rem;\r\n\ttext-align: center;\r\n\tposition: relative;\r\n\tz-index: 1;\r\n`;\r\nexport const UploadIconWrapper = styled.div `\r\n\tcolor: ${(props) => {\r\n    const baseColor = getColorScheme(props.$color || 'primary', props.theme);\r\n    return alterColorEnhanced(baseColor, -30);\r\n}};\r\n\tfilter: drop-shadow(2px 2px 0px rgba(0, 0, 0, 0.3));\r\n\r\n\tsvg {\r\n\t\tanimation: ${crtFlicker} 4s infinite;\r\n\t}\r\n`;\r\nexport const UploadText = styled.p `\r\n\tmargin: 0;\r\n\tfont-weight: bold;\r\n\tcolor: ${VGA_BLACK};\r\n\ttext-shadow: 1px 1px 0px rgba(255, 255, 255, 0.8);\r\n\tfont-size: 1.1rem;\r\n\tfont-family: ${SYSTEM_FONT};\r\n`;\r\nexport const SubText = styled.p `\r\n\tmargin: 0;\r\n\tfont-size: 0.85rem;\r\n\tcolor: ${WIN31_BUTTON_SHADOW};\r\n\ttext-shadow: 1px 1px 0px rgba(255, 255, 255, 0.8);\r\n\tfont-family: ${SYSTEM_FONT};\r\n`;\r\nexport const BlinkingCursor = styled.span `\r\n\tfont-size: 1.5rem;\r\n\tanimation: ${blink} 1s infinite;\r\n\tcolor: ${VGA_BLACK};\r\n`;\r\n// --- Progress Bar Styles ---\r\nexport const ProgressWrapper = styled.div `\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\talign-items: center;\r\n\tgap: 0.5rem;\r\n\tfont-family: ${SYSTEM_FONT};\r\n\tcolor: ${VGA_BLACK};\r\n`;\r\nexport const ProgressText = styled.div `\r\n\tfont-size: 0.9rem;\r\n\tfont-weight: bold;\r\n\tletter-spacing: 1px;\r\n\tfont-family: ${SYSTEM_FONT};\r\n`;\r\nexport const ProgressBar = styled.div `\r\n\tfont-family: ${SYSTEM_FONT};\r\n\tfont-size: 0.8rem;\r\n\tletter-spacing: 1px;\r\n\tcolor: ${VGA_BLACK};\r\n\ttext-shadow: 1px 1px 0px rgba(255, 255, 255, 0.5);\r\n`;\r\n// --- File Selected State Styles ---\r\nexport const FileSelectedWrapper = styled.div `\r\n\tdisplay: flex;\r\n\talign-items: flex-start;\r\n\tgap: 1rem;\r\n\twidth: 100%;\r\n\tmax-width: 100%;\r\n\tcolor: ${VGA_BLACK};\r\n\tposition: relative;\r\n\tz-index: 1;\r\n\tbox-sizing: border-box;\r\n\toverflow: hidden;\r\n\r\n\t@media (max-width: 768px) {\r\n\t\tgap: 0.75rem;\r\n\t}\r\n\r\n\t@media (max-width: 480px) {\r\n\t\tgap: 0.5rem;\r\n\t}\r\n\r\n\tsvg {\r\n\t\tflex-shrink: 0;\r\n\t\tfilter: drop-shadow(1px 1px 0px rgba(0, 0, 0, 0.3));\r\n\t}\r\n`;\r\nexport const FileInfo = styled.div `\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\tgap: 0.25rem;\r\n\tmin-width: 0;\r\n\tflex-grow: 1;\r\n\tflex-shrink: 1;\r\n\toverflow: hidden;\r\n`;\r\nexport const FileHeader = styled.div `\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\tgap: 0.5rem;\r\n\tmargin-bottom: 0.25rem;\r\n`;\r\nexport const FileType = styled.span `\r\n\tfont-size: 0.7rem;\r\n\tcolor: ${(props) => {\r\n    const baseColor = getColorScheme(props.$color || 'primary', props.theme);\r\n    return alterColorEnhanced(baseColor, -40);\r\n}};\r\n\tfont-weight: bold;\r\n\tbackground: ${VGA_WHITE};\r\n\tpadding: 2px 4px;\r\n\tborder: 1px solid ${WIN31_BUTTON_SHADOW};\r\n\tfont-family: ${SYSTEM_FONT};\r\n`;\r\nexport const FileStatus = styled.span `\r\n\tfont-size: 0.7rem;\r\n\tcolor: ${CRT_GREEN};\r\n\tfont-weight: bold;\r\n\tfont-family: ${SYSTEM_FONT};\r\n`;\r\nexport const FileName = styled.span `\r\n\twhite-space: nowrap;\r\n\toverflow: hidden;\r\n\ttext-overflow: ellipsis;\r\n\tfont-weight: bold;\r\n\tfont-size: 1rem;\r\n\ttext-shadow: 1px 1px 0px rgba(255, 255, 255, 0.8);\r\n\tfont-family: ${SYSTEM_FONT};\r\n`;\r\nexport const FileSize = styled.span `\r\n\tfont-size: 0.8rem;\r\n\tcolor: ${WIN31_BUTTON_SHADOW};\r\n\tfont-weight: bold;\r\n\ttext-shadow: 1px 1px 0px rgba(255, 255, 255, 0.8);\r\n\tfont-family: ${SYSTEM_FONT};\r\n`;\r\nexport const FileDate = styled.span `\r\n\tfont-size: 0.75rem;\r\n\tcolor: ${WIN31_BUTTON_SHADOW};\r\n\tfont-family: ${SYSTEM_FONT};\r\n`;\r\nexport const RemoveButton = styled.button `\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\tjustify-content: center;\r\n\twidth: 3rem;\r\n\theight: 2rem;\r\n\tflex-shrink: 0;\r\n\tmargin-left: auto;\r\n\tpadding: 0;\r\n\tborder: 2px solid;\r\n\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\tbackground: ${WIN31_BUTTON_FACE};\r\n\tcolor: ${VGA_BLACK};\r\n\tfont-size: 0.75rem;\r\n\tfont-weight: bold;\r\n\tfont-family: ${SYSTEM_FONT};\r\n\ttext-shadow: 1px 1px 0px rgba(255, 255, 255, 0.8);\r\n\tcursor: pointer;\r\n\ttransition: none;\r\n\ttext-transform: uppercase;\r\n\tletter-spacing: 1px;\r\n\r\n\t@media (max-width: 480px) {\r\n\t\twidth: 2.5rem;\r\n\t\theight: 1.8rem;\r\n\t\tfont-size: 0.7rem;\r\n\t}\r\n\r\n\t&:hover:not(:disabled) {\r\n\t\tbackground: ${(props) => getColorScheme('error', props.theme)};\r\n\t\tcolor: ${VGA_WHITE};\r\n\t\ttext-shadow: 1px 1px 0px rgba(0, 0, 0, 0.5);\r\n\t}\r\n\r\n\t&:active:not(:disabled) {\r\n\t\tborder-color: ${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT}\r\n\t\t\t${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW};\r\n\t}\r\n\r\n\t&:focus-visible {\r\n\t\toutline: 1px dotted ${VGA_BLACK};\r\n\t\toutline-offset: -3px;\r\n\t}\r\n`;\r\nexport const ButtonLabel = styled.span `\r\n\tposition: relative;\r\n\ttop: -1px;\r\n`;\r\nexport const ScanLine = styled.div `\r\n\tposition: absolute;\r\n\ttop: 0;\r\n\tleft: 0;\r\n\tright: 0;\r\n\tbottom: 0;\r\n\tbackground: linear-gradient(90deg, transparent, ${CRT_GREEN}40, transparent);\r\n\theight: 2px;\r\n\tanimation: ${scanLine} 2s linear infinite;\r\n\tpointer-events: none;\r\n\tz-index: 1;\r\n`;\r\n//# sourceMappingURL=DocumentUpload.styled.js.map"]} */",toString:G}),g=c("div","production"===process.env.NODE_ENV?{target:"ezy0we118"}:{target:"ezy0we118",label:"UploadPrompt"})("production"===process.env.NODE_ENV?{name:"18di661",styles:"display:flex;flex-direction:column;align-items:center;gap:0.75rem;text-align:center;position:relative;z-index:1"}:{name:"18di661",styles:"display:flex;flex-direction:column;align-items:center;gap:0.75rem;text-align:center;position:relative;z-index:1",map:"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["DocumentUpload.styled.tsx"],"names":[],"mappings":"AAiGuC","file":"DocumentUpload.styled.tsx","sourcesContent":["import { keyframes } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { alterColorEnhanced } from \"../../utils/alterColor\";\r\nimport getColorScheme from \"../../utils/getColorScheme\";\r\nimport { CRT_GREEN, VGA_BLACK, VGA_WHITE, WIN31_BUTTON_FACE, WIN31_BUTTON_HIGHLIGHT, WIN31_BUTTON_SHADOW, } from \"../../constants/colors\";\r\nimport { FONT_SIZES, SYSTEM_FONT } from \"../../constants/fonts\";\r\n// Retro animations\r\nconst blink = keyframes `\r\n\t0%, 50% { opacity: 1; }\r\n\t51%, 100% { opacity: 0; }\r\n`;\r\nconst scanLine = keyframes `\r\n\t0% { top: -2px; }\r\n\t100% { top: 100%; }\r\n`;\r\nconst crtFlicker = keyframes `\r\n\t0%, 98%, 100% { opacity: 1; }\r\n\t99% { opacity: 0.98; }\r\n`;\r\nexport const DropzoneWrapper = styled.label `\r\n\tposition: relative;\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\tjustify-content: ${(props) => (props.$hasFile ? 'flex-start' : 'center')};\r\n\tpadding: 16px;\r\n\twidth: 100%;\r\n\tmax-width: 100%;\r\n\tmin-height: 120px;\r\n\tbox-sizing: border-box;\r\n\tbackground: ${(props) => (props.$isDragOver ? WIN31_BUTTON_FACE : VGA_WHITE)};\r\n\tborder: 2px solid;\r\n\tborder-color: ${(props) => props.$isPressed\r\n    ? `${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT}`\r\n    : `${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}`};\r\n\tbox-shadow: ${(props) => props.$isPressed ? 'none' : 'inset 1px 1px 2px rgba(0, 0, 0, 0.1)'};\r\n\tcolor: ${VGA_BLACK};\r\n\tfont-family: ${SYSTEM_FONT};\r\n\tfont-size: ${FONT_SIZES.NORMAL};\r\n\tfont-weight: normal;\r\n\tcursor: ${(props) => (props.$isUploading ? 'wait' : 'pointer')};\r\n\ttransition: none;\r\n\toutline: none;\r\n\r\n\t/* Remove modern styling */\r\n\tborder-radius: 0;\r\n\r\n\t/* Responsive adjustments */\r\n\t@media (max-width: 768px) {\r\n\t\tpadding: 12px;\r\n\t\tmin-height: 100px;\r\n\t}\r\n\r\n\t@media (max-width: 480px) {\r\n\t\tpadding: 8px;\r\n\t\tmin-height: 80px;\r\n\t}\r\n\r\n\t&:focus {\r\n\t\toutline: 1px dotted ${VGA_BLACK};\r\n\t\toutline-offset: -3px;\r\n\t}\r\n\r\n\t&:hover:not(:disabled) {\r\n\t\tbackground: ${WIN31_BUTTON_FACE};\r\n\t}\r\n\r\n\t&:disabled {\r\n\t\tbackground: ${WIN31_BUTTON_FACE};\r\n\t\tcolor: ${WIN31_BUTTON_SHADOW};\r\n\t\tcursor: not-allowed;\r\n\t\tborder-color: ${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT}\r\n\t\t\t${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW};\r\n\t}\r\n\r\n\t/* Add CRT scan line effect */\r\n\t&::after {\r\n\t\tcontent: '';\r\n\t\tposition: absolute;\r\n\t\ttop: 0;\r\n\t\tleft: 0;\r\n\t\tright: 0;\r\n\t\theight: 2px;\r\n\t\tbackground: linear-gradient(\r\n\t\t\t90deg,\r\n\t\t\ttransparent,\r\n\t\t\t${CRT_GREEN}40,\r\n\t\t\ttransparent\r\n\t\t);\r\n\t\tanimation: ${scanLine} 2s linear infinite;\r\n\t\topacity: ${(props) => (props.$isUploading ? 1 : 0)};\r\n\t\ttransition: opacity 0.3s;\r\n\t}\r\n`;\r\nexport const HiddenInput = styled.input `\r\n\tdisplay: none;\r\n`;\r\n// --- Initial State Styles ---\r\nexport const UploadPrompt = styled.div `\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\talign-items: center;\r\n\tgap: 0.75rem;\r\n\ttext-align: center;\r\n\tposition: relative;\r\n\tz-index: 1;\r\n`;\r\nexport const UploadIconWrapper = styled.div `\r\n\tcolor: ${(props) => {\r\n    const baseColor = getColorScheme(props.$color || 'primary', props.theme);\r\n    return alterColorEnhanced(baseColor, -30);\r\n}};\r\n\tfilter: drop-shadow(2px 2px 0px rgba(0, 0, 0, 0.3));\r\n\r\n\tsvg {\r\n\t\tanimation: ${crtFlicker} 4s infinite;\r\n\t}\r\n`;\r\nexport const UploadText = styled.p `\r\n\tmargin: 0;\r\n\tfont-weight: bold;\r\n\tcolor: ${VGA_BLACK};\r\n\ttext-shadow: 1px 1px 0px rgba(255, 255, 255, 0.8);\r\n\tfont-size: 1.1rem;\r\n\tfont-family: ${SYSTEM_FONT};\r\n`;\r\nexport const SubText = styled.p `\r\n\tmargin: 0;\r\n\tfont-size: 0.85rem;\r\n\tcolor: ${WIN31_BUTTON_SHADOW};\r\n\ttext-shadow: 1px 1px 0px rgba(255, 255, 255, 0.8);\r\n\tfont-family: ${SYSTEM_FONT};\r\n`;\r\nexport const BlinkingCursor = styled.span `\r\n\tfont-size: 1.5rem;\r\n\tanimation: ${blink} 1s infinite;\r\n\tcolor: ${VGA_BLACK};\r\n`;\r\n// --- Progress Bar Styles ---\r\nexport const ProgressWrapper = styled.div `\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\talign-items: center;\r\n\tgap: 0.5rem;\r\n\tfont-family: ${SYSTEM_FONT};\r\n\tcolor: ${VGA_BLACK};\r\n`;\r\nexport const ProgressText = styled.div `\r\n\tfont-size: 0.9rem;\r\n\tfont-weight: bold;\r\n\tletter-spacing: 1px;\r\n\tfont-family: ${SYSTEM_FONT};\r\n`;\r\nexport const ProgressBar = styled.div `\r\n\tfont-family: ${SYSTEM_FONT};\r\n\tfont-size: 0.8rem;\r\n\tletter-spacing: 1px;\r\n\tcolor: ${VGA_BLACK};\r\n\ttext-shadow: 1px 1px 0px rgba(255, 255, 255, 0.5);\r\n`;\r\n// --- File Selected State Styles ---\r\nexport const FileSelectedWrapper = styled.div `\r\n\tdisplay: flex;\r\n\talign-items: flex-start;\r\n\tgap: 1rem;\r\n\twidth: 100%;\r\n\tmax-width: 100%;\r\n\tcolor: ${VGA_BLACK};\r\n\tposition: relative;\r\n\tz-index: 1;\r\n\tbox-sizing: border-box;\r\n\toverflow: hidden;\r\n\r\n\t@media (max-width: 768px) {\r\n\t\tgap: 0.75rem;\r\n\t}\r\n\r\n\t@media (max-width: 480px) {\r\n\t\tgap: 0.5rem;\r\n\t}\r\n\r\n\tsvg {\r\n\t\tflex-shrink: 0;\r\n\t\tfilter: drop-shadow(1px 1px 0px rgba(0, 0, 0, 0.3));\r\n\t}\r\n`;\r\nexport const FileInfo = styled.div `\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\tgap: 0.25rem;\r\n\tmin-width: 0;\r\n\tflex-grow: 1;\r\n\tflex-shrink: 1;\r\n\toverflow: hidden;\r\n`;\r\nexport const FileHeader = styled.div `\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\tgap: 0.5rem;\r\n\tmargin-bottom: 0.25rem;\r\n`;\r\nexport const FileType = styled.span `\r\n\tfont-size: 0.7rem;\r\n\tcolor: ${(props) => {\r\n    const baseColor = getColorScheme(props.$color || 'primary', props.theme);\r\n    return alterColorEnhanced(baseColor, -40);\r\n}};\r\n\tfont-weight: bold;\r\n\tbackground: ${VGA_WHITE};\r\n\tpadding: 2px 4px;\r\n\tborder: 1px solid ${WIN31_BUTTON_SHADOW};\r\n\tfont-family: ${SYSTEM_FONT};\r\n`;\r\nexport const FileStatus = styled.span `\r\n\tfont-size: 0.7rem;\r\n\tcolor: ${CRT_GREEN};\r\n\tfont-weight: bold;\r\n\tfont-family: ${SYSTEM_FONT};\r\n`;\r\nexport const FileName = styled.span `\r\n\twhite-space: nowrap;\r\n\toverflow: hidden;\r\n\ttext-overflow: ellipsis;\r\n\tfont-weight: bold;\r\n\tfont-size: 1rem;\r\n\ttext-shadow: 1px 1px 0px rgba(255, 255, 255, 0.8);\r\n\tfont-family: ${SYSTEM_FONT};\r\n`;\r\nexport const FileSize = styled.span `\r\n\tfont-size: 0.8rem;\r\n\tcolor: ${WIN31_BUTTON_SHADOW};\r\n\tfont-weight: bold;\r\n\ttext-shadow: 1px 1px 0px rgba(255, 255, 255, 0.8);\r\n\tfont-family: ${SYSTEM_FONT};\r\n`;\r\nexport const FileDate = styled.span `\r\n\tfont-size: 0.75rem;\r\n\tcolor: ${WIN31_BUTTON_SHADOW};\r\n\tfont-family: ${SYSTEM_FONT};\r\n`;\r\nexport const RemoveButton = styled.button `\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\tjustify-content: center;\r\n\twidth: 3rem;\r\n\theight: 2rem;\r\n\tflex-shrink: 0;\r\n\tmargin-left: auto;\r\n\tpadding: 0;\r\n\tborder: 2px solid;\r\n\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\tbackground: ${WIN31_BUTTON_FACE};\r\n\tcolor: ${VGA_BLACK};\r\n\tfont-size: 0.75rem;\r\n\tfont-weight: bold;\r\n\tfont-family: ${SYSTEM_FONT};\r\n\ttext-shadow: 1px 1px 0px rgba(255, 255, 255, 0.8);\r\n\tcursor: pointer;\r\n\ttransition: none;\r\n\ttext-transform: uppercase;\r\n\tletter-spacing: 1px;\r\n\r\n\t@media (max-width: 480px) {\r\n\t\twidth: 2.5rem;\r\n\t\theight: 1.8rem;\r\n\t\tfont-size: 0.7rem;\r\n\t}\r\n\r\n\t&:hover:not(:disabled) {\r\n\t\tbackground: ${(props) => getColorScheme('error', props.theme)};\r\n\t\tcolor: ${VGA_WHITE};\r\n\t\ttext-shadow: 1px 1px 0px rgba(0, 0, 0, 0.5);\r\n\t}\r\n\r\n\t&:active:not(:disabled) {\r\n\t\tborder-color: ${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT}\r\n\t\t\t${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW};\r\n\t}\r\n\r\n\t&:focus-visible {\r\n\t\toutline: 1px dotted ${VGA_BLACK};\r\n\t\toutline-offset: -3px;\r\n\t}\r\n`;\r\nexport const ButtonLabel = styled.span `\r\n\tposition: relative;\r\n\ttop: -1px;\r\n`;\r\nexport const ScanLine = styled.div `\r\n\tposition: absolute;\r\n\ttop: 0;\r\n\tleft: 0;\r\n\tright: 0;\r\n\tbottom: 0;\r\n\tbackground: linear-gradient(90deg, transparent, ${CRT_GREEN}40, transparent);\r\n\theight: 2px;\r\n\tanimation: ${scanLine} 2s linear infinite;\r\n\tpointer-events: none;\r\n\tz-index: 1;\r\n`;\r\n//# sourceMappingURL=DocumentUpload.styled.js.map"]} */",toString:G}),I=c("div","production"===process.env.NODE_ENV?{target:"ezy0we117"}:{target:"ezy0we117",label:"UploadIconWrapper"})("color:",(c=>{const X=x.default(c.$color||"primary",c.theme);return l.alterColorEnhanced(X,-30)}),";filter:drop-shadow(2px 2px 0px rgba(0, 0, 0, 0.3));svg{animation:",V," 4s infinite;}"+("production"===process.env.NODE_ENV?"":"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkRvY3VtZW50VXBsb2FkLnN0eWxlZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEc0QyIsImZpbGUiOiJEb2N1bWVudFVwbG9hZC5zdHlsZWQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsga2V5ZnJhbWVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmltcG9ydCB7IGFsdGVyQ29sb3JFbmhhbmNlZCB9IGZyb20gXCIuLi8uLi91dGlscy9hbHRlckNvbG9yXCI7XHJcbmltcG9ydCBnZXRDb2xvclNjaGVtZSBmcm9tIFwiLi4vLi4vdXRpbHMvZ2V0Q29sb3JTY2hlbWVcIjtcclxuaW1wb3J0IHsgQ1JUX0dSRUVOLCBWR0FfQkxBQ0ssIFZHQV9XSElURSwgV0lOMzFfQlVUVE9OX0ZBQ0UsIFdJTjMxX0JVVFRPTl9ISUdITElHSFQsIFdJTjMxX0JVVFRPTl9TSEFET1csIH0gZnJvbSBcIi4uLy4uL2NvbnN0YW50cy9jb2xvcnNcIjtcclxuaW1wb3J0IHsgRk9OVF9TSVpFUywgU1lTVEVNX0ZPTlQgfSBmcm9tIFwiLi4vLi4vY29uc3RhbnRzL2ZvbnRzXCI7XHJcbi8vIFJldHJvIGFuaW1hdGlvbnNcclxuY29uc3QgYmxpbmsgPSBrZXlmcmFtZXMgYFxyXG5cdDAlLCA1MCUgeyBvcGFjaXR5OiAxOyB9XHJcblx0NTElLCAxMDAlIHsgb3BhY2l0eTogMDsgfVxyXG5gO1xyXG5jb25zdCBzY2FuTGluZSA9IGtleWZyYW1lcyBgXHJcblx0MCUgeyB0b3A6IC0ycHg7IH1cclxuXHQxMDAlIHsgdG9wOiAxMDAlOyB9XHJcbmA7XHJcbmNvbnN0IGNydEZsaWNrZXIgPSBrZXlmcmFtZXMgYFxyXG5cdDAlLCA5OCUsIDEwMCUgeyBvcGFjaXR5OiAxOyB9XHJcblx0OTklIHsgb3BhY2l0eTogMC45ODsgfVxyXG5gO1xyXG5leHBvcnQgY29uc3QgRHJvcHpvbmVXcmFwcGVyID0gc3R5bGVkLmxhYmVsIGBcclxuXHRwb3NpdGlvbjogcmVsYXRpdmU7XHJcblx0ZGlzcGxheTogZmxleDtcclxuXHRhbGlnbi1pdGVtczogY2VudGVyO1xyXG5cdGp1c3RpZnktY29udGVudDogJHsocHJvcHMpID0+IChwcm9wcy4kaGFzRmlsZSA/ICdmbGV4LXN0YXJ0JyA6ICdjZW50ZXInKX07XHJcblx0cGFkZGluZzogMTZweDtcclxuXHR3aWR0aDogMTAwJTtcclxuXHRtYXgtd2lkdGg6IDEwMCU7XHJcblx0bWluLWhlaWdodDogMTIwcHg7XHJcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcclxuXHRiYWNrZ3JvdW5kOiAkeyhwcm9wcykgPT4gKHByb3BzLiRpc0RyYWdPdmVyID8gV0lOMzFfQlVUVE9OX0ZBQ0UgOiBWR0FfV0hJVEUpfTtcclxuXHRib3JkZXI6IDJweCBzb2xpZDtcclxuXHRib3JkZXItY29sb3I6ICR7KHByb3BzKSA9PiBwcm9wcy4kaXNQcmVzc2VkXHJcbiAgICA/IGAke1dJTjMxX0JVVFRPTl9ISUdITElHSFR9ICR7V0lOMzFfQlVUVE9OX1NIQURPV30gJHtXSU4zMV9CVVRUT05fU0hBRE9XfSAke1dJTjMxX0JVVFRPTl9ISUdITElHSFR9YFxyXG4gICAgOiBgJHtXSU4zMV9CVVRUT05fU0hBRE9XfSAke1dJTjMxX0JVVFRPTl9ISUdITElHSFR9ICR7V0lOMzFfQlVUVE9OX0hJR0hMSUdIVH0gJHtXSU4zMV9CVVRUT05fU0hBRE9XfWB9O1xyXG5cdGJveC1zaGFkb3c6ICR7KHByb3BzKSA9PiBwcm9wcy4kaXNQcmVzc2VkID8gJ25vbmUnIDogJ2luc2V0IDFweCAxcHggMnB4IHJnYmEoMCwgMCwgMCwgMC4xKSd9O1xyXG5cdGNvbG9yOiAke1ZHQV9CTEFDS307XHJcblx0Zm9udC1mYW1pbHk6ICR7U1lTVEVNX0ZPTlR9O1xyXG5cdGZvbnQtc2l6ZTogJHtGT05UX1NJWkVTLk5PUk1BTH07XHJcblx0Zm9udC13ZWlnaHQ6IG5vcm1hbDtcclxuXHRjdXJzb3I6ICR7KHByb3BzKSA9PiAocHJvcHMuJGlzVXBsb2FkaW5nID8gJ3dhaXQnIDogJ3BvaW50ZXInKX07XHJcblx0dHJhbnNpdGlvbjogbm9uZTtcclxuXHRvdXRsaW5lOiBub25lO1xyXG5cclxuXHQvKiBSZW1vdmUgbW9kZXJuIHN0eWxpbmcgKi9cclxuXHRib3JkZXItcmFkaXVzOiAwO1xyXG5cclxuXHQvKiBSZXNwb25zaXZlIGFkanVzdG1lbnRzICovXHJcblx0QG1lZGlhIChtYXgtd2lkdGg6IDc2OHB4KSB7XHJcblx0XHRwYWRkaW5nOiAxMnB4O1xyXG5cdFx0bWluLWhlaWdodDogMTAwcHg7XHJcblx0fVxyXG5cclxuXHRAbWVkaWEgKG1heC13aWR0aDogNDgwcHgpIHtcclxuXHRcdHBhZGRpbmc6IDhweDtcclxuXHRcdG1pbi1oZWlnaHQ6IDgwcHg7XHJcblx0fVxyXG5cclxuXHQmOmZvY3VzIHtcclxuXHRcdG91dGxpbmU6IDFweCBkb3R0ZWQgJHtWR0FfQkxBQ0t9O1xyXG5cdFx0b3V0bGluZS1vZmZzZXQ6IC0zcHg7XHJcblx0fVxyXG5cclxuXHQmOmhvdmVyOm5vdCg6ZGlzYWJsZWQpIHtcclxuXHRcdGJhY2tncm91bmQ6ICR7V0lOMzFfQlVUVE9OX0ZBQ0V9O1xyXG5cdH1cclxuXHJcblx0JjpkaXNhYmxlZCB7XHJcblx0XHRiYWNrZ3JvdW5kOiAke1dJTjMxX0JVVFRPTl9GQUNFfTtcclxuXHRcdGNvbG9yOiAke1dJTjMxX0JVVFRPTl9TSEFET1d9O1xyXG5cdFx0Y3Vyc29yOiBub3QtYWxsb3dlZDtcclxuXHRcdGJvcmRlci1jb2xvcjogJHtXSU4zMV9CVVRUT05fU0hBRE9XfSAke1dJTjMxX0JVVFRPTl9ISUdITElHSFR9XHJcblx0XHRcdCR7V0lOMzFfQlVUVE9OX0hJR0hMSUdIVH0gJHtXSU4zMV9CVVRUT05fU0hBRE9XfTtcclxuXHR9XHJcblxyXG5cdC8qIEFkZCBDUlQgc2NhbiBsaW5lIGVmZmVjdCAqL1xyXG5cdCY6OmFmdGVyIHtcclxuXHRcdGNvbnRlbnQ6ICcnO1xyXG5cdFx0cG9zaXRpb246IGFic29sdXRlO1xyXG5cdFx0dG9wOiAwO1xyXG5cdFx0bGVmdDogMDtcclxuXHRcdHJpZ2h0OiAwO1xyXG5cdFx0aGVpZ2h0OiAycHg7XHJcblx0XHRiYWNrZ3JvdW5kOiBsaW5lYXItZ3JhZGllbnQoXHJcblx0XHRcdDkwZGVnLFxyXG5cdFx0XHR0cmFuc3BhcmVudCxcclxuXHRcdFx0JHtDUlRfR1JFRU59NDAsXHJcblx0XHRcdHRyYW5zcGFyZW50XHJcblx0XHQpO1xyXG5cdFx0YW5pbWF0aW9uOiAke3NjYW5MaW5lfSAycyBsaW5lYXIgaW5maW5pdGU7XHJcblx0XHRvcGFjaXR5OiAkeyhwcm9wcykgPT4gKHByb3BzLiRpc1VwbG9hZGluZyA/IDEgOiAwKX07XHJcblx0XHR0cmFuc2l0aW9uOiBvcGFjaXR5IDAuM3M7XHJcblx0fVxyXG5gO1xyXG5leHBvcnQgY29uc3QgSGlkZGVuSW5wdXQgPSBzdHlsZWQuaW5wdXQgYFxyXG5cdGRpc3BsYXk6IG5vbmU7XHJcbmA7XHJcbi8vIC0tLSBJbml0aWFsIFN0YXRlIFN0eWxlcyAtLS1cclxuZXhwb3J0IGNvbnN0IFVwbG9hZFByb21wdCA9IHN0eWxlZC5kaXYgYFxyXG5cdGRpc3BsYXk6IGZsZXg7XHJcblx0ZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcclxuXHRhbGlnbi1pdGVtczogY2VudGVyO1xyXG5cdGdhcDogMC43NXJlbTtcclxuXHR0ZXh0LWFsaWduOiBjZW50ZXI7XHJcblx0cG9zaXRpb246IHJlbGF0aXZlO1xyXG5cdHotaW5kZXg6IDE7XHJcbmA7XHJcbmV4cG9ydCBjb25zdCBVcGxvYWRJY29uV3JhcHBlciA9IHN0eWxlZC5kaXYgYFxyXG5cdGNvbG9yOiAkeyhwcm9wcykgPT4ge1xyXG4gICAgY29uc3QgYmFzZUNvbG9yID0gZ2V0Q29sb3JTY2hlbWUocHJvcHMuJGNvbG9yIHx8ICdwcmltYXJ5JywgcHJvcHMudGhlbWUpO1xyXG4gICAgcmV0dXJuIGFsdGVyQ29sb3JFbmhhbmNlZChiYXNlQ29sb3IsIC0zMCk7XHJcbn19O1xyXG5cdGZpbHRlcjogZHJvcC1zaGFkb3coMnB4IDJweCAwcHggcmdiYSgwLCAwLCAwLCAwLjMpKTtcclxuXHJcblx0c3ZnIHtcclxuXHRcdGFuaW1hdGlvbjogJHtjcnRGbGlja2VyfSA0cyBpbmZpbml0ZTtcclxuXHR9XHJcbmA7XHJcbmV4cG9ydCBjb25zdCBVcGxvYWRUZXh0ID0gc3R5bGVkLnAgYFxyXG5cdG1hcmdpbjogMDtcclxuXHRmb250LXdlaWdodDogYm9sZDtcclxuXHRjb2xvcjogJHtWR0FfQkxBQ0t9O1xyXG5cdHRleHQtc2hhZG93OiAxcHggMXB4IDBweCByZ2JhKDI1NSwgMjU1LCAyNTUsIDAuOCk7XHJcblx0Zm9udC1zaXplOiAxLjFyZW07XHJcblx0Zm9udC1mYW1pbHk6ICR7U1lTVEVNX0ZPTlR9O1xyXG5gO1xyXG5leHBvcnQgY29uc3QgU3ViVGV4dCA9IHN0eWxlZC5wIGBcclxuXHRtYXJnaW46IDA7XHJcblx0Zm9udC1zaXplOiAwLjg1cmVtO1xyXG5cdGNvbG9yOiAke1dJTjMxX0JVVFRPTl9TSEFET1d9O1xyXG5cdHRleHQtc2hhZG93OiAxcHggMXB4IDBweCByZ2JhKDI1NSwgMjU1LCAyNTUsIDAuOCk7XHJcblx0Zm9udC1mYW1pbHk6ICR7U1lTVEVNX0ZPTlR9O1xyXG5gO1xyXG5leHBvcnQgY29uc3QgQmxpbmtpbmdDdXJzb3IgPSBzdHlsZWQuc3BhbiBgXHJcblx0Zm9udC1zaXplOiAxLjVyZW07XHJcblx0YW5pbWF0aW9uOiAke2JsaW5rfSAxcyBpbmZpbml0ZTtcclxuXHRjb2xvcjogJHtWR0FfQkxBQ0t9O1xyXG5gO1xyXG4vLyAtLS0gUHJvZ3Jlc3MgQmFyIFN0eWxlcyAtLS1cclxuZXhwb3J0IGNvbnN0IFByb2dyZXNzV3JhcHBlciA9IHN0eWxlZC5kaXYgYFxyXG5cdGRpc3BsYXk6IGZsZXg7XHJcblx0ZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcclxuXHRhbGlnbi1pdGVtczogY2VudGVyO1xyXG5cdGdhcDogMC41cmVtO1xyXG5cdGZvbnQtZmFtaWx5OiAke1NZU1RFTV9GT05UfTtcclxuXHRjb2xvcjogJHtWR0FfQkxBQ0t9O1xyXG5gO1xyXG5leHBvcnQgY29uc3QgUHJvZ3Jlc3NUZXh0ID0gc3R5bGVkLmRpdiBgXHJcblx0Zm9udC1zaXplOiAwLjlyZW07XHJcblx0Zm9udC13ZWlnaHQ6IGJvbGQ7XHJcblx0bGV0dGVyLXNwYWNpbmc6IDFweDtcclxuXHRmb250LWZhbWlseTogJHtTWVNURU1fRk9OVH07XHJcbmA7XHJcbmV4cG9ydCBjb25zdCBQcm9ncmVzc0JhciA9IHN0eWxlZC5kaXYgYFxyXG5cdGZvbnQtZmFtaWx5OiAke1NZU1RFTV9GT05UfTtcclxuXHRmb250LXNpemU6IDAuOHJlbTtcclxuXHRsZXR0ZXItc3BhY2luZzogMXB4O1xyXG5cdGNvbG9yOiAke1ZHQV9CTEFDS307XHJcblx0dGV4dC1zaGFkb3c6IDFweCAxcHggMHB4IHJnYmEoMjU1LCAyNTUsIDI1NSwgMC41KTtcclxuYDtcclxuLy8gLS0tIEZpbGUgU2VsZWN0ZWQgU3RhdGUgU3R5bGVzIC0tLVxyXG5leHBvcnQgY29uc3QgRmlsZVNlbGVjdGVkV3JhcHBlciA9IHN0eWxlZC5kaXYgYFxyXG5cdGRpc3BsYXk6IGZsZXg7XHJcblx0YWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XHJcblx0Z2FwOiAxcmVtO1xyXG5cdHdpZHRoOiAxMDAlO1xyXG5cdG1heC13aWR0aDogMTAwJTtcclxuXHRjb2xvcjogJHtWR0FfQkxBQ0t9O1xyXG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcclxuXHR6LWluZGV4OiAxO1xyXG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XHJcblx0b3ZlcmZsb3c6IGhpZGRlbjtcclxuXHJcblx0QG1lZGlhIChtYXgtd2lkdGg6IDc2OHB4KSB7XHJcblx0XHRnYXA6IDAuNzVyZW07XHJcblx0fVxyXG5cclxuXHRAbWVkaWEgKG1heC13aWR0aDogNDgwcHgpIHtcclxuXHRcdGdhcDogMC41cmVtO1xyXG5cdH1cclxuXHJcblx0c3ZnIHtcclxuXHRcdGZsZXgtc2hyaW5rOiAwO1xyXG5cdFx0ZmlsdGVyOiBkcm9wLXNoYWRvdygxcHggMXB4IDBweCByZ2JhKDAsIDAsIDAsIDAuMykpO1xyXG5cdH1cclxuYDtcclxuZXhwb3J0IGNvbnN0IEZpbGVJbmZvID0gc3R5bGVkLmRpdiBgXHJcblx0ZGlzcGxheTogZmxleDtcclxuXHRmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xyXG5cdGdhcDogMC4yNXJlbTtcclxuXHRtaW4td2lkdGg6IDA7XHJcblx0ZmxleC1ncm93OiAxO1xyXG5cdGZsZXgtc2hyaW5rOiAxO1xyXG5cdG92ZXJmbG93OiBoaWRkZW47XHJcbmA7XHJcbmV4cG9ydCBjb25zdCBGaWxlSGVhZGVyID0gc3R5bGVkLmRpdiBgXHJcblx0ZGlzcGxheTogZmxleDtcclxuXHRhbGlnbi1pdGVtczogY2VudGVyO1xyXG5cdGdhcDogMC41cmVtO1xyXG5cdG1hcmdpbi1ib3R0b206IDAuMjVyZW07XHJcbmA7XHJcbmV4cG9ydCBjb25zdCBGaWxlVHlwZSA9IHN0eWxlZC5zcGFuIGBcclxuXHRmb250LXNpemU6IDAuN3JlbTtcclxuXHRjb2xvcjogJHsocHJvcHMpID0+IHtcclxuICAgIGNvbnN0IGJhc2VDb2xvciA9IGdldENvbG9yU2NoZW1lKHByb3BzLiRjb2xvciB8fCAncHJpbWFyeScsIHByb3BzLnRoZW1lKTtcclxuICAgIHJldHVybiBhbHRlckNvbG9yRW5oYW5jZWQoYmFzZUNvbG9yLCAtNDApO1xyXG59fTtcclxuXHRmb250LXdlaWdodDogYm9sZDtcclxuXHRiYWNrZ3JvdW5kOiAke1ZHQV9XSElURX07XHJcblx0cGFkZGluZzogMnB4IDRweDtcclxuXHRib3JkZXI6IDFweCBzb2xpZCAke1dJTjMxX0JVVFRPTl9TSEFET1d9O1xyXG5cdGZvbnQtZmFtaWx5OiAke1NZU1RFTV9GT05UfTtcclxuYDtcclxuZXhwb3J0IGNvbnN0IEZpbGVTdGF0dXMgPSBzdHlsZWQuc3BhbiBgXHJcblx0Zm9udC1zaXplOiAwLjdyZW07XHJcblx0Y29sb3I6ICR7Q1JUX0dSRUVOfTtcclxuXHRmb250LXdlaWdodDogYm9sZDtcclxuXHRmb250LWZhbWlseTogJHtTWVNURU1fRk9OVH07XHJcbmA7XHJcbmV4cG9ydCBjb25zdCBGaWxlTmFtZSA9IHN0eWxlZC5zcGFuIGBcclxuXHR3aGl0ZS1zcGFjZTogbm93cmFwO1xyXG5cdG92ZXJmbG93OiBoaWRkZW47XHJcblx0dGV4dC1vdmVyZmxvdzogZWxsaXBzaXM7XHJcblx0Zm9udC13ZWlnaHQ6IGJvbGQ7XHJcblx0Zm9udC1zaXplOiAxcmVtO1xyXG5cdHRleHQtc2hhZG93OiAxcHggMXB4IDBweCByZ2JhKDI1NSwgMjU1LCAyNTUsIDAuOCk7XHJcblx0Zm9udC1mYW1pbHk6ICR7U1lTVEVNX0ZPTlR9O1xyXG5gO1xyXG5leHBvcnQgY29uc3QgRmlsZVNpemUgPSBzdHlsZWQuc3BhbiBgXHJcblx0Zm9udC1zaXplOiAwLjhyZW07XHJcblx0Y29sb3I6ICR7V0lOMzFfQlVUVE9OX1NIQURPV307XHJcblx0Zm9udC13ZWlnaHQ6IGJvbGQ7XHJcblx0dGV4dC1zaGFkb3c6IDFweCAxcHggMHB4IHJnYmEoMjU1LCAyNTUsIDI1NSwgMC44KTtcclxuXHRmb250LWZhbWlseTogJHtTWVNURU1fRk9OVH07XHJcbmA7XHJcbmV4cG9ydCBjb25zdCBGaWxlRGF0ZSA9IHN0eWxlZC5zcGFuIGBcclxuXHRmb250LXNpemU6IDAuNzVyZW07XHJcblx0Y29sb3I6ICR7V0lOMzFfQlVUVE9OX1NIQURPV307XHJcblx0Zm9udC1mYW1pbHk6ICR7U1lTVEVNX0ZPTlR9O1xyXG5gO1xyXG5leHBvcnQgY29uc3QgUmVtb3ZlQnV0dG9uID0gc3R5bGVkLmJ1dHRvbiBgXHJcblx0ZGlzcGxheTogZmxleDtcclxuXHRhbGlnbi1pdGVtczogY2VudGVyO1xyXG5cdGp1c3RpZnktY29udGVudDogY2VudGVyO1xyXG5cdHdpZHRoOiAzcmVtO1xyXG5cdGhlaWdodDogMnJlbTtcclxuXHRmbGV4LXNocmluazogMDtcclxuXHRtYXJnaW4tbGVmdDogYXV0bztcclxuXHRwYWRkaW5nOiAwO1xyXG5cdGJvcmRlcjogMnB4IHNvbGlkO1xyXG5cdGJvcmRlci1jb2xvcjogJHtXSU4zMV9CVVRUT05fSElHSExJR0hUfSAke1dJTjMxX0JVVFRPTl9TSEFET1d9XHJcblx0XHQke1dJTjMxX0JVVFRPTl9TSEFET1d9ICR7V0lOMzFfQlVUVE9OX0hJR0hMSUdIVH07XHJcblx0YmFja2dyb3VuZDogJHtXSU4zMV9CVVRUT05fRkFDRX07XHJcblx0Y29sb3I6ICR7VkdBX0JMQUNLfTtcclxuXHRmb250LXNpemU6IDAuNzVyZW07XHJcblx0Zm9udC13ZWlnaHQ6IGJvbGQ7XHJcblx0Zm9udC1mYW1pbHk6ICR7U1lTVEVNX0ZPTlR9O1xyXG5cdHRleHQtc2hhZG93OiAxcHggMXB4IDBweCByZ2JhKDI1NSwgMjU1LCAyNTUsIDAuOCk7XHJcblx0Y3Vyc29yOiBwb2ludGVyO1xyXG5cdHRyYW5zaXRpb246IG5vbmU7XHJcblx0dGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcclxuXHRsZXR0ZXItc3BhY2luZzogMXB4O1xyXG5cclxuXHRAbWVkaWEgKG1heC13aWR0aDogNDgwcHgpIHtcclxuXHRcdHdpZHRoOiAyLjVyZW07XHJcblx0XHRoZWlnaHQ6IDEuOHJlbTtcclxuXHRcdGZvbnQtc2l6ZTogMC43cmVtO1xyXG5cdH1cclxuXHJcblx0Jjpob3Zlcjpub3QoOmRpc2FibGVkKSB7XHJcblx0XHRiYWNrZ3JvdW5kOiAkeyhwcm9wcykgPT4gZ2V0Q29sb3JTY2hlbWUoJ2Vycm9yJywgcHJvcHMudGhlbWUpfTtcclxuXHRcdGNvbG9yOiAke1ZHQV9XSElURX07XHJcblx0XHR0ZXh0LXNoYWRvdzogMXB4IDFweCAwcHggcmdiYSgwLCAwLCAwLCAwLjUpO1xyXG5cdH1cclxuXHJcblx0JjphY3RpdmU6bm90KDpkaXNhYmxlZCkge1xyXG5cdFx0Ym9yZGVyLWNvbG9yOiAke1dJTjMxX0JVVFRPTl9TSEFET1d9ICR7V0lOMzFfQlVUVE9OX0hJR0hMSUdIVH1cclxuXHRcdFx0JHtXSU4zMV9CVVRUT05fSElHSExJR0hUfSAke1dJTjMxX0JVVFRPTl9TSEFET1d9O1xyXG5cdH1cclxuXHJcblx0Jjpmb2N1cy12aXNpYmxlIHtcclxuXHRcdG91dGxpbmU6IDFweCBkb3R0ZWQgJHtWR0FfQkxBQ0t9O1xyXG5cdFx0b3V0bGluZS1vZmZzZXQ6IC0zcHg7XHJcblx0fVxyXG5gO1xyXG5leHBvcnQgY29uc3QgQnV0dG9uTGFiZWwgPSBzdHlsZWQuc3BhbiBgXHJcblx0cG9zaXRpb246IHJlbGF0aXZlO1xyXG5cdHRvcDogLTFweDtcclxuYDtcclxuZXhwb3J0IGNvbnN0IFNjYW5MaW5lID0gc3R5bGVkLmRpdiBgXHJcblx0cG9zaXRpb246IGFic29sdXRlO1xyXG5cdHRvcDogMDtcclxuXHRsZWZ0OiAwO1xyXG5cdHJpZ2h0OiAwO1xyXG5cdGJvdHRvbTogMDtcclxuXHRiYWNrZ3JvdW5kOiBsaW5lYXItZ3JhZGllbnQoOTBkZWcsIHRyYW5zcGFyZW50LCAke0NSVF9HUkVFTn00MCw